##// END OF EJS Templates
Merge from upstream
Fernando Perez -
r1156:75a534f3 merge
parent child Browse files
Show More
@@ -1,359 +1,365 b''
1 #!/usr/bin/env python
1 #!/usr/bin/env python
2
2
3 """ Implementations for various useful completers
3 """ Implementations for various useful completers
4
4
5 See Extensions/ipy_stock_completers.py on examples of how to enable a completer,
5 See Extensions/ipy_stock_completers.py on examples of how to enable a completer,
6 but the basic idea is to do:
6 but the basic idea is to do:
7
7
8 ip.set_hook('complete_command', svn_completer, str_key = 'svn')
8 ip.set_hook('complete_command', svn_completer, str_key = 'svn')
9
9
10 """
10 """
11 import IPython.ipapi
11 import IPython.ipapi
12 import glob,os,shlex,sys
12 import glob,os,shlex,sys
13 import inspect
13 import inspect
14 from time import time
14 from time import time
15 from zipimport import zipimporter
15 ip = IPython.ipapi.get()
16 ip = IPython.ipapi.get()
16
17
17 try:
18 try:
18 set
19 set
19 except:
20 except:
20 from sets import Set as set
21 from sets import Set as set
21
22
22 TIMEOUT_STORAGE = 3 #Time in seconds after which the rootmodules will be stored
23 TIMEOUT_STORAGE = 3 #Time in seconds after which the rootmodules will be stored
23 TIMEOUT_GIVEUP = 20 #Time in seconds after which we give up
24 TIMEOUT_GIVEUP = 20 #Time in seconds after which we give up
24
25
25 def quick_completer(cmd, completions):
26 def quick_completer(cmd, completions):
26 """ Easily create a trivial completer for a command.
27 """ Easily create a trivial completer for a command.
27
28
28 Takes either a list of completions, or all completions in string
29 Takes either a list of completions, or all completions in string
29 (that will be split on whitespace)
30 (that will be split on whitespace)
30
31
31 Example::
32 Example::
32
33
33 [d:\ipython]|1> import ipy_completers
34 [d:\ipython]|1> import ipy_completers
34 [d:\ipython]|2> ipy_completers.quick_completer('foo', ['bar','baz'])
35 [d:\ipython]|2> ipy_completers.quick_completer('foo', ['bar','baz'])
35 [d:\ipython]|3> foo b<TAB>
36 [d:\ipython]|3> foo b<TAB>
36 bar baz
37 bar baz
37 [d:\ipython]|3> foo ba
38 [d:\ipython]|3> foo ba
38 """
39 """
39 if isinstance(completions, basestring):
40 if isinstance(completions, basestring):
40
41
41 completions = completions.split()
42 completions = completions.split()
42 def do_complete(self,event):
43 def do_complete(self,event):
43 return completions
44 return completions
44
45
45 ip.set_hook('complete_command',do_complete, str_key = cmd)
46 ip.set_hook('complete_command',do_complete, str_key = cmd)
46
47
47 def getRootModules():
48 def getRootModules():
48 """
49 """
49 Returns a list containing the names of all the modules available in the
50 Returns a list containing the names of all the modules available in the
50 folders of the pythonpath.
51 folders of the pythonpath.
51 """
52 """
52 modules = []
53 modules = []
53 if ip.db.has_key('rootmodules'):
54 if ip.db.has_key('rootmodules'):
54 return ip.db['rootmodules']
55 return ip.db['rootmodules']
55 t = time()
56 t = time()
56 store = False
57 store = False
57 for path in sys.path:
58 for path in sys.path:
58 modules += moduleList(path)
59 modules += moduleList(path)
59 if time() - t >= TIMEOUT_STORAGE and not store:
60 if time() - t >= TIMEOUT_STORAGE and not store:
60 store = True
61 store = True
61 print "\nCaching the list of root modules, please wait!"
62 print "\nCaching the list of root modules, please wait!"
62 print "(This will only be done once - type '%rehashx' to " + \
63 print "(This will only be done once - type '%rehashx' to " + \
63 "reset cache!)"
64 "reset cache!)"
64 print
65 print
65 if time() - t > TIMEOUT_GIVEUP:
66 if time() - t > TIMEOUT_GIVEUP:
66 print "This is taking too long, we give up."
67 print "This is taking too long, we give up."
67 print
68 print
68 ip.db['rootmodules'] = []
69 ip.db['rootmodules'] = []
69 return []
70 return []
70
71
71 modules += sys.builtin_module_names
72 modules += sys.builtin_module_names
72
73
73 modules = list(set(modules))
74 modules = list(set(modules))
74 if '__init__' in modules:
75 if '__init__' in modules:
75 modules.remove('__init__')
76 modules.remove('__init__')
76 modules = list(set(modules))
77 modules = list(set(modules))
77 if store:
78 if store:
78 ip.db['rootmodules'] = modules
79 ip.db['rootmodules'] = modules
79 return modules
80 return modules
80
81
81 def moduleList(path):
82 def moduleList(path):
82 """
83 """
83 Return the list containing the names of the modules available in the given
84 Return the list containing the names of the modules available in the given
84 folder.
85 folder.
85 """
86 """
86
87
87 if os.path.isdir(path):
88 if os.path.isdir(path):
88 folder_list = os.listdir(path)
89 folder_list = os.listdir(path)
90 elif path.endswith('.egg'):
91 try:
92 folder_list = [f for f in zipimporter(path)._files]
93 except:
94 folder_list = []
89 else:
95 else:
90 folder_list = []
96 folder_list = []
91 #folder_list = glob.glob(os.path.join(path,'*'))
97 #folder_list = glob.glob(os.path.join(path,'*'))
92 folder_list = [p for p in folder_list \
98 folder_list = [p for p in folder_list \
93 if os.path.exists(os.path.join(path, p,'__init__.py'))\
99 if os.path.exists(os.path.join(path, p,'__init__.py'))\
94 or p[-3:] in ('.py','.so')\
100 or p[-3:] in ('.py','.so')\
95 or p[-4:] in ('.pyc','.pyo','.pyd')]
101 or p[-4:] in ('.pyc','.pyo','.pyd')]
96
102
97 folder_list = [os.path.basename(p).split('.')[0] for p in folder_list]
103 folder_list = [os.path.basename(p).split('.')[0] for p in folder_list]
98 return folder_list
104 return folder_list
99
105
100 def moduleCompletion(line):
106 def moduleCompletion(line):
101 """
107 """
102 Returns a list containing the completion possibilities for an import line.
108 Returns a list containing the completion possibilities for an import line.
103 The line looks like this :
109 The line looks like this :
104 'import xml.d'
110 'import xml.d'
105 'from xml.dom import'
111 'from xml.dom import'
106 """
112 """
107 def tryImport(mod, only_modules=False):
113 def tryImport(mod, only_modules=False):
108 def isImportable(module, attr):
114 def isImportable(module, attr):
109 if only_modules:
115 if only_modules:
110 return inspect.ismodule(getattr(module, attr))
116 return inspect.ismodule(getattr(module, attr))
111 else:
117 else:
112 return not(attr[:2] == '__' and attr[-2:] == '__')
118 return not(attr[:2] == '__' and attr[-2:] == '__')
113 try:
119 try:
114 m = __import__(mod)
120 m = __import__(mod)
115 except:
121 except:
116 return []
122 return []
117 mods = mod.split('.')
123 mods = mod.split('.')
118 for module in mods[1:]:
124 for module in mods[1:]:
119 m = getattr(m,module)
125 m = getattr(m,module)
120 if (not hasattr(m, '__file__')) or (not only_modules) or\
126 if (not hasattr(m, '__file__')) or (not only_modules) or\
121 (hasattr(m, '__file__') and '__init__' in m.__file__):
127 (hasattr(m, '__file__') and '__init__' in m.__file__):
122 completion_list = [attr for attr in dir(m) if isImportable(m, attr)]
128 completion_list = [attr for attr in dir(m) if isImportable(m, attr)]
123 completion_list.extend(getattr(m,'__all__',[]))
129 completion_list.extend(getattr(m,'__all__',[]))
124 if hasattr(m, '__file__') and '__init__' in m.__file__:
130 if hasattr(m, '__file__') and '__init__' in m.__file__:
125 completion_list.extend(moduleList(os.path.dirname(m.__file__)))
131 completion_list.extend(moduleList(os.path.dirname(m.__file__)))
126 completion_list = list(set(completion_list))
132 completion_list = list(set(completion_list))
127 if '__init__' in completion_list:
133 if '__init__' in completion_list:
128 completion_list.remove('__init__')
134 completion_list.remove('__init__')
129 return completion_list
135 return completion_list
130
136
131 words = line.split(' ')
137 words = line.split(' ')
132 if len(words) == 3 and words[0] == 'from':
138 if len(words) == 3 and words[0] == 'from':
133 return ['import ']
139 return ['import ']
134 if len(words) < 3 and (words[0] in ['import','from']) :
140 if len(words) < 3 and (words[0] in ['import','from']) :
135 if len(words) == 1:
141 if len(words) == 1:
136 return getRootModules()
142 return getRootModules()
137 mod = words[1].split('.')
143 mod = words[1].split('.')
138 if len(mod) < 2:
144 if len(mod) < 2:
139 return getRootModules()
145 return getRootModules()
140 completion_list = tryImport('.'.join(mod[:-1]), True)
146 completion_list = tryImport('.'.join(mod[:-1]), True)
141 completion_list = ['.'.join(mod[:-1] + [el]) for el in completion_list]
147 completion_list = ['.'.join(mod[:-1] + [el]) for el in completion_list]
142 return completion_list
148 return completion_list
143 if len(words) >= 3 and words[0] == 'from':
149 if len(words) >= 3 and words[0] == 'from':
144 mod = words[1]
150 mod = words[1]
145 return tryImport(mod)
151 return tryImport(mod)
146
152
147 def vcs_completer(commands, event):
153 def vcs_completer(commands, event):
148 """ utility to make writing typical version control app completers easier
154 """ utility to make writing typical version control app completers easier
149
155
150 VCS command line apps typically have the format:
156 VCS command line apps typically have the format:
151
157
152 [sudo ]PROGNAME [help] [command] file file...
158 [sudo ]PROGNAME [help] [command] file file...
153
159
154 """
160 """
155
161
156
162
157 cmd_param = event.line.split()
163 cmd_param = event.line.split()
158 if event.line.endswith(' '):
164 if event.line.endswith(' '):
159 cmd_param.append('')
165 cmd_param.append('')
160
166
161 if cmd_param[0] == 'sudo':
167 if cmd_param[0] == 'sudo':
162 cmd_param = cmd_param[1:]
168 cmd_param = cmd_param[1:]
163
169
164 if len(cmd_param) == 2 or 'help' in cmd_param:
170 if len(cmd_param) == 2 or 'help' in cmd_param:
165 return commands.split()
171 return commands.split()
166
172
167 return ip.IP.Completer.file_matches(event.symbol)
173 return ip.IP.Completer.file_matches(event.symbol)
168
174
169
175
170 pkg_cache = None
176 pkg_cache = None
171
177
172 def module_completer(self,event):
178 def module_completer(self,event):
173 """ Give completions after user has typed 'import ...' or 'from ...'"""
179 """ Give completions after user has typed 'import ...' or 'from ...'"""
174
180
175 # This works in all versions of python. While 2.5 has
181 # This works in all versions of python. While 2.5 has
176 # pkgutil.walk_packages(), that particular routine is fairly dangerous,
182 # pkgutil.walk_packages(), that particular routine is fairly dangerous,
177 # since it imports *EVERYTHING* on sys.path. That is: a) very slow b) full
183 # since it imports *EVERYTHING* on sys.path. That is: a) very slow b) full
178 # of possibly problematic side effects.
184 # of possibly problematic side effects.
179 # This search the folders in the sys.path for available modules.
185 # This search the folders in the sys.path for available modules.
180
186
181 return moduleCompletion(event.line)
187 return moduleCompletion(event.line)
182
188
183
189
184 svn_commands = """\
190 svn_commands = """\
185 add blame praise annotate ann cat checkout co cleanup commit ci copy
191 add blame praise annotate ann cat checkout co cleanup commit ci copy
186 cp delete del remove rm diff di export help ? h import info list ls
192 cp delete del remove rm diff di export help ? h import info list ls
187 lock log merge mkdir move mv rename ren propdel pdel pd propedit pedit
193 lock log merge mkdir move mv rename ren propdel pdel pd propedit pedit
188 pe propget pget pg proplist plist pl propset pset ps resolved revert
194 pe propget pget pg proplist plist pl propset pset ps resolved revert
189 status stat st switch sw unlock update
195 status stat st switch sw unlock update
190 """
196 """
191
197
192 def svn_completer(self,event):
198 def svn_completer(self,event):
193 return vcs_completer(svn_commands, event)
199 return vcs_completer(svn_commands, event)
194
200
195
201
196 hg_commands = """
202 hg_commands = """
197 add addremove annotate archive backout branch branches bundle cat
203 add addremove annotate archive backout branch branches bundle cat
198 clone commit copy diff export grep heads help identify import incoming
204 clone commit copy diff export grep heads help identify import incoming
199 init locate log manifest merge outgoing parents paths pull push
205 init locate log manifest merge outgoing parents paths pull push
200 qapplied qclone qcommit qdelete qdiff qfold qguard qheader qimport
206 qapplied qclone qcommit qdelete qdiff qfold qguard qheader qimport
201 qinit qnew qnext qpop qprev qpush qrefresh qrename qrestore qsave
207 qinit qnew qnext qpop qprev qpush qrefresh qrename qrestore qsave
202 qselect qseries qtop qunapplied recover remove rename revert rollback
208 qselect qseries qtop qunapplied recover remove rename revert rollback
203 root serve showconfig status strip tag tags tip unbundle update verify
209 root serve showconfig status strip tag tags tip unbundle update verify
204 version
210 version
205 """
211 """
206
212
207 def hg_completer(self,event):
213 def hg_completer(self,event):
208 """ Completer for mercurial commands """
214 """ Completer for mercurial commands """
209
215
210 return vcs_completer(hg_commands, event)
216 return vcs_completer(hg_commands, event)
211
217
212
218
213
219
214 __bzr_commands = None
220 __bzr_commands = None
215
221
216 def bzr_commands():
222 def bzr_commands():
217 global __bzr_commands
223 global __bzr_commands
218 if __bzr_commands is not None:
224 if __bzr_commands is not None:
219 return __bzr_commands
225 return __bzr_commands
220 out = os.popen('bzr help commands')
226 out = os.popen('bzr help commands')
221 __bzr_commands = [l.split()[0] for l in out]
227 __bzr_commands = [l.split()[0] for l in out]
222 return __bzr_commands
228 return __bzr_commands
223
229
224 def bzr_completer(self,event):
230 def bzr_completer(self,event):
225 """ Completer for bazaar commands """
231 """ Completer for bazaar commands """
226 cmd_param = event.line.split()
232 cmd_param = event.line.split()
227 if event.line.endswith(' '):
233 if event.line.endswith(' '):
228 cmd_param.append('')
234 cmd_param.append('')
229
235
230 if len(cmd_param) > 2:
236 if len(cmd_param) > 2:
231 cmd = cmd_param[1]
237 cmd = cmd_param[1]
232 param = cmd_param[-1]
238 param = cmd_param[-1]
233 output_file = (param == '--output=')
239 output_file = (param == '--output=')
234 if cmd == 'help':
240 if cmd == 'help':
235 return bzr_commands()
241 return bzr_commands()
236 elif cmd in ['bundle-revisions','conflicts',
242 elif cmd in ['bundle-revisions','conflicts',
237 'deleted','nick','register-branch',
243 'deleted','nick','register-branch',
238 'serve','unbind','upgrade','version',
244 'serve','unbind','upgrade','version',
239 'whoami'] and not output_file:
245 'whoami'] and not output_file:
240 return []
246 return []
241 else:
247 else:
242 # the rest are probably file names
248 # the rest are probably file names
243 return ip.IP.Completer.file_matches(event.symbol)
249 return ip.IP.Completer.file_matches(event.symbol)
244
250
245 return bzr_commands()
251 return bzr_commands()
246
252
247
253
248 def shlex_split(x):
254 def shlex_split(x):
249 """Helper function to split lines into segments."""
255 """Helper function to split lines into segments."""
250 #shlex.split raise exception if syntax error in sh syntax
256 #shlex.split raise exception if syntax error in sh syntax
251 #for example if no closing " is found. This function keeps dropping
257 #for example if no closing " is found. This function keeps dropping
252 #the last character of the line until shlex.split does not raise
258 #the last character of the line until shlex.split does not raise
253 #exception. Adds end of the line to the result of shlex.split
259 #exception. Adds end of the line to the result of shlex.split
254 #example: %run "c:/python -> ['%run','"c:/python']
260 #example: %run "c:/python -> ['%run','"c:/python']
255 endofline=[]
261 endofline=[]
256 while x!="":
262 while x!="":
257 try:
263 try:
258 comps=shlex.split(x)
264 comps=shlex.split(x)
259 if len(endofline)>=1:
265 if len(endofline)>=1:
260 comps.append("".join(endofline))
266 comps.append("".join(endofline))
261 return comps
267 return comps
262 except ValueError:
268 except ValueError:
263 endofline=[x[-1:]]+endofline
269 endofline=[x[-1:]]+endofline
264 x=x[:-1]
270 x=x[:-1]
265 return ["".join(endofline)]
271 return ["".join(endofline)]
266
272
267 def runlistpy(self, event):
273 def runlistpy(self, event):
268 comps = shlex_split(event.line)
274 comps = shlex_split(event.line)
269 relpath = (len(comps) > 1 and comps[-1] or '').strip("'\"")
275 relpath = (len(comps) > 1 and comps[-1] or '').strip("'\"")
270
276
271 #print "\nev=",event # dbg
277 #print "\nev=",event # dbg
272 #print "rp=",relpath # dbg
278 #print "rp=",relpath # dbg
273 #print 'comps=',comps # dbg
279 #print 'comps=',comps # dbg
274
280
275 lglob = glob.glob
281 lglob = glob.glob
276 isdir = os.path.isdir
282 isdir = os.path.isdir
277 if relpath.startswith('~'):
283 if relpath.startswith('~'):
278 relpath = os.path.expanduser(relpath)
284 relpath = os.path.expanduser(relpath)
279 dirs = [f.replace('\\','/') + "/" for f in lglob(relpath+'*')
285 dirs = [f.replace('\\','/') + "/" for f in lglob(relpath+'*')
280 if isdir(f)]
286 if isdir(f)]
281
287
282 # Find if the user has already typed the first filename, after which we
288 # Find if the user has already typed the first filename, after which we
283 # should complete on all files, since after the first one other files may
289 # should complete on all files, since after the first one other files may
284 # be arguments to the input script.
290 # be arguments to the input script.
285 #filter(
291 #filter(
286 if filter(lambda f: f.endswith('.py') or f.endswith('.ipy') or
292 if filter(lambda f: f.endswith('.py') or f.endswith('.ipy') or
287 f.endswith('.pyw'),comps):
293 f.endswith('.pyw'),comps):
288 pys = [f.replace('\\','/') for f in lglob('*')]
294 pys = [f.replace('\\','/') for f in lglob('*')]
289 else:
295 else:
290 pys = [f.replace('\\','/')
296 pys = [f.replace('\\','/')
291 for f in lglob(relpath+'*.py') + lglob(relpath+'*.ipy') +
297 for f in lglob(relpath+'*.py') + lglob(relpath+'*.ipy') +
292 lglob(relpath + '*.pyw')]
298 lglob(relpath + '*.pyw')]
293 return dirs + pys
299 return dirs + pys
294
300
295
301
296 def cd_completer(self, event):
302 def cd_completer(self, event):
297 relpath = event.symbol
303 relpath = event.symbol
298 #print event # dbg
304 #print event # dbg
299 if '-b' in event.line:
305 if '-b' in event.line:
300 # return only bookmark completions
306 # return only bookmark completions
301 bkms = self.db.get('bookmarks',{})
307 bkms = self.db.get('bookmarks',{})
302 return bkms.keys()
308 return bkms.keys()
303
309
304
310
305 if event.symbol == '-':
311 if event.symbol == '-':
306 width_dh = str(len(str(len(ip.user_ns['_dh']) + 1)))
312 width_dh = str(len(str(len(ip.user_ns['_dh']) + 1)))
307 # jump in directory history by number
313 # jump in directory history by number
308 fmt = '-%0' + width_dh +'d [%s]'
314 fmt = '-%0' + width_dh +'d [%s]'
309 ents = [ fmt % (i,s) for i,s in enumerate(ip.user_ns['_dh'])]
315 ents = [ fmt % (i,s) for i,s in enumerate(ip.user_ns['_dh'])]
310 if len(ents) > 1:
316 if len(ents) > 1:
311 return ents
317 return ents
312 return []
318 return []
313
319
314 if relpath.startswith('~'):
320 if relpath.startswith('~'):
315 relpath = os.path.expanduser(relpath).replace('\\','/')
321 relpath = os.path.expanduser(relpath).replace('\\','/')
316 found = []
322 found = []
317 for d in [f.replace('\\','/') + '/' for f in glob.glob(relpath+'*')
323 for d in [f.replace('\\','/') + '/' for f in glob.glob(relpath+'*')
318 if os.path.isdir(f)]:
324 if os.path.isdir(f)]:
319 if ' ' in d:
325 if ' ' in d:
320 # we don't want to deal with any of that, complex code
326 # we don't want to deal with any of that, complex code
321 # for this is elsewhere
327 # for this is elsewhere
322 raise IPython.ipapi.TryNext
328 raise IPython.ipapi.TryNext
323 found.append( d )
329 found.append( d )
324
330
325 if not found:
331 if not found:
326 if os.path.isdir(relpath):
332 if os.path.isdir(relpath):
327 return [relpath]
333 return [relpath]
328 raise IPython.ipapi.TryNext
334 raise IPython.ipapi.TryNext
329 return found
335 return found
330
336
331 def apt_get_packages(prefix):
337 def apt_get_packages(prefix):
332 out = os.popen('apt-cache pkgnames')
338 out = os.popen('apt-cache pkgnames')
333 for p in out:
339 for p in out:
334 if p.startswith(prefix):
340 if p.startswith(prefix):
335 yield p.rstrip()
341 yield p.rstrip()
336
342
337
343
338 apt_commands = """\
344 apt_commands = """\
339 update upgrade install remove purge source build-dep dist-upgrade
345 update upgrade install remove purge source build-dep dist-upgrade
340 dselect-upgrade clean autoclean check"""
346 dselect-upgrade clean autoclean check"""
341
347
342 def apt_completer(self, event):
348 def apt_completer(self, event):
343 """ Completer for apt-get (uses apt-cache internally)
349 """ Completer for apt-get (uses apt-cache internally)
344
350
345 """
351 """
346
352
347
353
348 cmd_param = event.line.split()
354 cmd_param = event.line.split()
349 if event.line.endswith(' '):
355 if event.line.endswith(' '):
350 cmd_param.append('')
356 cmd_param.append('')
351
357
352 if cmd_param[0] == 'sudo':
358 if cmd_param[0] == 'sudo':
353 cmd_param = cmd_param[1:]
359 cmd_param = cmd_param[1:]
354
360
355 if len(cmd_param) == 2 or 'help' in cmd_param:
361 if len(cmd_param) == 2 or 'help' in cmd_param:
356 return apt_commands.split()
362 return apt_commands.split()
357
363
358 return list(apt_get_packages(event.symbol))
364 return list(apt_get_packages(event.symbol))
359
365
@@ -1,2008 +1,2024 b''
1 # -*- coding: utf-8 -*-
1 # -*- coding: utf-8 -*-
2 """
2 """
3 General purpose utilities.
3 General purpose utilities.
4
4
5 This is a grab-bag of stuff I find useful in most programs I write. Some of
5 This is a grab-bag of stuff I find useful in most programs I write. Some of
6 these things are also convenient when working at the command line.
6 these things are also convenient when working at the command line.
7
7
8 $Id: genutils.py 2998 2008-01-31 10:06:04Z vivainio $"""
8 $Id: genutils.py 2998 2008-01-31 10:06:04Z vivainio $"""
9
9
10 #*****************************************************************************
10 #*****************************************************************************
11 # Copyright (C) 2001-2006 Fernando Perez. <fperez@colorado.edu>
11 # Copyright (C) 2001-2006 Fernando Perez. <fperez@colorado.edu>
12 #
12 #
13 # Distributed under the terms of the BSD License. The full license is in
13 # Distributed under the terms of the BSD License. The full license is in
14 # the file COPYING, distributed as part of this software.
14 # the file COPYING, distributed as part of this software.
15 #*****************************************************************************
15 #*****************************************************************************
16
16
17 from IPython import Release
17 from IPython import Release
18 __author__ = '%s <%s>' % Release.authors['Fernando']
18 __author__ = '%s <%s>' % Release.authors['Fernando']
19 __license__ = Release.license
19 __license__ = Release.license
20
20
21 #****************************************************************************
21 #****************************************************************************
22 # required modules from the Python standard library
22 # required modules from the Python standard library
23 import __main__
23 import __main__
24 import commands
24 import commands
25 import doctest
25 import doctest
26 import os
26 import os
27 import re
27 import re
28 import shlex
28 import shlex
29 import shutil
29 import shutil
30 import sys
30 import sys
31 import tempfile
31 import tempfile
32 import time
32 import time
33 import types
33 import types
34 import warnings
34 import warnings
35
35
36 # Other IPython utilities
36 # Other IPython utilities
37 import IPython
37 import IPython
38 from IPython.Itpl import Itpl,itpl,printpl
38 from IPython.Itpl import Itpl,itpl,printpl
39 from IPython import DPyGetOpt, platutils
39 from IPython import DPyGetOpt, platutils
40 from IPython.generics import result_display
40 from IPython.generics import result_display
41 import IPython.ipapi
41 import IPython.ipapi
42 from IPython.external.path import path
42 from IPython.external.path import path
43 if os.name == "nt":
43 if os.name == "nt":
44 from IPython.winconsole import get_console_size
44 from IPython.winconsole import get_console_size
45
45
46 try:
46 try:
47 set
47 set
48 except:
48 except:
49 from sets import Set as set
49 from sets import Set as set
50
50
51
51
52 #****************************************************************************
52 #****************************************************************************
53 # Exceptions
53 # Exceptions
54 class Error(Exception):
54 class Error(Exception):
55 """Base class for exceptions in this module."""
55 """Base class for exceptions in this module."""
56 pass
56 pass
57
57
58 #----------------------------------------------------------------------------
58 #----------------------------------------------------------------------------
59 class IOStream:
59 class IOStream:
60 def __init__(self,stream,fallback):
60 def __init__(self,stream,fallback):
61 if not hasattr(stream,'write') or not hasattr(stream,'flush'):
61 if not hasattr(stream,'write') or not hasattr(stream,'flush'):
62 stream = fallback
62 stream = fallback
63 self.stream = stream
63 self.stream = stream
64 self._swrite = stream.write
64 self._swrite = stream.write
65 self.flush = stream.flush
65 self.flush = stream.flush
66
66
67 def write(self,data):
67 def write(self,data):
68 try:
68 try:
69 self._swrite(data)
69 self._swrite(data)
70 except:
70 except:
71 try:
71 try:
72 # print handles some unicode issues which may trip a plain
72 # print handles some unicode issues which may trip a plain
73 # write() call. Attempt to emulate write() by using a
73 # write() call. Attempt to emulate write() by using a
74 # trailing comma
74 # trailing comma
75 print >> self.stream, data,
75 print >> self.stream, data,
76 except:
76 except:
77 # if we get here, something is seriously broken.
77 # if we get here, something is seriously broken.
78 print >> sys.stderr, \
78 print >> sys.stderr, \
79 'ERROR - failed to write data to stream:', self.stream
79 'ERROR - failed to write data to stream:', self.stream
80
80
81 def close(self):
81 def close(self):
82 pass
82 pass
83
83
84
84
85 class IOTerm:
85 class IOTerm:
86 """ Term holds the file or file-like objects for handling I/O operations.
86 """ Term holds the file or file-like objects for handling I/O operations.
87
87
88 These are normally just sys.stdin, sys.stdout and sys.stderr but for
88 These are normally just sys.stdin, sys.stdout and sys.stderr but for
89 Windows they can can replaced to allow editing the strings before they are
89 Windows they can can replaced to allow editing the strings before they are
90 displayed."""
90 displayed."""
91
91
92 # In the future, having IPython channel all its I/O operations through
92 # In the future, having IPython channel all its I/O operations through
93 # this class will make it easier to embed it into other environments which
93 # this class will make it easier to embed it into other environments which
94 # are not a normal terminal (such as a GUI-based shell)
94 # are not a normal terminal (such as a GUI-based shell)
95 def __init__(self,cin=None,cout=None,cerr=None):
95 def __init__(self,cin=None,cout=None,cerr=None):
96 self.cin = IOStream(cin,sys.stdin)
96 self.cin = IOStream(cin,sys.stdin)
97 self.cout = IOStream(cout,sys.stdout)
97 self.cout = IOStream(cout,sys.stdout)
98 self.cerr = IOStream(cerr,sys.stderr)
98 self.cerr = IOStream(cerr,sys.stderr)
99
99
100 # Global variable to be used for all I/O
100 # Global variable to be used for all I/O
101 Term = IOTerm()
101 Term = IOTerm()
102
102
103 import IPython.rlineimpl as readline
103 import IPython.rlineimpl as readline
104 # Remake Term to use the readline i/o facilities
104 # Remake Term to use the readline i/o facilities
105 if sys.platform == 'win32' and readline.have_readline:
105 if sys.platform == 'win32' and readline.have_readline:
106
106
107 Term = IOTerm(cout=readline._outputfile,cerr=readline._outputfile)
107 Term = IOTerm(cout=readline._outputfile,cerr=readline._outputfile)
108
108
109
109
110 #****************************************************************************
110 #****************************************************************************
111 # Generic warning/error printer, used by everything else
111 # Generic warning/error printer, used by everything else
112 def warn(msg,level=2,exit_val=1):
112 def warn(msg,level=2,exit_val=1):
113 """Standard warning printer. Gives formatting consistency.
113 """Standard warning printer. Gives formatting consistency.
114
114
115 Output is sent to Term.cerr (sys.stderr by default).
115 Output is sent to Term.cerr (sys.stderr by default).
116
116
117 Options:
117 Options:
118
118
119 -level(2): allows finer control:
119 -level(2): allows finer control:
120 0 -> Do nothing, dummy function.
120 0 -> Do nothing, dummy function.
121 1 -> Print message.
121 1 -> Print message.
122 2 -> Print 'WARNING:' + message. (Default level).
122 2 -> Print 'WARNING:' + message. (Default level).
123 3 -> Print 'ERROR:' + message.
123 3 -> Print 'ERROR:' + message.
124 4 -> Print 'FATAL ERROR:' + message and trigger a sys.exit(exit_val).
124 4 -> Print 'FATAL ERROR:' + message and trigger a sys.exit(exit_val).
125
125
126 -exit_val (1): exit value returned by sys.exit() for a level 4
126 -exit_val (1): exit value returned by sys.exit() for a level 4
127 warning. Ignored for all other levels."""
127 warning. Ignored for all other levels."""
128
128
129 if level>0:
129 if level>0:
130 header = ['','','WARNING: ','ERROR: ','FATAL ERROR: ']
130 header = ['','','WARNING: ','ERROR: ','FATAL ERROR: ']
131 print >> Term.cerr, '%s%s' % (header[level],msg)
131 print >> Term.cerr, '%s%s' % (header[level],msg)
132 if level == 4:
132 if level == 4:
133 print >> Term.cerr,'Exiting.\n'
133 print >> Term.cerr,'Exiting.\n'
134 sys.exit(exit_val)
134 sys.exit(exit_val)
135
135
136 def info(msg):
136 def info(msg):
137 """Equivalent to warn(msg,level=1)."""
137 """Equivalent to warn(msg,level=1)."""
138
138
139 warn(msg,level=1)
139 warn(msg,level=1)
140
140
141 def error(msg):
141 def error(msg):
142 """Equivalent to warn(msg,level=3)."""
142 """Equivalent to warn(msg,level=3)."""
143
143
144 warn(msg,level=3)
144 warn(msg,level=3)
145
145
146 def fatal(msg,exit_val=1):
146 def fatal(msg,exit_val=1):
147 """Equivalent to warn(msg,exit_val=exit_val,level=4)."""
147 """Equivalent to warn(msg,exit_val=exit_val,level=4)."""
148
148
149 warn(msg,exit_val=exit_val,level=4)
149 warn(msg,exit_val=exit_val,level=4)
150
150
151 #---------------------------------------------------------------------------
151 #---------------------------------------------------------------------------
152 # Debugging routines
152 # Debugging routines
153 #
153 #
154 def debugx(expr,pre_msg=''):
154 def debugx(expr,pre_msg=''):
155 """Print the value of an expression from the caller's frame.
155 """Print the value of an expression from the caller's frame.
156
156
157 Takes an expression, evaluates it in the caller's frame and prints both
157 Takes an expression, evaluates it in the caller's frame and prints both
158 the given expression and the resulting value (as well as a debug mark
158 the given expression and the resulting value (as well as a debug mark
159 indicating the name of the calling function. The input must be of a form
159 indicating the name of the calling function. The input must be of a form
160 suitable for eval().
160 suitable for eval().
161
161
162 An optional message can be passed, which will be prepended to the printed
162 An optional message can be passed, which will be prepended to the printed
163 expr->value pair."""
163 expr->value pair."""
164
164
165 cf = sys._getframe(1)
165 cf = sys._getframe(1)
166 print '[DBG:%s] %s%s -> %r' % (cf.f_code.co_name,pre_msg,expr,
166 print '[DBG:%s] %s%s -> %r' % (cf.f_code.co_name,pre_msg,expr,
167 eval(expr,cf.f_globals,cf.f_locals))
167 eval(expr,cf.f_globals,cf.f_locals))
168
168
169 # deactivate it by uncommenting the following line, which makes it a no-op
169 # deactivate it by uncommenting the following line, which makes it a no-op
170 #def debugx(expr,pre_msg=''): pass
170 #def debugx(expr,pre_msg=''): pass
171
171
172 #----------------------------------------------------------------------------
172 #----------------------------------------------------------------------------
173 StringTypes = types.StringTypes
173 StringTypes = types.StringTypes
174
174
175 # Basic timing functionality
175 # Basic timing functionality
176
176
177 # If possible (Unix), use the resource module instead of time.clock()
177 # If possible (Unix), use the resource module instead of time.clock()
178 try:
178 try:
179 import resource
179 import resource
180 def clocku():
180 def clocku():
181 """clocku() -> floating point number
181 """clocku() -> floating point number
182
182
183 Return the *USER* CPU time in seconds since the start of the process.
183 Return the *USER* CPU time in seconds since the start of the process.
184 This is done via a call to resource.getrusage, so it avoids the
184 This is done via a call to resource.getrusage, so it avoids the
185 wraparound problems in time.clock()."""
185 wraparound problems in time.clock()."""
186
186
187 return resource.getrusage(resource.RUSAGE_SELF)[0]
187 return resource.getrusage(resource.RUSAGE_SELF)[0]
188
188
189 def clocks():
189 def clocks():
190 """clocks() -> floating point number
190 """clocks() -> floating point number
191
191
192 Return the *SYSTEM* CPU time in seconds since the start of the process.
192 Return the *SYSTEM* CPU time in seconds since the start of the process.
193 This is done via a call to resource.getrusage, so it avoids the
193 This is done via a call to resource.getrusage, so it avoids the
194 wraparound problems in time.clock()."""
194 wraparound problems in time.clock()."""
195
195
196 return resource.getrusage(resource.RUSAGE_SELF)[1]
196 return resource.getrusage(resource.RUSAGE_SELF)[1]
197
197
198 def clock():
198 def clock():
199 """clock() -> floating point number
199 """clock() -> floating point number
200
200
201 Return the *TOTAL USER+SYSTEM* CPU time in seconds since the start of
201 Return the *TOTAL USER+SYSTEM* CPU time in seconds since the start of
202 the process. This is done via a call to resource.getrusage, so it
202 the process. This is done via a call to resource.getrusage, so it
203 avoids the wraparound problems in time.clock()."""
203 avoids the wraparound problems in time.clock()."""
204
204
205 u,s = resource.getrusage(resource.RUSAGE_SELF)[:2]
205 u,s = resource.getrusage(resource.RUSAGE_SELF)[:2]
206 return u+s
206 return u+s
207
207
208 def clock2():
208 def clock2():
209 """clock2() -> (t_user,t_system)
209 """clock2() -> (t_user,t_system)
210
210
211 Similar to clock(), but return a tuple of user/system times."""
211 Similar to clock(), but return a tuple of user/system times."""
212 return resource.getrusage(resource.RUSAGE_SELF)[:2]
212 return resource.getrusage(resource.RUSAGE_SELF)[:2]
213
213
214 except ImportError:
214 except ImportError:
215 # There is no distinction of user/system time under windows, so we just use
215 # There is no distinction of user/system time under windows, so we just use
216 # time.clock() for everything...
216 # time.clock() for everything...
217 clocku = clocks = clock = time.clock
217 clocku = clocks = clock = time.clock
218 def clock2():
218 def clock2():
219 """Under windows, system CPU time can't be measured.
219 """Under windows, system CPU time can't be measured.
220
220
221 This just returns clock() and zero."""
221 This just returns clock() and zero."""
222 return time.clock(),0.0
222 return time.clock(),0.0
223
223
224 def timings_out(reps,func,*args,**kw):
224 def timings_out(reps,func,*args,**kw):
225 """timings_out(reps,func,*args,**kw) -> (t_total,t_per_call,output)
225 """timings_out(reps,func,*args,**kw) -> (t_total,t_per_call,output)
226
226
227 Execute a function reps times, return a tuple with the elapsed total
227 Execute a function reps times, return a tuple with the elapsed total
228 CPU time in seconds, the time per call and the function's output.
228 CPU time in seconds, the time per call and the function's output.
229
229
230 Under Unix, the return value is the sum of user+system time consumed by
230 Under Unix, the return value is the sum of user+system time consumed by
231 the process, computed via the resource module. This prevents problems
231 the process, computed via the resource module. This prevents problems
232 related to the wraparound effect which the time.clock() function has.
232 related to the wraparound effect which the time.clock() function has.
233
233
234 Under Windows the return value is in wall clock seconds. See the
234 Under Windows the return value is in wall clock seconds. See the
235 documentation for the time module for more details."""
235 documentation for the time module for more details."""
236
236
237 reps = int(reps)
237 reps = int(reps)
238 assert reps >=1, 'reps must be >= 1'
238 assert reps >=1, 'reps must be >= 1'
239 if reps==1:
239 if reps==1:
240 start = clock()
240 start = clock()
241 out = func(*args,**kw)
241 out = func(*args,**kw)
242 tot_time = clock()-start
242 tot_time = clock()-start
243 else:
243 else:
244 rng = xrange(reps-1) # the last time is executed separately to store output
244 rng = xrange(reps-1) # the last time is executed separately to store output
245 start = clock()
245 start = clock()
246 for dummy in rng: func(*args,**kw)
246 for dummy in rng: func(*args,**kw)
247 out = func(*args,**kw) # one last time
247 out = func(*args,**kw) # one last time
248 tot_time = clock()-start
248 tot_time = clock()-start
249 av_time = tot_time / reps
249 av_time = tot_time / reps
250 return tot_time,av_time,out
250 return tot_time,av_time,out
251
251
252 def timings(reps,func,*args,**kw):
252 def timings(reps,func,*args,**kw):
253 """timings(reps,func,*args,**kw) -> (t_total,t_per_call)
253 """timings(reps,func,*args,**kw) -> (t_total,t_per_call)
254
254
255 Execute a function reps times, return a tuple with the elapsed total CPU
255 Execute a function reps times, return a tuple with the elapsed total CPU
256 time in seconds and the time per call. These are just the first two values
256 time in seconds and the time per call. These are just the first two values
257 in timings_out()."""
257 in timings_out()."""
258
258
259 return timings_out(reps,func,*args,**kw)[0:2]
259 return timings_out(reps,func,*args,**kw)[0:2]
260
260
261 def timing(func,*args,**kw):
261 def timing(func,*args,**kw):
262 """timing(func,*args,**kw) -> t_total
262 """timing(func,*args,**kw) -> t_total
263
263
264 Execute a function once, return the elapsed total CPU time in
264 Execute a function once, return the elapsed total CPU time in
265 seconds. This is just the first value in timings_out()."""
265 seconds. This is just the first value in timings_out()."""
266
266
267 return timings_out(1,func,*args,**kw)[0]
267 return timings_out(1,func,*args,**kw)[0]
268
268
269 #****************************************************************************
269 #****************************************************************************
270 # file and system
270 # file and system
271
271
272 def arg_split(s,posix=False):
272 def arg_split(s,posix=False):
273 """Split a command line's arguments in a shell-like manner.
273 """Split a command line's arguments in a shell-like manner.
274
274
275 This is a modified version of the standard library's shlex.split()
275 This is a modified version of the standard library's shlex.split()
276 function, but with a default of posix=False for splitting, so that quotes
276 function, but with a default of posix=False for splitting, so that quotes
277 in inputs are respected."""
277 in inputs are respected."""
278
278
279 # XXX - there may be unicode-related problems here!!! I'm not sure that
279 # XXX - there may be unicode-related problems here!!! I'm not sure that
280 # shlex is truly unicode-safe, so it might be necessary to do
280 # shlex is truly unicode-safe, so it might be necessary to do
281 #
281 #
282 # s = s.encode(sys.stdin.encoding)
282 # s = s.encode(sys.stdin.encoding)
283 #
283 #
284 # first, to ensure that shlex gets a normal string. Input from anyone who
284 # first, to ensure that shlex gets a normal string. Input from anyone who
285 # knows more about unicode and shlex than I would be good to have here...
285 # knows more about unicode and shlex than I would be good to have here...
286 lex = shlex.shlex(s, posix=posix)
286 lex = shlex.shlex(s, posix=posix)
287 lex.whitespace_split = True
287 lex.whitespace_split = True
288 return list(lex)
288 return list(lex)
289
289
290 def system(cmd,verbose=0,debug=0,header=''):
290 def system(cmd,verbose=0,debug=0,header=''):
291 """Execute a system command, return its exit status.
291 """Execute a system command, return its exit status.
292
292
293 Options:
293 Options:
294
294
295 - verbose (0): print the command to be executed.
295 - verbose (0): print the command to be executed.
296
296
297 - debug (0): only print, do not actually execute.
297 - debug (0): only print, do not actually execute.
298
298
299 - header (''): Header to print on screen prior to the executed command (it
299 - header (''): Header to print on screen prior to the executed command (it
300 is only prepended to the command, no newlines are added).
300 is only prepended to the command, no newlines are added).
301
301
302 Note: a stateful version of this function is available through the
302 Note: a stateful version of this function is available through the
303 SystemExec class."""
303 SystemExec class."""
304
304
305 stat = 0
305 stat = 0
306 if verbose or debug: print header+cmd
306 if verbose or debug: print header+cmd
307 sys.stdout.flush()
307 sys.stdout.flush()
308 if not debug: stat = os.system(cmd)
308 if not debug: stat = os.system(cmd)
309 return stat
309 return stat
310
310
311 def abbrev_cwd():
311 def abbrev_cwd():
312 """ Return abbreviated version of cwd, e.g. d:mydir """
312 """ Return abbreviated version of cwd, e.g. d:mydir """
313 cwd = os.getcwd().replace('\\','/')
313 cwd = os.getcwd().replace('\\','/')
314 drivepart = ''
314 drivepart = ''
315 tail = cwd
315 tail = cwd
316 if sys.platform == 'win32':
316 if sys.platform == 'win32':
317 if len(cwd) < 4:
317 if len(cwd) < 4:
318 return cwd
318 return cwd
319 drivepart,tail = os.path.splitdrive(cwd)
319 drivepart,tail = os.path.splitdrive(cwd)
320
320
321
321
322 parts = tail.split('/')
322 parts = tail.split('/')
323 if len(parts) > 2:
323 if len(parts) > 2:
324 tail = '/'.join(parts[-2:])
324 tail = '/'.join(parts[-2:])
325
325
326 return (drivepart + (
326 return (drivepart + (
327 cwd == '/' and '/' or tail))
327 cwd == '/' and '/' or tail))
328
328
329
329
330 # This function is used by ipython in a lot of places to make system calls.
330 # This function is used by ipython in a lot of places to make system calls.
331 # We need it to be slightly different under win32, due to the vagaries of
331 # We need it to be slightly different under win32, due to the vagaries of
332 # 'network shares'. A win32 override is below.
332 # 'network shares'. A win32 override is below.
333
333
334 def shell(cmd,verbose=0,debug=0,header=''):
334 def shell(cmd,verbose=0,debug=0,header=''):
335 """Execute a command in the system shell, always return None.
335 """Execute a command in the system shell, always return None.
336
336
337 Options:
337 Options:
338
338
339 - verbose (0): print the command to be executed.
339 - verbose (0): print the command to be executed.
340
340
341 - debug (0): only print, do not actually execute.
341 - debug (0): only print, do not actually execute.
342
342
343 - header (''): Header to print on screen prior to the executed command (it
343 - header (''): Header to print on screen prior to the executed command (it
344 is only prepended to the command, no newlines are added).
344 is only prepended to the command, no newlines are added).
345
345
346 Note: this is similar to genutils.system(), but it returns None so it can
346 Note: this is similar to genutils.system(), but it returns None so it can
347 be conveniently used in interactive loops without getting the return value
347 be conveniently used in interactive loops without getting the return value
348 (typically 0) printed many times."""
348 (typically 0) printed many times."""
349
349
350 stat = 0
350 stat = 0
351 if verbose or debug: print header+cmd
351 if verbose or debug: print header+cmd
352 # flush stdout so we don't mangle python's buffering
352 # flush stdout so we don't mangle python's buffering
353 sys.stdout.flush()
353 sys.stdout.flush()
354
354
355 if not debug:
355 if not debug:
356 platutils.set_term_title("IPy " + cmd)
356 platutils.set_term_title("IPy " + cmd)
357 os.system(cmd)
357 os.system(cmd)
358 platutils.set_term_title("IPy " + abbrev_cwd())
358 platutils.set_term_title("IPy " + abbrev_cwd())
359
359
360 # override shell() for win32 to deal with network shares
360 # override shell() for win32 to deal with network shares
361 if os.name in ('nt','dos'):
361 if os.name in ('nt','dos'):
362
362
363 shell_ori = shell
363 shell_ori = shell
364
364
365 def shell(cmd,verbose=0,debug=0,header=''):
365 def shell(cmd,verbose=0,debug=0,header=''):
366 if os.getcwd().startswith(r"\\"):
366 if os.getcwd().startswith(r"\\"):
367 path = os.getcwd()
367 path = os.getcwd()
368 # change to c drive (cannot be on UNC-share when issuing os.system,
368 # change to c drive (cannot be on UNC-share when issuing os.system,
369 # as cmd.exe cannot handle UNC addresses)
369 # as cmd.exe cannot handle UNC addresses)
370 os.chdir("c:")
370 os.chdir("c:")
371 # issue pushd to the UNC-share and then run the command
371 # issue pushd to the UNC-share and then run the command
372 try:
372 try:
373 shell_ori('"pushd %s&&"'%path+cmd,verbose,debug,header)
373 shell_ori('"pushd %s&&"'%path+cmd,verbose,debug,header)
374 finally:
374 finally:
375 os.chdir(path)
375 os.chdir(path)
376 else:
376 else:
377 shell_ori(cmd,verbose,debug,header)
377 shell_ori(cmd,verbose,debug,header)
378
378
379 shell.__doc__ = shell_ori.__doc__
379 shell.__doc__ = shell_ori.__doc__
380
380
381 def getoutput(cmd,verbose=0,debug=0,header='',split=0):
381 def getoutput(cmd,verbose=0,debug=0,header='',split=0):
382 """Dummy substitute for perl's backquotes.
382 """Dummy substitute for perl's backquotes.
383
383
384 Executes a command and returns the output.
384 Executes a command and returns the output.
385
385
386 Accepts the same arguments as system(), plus:
386 Accepts the same arguments as system(), plus:
387
387
388 - split(0): if true, the output is returned as a list split on newlines.
388 - split(0): if true, the output is returned as a list split on newlines.
389
389
390 Note: a stateful version of this function is available through the
390 Note: a stateful version of this function is available through the
391 SystemExec class.
391 SystemExec class.
392
392
393 This is pretty much deprecated and rarely used,
393 This is pretty much deprecated and rarely used,
394 genutils.getoutputerror may be what you need.
394 genutils.getoutputerror may be what you need.
395
395
396 """
396 """
397
397
398 if verbose or debug: print header+cmd
398 if verbose or debug: print header+cmd
399 if not debug:
399 if not debug:
400 output = os.popen(cmd).read()
400 output = os.popen(cmd).read()
401 # stipping last \n is here for backwards compat.
401 # stipping last \n is here for backwards compat.
402 if output.endswith('\n'):
402 if output.endswith('\n'):
403 output = output[:-1]
403 output = output[:-1]
404 if split:
404 if split:
405 return output.split('\n')
405 return output.split('\n')
406 else:
406 else:
407 return output
407 return output
408
408
409 def getoutputerror(cmd,verbose=0,debug=0,header='',split=0):
409 def getoutputerror(cmd,verbose=0,debug=0,header='',split=0):
410 """Return (standard output,standard error) of executing cmd in a shell.
410 """Return (standard output,standard error) of executing cmd in a shell.
411
411
412 Accepts the same arguments as system(), plus:
412 Accepts the same arguments as system(), plus:
413
413
414 - split(0): if true, each of stdout/err is returned as a list split on
414 - split(0): if true, each of stdout/err is returned as a list split on
415 newlines.
415 newlines.
416
416
417 Note: a stateful version of this function is available through the
417 Note: a stateful version of this function is available through the
418 SystemExec class."""
418 SystemExec class."""
419
419
420 if verbose or debug: print header+cmd
420 if verbose or debug: print header+cmd
421 if not cmd:
421 if not cmd:
422 if split:
422 if split:
423 return [],[]
423 return [],[]
424 else:
424 else:
425 return '',''
425 return '',''
426 if not debug:
426 if not debug:
427 pin,pout,perr = os.popen3(cmd)
427 pin,pout,perr = os.popen3(cmd)
428 tout = pout.read().rstrip()
428 tout = pout.read().rstrip()
429 terr = perr.read().rstrip()
429 terr = perr.read().rstrip()
430 pin.close()
430 pin.close()
431 pout.close()
431 pout.close()
432 perr.close()
432 perr.close()
433 if split:
433 if split:
434 return tout.split('\n'),terr.split('\n')
434 return tout.split('\n'),terr.split('\n')
435 else:
435 else:
436 return tout,terr
436 return tout,terr
437
437
438 # for compatibility with older naming conventions
438 # for compatibility with older naming conventions
439 xsys = system
439 xsys = system
440 bq = getoutput
440 bq = getoutput
441
441
442 class SystemExec:
442 class SystemExec:
443 """Access the system and getoutput functions through a stateful interface.
443 """Access the system and getoutput functions through a stateful interface.
444
444
445 Note: here we refer to the system and getoutput functions from this
445 Note: here we refer to the system and getoutput functions from this
446 library, not the ones from the standard python library.
446 library, not the ones from the standard python library.
447
447
448 This class offers the system and getoutput functions as methods, but the
448 This class offers the system and getoutput functions as methods, but the
449 verbose, debug and header parameters can be set for the instance (at
449 verbose, debug and header parameters can be set for the instance (at
450 creation time or later) so that they don't need to be specified on each
450 creation time or later) so that they don't need to be specified on each
451 call.
451 call.
452
452
453 For efficiency reasons, there's no way to override the parameters on a
453 For efficiency reasons, there's no way to override the parameters on a
454 per-call basis other than by setting instance attributes. If you need
454 per-call basis other than by setting instance attributes. If you need
455 local overrides, it's best to directly call system() or getoutput().
455 local overrides, it's best to directly call system() or getoutput().
456
456
457 The following names are provided as alternate options:
457 The following names are provided as alternate options:
458 - xsys: alias to system
458 - xsys: alias to system
459 - bq: alias to getoutput
459 - bq: alias to getoutput
460
460
461 An instance can then be created as:
461 An instance can then be created as:
462 >>> sysexec = SystemExec(verbose=1,debug=0,header='Calling: ')
462 >>> sysexec = SystemExec(verbose=1,debug=0,header='Calling: ')
463
463
464 And used as:
464 And used as:
465 >>> sysexec.xsys('pwd')
465 >>> sysexec.xsys('pwd')
466 >>> dirlist = sysexec.bq('ls -l')
466 >>> dirlist = sysexec.bq('ls -l')
467 """
467 """
468
468
469 def __init__(self,verbose=0,debug=0,header='',split=0):
469 def __init__(self,verbose=0,debug=0,header='',split=0):
470 """Specify the instance's values for verbose, debug and header."""
470 """Specify the instance's values for verbose, debug and header."""
471 setattr_list(self,'verbose debug header split')
471 setattr_list(self,'verbose debug header split')
472
472
473 def system(self,cmd):
473 def system(self,cmd):
474 """Stateful interface to system(), with the same keyword parameters."""
474 """Stateful interface to system(), with the same keyword parameters."""
475
475
476 system(cmd,self.verbose,self.debug,self.header)
476 system(cmd,self.verbose,self.debug,self.header)
477
477
478 def shell(self,cmd):
478 def shell(self,cmd):
479 """Stateful interface to shell(), with the same keyword parameters."""
479 """Stateful interface to shell(), with the same keyword parameters."""
480
480
481 shell(cmd,self.verbose,self.debug,self.header)
481 shell(cmd,self.verbose,self.debug,self.header)
482
482
483 xsys = system # alias
483 xsys = system # alias
484
484
485 def getoutput(self,cmd):
485 def getoutput(self,cmd):
486 """Stateful interface to getoutput()."""
486 """Stateful interface to getoutput()."""
487
487
488 return getoutput(cmd,self.verbose,self.debug,self.header,self.split)
488 return getoutput(cmd,self.verbose,self.debug,self.header,self.split)
489
489
490 def getoutputerror(self,cmd):
490 def getoutputerror(self,cmd):
491 """Stateful interface to getoutputerror()."""
491 """Stateful interface to getoutputerror()."""
492
492
493 return getoutputerror(cmd,self.verbose,self.debug,self.header,self.split)
493 return getoutputerror(cmd,self.verbose,self.debug,self.header,self.split)
494
494
495 bq = getoutput # alias
495 bq = getoutput # alias
496
496
497 #-----------------------------------------------------------------------------
497 #-----------------------------------------------------------------------------
498 def mutex_opts(dict,ex_op):
498 def mutex_opts(dict,ex_op):
499 """Check for presence of mutually exclusive keys in a dict.
499 """Check for presence of mutually exclusive keys in a dict.
500
500
501 Call: mutex_opts(dict,[[op1a,op1b],[op2a,op2b]...]"""
501 Call: mutex_opts(dict,[[op1a,op1b],[op2a,op2b]...]"""
502 for op1,op2 in ex_op:
502 for op1,op2 in ex_op:
503 if op1 in dict and op2 in dict:
503 if op1 in dict and op2 in dict:
504 raise ValueError,'\n*** ERROR in Arguments *** '\
504 raise ValueError,'\n*** ERROR in Arguments *** '\
505 'Options '+op1+' and '+op2+' are mutually exclusive.'
505 'Options '+op1+' and '+op2+' are mutually exclusive.'
506
506
507 #-----------------------------------------------------------------------------
507 #-----------------------------------------------------------------------------
508 def get_py_filename(name):
508 def get_py_filename(name):
509 """Return a valid python filename in the current directory.
509 """Return a valid python filename in the current directory.
510
510
511 If the given name is not a file, it adds '.py' and searches again.
511 If the given name is not a file, it adds '.py' and searches again.
512 Raises IOError with an informative message if the file isn't found."""
512 Raises IOError with an informative message if the file isn't found."""
513
513
514 name = os.path.expanduser(name)
514 name = os.path.expanduser(name)
515 if not os.path.isfile(name) and not name.endswith('.py'):
515 if not os.path.isfile(name) and not name.endswith('.py'):
516 name += '.py'
516 name += '.py'
517 if os.path.isfile(name):
517 if os.path.isfile(name):
518 return name
518 return name
519 else:
519 else:
520 raise IOError,'File `%s` not found.' % name
520 raise IOError,'File `%s` not found.' % name
521
521
522 #-----------------------------------------------------------------------------
522 #-----------------------------------------------------------------------------
523 def filefind(fname,alt_dirs = None):
523 def filefind(fname,alt_dirs = None):
524 """Return the given filename either in the current directory, if it
524 """Return the given filename either in the current directory, if it
525 exists, or in a specified list of directories.
525 exists, or in a specified list of directories.
526
526
527 ~ expansion is done on all file and directory names.
527 ~ expansion is done on all file and directory names.
528
528
529 Upon an unsuccessful search, raise an IOError exception."""
529 Upon an unsuccessful search, raise an IOError exception."""
530
530
531 if alt_dirs is None:
531 if alt_dirs is None:
532 try:
532 try:
533 alt_dirs = get_home_dir()
533 alt_dirs = get_home_dir()
534 except HomeDirError:
534 except HomeDirError:
535 alt_dirs = os.getcwd()
535 alt_dirs = os.getcwd()
536 search = [fname] + list_strings(alt_dirs)
536 search = [fname] + list_strings(alt_dirs)
537 search = map(os.path.expanduser,search)
537 search = map(os.path.expanduser,search)
538 #print 'search list for',fname,'list:',search # dbg
538 #print 'search list for',fname,'list:',search # dbg
539 fname = search[0]
539 fname = search[0]
540 if os.path.isfile(fname):
540 if os.path.isfile(fname):
541 return fname
541 return fname
542 for direc in search[1:]:
542 for direc in search[1:]:
543 testname = os.path.join(direc,fname)
543 testname = os.path.join(direc,fname)
544 #print 'testname',testname # dbg
544 #print 'testname',testname # dbg
545 if os.path.isfile(testname):
545 if os.path.isfile(testname):
546 return testname
546 return testname
547 raise IOError,'File' + `fname` + \
547 raise IOError,'File' + `fname` + \
548 ' not found in current or supplied directories:' + `alt_dirs`
548 ' not found in current or supplied directories:' + `alt_dirs`
549
549
550 #----------------------------------------------------------------------------
550 #----------------------------------------------------------------------------
551 def file_read(filename):
551 def file_read(filename):
552 """Read a file and close it. Returns the file source."""
552 """Read a file and close it. Returns the file source."""
553 fobj = open(filename,'r');
553 fobj = open(filename,'r');
554 source = fobj.read();
554 source = fobj.read();
555 fobj.close()
555 fobj.close()
556 return source
556 return source
557
557
558 def file_readlines(filename):
558 def file_readlines(filename):
559 """Read a file and close it. Returns the file source using readlines()."""
559 """Read a file and close it. Returns the file source using readlines()."""
560 fobj = open(filename,'r');
560 fobj = open(filename,'r');
561 lines = fobj.readlines();
561 lines = fobj.readlines();
562 fobj.close()
562 fobj.close()
563 return lines
563 return lines
564
564
565 #----------------------------------------------------------------------------
565 #----------------------------------------------------------------------------
566 def target_outdated(target,deps):
566 def target_outdated(target,deps):
567 """Determine whether a target is out of date.
567 """Determine whether a target is out of date.
568
568
569 target_outdated(target,deps) -> 1/0
569 target_outdated(target,deps) -> 1/0
570
570
571 deps: list of filenames which MUST exist.
571 deps: list of filenames which MUST exist.
572 target: single filename which may or may not exist.
572 target: single filename which may or may not exist.
573
573
574 If target doesn't exist or is older than any file listed in deps, return
574 If target doesn't exist or is older than any file listed in deps, return
575 true, otherwise return false.
575 true, otherwise return false.
576 """
576 """
577 try:
577 try:
578 target_time = os.path.getmtime(target)
578 target_time = os.path.getmtime(target)
579 except os.error:
579 except os.error:
580 return 1
580 return 1
581 for dep in deps:
581 for dep in deps:
582 dep_time = os.path.getmtime(dep)
582 dep_time = os.path.getmtime(dep)
583 if dep_time > target_time:
583 if dep_time > target_time:
584 #print "For target",target,"Dep failed:",dep # dbg
584 #print "For target",target,"Dep failed:",dep # dbg
585 #print "times (dep,tar):",dep_time,target_time # dbg
585 #print "times (dep,tar):",dep_time,target_time # dbg
586 return 1
586 return 1
587 return 0
587 return 0
588
588
589 #-----------------------------------------------------------------------------
589 #-----------------------------------------------------------------------------
590 def target_update(target,deps,cmd):
590 def target_update(target,deps,cmd):
591 """Update a target with a given command given a list of dependencies.
591 """Update a target with a given command given a list of dependencies.
592
592
593 target_update(target,deps,cmd) -> runs cmd if target is outdated.
593 target_update(target,deps,cmd) -> runs cmd if target is outdated.
594
594
595 This is just a wrapper around target_outdated() which calls the given
595 This is just a wrapper around target_outdated() which calls the given
596 command if target is outdated."""
596 command if target is outdated."""
597
597
598 if target_outdated(target,deps):
598 if target_outdated(target,deps):
599 xsys(cmd)
599 xsys(cmd)
600
600
601 #----------------------------------------------------------------------------
601 #----------------------------------------------------------------------------
602 def unquote_ends(istr):
602 def unquote_ends(istr):
603 """Remove a single pair of quotes from the endpoints of a string."""
603 """Remove a single pair of quotes from the endpoints of a string."""
604
604
605 if not istr:
605 if not istr:
606 return istr
606 return istr
607 if (istr[0]=="'" and istr[-1]=="'") or \
607 if (istr[0]=="'" and istr[-1]=="'") or \
608 (istr[0]=='"' and istr[-1]=='"'):
608 (istr[0]=='"' and istr[-1]=='"'):
609 return istr[1:-1]
609 return istr[1:-1]
610 else:
610 else:
611 return istr
611 return istr
612
612
613 #----------------------------------------------------------------------------
613 #----------------------------------------------------------------------------
614 def process_cmdline(argv,names=[],defaults={},usage=''):
614 def process_cmdline(argv,names=[],defaults={},usage=''):
615 """ Process command-line options and arguments.
615 """ Process command-line options and arguments.
616
616
617 Arguments:
617 Arguments:
618
618
619 - argv: list of arguments, typically sys.argv.
619 - argv: list of arguments, typically sys.argv.
620
620
621 - names: list of option names. See DPyGetOpt docs for details on options
621 - names: list of option names. See DPyGetOpt docs for details on options
622 syntax.
622 syntax.
623
623
624 - defaults: dict of default values.
624 - defaults: dict of default values.
625
625
626 - usage: optional usage notice to print if a wrong argument is passed.
626 - usage: optional usage notice to print if a wrong argument is passed.
627
627
628 Return a dict of options and a list of free arguments."""
628 Return a dict of options and a list of free arguments."""
629
629
630 getopt = DPyGetOpt.DPyGetOpt()
630 getopt = DPyGetOpt.DPyGetOpt()
631 getopt.setIgnoreCase(0)
631 getopt.setIgnoreCase(0)
632 getopt.parseConfiguration(names)
632 getopt.parseConfiguration(names)
633
633
634 try:
634 try:
635 getopt.processArguments(argv)
635 getopt.processArguments(argv)
636 except DPyGetOpt.ArgumentError, exc:
636 except DPyGetOpt.ArgumentError, exc:
637 print usage
637 print usage
638 warn('"%s"' % exc,level=4)
638 warn('"%s"' % exc,level=4)
639
639
640 defaults.update(getopt.optionValues)
640 defaults.update(getopt.optionValues)
641 args = getopt.freeValues
641 args = getopt.freeValues
642
642
643 return defaults,args
643 return defaults,args
644
644
645 #----------------------------------------------------------------------------
645 #----------------------------------------------------------------------------
646 def optstr2types(ostr):
646 def optstr2types(ostr):
647 """Convert a string of option names to a dict of type mappings.
647 """Convert a string of option names to a dict of type mappings.
648
648
649 optstr2types(str) -> {None:'string_opts',int:'int_opts',float:'float_opts'}
649 optstr2types(str) -> {None:'string_opts',int:'int_opts',float:'float_opts'}
650
650
651 This is used to get the types of all the options in a string formatted
651 This is used to get the types of all the options in a string formatted
652 with the conventions of DPyGetOpt. The 'type' None is used for options
652 with the conventions of DPyGetOpt. The 'type' None is used for options
653 which are strings (they need no further conversion). This function's main
653 which are strings (they need no further conversion). This function's main
654 use is to get a typemap for use with read_dict().
654 use is to get a typemap for use with read_dict().
655 """
655 """
656
656
657 typeconv = {None:'',int:'',float:''}
657 typeconv = {None:'',int:'',float:''}
658 typemap = {'s':None,'i':int,'f':float}
658 typemap = {'s':None,'i':int,'f':float}
659 opt_re = re.compile(r'([\w]*)([^:=]*:?=?)([sif]?)')
659 opt_re = re.compile(r'([\w]*)([^:=]*:?=?)([sif]?)')
660
660
661 for w in ostr.split():
661 for w in ostr.split():
662 oname,alias,otype = opt_re.match(w).groups()
662 oname,alias,otype = opt_re.match(w).groups()
663 if otype == '' or alias == '!': # simple switches are integers too
663 if otype == '' or alias == '!': # simple switches are integers too
664 otype = 'i'
664 otype = 'i'
665 typeconv[typemap[otype]] += oname + ' '
665 typeconv[typemap[otype]] += oname + ' '
666 return typeconv
666 return typeconv
667
667
668 #----------------------------------------------------------------------------
668 #----------------------------------------------------------------------------
669 def read_dict(filename,type_conv=None,**opt):
669 def read_dict(filename,type_conv=None,**opt):
670
670
671 """Read a dictionary of key=value pairs from an input file, optionally
671 """Read a dictionary of key=value pairs from an input file, optionally
672 performing conversions on the resulting values.
672 performing conversions on the resulting values.
673
673
674 read_dict(filename,type_conv,**opt) -> dict
674 read_dict(filename,type_conv,**opt) -> dict
675
675
676 Only one value per line is accepted, the format should be
676 Only one value per line is accepted, the format should be
677 # optional comments are ignored
677 # optional comments are ignored
678 key value\n
678 key value\n
679
679
680 Args:
680 Args:
681
681
682 - type_conv: A dictionary specifying which keys need to be converted to
682 - type_conv: A dictionary specifying which keys need to be converted to
683 which types. By default all keys are read as strings. This dictionary
683 which types. By default all keys are read as strings. This dictionary
684 should have as its keys valid conversion functions for strings
684 should have as its keys valid conversion functions for strings
685 (int,long,float,complex, or your own). The value for each key
685 (int,long,float,complex, or your own). The value for each key
686 (converter) should be a whitespace separated string containing the names
686 (converter) should be a whitespace separated string containing the names
687 of all the entries in the file to be converted using that function. For
687 of all the entries in the file to be converted using that function. For
688 keys to be left alone, use None as the conversion function (only needed
688 keys to be left alone, use None as the conversion function (only needed
689 with purge=1, see below).
689 with purge=1, see below).
690
690
691 - opt: dictionary with extra options as below (default in parens)
691 - opt: dictionary with extra options as below (default in parens)
692
692
693 purge(0): if set to 1, all keys *not* listed in type_conv are purged out
693 purge(0): if set to 1, all keys *not* listed in type_conv are purged out
694 of the dictionary to be returned. If purge is going to be used, the
694 of the dictionary to be returned. If purge is going to be used, the
695 set of keys to be left as strings also has to be explicitly specified
695 set of keys to be left as strings also has to be explicitly specified
696 using the (non-existent) conversion function None.
696 using the (non-existent) conversion function None.
697
697
698 fs(None): field separator. This is the key/value separator to be used
698 fs(None): field separator. This is the key/value separator to be used
699 when parsing the file. The None default means any whitespace [behavior
699 when parsing the file. The None default means any whitespace [behavior
700 of string.split()].
700 of string.split()].
701
701
702 strip(0): if 1, strip string values of leading/trailinig whitespace.
702 strip(0): if 1, strip string values of leading/trailinig whitespace.
703
703
704 warn(1): warning level if requested keys are not found in file.
704 warn(1): warning level if requested keys are not found in file.
705 - 0: silently ignore.
705 - 0: silently ignore.
706 - 1: inform but proceed.
706 - 1: inform but proceed.
707 - 2: raise KeyError exception.
707 - 2: raise KeyError exception.
708
708
709 no_empty(0): if 1, remove keys with whitespace strings as a value.
709 no_empty(0): if 1, remove keys with whitespace strings as a value.
710
710
711 unique([]): list of keys (or space separated string) which can't be
711 unique([]): list of keys (or space separated string) which can't be
712 repeated. If one such key is found in the file, each new instance
712 repeated. If one such key is found in the file, each new instance
713 overwrites the previous one. For keys not listed here, the behavior is
713 overwrites the previous one. For keys not listed here, the behavior is
714 to make a list of all appearances.
714 to make a list of all appearances.
715
715
716 Example:
716 Example:
717 If the input file test.ini has:
717 If the input file test.ini has:
718 i 3
718 i 3
719 x 4.5
719 x 4.5
720 y 5.5
720 y 5.5
721 s hi ho
721 s hi ho
722 Then:
722 Then:
723
723
724 >>> type_conv={int:'i',float:'x',None:'s'}
724 >>> type_conv={int:'i',float:'x',None:'s'}
725 >>> read_dict('test.ini')
725 >>> read_dict('test.ini')
726 {'i': '3', 's': 'hi ho', 'x': '4.5', 'y': '5.5'}
726 {'i': '3', 's': 'hi ho', 'x': '4.5', 'y': '5.5'}
727 >>> read_dict('test.ini',type_conv)
727 >>> read_dict('test.ini',type_conv)
728 {'i': 3, 's': 'hi ho', 'x': 4.5, 'y': '5.5'}
728 {'i': 3, 's': 'hi ho', 'x': 4.5, 'y': '5.5'}
729 >>> read_dict('test.ini',type_conv,purge=1)
729 >>> read_dict('test.ini',type_conv,purge=1)
730 {'i': 3, 's': 'hi ho', 'x': 4.5}
730 {'i': 3, 's': 'hi ho', 'x': 4.5}
731 """
731 """
732
732
733 # starting config
733 # starting config
734 opt.setdefault('purge',0)
734 opt.setdefault('purge',0)
735 opt.setdefault('fs',None) # field sep defaults to any whitespace
735 opt.setdefault('fs',None) # field sep defaults to any whitespace
736 opt.setdefault('strip',0)
736 opt.setdefault('strip',0)
737 opt.setdefault('warn',1)
737 opt.setdefault('warn',1)
738 opt.setdefault('no_empty',0)
738 opt.setdefault('no_empty',0)
739 opt.setdefault('unique','')
739 opt.setdefault('unique','')
740 if type(opt['unique']) in StringTypes:
740 if type(opt['unique']) in StringTypes:
741 unique_keys = qw(opt['unique'])
741 unique_keys = qw(opt['unique'])
742 elif type(opt['unique']) in (types.TupleType,types.ListType):
742 elif type(opt['unique']) in (types.TupleType,types.ListType):
743 unique_keys = opt['unique']
743 unique_keys = opt['unique']
744 else:
744 else:
745 raise ValueError, 'Unique keys must be given as a string, List or Tuple'
745 raise ValueError, 'Unique keys must be given as a string, List or Tuple'
746
746
747 dict = {}
747 dict = {}
748 # first read in table of values as strings
748 # first read in table of values as strings
749 file = open(filename,'r')
749 file = open(filename,'r')
750 for line in file.readlines():
750 for line in file.readlines():
751 line = line.strip()
751 line = line.strip()
752 if len(line) and line[0]=='#': continue
752 if len(line) and line[0]=='#': continue
753 if len(line)>0:
753 if len(line)>0:
754 lsplit = line.split(opt['fs'],1)
754 lsplit = line.split(opt['fs'],1)
755 try:
755 try:
756 key,val = lsplit
756 key,val = lsplit
757 except ValueError:
757 except ValueError:
758 key,val = lsplit[0],''
758 key,val = lsplit[0],''
759 key = key.strip()
759 key = key.strip()
760 if opt['strip']: val = val.strip()
760 if opt['strip']: val = val.strip()
761 if val == "''" or val == '""': val = ''
761 if val == "''" or val == '""': val = ''
762 if opt['no_empty'] and (val=='' or val.isspace()):
762 if opt['no_empty'] and (val=='' or val.isspace()):
763 continue
763 continue
764 # if a key is found more than once in the file, build a list
764 # if a key is found more than once in the file, build a list
765 # unless it's in the 'unique' list. In that case, last found in file
765 # unless it's in the 'unique' list. In that case, last found in file
766 # takes precedence. User beware.
766 # takes precedence. User beware.
767 try:
767 try:
768 if dict[key] and key in unique_keys:
768 if dict[key] and key in unique_keys:
769 dict[key] = val
769 dict[key] = val
770 elif type(dict[key]) is types.ListType:
770 elif type(dict[key]) is types.ListType:
771 dict[key].append(val)
771 dict[key].append(val)
772 else:
772 else:
773 dict[key] = [dict[key],val]
773 dict[key] = [dict[key],val]
774 except KeyError:
774 except KeyError:
775 dict[key] = val
775 dict[key] = val
776 # purge if requested
776 # purge if requested
777 if opt['purge']:
777 if opt['purge']:
778 accepted_keys = qwflat(type_conv.values())
778 accepted_keys = qwflat(type_conv.values())
779 for key in dict.keys():
779 for key in dict.keys():
780 if key in accepted_keys: continue
780 if key in accepted_keys: continue
781 del(dict[key])
781 del(dict[key])
782 # now convert if requested
782 # now convert if requested
783 if type_conv==None: return dict
783 if type_conv==None: return dict
784 conversions = type_conv.keys()
784 conversions = type_conv.keys()
785 try: conversions.remove(None)
785 try: conversions.remove(None)
786 except: pass
786 except: pass
787 for convert in conversions:
787 for convert in conversions:
788 for val in qw(type_conv[convert]):
788 for val in qw(type_conv[convert]):
789 try:
789 try:
790 dict[val] = convert(dict[val])
790 dict[val] = convert(dict[val])
791 except KeyError,e:
791 except KeyError,e:
792 if opt['warn'] == 0:
792 if opt['warn'] == 0:
793 pass
793 pass
794 elif opt['warn'] == 1:
794 elif opt['warn'] == 1:
795 print >>sys.stderr, 'Warning: key',val,\
795 print >>sys.stderr, 'Warning: key',val,\
796 'not found in file',filename
796 'not found in file',filename
797 elif opt['warn'] == 2:
797 elif opt['warn'] == 2:
798 raise KeyError,e
798 raise KeyError,e
799 else:
799 else:
800 raise ValueError,'Warning level must be 0,1 or 2'
800 raise ValueError,'Warning level must be 0,1 or 2'
801
801
802 return dict
802 return dict
803
803
804 #----------------------------------------------------------------------------
804 #----------------------------------------------------------------------------
805 def flag_calls(func):
805 def flag_calls(func):
806 """Wrap a function to detect and flag when it gets called.
806 """Wrap a function to detect and flag when it gets called.
807
807
808 This is a decorator which takes a function and wraps it in a function with
808 This is a decorator which takes a function and wraps it in a function with
809 a 'called' attribute. wrapper.called is initialized to False.
809 a 'called' attribute. wrapper.called is initialized to False.
810
810
811 The wrapper.called attribute is set to False right before each call to the
811 The wrapper.called attribute is set to False right before each call to the
812 wrapped function, so if the call fails it remains False. After the call
812 wrapped function, so if the call fails it remains False. After the call
813 completes, wrapper.called is set to True and the output is returned.
813 completes, wrapper.called is set to True and the output is returned.
814
814
815 Testing for truth in wrapper.called allows you to determine if a call to
815 Testing for truth in wrapper.called allows you to determine if a call to
816 func() was attempted and succeeded."""
816 func() was attempted and succeeded."""
817
817
818 def wrapper(*args,**kw):
818 def wrapper(*args,**kw):
819 wrapper.called = False
819 wrapper.called = False
820 out = func(*args,**kw)
820 out = func(*args,**kw)
821 wrapper.called = True
821 wrapper.called = True
822 return out
822 return out
823
823
824 wrapper.called = False
824 wrapper.called = False
825 wrapper.__doc__ = func.__doc__
825 wrapper.__doc__ = func.__doc__
826 return wrapper
826 return wrapper
827
827
828 #----------------------------------------------------------------------------
828 #----------------------------------------------------------------------------
829 def dhook_wrap(func,*a,**k):
829 def dhook_wrap(func,*a,**k):
830 """Wrap a function call in a sys.displayhook controller.
830 """Wrap a function call in a sys.displayhook controller.
831
831
832 Returns a wrapper around func which calls func, with all its arguments and
832 Returns a wrapper around func which calls func, with all its arguments and
833 keywords unmodified, using the default sys.displayhook. Since IPython
833 keywords unmodified, using the default sys.displayhook. Since IPython
834 modifies sys.displayhook, it breaks the behavior of certain systems that
834 modifies sys.displayhook, it breaks the behavior of certain systems that
835 rely on the default behavior, notably doctest.
835 rely on the default behavior, notably doctest.
836 """
836 """
837
837
838 def f(*a,**k):
838 def f(*a,**k):
839
839
840 dhook_s = sys.displayhook
840 dhook_s = sys.displayhook
841 sys.displayhook = sys.__displayhook__
841 sys.displayhook = sys.__displayhook__
842 try:
842 try:
843 out = func(*a,**k)
843 out = func(*a,**k)
844 finally:
844 finally:
845 sys.displayhook = dhook_s
845 sys.displayhook = dhook_s
846
846
847 return out
847 return out
848
848
849 f.__doc__ = func.__doc__
849 f.__doc__ = func.__doc__
850 return f
850 return f
851
851
852 #----------------------------------------------------------------------------
852 #----------------------------------------------------------------------------
853 def doctest_reload():
853 def doctest_reload():
854 """Properly reload doctest to reuse it interactively.
854 """Properly reload doctest to reuse it interactively.
855
855
856 This routine:
856 This routine:
857
857
858 - reloads doctest
858 - reloads doctest
859
859
860 - resets its global 'master' attribute to None, so that multiple uses of
860 - resets its global 'master' attribute to None, so that multiple uses of
861 the module interactively don't produce cumulative reports.
861 the module interactively don't produce cumulative reports.
862
862
863 - Monkeypatches its core test runner method to protect it from IPython's
863 - Monkeypatches its core test runner method to protect it from IPython's
864 modified displayhook. Doctest expects the default displayhook behavior
864 modified displayhook. Doctest expects the default displayhook behavior
865 deep down, so our modification breaks it completely. For this reason, a
865 deep down, so our modification breaks it completely. For this reason, a
866 hard monkeypatch seems like a reasonable solution rather than asking
866 hard monkeypatch seems like a reasonable solution rather than asking
867 users to manually use a different doctest runner when under IPython."""
867 users to manually use a different doctest runner when under IPython."""
868
868
869 import doctest
869 import doctest
870 reload(doctest)
870 reload(doctest)
871 doctest.master=None
871 doctest.master=None
872
872
873 try:
873 try:
874 doctest.DocTestRunner
874 doctest.DocTestRunner
875 except AttributeError:
875 except AttributeError:
876 # This is only for python 2.3 compatibility, remove once we move to
876 # This is only for python 2.3 compatibility, remove once we move to
877 # 2.4 only.
877 # 2.4 only.
878 pass
878 pass
879 else:
879 else:
880 doctest.DocTestRunner.run = dhook_wrap(doctest.DocTestRunner.run)
880 doctest.DocTestRunner.run = dhook_wrap(doctest.DocTestRunner.run)
881
881
882 #----------------------------------------------------------------------------
882 #----------------------------------------------------------------------------
883 class HomeDirError(Error):
883 class HomeDirError(Error):
884 pass
884 pass
885
885
886 def get_home_dir():
886 def get_home_dir():
887 """Return the closest possible equivalent to a 'home' directory.
887 """Return the closest possible equivalent to a 'home' directory.
888
888
889 We first try $HOME. Absent that, on NT it's $HOMEDRIVE\$HOMEPATH.
889 We first try $HOME. Absent that, on NT it's $HOMEDRIVE\$HOMEPATH.
890
890
891 Currently only Posix and NT are implemented, a HomeDirError exception is
891 Currently only Posix and NT are implemented, a HomeDirError exception is
892 raised for all other OSes. """
892 raised for all other OSes. """
893
893
894 isdir = os.path.isdir
894 isdir = os.path.isdir
895 env = os.environ
895 env = os.environ
896
896
897 # first, check py2exe distribution root directory for _ipython.
897 # first, check py2exe distribution root directory for _ipython.
898 # This overrides all. Normally does not exist.
898 # This overrides all. Normally does not exist.
899
899
900 if '\\library.zip\\' in IPython.__file__.lower():
900 if '\\library.zip\\' in IPython.__file__.lower():
901 root, rest = IPython.__file__.lower().split('library.zip')
901 root, rest = IPython.__file__.lower().split('library.zip')
902 if isdir(root + '_ipython'):
902 if isdir(root + '_ipython'):
903 os.environ["IPYKITROOT"] = root.rstrip('\\')
903 os.environ["IPYKITROOT"] = root.rstrip('\\')
904 return root
904 return root
905
905
906 try:
906 try:
907 homedir = env['HOME']
907 homedir = env['HOME']
908 if not isdir(homedir):
908 if not isdir(homedir):
909 # in case a user stuck some string which does NOT resolve to a
909 # in case a user stuck some string which does NOT resolve to a
910 # valid path, it's as good as if we hadn't foud it
910 # valid path, it's as good as if we hadn't foud it
911 raise KeyError
911 raise KeyError
912 return homedir
912 return homedir
913 except KeyError:
913 except KeyError:
914 if os.name == 'posix':
914 if os.name == 'posix':
915 raise HomeDirError,'undefined $HOME, IPython can not proceed.'
915 raise HomeDirError,'undefined $HOME, IPython can not proceed.'
916 elif os.name == 'nt':
916 elif os.name == 'nt':
917 # For some strange reason, win9x returns 'nt' for os.name.
917 # For some strange reason, win9x returns 'nt' for os.name.
918 try:
918 try:
919 homedir = os.path.join(env['HOMEDRIVE'],env['HOMEPATH'])
919 homedir = os.path.join(env['HOMEDRIVE'],env['HOMEPATH'])
920 if not isdir(homedir):
920 if not isdir(homedir):
921 homedir = os.path.join(env['USERPROFILE'])
921 homedir = os.path.join(env['USERPROFILE'])
922 if not isdir(homedir):
922 if not isdir(homedir):
923 raise HomeDirError
923 raise HomeDirError
924 return homedir
924 return homedir
925 except:
925 except:
926 try:
926 try:
927 # Use the registry to get the 'My Documents' folder.
927 # Use the registry to get the 'My Documents' folder.
928 import _winreg as wreg
928 import _winreg as wreg
929 key = wreg.OpenKey(wreg.HKEY_CURRENT_USER,
929 key = wreg.OpenKey(wreg.HKEY_CURRENT_USER,
930 "Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders")
930 "Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders")
931 homedir = wreg.QueryValueEx(key,'Personal')[0]
931 homedir = wreg.QueryValueEx(key,'Personal')[0]
932 key.Close()
932 key.Close()
933 if not isdir(homedir):
933 if not isdir(homedir):
934 e = ('Invalid "Personal" folder registry key '
934 e = ('Invalid "Personal" folder registry key '
935 'typically "My Documents".\n'
935 'typically "My Documents".\n'
936 'Value: %s\n'
936 'Value: %s\n'
937 'This is not a valid directory on your system.' %
937 'This is not a valid directory on your system.' %
938 homedir)
938 homedir)
939 raise HomeDirError(e)
939 raise HomeDirError(e)
940 return homedir
940 return homedir
941 except HomeDirError:
941 except HomeDirError:
942 raise
942 raise
943 except:
943 except:
944 return 'C:\\'
944 return 'C:\\'
945 elif os.name == 'dos':
945 elif os.name == 'dos':
946 # Desperate, may do absurd things in classic MacOS. May work under DOS.
946 # Desperate, may do absurd things in classic MacOS. May work under DOS.
947 return 'C:\\'
947 return 'C:\\'
948 else:
948 else:
949 raise HomeDirError,'support for your operating system not implemented.'
949 raise HomeDirError,'support for your operating system not implemented.'
950
950
951 #****************************************************************************
951 #****************************************************************************
952 # strings and text
952 # strings and text
953
953
954 class LSString(str):
954 class LSString(str):
955 """String derivative with a special access attributes.
955 """String derivative with a special access attributes.
956
956
957 These are normal strings, but with the special attributes:
957 These are normal strings, but with the special attributes:
958
958
959 .l (or .list) : value as list (split on newlines).
959 .l (or .list) : value as list (split on newlines).
960 .n (or .nlstr): original value (the string itself).
960 .n (or .nlstr): original value (the string itself).
961 .s (or .spstr): value as whitespace-separated string.
961 .s (or .spstr): value as whitespace-separated string.
962 .p (or .paths): list of path objects
962 .p (or .paths): list of path objects
963
963
964 Any values which require transformations are computed only once and
964 Any values which require transformations are computed only once and
965 cached.
965 cached.
966
966
967 Such strings are very useful to efficiently interact with the shell, which
967 Such strings are very useful to efficiently interact with the shell, which
968 typically only understands whitespace-separated options for commands."""
968 typically only understands whitespace-separated options for commands."""
969
969
970 def get_list(self):
970 def get_list(self):
971 try:
971 try:
972 return self.__list
972 return self.__list
973 except AttributeError:
973 except AttributeError:
974 self.__list = self.split('\n')
974 self.__list = self.split('\n')
975 return self.__list
975 return self.__list
976
976
977 l = list = property(get_list)
977 l = list = property(get_list)
978
978
979 def get_spstr(self):
979 def get_spstr(self):
980 try:
980 try:
981 return self.__spstr
981 return self.__spstr
982 except AttributeError:
982 except AttributeError:
983 self.__spstr = self.replace('\n',' ')
983 self.__spstr = self.replace('\n',' ')
984 return self.__spstr
984 return self.__spstr
985
985
986 s = spstr = property(get_spstr)
986 s = spstr = property(get_spstr)
987
987
988 def get_nlstr(self):
988 def get_nlstr(self):
989 return self
989 return self
990
990
991 n = nlstr = property(get_nlstr)
991 n = nlstr = property(get_nlstr)
992
992
993 def get_paths(self):
993 def get_paths(self):
994 try:
994 try:
995 return self.__paths
995 return self.__paths
996 except AttributeError:
996 except AttributeError:
997 self.__paths = [path(p) for p in self.split('\n') if os.path.exists(p)]
997 self.__paths = [path(p) for p in self.split('\n') if os.path.exists(p)]
998 return self.__paths
998 return self.__paths
999
999
1000 p = paths = property(get_paths)
1000 p = paths = property(get_paths)
1001
1001
1002 def print_lsstring(arg):
1002 def print_lsstring(arg):
1003 """ Prettier (non-repr-like) and more informative printer for LSString """
1003 """ Prettier (non-repr-like) and more informative printer for LSString """
1004 print "LSString (.p, .n, .l, .s available). Value:"
1004 print "LSString (.p, .n, .l, .s available). Value:"
1005 print arg
1005 print arg
1006
1006
1007 print_lsstring = result_display.when_type(LSString)(print_lsstring)
1007 print_lsstring = result_display.when_type(LSString)(print_lsstring)
1008
1008
1009 #----------------------------------------------------------------------------
1009 #----------------------------------------------------------------------------
1010 class SList(list):
1010 class SList(list):
1011 """List derivative with a special access attributes.
1011 """List derivative with a special access attributes.
1012
1012
1013 These are normal lists, but with the special attributes:
1013 These are normal lists, but with the special attributes:
1014
1014
1015 .l (or .list) : value as list (the list itself).
1015 .l (or .list) : value as list (the list itself).
1016 .n (or .nlstr): value as a string, joined on newlines.
1016 .n (or .nlstr): value as a string, joined on newlines.
1017 .s (or .spstr): value as a string, joined on spaces.
1017 .s (or .spstr): value as a string, joined on spaces.
1018 .p (or .paths): list of path objects
1018 .p (or .paths): list of path objects
1019
1019
1020 Any values which require transformations are computed only once and
1020 Any values which require transformations are computed only once and
1021 cached."""
1021 cached."""
1022
1022
1023 def get_list(self):
1023 def get_list(self):
1024 return self
1024 return self
1025
1025
1026 l = list = property(get_list)
1026 l = list = property(get_list)
1027
1027
1028 def get_spstr(self):
1028 def get_spstr(self):
1029 try:
1029 try:
1030 return self.__spstr
1030 return self.__spstr
1031 except AttributeError:
1031 except AttributeError:
1032 self.__spstr = ' '.join(self)
1032 self.__spstr = ' '.join(self)
1033 return self.__spstr
1033 return self.__spstr
1034
1034
1035 s = spstr = property(get_spstr)
1035 s = spstr = property(get_spstr)
1036
1036
1037 def get_nlstr(self):
1037 def get_nlstr(self):
1038 try:
1038 try:
1039 return self.__nlstr
1039 return self.__nlstr
1040 except AttributeError:
1040 except AttributeError:
1041 self.__nlstr = '\n'.join(self)
1041 self.__nlstr = '\n'.join(self)
1042 return self.__nlstr
1042 return self.__nlstr
1043
1043
1044 n = nlstr = property(get_nlstr)
1044 n = nlstr = property(get_nlstr)
1045
1045
1046 def get_paths(self):
1046 def get_paths(self):
1047 try:
1047 try:
1048 return self.__paths
1048 return self.__paths
1049 except AttributeError:
1049 except AttributeError:
1050 self.__paths = [path(p) for p in self if os.path.exists(p)]
1050 self.__paths = [path(p) for p in self if os.path.exists(p)]
1051 return self.__paths
1051 return self.__paths
1052
1052
1053 p = paths = property(get_paths)
1053 p = paths = property(get_paths)
1054
1054
1055 def grep(self, pattern, prune = False):
1055 def grep(self, pattern, prune = False, field = None):
1056 """ Return all strings matching 'pattern' (a regex or callable)
1056 """ Return all strings matching 'pattern' (a regex or callable)
1057
1057
1058 This is case-insensitive. If prune is true, return all items
1058 This is case-insensitive. If prune is true, return all items
1059 NOT matching the pattern.
1059 NOT matching the pattern.
1060
1060
1061 If field is specified, the match must occur in the specified
1062 whitespace-separated field.
1063
1061 Examples::
1064 Examples::
1062
1065
1063 a.grep( lambda x: x.startswith('C') )
1066 a.grep( lambda x: x.startswith('C') )
1064 a.grep('Cha.*log', prune=1)
1067 a.grep('Cha.*log', prune=1)
1068 a.grep('chm', field=-1)
1065 """
1069 """
1070
1071 def match_target(s):
1072 if field is None:
1073 return s
1074 parts = s.split()
1075 try:
1076 tgt = parts[field]
1077 return tgt
1078 except IndexError:
1079 return ""
1080
1066 if isinstance(pattern, basestring):
1081 if isinstance(pattern, basestring):
1067 pred = lambda x : re.search(pattern, x, re.IGNORECASE)
1082 pred = lambda x : re.search(pattern, x, re.IGNORECASE)
1068 else:
1083 else:
1069 pred = pattern
1084 pred = pattern
1070 if not prune:
1085 if not prune:
1071 return SList([el for el in self if pred(el)])
1086 return SList([el for el in self if pred(match_target(el))])
1072 else:
1087 else:
1073 return SList([el for el in self if not pred(el)])
1088 return SList([el for el in self if not pred(match_target(el))])
1074 def fields(self, *fields):
1089 def fields(self, *fields):
1075 """ Collect whitespace-separated fields from string list
1090 """ Collect whitespace-separated fields from string list
1076
1091
1077 Allows quick awk-like usage of string lists.
1092 Allows quick awk-like usage of string lists.
1078
1093
1079 Example data (in var a, created by 'a = !ls -l')::
1094 Example data (in var a, created by 'a = !ls -l')::
1080 -rwxrwxrwx 1 ville None 18 Dec 14 2006 ChangeLog
1095 -rwxrwxrwx 1 ville None 18 Dec 14 2006 ChangeLog
1081 drwxrwxrwx+ 6 ville None 0 Oct 24 18:05 IPython
1096 drwxrwxrwx+ 6 ville None 0 Oct 24 18:05 IPython
1082
1097
1083 a.fields(0) is ['-rwxrwxrwx', 'drwxrwxrwx+']
1098 a.fields(0) is ['-rwxrwxrwx', 'drwxrwxrwx+']
1084 a.fields(1,0) is ['1 -rwxrwxrwx', '6 drwxrwxrwx+']
1099 a.fields(1,0) is ['1 -rwxrwxrwx', '6 drwxrwxrwx+']
1085 (note the joining by space).
1100 (note the joining by space).
1101 a.fields(-1) is ['ChangeLog', 'IPython']
1086
1102
1087 IndexErrors are ignored.
1103 IndexErrors are ignored.
1088
1104
1089 Without args, fields() just split()'s the strings.
1105 Without args, fields() just split()'s the strings.
1090 """
1106 """
1091 if len(fields) == 0:
1107 if len(fields) == 0:
1092 return [el.split() for el in self]
1108 return [el.split() for el in self]
1093
1109
1094 res = SList()
1110 res = SList()
1095 for el in [f.split() for f in self]:
1111 for el in [f.split() for f in self]:
1096 lineparts = []
1112 lineparts = []
1097
1113
1098 for fd in fields:
1114 for fd in fields:
1099 try:
1115 try:
1100 lineparts.append(el[fd])
1116 lineparts.append(el[fd])
1101 except IndexError:
1117 except IndexError:
1102 pass
1118 pass
1103 if lineparts:
1119 if lineparts:
1104 res.append(" ".join(lineparts))
1120 res.append(" ".join(lineparts))
1105
1121
1106 return res
1122 return res
1107
1123
1108
1124
1109
1125
1110
1126
1111
1127
1112 def print_slist(arg):
1128 def print_slist(arg):
1113 """ Prettier (non-repr-like) and more informative printer for SList """
1129 """ Prettier (non-repr-like) and more informative printer for SList """
1114 print "SList (.p, .n, .l, .s, .grep(), .fields() available). Value:"
1130 print "SList (.p, .n, .l, .s, .grep(), .fields() available). Value:"
1115 nlprint(arg)
1131 nlprint(arg)
1116
1132
1117 print_slist = result_display.when_type(SList)(print_slist)
1133 print_slist = result_display.when_type(SList)(print_slist)
1118
1134
1119
1135
1120
1136
1121 #----------------------------------------------------------------------------
1137 #----------------------------------------------------------------------------
1122 def esc_quotes(strng):
1138 def esc_quotes(strng):
1123 """Return the input string with single and double quotes escaped out"""
1139 """Return the input string with single and double quotes escaped out"""
1124
1140
1125 return strng.replace('"','\\"').replace("'","\\'")
1141 return strng.replace('"','\\"').replace("'","\\'")
1126
1142
1127 #----------------------------------------------------------------------------
1143 #----------------------------------------------------------------------------
1128 def make_quoted_expr(s):
1144 def make_quoted_expr(s):
1129 """Return string s in appropriate quotes, using raw string if possible.
1145 """Return string s in appropriate quotes, using raw string if possible.
1130
1146
1131 Effectively this turns string: cd \ao\ao\
1147 Effectively this turns string: cd \ao\ao\
1132 to: r"cd \ao\ao\_"[:-1]
1148 to: r"cd \ao\ao\_"[:-1]
1133
1149
1134 Note the use of raw string and padding at the end to allow trailing backslash.
1150 Note the use of raw string and padding at the end to allow trailing backslash.
1135
1151
1136 """
1152 """
1137
1153
1138 tail = ''
1154 tail = ''
1139 tailpadding = ''
1155 tailpadding = ''
1140 raw = ''
1156 raw = ''
1141 if "\\" in s:
1157 if "\\" in s:
1142 raw = 'r'
1158 raw = 'r'
1143 if s.endswith('\\'):
1159 if s.endswith('\\'):
1144 tail = '[:-1]'
1160 tail = '[:-1]'
1145 tailpadding = '_'
1161 tailpadding = '_'
1146 if '"' not in s:
1162 if '"' not in s:
1147 quote = '"'
1163 quote = '"'
1148 elif "'" not in s:
1164 elif "'" not in s:
1149 quote = "'"
1165 quote = "'"
1150 elif '"""' not in s and not s.endswith('"'):
1166 elif '"""' not in s and not s.endswith('"'):
1151 quote = '"""'
1167 quote = '"""'
1152 elif "'''" not in s and not s.endswith("'"):
1168 elif "'''" not in s and not s.endswith("'"):
1153 quote = "'''"
1169 quote = "'''"
1154 else:
1170 else:
1155 # give up, backslash-escaped string will do
1171 # give up, backslash-escaped string will do
1156 return '"%s"' % esc_quotes(s)
1172 return '"%s"' % esc_quotes(s)
1157 res = raw + quote + s + tailpadding + quote + tail
1173 res = raw + quote + s + tailpadding + quote + tail
1158 return res
1174 return res
1159
1175
1160
1176
1161 #----------------------------------------------------------------------------
1177 #----------------------------------------------------------------------------
1162 def raw_input_multi(header='', ps1='==> ', ps2='..> ',terminate_str = '.'):
1178 def raw_input_multi(header='', ps1='==> ', ps2='..> ',terminate_str = '.'):
1163 """Take multiple lines of input.
1179 """Take multiple lines of input.
1164
1180
1165 A list with each line of input as a separate element is returned when a
1181 A list with each line of input as a separate element is returned when a
1166 termination string is entered (defaults to a single '.'). Input can also
1182 termination string is entered (defaults to a single '.'). Input can also
1167 terminate via EOF (^D in Unix, ^Z-RET in Windows).
1183 terminate via EOF (^D in Unix, ^Z-RET in Windows).
1168
1184
1169 Lines of input which end in \\ are joined into single entries (and a
1185 Lines of input which end in \\ are joined into single entries (and a
1170 secondary continuation prompt is issued as long as the user terminates
1186 secondary continuation prompt is issued as long as the user terminates
1171 lines with \\). This allows entering very long strings which are still
1187 lines with \\). This allows entering very long strings which are still
1172 meant to be treated as single entities.
1188 meant to be treated as single entities.
1173 """
1189 """
1174
1190
1175 try:
1191 try:
1176 if header:
1192 if header:
1177 header += '\n'
1193 header += '\n'
1178 lines = [raw_input(header + ps1)]
1194 lines = [raw_input(header + ps1)]
1179 except EOFError:
1195 except EOFError:
1180 return []
1196 return []
1181 terminate = [terminate_str]
1197 terminate = [terminate_str]
1182 try:
1198 try:
1183 while lines[-1:] != terminate:
1199 while lines[-1:] != terminate:
1184 new_line = raw_input(ps1)
1200 new_line = raw_input(ps1)
1185 while new_line.endswith('\\'):
1201 while new_line.endswith('\\'):
1186 new_line = new_line[:-1] + raw_input(ps2)
1202 new_line = new_line[:-1] + raw_input(ps2)
1187 lines.append(new_line)
1203 lines.append(new_line)
1188
1204
1189 return lines[:-1] # don't return the termination command
1205 return lines[:-1] # don't return the termination command
1190 except EOFError:
1206 except EOFError:
1191 print
1207 print
1192 return lines
1208 return lines
1193
1209
1194 #----------------------------------------------------------------------------
1210 #----------------------------------------------------------------------------
1195 def raw_input_ext(prompt='', ps2='... '):
1211 def raw_input_ext(prompt='', ps2='... '):
1196 """Similar to raw_input(), but accepts extended lines if input ends with \\."""
1212 """Similar to raw_input(), but accepts extended lines if input ends with \\."""
1197
1213
1198 line = raw_input(prompt)
1214 line = raw_input(prompt)
1199 while line.endswith('\\'):
1215 while line.endswith('\\'):
1200 line = line[:-1] + raw_input(ps2)
1216 line = line[:-1] + raw_input(ps2)
1201 return line
1217 return line
1202
1218
1203 #----------------------------------------------------------------------------
1219 #----------------------------------------------------------------------------
1204 def ask_yes_no(prompt,default=None):
1220 def ask_yes_no(prompt,default=None):
1205 """Asks a question and returns a boolean (y/n) answer.
1221 """Asks a question and returns a boolean (y/n) answer.
1206
1222
1207 If default is given (one of 'y','n'), it is used if the user input is
1223 If default is given (one of 'y','n'), it is used if the user input is
1208 empty. Otherwise the question is repeated until an answer is given.
1224 empty. Otherwise the question is repeated until an answer is given.
1209
1225
1210 An EOF is treated as the default answer. If there is no default, an
1226 An EOF is treated as the default answer. If there is no default, an
1211 exception is raised to prevent infinite loops.
1227 exception is raised to prevent infinite loops.
1212
1228
1213 Valid answers are: y/yes/n/no (match is not case sensitive)."""
1229 Valid answers are: y/yes/n/no (match is not case sensitive)."""
1214
1230
1215 answers = {'y':True,'n':False,'yes':True,'no':False}
1231 answers = {'y':True,'n':False,'yes':True,'no':False}
1216 ans = None
1232 ans = None
1217 while ans not in answers.keys():
1233 while ans not in answers.keys():
1218 try:
1234 try:
1219 ans = raw_input(prompt+' ').lower()
1235 ans = raw_input(prompt+' ').lower()
1220 if not ans: # response was an empty string
1236 if not ans: # response was an empty string
1221 ans = default
1237 ans = default
1222 except KeyboardInterrupt:
1238 except KeyboardInterrupt:
1223 pass
1239 pass
1224 except EOFError:
1240 except EOFError:
1225 if default in answers.keys():
1241 if default in answers.keys():
1226 ans = default
1242 ans = default
1227 print
1243 print
1228 else:
1244 else:
1229 raise
1245 raise
1230
1246
1231 return answers[ans]
1247 return answers[ans]
1232
1248
1233 #----------------------------------------------------------------------------
1249 #----------------------------------------------------------------------------
1234 def marquee(txt='',width=78,mark='*'):
1250 def marquee(txt='',width=78,mark='*'):
1235 """Return the input string centered in a 'marquee'."""
1251 """Return the input string centered in a 'marquee'."""
1236 if not txt:
1252 if not txt:
1237 return (mark*width)[:width]
1253 return (mark*width)[:width]
1238 nmark = (width-len(txt)-2)/len(mark)/2
1254 nmark = (width-len(txt)-2)/len(mark)/2
1239 if nmark < 0: nmark =0
1255 if nmark < 0: nmark =0
1240 marks = mark*nmark
1256 marks = mark*nmark
1241 return '%s %s %s' % (marks,txt,marks)
1257 return '%s %s %s' % (marks,txt,marks)
1242
1258
1243 #----------------------------------------------------------------------------
1259 #----------------------------------------------------------------------------
1244 class EvalDict:
1260 class EvalDict:
1245 """
1261 """
1246 Emulate a dict which evaluates its contents in the caller's frame.
1262 Emulate a dict which evaluates its contents in the caller's frame.
1247
1263
1248 Usage:
1264 Usage:
1249 >>>number = 19
1265 >>>number = 19
1250 >>>text = "python"
1266 >>>text = "python"
1251 >>>print "%(text.capitalize())s %(number/9.0).1f rules!" % EvalDict()
1267 >>>print "%(text.capitalize())s %(number/9.0).1f rules!" % EvalDict()
1252 """
1268 """
1253
1269
1254 # This version is due to sismex01@hebmex.com on c.l.py, and is basically a
1270 # This version is due to sismex01@hebmex.com on c.l.py, and is basically a
1255 # modified (shorter) version of:
1271 # modified (shorter) version of:
1256 # http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/66018 by
1272 # http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/66018 by
1257 # Skip Montanaro (skip@pobox.com).
1273 # Skip Montanaro (skip@pobox.com).
1258
1274
1259 def __getitem__(self, name):
1275 def __getitem__(self, name):
1260 frame = sys._getframe(1)
1276 frame = sys._getframe(1)
1261 return eval(name, frame.f_globals, frame.f_locals)
1277 return eval(name, frame.f_globals, frame.f_locals)
1262
1278
1263 EvalString = EvalDict # for backwards compatibility
1279 EvalString = EvalDict # for backwards compatibility
1264 #----------------------------------------------------------------------------
1280 #----------------------------------------------------------------------------
1265 def qw(words,flat=0,sep=None,maxsplit=-1):
1281 def qw(words,flat=0,sep=None,maxsplit=-1):
1266 """Similar to Perl's qw() operator, but with some more options.
1282 """Similar to Perl's qw() operator, but with some more options.
1267
1283
1268 qw(words,flat=0,sep=' ',maxsplit=-1) -> words.split(sep,maxsplit)
1284 qw(words,flat=0,sep=' ',maxsplit=-1) -> words.split(sep,maxsplit)
1269
1285
1270 words can also be a list itself, and with flat=1, the output will be
1286 words can also be a list itself, and with flat=1, the output will be
1271 recursively flattened. Examples:
1287 recursively flattened. Examples:
1272
1288
1273 >>> qw('1 2')
1289 >>> qw('1 2')
1274 ['1', '2']
1290 ['1', '2']
1275 >>> qw(['a b','1 2',['m n','p q']])
1291 >>> qw(['a b','1 2',['m n','p q']])
1276 [['a', 'b'], ['1', '2'], [['m', 'n'], ['p', 'q']]]
1292 [['a', 'b'], ['1', '2'], [['m', 'n'], ['p', 'q']]]
1277 >>> qw(['a b','1 2',['m n','p q']],flat=1)
1293 >>> qw(['a b','1 2',['m n','p q']],flat=1)
1278 ['a', 'b', '1', '2', 'm', 'n', 'p', 'q'] """
1294 ['a', 'b', '1', '2', 'm', 'n', 'p', 'q'] """
1279
1295
1280 if type(words) in StringTypes:
1296 if type(words) in StringTypes:
1281 return [word.strip() for word in words.split(sep,maxsplit)
1297 return [word.strip() for word in words.split(sep,maxsplit)
1282 if word and not word.isspace() ]
1298 if word and not word.isspace() ]
1283 if flat:
1299 if flat:
1284 return flatten(map(qw,words,[1]*len(words)))
1300 return flatten(map(qw,words,[1]*len(words)))
1285 return map(qw,words)
1301 return map(qw,words)
1286
1302
1287 #----------------------------------------------------------------------------
1303 #----------------------------------------------------------------------------
1288 def qwflat(words,sep=None,maxsplit=-1):
1304 def qwflat(words,sep=None,maxsplit=-1):
1289 """Calls qw(words) in flat mode. It's just a convenient shorthand."""
1305 """Calls qw(words) in flat mode. It's just a convenient shorthand."""
1290 return qw(words,1,sep,maxsplit)
1306 return qw(words,1,sep,maxsplit)
1291
1307
1292 #----------------------------------------------------------------------------
1308 #----------------------------------------------------------------------------
1293 def qw_lol(indata):
1309 def qw_lol(indata):
1294 """qw_lol('a b') -> [['a','b']],
1310 """qw_lol('a b') -> [['a','b']],
1295 otherwise it's just a call to qw().
1311 otherwise it's just a call to qw().
1296
1312
1297 We need this to make sure the modules_some keys *always* end up as a
1313 We need this to make sure the modules_some keys *always* end up as a
1298 list of lists."""
1314 list of lists."""
1299
1315
1300 if type(indata) in StringTypes:
1316 if type(indata) in StringTypes:
1301 return [qw(indata)]
1317 return [qw(indata)]
1302 else:
1318 else:
1303 return qw(indata)
1319 return qw(indata)
1304
1320
1305 #-----------------------------------------------------------------------------
1321 #-----------------------------------------------------------------------------
1306 def list_strings(arg):
1322 def list_strings(arg):
1307 """Always return a list of strings, given a string or list of strings
1323 """Always return a list of strings, given a string or list of strings
1308 as input."""
1324 as input."""
1309
1325
1310 if type(arg) in StringTypes: return [arg]
1326 if type(arg) in StringTypes: return [arg]
1311 else: return arg
1327 else: return arg
1312
1328
1313 #----------------------------------------------------------------------------
1329 #----------------------------------------------------------------------------
1314 def grep(pat,list,case=1):
1330 def grep(pat,list,case=1):
1315 """Simple minded grep-like function.
1331 """Simple minded grep-like function.
1316 grep(pat,list) returns occurrences of pat in list, None on failure.
1332 grep(pat,list) returns occurrences of pat in list, None on failure.
1317
1333
1318 It only does simple string matching, with no support for regexps. Use the
1334 It only does simple string matching, with no support for regexps. Use the
1319 option case=0 for case-insensitive matching."""
1335 option case=0 for case-insensitive matching."""
1320
1336
1321 # This is pretty crude. At least it should implement copying only references
1337 # This is pretty crude. At least it should implement copying only references
1322 # to the original data in case it's big. Now it copies the data for output.
1338 # to the original data in case it's big. Now it copies the data for output.
1323 out=[]
1339 out=[]
1324 if case:
1340 if case:
1325 for term in list:
1341 for term in list:
1326 if term.find(pat)>-1: out.append(term)
1342 if term.find(pat)>-1: out.append(term)
1327 else:
1343 else:
1328 lpat=pat.lower()
1344 lpat=pat.lower()
1329 for term in list:
1345 for term in list:
1330 if term.lower().find(lpat)>-1: out.append(term)
1346 if term.lower().find(lpat)>-1: out.append(term)
1331
1347
1332 if len(out): return out
1348 if len(out): return out
1333 else: return None
1349 else: return None
1334
1350
1335 #----------------------------------------------------------------------------
1351 #----------------------------------------------------------------------------
1336 def dgrep(pat,*opts):
1352 def dgrep(pat,*opts):
1337 """Return grep() on dir()+dir(__builtins__).
1353 """Return grep() on dir()+dir(__builtins__).
1338
1354
1339 A very common use of grep() when working interactively."""
1355 A very common use of grep() when working interactively."""
1340
1356
1341 return grep(pat,dir(__main__)+dir(__main__.__builtins__),*opts)
1357 return grep(pat,dir(__main__)+dir(__main__.__builtins__),*opts)
1342
1358
1343 #----------------------------------------------------------------------------
1359 #----------------------------------------------------------------------------
1344 def idgrep(pat):
1360 def idgrep(pat):
1345 """Case-insensitive dgrep()"""
1361 """Case-insensitive dgrep()"""
1346
1362
1347 return dgrep(pat,0)
1363 return dgrep(pat,0)
1348
1364
1349 #----------------------------------------------------------------------------
1365 #----------------------------------------------------------------------------
1350 def igrep(pat,list):
1366 def igrep(pat,list):
1351 """Synonym for case-insensitive grep."""
1367 """Synonym for case-insensitive grep."""
1352
1368
1353 return grep(pat,list,case=0)
1369 return grep(pat,list,case=0)
1354
1370
1355 #----------------------------------------------------------------------------
1371 #----------------------------------------------------------------------------
1356 def indent(str,nspaces=4,ntabs=0):
1372 def indent(str,nspaces=4,ntabs=0):
1357 """Indent a string a given number of spaces or tabstops.
1373 """Indent a string a given number of spaces or tabstops.
1358
1374
1359 indent(str,nspaces=4,ntabs=0) -> indent str by ntabs+nspaces.
1375 indent(str,nspaces=4,ntabs=0) -> indent str by ntabs+nspaces.
1360 """
1376 """
1361 if str is None:
1377 if str is None:
1362 return
1378 return
1363 ind = '\t'*ntabs+' '*nspaces
1379 ind = '\t'*ntabs+' '*nspaces
1364 outstr = '%s%s' % (ind,str.replace(os.linesep,os.linesep+ind))
1380 outstr = '%s%s' % (ind,str.replace(os.linesep,os.linesep+ind))
1365 if outstr.endswith(os.linesep+ind):
1381 if outstr.endswith(os.linesep+ind):
1366 return outstr[:-len(ind)]
1382 return outstr[:-len(ind)]
1367 else:
1383 else:
1368 return outstr
1384 return outstr
1369
1385
1370 #-----------------------------------------------------------------------------
1386 #-----------------------------------------------------------------------------
1371 def native_line_ends(filename,backup=1):
1387 def native_line_ends(filename,backup=1):
1372 """Convert (in-place) a file to line-ends native to the current OS.
1388 """Convert (in-place) a file to line-ends native to the current OS.
1373
1389
1374 If the optional backup argument is given as false, no backup of the
1390 If the optional backup argument is given as false, no backup of the
1375 original file is left. """
1391 original file is left. """
1376
1392
1377 backup_suffixes = {'posix':'~','dos':'.bak','nt':'.bak','mac':'.bak'}
1393 backup_suffixes = {'posix':'~','dos':'.bak','nt':'.bak','mac':'.bak'}
1378
1394
1379 bak_filename = filename + backup_suffixes[os.name]
1395 bak_filename = filename + backup_suffixes[os.name]
1380
1396
1381 original = open(filename).read()
1397 original = open(filename).read()
1382 shutil.copy2(filename,bak_filename)
1398 shutil.copy2(filename,bak_filename)
1383 try:
1399 try:
1384 new = open(filename,'wb')
1400 new = open(filename,'wb')
1385 new.write(os.linesep.join(original.splitlines()))
1401 new.write(os.linesep.join(original.splitlines()))
1386 new.write(os.linesep) # ALWAYS put an eol at the end of the file
1402 new.write(os.linesep) # ALWAYS put an eol at the end of the file
1387 new.close()
1403 new.close()
1388 except:
1404 except:
1389 os.rename(bak_filename,filename)
1405 os.rename(bak_filename,filename)
1390 if not backup:
1406 if not backup:
1391 try:
1407 try:
1392 os.remove(bak_filename)
1408 os.remove(bak_filename)
1393 except:
1409 except:
1394 pass
1410 pass
1395
1411
1396 #----------------------------------------------------------------------------
1412 #----------------------------------------------------------------------------
1397 def get_pager_cmd(pager_cmd = None):
1413 def get_pager_cmd(pager_cmd = None):
1398 """Return a pager command.
1414 """Return a pager command.
1399
1415
1400 Makes some attempts at finding an OS-correct one."""
1416 Makes some attempts at finding an OS-correct one."""
1401
1417
1402 if os.name == 'posix':
1418 if os.name == 'posix':
1403 default_pager_cmd = 'less -r' # -r for color control sequences
1419 default_pager_cmd = 'less -r' # -r for color control sequences
1404 elif os.name in ['nt','dos']:
1420 elif os.name in ['nt','dos']:
1405 default_pager_cmd = 'type'
1421 default_pager_cmd = 'type'
1406
1422
1407 if pager_cmd is None:
1423 if pager_cmd is None:
1408 try:
1424 try:
1409 pager_cmd = os.environ['PAGER']
1425 pager_cmd = os.environ['PAGER']
1410 except:
1426 except:
1411 pager_cmd = default_pager_cmd
1427 pager_cmd = default_pager_cmd
1412 return pager_cmd
1428 return pager_cmd
1413
1429
1414 #-----------------------------------------------------------------------------
1430 #-----------------------------------------------------------------------------
1415 def get_pager_start(pager,start):
1431 def get_pager_start(pager,start):
1416 """Return the string for paging files with an offset.
1432 """Return the string for paging files with an offset.
1417
1433
1418 This is the '+N' argument which less and more (under Unix) accept.
1434 This is the '+N' argument which less and more (under Unix) accept.
1419 """
1435 """
1420
1436
1421 if pager in ['less','more']:
1437 if pager in ['less','more']:
1422 if start:
1438 if start:
1423 start_string = '+' + str(start)
1439 start_string = '+' + str(start)
1424 else:
1440 else:
1425 start_string = ''
1441 start_string = ''
1426 else:
1442 else:
1427 start_string = ''
1443 start_string = ''
1428 return start_string
1444 return start_string
1429
1445
1430 #----------------------------------------------------------------------------
1446 #----------------------------------------------------------------------------
1431 # (X)emacs on W32 doesn't like to be bypassed with msvcrt.getch()
1447 # (X)emacs on W32 doesn't like to be bypassed with msvcrt.getch()
1432 if os.name == 'nt' and os.environ.get('TERM','dumb') != 'emacs':
1448 if os.name == 'nt' and os.environ.get('TERM','dumb') != 'emacs':
1433 import msvcrt
1449 import msvcrt
1434 def page_more():
1450 def page_more():
1435 """ Smart pausing between pages
1451 """ Smart pausing between pages
1436
1452
1437 @return: True if need print more lines, False if quit
1453 @return: True if need print more lines, False if quit
1438 """
1454 """
1439 Term.cout.write('---Return to continue, q to quit--- ')
1455 Term.cout.write('---Return to continue, q to quit--- ')
1440 ans = msvcrt.getch()
1456 ans = msvcrt.getch()
1441 if ans in ("q", "Q"):
1457 if ans in ("q", "Q"):
1442 result = False
1458 result = False
1443 else:
1459 else:
1444 result = True
1460 result = True
1445 Term.cout.write("\b"*37 + " "*37 + "\b"*37)
1461 Term.cout.write("\b"*37 + " "*37 + "\b"*37)
1446 return result
1462 return result
1447 else:
1463 else:
1448 def page_more():
1464 def page_more():
1449 ans = raw_input('---Return to continue, q to quit--- ')
1465 ans = raw_input('---Return to continue, q to quit--- ')
1450 if ans.lower().startswith('q'):
1466 if ans.lower().startswith('q'):
1451 return False
1467 return False
1452 else:
1468 else:
1453 return True
1469 return True
1454
1470
1455 esc_re = re.compile(r"(\x1b[^m]+m)")
1471 esc_re = re.compile(r"(\x1b[^m]+m)")
1456
1472
1457 def page_dumb(strng,start=0,screen_lines=25):
1473 def page_dumb(strng,start=0,screen_lines=25):
1458 """Very dumb 'pager' in Python, for when nothing else works.
1474 """Very dumb 'pager' in Python, for when nothing else works.
1459
1475
1460 Only moves forward, same interface as page(), except for pager_cmd and
1476 Only moves forward, same interface as page(), except for pager_cmd and
1461 mode."""
1477 mode."""
1462
1478
1463 out_ln = strng.splitlines()[start:]
1479 out_ln = strng.splitlines()[start:]
1464 screens = chop(out_ln,screen_lines-1)
1480 screens = chop(out_ln,screen_lines-1)
1465 if len(screens) == 1:
1481 if len(screens) == 1:
1466 print >>Term.cout, os.linesep.join(screens[0])
1482 print >>Term.cout, os.linesep.join(screens[0])
1467 else:
1483 else:
1468 last_escape = ""
1484 last_escape = ""
1469 for scr in screens[0:-1]:
1485 for scr in screens[0:-1]:
1470 hunk = os.linesep.join(scr)
1486 hunk = os.linesep.join(scr)
1471 print >>Term.cout, last_escape + hunk
1487 print >>Term.cout, last_escape + hunk
1472 if not page_more():
1488 if not page_more():
1473 return
1489 return
1474 esc_list = esc_re.findall(hunk)
1490 esc_list = esc_re.findall(hunk)
1475 if len(esc_list) > 0:
1491 if len(esc_list) > 0:
1476 last_escape = esc_list[-1]
1492 last_escape = esc_list[-1]
1477 print >>Term.cout, last_escape + os.linesep.join(screens[-1])
1493 print >>Term.cout, last_escape + os.linesep.join(screens[-1])
1478
1494
1479 #----------------------------------------------------------------------------
1495 #----------------------------------------------------------------------------
1480 def page(strng,start=0,screen_lines=0,pager_cmd = None):
1496 def page(strng,start=0,screen_lines=0,pager_cmd = None):
1481 """Print a string, piping through a pager after a certain length.
1497 """Print a string, piping through a pager after a certain length.
1482
1498
1483 The screen_lines parameter specifies the number of *usable* lines of your
1499 The screen_lines parameter specifies the number of *usable* lines of your
1484 terminal screen (total lines minus lines you need to reserve to show other
1500 terminal screen (total lines minus lines you need to reserve to show other
1485 information).
1501 information).
1486
1502
1487 If you set screen_lines to a number <=0, page() will try to auto-determine
1503 If you set screen_lines to a number <=0, page() will try to auto-determine
1488 your screen size and will only use up to (screen_size+screen_lines) for
1504 your screen size and will only use up to (screen_size+screen_lines) for
1489 printing, paging after that. That is, if you want auto-detection but need
1505 printing, paging after that. That is, if you want auto-detection but need
1490 to reserve the bottom 3 lines of the screen, use screen_lines = -3, and for
1506 to reserve the bottom 3 lines of the screen, use screen_lines = -3, and for
1491 auto-detection without any lines reserved simply use screen_lines = 0.
1507 auto-detection without any lines reserved simply use screen_lines = 0.
1492
1508
1493 If a string won't fit in the allowed lines, it is sent through the
1509 If a string won't fit in the allowed lines, it is sent through the
1494 specified pager command. If none given, look for PAGER in the environment,
1510 specified pager command. If none given, look for PAGER in the environment,
1495 and ultimately default to less.
1511 and ultimately default to less.
1496
1512
1497 If no system pager works, the string is sent through a 'dumb pager'
1513 If no system pager works, the string is sent through a 'dumb pager'
1498 written in python, very simplistic.
1514 written in python, very simplistic.
1499 """
1515 """
1500
1516
1501
1517
1502 # first, try the hook
1518 # first, try the hook
1503 ip = IPython.ipapi.get()
1519 ip = IPython.ipapi.get()
1504 if ip:
1520 if ip:
1505 try:
1521 try:
1506 ip.IP.hooks.show_in_pager(strng)
1522 ip.IP.hooks.show_in_pager(strng)
1507 return
1523 return
1508 except IPython.ipapi.TryNext:
1524 except IPython.ipapi.TryNext:
1509 pass
1525 pass
1510
1526
1511 # Ugly kludge, but calling curses.initscr() flat out crashes in emacs
1527 # Ugly kludge, but calling curses.initscr() flat out crashes in emacs
1512 TERM = os.environ.get('TERM','dumb')
1528 TERM = os.environ.get('TERM','dumb')
1513 if TERM in ['dumb','emacs'] and os.name != 'nt':
1529 if TERM in ['dumb','emacs'] and os.name != 'nt':
1514 print strng
1530 print strng
1515 return
1531 return
1516 # chop off the topmost part of the string we don't want to see
1532 # chop off the topmost part of the string we don't want to see
1517 str_lines = strng.split(os.linesep)[start:]
1533 str_lines = strng.split(os.linesep)[start:]
1518 str_toprint = os.linesep.join(str_lines)
1534 str_toprint = os.linesep.join(str_lines)
1519 num_newlines = len(str_lines)
1535 num_newlines = len(str_lines)
1520 len_str = len(str_toprint)
1536 len_str = len(str_toprint)
1521
1537
1522 # Dumb heuristics to guesstimate number of on-screen lines the string
1538 # Dumb heuristics to guesstimate number of on-screen lines the string
1523 # takes. Very basic, but good enough for docstrings in reasonable
1539 # takes. Very basic, but good enough for docstrings in reasonable
1524 # terminals. If someone later feels like refining it, it's not hard.
1540 # terminals. If someone later feels like refining it, it's not hard.
1525 numlines = max(num_newlines,int(len_str/80)+1)
1541 numlines = max(num_newlines,int(len_str/80)+1)
1526
1542
1527 if os.name == "nt":
1543 if os.name == "nt":
1528 screen_lines_def = get_console_size(defaulty=25)[1]
1544 screen_lines_def = get_console_size(defaulty=25)[1]
1529 else:
1545 else:
1530 screen_lines_def = 25 # default value if we can't auto-determine
1546 screen_lines_def = 25 # default value if we can't auto-determine
1531
1547
1532 # auto-determine screen size
1548 # auto-determine screen size
1533 if screen_lines <= 0:
1549 if screen_lines <= 0:
1534 if TERM=='xterm':
1550 if TERM=='xterm':
1535 try:
1551 try:
1536 import curses
1552 import curses
1537 if hasattr(curses,'initscr'):
1553 if hasattr(curses,'initscr'):
1538 use_curses = 1
1554 use_curses = 1
1539 else:
1555 else:
1540 use_curses = 0
1556 use_curses = 0
1541 except ImportError:
1557 except ImportError:
1542 use_curses = 0
1558 use_curses = 0
1543 else:
1559 else:
1544 # curses causes problems on many terminals other than xterm.
1560 # curses causes problems on many terminals other than xterm.
1545 use_curses = 0
1561 use_curses = 0
1546 if use_curses:
1562 if use_curses:
1547 scr = curses.initscr()
1563 scr = curses.initscr()
1548 screen_lines_real,screen_cols = scr.getmaxyx()
1564 screen_lines_real,screen_cols = scr.getmaxyx()
1549 curses.endwin()
1565 curses.endwin()
1550 screen_lines += screen_lines_real
1566 screen_lines += screen_lines_real
1551 #print '***Screen size:',screen_lines_real,'lines x',\
1567 #print '***Screen size:',screen_lines_real,'lines x',\
1552 #screen_cols,'columns.' # dbg
1568 #screen_cols,'columns.' # dbg
1553 else:
1569 else:
1554 screen_lines += screen_lines_def
1570 screen_lines += screen_lines_def
1555
1571
1556 #print 'numlines',numlines,'screenlines',screen_lines # dbg
1572 #print 'numlines',numlines,'screenlines',screen_lines # dbg
1557 if numlines <= screen_lines :
1573 if numlines <= screen_lines :
1558 #print '*** normal print' # dbg
1574 #print '*** normal print' # dbg
1559 print >>Term.cout, str_toprint
1575 print >>Term.cout, str_toprint
1560 else:
1576 else:
1561 # Try to open pager and default to internal one if that fails.
1577 # Try to open pager and default to internal one if that fails.
1562 # All failure modes are tagged as 'retval=1', to match the return
1578 # All failure modes are tagged as 'retval=1', to match the return
1563 # value of a failed system command. If any intermediate attempt
1579 # value of a failed system command. If any intermediate attempt
1564 # sets retval to 1, at the end we resort to our own page_dumb() pager.
1580 # sets retval to 1, at the end we resort to our own page_dumb() pager.
1565 pager_cmd = get_pager_cmd(pager_cmd)
1581 pager_cmd = get_pager_cmd(pager_cmd)
1566 pager_cmd += ' ' + get_pager_start(pager_cmd,start)
1582 pager_cmd += ' ' + get_pager_start(pager_cmd,start)
1567 if os.name == 'nt':
1583 if os.name == 'nt':
1568 if pager_cmd.startswith('type'):
1584 if pager_cmd.startswith('type'):
1569 # The default WinXP 'type' command is failing on complex strings.
1585 # The default WinXP 'type' command is failing on complex strings.
1570 retval = 1
1586 retval = 1
1571 else:
1587 else:
1572 tmpname = tempfile.mktemp('.txt')
1588 tmpname = tempfile.mktemp('.txt')
1573 tmpfile = file(tmpname,'wt')
1589 tmpfile = file(tmpname,'wt')
1574 tmpfile.write(strng)
1590 tmpfile.write(strng)
1575 tmpfile.close()
1591 tmpfile.close()
1576 cmd = "%s < %s" % (pager_cmd,tmpname)
1592 cmd = "%s < %s" % (pager_cmd,tmpname)
1577 if os.system(cmd):
1593 if os.system(cmd):
1578 retval = 1
1594 retval = 1
1579 else:
1595 else:
1580 retval = None
1596 retval = None
1581 os.remove(tmpname)
1597 os.remove(tmpname)
1582 else:
1598 else:
1583 try:
1599 try:
1584 retval = None
1600 retval = None
1585 # if I use popen4, things hang. No idea why.
1601 # if I use popen4, things hang. No idea why.
1586 #pager,shell_out = os.popen4(pager_cmd)
1602 #pager,shell_out = os.popen4(pager_cmd)
1587 pager = os.popen(pager_cmd,'w')
1603 pager = os.popen(pager_cmd,'w')
1588 pager.write(strng)
1604 pager.write(strng)
1589 pager.close()
1605 pager.close()
1590 retval = pager.close() # success returns None
1606 retval = pager.close() # success returns None
1591 except IOError,msg: # broken pipe when user quits
1607 except IOError,msg: # broken pipe when user quits
1592 if msg.args == (32,'Broken pipe'):
1608 if msg.args == (32,'Broken pipe'):
1593 retval = None
1609 retval = None
1594 else:
1610 else:
1595 retval = 1
1611 retval = 1
1596 except OSError:
1612 except OSError:
1597 # Other strange problems, sometimes seen in Win2k/cygwin
1613 # Other strange problems, sometimes seen in Win2k/cygwin
1598 retval = 1
1614 retval = 1
1599 if retval is not None:
1615 if retval is not None:
1600 page_dumb(strng,screen_lines=screen_lines)
1616 page_dumb(strng,screen_lines=screen_lines)
1601
1617
1602 #----------------------------------------------------------------------------
1618 #----------------------------------------------------------------------------
1603 def page_file(fname,start = 0, pager_cmd = None):
1619 def page_file(fname,start = 0, pager_cmd = None):
1604 """Page a file, using an optional pager command and starting line.
1620 """Page a file, using an optional pager command and starting line.
1605 """
1621 """
1606
1622
1607 pager_cmd = get_pager_cmd(pager_cmd)
1623 pager_cmd = get_pager_cmd(pager_cmd)
1608 pager_cmd += ' ' + get_pager_start(pager_cmd,start)
1624 pager_cmd += ' ' + get_pager_start(pager_cmd,start)
1609
1625
1610 try:
1626 try:
1611 if os.environ['TERM'] in ['emacs','dumb']:
1627 if os.environ['TERM'] in ['emacs','dumb']:
1612 raise EnvironmentError
1628 raise EnvironmentError
1613 xsys(pager_cmd + ' ' + fname)
1629 xsys(pager_cmd + ' ' + fname)
1614 except:
1630 except:
1615 try:
1631 try:
1616 if start > 0:
1632 if start > 0:
1617 start -= 1
1633 start -= 1
1618 page(open(fname).read(),start)
1634 page(open(fname).read(),start)
1619 except:
1635 except:
1620 print 'Unable to show file',`fname`
1636 print 'Unable to show file',`fname`
1621
1637
1622
1638
1623 #----------------------------------------------------------------------------
1639 #----------------------------------------------------------------------------
1624 def snip_print(str,width = 75,print_full = 0,header = ''):
1640 def snip_print(str,width = 75,print_full = 0,header = ''):
1625 """Print a string snipping the midsection to fit in width.
1641 """Print a string snipping the midsection to fit in width.
1626
1642
1627 print_full: mode control:
1643 print_full: mode control:
1628 - 0: only snip long strings
1644 - 0: only snip long strings
1629 - 1: send to page() directly.
1645 - 1: send to page() directly.
1630 - 2: snip long strings and ask for full length viewing with page()
1646 - 2: snip long strings and ask for full length viewing with page()
1631 Return 1 if snipping was necessary, 0 otherwise."""
1647 Return 1 if snipping was necessary, 0 otherwise."""
1632
1648
1633 if print_full == 1:
1649 if print_full == 1:
1634 page(header+str)
1650 page(header+str)
1635 return 0
1651 return 0
1636
1652
1637 print header,
1653 print header,
1638 if len(str) < width:
1654 if len(str) < width:
1639 print str
1655 print str
1640 snip = 0
1656 snip = 0
1641 else:
1657 else:
1642 whalf = int((width -5)/2)
1658 whalf = int((width -5)/2)
1643 print str[:whalf] + ' <...> ' + str[-whalf:]
1659 print str[:whalf] + ' <...> ' + str[-whalf:]
1644 snip = 1
1660 snip = 1
1645 if snip and print_full == 2:
1661 if snip and print_full == 2:
1646 if raw_input(header+' Snipped. View (y/n)? [N]').lower() == 'y':
1662 if raw_input(header+' Snipped. View (y/n)? [N]').lower() == 'y':
1647 page(str)
1663 page(str)
1648 return snip
1664 return snip
1649
1665
1650 #****************************************************************************
1666 #****************************************************************************
1651 # lists, dicts and structures
1667 # lists, dicts and structures
1652
1668
1653 def belong(candidates,checklist):
1669 def belong(candidates,checklist):
1654 """Check whether a list of items appear in a given list of options.
1670 """Check whether a list of items appear in a given list of options.
1655
1671
1656 Returns a list of 1 and 0, one for each candidate given."""
1672 Returns a list of 1 and 0, one for each candidate given."""
1657
1673
1658 return [x in checklist for x in candidates]
1674 return [x in checklist for x in candidates]
1659
1675
1660 #----------------------------------------------------------------------------
1676 #----------------------------------------------------------------------------
1661 def uniq_stable(elems):
1677 def uniq_stable(elems):
1662 """uniq_stable(elems) -> list
1678 """uniq_stable(elems) -> list
1663
1679
1664 Return from an iterable, a list of all the unique elements in the input,
1680 Return from an iterable, a list of all the unique elements in the input,
1665 but maintaining the order in which they first appear.
1681 but maintaining the order in which they first appear.
1666
1682
1667 A naive solution to this problem which just makes a dictionary with the
1683 A naive solution to this problem which just makes a dictionary with the
1668 elements as keys fails to respect the stability condition, since
1684 elements as keys fails to respect the stability condition, since
1669 dictionaries are unsorted by nature.
1685 dictionaries are unsorted by nature.
1670
1686
1671 Note: All elements in the input must be valid dictionary keys for this
1687 Note: All elements in the input must be valid dictionary keys for this
1672 routine to work, as it internally uses a dictionary for efficiency
1688 routine to work, as it internally uses a dictionary for efficiency
1673 reasons."""
1689 reasons."""
1674
1690
1675 unique = []
1691 unique = []
1676 unique_dict = {}
1692 unique_dict = {}
1677 for nn in elems:
1693 for nn in elems:
1678 if nn not in unique_dict:
1694 if nn not in unique_dict:
1679 unique.append(nn)
1695 unique.append(nn)
1680 unique_dict[nn] = None
1696 unique_dict[nn] = None
1681 return unique
1697 return unique
1682
1698
1683 #----------------------------------------------------------------------------
1699 #----------------------------------------------------------------------------
1684 class NLprinter:
1700 class NLprinter:
1685 """Print an arbitrarily nested list, indicating index numbers.
1701 """Print an arbitrarily nested list, indicating index numbers.
1686
1702
1687 An instance of this class called nlprint is available and callable as a
1703 An instance of this class called nlprint is available and callable as a
1688 function.
1704 function.
1689
1705
1690 nlprint(list,indent=' ',sep=': ') -> prints indenting each level by 'indent'
1706 nlprint(list,indent=' ',sep=': ') -> prints indenting each level by 'indent'
1691 and using 'sep' to separate the index from the value. """
1707 and using 'sep' to separate the index from the value. """
1692
1708
1693 def __init__(self):
1709 def __init__(self):
1694 self.depth = 0
1710 self.depth = 0
1695
1711
1696 def __call__(self,lst,pos='',**kw):
1712 def __call__(self,lst,pos='',**kw):
1697 """Prints the nested list numbering levels."""
1713 """Prints the nested list numbering levels."""
1698 kw.setdefault('indent',' ')
1714 kw.setdefault('indent',' ')
1699 kw.setdefault('sep',': ')
1715 kw.setdefault('sep',': ')
1700 kw.setdefault('start',0)
1716 kw.setdefault('start',0)
1701 kw.setdefault('stop',len(lst))
1717 kw.setdefault('stop',len(lst))
1702 # we need to remove start and stop from kw so they don't propagate
1718 # we need to remove start and stop from kw so they don't propagate
1703 # into a recursive call for a nested list.
1719 # into a recursive call for a nested list.
1704 start = kw['start']; del kw['start']
1720 start = kw['start']; del kw['start']
1705 stop = kw['stop']; del kw['stop']
1721 stop = kw['stop']; del kw['stop']
1706 if self.depth == 0 and 'header' in kw.keys():
1722 if self.depth == 0 and 'header' in kw.keys():
1707 print kw['header']
1723 print kw['header']
1708
1724
1709 for idx in range(start,stop):
1725 for idx in range(start,stop):
1710 elem = lst[idx]
1726 elem = lst[idx]
1711 if type(elem)==type([]):
1727 if type(elem)==type([]):
1712 self.depth += 1
1728 self.depth += 1
1713 self.__call__(elem,itpl('$pos$idx,'),**kw)
1729 self.__call__(elem,itpl('$pos$idx,'),**kw)
1714 self.depth -= 1
1730 self.depth -= 1
1715 else:
1731 else:
1716 printpl(kw['indent']*self.depth+'$pos$idx$kw["sep"]$elem')
1732 printpl(kw['indent']*self.depth+'$pos$idx$kw["sep"]$elem')
1717
1733
1718 nlprint = NLprinter()
1734 nlprint = NLprinter()
1719 #----------------------------------------------------------------------------
1735 #----------------------------------------------------------------------------
1720 def all_belong(candidates,checklist):
1736 def all_belong(candidates,checklist):
1721 """Check whether a list of items ALL appear in a given list of options.
1737 """Check whether a list of items ALL appear in a given list of options.
1722
1738
1723 Returns a single 1 or 0 value."""
1739 Returns a single 1 or 0 value."""
1724
1740
1725 return 1-(0 in [x in checklist for x in candidates])
1741 return 1-(0 in [x in checklist for x in candidates])
1726
1742
1727 #----------------------------------------------------------------------------
1743 #----------------------------------------------------------------------------
1728 def sort_compare(lst1,lst2,inplace = 1):
1744 def sort_compare(lst1,lst2,inplace = 1):
1729 """Sort and compare two lists.
1745 """Sort and compare two lists.
1730
1746
1731 By default it does it in place, thus modifying the lists. Use inplace = 0
1747 By default it does it in place, thus modifying the lists. Use inplace = 0
1732 to avoid that (at the cost of temporary copy creation)."""
1748 to avoid that (at the cost of temporary copy creation)."""
1733 if not inplace:
1749 if not inplace:
1734 lst1 = lst1[:]
1750 lst1 = lst1[:]
1735 lst2 = lst2[:]
1751 lst2 = lst2[:]
1736 lst1.sort(); lst2.sort()
1752 lst1.sort(); lst2.sort()
1737 return lst1 == lst2
1753 return lst1 == lst2
1738
1754
1739 #----------------------------------------------------------------------------
1755 #----------------------------------------------------------------------------
1740 def mkdict(**kwargs):
1756 def mkdict(**kwargs):
1741 """Return a dict from a keyword list.
1757 """Return a dict from a keyword list.
1742
1758
1743 It's just syntactic sugar for making ditcionary creation more convenient:
1759 It's just syntactic sugar for making ditcionary creation more convenient:
1744 # the standard way
1760 # the standard way
1745 >>>data = { 'red' : 1, 'green' : 2, 'blue' : 3 }
1761 >>>data = { 'red' : 1, 'green' : 2, 'blue' : 3 }
1746 # a cleaner way
1762 # a cleaner way
1747 >>>data = dict(red=1, green=2, blue=3)
1763 >>>data = dict(red=1, green=2, blue=3)
1748
1764
1749 If you need more than this, look at the Struct() class."""
1765 If you need more than this, look at the Struct() class."""
1750
1766
1751 return kwargs
1767 return kwargs
1752
1768
1753 #----------------------------------------------------------------------------
1769 #----------------------------------------------------------------------------
1754 def list2dict(lst):
1770 def list2dict(lst):
1755 """Takes a list of (key,value) pairs and turns it into a dict."""
1771 """Takes a list of (key,value) pairs and turns it into a dict."""
1756
1772
1757 dic = {}
1773 dic = {}
1758 for k,v in lst: dic[k] = v
1774 for k,v in lst: dic[k] = v
1759 return dic
1775 return dic
1760
1776
1761 #----------------------------------------------------------------------------
1777 #----------------------------------------------------------------------------
1762 def list2dict2(lst,default=''):
1778 def list2dict2(lst,default=''):
1763 """Takes a list and turns it into a dict.
1779 """Takes a list and turns it into a dict.
1764 Much slower than list2dict, but more versatile. This version can take
1780 Much slower than list2dict, but more versatile. This version can take
1765 lists with sublists of arbitrary length (including sclars)."""
1781 lists with sublists of arbitrary length (including sclars)."""
1766
1782
1767 dic = {}
1783 dic = {}
1768 for elem in lst:
1784 for elem in lst:
1769 if type(elem) in (types.ListType,types.TupleType):
1785 if type(elem) in (types.ListType,types.TupleType):
1770 size = len(elem)
1786 size = len(elem)
1771 if size == 0:
1787 if size == 0:
1772 pass
1788 pass
1773 elif size == 1:
1789 elif size == 1:
1774 dic[elem] = default
1790 dic[elem] = default
1775 else:
1791 else:
1776 k,v = elem[0], elem[1:]
1792 k,v = elem[0], elem[1:]
1777 if len(v) == 1: v = v[0]
1793 if len(v) == 1: v = v[0]
1778 dic[k] = v
1794 dic[k] = v
1779 else:
1795 else:
1780 dic[elem] = default
1796 dic[elem] = default
1781 return dic
1797 return dic
1782
1798
1783 #----------------------------------------------------------------------------
1799 #----------------------------------------------------------------------------
1784 def flatten(seq):
1800 def flatten(seq):
1785 """Flatten a list of lists (NOT recursive, only works for 2d lists)."""
1801 """Flatten a list of lists (NOT recursive, only works for 2d lists)."""
1786
1802
1787 return [x for subseq in seq for x in subseq]
1803 return [x for subseq in seq for x in subseq]
1788
1804
1789 #----------------------------------------------------------------------------
1805 #----------------------------------------------------------------------------
1790 def get_slice(seq,start=0,stop=None,step=1):
1806 def get_slice(seq,start=0,stop=None,step=1):
1791 """Get a slice of a sequence with variable step. Specify start,stop,step."""
1807 """Get a slice of a sequence with variable step. Specify start,stop,step."""
1792 if stop == None:
1808 if stop == None:
1793 stop = len(seq)
1809 stop = len(seq)
1794 item = lambda i: seq[i]
1810 item = lambda i: seq[i]
1795 return map(item,xrange(start,stop,step))
1811 return map(item,xrange(start,stop,step))
1796
1812
1797 #----------------------------------------------------------------------------
1813 #----------------------------------------------------------------------------
1798 def chop(seq,size):
1814 def chop(seq,size):
1799 """Chop a sequence into chunks of the given size."""
1815 """Chop a sequence into chunks of the given size."""
1800 chunk = lambda i: seq[i:i+size]
1816 chunk = lambda i: seq[i:i+size]
1801 return map(chunk,xrange(0,len(seq),size))
1817 return map(chunk,xrange(0,len(seq),size))
1802
1818
1803 #----------------------------------------------------------------------------
1819 #----------------------------------------------------------------------------
1804 # with is a keyword as of python 2.5, so this function is renamed to withobj
1820 # with is a keyword as of python 2.5, so this function is renamed to withobj
1805 # from its old 'with' name.
1821 # from its old 'with' name.
1806 def with_obj(object, **args):
1822 def with_obj(object, **args):
1807 """Set multiple attributes for an object, similar to Pascal's with.
1823 """Set multiple attributes for an object, similar to Pascal's with.
1808
1824
1809 Example:
1825 Example:
1810 with_obj(jim,
1826 with_obj(jim,
1811 born = 1960,
1827 born = 1960,
1812 haircolour = 'Brown',
1828 haircolour = 'Brown',
1813 eyecolour = 'Green')
1829 eyecolour = 'Green')
1814
1830
1815 Credit: Greg Ewing, in
1831 Credit: Greg Ewing, in
1816 http://mail.python.org/pipermail/python-list/2001-May/040703.html.
1832 http://mail.python.org/pipermail/python-list/2001-May/040703.html.
1817
1833
1818 NOTE: up until IPython 0.7.2, this was called simply 'with', but 'with'
1834 NOTE: up until IPython 0.7.2, this was called simply 'with', but 'with'
1819 has become a keyword for Python 2.5, so we had to rename it."""
1835 has become a keyword for Python 2.5, so we had to rename it."""
1820
1836
1821 object.__dict__.update(args)
1837 object.__dict__.update(args)
1822
1838
1823 #----------------------------------------------------------------------------
1839 #----------------------------------------------------------------------------
1824 def setattr_list(obj,alist,nspace = None):
1840 def setattr_list(obj,alist,nspace = None):
1825 """Set a list of attributes for an object taken from a namespace.
1841 """Set a list of attributes for an object taken from a namespace.
1826
1842
1827 setattr_list(obj,alist,nspace) -> sets in obj all the attributes listed in
1843 setattr_list(obj,alist,nspace) -> sets in obj all the attributes listed in
1828 alist with their values taken from nspace, which must be a dict (something
1844 alist with their values taken from nspace, which must be a dict (something
1829 like locals() will often do) If nspace isn't given, locals() of the
1845 like locals() will often do) If nspace isn't given, locals() of the
1830 *caller* is used, so in most cases you can omit it.
1846 *caller* is used, so in most cases you can omit it.
1831
1847
1832 Note that alist can be given as a string, which will be automatically
1848 Note that alist can be given as a string, which will be automatically
1833 split into a list on whitespace. If given as a list, it must be a list of
1849 split into a list on whitespace. If given as a list, it must be a list of
1834 *strings* (the variable names themselves), not of variables."""
1850 *strings* (the variable names themselves), not of variables."""
1835
1851
1836 # this grabs the local variables from the *previous* call frame -- that is
1852 # this grabs the local variables from the *previous* call frame -- that is
1837 # the locals from the function that called setattr_list().
1853 # the locals from the function that called setattr_list().
1838 # - snipped from weave.inline()
1854 # - snipped from weave.inline()
1839 if nspace is None:
1855 if nspace is None:
1840 call_frame = sys._getframe().f_back
1856 call_frame = sys._getframe().f_back
1841 nspace = call_frame.f_locals
1857 nspace = call_frame.f_locals
1842
1858
1843 if type(alist) in StringTypes:
1859 if type(alist) in StringTypes:
1844 alist = alist.split()
1860 alist = alist.split()
1845 for attr in alist:
1861 for attr in alist:
1846 val = eval(attr,nspace)
1862 val = eval(attr,nspace)
1847 setattr(obj,attr,val)
1863 setattr(obj,attr,val)
1848
1864
1849 #----------------------------------------------------------------------------
1865 #----------------------------------------------------------------------------
1850 def getattr_list(obj,alist,*args):
1866 def getattr_list(obj,alist,*args):
1851 """getattr_list(obj,alist[, default]) -> attribute list.
1867 """getattr_list(obj,alist[, default]) -> attribute list.
1852
1868
1853 Get a list of named attributes for an object. When a default argument is
1869 Get a list of named attributes for an object. When a default argument is
1854 given, it is returned when the attribute doesn't exist; without it, an
1870 given, it is returned when the attribute doesn't exist; without it, an
1855 exception is raised in that case.
1871 exception is raised in that case.
1856
1872
1857 Note that alist can be given as a string, which will be automatically
1873 Note that alist can be given as a string, which will be automatically
1858 split into a list on whitespace. If given as a list, it must be a list of
1874 split into a list on whitespace. If given as a list, it must be a list of
1859 *strings* (the variable names themselves), not of variables."""
1875 *strings* (the variable names themselves), not of variables."""
1860
1876
1861 if type(alist) in StringTypes:
1877 if type(alist) in StringTypes:
1862 alist = alist.split()
1878 alist = alist.split()
1863 if args:
1879 if args:
1864 if len(args)==1:
1880 if len(args)==1:
1865 default = args[0]
1881 default = args[0]
1866 return map(lambda attr: getattr(obj,attr,default),alist)
1882 return map(lambda attr: getattr(obj,attr,default),alist)
1867 else:
1883 else:
1868 raise ValueError,'getattr_list() takes only one optional argument'
1884 raise ValueError,'getattr_list() takes only one optional argument'
1869 else:
1885 else:
1870 return map(lambda attr: getattr(obj,attr),alist)
1886 return map(lambda attr: getattr(obj,attr),alist)
1871
1887
1872 #----------------------------------------------------------------------------
1888 #----------------------------------------------------------------------------
1873 def map_method(method,object_list,*argseq,**kw):
1889 def map_method(method,object_list,*argseq,**kw):
1874 """map_method(method,object_list,*args,**kw) -> list
1890 """map_method(method,object_list,*args,**kw) -> list
1875
1891
1876 Return a list of the results of applying the methods to the items of the
1892 Return a list of the results of applying the methods to the items of the
1877 argument sequence(s). If more than one sequence is given, the method is
1893 argument sequence(s). If more than one sequence is given, the method is
1878 called with an argument list consisting of the corresponding item of each
1894 called with an argument list consisting of the corresponding item of each
1879 sequence. All sequences must be of the same length.
1895 sequence. All sequences must be of the same length.
1880
1896
1881 Keyword arguments are passed verbatim to all objects called.
1897 Keyword arguments are passed verbatim to all objects called.
1882
1898
1883 This is Python code, so it's not nearly as fast as the builtin map()."""
1899 This is Python code, so it's not nearly as fast as the builtin map()."""
1884
1900
1885 out_list = []
1901 out_list = []
1886 idx = 0
1902 idx = 0
1887 for object in object_list:
1903 for object in object_list:
1888 try:
1904 try:
1889 handler = getattr(object, method)
1905 handler = getattr(object, method)
1890 except AttributeError:
1906 except AttributeError:
1891 out_list.append(None)
1907 out_list.append(None)
1892 else:
1908 else:
1893 if argseq:
1909 if argseq:
1894 args = map(lambda lst:lst[idx],argseq)
1910 args = map(lambda lst:lst[idx],argseq)
1895 #print 'ob',object,'hand',handler,'ar',args # dbg
1911 #print 'ob',object,'hand',handler,'ar',args # dbg
1896 out_list.append(handler(args,**kw))
1912 out_list.append(handler(args,**kw))
1897 else:
1913 else:
1898 out_list.append(handler(**kw))
1914 out_list.append(handler(**kw))
1899 idx += 1
1915 idx += 1
1900 return out_list
1916 return out_list
1901
1917
1902 #----------------------------------------------------------------------------
1918 #----------------------------------------------------------------------------
1903 def get_class_members(cls):
1919 def get_class_members(cls):
1904 ret = dir(cls)
1920 ret = dir(cls)
1905 if hasattr(cls,'__bases__'):
1921 if hasattr(cls,'__bases__'):
1906 for base in cls.__bases__:
1922 for base in cls.__bases__:
1907 ret.extend(get_class_members(base))
1923 ret.extend(get_class_members(base))
1908 return ret
1924 return ret
1909
1925
1910 #----------------------------------------------------------------------------
1926 #----------------------------------------------------------------------------
1911 def dir2(obj):
1927 def dir2(obj):
1912 """dir2(obj) -> list of strings
1928 """dir2(obj) -> list of strings
1913
1929
1914 Extended version of the Python builtin dir(), which does a few extra
1930 Extended version of the Python builtin dir(), which does a few extra
1915 checks, and supports common objects with unusual internals that confuse
1931 checks, and supports common objects with unusual internals that confuse
1916 dir(), such as Traits and PyCrust.
1932 dir(), such as Traits and PyCrust.
1917
1933
1918 This version is guaranteed to return only a list of true strings, whereas
1934 This version is guaranteed to return only a list of true strings, whereas
1919 dir() returns anything that objects inject into themselves, even if they
1935 dir() returns anything that objects inject into themselves, even if they
1920 are later not really valid for attribute access (many extension libraries
1936 are later not really valid for attribute access (many extension libraries
1921 have such bugs).
1937 have such bugs).
1922 """
1938 """
1923
1939
1924 # Start building the attribute list via dir(), and then complete it
1940 # Start building the attribute list via dir(), and then complete it
1925 # with a few extra special-purpose calls.
1941 # with a few extra special-purpose calls.
1926 words = dir(obj)
1942 words = dir(obj)
1927
1943
1928 if hasattr(obj,'__class__'):
1944 if hasattr(obj,'__class__'):
1929 words.append('__class__')
1945 words.append('__class__')
1930 words.extend(get_class_members(obj.__class__))
1946 words.extend(get_class_members(obj.__class__))
1931 #if '__base__' in words: 1/0
1947 #if '__base__' in words: 1/0
1932
1948
1933 # Some libraries (such as traits) may introduce duplicates, we want to
1949 # Some libraries (such as traits) may introduce duplicates, we want to
1934 # track and clean this up if it happens
1950 # track and clean this up if it happens
1935 may_have_dupes = False
1951 may_have_dupes = False
1936
1952
1937 # this is the 'dir' function for objects with Enthought's traits
1953 # this is the 'dir' function for objects with Enthought's traits
1938 if hasattr(obj, 'trait_names'):
1954 if hasattr(obj, 'trait_names'):
1939 try:
1955 try:
1940 words.extend(obj.trait_names())
1956 words.extend(obj.trait_names())
1941 may_have_dupes = True
1957 may_have_dupes = True
1942 except TypeError:
1958 except TypeError:
1943 # This will happen if `obj` is a class and not an instance.
1959 # This will happen if `obj` is a class and not an instance.
1944 pass
1960 pass
1945
1961
1946 # Support for PyCrust-style _getAttributeNames magic method.
1962 # Support for PyCrust-style _getAttributeNames magic method.
1947 if hasattr(obj, '_getAttributeNames'):
1963 if hasattr(obj, '_getAttributeNames'):
1948 try:
1964 try:
1949 words.extend(obj._getAttributeNames())
1965 words.extend(obj._getAttributeNames())
1950 may_have_dupes = True
1966 may_have_dupes = True
1951 except TypeError:
1967 except TypeError:
1952 # `obj` is a class and not an instance. Ignore
1968 # `obj` is a class and not an instance. Ignore
1953 # this error.
1969 # this error.
1954 pass
1970 pass
1955
1971
1956 if may_have_dupes:
1972 if may_have_dupes:
1957 # eliminate possible duplicates, as some traits may also
1973 # eliminate possible duplicates, as some traits may also
1958 # appear as normal attributes in the dir() call.
1974 # appear as normal attributes in the dir() call.
1959 words = list(set(words))
1975 words = list(set(words))
1960 words.sort()
1976 words.sort()
1961
1977
1962 # filter out non-string attributes which may be stuffed by dir() calls
1978 # filter out non-string attributes which may be stuffed by dir() calls
1963 # and poor coding in third-party modules
1979 # and poor coding in third-party modules
1964 return [w for w in words if isinstance(w, basestring)]
1980 return [w for w in words if isinstance(w, basestring)]
1965
1981
1966 #----------------------------------------------------------------------------
1982 #----------------------------------------------------------------------------
1967 def import_fail_info(mod_name,fns=None):
1983 def import_fail_info(mod_name,fns=None):
1968 """Inform load failure for a module."""
1984 """Inform load failure for a module."""
1969
1985
1970 if fns == None:
1986 if fns == None:
1971 warn("Loading of %s failed.\n" % (mod_name,))
1987 warn("Loading of %s failed.\n" % (mod_name,))
1972 else:
1988 else:
1973 warn("Loading of %s from %s failed.\n" % (fns,mod_name))
1989 warn("Loading of %s from %s failed.\n" % (fns,mod_name))
1974
1990
1975 #----------------------------------------------------------------------------
1991 #----------------------------------------------------------------------------
1976 # Proposed popitem() extension, written as a method
1992 # Proposed popitem() extension, written as a method
1977
1993
1978
1994
1979 class NotGiven: pass
1995 class NotGiven: pass
1980
1996
1981 def popkey(dct,key,default=NotGiven):
1997 def popkey(dct,key,default=NotGiven):
1982 """Return dct[key] and delete dct[key].
1998 """Return dct[key] and delete dct[key].
1983
1999
1984 If default is given, return it if dct[key] doesn't exist, otherwise raise
2000 If default is given, return it if dct[key] doesn't exist, otherwise raise
1985 KeyError. """
2001 KeyError. """
1986
2002
1987 try:
2003 try:
1988 val = dct[key]
2004 val = dct[key]
1989 except KeyError:
2005 except KeyError:
1990 if default is NotGiven:
2006 if default is NotGiven:
1991 raise
2007 raise
1992 else:
2008 else:
1993 return default
2009 return default
1994 else:
2010 else:
1995 del dct[key]
2011 del dct[key]
1996 return val
2012 return val
1997
2013
1998 def wrap_deprecated(func, suggest = '<nothing>'):
2014 def wrap_deprecated(func, suggest = '<nothing>'):
1999 def newFunc(*args, **kwargs):
2015 def newFunc(*args, **kwargs):
2000 warnings.warn("Call to deprecated function %s, use %s instead" %
2016 warnings.warn("Call to deprecated function %s, use %s instead" %
2001 ( func.__name__, suggest),
2017 ( func.__name__, suggest),
2002 category=DeprecationWarning,
2018 category=DeprecationWarning,
2003 stacklevel = 2)
2019 stacklevel = 2)
2004 return func(*args, **kwargs)
2020 return func(*args, **kwargs)
2005 return newFunc
2021 return newFunc
2006
2022
2007 #*************************** end of file <genutils.py> **********************
2023 #*************************** end of file <genutils.py> **********************
2008
2024
@@ -1,436 +1,460 b''
1 #!/usr/bin/python
1 #!/usr/bin/python
2 # -*- coding: iso-8859-15 -*-
2 # -*- coding: iso-8859-15 -*-
3 '''
3 '''
4 Provides IPython remote instance.
4 Provides IPython remote instance.
5
5
6 @author: Laurent Dufrechou
6 @author: Laurent Dufrechou
7 laurent.dufrechou _at_ gmail.com
7 laurent.dufrechou _at_ gmail.com
8 @license: BSD
8 @license: BSD
9
9
10 All rights reserved. This program and the accompanying materials are made
10 All rights reserved. This program and the accompanying materials are made
11 available under the terms of the BSD which accompanies this distribution, and
11 available under the terms of the BSD which accompanies this distribution, and
12 is available at U{http://www.opensource.org/licenses/bsd-license.php}
12 is available at U{http://www.opensource.org/licenses/bsd-license.php}
13 '''
13 '''
14
14
15 __version__ = 0.9
15 __version__ = 0.9
16 __author__ = "Laurent Dufrechou"
16 __author__ = "Laurent Dufrechou"
17 __email__ = "laurent.dufrechou _at_ gmail.com"
17 __email__ = "laurent.dufrechou _at_ gmail.com"
18 __license__ = "BSD"
18 __license__ = "BSD"
19
19
20 import re
20 import re
21 import sys
21 import sys
22 import os
22 import os
23 import locale
23 import locale
24 import time
24 import time
25 import pydoc,__builtin__,site
25 import pydoc,__builtin__,site
26 from thread_ex import ThreadEx
26 from thread_ex import ThreadEx
27 from StringIO import StringIO
27 from StringIO import StringIO
28
28
29 try:
29 try:
30 import IPython
30 import IPython
31 except Exception,e:
31 except Exception,e:
32 raise "Error importing IPython (%s)" % str(e)
32 raise "Error importing IPython (%s)" % str(e)
33
33
34 ##############################################################################
34 ##############################################################################
35 class _Helper(object):
35 class _Helper(object):
36 """Redefine the built-in 'help'.
36 """Redefine the built-in 'help'.
37 This is a wrapper around pydoc.help (with a twist).
37 This is a wrapper around pydoc.help (with a twist).
38 """
38 """
39
39
40 def __init__(self,pager):
40 def __init__(self,pager):
41 self._pager = pager
41 self._pager = pager
42
42
43 def __repr__(self):
43 def __repr__(self):
44 return "Type help() for interactive help, " \
44 return "Type help() for interactive help, " \
45 "or help(object) for help about object."
45 "or help(object) for help about object."
46
46
47 def __call__(self, *args, **kwds):
47 def __call__(self, *args, **kwds):
48 class DummyWriter(object):
48 class DummyWriter(object):
49 def __init__(self,pager):
49 def __init__(self,pager):
50 self._pager = pager
50 self._pager = pager
51
51
52 def write(self,data):
52 def write(self,data):
53 self._pager(data)
53 self._pager(data)
54
54
55 import pydoc
55 import pydoc
56 pydoc.help.output = DummyWriter(self._pager)
56 pydoc.help.output = DummyWriter(self._pager)
57 pydoc.help.interact = lambda :1
57 pydoc.help.interact = lambda :1
58
58
59 return pydoc.help(*args, **kwds)
59 return pydoc.help(*args, **kwds)
60
60
61
61
62 ##############################################################################
62 ##############################################################################
63 class _CodeExecutor(ThreadEx):
63 class _CodeExecutor(ThreadEx):
64
64
65 def __init__(self, instance, after):
65 def __init__(self, instance, after):
66 ThreadEx.__init__(self)
66 ThreadEx.__init__(self)
67 self.instance = instance
67 self.instance = instance
68 self._afterExecute=after
68 self._afterExecute=after
69
69
70 def run(self):
70 def run(self):
71 try:
71 try:
72 self.instance._doc_text = None
72 self.instance._doc_text = None
73 self.instance._help_text = None
73 self.instance._help_text = None
74 self.instance._execute()
74 self.instance._execute()
75 # used for uper class to generate event after execution
75 # used for uper class to generate event after execution
76 self._afterExecute()
76 self._afterExecute()
77
77
78 except KeyboardInterrupt:
78 except KeyboardInterrupt:
79 pass
79 pass
80
80
81
81
82 ##############################################################################
82 ##############################################################################
83 class NonBlockingIPShell(object):
83 class NonBlockingIPShell(object):
84 '''
84 '''
85 Create an IPython instance, running the commands in a separate,
85 Create an IPython instance, running the commands in a separate,
86 non-blocking thread.
86 non-blocking thread.
87 This allows embedding in any GUI without blockage.
87 This allows embedding in any GUI without blockage.
88
88
89 Note: The ThreadEx class supports asynchroneous function call
89 Note: The ThreadEx class supports asynchroneous function call
90 via raise_exc()
90 via raise_exc()
91 '''
91 '''
92
92
93 def __init__(self,argv=[],user_ns={},user_global_ns=None,
93 def __init__(self,argv=[],user_ns={},user_global_ns=None,
94 cin=None, cout=None, cerr=None,
94 cin=None, cout=None, cerr=None,
95 ask_exit_handler=None, rawinput=None):
95 ask_exit_handler=None):
96 '''
96 '''
97 @param argv: Command line options for IPython
97 @param argv: Command line options for IPython
98 @type argv: list
98 @type argv: list
99 @param user_ns: User namespace.
99 @param user_ns: User namespace.
100 @type user_ns: dictionary
100 @type user_ns: dictionary
101 @param user_global_ns: User global namespace.
101 @param user_global_ns: User global namespace.
102 @type user_global_ns: dictionary.
102 @type user_global_ns: dictionary.
103 @param cin: Console standard input.
103 @param cin: Console standard input.
104 @type cin: IO stream
104 @type cin: IO stream
105 @param cout: Console standard output.
105 @param cout: Console standard output.
106 @type cout: IO stream
106 @type cout: IO stream
107 @param cerr: Console standard error.
107 @param cerr: Console standard error.
108 @type cerr: IO stream
108 @type cerr: IO stream
109 @param exit_handler: Replacement for builtin exit() function
109 @param exit_handler: Replacement for builtin exit() function
110 @type exit_handler: function
110 @type exit_handler: function
111 @param time_loop: Define the sleep time between two thread's loop
111 @param time_loop: Define the sleep time between two thread's loop
112 @type int
112 @type int
113 '''
113 '''
114 #ipython0 initialisation
114 #ipython0 initialisation
115 self.initIpython0(argv, user_ns, user_global_ns,
115 self.initIpython0(argv, user_ns, user_global_ns,
116 cin, cout, cerr,
116 cin, cout, cerr,
117 ask_exit_handler, rawinput)
117 ask_exit_handler)
118
118
119 #vars used by _execute
119 #vars used by _execute
120 self._iter_more = 0
120 self._iter_more = 0
121 self._history_level = 0
121 self._history_level = 0
122 self._complete_sep = re.compile('[\s\{\}\[\]\(\)]')
122 self._complete_sep = re.compile('[\s\{\}\[\]\(\)]')
123 self._prompt = str(self._IP.outputcache.prompt1).strip()
123 self._prompt = str(self._IP.outputcache.prompt1).strip()
124
124
125 #thread working vars
125 #thread working vars
126 self._line_to_execute = ''
126 self._line_to_execute = ''
127
127
128 #vars that will be checked by GUI loop to handle thread states...
128 #vars that will be checked by GUI loop to handle thread states...
129 #will be replaced later by PostEvent GUI funtions...
129 #will be replaced later by PostEvent GUI funtions...
130 self._doc_text = None
130 self._doc_text = None
131 self._help_text = None
131 self._help_text = None
132 self._add_button = None
132 self._add_button = None
133
133
134 def initIpython0(self, argv=[], user_ns={}, user_global_ns=None,
134 def initIpython0(self, argv=[], user_ns={}, user_global_ns=None,
135 cin=None, cout=None, cerr=None,
135 cin=None, cout=None, cerr=None,
136 ask_exit_handler=None, rawinput=None):
136 ask_exit_handler=None):
137 #first we redefine in/out/error functions of IPython
137 #first we redefine in/out/error functions of IPython
138 if cin:
138 if cin:
139 IPython.Shell.Term.cin = cin
139 IPython.Shell.Term.cin = cin
140 if cout:
140 if cout:
141 IPython.Shell.Term.cout = cout
141 IPython.Shell.Term.cout = cout
142 if cerr:
142 if cerr:
143 IPython.Shell.Term.cerr = cerr
143 IPython.Shell.Term.cerr = cerr
144
144
145 # This is to get rid of the blockage that accurs during
145 # This is to get rid of the blockage that accurs during
146 # IPython.Shell.InteractiveShell.user_setup()
146 # IPython.Shell.InteractiveShell.user_setup()
147 IPython.iplib.raw_input = lambda x: None
147 IPython.iplib.raw_input = lambda x: None
148
148
149 self._term = IPython.genutils.IOTerm(cin=cin, cout=cout, cerr=cerr)
149 self._term = IPython.genutils.IOTerm(cin=cin, cout=cout, cerr=cerr)
150
150
151 excepthook = sys.excepthook
151 excepthook = sys.excepthook
152
152
153 self._IP = IPython.Shell.make_IPython(
153 self._IP = IPython.Shell.make_IPython(
154 argv,user_ns=user_ns,
154 argv,user_ns=user_ns,
155 user_global_ns=user_global_ns,
155 user_global_ns=user_global_ns,
156 embedded=True,
156 embedded=True,
157 shell_class=IPython.Shell.InteractiveShell)
157 shell_class=IPython.Shell.InteractiveShell)
158
158
159 #we replace IPython default encoding by wx locale encoding
159 #we replace IPython default encoding by wx locale encoding
160 loc = locale.getpreferredencoding()
160 loc = locale.getpreferredencoding()
161 if loc:
161 if loc:
162 self._IP.stdin_encoding = loc
162 self._IP.stdin_encoding = loc
163 #we replace the ipython default pager by our pager
163 #we replace the ipython default pager by our pager
164 self._IP.set_hook('show_in_pager',self._pager)
164 self._IP.set_hook('show_in_pager',self._pager)
165
165
166 #we replace the ipython default shell command caller by our shell handler
166 #we replace the ipython default shell command caller by our shell handler
167 self._IP.set_hook('shell_hook',self._shell)
167 self._IP.set_hook('shell_hook',self._shell)
168
168
169 #we replace the ipython default input command caller by our method
169 #we replace the ipython default input command caller by our method
170 IPython.iplib.raw_input_original = rawinput
170 IPython.iplib.raw_input_original = self._raw_input
171
172 #we replace the ipython default exit command by our method
171 #we replace the ipython default exit command by our method
173 self._IP.exit = ask_exit_handler
172 self._IP.exit = ask_exit_handler
174 #we replace the help command
173 #we replace the help command
175 self._IP.user_ns['help'] = _Helper(self._pager_help)
174 self._IP.user_ns['help'] = _Helper(self._pager_help)
175
176 #we disable cpase magic... until we found a way to use it properly.
177 #import IPython.ipapi
178 ip = IPython.ipapi.get()
179 def bypassMagic(self, arg):
180 print '%this magic is currently disabled.'
181 ip.expose_magic('cpaste', bypassMagic)
176
182
177 sys.excepthook = excepthook
183 sys.excepthook = excepthook
178
184
179 #----------------------- Thread management section ----------------------
185 #----------------------- Thread management section ----------------------
180 def doExecute(self,line):
186 def doExecute(self,line):
181 """
187 """
182 Tell the thread to process the 'line' command
188 Tell the thread to process the 'line' command
183 """
189 """
184
190
185 self._line_to_execute = line
191 self._line_to_execute = line
186 #we launch the ipython line execution in a thread to make it interruptible
192 #we launch the ipython line execution in a thread to make it interruptible
187 self.ce = _CodeExecutor(self,self._afterExecute)
193 self.ce = _CodeExecutor(self,self._afterExecute)
188 self.ce.start()
194 self.ce.start()
189
195
190 #----------------------- IPython management section ----------------------
196 #----------------------- IPython management section ----------------------
191 def getDocText(self):
197 def getDocText(self):
192 """
198 """
193 Returns the output of the processing that need to be paged (if any)
199 Returns the output of the processing that need to be paged (if any)
194
200
195 @return: The std output string.
201 @return: The std output string.
196 @rtype: string
202 @rtype: string
197 """
203 """
198 return self._doc_text
204 return self._doc_text
199
205
200 def getHelpText(self):
206 def getHelpText(self):
201 """
207 """
202 Returns the output of the processing that need to be paged via help pager(if any)
208 Returns the output of the processing that need to be paged via help pager(if any)
203
209
204 @return: The std output string.
210 @return: The std output string.
205 @rtype: string
211 @rtype: string
206 """
212 """
207 return self._help_text
213 return self._help_text
208
214
209 def getBanner(self):
215 def getBanner(self):
210 """
216 """
211 Returns the IPython banner for useful info on IPython instance
217 Returns the IPython banner for useful info on IPython instance
212
218
213 @return: The banner string.
219 @return: The banner string.
214 @rtype: string
220 @rtype: string
215 """
221 """
216 return self._IP.BANNER
222 return self._IP.BANNER
217
223
218 def getPromptCount(self):
224 def getPromptCount(self):
219 """
225 """
220 Returns the prompt number.
226 Returns the prompt number.
221 Each time a user execute a line in the IPython shell the prompt count is increased
227 Each time a user execute a line in the IPython shell the prompt count is increased
222
228
223 @return: The prompt number
229 @return: The prompt number
224 @rtype: int
230 @rtype: int
225 """
231 """
226 return self._IP.outputcache.prompt_count
232 return self._IP.outputcache.prompt_count
227
233
228 def getPrompt(self):
234 def getPrompt(self):
229 """
235 """
230 Returns current prompt inside IPython instance
236 Returns current prompt inside IPython instance
231 (Can be In [...]: ot ...:)
237 (Can be In [...]: ot ...:)
232
238
233 @return: The current prompt.
239 @return: The current prompt.
234 @rtype: string
240 @rtype: string
235 """
241 """
236 return self._prompt
242 return self._prompt
237
243
238 def getIndentation(self):
244 def getIndentation(self):
239 """
245 """
240 Returns the current indentation level
246 Returns the current indentation level
241 Usefull to put the caret at the good start position if we want to do autoindentation.
247 Usefull to put the caret at the good start position if we want to do autoindentation.
242
248
243 @return: The indentation level.
249 @return: The indentation level.
244 @rtype: int
250 @rtype: int
245 """
251 """
246 return self._IP.indent_current_nsp
252 return self._IP.indent_current_nsp
247
253
248 def updateNamespace(self, ns_dict):
254 def updateNamespace(self, ns_dict):
249 '''
255 '''
250 Add the current dictionary to the shell namespace.
256 Add the current dictionary to the shell namespace.
251
257
252 @param ns_dict: A dictionary of symbol-values.
258 @param ns_dict: A dictionary of symbol-values.
253 @type ns_dict: dictionary
259 @type ns_dict: dictionary
254 '''
260 '''
255 self._IP.user_ns.update(ns_dict)
261 self._IP.user_ns.update(ns_dict)
256
262
257 def complete(self, line):
263 def complete(self, line):
258 '''
264 '''
259 Returns an auto completed line and/or posibilities for completion.
265 Returns an auto completed line and/or posibilities for completion.
260
266
261 @param line: Given line so far.
267 @param line: Given line so far.
262 @type line: string
268 @type line: string
263
269
264 @return: Line completed as for as possible,
270 @return: Line completed as for as possible,
265 and possible further completions.
271 and possible further completions.
266 @rtype: tuple
272 @rtype: tuple
267 '''
273 '''
268 split_line = self._complete_sep.split(line)
274 split_line = self._complete_sep.split(line)
269 possibilities = self._IP.complete(split_line[-1])
275 possibilities = self._IP.complete(split_line[-1])
270 if possibilities:
276 if possibilities:
271
277
272 def _commonPrefix(str1, str2):
278 def _commonPrefix(str1, str2):
273 '''
279 '''
274 Reduction function. returns common prefix of two given strings.
280 Reduction function. returns common prefix of two given strings.
275
281
276 @param str1: First string.
282 @param str1: First string.
277 @type str1: string
283 @type str1: string
278 @param str2: Second string
284 @param str2: Second string
279 @type str2: string
285 @type str2: string
280
286
281 @return: Common prefix to both strings.
287 @return: Common prefix to both strings.
282 @rtype: string
288 @rtype: string
283 '''
289 '''
284 for i in range(len(str1)):
290 for i in range(len(str1)):
285 if not str2.startswith(str1[:i+1]):
291 if not str2.startswith(str1[:i+1]):
286 return str1[:i]
292 return str1[:i]
287 return str1
293 return str1
288 common_prefix = reduce(_commonPrefix, possibilities)
294 common_prefix = reduce(_commonPrefix, possibilities)
289 completed = line[:-len(split_line[-1])]+common_prefix
295 completed = line[:-len(split_line[-1])]+common_prefix
290 else:
296 else:
291 completed = line
297 completed = line
292 return completed, possibilities
298 return completed, possibilities
293
299
294 def historyBack(self):
300 def historyBack(self):
295 '''
301 '''
296 Provides one history command back.
302 Provides one history command back.
297
303
298 @return: The command string.
304 @return: The command string.
299 @rtype: string
305 @rtype: string
300 '''
306 '''
301 history = ''
307 history = ''
302 #the below while loop is used to suppress empty history lines
308 #the below while loop is used to suppress empty history lines
303 while((history == '' or history == '\n') and self._history_level >0):
309 while((history == '' or history == '\n') and self._history_level >0):
304 if self._history_level>=1:
310 if self._history_level>=1:
305 self._history_level -= 1
311 self._history_level -= 1
306 history = self._getHistory()
312 history = self._getHistory()
307 return history
313 return history
308
314
309 def historyForward(self):
315 def historyForward(self):
310 '''
316 '''
311 Provides one history command forward.
317 Provides one history command forward.
312
318
313 @return: The command string.
319 @return: The command string.
314 @rtype: string
320 @rtype: string
315 '''
321 '''
316 history = ''
322 history = ''
317 #the below while loop is used to suppress empty history lines
323 #the below while loop is used to suppress empty history lines
318 while((history == '' or history == '\n') and self._history_level <= self._getHistoryMaxIndex()):
324 while((history == '' or history == '\n') and self._history_level <= self._getHistoryMaxIndex()):
319 if self._history_level < self._getHistoryMaxIndex():
325 if self._history_level < self._getHistoryMaxIndex():
320 self._history_level += 1
326 self._history_level += 1
321 history = self._getHistory()
327 history = self._getHistory()
322 else:
328 else:
323 if self._history_level == self._getHistoryMaxIndex():
329 if self._history_level == self._getHistoryMaxIndex():
324 history = self._getHistory()
330 history = self._getHistory()
325 self._history_level += 1
331 self._history_level += 1
326 else:
332 else:
327 history = ''
333 history = ''
328 return history
334 return history
329
335
330 def initHistoryIndex(self):
336 def initHistoryIndex(self):
331 '''
337 '''
332 set history to last command entered
338 set history to last command entered
333 '''
339 '''
334 self._history_level = self._getHistoryMaxIndex()+1
340 self._history_level = self._getHistoryMaxIndex()+1
335
341
336 #----------------------- IPython PRIVATE management section --------------
342 #----------------------- IPython PRIVATE management section --------------
337 def _afterExecute(self):
343 def _afterExecute(self):
338 '''
344 '''
339 Can be redefined to generate post event after excution is done
345 Can be redefined to generate post event after excution is done
340 '''
346 '''
341 pass
347 pass
342
348
349 #def _askExit(self):
350 # '''
351 # Can be redefined to generate post event to exit the Ipython shell
352 # '''
353 # pass
354
343 def _getHistoryMaxIndex(self):
355 def _getHistoryMaxIndex(self):
344 '''
356 '''
345 returns the max length of the history buffer
357 returns the max length of the history buffer
346
358
347 @return: history length
359 @return: history length
348 @rtype: int
360 @rtype: int
349 '''
361 '''
350 return len(self._IP.input_hist_raw)-1
362 return len(self._IP.input_hist_raw)-1
351
363
352 def _getHistory(self):
364 def _getHistory(self):
353 '''
365 '''
354 Get's the command string of the current history level.
366 Get's the command string of the current history level.
355
367
356 @return: Historic command stri
368 @return: Historic command stri
357 @rtype: string
369 @rtype: string
358 '''
370 '''
359 rv = self._IP.input_hist_raw[self._history_level].strip('\n')
371 rv = self._IP.input_hist_raw[self._history_level].strip('\n')
360 return rv
372 return rv
361
373
362 def _pager_help(self,text):
374 def _pager_help(self,text):
363 '''
375 '''
364 This function is used as a callback replacment to IPython help pager function
376 This function is used as a callback replacment to IPython help pager function
365
377
366 It puts the 'text' value inside the self._help_text string that can be retrived via getHelpText
378 It puts the 'text' value inside the self._help_text string that can be retrived via getHelpText
367 function.
379 function.
368 '''
380 '''
369 if self._help_text == None:
381 if self._help_text == None:
370 self._help_text = text
382 self._help_text = text
371 else:
383 else:
372 self._help_text += text
384 self._help_text += text
373
385
374 def _pager(self,IP,text):
386 def _pager(self,IP,text):
375 '''
387 '''
376 This function is used as a callback replacment to IPython pager function
388 This function is used as a callback replacment to IPython pager function
377
389
378 It puts the 'text' value inside the self._doc_text string that can be retrived via getDocText
390 It puts the 'text' value inside the self._doc_text string that can be retrived via getDocText
379 function.
391 function.
380 '''
392 '''
381 self._doc_text = text
393 self._doc_text = text
382
394
395 def _raw_input(self, prompt=''):
396 '''
397 Custom raw_input() replacement. Get's current line from console buffer.
398
399 @param prompt: Prompt to print. Here for compatability as replacement.
400 @type prompt: string
401
402 @return: The current command line text.
403 @rtype: string
404 '''
405 return self._line_to_execute
406
383 def _execute(self):
407 def _execute(self):
384 '''
408 '''
385 Executes the current line provided by the shell object.
409 Executes the current line provided by the shell object.
386 '''
410 '''
387 orig_stdout = sys.stdout
411 orig_stdout = sys.stdout
388 sys.stdout = IPython.Shell.Term.cout
412 sys.stdout = IPython.Shell.Term.cout
389
413
390 try:
414 try:
391 line = self._IP.raw_input(None, self._iter_more)
415 line = self._IP.raw_input(None, self._iter_more)
392 if self._IP.autoindent:
416 if self._IP.autoindent:
393 self._IP.readline_startup_hook(None)
417 self._IP.readline_startup_hook(None)
394
418
395 except KeyboardInterrupt:
419 except KeyboardInterrupt:
396 self._IP.write('\nKeyboardInterrupt\n')
420 self._IP.write('\nKeyboardInterrupt\n')
397 self._IP.resetbuffer()
421 self._IP.resetbuffer()
398 # keep cache in sync with the prompt counter:
422 # keep cache in sync with the prompt counter:
399 self._IP.outputcache.prompt_count -= 1
423 self._IP.outputcache.prompt_count -= 1
400
424
401 if self._IP.autoindent:
425 if self._IP.autoindent:
402 self._IP.indent_current_nsp = 0
426 self._IP.indent_current_nsp = 0
403 self._iter_more = 0
427 self._iter_more = 0
404 except:
428 except:
405 self._IP.showtraceback()
429 self._IP.showtraceback()
406 else:
430 else:
407 self._iter_more = self._IP.push(line)
431 self._iter_more = self._IP.push(line)
408 if (self._IP.SyntaxTB.last_syntax_error and
432 if (self._IP.SyntaxTB.last_syntax_error and
409 self._IP.rc.autoedit_syntax):
433 self._IP.rc.autoedit_syntax):
410 self._IP.edit_syntax_error()
434 self._IP.edit_syntax_error()
411 if self._iter_more:
435 if self._iter_more:
412 self._prompt = str(self._IP.outputcache.prompt2).strip()
436 self._prompt = str(self._IP.outputcache.prompt2).strip()
413 if self._IP.autoindent:
437 if self._IP.autoindent:
414 self._IP.readline_startup_hook(self._IP.pre_readline)
438 self._IP.readline_startup_hook(self._IP.pre_readline)
415 else:
439 else:
416 self._prompt = str(self._IP.outputcache.prompt1).strip()
440 self._prompt = str(self._IP.outputcache.prompt1).strip()
417 self._IP.indent_current_nsp = 0 #we set indentation to 0
441 self._IP.indent_current_nsp = 0 #we set indentation to 0
418 sys.stdout = orig_stdout
442 sys.stdout = orig_stdout
419
443
420 def _shell(self, ip, cmd):
444 def _shell(self, ip, cmd):
421 '''
445 '''
422 Replacement method to allow shell commands without them blocking.
446 Replacement method to allow shell commands without them blocking.
423
447
424 @param ip: Ipython instance, same as self._IP
448 @param ip: Ipython instance, same as self._IP
425 @type cmd: Ipython instance
449 @type cmd: Ipython instance
426 @param cmd: Shell command to execute.
450 @param cmd: Shell command to execute.
427 @type cmd: string
451 @type cmd: string
428 '''
452 '''
429 stdin, stdout = os.popen4(cmd)
453 stdin, stdout = os.popen4(cmd)
430 result = stdout.read().decode('cp437').encode(locale.getpreferredencoding())
454 result = stdout.read().decode('cp437').encode(locale.getpreferredencoding())
431 #we use print command because the shell command is called inside IPython instance and thus is
455 #we use print command because the shell command is called inside IPython instance and thus is
432 #redirected to thread cout
456 #redirected to thread cout
433 #"\x01\x1b[1;36m\x02" <-- add colour to the text...
457 #"\x01\x1b[1;36m\x02" <-- add colour to the text...
434 print "\x01\x1b[1;36m\x02"+result
458 print "\x01\x1b[1;36m\x02"+result
435 stdout.close()
459 stdout.close()
436 stdin.close()
460 stdin.close()
@@ -1,737 +1,752 b''
1 #!/usr/bin/python
1 #!/usr/bin/python
2 # -*- coding: iso-8859-15 -*-
2 # -*- coding: iso-8859-15 -*-
3 '''
3 '''
4 Provides IPython WX console widgets.
4 Provides IPython WX console widgets.
5
5
6 @author: Laurent Dufrechou
6 @author: Laurent Dufrechou
7 laurent.dufrechou _at_ gmail.com
7 laurent.dufrechou _at_ gmail.com
8 This WX widget is based on the original work of Eitan Isaacson
8 This WX widget is based on the original work of Eitan Isaacson
9 that provided the console for the GTK toolkit.
9 that provided the console for the GTK toolkit.
10
10
11 Original work from:
11 Original work from:
12 @author: Eitan Isaacson
12 @author: Eitan Isaacson
13 @organization: IBM Corporation
13 @organization: IBM Corporation
14 @copyright: Copyright (c) 2007 IBM Corporation
14 @copyright: Copyright (c) 2007 IBM Corporation
15 @license: BSD
15 @license: BSD
16
16
17 All rights reserved. This program and the accompanying materials are made
17 All rights reserved. This program and the accompanying materials are made
18 available under the terms of the BSD which accompanies this distribution, and
18 available under the terms of the BSD which accompanies this distribution, and
19 is available at U{http://www.opensource.org/licenses/bsd-license.php}
19 is available at U{http://www.opensource.org/licenses/bsd-license.php}
20 '''
20 '''
21
21
22 __version__ = 0.8
22 __version__ = 0.8
23 __author__ = "Laurent Dufrechou"
23 __author__ = "Laurent Dufrechou"
24 __email__ = "laurent.dufrechou _at_ gmail.com"
24 __email__ = "laurent.dufrechou _at_ gmail.com"
25 __license__ = "BSD"
25 __license__ = "BSD"
26
26
27 import wx
27 import wx
28 import wx.stc as stc
28 import wx.stc as stc
29 import wx.lib.newevent
29 import wx.lib.newevent
30
30
31 import re
31 import re
32 import sys
32 import sys
33 import locale
33 import locale
34 from StringIO import StringIO
34 from StringIO import StringIO
35 try:
35 try:
36 import IPython
36 import IPython
37 except Exception,e:
37 except Exception,e:
38 raise "Error importing IPython (%s)" % str(e)
38 raise "Error importing IPython (%s)" % str(e)
39
39
40 from ipshell_nonblocking import NonBlockingIPShell
40 from ipshell_nonblocking import NonBlockingIPShell
41
41
42
42
43 class WxNonBlockingIPShell(NonBlockingIPShell):
43 class WxNonBlockingIPShell(NonBlockingIPShell):
44 '''
44 '''
45 An NonBlockingIPShell Thread that is WX dependent.
45 An NonBlockingIPShell Thread that is WX dependent.
46 '''
46 '''
47 def __init__(self, parent,
47 def __init__(self, parent,
48 argv=[],user_ns={},user_global_ns=None,
48 argv=[],user_ns={},user_global_ns=None,
49 cin=None, cout=None, cerr=None,
49 cin=None, cout=None, cerr=None,
50 ask_exit_handler=None, rawinput=None):
50 ask_exit_handler=None):
51
51
52 NonBlockingIPShell.__init__(self,argv,user_ns,user_global_ns,
52 NonBlockingIPShell.__init__(self,argv,user_ns,user_global_ns,
53 cin, cout, cerr,
53 cin, cout, cerr,
54 ask_exit_handler,
54 ask_exit_handler)
55 rawinput)
56
55
57 self.parent = parent
56 self.parent = parent
58
57
59 self.ask_exit_callback = ask_exit_handler
58 self.ask_exit_callback = ask_exit_handler
60 self._IP.exit = self._askExit
59 self._IP.exit = self._askExit
61
60
62 def addGUIShortcut(self,text,func):
61 def addGUIShortcut(self,text,func):
63 wx.CallAfter(self.parent.add_button_handler,
62 wx.CallAfter(self.parent.add_button_handler,
64 button_info={ 'text':text,
63 button_info={ 'text':text,
65 'func':self.parent.doExecuteLine(func)})
64 'func':self.parent.doExecuteLine(func)})
66
65
67 def _askExit(self):
66 def _askExit(self):
68 wx.CallAfter(self.ask_exit_callback, ())
67 wx.CallAfter(self.ask_exit_callback, ())
69
68
70 def _afterExecute(self):
69 def _afterExecute(self):
71 wx.CallAfter(self.parent.evtStateExecuteDone, ())
70 wx.CallAfter(self.parent.evtStateExecuteDone, ())
72
71
73
72
74 class WxConsoleView(stc.StyledTextCtrl):
73 class WxConsoleView(stc.StyledTextCtrl):
75 '''
74 '''
76 Specialized styled text control view for console-like workflow.
75 Specialized styled text control view for console-like workflow.
77 We use here a scintilla frontend thus it can be reused in any GUI that
76 We use here a scintilla frontend thus it can be reused in any GUI that
78 supports scintilla with less work.
77 supports scintilla with less work.
79
78
80 @cvar ANSI_COLORS_BLACK: Mapping of terminal colors to X11 names.
79 @cvar ANSI_COLORS_BLACK: Mapping of terminal colors to X11 names.
81 (with Black background)
80 (with Black background)
82 @type ANSI_COLORS_BLACK: dictionary
81 @type ANSI_COLORS_BLACK: dictionary
83
82
84 @cvar ANSI_COLORS_WHITE: Mapping of terminal colors to X11 names.
83 @cvar ANSI_COLORS_WHITE: Mapping of terminal colors to X11 names.
85 (with White background)
84 (with White background)
86 @type ANSI_COLORS_WHITE: dictionary
85 @type ANSI_COLORS_WHITE: dictionary
87
86
88 @ivar color_pat: Regex of terminal color pattern
87 @ivar color_pat: Regex of terminal color pattern
89 @type color_pat: _sre.SRE_Pattern
88 @type color_pat: _sre.SRE_Pattern
90 '''
89 '''
91 ANSI_STYLES_BLACK={'0;30': [0,'WHITE'], '0;31': [1,'RED'],
90 ANSI_STYLES_BLACK={'0;30': [0,'WHITE'], '0;31': [1,'RED'],
92 '0;32': [2,'GREEN'], '0;33': [3,'BROWN'],
91 '0;32': [2,'GREEN'], '0;33': [3,'BROWN'],
93 '0;34': [4,'BLUE'], '0;35': [5,'PURPLE'],
92 '0;34': [4,'BLUE'], '0;35': [5,'PURPLE'],
94 '0;36': [6,'CYAN'], '0;37': [7,'LIGHT GREY'],
93 '0;36': [6,'CYAN'], '0;37': [7,'LIGHT GREY'],
95 '1;30': [8,'DARK GREY'], '1;31': [9,'RED'],
94 '1;30': [8,'DARK GREY'], '1;31': [9,'RED'],
96 '1;32': [10,'SEA GREEN'], '1;33': [11,'YELLOW'],
95 '1;32': [10,'SEA GREEN'], '1;33': [11,'YELLOW'],
97 '1;34': [12,'LIGHT BLUE'], '1;35':
96 '1;34': [12,'LIGHT BLUE'], '1;35':
98 [13,'MEDIUM VIOLET RED'],
97 [13,'MEDIUM VIOLET RED'],
99 '1;36': [14,'LIGHT STEEL BLUE'],'1;37': [15,'YELLOW']}
98 '1;36': [14,'LIGHT STEEL BLUE'],'1;37': [15,'YELLOW']}
100
99
101 ANSI_STYLES_WHITE={'0;30': [0,'BLACK'], '0;31': [1,'RED'],
100 ANSI_STYLES_WHITE={'0;30': [0,'BLACK'], '0;31': [1,'RED'],
102 '0;32': [2,'GREEN'], '0;33': [3,'BROWN'],
101 '0;32': [2,'GREEN'], '0;33': [3,'BROWN'],
103 '0;34': [4,'BLUE'], '0;35': [5,'PURPLE'],
102 '0;34': [4,'BLUE'], '0;35': [5,'PURPLE'],
104 '0;36': [6,'CYAN'], '0;37': [7,'LIGHT GREY'],
103 '0;36': [6,'CYAN'], '0;37': [7,'LIGHT GREY'],
105 '1;30': [8,'DARK GREY'], '1;31': [9,'RED'],
104 '1;30': [8,'DARK GREY'], '1;31': [9,'RED'],
106 '1;32': [10,'SEA GREEN'], '1;33': [11,'YELLOW'],
105 '1;32': [10,'SEA GREEN'], '1;33': [11,'YELLOW'],
107 '1;34': [12,'LIGHT BLUE'], '1;35':
106 '1;34': [12,'LIGHT BLUE'], '1;35':
108 [13,'MEDIUM VIOLET RED'],
107 [13,'MEDIUM VIOLET RED'],
109 '1;36': [14,'LIGHT STEEL BLUE'],'1;37': [15,'YELLOW']}
108 '1;36': [14,'LIGHT STEEL BLUE'],'1;37': [15,'YELLOW']}
110
109
111 def __init__(self,parent,prompt,intro="",background_color="BLACK",
110 def __init__(self,parent,prompt,intro="",background_color="BLACK",
112 pos=wx.DefaultPosition, ID = -1, size=wx.DefaultSize,
111 pos=wx.DefaultPosition, ID = -1, size=wx.DefaultSize,
113 style=0):
112 style=0):
114 '''
113 '''
115 Initialize console view.
114 Initialize console view.
116
115
117 @param parent: Parent widget
116 @param parent: Parent widget
118 @param prompt: User specified prompt
117 @param prompt: User specified prompt
119 @type intro: string
118 @type intro: string
120 @param intro: User specified startup introduction string
119 @param intro: User specified startup introduction string
121 @type intro: string
120 @type intro: string
122 @param background_color: Can be BLACK or WHITE
121 @param background_color: Can be BLACK or WHITE
123 @type background_color: string
122 @type background_color: string
124 @param other: init param of styledTextControl (can be used as-is)
123 @param other: init param of styledTextControl (can be used as-is)
125 '''
124 '''
126 stc.StyledTextCtrl.__init__(self, parent, ID, pos, size, style)
125 stc.StyledTextCtrl.__init__(self, parent, ID, pos, size, style)
127
126
128 ####### Scintilla configuration ###################################
127 ####### Scintilla configuration ###################################
129
128
130 # Ctrl + B or Ctrl + N can be used to zoomin/zoomout the text inside
129 # Ctrl + B or Ctrl + N can be used to zoomin/zoomout the text inside
131 # the widget
130 # the widget
132 self.CmdKeyAssign(ord('B'), stc.STC_SCMOD_CTRL, stc.STC_CMD_ZOOMIN)
131 self.CmdKeyAssign(ord('B'), stc.STC_SCMOD_CTRL, stc.STC_CMD_ZOOMIN)
133 self.CmdKeyAssign(ord('N'), stc.STC_SCMOD_CTRL, stc.STC_CMD_ZOOMOUT)
132 self.CmdKeyAssign(ord('N'), stc.STC_SCMOD_CTRL, stc.STC_CMD_ZOOMOUT)
134
133
135 #we define platform specific fonts
134 #we define platform specific fonts
136 if wx.Platform == '__WXMSW__':
135 if wx.Platform == '__WXMSW__':
137 faces = { 'times': 'Times New Roman',
136 faces = { 'times': 'Times New Roman',
138 'mono' : 'Courier New',
137 'mono' : 'Courier New',
139 'helv' : 'Arial',
138 'helv' : 'Arial',
140 'other': 'Comic Sans MS',
139 'other': 'Comic Sans MS',
141 'size' : 10,
140 'size' : 10,
142 'size2': 8,
141 'size2': 8,
143 }
142 }
144 elif wx.Platform == '__WXMAC__':
143 elif wx.Platform == '__WXMAC__':
145 faces = { 'times': 'Times New Roman',
144 faces = { 'times': 'Times New Roman',
146 'mono' : 'Monaco',
145 'mono' : 'Monaco',
147 'helv' : 'Arial',
146 'helv' : 'Arial',
148 'other': 'Comic Sans MS',
147 'other': 'Comic Sans MS',
149 'size' : 10,
148 'size' : 10,
150 'size2': 8,
149 'size2': 8,
151 }
150 }
152 else:
151 else:
153 faces = { 'times': 'Times',
152 faces = { 'times': 'Times',
154 'mono' : 'Courier',
153 'mono' : 'Courier',
155 'helv' : 'Helvetica',
154 'helv' : 'Helvetica',
156 'other': 'new century schoolbook',
155 'other': 'new century schoolbook',
157 'size' : 10,
156 'size' : 10,
158 'size2': 8,
157 'size2': 8,
159 }
158 }
160
159
161 #We draw a line at position 80
160 #We draw a line at position 80
162 self.SetEdgeMode(stc.STC_EDGE_LINE)
161 self.SetEdgeMode(stc.STC_EDGE_LINE)
163 self.SetEdgeColumn(80)
162 self.SetEdgeColumn(80)
164 self.SetEdgeColour(wx.LIGHT_GREY)
163 self.SetEdgeColour(wx.LIGHT_GREY)
165
164
166 #self.SetViewWhiteSpace(True)
165 #self.SetViewWhiteSpace(True)
167 #self.SetViewEOL(True)
166 #self.SetViewEOL(True)
168 self.SetEOLMode(stc.STC_EOL_CRLF)
167 self.SetEOLMode(stc.STC_EOL_CRLF)
169 #self.SetWrapMode(stc.STC_WRAP_CHAR)
168 #self.SetWrapMode(stc.STC_WRAP_CHAR)
170 #self.SetWrapMode(stc.STC_WRAP_WORD)
169 #self.SetWrapMode(stc.STC_WRAP_WORD)
171 self.SetBufferedDraw(True)
170 self.SetBufferedDraw(True)
172 #self.SetUseAntiAliasing(True)
171 #self.SetUseAntiAliasing(True)
173 self.SetLayoutCache(stc.STC_CACHE_PAGE)
172 self.SetLayoutCache(stc.STC_CACHE_PAGE)
174
173
175 self.EnsureCaretVisible()
174 self.EnsureCaretVisible()
176
175
177 self.SetMargins(3,3) #text is moved away from border with 3px
176 self.SetMargins(3,3) #text is moved away from border with 3px
178 # Suppressing Scintilla margins
177 # Suppressing Scintilla margins
179 self.SetMarginWidth(0,0)
178 self.SetMarginWidth(0,0)
180 self.SetMarginWidth(1,0)
179 self.SetMarginWidth(1,0)
181 self.SetMarginWidth(2,0)
180 self.SetMarginWidth(2,0)
182
181
183 # make some styles
182 # make some styles
184 if background_color != "BLACK":
183 if background_color != "BLACK":
185 self.background_color = "WHITE"
184 self.background_color = "WHITE"
186 self.SetCaretForeground("BLACK")
185 self.SetCaretForeground("BLACK")
187 self.ANSI_STYLES = self.ANSI_STYLES_WHITE
186 self.ANSI_STYLES = self.ANSI_STYLES_WHITE
188 else:
187 else:
189 self.background_color = background_color
188 self.background_color = background_color
190 self.SetCaretForeground("WHITE")
189 self.SetCaretForeground("WHITE")
191 self.ANSI_STYLES = self.ANSI_STYLES_BLACK
190 self.ANSI_STYLES = self.ANSI_STYLES_BLACK
192
191
193 self.StyleSetSpec(stc.STC_STYLE_DEFAULT,
192 self.StyleSetSpec(stc.STC_STYLE_DEFAULT,
194 "fore:%s,back:%s,size:%d,face:%s"
193 "fore:%s,back:%s,size:%d,face:%s"
195 % (self.ANSI_STYLES['0;30'][1],
194 % (self.ANSI_STYLES['0;30'][1],
196 self.background_color,
195 self.background_color,
197 faces['size'], faces['mono']))
196 faces['size'], faces['mono']))
198 self.StyleClearAll()
197 self.StyleClearAll()
199 self.StyleSetSpec(stc.STC_STYLE_BRACELIGHT,
198 self.StyleSetSpec(stc.STC_STYLE_BRACELIGHT,
200 "fore:#FF0000,back:#0000FF,bold")
199 "fore:#FF0000,back:#0000FF,bold")
201 self.StyleSetSpec(stc.STC_STYLE_BRACEBAD,
200 self.StyleSetSpec(stc.STC_STYLE_BRACEBAD,
202 "fore:#000000,back:#FF0000,bold")
201 "fore:#000000,back:#FF0000,bold")
203
202
204 for style in self.ANSI_STYLES.values():
203 for style in self.ANSI_STYLES.values():
205 self.StyleSetSpec(style[0], "bold,fore:%s" % style[1])
204 self.StyleSetSpec(style[0], "bold,fore:%s" % style[1])
206
205
207 #######################################################################
206 #######################################################################
208
207
209 self.indent = 0
208 self.indent = 0
210 self.prompt_count = 0
209 self.prompt_count = 0
211 self.color_pat = re.compile('\x01?\x1b\[(.*?)m\x02?')
210 self.color_pat = re.compile('\x01?\x1b\[(.*?)m\x02?')
212
211
213 self.write(intro)
212 self.write(intro)
214 self.setPrompt(prompt)
213 self.setPrompt(prompt)
215 self.showPrompt()
214 self.showPrompt()
216
215
217 self.Bind(wx.EVT_KEY_DOWN, self._onKeypress, self)
216 self.Bind(wx.EVT_KEY_DOWN, self._onKeypress, self)
218
217
218 def asyncWrite(self, text):
219 '''
220 Write given text to buffer in an asynchroneous way.
221 It is used from another thread to be able to acces the GUI.
222 @param text: Text to append
223 @type text: string
224 '''
225 try:
226 #print >>sys.__stdout__,'entering'
227 wx.MutexGuiEnter()
228 #print >>sys.__stdout__,'locking the GUI'
229
230 #be sure not to be interrutpted before the MutexGuiLeave!
231 self.write(text)
232 #print >>sys.__stdout__,'done'
233
234 except KeyboardInterrupt:
235 #print >>sys.__stdout__,'got keyboard interrupt'
236 wx.MutexGuiLeave()
237 #print >>sys.__stdout__,'interrupt unlock the GUI'
238 raise KeyboardInterrupt
239 wx.MutexGuiLeave()
240 #print >>sys.__stdout__,'normal unlock the GUI'
241
242
219 def write(self, text):
243 def write(self, text):
220 '''
244 '''
221 Write given text to buffer.
245 Write given text to buffer.
222
246
223 @param text: Text to append.
247 @param text: Text to append.
224 @type text: string
248 @type text: string
225 '''
249 '''
226 segments = self.color_pat.split(text)
250 segments = self.color_pat.split(text)
227 segment = segments.pop(0)
251 segment = segments.pop(0)
228 self.StartStyling(self.getCurrentLineEnd(),0xFF)
252 self.StartStyling(self.getCurrentLineEnd(),0xFF)
229 self.AppendText(segment)
253 self.AppendText(segment)
230
254
231 if segments:
255 if segments:
232 ansi_tags = self.color_pat.findall(text)
256 ansi_tags = self.color_pat.findall(text)
233
257
234 for tag in ansi_tags:
258 for tag in ansi_tags:
235 i = segments.index(tag)
259 i = segments.index(tag)
236 self.StartStyling(self.getCurrentLineEnd(),0xFF)
260 self.StartStyling(self.getCurrentLineEnd(),0xFF)
237 self.AppendText(segments[i+1])
261 self.AppendText(segments[i+1])
238
262
239 if tag != '0':
263 if tag != '0':
240 self.SetStyling(len(segments[i+1]),self.ANSI_STYLES[tag][0])
264 self.SetStyling(len(segments[i+1]),self.ANSI_STYLES[tag][0])
241
265
242 segments.pop(i)
266 segments.pop(i)
243
267
244 self.moveCursor(self.getCurrentLineEnd())
268 self.moveCursor(self.getCurrentLineEnd())
245
269
246 def getPromptLen(self):
270 def getPromptLen(self):
247 '''
271 '''
248 Return the length of current prompt
272 Return the length of current prompt
249 '''
273 '''
250 return len(str(self.prompt_count)) + 7
274 return len(str(self.prompt_count)) + 7
251
275
252 def setPrompt(self,prompt):
276 def setPrompt(self,prompt):
253 self.prompt = prompt
277 self.prompt = prompt
254
278
255 def setIndentation(self,indentation):
279 def setIndentation(self,indentation):
256 self.indent = indentation
280 self.indent = indentation
257
281
258 def setPromptCount(self,count):
282 def setPromptCount(self,count):
259 self.prompt_count = count
283 self.prompt_count = count
260
284
261 def showPrompt(self):
285 def showPrompt(self):
262 '''
286 '''
263 Prints prompt at start of line.
287 Prints prompt at start of line.
264
288
265 @param prompt: Prompt to print.
289 @param prompt: Prompt to print.
266 @type prompt: string
290 @type prompt: string
267 '''
291 '''
268 self.write(self.prompt)
292 self.write(self.prompt)
269 #now we update the position of end of prompt
293 #now we update the position of end of prompt
270 self.current_start = self.getCurrentLineEnd()
294 self.current_start = self.getCurrentLineEnd()
271
295
272 autoindent = self.indent*' '
296 autoindent = self.indent*' '
273 autoindent = autoindent.replace(' ','\t')
297 autoindent = autoindent.replace(' ','\t')
274 self.write(autoindent)
298 self.write(autoindent)
275
299
276 def changeLine(self, text):
300 def changeLine(self, text):
277 '''
301 '''
278 Replace currently entered command line with given text.
302 Replace currently entered command line with given text.
279
303
280 @param text: Text to use as replacement.
304 @param text: Text to use as replacement.
281 @type text: string
305 @type text: string
282 '''
306 '''
283 self.SetSelection(self.getCurrentPromptStart(),self.getCurrentLineEnd())
307 self.SetSelection(self.getCurrentPromptStart(),self.getCurrentLineEnd())
284 self.ReplaceSelection(text)
308 self.ReplaceSelection(text)
285 self.moveCursor(self.getCurrentLineEnd())
309 self.moveCursor(self.getCurrentLineEnd())
286
310
287 def getCurrentPromptStart(self):
311 def getCurrentPromptStart(self):
288 return self.current_start
312 return self.current_start
289
313
290 def getCurrentLineStart(self):
314 def getCurrentLineStart(self):
291 return self.GotoLine(self.LineFromPosition(self.GetCurrentPos()))
315 return self.GotoLine(self.LineFromPosition(self.GetCurrentPos()))
292
316
293 def getCurrentLineEnd(self):
317 def getCurrentLineEnd(self):
294 return self.GetLength()
318 return self.GetLength()
295
319
296 def getCurrentLine(self):
320 def getCurrentLine(self):
297 '''
321 '''
298 Get text in current command line.
322 Get text in current command line.
299
323
300 @return: Text of current command line.
324 @return: Text of current command line.
301 @rtype: string
325 @rtype: string
302 '''
326 '''
303 return self.GetTextRange(self.getCurrentPromptStart(),
327 return self.GetTextRange(self.getCurrentPromptStart(),
304 self.getCurrentLineEnd())
328 self.getCurrentLineEnd())
305
329
306 def moveCursorOnNewValidKey(self):
330 def moveCursorOnNewValidKey(self):
307 #If cursor is at wrong position put it at last line...
331 #If cursor is at wrong position put it at last line...
308 if self.GetCurrentPos() < self.getCurrentPromptStart():
332 if self.GetCurrentPos() < self.getCurrentPromptStart():
309 self.GotoPos(self.getCurrentPromptStart())
333 self.GotoPos(self.getCurrentPromptStart())
310
334
311 def removeFromTo(self,from_pos,to_pos):
335 def removeFromTo(self,from_pos,to_pos):
312 if from_pos < to_pos:
336 if from_pos < to_pos:
313 self.SetSelection(from_pos,to_pos)
337 self.SetSelection(from_pos,to_pos)
314 self.DeleteBack()
338 self.DeleteBack()
315
339
316 def removeCurrentLine(self):
340 def removeCurrentLine(self):
317 self.LineDelete()
341 self.LineDelete()
318
342
319 def moveCursor(self,position):
343 def moveCursor(self,position):
320 self.GotoPos(position)
344 self.GotoPos(position)
321
345
322 def getCursorPos(self):
346 def getCursorPos(self):
323 return self.GetCurrentPos()
347 return self.GetCurrentPos()
324
348
325 def selectFromTo(self,from_pos,to_pos):
349 def selectFromTo(self,from_pos,to_pos):
326 self.SetSelectionStart(from_pos)
350 self.SetSelectionStart(from_pos)
327 self.SetSelectionEnd(to_pos)
351 self.SetSelectionEnd(to_pos)
328
352
329 def writeHistory(self,history):
353 def writeHistory(self,history):
330 self.removeFromTo(self.getCurrentPromptStart(),self.getCurrentLineEnd())
354 self.removeFromTo(self.getCurrentPromptStart(),self.getCurrentLineEnd())
331 self.changeLine(history)
355 self.changeLine(history)
332
356
333 def writeCompletion(self, possibilities):
357 def writeCompletion(self, possibilities):
334 max_len = len(max(possibilities,key=len))
358 max_len = len(max(possibilities,key=len))
335 max_symbol =' '*max_len
359 max_symbol =' '*max_len
336
360
337 #now we check how much symbol we can put on a line...
361 #now we check how much symbol we can put on a line...
338 cursor_pos = self.getCursorPos()
362 cursor_pos = self.getCursorPos()
339 test_buffer = max_symbol + ' '*4
363 test_buffer = max_symbol + ' '*4
340 current_lines = self.GetLineCount()
364 current_lines = self.GetLineCount()
341
365
342 allowed_symbols = 80/len(test_buffer)
366 allowed_symbols = 80/len(test_buffer)
343 if allowed_symbols == 0:
367 if allowed_symbols == 0:
344 allowed_symbols = 1
368 allowed_symbols = 1
345
369
346 pos = 1
370 pos = 1
347 buf = ''
371 buf = ''
348 for symbol in possibilities:
372 for symbol in possibilities:
349 #buf += symbol+'\n'#*spaces)
373 #buf += symbol+'\n'#*spaces)
350 if pos<allowed_symbols:
374 if pos<allowed_symbols:
351 spaces = max_len - len(symbol) + 4
375 spaces = max_len - len(symbol) + 4
352 buf += symbol+' '*spaces
376 buf += symbol+' '*spaces
353 pos += 1
377 pos += 1
354 else:
378 else:
355 buf+=symbol+'\n'
379 buf+=symbol+'\n'
356 pos = 1
380 pos = 1
357 self.write(buf)
381 self.write(buf)
358
382
359 def _onKeypress(self, event, skip=True):
383 def _onKeypress(self, event, skip=True):
360 '''
384 '''
361 Key press callback used for correcting behavior for console-like
385 Key press callback used for correcting behavior for console-like
362 interfaces. For example 'home' should go to prompt, not to begining of
386 interfaces. For example 'home' should go to prompt, not to begining of
363 line.
387 line.
364
388
365 @param widget: Widget that key press accored in.
389 @param widget: Widget that key press accored in.
366 @type widget: gtk.Widget
390 @type widget: gtk.Widget
367 @param event: Event object
391 @param event: Event object
368 @type event: gtk.gdk.Event
392 @type event: gtk.gdk.Event
369
393
370 @return: Return True if event as been catched.
394 @return: Return True if event as been catched.
371 @rtype: boolean
395 @rtype: boolean
372 '''
396 '''
373
397
374 if event.GetKeyCode() == wx.WXK_HOME:
398 if event.GetKeyCode() == wx.WXK_HOME:
375 if event.Modifiers == wx.MOD_NONE:
399 if event.Modifiers == wx.MOD_NONE:
376 self.moveCursorOnNewValidKey()
400 self.moveCursorOnNewValidKey()
377 self.moveCursor(self.getCurrentPromptStart())
401 self.moveCursor(self.getCurrentPromptStart())
378 return True
402 return True
379 elif event.Modifiers == wx.MOD_SHIFT:
403 elif event.Modifiers == wx.MOD_SHIFT:
380 self.moveCursorOnNewValidKey()
404 self.moveCursorOnNewValidKey()
381 self.selectFromTo(self.getCurrentPromptStart(),self.getCursorPos())
405 self.selectFromTo(self.getCurrentPromptStart(),self.getCursorPos())
382 return True
406 return True
383 else:
407 else:
384 return False
408 return False
385
409
386 elif event.GetKeyCode() == wx.WXK_LEFT:
410 elif event.GetKeyCode() == wx.WXK_LEFT:
387 if event.Modifiers == wx.MOD_NONE:
411 if event.Modifiers == wx.MOD_NONE:
388 self.moveCursorOnNewValidKey()
412 self.moveCursorOnNewValidKey()
389
413
390 self.moveCursor(self.getCursorPos()-1)
414 self.moveCursor(self.getCursorPos()-1)
391 if self.getCursorPos() < self.getCurrentPromptStart():
415 if self.getCursorPos() < self.getCurrentPromptStart():
392 self.moveCursor(self.getCurrentPromptStart())
416 self.moveCursor(self.getCurrentPromptStart())
393 return True
417 return True
394
418
395 elif event.GetKeyCode() == wx.WXK_BACK:
419 elif event.GetKeyCode() == wx.WXK_BACK:
396 self.moveCursorOnNewValidKey()
420 self.moveCursorOnNewValidKey()
397 if self.getCursorPos() > self.getCurrentPromptStart():
421 if self.getCursorPos() > self.getCurrentPromptStart():
398 event.Skip()
422 event.Skip()
399 return True
423 return True
400
424
401 if skip:
425 if skip:
402 if event.GetKeyCode() not in [wx.WXK_PAGEUP,wx.WXK_PAGEDOWN] and event.Modifiers == wx.MOD_NONE:
426 if event.GetKeyCode() not in [wx.WXK_PAGEUP,wx.WXK_PAGEDOWN] and event.Modifiers == wx.MOD_NONE:
403 self.moveCursorOnNewValidKey()
427 self.moveCursorOnNewValidKey()
404
428
405 event.Skip()
429 event.Skip()
406 return True
430 return True
407 return False
431 return False
408
432
409 def OnUpdateUI(self, evt):
433 def OnUpdateUI(self, evt):
410 # check for matching braces
434 # check for matching braces
411 braceAtCaret = -1
435 braceAtCaret = -1
412 braceOpposite = -1
436 braceOpposite = -1
413 charBefore = None
437 charBefore = None
414 caretPos = self.GetCurrentPos()
438 caretPos = self.GetCurrentPos()
415
439
416 if caretPos > 0:
440 if caretPos > 0:
417 charBefore = self.GetCharAt(caretPos - 1)
441 charBefore = self.GetCharAt(caretPos - 1)
418 styleBefore = self.GetStyleAt(caretPos - 1)
442 styleBefore = self.GetStyleAt(caretPos - 1)
419
443
420 # check before
444 # check before
421 if charBefore and chr(charBefore) in "[]{}()" and styleBefore == stc.STC_P_OPERATOR:
445 if charBefore and chr(charBefore) in "[]{}()" and styleBefore == stc.STC_P_OPERATOR:
422 braceAtCaret = caretPos - 1
446 braceAtCaret = caretPos - 1
423
447
424 # check after
448 # check after
425 if braceAtCaret < 0:
449 if braceAtCaret < 0:
426 charAfter = self.GetCharAt(caretPos)
450 charAfter = self.GetCharAt(caretPos)
427 styleAfter = self.GetStyleAt(caretPos)
451 styleAfter = self.GetStyleAt(caretPos)
428
452
429 if charAfter and chr(charAfter) in "[]{}()" and styleAfter == stc.STC_P_OPERATOR:
453 if charAfter and chr(charAfter) in "[]{}()" and styleAfter == stc.STC_P_OPERATOR:
430 braceAtCaret = caretPos
454 braceAtCaret = caretPos
431
455
432 if braceAtCaret >= 0:
456 if braceAtCaret >= 0:
433 braceOpposite = self.BraceMatch(braceAtCaret)
457 braceOpposite = self.BraceMatch(braceAtCaret)
434
458
435 if braceAtCaret != -1 and braceOpposite == -1:
459 if braceAtCaret != -1 and braceOpposite == -1:
436 self.BraceBadLight(braceAtCaret)
460 self.BraceBadLight(braceAtCaret)
437 else:
461 else:
438 self.BraceHighlight(braceAtCaret, braceOpposite)
462 self.BraceHighlight(braceAtCaret, braceOpposite)
439 #pt = self.PointFromPosition(braceOpposite)
463 #pt = self.PointFromPosition(braceOpposite)
440 #self.Refresh(True, wxRect(pt.x, pt.y, 5,5))
464 #self.Refresh(True, wxRect(pt.x, pt.y, 5,5))
441 #print pt
465 #print pt
442 #self.Refresh(False)
466 #self.Refresh(False)
443
467
444 class IPShellWidget(wx.Panel):
468 class IPShellWidget(wx.Panel):
445 '''
469 '''
446 This is wx.Panel that embbed the IPython Thread and the wx.StyledTextControl
470 This is wx.Panel that embbed the IPython Thread and the wx.StyledTextControl
447 If you want to port this to any other GUI toolkit, just replace the
471 If you want to port this to any other GUI toolkit, just replace the
448 WxConsoleView by YOURGUIConsoleView and make YOURGUIIPythonView derivate
472 WxConsoleView by YOURGUIConsoleView and make YOURGUIIPythonView derivate
449 from whatever container you want. I've choosed to derivate from a wx.Panel
473 from whatever container you want. I've choosed to derivate from a wx.Panel
450 because it seems to be more useful
474 because it seems to be more useful
451 Any idea to make it more 'generic' welcomed.
475 Any idea to make it more 'generic' welcomed.
452 '''
476 '''
453
477
454 def __init__(self, parent, intro=None,
478 def __init__(self, parent, intro=None,
455 background_color="BLACK", add_button_handler=None,
479 background_color="BLACK", add_button_handler=None,
456 wx_ip_shell=None,
480 wx_ip_shell=None, user_ns={},user_global_ns=None,
457 ):
481 ):
458 '''
482 '''
459 Initialize.
483 Initialize.
460 Instanciate an IPython thread.
484 Instanciate an IPython thread.
461 Instanciate a WxConsoleView.
485 Instanciate a WxConsoleView.
462 Redirect I/O to console.
486 Redirect I/O to console.
463 '''
487 '''
464 wx.Panel.__init__(self,parent,-1)
488 wx.Panel.__init__(self,parent,-1)
465
489
466 ### IPython non blocking shell instanciation ###
490 ### IPython non blocking shell instanciation ###
467 self.cout = StringIO()
491 self.cout = StringIO()
468 self.add_button_handler = add_button_handler
492 self.add_button_handler = add_button_handler
469
493
470 if wx_ip_shell is not None:
494 if wx_ip_shell is not None:
471 self.IP = wx_ip_shell
495 self.IP = wx_ip_shell
472 else:
496 else:
473 self.IP = WxNonBlockingIPShell(self,
497 self.IP = WxNonBlockingIPShell(self,
474 cout = self.cout, cerr = self.cout,
498 cout = self.cout, cerr = self.cout,
475 ask_exit_handler = self.askExitCallback,
499 ask_exit_handler = self.askExitCallback)
476 rawinput = self.rawInput)
477
500
478 ### IPython wx console view instanciation ###
501 ### IPython wx console view instanciation ###
479 #If user didn't defined an intro text, we create one for him
502 #If user didn't defined an intro text, we create one for him
480 #If you really wnat an empty intrp just call wxIPythonViewPanel
503 #If you really wnat an empty intrp just call wxIPythonViewPanel
481 #with intro=''
504 #with intro=''
482 if intro is None:
505 if intro is None:
483 welcome_text = "Welcome to WxIPython Shell.\n\n"
506 welcome_text = "Welcome to WxIPython Shell.\n\n"
484 welcome_text+= self.IP.getBanner()
507 welcome_text+= self.IP.getBanner()
485 welcome_text+= "!command -> Execute command in shell\n"
508 welcome_text+= "!command -> Execute command in shell\n"
486 welcome_text+= "TAB -> Autocompletion\n"
509 welcome_text+= "TAB -> Autocompletion\n"
487 else:
510 else:
488 welcome_text = intro
511 welcome_text = intro
489
512
490 self.text_ctrl = WxConsoleView(self,
513 self.text_ctrl = WxConsoleView(self,
491 self.IP.getPrompt(),
514 self.IP.getPrompt(),
492 intro=welcome_text,
515 intro=welcome_text,
493 background_color=background_color)
516 background_color=background_color)
494
517
495 self.cout.write = self.text_ctrl.write
518 self.cout.write = self.text_ctrl.asyncWrite
496
519
497 self.text_ctrl.Bind(wx.EVT_KEY_DOWN, self.keyPress, self.text_ctrl)
520 self.text_ctrl.Bind(wx.EVT_KEY_DOWN, self.keyPress, self.text_ctrl)
498
521
499 ### making the layout of the panel ###
522 ### making the layout of the panel ###
500 sizer = wx.BoxSizer(wx.VERTICAL)
523 sizer = wx.BoxSizer(wx.VERTICAL)
501 sizer.Add(self.text_ctrl, 1, wx.EXPAND)
524 sizer.Add(self.text_ctrl, 1, wx.EXPAND)
502 self.SetAutoLayout(True)
525 self.SetAutoLayout(True)
503 sizer.Fit(self)
526 sizer.Fit(self)
504 sizer.SetSizeHints(self)
527 sizer.SetSizeHints(self)
505 self.SetSizer(sizer)
528 self.SetSizer(sizer)
506 #and we focus on the widget :)
529 #and we focus on the widget :)
507 self.SetFocus()
530 self.SetFocus()
508
531
509 #widget state management (for key handling different cases)
532 #widget state management (for key handling different cases)
510 self.setCurrentState('IDLE')
533 self.setCurrentState('IDLE')
511 self.pager_state = 'DONE'
534 self.pager_state = 'DONE'
535 self.raw_input_current_line = 0
512
536
513 def askExitCallback(self, event):
537 def askExitCallback(self, event):
514 self.askExitHandler(event)
538 self.askExitHandler(event)
515
539
516 #---------------------- IPython Thread Management ------------------------
540 #---------------------- IPython Thread Management ------------------------
517 def stateDoExecuteLine(self):
541 def stateDoExecuteLine(self):
518 #print >>sys.__stdout__,"command:",self.getCurrentLine()
519 lines=self.text_ctrl.getCurrentLine()
542 lines=self.text_ctrl.getCurrentLine()
520 self.text_ctrl.write('\n')
543 self.text_ctrl.write('\n')
521 for line in lines.split('\n'):
544 lines_to_execute = lines.replace('\t',' '*4)
522 self.IP.doExecute((line.replace('\t',' '*4)).encode('cp1252'))
545 lines_to_execute = lines_to_execute.replace('\r\n','\n')
523 self.updateHistoryTracker(self.text_ctrl.getCurrentLine())
546 self.IP.doExecute(lines.encode('cp1252'))
547 self.updateHistoryTracker(lines)
524 self.setCurrentState('WAIT_END_OF_EXECUTION')
548 self.setCurrentState('WAIT_END_OF_EXECUTION')
525
549
526 def evtStateExecuteDone(self,evt):
550 def evtStateExecuteDone(self,evt):
527 self.doc = self.IP.getDocText()
551 self.doc = self.IP.getDocText()
528 self.help = self.IP.getHelpText()
552 self.help = self.IP.getHelpText()
529 if self.doc:
553 if self.doc:
530 self.pager_lines = self.doc[7:].split('\n')
554 self.pager_lines = self.doc[7:].split('\n')
531 self.pager_state = 'INIT'
555 self.pager_state = 'INIT'
532 self.setCurrentState('SHOW_DOC')
556 self.setCurrentState('SHOW_DOC')
533 self.pager(self.doc)
557 self.pager(self.doc)
534 elif self.help:
558 elif self.help:
535 self.pager_lines = self.help.split('\n')
559 self.pager_lines = self.help.split('\n')
536 self.pager_state = 'INIT'
560 self.pager_state = 'INIT'
537 self.setCurrentState('SHOW_DOC')
561 self.setCurrentState('SHOW_DOC')
538 self.pager(self.help)
562 self.pager(self.help)
539 else:
563 else:
540 self.stateShowPrompt()
564 self.stateShowPrompt()
541
565
542 def stateShowPrompt(self):
566 def stateShowPrompt(self):
543 self.setCurrentState('SHOW_PROMPT')
567 self.setCurrentState('SHOW_PROMPT')
544 self.text_ctrl.setPrompt(self.IP.getPrompt())
568 self.text_ctrl.setPrompt(self.IP.getPrompt())
545 self.text_ctrl.setIndentation(self.IP.getIndentation())
569 self.text_ctrl.setIndentation(self.IP.getIndentation())
546 self.text_ctrl.setPromptCount(self.IP.getPromptCount())
570 self.text_ctrl.setPromptCount(self.IP.getPromptCount())
547 self.text_ctrl.showPrompt()
571 self.text_ctrl.showPrompt()
548 self.IP.initHistoryIndex()
572 self.IP.initHistoryIndex()
549 self.setCurrentState('IDLE')
573 self.setCurrentState('IDLE')
550
574
551 def setCurrentState(self, state):
575 def setCurrentState(self, state):
552 self.cur_state = state
576 self.cur_state = state
553 self.updateStatusTracker(self.cur_state)
577 self.updateStatusTracker(self.cur_state)
554 #---------------------------- Ipython raw_input -----------------------------------
578
555 def rawInput(self, prompt=''):
556 self.setCurrentState('WAITING_USER_INPUT')
557 while self.cur_state != 'WAIT_END_OF_EXECUTION':
558 pass
559 line = self.text_ctrl.getCurrentLine()
560 line = line.split('\n')
561 return line[-2]
562
563 #---------------------------- IPython pager ---------------------------------------
564 def pager(self,text):
579 def pager(self,text):
565
580
566 if self.pager_state == 'INIT':
581 if self.pager_state == 'INIT':
567 #print >>sys.__stdout__,"PAGER state:",self.pager_state
582 #print >>sys.__stdout__,"PAGER state:",self.pager_state
568 self.pager_nb_lines = len(self.pager_lines)
583 self.pager_nb_lines = len(self.pager_lines)
569 self.pager_index = 0
584 self.pager_index = 0
570 self.pager_do_remove = False
585 self.pager_do_remove = False
571 self.text_ctrl.write('\n')
586 self.text_ctrl.write('\n')
572 self.pager_state = 'PROCESS_LINES'
587 self.pager_state = 'PROCESS_LINES'
573
588
574 if self.pager_state == 'PROCESS_LINES':
589 if self.pager_state == 'PROCESS_LINES':
575 #print >>sys.__stdout__,"PAGER state:",self.pager_state
590 #print >>sys.__stdout__,"PAGER state:",self.pager_state
576 if self.pager_do_remove == True:
591 if self.pager_do_remove == True:
577 self.text_ctrl.removeCurrentLine()
592 self.text_ctrl.removeCurrentLine()
578 self.pager_do_remove = False
593 self.pager_do_remove = False
579
594
580 if self.pager_nb_lines > 10:
595 if self.pager_nb_lines > 10:
581 #print >>sys.__stdout__,"PAGER processing 10 lines"
596 #print >>sys.__stdout__,"PAGER processing 10 lines"
582 if self.pager_index > 0:
597 if self.pager_index > 0:
583 self.text_ctrl.write(">\x01\x1b[1;36m\x02"+self.pager_lines[self.pager_index]+'\n')
598 self.text_ctrl.write(">\x01\x1b[1;36m\x02"+self.pager_lines[self.pager_index]+'\n')
584 else:
599 else:
585 self.text_ctrl.write("\x01\x1b[1;36m\x02 "+self.pager_lines[self.pager_index]+'\n')
600 self.text_ctrl.write("\x01\x1b[1;36m\x02 "+self.pager_lines[self.pager_index]+'\n')
586
601
587 for line in self.pager_lines[self.pager_index+1:self.pager_index+9]:
602 for line in self.pager_lines[self.pager_index+1:self.pager_index+9]:
588 self.text_ctrl.write("\x01\x1b[1;36m\x02 "+line+'\n')
603 self.text_ctrl.write("\x01\x1b[1;36m\x02 "+line+'\n')
589 self.pager_index += 10
604 self.pager_index += 10
590 self.pager_nb_lines -= 10
605 self.pager_nb_lines -= 10
591 self.text_ctrl.write("--- Push Enter to continue or 'Q' to quit---")
606 self.text_ctrl.write("--- Push Enter to continue or 'Q' to quit---")
592 self.pager_do_remove = True
607 self.pager_do_remove = True
593 self.pager_state = 'WAITING'
608 self.pager_state = 'WAITING'
594 return
609 return
595 else:
610 else:
596 #print >>sys.__stdout__,"PAGER processing last lines"
611 #print >>sys.__stdout__,"PAGER processing last lines"
597 if self.pager_nb_lines > 0:
612 if self.pager_nb_lines > 0:
598 if self.pager_index > 0:
613 if self.pager_index > 0:
599 self.text_ctrl.write(">\x01\x1b[1;36m\x02"+self.pager_lines[self.pager_index]+'\n')
614 self.text_ctrl.write(">\x01\x1b[1;36m\x02"+self.pager_lines[self.pager_index]+'\n')
600 else:
615 else:
601 self.text_ctrl.write("\x01\x1b[1;36m\x02 "+self.pager_lines[self.pager_index]+'\n')
616 self.text_ctrl.write("\x01\x1b[1;36m\x02 "+self.pager_lines[self.pager_index]+'\n')
602
617
603 self.pager_index += 1
618 self.pager_index += 1
604 self.pager_nb_lines -= 1
619 self.pager_nb_lines -= 1
605 if self.pager_nb_lines > 0:
620 if self.pager_nb_lines > 0:
606 for line in self.pager_lines[self.pager_index:]:
621 for line in self.pager_lines[self.pager_index:]:
607 self.text_ctrl.write("\x01\x1b[1;36m\x02 "+line+'\n')
622 self.text_ctrl.write("\x01\x1b[1;36m\x02 "+line+'\n')
608 self.pager_nb_lines = 0
623 self.pager_nb_lines = 0
609 self.pager_state = 'DONE'
624 self.pager_state = 'DONE'
610 self.stateShowPrompt()
625 self.stateShowPrompt()
611
626
612 #------------------------ Key Handler ------------------------------------
627 #------------------------ Key Handler ------------------------------------
613 def keyPress(self, event):
628 def keyPress(self, event):
614 '''
629 '''
615 Key press callback with plenty of shell goodness, like history,
630 Key press callback with plenty of shell goodness, like history,
616 autocompletions, etc.
631 autocompletions, etc.
617 '''
632 '''
618
633
619 if event.GetKeyCode() == ord('C'):
634 if event.GetKeyCode() == ord('C'):
620 if event.Modifiers == wx.MOD_CONTROL:
635 if event.Modifiers == wx.MOD_CONTROL:
621 if self.cur_state == 'WAIT_END_OF_EXECUTION':
636 if self.cur_state == 'WAIT_END_OF_EXECUTION':
622 #we raise an exception inside the IPython thread container
637 #we raise an exception inside the IPython thread container
623 self.IP.ce.raise_exc(KeyboardInterrupt)
638 self.IP.ce.raise_exc(KeyboardInterrupt)
624 return
639 return
625
640
626 if event.KeyCode == wx.WXK_RETURN:
641 if event.KeyCode == wx.WXK_RETURN:
627 if self.cur_state == 'IDLE':
642 if self.cur_state == 'IDLE':
628 #we change the state ot the state machine
643 #we change the state ot the state machine
629 self.setCurrentState('DO_EXECUTE_LINE')
644 self.setCurrentState('DO_EXECUTE_LINE')
630 self.stateDoExecuteLine()
645 self.stateDoExecuteLine()
631 return
646 return
632 if self.pager_state == 'WAITING':
647 if self.pager_state == 'WAITING':
633 self.pager_state = 'PROCESS_LINES'
648 self.pager_state = 'PROCESS_LINES'
634 self.pager(self.doc)
649 self.pager(self.doc)
635 return
650 return
636
651
637 if self.cur_state == 'WAITING_USER_INPUT':
652 if self.cur_state == 'WAITING_USER_INPUT':
638 line=self.text_ctrl.getCurrentLine()
653 line=self.text_ctrl.getCurrentLine()
639 self.text_ctrl.write('\n')
654 self.text_ctrl.write('\n')
640 self.setCurrentState('WAIT_END_OF_EXECUTION')
655 self.setCurrentState('WAIT_END_OF_EXECUTION')
641 return
656 return
642
657
643 if event.GetKeyCode() in [ord('q'),ord('Q')]:
658 if event.GetKeyCode() in [ord('q'),ord('Q')]:
644 if self.pager_state == 'WAITING':
659 if self.pager_state == 'WAITING':
645 self.pager_state = 'DONE'
660 self.pager_state = 'DONE'
646 self.text_ctrl.write('\n')
661 self.text_ctrl.write('\n')
647 self.stateShowPrompt()
662 self.stateShowPrompt()
648 return
663 return
649
664
650 if self.cur_state == 'WAITING_USER_INPUT':
665 if self.cur_state == 'WAITING_USER_INPUT':
651 event.Skip()
666 event.Skip()
652
667
653 if self.cur_state == 'IDLE':
668 if self.cur_state == 'IDLE':
654 if event.KeyCode == wx.WXK_UP:
669 if event.KeyCode == wx.WXK_UP:
655 history = self.IP.historyBack()
670 history = self.IP.historyBack()
656 self.text_ctrl.writeHistory(history)
671 self.text_ctrl.writeHistory(history)
657 return
672 return
658 if event.KeyCode == wx.WXK_DOWN:
673 if event.KeyCode == wx.WXK_DOWN:
659 history = self.IP.historyForward()
674 history = self.IP.historyForward()
660 self.text_ctrl.writeHistory(history)
675 self.text_ctrl.writeHistory(history)
661 return
676 return
662 if event.KeyCode == wx.WXK_TAB:
677 if event.KeyCode == wx.WXK_TAB:
663 #if line empty we disable tab completion
678 #if line empty we disable tab completion
664 if not self.text_ctrl.getCurrentLine().strip():
679 if not self.text_ctrl.getCurrentLine().strip():
665 self.text_ctrl.write('\t')
680 self.text_ctrl.write('\t')
666 return
681 return
667 completed, possibilities = self.IP.complete(self.text_ctrl.getCurrentLine())
682 completed, possibilities = self.IP.complete(self.text_ctrl.getCurrentLine())
668 if len(possibilities) > 1:
683 if len(possibilities) > 1:
669 cur_slice = self.text_ctrl.getCurrentLine()
684 cur_slice = self.text_ctrl.getCurrentLine()
670 self.text_ctrl.write('\n')
685 self.text_ctrl.write('\n')
671 self.text_ctrl.writeCompletion(possibilities)
686 self.text_ctrl.writeCompletion(possibilities)
672 self.text_ctrl.write('\n')
687 self.text_ctrl.write('\n')
673
688
674 self.text_ctrl.showPrompt()
689 self.text_ctrl.showPrompt()
675 self.text_ctrl.write(cur_slice)
690 self.text_ctrl.write(cur_slice)
676 self.text_ctrl.changeLine(completed or cur_slice)
691 self.text_ctrl.changeLine(completed or cur_slice)
677
692
678 return
693 return
679 event.Skip()
694 event.Skip()
680
695
681 #------------------------ Hook Section -----------------------------------
696 #------------------------ Hook Section -----------------------------------
682 def updateHistoryTracker(self,command_line):
697 def updateHistoryTracker(self,command_line):
683 '''
698 '''
684 Default history tracker (does nothing)
699 Default history tracker (does nothing)
685 '''
700 '''
686 pass
701 pass
687
702
688 def setHistoryTrackerHook(self,func):
703 def setHistoryTrackerHook(self,func):
689 '''
704 '''
690 Define a new history tracker
705 Define a new history tracker
691 '''
706 '''
692 self.updateHistoryTracker = func
707 self.updateHistoryTracker = func
693
708
694 def updateStatusTracker(self,status):
709 def updateStatusTracker(self,status):
695 '''
710 '''
696 Default status tracker (does nothing)
711 Default status tracker (does nothing)
697 '''
712 '''
698 pass
713 pass
699
714
700 def setStatusTrackerHook(self,func):
715 def setStatusTrackerHook(self,func):
701 '''
716 '''
702 Define a new status tracker
717 Define a new status tracker
703 '''
718 '''
704 self.updateStatusTracker = func
719 self.updateStatusTracker = func
705
720
706 def askExitHandler(self, event):
721 def askExitHandler(self, event):
707 '''
722 '''
708 Default exit handler
723 Default exit handler
709 '''
724 '''
710 self.text_ctrl.write('\nExit callback has not been set.')
725 self.text_ctrl.write('\nExit callback has not been set.')
711
726
712 def setAskExitHandler(self, func):
727 def setAskExitHandler(self, func):
713 '''
728 '''
714 Define an exit handler
729 Define an exit handler
715 '''
730 '''
716 self.askExitHandler = func
731 self.askExitHandler = func
717
732
718 if __name__ == '__main__':
733 if __name__ == '__main__':
719 # Some simple code to test the shell widget.
734 # Some simple code to test the shell widget.
720 class MainWindow(wx.Frame):
735 class MainWindow(wx.Frame):
721 def __init__(self, parent, id, title):
736 def __init__(self, parent, id, title):
722 wx.Frame.__init__(self, parent, id, title, size=(300,250))
737 wx.Frame.__init__(self, parent, id, title, size=(300,250))
723 self._sizer = wx.BoxSizer(wx.VERTICAL)
738 self._sizer = wx.BoxSizer(wx.VERTICAL)
724 self.shell = IPShellWidget(self)
739 self.shell = IPShellWidget(self)
725 self._sizer.Add(self.shell, 1, wx.EXPAND)
740 self._sizer.Add(self.shell, 1, wx.EXPAND)
726 self.SetSizer(self._sizer)
741 self.SetSizer(self._sizer)
727 self.SetAutoLayout(1)
742 self.SetAutoLayout(1)
728 self.Show(True)
743 self.Show(True)
729
744
730 app = wx.PySimpleApp()
745 app = wx.PySimpleApp()
731 frame = MainWindow(None, wx.ID_ANY, 'Ipython')
746 frame = MainWindow(None, wx.ID_ANY, 'Ipython')
732 frame.SetSize((780, 460))
747 frame.SetSize((780, 460))
733 shell = frame.shell
748 shell = frame.shell
734
749
735 app.MainLoop()
750 app.MainLoop()
736
751
737
752
@@ -1,7571 +1,7578 b''
1 2008-04-15 Ville Vainio <vivainio@gmail.com>
2
3 * genutils.py: SList.grep supports 'field' argument
4
5 * ipy_completers.py: module completer looks inside
6 .egg zip files (patch by mc). Close #196.
7
1 2008-04-09 Ville Vainio <vivainio@gmail.com>
8 2008-04-09 Ville Vainio <vivainio@gmail.com>
2
9
3 * deep_reload.py: do not crash on from __future__ import
10 * deep_reload.py: do not crash on from __future__ import
4 absolute_import. Close #244.
11 absolute_import. Close #244.
5
12
6 2008-04-02 Ville Vainio <vivainio@gmail.com>
13 2008-04-02 Ville Vainio <vivainio@gmail.com>
7
14
8 * ipy_winpdb.py: New extension for winpdb integration. %wdb
15 * ipy_winpdb.py: New extension for winpdb integration. %wdb
9 test.py is winpdb equivalent of %run -d test.py. winpdb is a
16 test.py is winpdb equivalent of %run -d test.py. winpdb is a
10 crossplatform remote GUI debugger based on wxpython.
17 crossplatform remote GUI debugger based on wxpython.
11
18
12 2008-03-29 Ville Vainio <vivainio@gmail.com>
19 2008-03-29 Ville Vainio <vivainio@gmail.com>
13
20
14 * ipython.rst, do_sphinx.py: New documentation base, based on
21 * ipython.rst, do_sphinx.py: New documentation base, based on
15 reStucturedText and Sphinx (html/pdf generation). The old Lyx
22 reStucturedText and Sphinx (html/pdf generation). The old Lyx
16 based documentation will not be updated anymore.
23 based documentation will not be updated anymore.
17
24
18 * jobctrl.py: Use shell in Popen for 'start' command (in windows).
25 * jobctrl.py: Use shell in Popen for 'start' command (in windows).
19
26
20 2008-03-24 Ville Vainio <vivainio@gmail.com>
27 2008-03-24 Ville Vainio <vivainio@gmail.com>
21
28
22 * ipython.rst, do_sphinx.py: New documentation base, based on
29 * ipython.rst, do_sphinx.py: New documentation base, based on
23 reStucturedText and Sphinx (html/pdf generation). The old Lyx
30 reStucturedText and Sphinx (html/pdf generation). The old Lyx
24 based documentation will not be updated anymore.
31 based documentation will not be updated anymore.
25
32
26 ipython.rst has up to date documentation on matters that were not
33 ipython.rst has up to date documentation on matters that were not
27 documented at all, and it also removes various
34 documented at all, and it also removes various
28 misdocumented/deprecated features.
35 misdocumented/deprecated features.
29
36
30 2008-03-22 Ville Vainio <vivainio@gmail.com>
37 2008-03-22 Ville Vainio <vivainio@gmail.com>
31
38
32 * Shell.py: Merge mtexp branch:
39 * Shell.py: Merge mtexp branch:
33 https://code.launchpad.net/~ipython/ipython/mtexp
40 https://code.launchpad.net/~ipython/ipython/mtexp
34
41
35 Privides simpler and more robust MTInteractiveShell that won't
42 Privides simpler and more robust MTInteractiveShell that won't
36 deadlock, even when the worker thread (GUI) stops doing runcode()
43 deadlock, even when the worker thread (GUI) stops doing runcode()
37 regularly. r71.
44 regularly. r71.
38
45
39 2008-03-20 Ville Vainio <vivainio@gmail.com>
46 2008-03-20 Ville Vainio <vivainio@gmail.com>
40
47
41 * twshell.py: New shell that runs IPython code in Twisted reactor.
48 * twshell.py: New shell that runs IPython code in Twisted reactor.
42 Launch by doing ipython -twisted. r67.
49 Launch by doing ipython -twisted. r67.
43
50
44 2008-03-19 Ville Vainio <vivainio@gmail.com>
51 2008-03-19 Ville Vainio <vivainio@gmail.com>
45
52
46 * Magic.py: %rehashx works correctly when shadowed system commands
53 * Magic.py: %rehashx works correctly when shadowed system commands
47 have upper case characters (e.g. Print.exe). r64.
54 have upper case characters (e.g. Print.exe). r64.
48
55
49 * ipy_bzr.py, ipy_app_completers.py: new bzr completer that also
56 * ipy_bzr.py, ipy_app_completers.py: new bzr completer that also
50 knows options to commands, based on bzrtools. Uses bzrlib
57 knows options to commands, based on bzrtools. Uses bzrlib
51 directly. r66.
58 directly. r66.
52
59
53 2008-03-16 Ville Vainio <vivainio@gmail.com>
60 2008-03-16 Ville Vainio <vivainio@gmail.com>
54
61
55 * make_tarball.py: Fixed for bzr.
62 * make_tarball.py: Fixed for bzr.
56
63
57 * ipapi.py: Better _ip.runlines() script cleanup. r56,r79.
64 * ipapi.py: Better _ip.runlines() script cleanup. r56,r79.
58
65
59 * ipy_vimserver.py, ipy.vim: New extension for vim server mode,
66 * ipy_vimserver.py, ipy.vim: New extension for vim server mode,
60 by Erich Heine.
67 by Erich Heine.
61
68
62 2008-03-12 Ville Vainio <vivainio@gmail.com>
69 2008-03-12 Ville Vainio <vivainio@gmail.com>
63
70
64 * ipmaker.py: Force (reload?) import of ipy_user_conf and
71 * ipmaker.py: Force (reload?) import of ipy_user_conf and
65 ipy_profile_foo, so that embedded instances can be relaunched and
72 ipy_profile_foo, so that embedded instances can be relaunched and
66 configuration is still done. r50
73 configuration is still done. r50
67
74
68 * ipapi.py, test_embed.py: Allow specifying shell class in
75 * ipapi.py, test_embed.py: Allow specifying shell class in
69 launch_new_instance & make_new instance. Use this in
76 launch_new_instance & make_new instance. Use this in
70 test_embed.py. r51.
77 test_embed.py. r51.
71
78
72 test_embed.py is also a good and simple demo of embedding IPython.
79 test_embed.py is also a good and simple demo of embedding IPython.
73
80
74
81
75 2008-03-10 Ville Vainio <vivainio@gmail.com>
82 2008-03-10 Ville Vainio <vivainio@gmail.com>
76
83
77 * tool/update_revnum.py: Change to bzr revisioning scheme in
84 * tool/update_revnum.py: Change to bzr revisioning scheme in
78 revision numbers.
85 revision numbers.
79
86
80 * Shell.py: Threading improvements:
87 * Shell.py: Threading improvements:
81
88
82 In multithreaded shells, do not hang on macros and o.autoexec
89 In multithreaded shells, do not hang on macros and o.autoexec
83 commands (or anything executed with _ip.runlines()) anymore. Allow
90 commands (or anything executed with _ip.runlines()) anymore. Allow
84 recursive execution of IPython code in
91 recursive execution of IPython code in
85 MTInteractiveShell.runsource by checking if we are already in
92 MTInteractiveShell.runsource by checking if we are already in
86 worker thread, and execute code directly if we are. r48.
93 worker thread, and execute code directly if we are. r48.
87
94
88 MTInteractiveShell.runsource: execute code directly if worker
95 MTInteractiveShell.runsource: execute code directly if worker
89 thread is not running yet (this is the case in config files). r49.
96 thread is not running yet (this is the case in config files). r49.
90
97
91 2008-03-09 Ville Vainio <vivainio@gmail.com>
98 2008-03-09 Ville Vainio <vivainio@gmail.com>
92
99
93 * ipy_profile_sh.py: You can now use $LA or LA() to refer to last
100 * ipy_profile_sh.py: You can now use $LA or LA() to refer to last
94 argument of previous command in sh profile. Similar to bash '!$'.
101 argument of previous command in sh profile. Similar to bash '!$'.
95 LA(3) or $LA(3) stands for last argument of input history command
102 LA(3) or $LA(3) stands for last argument of input history command
96 3.
103 3.
97
104
98 * Shell.py: -pylab names don't clutter %whos listing.
105 * Shell.py: -pylab names don't clutter %whos listing.
99
106
100 2008-03-07 Ville Vainio <vivainio@gmail.com>
107 2008-03-07 Ville Vainio <vivainio@gmail.com>
101
108
102 * ipy_autoreload.py: new extension (by Pauli Virtanen) for
109 * ipy_autoreload.py: new extension (by Pauli Virtanen) for
103 autoreloading modules; try %autoreload and %aimport. Close #154.
110 autoreloading modules; try %autoreload and %aimport. Close #154.
104 Uses the new pre_runcode_hook.
111 Uses the new pre_runcode_hook.
105
112
106 2008-02-24 Ville Vainio <vivainio@gmail.com>
113 2008-02-24 Ville Vainio <vivainio@gmail.com>
107
114
108 * platutils_posix.py: freeze_term_title works
115 * platutils_posix.py: freeze_term_title works
109
116
110 2008-02-21 Ville Vainio <vivainio@gmail.com>
117 2008-02-21 Ville Vainio <vivainio@gmail.com>
111
118
112 * Magic.py: %quickref does not crash with empty docstring
119 * Magic.py: %quickref does not crash with empty docstring
113
120
114 2008-02-20 Ville Vainio <vivainio@gmail.com>
121 2008-02-20 Ville Vainio <vivainio@gmail.com>
115
122
116 * completer.py: do not treat [](){} as protectable chars anymore,
123 * completer.py: do not treat [](){} as protectable chars anymore,
117 close #233.
124 close #233.
118
125
119 * completer.py: do not treat [](){} as protectable chars anymore
126 * completer.py: do not treat [](){} as protectable chars anymore
120
127
121 * magic.py, test_cpaste.py: Allow different prefix for pasting
128 * magic.py, test_cpaste.py: Allow different prefix for pasting
122 from email
129 from email
123
130
124 2008-02-17 Ville Vainio <vivainio@gmail.com>
131 2008-02-17 Ville Vainio <vivainio@gmail.com>
125
132
126 * Switched over to Launchpad/bzr as primary VCS.
133 * Switched over to Launchpad/bzr as primary VCS.
127
134
128 2008-02-14 Ville Vainio <vivainio@gmail.com>
135 2008-02-14 Ville Vainio <vivainio@gmail.com>
129
136
130 * ipapi.py: _ip.runlines() is now much more liberal about
137 * ipapi.py: _ip.runlines() is now much more liberal about
131 indentation - it cleans up the scripts it gets
138 indentation - it cleans up the scripts it gets
132
139
133 2008-02-14 Ville Vainio <vivainio@gmail.com>
140 2008-02-14 Ville Vainio <vivainio@gmail.com>
134
141
135 * Extensions/ipy_leo.py: created 'ILeo' IPython-Leo bridge.
142 * Extensions/ipy_leo.py: created 'ILeo' IPython-Leo bridge.
136 Changes to it (later on) are too numerous to list in ChangeLog
143 Changes to it (later on) are too numerous to list in ChangeLog
137 until it stabilizes
144 until it stabilizes
138
145
139 2008-02-07 Darren Dale <darren.dale@cornell.edu>
146 2008-02-07 Darren Dale <darren.dale@cornell.edu>
140
147
141 * IPython/Shell.py: Call QtCore.pyqtRemoveInputHook() when creating
148 * IPython/Shell.py: Call QtCore.pyqtRemoveInputHook() when creating
142 an IPShellQt4. PyQt4-4.2.1 and later uses PyOS_InputHook to improve
149 an IPShellQt4. PyQt4-4.2.1 and later uses PyOS_InputHook to improve
143 interaction in the interpreter (like Tkinter does), but it seems to
150 interaction in the interpreter (like Tkinter does), but it seems to
144 partially interfere with the IPython implementation and exec_()
151 partially interfere with the IPython implementation and exec_()
145 still seems to block. So we disable the PyQt implementation and
152 still seems to block. So we disable the PyQt implementation and
146 stick with the IPython one for now.
153 stick with the IPython one for now.
147
154
148 2008-02-02 Walter Doerwald <walter@livinglogic.de>
155 2008-02-02 Walter Doerwald <walter@livinglogic.de>
149
156
150 * ipipe.py: A new ipipe table has been added: ialias produces all
157 * ipipe.py: A new ipipe table has been added: ialias produces all
151 entries from IPython's alias table.
158 entries from IPython's alias table.
152
159
153 2008-02-01 Fernando Perez <Fernando.Perez@colorado.edu>
160 2008-02-01 Fernando Perez <Fernando.Perez@colorado.edu>
154
161
155 * IPython/Shell.py (MTInteractiveShell.runcode): Improve handling
162 * IPython/Shell.py (MTInteractiveShell.runcode): Improve handling
156 of KBINT in threaded shells. After code provided by Marc in #212.
163 of KBINT in threaded shells. After code provided by Marc in #212.
157
164
158 2008-01-30 Fernando Perez <Fernando.Perez@colorado.edu>
165 2008-01-30 Fernando Perez <Fernando.Perez@colorado.edu>
159
166
160 * IPython/Shell.py (MTInteractiveShell.__init__): Fixed deadlock
167 * IPython/Shell.py (MTInteractiveShell.__init__): Fixed deadlock
161 that could occur due to a race condition in threaded shells.
168 that could occur due to a race condition in threaded shells.
162 Thanks to code provided by Marc, as #210.
169 Thanks to code provided by Marc, as #210.
163
170
164 2008-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
171 2008-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
165
172
166 * IPython/Magic.py (magic_doctest_mode): respect the user's
173 * IPython/Magic.py (magic_doctest_mode): respect the user's
167 settings for input separators rather than overriding them. After
174 settings for input separators rather than overriding them. After
168 a report by Jeff Kowalczyk <jtk-AT-yahoo.com>
175 a report by Jeff Kowalczyk <jtk-AT-yahoo.com>
169
176
170 * IPython/history.py (magic_history): Add support for declaring an
177 * IPython/history.py (magic_history): Add support for declaring an
171 output file directly from the history command.
178 output file directly from the history command.
172
179
173 2008-01-21 Walter Doerwald <walter@livinglogic.de>
180 2008-01-21 Walter Doerwald <walter@livinglogic.de>
174
181
175 * ipipe.py: Register ipipe's displayhooks via the generic function
182 * ipipe.py: Register ipipe's displayhooks via the generic function
176 generics.result_display() instead of using ipapi.set_hook().
183 generics.result_display() instead of using ipapi.set_hook().
177
184
178 2008-01-19 Walter Doerwald <walter@livinglogic.de>
185 2008-01-19 Walter Doerwald <walter@livinglogic.de>
179
186
180 * ibrowse.py, igrid.py, ipipe.py:
187 * ibrowse.py, igrid.py, ipipe.py:
181 The input object can now be passed to the constructor of the display classes.
188 The input object can now be passed to the constructor of the display classes.
182 This makes it possible to use them with objects that implement __or__.
189 This makes it possible to use them with objects that implement __or__.
183 Use this constructor in the displayhook instead of piping.
190 Use this constructor in the displayhook instead of piping.
184
191
185 * ipipe.py: Importing astyle.py is done as late as possible to
192 * ipipe.py: Importing astyle.py is done as late as possible to
186 avoid problems with circular imports.
193 avoid problems with circular imports.
187
194
188 2008-01-19 Ville Vainio <vivainio@gmail.com>
195 2008-01-19 Ville Vainio <vivainio@gmail.com>
189
196
190 * hooks.py, iplib.py: Added 'shell_hook' to customize how
197 * hooks.py, iplib.py: Added 'shell_hook' to customize how
191 IPython calls shell.
198 IPython calls shell.
192
199
193 * hooks.py, iplib.py: Added 'show_in_pager' hook to specify
200 * hooks.py, iplib.py: Added 'show_in_pager' hook to specify
194 how IPython pages text (%page, %pycat, %pdoc etc.)
201 how IPython pages text (%page, %pycat, %pdoc etc.)
195
202
196 * Extensions/jobctrl.py: Use shell_hook. New magics: '%tasks'
203 * Extensions/jobctrl.py: Use shell_hook. New magics: '%tasks'
197 and '%kill' to kill hanging processes that won't obey ctrl+C.
204 and '%kill' to kill hanging processes that won't obey ctrl+C.
198
205
199 2008-01-16 Ville Vainio <vivainio@gmail.com>
206 2008-01-16 Ville Vainio <vivainio@gmail.com>
200
207
201 * ipy_completers.py: pyw extension support for %run completer.
208 * ipy_completers.py: pyw extension support for %run completer.
202
209
203 2008-01-11 Ville Vainio <vivainio@gmail.com>
210 2008-01-11 Ville Vainio <vivainio@gmail.com>
204
211
205 * iplib.py, ipmaker.py: new rc option - autoexec. It's a list
212 * iplib.py, ipmaker.py: new rc option - autoexec. It's a list
206 of ipython commands to be run when IPython has started up
213 of ipython commands to be run when IPython has started up
207 (just before running the scripts and -c arg on command line).
214 (just before running the scripts and -c arg on command line).
208
215
209 * ipy_user_conf.py: Added an example on how to change term
216 * ipy_user_conf.py: Added an example on how to change term
210 colors in config file (through using autoexec).
217 colors in config file (through using autoexec).
211
218
212 * completer.py, test_completer.py: Ability to specify custom
219 * completer.py, test_completer.py: Ability to specify custom
213 get_endidx to replace readline.get_endidx. For emacs users.
220 get_endidx to replace readline.get_endidx. For emacs users.
214
221
215 2008-01-10 Ville Vainio <vivainio@gmail.com>
222 2008-01-10 Ville Vainio <vivainio@gmail.com>
216
223
217 * Prompts.py (set_p_str): do not crash on illegal prompt strings
224 * Prompts.py (set_p_str): do not crash on illegal prompt strings
218
225
219 2008-01-08 Ville Vainio <vivainio@gmail.com>
226 2008-01-08 Ville Vainio <vivainio@gmail.com>
220
227
221 * '%macro -r' (raw mode) is now default in sh profile.
228 * '%macro -r' (raw mode) is now default in sh profile.
222
229
223 2007-12-31 Ville Vainio <vivainio@gmail.com>
230 2007-12-31 Ville Vainio <vivainio@gmail.com>
224
231
225 * completer.py: custom completer matching is now case sensitive
232 * completer.py: custom completer matching is now case sensitive
226 (#207).
233 (#207).
227
234
228 * ultraTB.py, iplib.py: Add some KeyboardInterrupt catching in
235 * ultraTB.py, iplib.py: Add some KeyboardInterrupt catching in
229 an attempt to prevent occasional crashes.
236 an attempt to prevent occasional crashes.
230
237
231 * CrashHandler.py: Crash log dump now asks user to press enter
238 * CrashHandler.py: Crash log dump now asks user to press enter
232 before exiting.
239 before exiting.
233
240
234 * Store _ip in user_ns instead of __builtin__, enabling safer
241 * Store _ip in user_ns instead of __builtin__, enabling safer
235 coexistence of multiple IPython instances in the same python
242 coexistence of multiple IPython instances in the same python
236 interpreter (#197).
243 interpreter (#197).
237
244
238 * Debugger.py, ipmaker.py: Need to add '-pydb' command line
245 * Debugger.py, ipmaker.py: Need to add '-pydb' command line
239 switch to enable pydb in post-mortem debugging and %run -d.
246 switch to enable pydb in post-mortem debugging and %run -d.
240
247
241 2007-12-28 Ville Vainio <vivainio@gmail.com>
248 2007-12-28 Ville Vainio <vivainio@gmail.com>
242
249
243 * ipy_server.py: TCP socket server for "remote control" of an IPython
250 * ipy_server.py: TCP socket server for "remote control" of an IPython
244 instance.
251 instance.
245
252
246 * Debugger.py: Change to PSF license
253 * Debugger.py: Change to PSF license
247
254
248 * simplegeneric.py: Add license & author notes.
255 * simplegeneric.py: Add license & author notes.
249
256
250 * ipy_fsops.py: Added PathObj and FileObj, an object-oriented way
257 * ipy_fsops.py: Added PathObj and FileObj, an object-oriented way
251 to navigate file system with a custom completer. Run
258 to navigate file system with a custom completer. Run
252 ipy_fsops.test_pathobj() to play with it.
259 ipy_fsops.test_pathobj() to play with it.
253
260
254 2007-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
261 2007-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
255
262
256 * IPython/dtutils.py: Add utilities for interactively running
263 * IPython/dtutils.py: Add utilities for interactively running
257 doctests. Still needs work to more easily handle the namespace of
264 doctests. Still needs work to more easily handle the namespace of
258 the package one may be working on, but the basics are in place.
265 the package one may be working on, but the basics are in place.
259
266
260 2007-12-27 Ville Vainio <vivainio@gmail.com>
267 2007-12-27 Ville Vainio <vivainio@gmail.com>
261
268
262 * ipy_completers.py: Applied arno's patch to get proper list of
269 * ipy_completers.py: Applied arno's patch to get proper list of
263 packages in import completer. Closes #196.
270 packages in import completer. Closes #196.
264
271
265 2007-12-20 Ville Vainio <vivainio@gmail.com>
272 2007-12-20 Ville Vainio <vivainio@gmail.com>
266
273
267 * completer.py, generics.py(complete_object): Allow
274 * completer.py, generics.py(complete_object): Allow
268 custom complers based on python objects via simplegeneric.
275 custom complers based on python objects via simplegeneric.
269 See generics.py / my_demo_complete_object
276 See generics.py / my_demo_complete_object
270
277
271 2007-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
278 2007-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
272
279
273 * IPython/Prompts.py (BasePrompt.__nonzero__): add proper boolean
280 * IPython/Prompts.py (BasePrompt.__nonzero__): add proper boolean
274 behavior to prompt objects, useful for display hooks to adjust
281 behavior to prompt objects, useful for display hooks to adjust
275 themselves depending on whether prompts will be there or not.
282 themselves depending on whether prompts will be there or not.
276
283
277 2007-12-13 Ville Vainio <vivainio@gmail.com>
284 2007-12-13 Ville Vainio <vivainio@gmail.com>
278
285
279 * iplib.py(raw_input): unix readline does not allow unicode in
286 * iplib.py(raw_input): unix readline does not allow unicode in
280 history, encode to normal string. After patch by Tiago.
287 history, encode to normal string. After patch by Tiago.
281 Close #201
288 Close #201
282
289
283 2007-12-12 Ville Vainio <vivainio@gmail.com>
290 2007-12-12 Ville Vainio <vivainio@gmail.com>
284
291
285 * genutils.py (abbrev_cwd): Terminal title now shows 2 levels of
292 * genutils.py (abbrev_cwd): Terminal title now shows 2 levels of
286 current directory.
293 current directory.
287
294
288 2007-12-12 Fernando Perez <Fernando.Perez@colorado.edu>
295 2007-12-12 Fernando Perez <Fernando.Perez@colorado.edu>
289
296
290 * IPython/Shell.py (_select_shell): add support for controlling
297 * IPython/Shell.py (_select_shell): add support for controlling
291 the pylab threading mode directly at the command line, without
298 the pylab threading mode directly at the command line, without
292 having to modify MPL config files. Added unit tests for this
299 having to modify MPL config files. Added unit tests for this
293 feature, though manual/docs update is still pending, will do later.
300 feature, though manual/docs update is still pending, will do later.
294
301
295 2007-12-11 Ville Vainio <vivainio@gmail.com>
302 2007-12-11 Ville Vainio <vivainio@gmail.com>
296
303
297 * ext_rescapture.py: var = !cmd is no longer verbose (to facilitate
304 * ext_rescapture.py: var = !cmd is no longer verbose (to facilitate
298 use in scripts)
305 use in scripts)
299
306
300 2007-12-07 Ville Vainio <vivainio@gmail.com>
307 2007-12-07 Ville Vainio <vivainio@gmail.com>
301
308
302 * iplib.py, ipy_profile_sh.py: Do not escape # on command lines
309 * iplib.py, ipy_profile_sh.py: Do not escape # on command lines
303 anymore (to \#) - even if it is a comment char that is implicitly
310 anymore (to \#) - even if it is a comment char that is implicitly
304 escaped in some unix shells in interactive mode, it is ok to leave
311 escaped in some unix shells in interactive mode, it is ok to leave
305 it in IPython as such.
312 it in IPython as such.
306
313
307
314
308 2007-12-01 Robert Kern <robert.kern@gmail.com>
315 2007-12-01 Robert Kern <robert.kern@gmail.com>
309
316
310 * IPython/ultraTB.py (findsource): Improve the monkeypatch to
317 * IPython/ultraTB.py (findsource): Improve the monkeypatch to
311 inspect.findsource(). It can now find source lines inside zipped
318 inspect.findsource(). It can now find source lines inside zipped
312 packages.
319 packages.
313
320
314 * IPython/ultraTB.py: When constructing tracebacks, try to use __file__
321 * IPython/ultraTB.py: When constructing tracebacks, try to use __file__
315 in the frame's namespace before trusting the filename in the code object
322 in the frame's namespace before trusting the filename in the code object
316 which created the frame.
323 which created the frame.
317
324
318 2007-11-29 *** Released version 0.8.2
325 2007-11-29 *** Released version 0.8.2
319
326
320 2007-11-25 Fernando Perez <Fernando.Perez@colorado.edu>
327 2007-11-25 Fernando Perez <Fernando.Perez@colorado.edu>
321
328
322 * IPython/Logger.py (Logger.logstop): add a proper logstop()
329 * IPython/Logger.py (Logger.logstop): add a proper logstop()
323 method to fully stop the logger, along with a corresponding
330 method to fully stop the logger, along with a corresponding
324 %logstop magic for interactive use.
331 %logstop magic for interactive use.
325
332
326 * IPython/Extensions/ipy_host_completers.py: added new host
333 * IPython/Extensions/ipy_host_completers.py: added new host
327 completers functionality, contributed by Gael Pasgrimaud
334 completers functionality, contributed by Gael Pasgrimaud
328 <gawel-AT-afpy.org>.
335 <gawel-AT-afpy.org>.
329
336
330 2007-11-24 Fernando Perez <Fernando.Perez@colorado.edu>
337 2007-11-24 Fernando Perez <Fernando.Perez@colorado.edu>
331
338
332 * IPython/DPyGetOpt.py (ArgumentError): Apply patch by Paul Mueller
339 * IPython/DPyGetOpt.py (ArgumentError): Apply patch by Paul Mueller
333 <gakusei-AT-dakotacom.net>, to fix deprecated string exceptions in
340 <gakusei-AT-dakotacom.net>, to fix deprecated string exceptions in
334 options handling. Unicode fix in %whos (committed a while ago)
341 options handling. Unicode fix in %whos (committed a while ago)
335 was also contributed by Paul.
342 was also contributed by Paul.
336
343
337 2007-11-23 Darren Dale <darren.dale@cornell.edu>
344 2007-11-23 Darren Dale <darren.dale@cornell.edu>
338 * ipy_traits_completer.py: let traits_completer respect the user's
345 * ipy_traits_completer.py: let traits_completer respect the user's
339 readline_omit__names setting.
346 readline_omit__names setting.
340
347
341 2007-11-08 Ville Vainio <vivainio@gmail.com>
348 2007-11-08 Ville Vainio <vivainio@gmail.com>
342
349
343 * ipy_completers.py (import completer): assume 'xml' module exists.
350 * ipy_completers.py (import completer): assume 'xml' module exists.
344 Do not add every module twice anymore. Closes #196.
351 Do not add every module twice anymore. Closes #196.
345
352
346 * ipy_completers.py, ipy_app_completers.py: Add proper apt-get
353 * ipy_completers.py, ipy_app_completers.py: Add proper apt-get
347 completer that uses apt-cache to search for existing packages.
354 completer that uses apt-cache to search for existing packages.
348
355
349 2007-11-06 Ville Vainio <vivainio@gmail.com>
356 2007-11-06 Ville Vainio <vivainio@gmail.com>
350
357
351 * Prompts.py: Do not update _oh and _123 when do_full_cache is not
358 * Prompts.py: Do not update _oh and _123 when do_full_cache is not
352 true. Closes #194.
359 true. Closes #194.
353
360
354 2007-11-01 Brian Granger <ellisonbg@gmail.com>
361 2007-11-01 Brian Granger <ellisonbg@gmail.com>
355
362
356 * iplib.py, rlineimpl.py: Applied Body Water's patches to get IPython
363 * iplib.py, rlineimpl.py: Applied Body Water's patches to get IPython
357 working with OS X 10.5 libedit implementation of readline.
364 working with OS X 10.5 libedit implementation of readline.
358
365
359 2007-10-24 Ville Vainio <vivainio@gmail.com>
366 2007-10-24 Ville Vainio <vivainio@gmail.com>
360
367
361 * iplib.py(user_setup): To route around buggy installations where
368 * iplib.py(user_setup): To route around buggy installations where
362 UserConfig is not available, create a minimal _ipython.
369 UserConfig is not available, create a minimal _ipython.
363
370
364 * iplib.py: Unicode fixes from Jorgen.
371 * iplib.py: Unicode fixes from Jorgen.
365
372
366 * genutils.py: Slist now has new method 'fields()' for extraction of
373 * genutils.py: Slist now has new method 'fields()' for extraction of
367 whitespace-separated fields from line-oriented data.
374 whitespace-separated fields from line-oriented data.
368
375
369 2007-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
376 2007-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
370
377
371 * IPython/OInspect.py (Inspector.pinfo): fix bug that could arise
378 * IPython/OInspect.py (Inspector.pinfo): fix bug that could arise
372 when querying objects with no __class__ attribute (such as
379 when querying objects with no __class__ attribute (such as
373 f2py-generated modules).
380 f2py-generated modules).
374
381
375 2007-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
382 2007-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
376
383
377 * IPython/Magic.py (magic_time): track compilation time and report
384 * IPython/Magic.py (magic_time): track compilation time and report
378 it if longer than 0.1s (fix done to %time and %timeit). After a
385 it if longer than 0.1s (fix done to %time and %timeit). After a
379 SAGE bug report: http://trac.sagemath.org/sage_trac/ticket/632.
386 SAGE bug report: http://trac.sagemath.org/sage_trac/ticket/632.
380
387
381 2007-09-18 Ville Vainio <vivainio@gmail.com>
388 2007-09-18 Ville Vainio <vivainio@gmail.com>
382
389
383 * genutils.py(make_quoted_expr): Do not use Itpl, it does
390 * genutils.py(make_quoted_expr): Do not use Itpl, it does
384 not support unicode at the moment. Fixes (many) magic calls with
391 not support unicode at the moment. Fixes (many) magic calls with
385 special characters.
392 special characters.
386
393
387 2007-09-14 Fernando Perez <Fernando.Perez@colorado.edu>
394 2007-09-14 Fernando Perez <Fernando.Perez@colorado.edu>
388
395
389 * IPython/genutils.py (doctest_reload): expose the doctest
396 * IPython/genutils.py (doctest_reload): expose the doctest
390 reloader to the user so that people can easily reset doctest while
397 reloader to the user so that people can easily reset doctest while
391 using it interactively. Fixes a problem reported by Jorgen.
398 using it interactively. Fixes a problem reported by Jorgen.
392
399
393 * IPython/iplib.py (InteractiveShell.__init__): protect the
400 * IPython/iplib.py (InteractiveShell.__init__): protect the
394 FakeModule instances used for __main__ in %run calls from
401 FakeModule instances used for __main__ in %run calls from
395 deletion, so that user code defined in them isn't left with
402 deletion, so that user code defined in them isn't left with
396 dangling references due to the Python module deletion machinery.
403 dangling references due to the Python module deletion machinery.
397 This should fix the problems reported by Darren.
404 This should fix the problems reported by Darren.
398
405
399 2007-09-10 Darren Dale <dd55@cornell.edu>
406 2007-09-10 Darren Dale <dd55@cornell.edu>
400
407
401 * Cleanup of IPShellQt and IPShellQt4
408 * Cleanup of IPShellQt and IPShellQt4
402
409
403 2007-09-09 Fernando Perez <Fernando.Perez@colorado.edu>
410 2007-09-09 Fernando Perez <Fernando.Perez@colorado.edu>
404
411
405 * IPython/FakeModule.py (FakeModule.__init__): further fixes for
412 * IPython/FakeModule.py (FakeModule.__init__): further fixes for
406 doctest support.
413 doctest support.
407
414
408 * IPython/iplib.py (safe_execfile): minor docstring improvements.
415 * IPython/iplib.py (safe_execfile): minor docstring improvements.
409
416
410 2007-09-08 Ville Vainio <vivainio@gmail.com>
417 2007-09-08 Ville Vainio <vivainio@gmail.com>
411
418
412 * Magic.py (%pushd, %popd, %dirs): Fix dir stack - push *current*
419 * Magic.py (%pushd, %popd, %dirs): Fix dir stack - push *current*
413 directory, not the target directory.
420 directory, not the target directory.
414
421
415 * ipapi.py, Magic.py, iplib.py: Add ipapi.UsageError, a lighter weight
422 * ipapi.py, Magic.py, iplib.py: Add ipapi.UsageError, a lighter weight
416 exception that won't print the tracebacks. Switched many magics to
423 exception that won't print the tracebacks. Switched many magics to
417 raise them on error situations, also GetoptError is not printed
424 raise them on error situations, also GetoptError is not printed
418 anymore.
425 anymore.
419
426
420 2007-09-07 Ville Vainio <vivainio@gmail.com>
427 2007-09-07 Ville Vainio <vivainio@gmail.com>
421
428
422 * iplib.py: do not auto-alias "dir", it screws up other dir auto
429 * iplib.py: do not auto-alias "dir", it screws up other dir auto
423 aliases.
430 aliases.
424
431
425 * genutils.py: SList.grep() implemented.
432 * genutils.py: SList.grep() implemented.
426
433
427 * ipy_editors.py, UserConfig/ipy_user_conf.py: Add some editors
434 * ipy_editors.py, UserConfig/ipy_user_conf.py: Add some editors
428 for easy "out of the box" setup of several common editors, so that
435 for easy "out of the box" setup of several common editors, so that
429 e.g. '%edit os.path.isfile' will jump to the correct line
436 e.g. '%edit os.path.isfile' will jump to the correct line
430 automatically. Contributions for command lines of your favourite
437 automatically. Contributions for command lines of your favourite
431 editors welcome.
438 editors welcome.
432
439
433 2007-09-07 Fernando Perez <Fernando.Perez@colorado.edu>
440 2007-09-07 Fernando Perez <Fernando.Perez@colorado.edu>
434
441
435 * IPython/OInspect.py (Inspector.pinfo): fixed bug that was
442 * IPython/OInspect.py (Inspector.pinfo): fixed bug that was
436 preventing source display in certain cases. In reality I think
443 preventing source display in certain cases. In reality I think
437 the problem is with Ubuntu's Python build, but this change works
444 the problem is with Ubuntu's Python build, but this change works
438 around the issue in some cases (not in all, unfortunately). I'd
445 around the issue in some cases (not in all, unfortunately). I'd
439 filed a Python bug on this with more details, but in the change of
446 filed a Python bug on this with more details, but in the change of
440 bug trackers it seems to have been lost.
447 bug trackers it seems to have been lost.
441
448
442 * IPython/Magic.py (magic_dhist): restore %dhist. No, cd -TAB is
449 * IPython/Magic.py (magic_dhist): restore %dhist. No, cd -TAB is
443 not the same, it's not self-documenting, doesn't allow range
450 not the same, it's not self-documenting, doesn't allow range
444 selection, and sorts alphabetically instead of numerically.
451 selection, and sorts alphabetically instead of numerically.
445 (magic_r): restore %r. No, "up + enter. One char magic" is not
452 (magic_r): restore %r. No, "up + enter. One char magic" is not
446 the same thing, since %r takes parameters to allow fast retrieval
453 the same thing, since %r takes parameters to allow fast retrieval
447 of old commands. I've received emails from users who use this a
454 of old commands. I've received emails from users who use this a
448 LOT, so it stays.
455 LOT, so it stays.
449 (magic_automagic): restore %automagic. "use _ip.option.automagic"
456 (magic_automagic): restore %automagic. "use _ip.option.automagic"
450 is not a valid replacement b/c it doesn't provide an complete
457 is not a valid replacement b/c it doesn't provide an complete
451 explanation (which the automagic docstring does).
458 explanation (which the automagic docstring does).
452 (magic_autocall): restore %autocall, with improved docstring.
459 (magic_autocall): restore %autocall, with improved docstring.
453 Same argument as for others, "use _ip.options.autocall" is not a
460 Same argument as for others, "use _ip.options.autocall" is not a
454 valid replacement.
461 valid replacement.
455 (magic_pdef): restore %pdef & friends. Used widely, mentioned in
462 (magic_pdef): restore %pdef & friends. Used widely, mentioned in
456 tutorials and online docs.
463 tutorials and online docs.
457
464
458 2007-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
465 2007-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
459
466
460 * IPython/usage.py (quick_reference): mention magics in quickref,
467 * IPython/usage.py (quick_reference): mention magics in quickref,
461 modified main banner to mention %quickref.
468 modified main banner to mention %quickref.
462
469
463 * IPython/FakeModule.py (FakeModule): fixes for doctest compatibility.
470 * IPython/FakeModule.py (FakeModule): fixes for doctest compatibility.
464
471
465 2007-09-06 Ville Vainio <vivainio@gmail.com>
472 2007-09-06 Ville Vainio <vivainio@gmail.com>
466
473
467 * ipy_rehashdir.py, ipy_workdir.py, ipy_fsops.py, iplib.py:
474 * ipy_rehashdir.py, ipy_workdir.py, ipy_fsops.py, iplib.py:
468 Callable aliases now pass the _ip as first arg. This breaks
475 Callable aliases now pass the _ip as first arg. This breaks
469 compatibility with earlier 0.8.2.svn series! (though they should
476 compatibility with earlier 0.8.2.svn series! (though they should
470 not have been in use yet outside these few extensions)
477 not have been in use yet outside these few extensions)
471
478
472 2007-09-05 Ville Vainio <vivainio@gmail.com>
479 2007-09-05 Ville Vainio <vivainio@gmail.com>
473
480
474 * external/mglob.py: expand('dirname') => ['dirname'], instead
481 * external/mglob.py: expand('dirname') => ['dirname'], instead
475 of ['dirname/foo','dirname/bar', ...].
482 of ['dirname/foo','dirname/bar', ...].
476
483
477 * Extensions/ipy_fsops.py: added, has usefull shell utils for plain
484 * Extensions/ipy_fsops.py: added, has usefull shell utils for plain
478 win32 installations: icp, imv, imkdir, igrep, irm, collect (collect
485 win32 installations: icp, imv, imkdir, igrep, irm, collect (collect
479 is useful for others as well).
486 is useful for others as well).
480
487
481 * iplib.py: on callable aliases (as opposed to old style aliases),
488 * iplib.py: on callable aliases (as opposed to old style aliases),
482 do var_expand() immediately, and use make_quoted_expr instead
489 do var_expand() immediately, and use make_quoted_expr instead
483 of hardcoded r"""
490 of hardcoded r"""
484
491
485 * Extensions/ipy_profile_sh.py: Try to detect cygwin on win32,
492 * Extensions/ipy_profile_sh.py: Try to detect cygwin on win32,
486 if not available load ipy_fsops.py for cp, mv, etc. replacements
493 if not available load ipy_fsops.py for cp, mv, etc. replacements
487
494
488 * OInspect.py, ipy_which.py: improve %which and obj? for callable
495 * OInspect.py, ipy_which.py: improve %which and obj? for callable
489 aliases
496 aliases
490
497
491 2007-09-04 Ville Vainio <vivainio@gmail.com>
498 2007-09-04 Ville Vainio <vivainio@gmail.com>
492
499
493 * ipy_profile_zope.py: add zope profile, by Stefan Eletzhofer.
500 * ipy_profile_zope.py: add zope profile, by Stefan Eletzhofer.
494 Relicensed under BSD with the authors approval.
501 Relicensed under BSD with the authors approval.
495
502
496 * ipmaker.py, usage.py: Remove %magic from default banner, improve
503 * ipmaker.py, usage.py: Remove %magic from default banner, improve
497 %quickref
504 %quickref
498
505
499 2007-09-03 Ville Vainio <vivainio@gmail.com>
506 2007-09-03 Ville Vainio <vivainio@gmail.com>
500
507
501 * Magic.py: %time now passes expression through prefilter,
508 * Magic.py: %time now passes expression through prefilter,
502 allowing IPython syntax.
509 allowing IPython syntax.
503
510
504 2007-09-01 Ville Vainio <vivainio@gmail.com>
511 2007-09-01 Ville Vainio <vivainio@gmail.com>
505
512
506 * ipmaker.py: Always show full traceback when newstyle config fails
513 * ipmaker.py: Always show full traceback when newstyle config fails
507
514
508 2007-08-27 Ville Vainio <vivainio@gmail.com>
515 2007-08-27 Ville Vainio <vivainio@gmail.com>
509
516
510 * Magic.py: fix %cd for nonexistent dir when dhist is empty, close #180
517 * Magic.py: fix %cd for nonexistent dir when dhist is empty, close #180
511
518
512 2007-08-26 Ville Vainio <vivainio@gmail.com>
519 2007-08-26 Ville Vainio <vivainio@gmail.com>
513
520
514 * ipmaker.py: Command line args have the highest priority again
521 * ipmaker.py: Command line args have the highest priority again
515
522
516 * iplib.py, ipmaker.py: -i command line argument now behaves as in
523 * iplib.py, ipmaker.py: -i command line argument now behaves as in
517 normal python, i.e. leaves the IPython session running after -c
524 normal python, i.e. leaves the IPython session running after -c
518 command or running a batch file from command line.
525 command or running a batch file from command line.
519
526
520 2007-08-22 Ville Vainio <vivainio@gmail.com>
527 2007-08-22 Ville Vainio <vivainio@gmail.com>
521
528
522 * iplib.py: no extra empty (last) line in raw hist w/ multiline
529 * iplib.py: no extra empty (last) line in raw hist w/ multiline
523 statements
530 statements
524
531
525 * logger.py: Fix bug where blank lines in history were not
532 * logger.py: Fix bug where blank lines in history were not
526 added until AFTER adding the current line; translated and raw
533 added until AFTER adding the current line; translated and raw
527 history should finally be in sync with prompt now.
534 history should finally be in sync with prompt now.
528
535
529 * ipy_completers.py: quick_completer now makes it easy to create
536 * ipy_completers.py: quick_completer now makes it easy to create
530 trivial custom completers
537 trivial custom completers
531
538
532 * clearcmd.py: shadow history compression & erasing, fixed input hist
539 * clearcmd.py: shadow history compression & erasing, fixed input hist
533 clearing.
540 clearing.
534
541
535 * envpersist.py, history.py: %env (sh profile only), %hist completers
542 * envpersist.py, history.py: %env (sh profile only), %hist completers
536
543
537 * genutils.py, Prompts.py, Magic.py: win32 - prompt (with \yDEPTH) and
544 * genutils.py, Prompts.py, Magic.py: win32 - prompt (with \yDEPTH) and
538 term title now include the drive letter, and always use / instead of
545 term title now include the drive letter, and always use / instead of
539 os.sep (as per recommended approach for win32 ipython in general).
546 os.sep (as per recommended approach for win32 ipython in general).
540
547
541 * ipykit.py, ipy_kitcfg.py: special launcher for ipykit. Allows running
548 * ipykit.py, ipy_kitcfg.py: special launcher for ipykit. Allows running
542 plain python scripts from ipykit command line by running
549 plain python scripts from ipykit command line by running
543 "py myscript.py", even w/o installed python.
550 "py myscript.py", even w/o installed python.
544
551
545 2007-08-21 Ville Vainio <vivainio@gmail.com>
552 2007-08-21 Ville Vainio <vivainio@gmail.com>
546
553
547 * ipmaker.py: finding ipythonrc-PROF now skips ipy_profile_PROF.
554 * ipmaker.py: finding ipythonrc-PROF now skips ipy_profile_PROF.
548 (for backwards compatibility)
555 (for backwards compatibility)
549
556
550 * history.py: switch back to %hist -t from %hist -r as default.
557 * history.py: switch back to %hist -t from %hist -r as default.
551 At least until raw history is fixed for good.
558 At least until raw history is fixed for good.
552
559
553 2007-08-20 Ville Vainio <vivainio@gmail.com>
560 2007-08-20 Ville Vainio <vivainio@gmail.com>
554
561
555 * ipapi.py, iplib.py: DebugTools accessible via _ip.dbg, to catch &
562 * ipapi.py, iplib.py: DebugTools accessible via _ip.dbg, to catch &
556 locate alias redeclarations etc. Also, avoid handling
563 locate alias redeclarations etc. Also, avoid handling
557 _ip.IP.alias_table directly, prefer using _ip.defalias.
564 _ip.IP.alias_table directly, prefer using _ip.defalias.
558
565
559
566
560 2007-08-15 Ville Vainio <vivainio@gmail.com>
567 2007-08-15 Ville Vainio <vivainio@gmail.com>
561
568
562 * prefilter.py: ! is now always served first
569 * prefilter.py: ! is now always served first
563
570
564 2007-08-15 Fernando Perez <Fernando.Perez@colorado.edu>
571 2007-08-15 Fernando Perez <Fernando.Perez@colorado.edu>
565
572
566 * IPython/iplib.py (safe_execfile): fix the SystemExit
573 * IPython/iplib.py (safe_execfile): fix the SystemExit
567 auto-suppression code to work in Python2.4 (the internal structure
574 auto-suppression code to work in Python2.4 (the internal structure
568 of that exception changed and I'd only tested the code with 2.5).
575 of that exception changed and I'd only tested the code with 2.5).
569 Bug reported by a SciPy attendee.
576 Bug reported by a SciPy attendee.
570
577
571 2007-08-13 Ville Vainio <vivainio@gmail.com>
578 2007-08-13 Ville Vainio <vivainio@gmail.com>
572
579
573 * prefilter.py: reverted !c:/bin/foo fix, made % in
580 * prefilter.py: reverted !c:/bin/foo fix, made % in
574 multiline specials work again
581 multiline specials work again
575
582
576 2007-08-13 Ville Vainio <vivainio@gmail.com>
583 2007-08-13 Ville Vainio <vivainio@gmail.com>
577
584
578 * prefilter.py: Take more care to special-case !, so that
585 * prefilter.py: Take more care to special-case !, so that
579 !c:/bin/foo.exe works.
586 !c:/bin/foo.exe works.
580
587
581 * setup.py: if we are building eggs, strip all docs and
588 * setup.py: if we are building eggs, strip all docs and
582 examples (it doesn't make sense to bytecompile examples,
589 examples (it doesn't make sense to bytecompile examples,
583 and docs would be in an awkward place anyway).
590 and docs would be in an awkward place anyway).
584
591
585 * Ryan Krauss' patch fixes start menu shortcuts when IPython
592 * Ryan Krauss' patch fixes start menu shortcuts when IPython
586 is installed into a directory that has spaces in the name.
593 is installed into a directory that has spaces in the name.
587
594
588 2007-08-13 Fernando Perez <Fernando.Perez@colorado.edu>
595 2007-08-13 Fernando Perez <Fernando.Perez@colorado.edu>
589
596
590 * IPython/Magic.py (magic_doctest_mode): fix prompt separators in
597 * IPython/Magic.py (magic_doctest_mode): fix prompt separators in
591 doctest profile and %doctest_mode, so they actually generate the
598 doctest profile and %doctest_mode, so they actually generate the
592 blank lines needed by doctest to separate individual tests.
599 blank lines needed by doctest to separate individual tests.
593
600
594 * IPython/iplib.py (safe_execfile): modify so that running code
601 * IPython/iplib.py (safe_execfile): modify so that running code
595 which calls sys.exit(0) (or equivalently, raise SystemExit(0))
602 which calls sys.exit(0) (or equivalently, raise SystemExit(0))
596 doesn't get a printed traceback. Any other value in sys.exit(),
603 doesn't get a printed traceback. Any other value in sys.exit(),
597 including the empty call, still generates a traceback. This
604 including the empty call, still generates a traceback. This
598 enables use of %run without having to pass '-e' for codes that
605 enables use of %run without having to pass '-e' for codes that
599 correctly set the exit status flag.
606 correctly set the exit status flag.
600
607
601 2007-08-12 Fernando Perez <Fernando.Perez@colorado.edu>
608 2007-08-12 Fernando Perez <Fernando.Perez@colorado.edu>
602
609
603 * IPython/iplib.py (InteractiveShell.post_config_initialization):
610 * IPython/iplib.py (InteractiveShell.post_config_initialization):
604 fix problems with doctests failing when run inside IPython due to
611 fix problems with doctests failing when run inside IPython due to
605 IPython's modifications of sys.displayhook.
612 IPython's modifications of sys.displayhook.
606
613
607 2007-8-9 Fernando Perez <fperez@planck.colorado.edu>
614 2007-8-9 Fernando Perez <fperez@planck.colorado.edu>
608
615
609 * IPython/ipapi.py (to_user_ns): update to accept a dict as well as
616 * IPython/ipapi.py (to_user_ns): update to accept a dict as well as
610 a string with names.
617 a string with names.
611
618
612 2007-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
619 2007-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
613
620
614 * IPython/Magic.py (magic_doctest_mode): added new %doctest_mode
621 * IPython/Magic.py (magic_doctest_mode): added new %doctest_mode
615 magic to toggle on/off the doctest pasting support without having
622 magic to toggle on/off the doctest pasting support without having
616 to leave a session to switch to a separate profile.
623 to leave a session to switch to a separate profile.
617
624
618 2007-08-08 Fernando Perez <Fernando.Perez@colorado.edu>
625 2007-08-08 Fernando Perez <Fernando.Perez@colorado.edu>
619
626
620 * IPython/Extensions/ipy_profile_doctest.py (main): fix prompt to
627 * IPython/Extensions/ipy_profile_doctest.py (main): fix prompt to
621 introduce a blank line between inputs, to conform to doctest
628 introduce a blank line between inputs, to conform to doctest
622 requirements.
629 requirements.
623
630
624 * IPython/OInspect.py (Inspector.pinfo): fix another part where
631 * IPython/OInspect.py (Inspector.pinfo): fix another part where
625 auto-generated docstrings for new-style classes were showing up.
632 auto-generated docstrings for new-style classes were showing up.
626
633
627 2007-08-07 Fernando Perez <Fernando.Perez@colorado.edu>
634 2007-08-07 Fernando Perez <Fernando.Perez@colorado.edu>
628
635
629 * api_changes: Add new file to track backward-incompatible
636 * api_changes: Add new file to track backward-incompatible
630 user-visible changes.
637 user-visible changes.
631
638
632 2007-08-06 Ville Vainio <vivainio@gmail.com>
639 2007-08-06 Ville Vainio <vivainio@gmail.com>
633
640
634 * ipmaker.py: fix bug where user_config_ns didn't exist at all
641 * ipmaker.py: fix bug where user_config_ns didn't exist at all
635 before all the config files were handled.
642 before all the config files were handled.
636
643
637 2007-08-04 Fernando Perez <Fernando.Perez@colorado.edu>
644 2007-08-04 Fernando Perez <Fernando.Perez@colorado.edu>
638
645
639 * IPython/irunner.py (RunnerFactory): Add new factory class for
646 * IPython/irunner.py (RunnerFactory): Add new factory class for
640 creating reusable runners based on filenames.
647 creating reusable runners based on filenames.
641
648
642 * IPython/Extensions/ipy_profile_doctest.py: New profile for
649 * IPython/Extensions/ipy_profile_doctest.py: New profile for
643 doctest support. It sets prompts/exceptions as similar to
650 doctest support. It sets prompts/exceptions as similar to
644 standard Python as possible, so that ipython sessions in this
651 standard Python as possible, so that ipython sessions in this
645 profile can be easily pasted as doctests with minimal
652 profile can be easily pasted as doctests with minimal
646 modifications. It also enables pasting of doctests from external
653 modifications. It also enables pasting of doctests from external
647 sources (even if they have leading whitespace), so that you can
654 sources (even if they have leading whitespace), so that you can
648 rerun doctests from existing sources.
655 rerun doctests from existing sources.
649
656
650 * IPython/iplib.py (_prefilter): fix a buglet where after entering
657 * IPython/iplib.py (_prefilter): fix a buglet where after entering
651 some whitespace, the prompt would become a continuation prompt
658 some whitespace, the prompt would become a continuation prompt
652 with no way of exiting it other than Ctrl-C. This fix brings us
659 with no way of exiting it other than Ctrl-C. This fix brings us
653 into conformity with how the default python prompt works.
660 into conformity with how the default python prompt works.
654
661
655 * IPython/Extensions/InterpreterPasteInput.py (prefilter_paste):
662 * IPython/Extensions/InterpreterPasteInput.py (prefilter_paste):
656 Add support for pasting not only lines that start with '>>>', but
663 Add support for pasting not only lines that start with '>>>', but
657 also with ' >>>'. That is, arbitrary whitespace can now precede
664 also with ' >>>'. That is, arbitrary whitespace can now precede
658 the prompts. This makes the system useful for pasting doctests
665 the prompts. This makes the system useful for pasting doctests
659 from docstrings back into a normal session.
666 from docstrings back into a normal session.
660
667
661 2007-08-02 Fernando Perez <Fernando.Perez@colorado.edu>
668 2007-08-02 Fernando Perez <Fernando.Perez@colorado.edu>
662
669
663 * IPython/Shell.py (IPShellEmbed.__call__): fix bug introduced in
670 * IPython/Shell.py (IPShellEmbed.__call__): fix bug introduced in
664 r1357, which had killed multiple invocations of an embedded
671 r1357, which had killed multiple invocations of an embedded
665 ipython (this means that example-embed has been broken for over 1
672 ipython (this means that example-embed has been broken for over 1
666 year!!!). Rather than possibly breaking the batch stuff for which
673 year!!!). Rather than possibly breaking the batch stuff for which
667 the code in iplib.py/interact was introduced, I worked around the
674 the code in iplib.py/interact was introduced, I worked around the
668 problem in the embedding class in Shell.py. We really need a
675 problem in the embedding class in Shell.py. We really need a
669 bloody test suite for this code, I'm sick of finding stuff that
676 bloody test suite for this code, I'm sick of finding stuff that
670 used to work breaking left and right every time I use an old
677 used to work breaking left and right every time I use an old
671 feature I hadn't touched in a few months.
678 feature I hadn't touched in a few months.
672 (kill_embedded): Add a new magic that only shows up in embedded
679 (kill_embedded): Add a new magic that only shows up in embedded
673 mode, to allow users to permanently deactivate an embedded instance.
680 mode, to allow users to permanently deactivate an embedded instance.
674
681
675 2007-08-01 Ville Vainio <vivainio@gmail.com>
682 2007-08-01 Ville Vainio <vivainio@gmail.com>
676
683
677 * iplib.py, ipy_profile_sh.py (runlines): Fix the bug where raw
684 * iplib.py, ipy_profile_sh.py (runlines): Fix the bug where raw
678 history gets out of sync on runlines (e.g. when running macros).
685 history gets out of sync on runlines (e.g. when running macros).
679
686
680 2007-07-31 Fernando Perez <Fernando.Perez@colorado.edu>
687 2007-07-31 Fernando Perez <Fernando.Perez@colorado.edu>
681
688
682 * IPython/Magic.py (magic_colors): fix win32-related error message
689 * IPython/Magic.py (magic_colors): fix win32-related error message
683 that could appear under *nix when readline was missing. Patch by
690 that could appear under *nix when readline was missing. Patch by
684 Scott Jackson, closes #175.
691 Scott Jackson, closes #175.
685
692
686 2007-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
693 2007-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
687
694
688 * IPython/Extensions/ipy_traits_completer.py: Add a new custom
695 * IPython/Extensions/ipy_traits_completer.py: Add a new custom
689 completer that it traits-aware, so that traits objects don't show
696 completer that it traits-aware, so that traits objects don't show
690 all of their internal attributes all the time.
697 all of their internal attributes all the time.
691
698
692 * IPython/genutils.py (dir2): moved this code from inside
699 * IPython/genutils.py (dir2): moved this code from inside
693 completer.py to expose it publicly, so I could use it in the
700 completer.py to expose it publicly, so I could use it in the
694 wildcards bugfix.
701 wildcards bugfix.
695
702
696 * IPython/wildcard.py (NameSpace.__init__): fix a bug reported by
703 * IPython/wildcard.py (NameSpace.__init__): fix a bug reported by
697 Stefan with Traits.
704 Stefan with Traits.
698
705
699 * IPython/completer.py (Completer.attr_matches): change internal
706 * IPython/completer.py (Completer.attr_matches): change internal
700 var name from 'object' to 'obj', since 'object' is now a builtin
707 var name from 'object' to 'obj', since 'object' is now a builtin
701 and this can lead to weird bugs if reusing this code elsewhere.
708 and this can lead to weird bugs if reusing this code elsewhere.
702
709
703 2007-07-25 Fernando Perez <Fernando.Perez@colorado.edu>
710 2007-07-25 Fernando Perez <Fernando.Perez@colorado.edu>
704
711
705 * IPython/OInspect.py (Inspector.pinfo): fix small glitches in
712 * IPython/OInspect.py (Inspector.pinfo): fix small glitches in
706 'foo?' and update the code to prevent printing of default
713 'foo?' and update the code to prevent printing of default
707 docstrings that started appearing after I added support for
714 docstrings that started appearing after I added support for
708 new-style classes. The approach I'm using isn't ideal (I just
715 new-style classes. The approach I'm using isn't ideal (I just
709 special-case those strings) but I'm not sure how to more robustly
716 special-case those strings) but I'm not sure how to more robustly
710 differentiate between truly user-written strings and Python's
717 differentiate between truly user-written strings and Python's
711 automatic ones.
718 automatic ones.
712
719
713 2007-07-09 Ville Vainio <vivainio@gmail.com>
720 2007-07-09 Ville Vainio <vivainio@gmail.com>
714
721
715 * completer.py: Applied Matthew Neeley's patch:
722 * completer.py: Applied Matthew Neeley's patch:
716 Dynamic attributes from trait_names and _getAttributeNames are added
723 Dynamic attributes from trait_names and _getAttributeNames are added
717 to the list of tab completions, but when this happens, the attribute
724 to the list of tab completions, but when this happens, the attribute
718 list is turned into a set, so the attributes are unordered when
725 list is turned into a set, so the attributes are unordered when
719 printed, which makes it hard to find the right completion. This patch
726 printed, which makes it hard to find the right completion. This patch
720 turns this set back into a list and sort it.
727 turns this set back into a list and sort it.
721
728
722 2007-07-06 Fernando Perez <Fernando.Perez@colorado.edu>
729 2007-07-06 Fernando Perez <Fernando.Perez@colorado.edu>
723
730
724 * IPython/OInspect.py (Inspector.pinfo): Add support for new-style
731 * IPython/OInspect.py (Inspector.pinfo): Add support for new-style
725 classes in various inspector functions.
732 classes in various inspector functions.
726
733
727 2007-06-28 Ville Vainio <vivainio@gmail.com>
734 2007-06-28 Ville Vainio <vivainio@gmail.com>
728
735
729 * shadowns.py, iplib.py, ipapi.py, OInspect.py:
736 * shadowns.py, iplib.py, ipapi.py, OInspect.py:
730 Implement "shadow" namespace, and callable aliases that reside there.
737 Implement "shadow" namespace, and callable aliases that reside there.
731 Use them by:
738 Use them by:
732
739
733 _ip.defalias('foo',myfunc) # creates _sh.foo that points to myfunc
740 _ip.defalias('foo',myfunc) # creates _sh.foo that points to myfunc
734
741
735 foo hello world
742 foo hello world
736 (gets translated to:)
743 (gets translated to:)
737 _sh.foo(r"""hello world""")
744 _sh.foo(r"""hello world""")
738
745
739 In practice, this kind of alias can take the role of a magic function
746 In practice, this kind of alias can take the role of a magic function
740
747
741 * New generic inspect_object, called on obj? and obj??
748 * New generic inspect_object, called on obj? and obj??
742
749
743 2007-06-15 Fernando Perez <Fernando.Perez@colorado.edu>
750 2007-06-15 Fernando Perez <Fernando.Perez@colorado.edu>
744
751
745 * IPython/ultraTB.py (findsource): fix a problem with
752 * IPython/ultraTB.py (findsource): fix a problem with
746 inspect.getfile that can cause crashes during traceback construction.
753 inspect.getfile that can cause crashes during traceback construction.
747
754
748 2007-06-14 Ville Vainio <vivainio@gmail.com>
755 2007-06-14 Ville Vainio <vivainio@gmail.com>
749
756
750 * iplib.py (handle_auto): Try to use ascii for printing "--->"
757 * iplib.py (handle_auto): Try to use ascii for printing "--->"
751 autocall rewrite indication, becausesometimes unicode fails to print
758 autocall rewrite indication, becausesometimes unicode fails to print
752 properly (and you get ' - - - '). Use plain uncoloured ---> for
759 properly (and you get ' - - - '). Use plain uncoloured ---> for
753 unicode.
760 unicode.
754
761
755 * shadow history. Usable through "%hist -g <pat>" and "%rep 0123".
762 * shadow history. Usable through "%hist -g <pat>" and "%rep 0123".
756
763
757 . pickleshare 'hash' commands (hget, hset, hcompress,
764 . pickleshare 'hash' commands (hget, hset, hcompress,
758 hdict) for efficient shadow history storage.
765 hdict) for efficient shadow history storage.
759
766
760 2007-06-13 Ville Vainio <vivainio@gmail.com>
767 2007-06-13 Ville Vainio <vivainio@gmail.com>
761
768
762 * ipapi.py: _ip.to_user_ns(vars, interactive = True).
769 * ipapi.py: _ip.to_user_ns(vars, interactive = True).
763 Added kw arg 'interactive', tell whether vars should be visible
770 Added kw arg 'interactive', tell whether vars should be visible
764 with %whos.
771 with %whos.
765
772
766 2007-06-11 Ville Vainio <vivainio@gmail.com>
773 2007-06-11 Ville Vainio <vivainio@gmail.com>
767
774
768 * pspersistence.py, Magic.py, iplib.py: directory history now saved
775 * pspersistence.py, Magic.py, iplib.py: directory history now saved
769 to db
776 to db
770
777
771 * iplib.py: "ipython -c <cmd>" now passes the command through prefilter.
778 * iplib.py: "ipython -c <cmd>" now passes the command through prefilter.
772 Also, it exits IPython immediately after evaluating the command (just like
779 Also, it exits IPython immediately after evaluating the command (just like
773 std python)
780 std python)
774
781
775 2007-06-05 Walter Doerwald <walter@livinglogic.de>
782 2007-06-05 Walter Doerwald <walter@livinglogic.de>
776
783
777 * IPython/Extensions/ipipe.py: Added a new table icap, which executes a
784 * IPython/Extensions/ipipe.py: Added a new table icap, which executes a
778 Python string and captures the output. (Idea and original patch by
785 Python string and captures the output. (Idea and original patch by
779 Stefan van der Walt)
786 Stefan van der Walt)
780
787
781 2007-06-01 Fernando Perez <Fernando.Perez@colorado.edu>
788 2007-06-01 Fernando Perez <Fernando.Perez@colorado.edu>
782
789
783 * IPython/ultraTB.py (VerboseTB.text): update printing of
790 * IPython/ultraTB.py (VerboseTB.text): update printing of
784 exception types for Python 2.5 (now all exceptions in the stdlib
791 exception types for Python 2.5 (now all exceptions in the stdlib
785 are new-style classes).
792 are new-style classes).
786
793
787 2007-05-31 Walter Doerwald <walter@livinglogic.de>
794 2007-05-31 Walter Doerwald <walter@livinglogic.de>
788
795
789 * IPython/Extensions/igrid.py: Add new commands refresh and
796 * IPython/Extensions/igrid.py: Add new commands refresh and
790 refresh_timer (mapped to "R"/"F5" and to the menu) which restarts
797 refresh_timer (mapped to "R"/"F5" and to the menu) which restarts
791 the iterator once (refresh) or after every x seconds (refresh_timer).
798 the iterator once (refresh) or after every x seconds (refresh_timer).
792 Add a working implementation of "searchexpression", where the text
799 Add a working implementation of "searchexpression", where the text
793 entered is not the text to search for, but an expression that must
800 entered is not the text to search for, but an expression that must
794 be true. Added display of shortcuts to the menu. Added commands "pickinput"
801 be true. Added display of shortcuts to the menu. Added commands "pickinput"
795 and "pickinputattr" that put the object or attribute under the cursor
802 and "pickinputattr" that put the object or attribute under the cursor
796 in the input line. Split the statusbar to be able to display the currently
803 in the input line. Split the statusbar to be able to display the currently
797 active refresh interval. (Patch by Nik Tautenhahn)
804 active refresh interval. (Patch by Nik Tautenhahn)
798
805
799 2007-05-29 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
806 2007-05-29 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
800
807
801 * fixing set_term_title to use ctypes as default
808 * fixing set_term_title to use ctypes as default
802
809
803 * fixing set_term_title fallback to work when curent dir
810 * fixing set_term_title fallback to work when curent dir
804 is on a windows network share
811 is on a windows network share
805
812
806 2007-05-28 Ville Vainio <vivainio@gmail.com>
813 2007-05-28 Ville Vainio <vivainio@gmail.com>
807
814
808 * %cpaste: strip + with > from left (diffs).
815 * %cpaste: strip + with > from left (diffs).
809
816
810 * iplib.py: Fix crash when readline not installed
817 * iplib.py: Fix crash when readline not installed
811
818
812 2007-05-26 Ville Vainio <vivainio@gmail.com>
819 2007-05-26 Ville Vainio <vivainio@gmail.com>
813
820
814 * generics.py: introduce easy to extend result_display generic
821 * generics.py: introduce easy to extend result_display generic
815 function (using simplegeneric.py).
822 function (using simplegeneric.py).
816
823
817 * Fixed the append functionality of %set.
824 * Fixed the append functionality of %set.
818
825
819 2007-05-25 Ville Vainio <vivainio@gmail.com>
826 2007-05-25 Ville Vainio <vivainio@gmail.com>
820
827
821 * New magic: %rep (fetch / run old commands from history)
828 * New magic: %rep (fetch / run old commands from history)
822
829
823 * New extension: mglob (%mglob magic), for powerful glob / find /filter
830 * New extension: mglob (%mglob magic), for powerful glob / find /filter
824 like functionality
831 like functionality
825
832
826 % maghistory.py: %hist -g PATTERM greps the history for pattern
833 % maghistory.py: %hist -g PATTERM greps the history for pattern
827
834
828 2007-05-24 Walter Doerwald <walter@livinglogic.de>
835 2007-05-24 Walter Doerwald <walter@livinglogic.de>
829
836
830 * IPython/Extensions/ipipe.py: Added a Table ihist that can be used to
837 * IPython/Extensions/ipipe.py: Added a Table ihist that can be used to
831 browse the IPython input history
838 browse the IPython input history
832
839
833 * IPython/Extensions/ibrowse.py: Added two command to ibrowse: pickinput
840 * IPython/Extensions/ibrowse.py: Added two command to ibrowse: pickinput
834 (mapped to "i") can be used to put the object under the curser in the input
841 (mapped to "i") can be used to put the object under the curser in the input
835 line. pickinputattr (mapped to "I") does the same for the attribute under
842 line. pickinputattr (mapped to "I") does the same for the attribute under
836 the cursor.
843 the cursor.
837
844
838 2007-05-24 Ville Vainio <vivainio@gmail.com>
845 2007-05-24 Ville Vainio <vivainio@gmail.com>
839
846
840 * Grand magic cleansing (changeset [2380]):
847 * Grand magic cleansing (changeset [2380]):
841
848
842 * Introduce ipy_legacy.py where the following magics were
849 * Introduce ipy_legacy.py where the following magics were
843 moved:
850 moved:
844
851
845 pdef pdoc psource pfile rehash dhist Quit p r automagic autocall
852 pdef pdoc psource pfile rehash dhist Quit p r automagic autocall
846
853
847 If you need them, either use default profile or "import ipy_legacy"
854 If you need them, either use default profile or "import ipy_legacy"
848 in your ipy_user_conf.py
855 in your ipy_user_conf.py
849
856
850 * Move sh and scipy profile to Extensions from UserConfig. this implies
857 * Move sh and scipy profile to Extensions from UserConfig. this implies
851 you should not edit them, but you don't need to run %upgrade when
858 you should not edit them, but you don't need to run %upgrade when
852 upgrading IPython anymore.
859 upgrading IPython anymore.
853
860
854 * %hist/%history now operates in "raw" mode by default. To get the old
861 * %hist/%history now operates in "raw" mode by default. To get the old
855 behaviour, run '%hist -n' (native mode).
862 behaviour, run '%hist -n' (native mode).
856
863
857 * split ipy_stock_completers.py to ipy_stock_completers.py and
864 * split ipy_stock_completers.py to ipy_stock_completers.py and
858 ipy_app_completers.py. Stock completers (%cd, import, %run) are now
865 ipy_app_completers.py. Stock completers (%cd, import, %run) are now
859 installed as default.
866 installed as default.
860
867
861 * sh profile now installs ipy_signals.py, for (hopefully) better ctrl+c
868 * sh profile now installs ipy_signals.py, for (hopefully) better ctrl+c
862 handling.
869 handling.
863
870
864 * iplib.py, ipapi.py: _ip.set_next_input(s) sets the next ("default")
871 * iplib.py, ipapi.py: _ip.set_next_input(s) sets the next ("default")
865 input if readline is available.
872 input if readline is available.
866
873
867 2007-05-23 Ville Vainio <vivainio@gmail.com>
874 2007-05-23 Ville Vainio <vivainio@gmail.com>
868
875
869 * macro.py: %store uses __getstate__ properly
876 * macro.py: %store uses __getstate__ properly
870
877
871 * exesetup.py: added new setup script for creating
878 * exesetup.py: added new setup script for creating
872 standalone IPython executables with py2exe (i.e.
879 standalone IPython executables with py2exe (i.e.
873 no python installation required).
880 no python installation required).
874
881
875 * Removed ipythonrc-scipy, ipy_profile_scipy.py takes
882 * Removed ipythonrc-scipy, ipy_profile_scipy.py takes
876 its place.
883 its place.
877
884
878 * rlineimpl.py, genutils.py (get_home_dir): py2exe support
885 * rlineimpl.py, genutils.py (get_home_dir): py2exe support
879
886
880 2007-05-21 Ville Vainio <vivainio@gmail.com>
887 2007-05-21 Ville Vainio <vivainio@gmail.com>
881
888
882 * platutil_win32.py (set_term_title): handle
889 * platutil_win32.py (set_term_title): handle
883 failure of 'title' system call properly.
890 failure of 'title' system call properly.
884
891
885 2007-05-17 Walter Doerwald <walter@livinglogic.de>
892 2007-05-17 Walter Doerwald <walter@livinglogic.de>
886
893
887 * IPython/Extensions/ipipe.py: Fix xrepr for ifiles.
894 * IPython/Extensions/ipipe.py: Fix xrepr for ifiles.
888 (Bug detected by Paul Mueller).
895 (Bug detected by Paul Mueller).
889
896
890 2007-05-16 Ville Vainio <vivainio@gmail.com>
897 2007-05-16 Ville Vainio <vivainio@gmail.com>
891
898
892 * ipy_profile_sci.py, ipython_win_post_install.py: Create
899 * ipy_profile_sci.py, ipython_win_post_install.py: Create
893 new "sci" profile, effectively a modern version of the old
900 new "sci" profile, effectively a modern version of the old
894 "scipy" profile (which is now slated for deprecation).
901 "scipy" profile (which is now slated for deprecation).
895
902
896 2007-05-15 Ville Vainio <vivainio@gmail.com>
903 2007-05-15 Ville Vainio <vivainio@gmail.com>
897
904
898 * pycolorize.py, pycolor.1: Paul Mueller's patches that
905 * pycolorize.py, pycolor.1: Paul Mueller's patches that
899 make pycolorize read input from stdin when run without arguments.
906 make pycolorize read input from stdin when run without arguments.
900
907
901 * Magic.py: do not require 'PATH' in %rehash/%rehashx. Closes #155
908 * Magic.py: do not require 'PATH' in %rehash/%rehashx. Closes #155
902
909
903 * ipy_rehashdir.py: rename ext_rehashdir to ipy_rehashdir, import
910 * ipy_rehashdir.py: rename ext_rehashdir to ipy_rehashdir, import
904 it in sh profile (instead of ipy_system_conf.py).
911 it in sh profile (instead of ipy_system_conf.py).
905
912
906 * Magic.py, ipy_rehashdir.py, ipy_profile_sh.py: System command
913 * Magic.py, ipy_rehashdir.py, ipy_profile_sh.py: System command
907 aliases are now lower case on windows (MyCommand.exe => mycommand).
914 aliases are now lower case on windows (MyCommand.exe => mycommand).
908
915
909 * macro.py, ipapi.py, iplib.py, Prompts.py: Macro system rehaul.
916 * macro.py, ipapi.py, iplib.py, Prompts.py: Macro system rehaul.
910 Macros are now callable objects that inherit from ipapi.IPyAutocall,
917 Macros are now callable objects that inherit from ipapi.IPyAutocall,
911 i.e. get autocalled regardless of system autocall setting.
918 i.e. get autocalled regardless of system autocall setting.
912
919
913 2007-05-10 Fernando Perez <Fernando.Perez@colorado.edu>
920 2007-05-10 Fernando Perez <Fernando.Perez@colorado.edu>
914
921
915 * IPython/rlineimpl.py: check for clear_history in readline and
922 * IPython/rlineimpl.py: check for clear_history in readline and
916 make it a dummy no-op if not available. This function isn't
923 make it a dummy no-op if not available. This function isn't
917 guaranteed to be in the API and appeared in Python 2.4, so we need
924 guaranteed to be in the API and appeared in Python 2.4, so we need
918 to check it ourselves. Also, clean up this file quite a bit.
925 to check it ourselves. Also, clean up this file quite a bit.
919
926
920 * ipython.1: update man page and full manual with information
927 * ipython.1: update man page and full manual with information
921 about threads (remove outdated warning). Closes #151.
928 about threads (remove outdated warning). Closes #151.
922
929
923 2007-05-09 Fernando Perez <Fernando.Perez@colorado.edu>
930 2007-05-09 Fernando Perez <Fernando.Perez@colorado.edu>
924
931
925 * IPython/Extensions/ipy_constants.py: Add Gael's constants module
932 * IPython/Extensions/ipy_constants.py: Add Gael's constants module
926 in trunk (note that this made it into the 0.8.1 release already,
933 in trunk (note that this made it into the 0.8.1 release already,
927 but the changelogs didn't get coordinated). Many thanks to Gael
934 but the changelogs didn't get coordinated). Many thanks to Gael
928 Varoquaux <gael.varoquaux-AT-normalesup.org>
935 Varoquaux <gael.varoquaux-AT-normalesup.org>
929
936
930 2007-05-09 *** Released version 0.8.1
937 2007-05-09 *** Released version 0.8.1
931
938
932 2007-05-10 Walter Doerwald <walter@livinglogic.de>
939 2007-05-10 Walter Doerwald <walter@livinglogic.de>
933
940
934 * IPython/Extensions/igrid.py: Incorporate html help into
941 * IPython/Extensions/igrid.py: Incorporate html help into
935 the module, so we don't have to search for the file.
942 the module, so we don't have to search for the file.
936
943
937 2007-05-02 Fernando Perez <Fernando.Perez@colorado.edu>
944 2007-05-02 Fernando Perez <Fernando.Perez@colorado.edu>
938
945
939 * test/test_irunner.py (RunnerTestCase._test_runner): Close #147.
946 * test/test_irunner.py (RunnerTestCase._test_runner): Close #147.
940
947
941 2007-04-30 Ville Vainio <vivainio@gmail.com>
948 2007-04-30 Ville Vainio <vivainio@gmail.com>
942
949
943 * iplib.py: (pre_config_initialization) Catch UnicodeDecodeError if the
950 * iplib.py: (pre_config_initialization) Catch UnicodeDecodeError if the
944 user has illegal (non-ascii) home directory name
951 user has illegal (non-ascii) home directory name
945
952
946 2007-04-27 Ville Vainio <vivainio@gmail.com>
953 2007-04-27 Ville Vainio <vivainio@gmail.com>
947
954
948 * platutils_win32.py: implement set_term_title for windows
955 * platutils_win32.py: implement set_term_title for windows
949
956
950 * Update version number
957 * Update version number
951
958
952 * ipy_profile_sh.py: more informative prompt (2 dir levels)
959 * ipy_profile_sh.py: more informative prompt (2 dir levels)
953
960
954 2007-04-26 Walter Doerwald <walter@livinglogic.de>
961 2007-04-26 Walter Doerwald <walter@livinglogic.de>
955
962
956 * IPython/Extensions/igrid.py: (igrid) Fix bug that surfaced
963 * IPython/Extensions/igrid.py: (igrid) Fix bug that surfaced
957 when the igrid input raised an exception. (Patch by Nik Tautenhahn,
964 when the igrid input raised an exception. (Patch by Nik Tautenhahn,
958 bug discovered by Ville).
965 bug discovered by Ville).
959
966
960 2007-04-26 Ville Vainio <vivainio@gmail.com>
967 2007-04-26 Ville Vainio <vivainio@gmail.com>
961
968
962 * Extensions/ipy_completers.py: Olivier's module completer now
969 * Extensions/ipy_completers.py: Olivier's module completer now
963 saves the list of root modules if it takes > 4 secs on the first run.
970 saves the list of root modules if it takes > 4 secs on the first run.
964
971
965 * Magic.py (%rehashx): %rehashx now clears the completer cache
972 * Magic.py (%rehashx): %rehashx now clears the completer cache
966
973
967
974
968 2007-04-26 Fernando Perez <Fernando.Perez@colorado.edu>
975 2007-04-26 Fernando Perez <Fernando.Perez@colorado.edu>
969
976
970 * ipython.el: fix incorrect color scheme, reported by Stefan.
977 * ipython.el: fix incorrect color scheme, reported by Stefan.
971 Closes #149.
978 Closes #149.
972
979
973 * IPython/PyColorize.py (Parser.format2): fix state-handling
980 * IPython/PyColorize.py (Parser.format2): fix state-handling
974 logic. I still don't like how that code handles state, but at
981 logic. I still don't like how that code handles state, but at
975 least now it should be correct, if inelegant. Closes #146.
982 least now it should be correct, if inelegant. Closes #146.
976
983
977 2007-04-25 Ville Vainio <vivainio@gmail.com>
984 2007-04-25 Ville Vainio <vivainio@gmail.com>
978
985
979 * Extensions/ipy_which.py: added extension for %which magic, works
986 * Extensions/ipy_which.py: added extension for %which magic, works
980 a lot like unix 'which' but also finds and expands aliases, and
987 a lot like unix 'which' but also finds and expands aliases, and
981 allows wildcards.
988 allows wildcards.
982
989
983 * ipapi.py (expand_alias): Now actually *return* the expanded alias,
990 * ipapi.py (expand_alias): Now actually *return* the expanded alias,
984 as opposed to returning nothing.
991 as opposed to returning nothing.
985
992
986 * UserConfig/ipy_user_conf.py, ipy_profile_sh.py: do not import
993 * UserConfig/ipy_user_conf.py, ipy_profile_sh.py: do not import
987 ipy_stock_completers on default profile, do import on sh profile.
994 ipy_stock_completers on default profile, do import on sh profile.
988
995
989 2007-04-22 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
996 2007-04-22 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
990
997
991 * Fix bug in iplib.py/safe_execfile when launching ipython with a script
998 * Fix bug in iplib.py/safe_execfile when launching ipython with a script
992 like ipython.py foo.py which raised a IndexError.
999 like ipython.py foo.py which raised a IndexError.
993
1000
994 2007-04-21 Ville Vainio <vivainio@gmail.com>
1001 2007-04-21 Ville Vainio <vivainio@gmail.com>
995
1002
996 * Extensions/ipy_extutil.py: added extension to manage other ipython
1003 * Extensions/ipy_extutil.py: added extension to manage other ipython
997 extensions. Now only supports 'ls' == list extensions.
1004 extensions. Now only supports 'ls' == list extensions.
998
1005
999 2007-04-20 Fernando Perez <Fernando.Perez@colorado.edu>
1006 2007-04-20 Fernando Perez <Fernando.Perez@colorado.edu>
1000
1007
1001 * IPython/Debugger.py (BdbQuit_excepthook): fix small bug that
1008 * IPython/Debugger.py (BdbQuit_excepthook): fix small bug that
1002 would prevent use of the exception system outside of a running
1009 would prevent use of the exception system outside of a running
1003 IPython instance.
1010 IPython instance.
1004
1011
1005 2007-04-20 Ville Vainio <vivainio@gmail.com>
1012 2007-04-20 Ville Vainio <vivainio@gmail.com>
1006
1013
1007 * Extensions/ipy_render.py: added extension for easy
1014 * Extensions/ipy_render.py: added extension for easy
1008 interactive text template rendering (to clipboard). Uses Ka-Ping Yee's
1015 interactive text template rendering (to clipboard). Uses Ka-Ping Yee's
1009 'Iptl' template notation,
1016 'Iptl' template notation,
1010
1017
1011 * Extensions/ipy_completers.py: introduced Olivier Lauzanne's
1018 * Extensions/ipy_completers.py: introduced Olivier Lauzanne's
1012 safer & faster 'import' completer.
1019 safer & faster 'import' completer.
1013
1020
1014 * ipapi.py: Introduced new ipapi methods, _ip.defmacro(name, value)
1021 * ipapi.py: Introduced new ipapi methods, _ip.defmacro(name, value)
1015 and _ip.defalias(name, command).
1022 and _ip.defalias(name, command).
1016
1023
1017 * Extensions/ipy_exportdb.py: New extension for exporting all the
1024 * Extensions/ipy_exportdb.py: New extension for exporting all the
1018 %store'd data in a portable format (normal ipapi calls like
1025 %store'd data in a portable format (normal ipapi calls like
1019 defmacro() etc.)
1026 defmacro() etc.)
1020
1027
1021 2007-04-19 Ville Vainio <vivainio@gmail.com>
1028 2007-04-19 Ville Vainio <vivainio@gmail.com>
1022
1029
1023 * upgrade_dir.py: skip junk files like *.pyc
1030 * upgrade_dir.py: skip junk files like *.pyc
1024
1031
1025 * Release.py: version number to 0.8.1
1032 * Release.py: version number to 0.8.1
1026
1033
1027 2007-04-18 Ville Vainio <vivainio@gmail.com>
1034 2007-04-18 Ville Vainio <vivainio@gmail.com>
1028
1035
1029 * iplib.py (safe_execfile): make "ipython foo.py" work with 2.5.1c1
1036 * iplib.py (safe_execfile): make "ipython foo.py" work with 2.5.1c1
1030 and later on win32.
1037 and later on win32.
1031
1038
1032 2007-04-16 Ville Vainio <vivainio@gmail.com>
1039 2007-04-16 Ville Vainio <vivainio@gmail.com>
1033
1040
1034 * iplib.py (showtraceback): Do not crash when running w/o readline.
1041 * iplib.py (showtraceback): Do not crash when running w/o readline.
1035
1042
1036 2007-04-12 Walter Doerwald <walter@livinglogic.de>
1043 2007-04-12 Walter Doerwald <walter@livinglogic.de>
1037
1044
1038 * IPython/Extensions/ipipe.py: (ils) Directoy listings are now
1045 * IPython/Extensions/ipipe.py: (ils) Directoy listings are now
1039 sorted (case sensitive with files and dirs mixed).
1046 sorted (case sensitive with files and dirs mixed).
1040
1047
1041 2007-04-10 Fernando Perez <Fernando.Perez@colorado.edu>
1048 2007-04-10 Fernando Perez <Fernando.Perez@colorado.edu>
1042
1049
1043 * IPython/Release.py (version): Open trunk for 0.8.1 development.
1050 * IPython/Release.py (version): Open trunk for 0.8.1 development.
1044
1051
1045 2007-04-10 *** Released version 0.8.0
1052 2007-04-10 *** Released version 0.8.0
1046
1053
1047 2007-04-07 Fernando Perez <Fernando.Perez@colorado.edu>
1054 2007-04-07 Fernando Perez <Fernando.Perez@colorado.edu>
1048
1055
1049 * Tag 0.8.0 for release.
1056 * Tag 0.8.0 for release.
1050
1057
1051 * IPython/iplib.py (reloadhist): add API function to cleanly
1058 * IPython/iplib.py (reloadhist): add API function to cleanly
1052 reload the readline history, which was growing inappropriately on
1059 reload the readline history, which was growing inappropriately on
1053 every %run call.
1060 every %run call.
1054
1061
1055 * win32_manual_post_install.py (run): apply last part of Nicolas
1062 * win32_manual_post_install.py (run): apply last part of Nicolas
1056 Pernetty's patch (I'd accidentally applied it in a different
1063 Pernetty's patch (I'd accidentally applied it in a different
1057 directory and this particular file didn't get patched).
1064 directory and this particular file didn't get patched).
1058
1065
1059 2007-04-05 Fernando Perez <Fernando.Perez@colorado.edu>
1066 2007-04-05 Fernando Perez <Fernando.Perez@colorado.edu>
1060
1067
1061 * IPython/Shell.py (MAIN_THREAD_ID): get rid of my stupid hack to
1068 * IPython/Shell.py (MAIN_THREAD_ID): get rid of my stupid hack to
1062 find the main thread id and use the proper API call. Thanks to
1069 find the main thread id and use the proper API call. Thanks to
1063 Stefan for the fix.
1070 Stefan for the fix.
1064
1071
1065 * test/test_prefilter.py (esc_handler_tests): udpate one of Dan's
1072 * test/test_prefilter.py (esc_handler_tests): udpate one of Dan's
1066 unit tests to reflect fixed ticket #52, and add more tests sent by
1073 unit tests to reflect fixed ticket #52, and add more tests sent by
1067 him.
1074 him.
1068
1075
1069 * IPython/iplib.py (raw_input): restore the readline completer
1076 * IPython/iplib.py (raw_input): restore the readline completer
1070 state on every input, in case third-party code messed it up.
1077 state on every input, in case third-party code messed it up.
1071 (_prefilter): revert recent addition of early-escape checks which
1078 (_prefilter): revert recent addition of early-escape checks which
1072 prevent many valid alias calls from working.
1079 prevent many valid alias calls from working.
1073
1080
1074 * IPython/Shell.py (MTInteractiveShell.runcode): add a tracking
1081 * IPython/Shell.py (MTInteractiveShell.runcode): add a tracking
1075 flag for sigint handler so we don't run a full signal() call on
1082 flag for sigint handler so we don't run a full signal() call on
1076 each runcode access.
1083 each runcode access.
1077
1084
1078 * IPython/Magic.py (magic_whos): small improvement to diagnostic
1085 * IPython/Magic.py (magic_whos): small improvement to diagnostic
1079 message.
1086 message.
1080
1087
1081 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
1088 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
1082
1089
1083 * IPython/Shell.py (sigint_handler): I *THINK* I finally got
1090 * IPython/Shell.py (sigint_handler): I *THINK* I finally got
1084 asynchronous exceptions working, i.e., Ctrl-C can actually
1091 asynchronous exceptions working, i.e., Ctrl-C can actually
1085 interrupt long-running code in the multithreaded shells.
1092 interrupt long-running code in the multithreaded shells.
1086
1093
1087 This is using Tomer Filiba's great ctypes-based trick:
1094 This is using Tomer Filiba's great ctypes-based trick:
1088 http://sebulba.wikispaces.com/recipe+thread2. I'd already tried
1095 http://sebulba.wikispaces.com/recipe+thread2. I'd already tried
1089 this in the past, but hadn't been able to make it work before. So
1096 this in the past, but hadn't been able to make it work before. So
1090 far it looks like it's actually running, but this needs more
1097 far it looks like it's actually running, but this needs more
1091 testing. If it really works, I'll be *very* happy, and we'll owe
1098 testing. If it really works, I'll be *very* happy, and we'll owe
1092 a huge thank you to Tomer. My current implementation is ugly,
1099 a huge thank you to Tomer. My current implementation is ugly,
1093 hackish and uses nasty globals, but I don't want to try and clean
1100 hackish and uses nasty globals, but I don't want to try and clean
1094 anything up until we know if it actually works.
1101 anything up until we know if it actually works.
1095
1102
1096 NOTE: this feature needs ctypes to work. ctypes is included in
1103 NOTE: this feature needs ctypes to work. ctypes is included in
1097 Python2.5, but 2.4 users will need to manually install it. This
1104 Python2.5, but 2.4 users will need to manually install it. This
1098 feature makes multi-threaded shells so much more usable that it's
1105 feature makes multi-threaded shells so much more usable that it's
1099 a minor price to pay (ctypes is very easy to install, already a
1106 a minor price to pay (ctypes is very easy to install, already a
1100 requirement for win32 and available in major linux distros).
1107 requirement for win32 and available in major linux distros).
1101
1108
1102 2007-04-04 Ville Vainio <vivainio@gmail.com>
1109 2007-04-04 Ville Vainio <vivainio@gmail.com>
1103
1110
1104 * Extensions/ipy_completers.py, ipy_stock_completers.py:
1111 * Extensions/ipy_completers.py, ipy_stock_completers.py:
1105 Moved implementations of 'bundled' completers to ipy_completers.py,
1112 Moved implementations of 'bundled' completers to ipy_completers.py,
1106 they are only enabled in ipy_stock_completers.py.
1113 they are only enabled in ipy_stock_completers.py.
1107
1114
1108 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
1115 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
1109
1116
1110 * IPython/PyColorize.py (Parser.format2): Fix identation of
1117 * IPython/PyColorize.py (Parser.format2): Fix identation of
1111 colorzied output and return early if color scheme is NoColor, to
1118 colorzied output and return early if color scheme is NoColor, to
1112 avoid unnecessary and expensive tokenization. Closes #131.
1119 avoid unnecessary and expensive tokenization. Closes #131.
1113
1120
1114 2007-04-03 Fernando Perez <Fernando.Perez@colorado.edu>
1121 2007-04-03 Fernando Perez <Fernando.Perez@colorado.edu>
1115
1122
1116 * IPython/Debugger.py: disable the use of pydb version 1.17. It
1123 * IPython/Debugger.py: disable the use of pydb version 1.17. It
1117 has a critical bug (a missing import that makes post-mortem not
1124 has a critical bug (a missing import that makes post-mortem not
1118 work at all). Unfortunately as of this time, this is the version
1125 work at all). Unfortunately as of this time, this is the version
1119 shipped with Ubuntu Edgy, so quite a few people have this one. I
1126 shipped with Ubuntu Edgy, so quite a few people have this one. I
1120 hope Edgy will update to a more recent package.
1127 hope Edgy will update to a more recent package.
1121
1128
1122 2007-04-02 Fernando Perez <Fernando.Perez@colorado.edu>
1129 2007-04-02 Fernando Perez <Fernando.Perez@colorado.edu>
1123
1130
1124 * IPython/iplib.py (_prefilter): close #52, second part of a patch
1131 * IPython/iplib.py (_prefilter): close #52, second part of a patch
1125 set by Stefan (only the first part had been applied before).
1132 set by Stefan (only the first part had been applied before).
1126
1133
1127 * IPython/Extensions/ipy_stock_completers.py (module_completer):
1134 * IPython/Extensions/ipy_stock_completers.py (module_completer):
1128 remove usage of the dangerous pkgutil.walk_packages(). See
1135 remove usage of the dangerous pkgutil.walk_packages(). See
1129 details in comments left in the code.
1136 details in comments left in the code.
1130
1137
1131 * IPython/Magic.py (magic_whos): add support for numpy arrays
1138 * IPython/Magic.py (magic_whos): add support for numpy arrays
1132 similar to what we had for Numeric.
1139 similar to what we had for Numeric.
1133
1140
1134 * IPython/completer.py (IPCompleter.complete): extend the
1141 * IPython/completer.py (IPCompleter.complete): extend the
1135 complete() call API to support completions by other mechanisms
1142 complete() call API to support completions by other mechanisms
1136 than readline. Closes #109.
1143 than readline. Closes #109.
1137
1144
1138 * IPython/iplib.py (safe_execfile): add a safeguard under Win32 to
1145 * IPython/iplib.py (safe_execfile): add a safeguard under Win32 to
1139 protect against a bug in Python's execfile(). Closes #123.
1146 protect against a bug in Python's execfile(). Closes #123.
1140
1147
1141 2007-04-01 Fernando Perez <Fernando.Perez@colorado.edu>
1148 2007-04-01 Fernando Perez <Fernando.Perez@colorado.edu>
1142
1149
1143 * IPython/iplib.py (split_user_input): ensure that when splitting
1150 * IPython/iplib.py (split_user_input): ensure that when splitting
1144 user input, the part that can be treated as a python name is pure
1151 user input, the part that can be treated as a python name is pure
1145 ascii (Python identifiers MUST be pure ascii). Part of the
1152 ascii (Python identifiers MUST be pure ascii). Part of the
1146 ongoing Unicode support work.
1153 ongoing Unicode support work.
1147
1154
1148 * IPython/Prompts.py (prompt_specials_color): Add \N for the
1155 * IPython/Prompts.py (prompt_specials_color): Add \N for the
1149 actual prompt number, without any coloring. This allows users to
1156 actual prompt number, without any coloring. This allows users to
1150 produce numbered prompts with their own colors. Added after a
1157 produce numbered prompts with their own colors. Added after a
1151 report/request by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
1158 report/request by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
1152
1159
1153 2007-03-31 Walter Doerwald <walter@livinglogic.de>
1160 2007-03-31 Walter Doerwald <walter@livinglogic.de>
1154
1161
1155 * IPython/Extensions/igrid.py: Map the return key
1162 * IPython/Extensions/igrid.py: Map the return key
1156 to enter() and shift-return to enterattr().
1163 to enter() and shift-return to enterattr().
1157
1164
1158 2007-03-30 Fernando Perez <Fernando.Perez@colorado.edu>
1165 2007-03-30 Fernando Perez <Fernando.Perez@colorado.edu>
1159
1166
1160 * IPython/Magic.py (magic_psearch): add unicode support by
1167 * IPython/Magic.py (magic_psearch): add unicode support by
1161 encoding to ascii the input, since this routine also only deals
1168 encoding to ascii the input, since this routine also only deals
1162 with valid Python names. Fixes a bug reported by Stefan.
1169 with valid Python names. Fixes a bug reported by Stefan.
1163
1170
1164 2007-03-29 Fernando Perez <Fernando.Perez@colorado.edu>
1171 2007-03-29 Fernando Perez <Fernando.Perez@colorado.edu>
1165
1172
1166 * IPython/Magic.py (_inspect): convert unicode input into ascii
1173 * IPython/Magic.py (_inspect): convert unicode input into ascii
1167 before trying to evaluate it as a Python identifier. This fixes a
1174 before trying to evaluate it as a Python identifier. This fixes a
1168 problem that the new unicode support had introduced when analyzing
1175 problem that the new unicode support had introduced when analyzing
1169 long definition lines for functions.
1176 long definition lines for functions.
1170
1177
1171 2007-03-24 Walter Doerwald <walter@livinglogic.de>
1178 2007-03-24 Walter Doerwald <walter@livinglogic.de>
1172
1179
1173 * IPython/Extensions/igrid.py: Fix picking. Using
1180 * IPython/Extensions/igrid.py: Fix picking. Using
1174 igrid with wxPython 2.6 and -wthread should work now.
1181 igrid with wxPython 2.6 and -wthread should work now.
1175 igrid.display() simply tries to create a frame without
1182 igrid.display() simply tries to create a frame without
1176 an application. Only if this fails an application is created.
1183 an application. Only if this fails an application is created.
1177
1184
1178 2007-03-23 Walter Doerwald <walter@livinglogic.de>
1185 2007-03-23 Walter Doerwald <walter@livinglogic.de>
1179
1186
1180 * IPython/Extensions/path.py: Updated to version 2.2.
1187 * IPython/Extensions/path.py: Updated to version 2.2.
1181
1188
1182 2007-03-23 Ville Vainio <vivainio@gmail.com>
1189 2007-03-23 Ville Vainio <vivainio@gmail.com>
1183
1190
1184 * iplib.py: recursive alias expansion now works better, so that
1191 * iplib.py: recursive alias expansion now works better, so that
1185 cases like 'top' -> 'd:/cygwin/top' -> 'ls :/cygwin/top'
1192 cases like 'top' -> 'd:/cygwin/top' -> 'ls :/cygwin/top'
1186 doesn't trip up the process, if 'd' has been aliased to 'ls'.
1193 doesn't trip up the process, if 'd' has been aliased to 'ls'.
1187
1194
1188 * Extensions/ipy_gnuglobal.py added, provides %global magic
1195 * Extensions/ipy_gnuglobal.py added, provides %global magic
1189 for users of http://www.gnu.org/software/global
1196 for users of http://www.gnu.org/software/global
1190
1197
1191 * iplib.py: '!command /?' now doesn't invoke IPython's help system.
1198 * iplib.py: '!command /?' now doesn't invoke IPython's help system.
1192 Closes #52. Patch by Stefan van der Walt.
1199 Closes #52. Patch by Stefan van der Walt.
1193
1200
1194 2007-03-23 Fernando Perez <Fernando.Perez@colorado.edu>
1201 2007-03-23 Fernando Perez <Fernando.Perez@colorado.edu>
1195
1202
1196 * IPython/FakeModule.py (FakeModule.__init__): Small fix to
1203 * IPython/FakeModule.py (FakeModule.__init__): Small fix to
1197 respect the __file__ attribute when using %run. Thanks to a bug
1204 respect the __file__ attribute when using %run. Thanks to a bug
1198 report by Sebastian Rooks <sebastian.rooks-AT-free.fr>.
1205 report by Sebastian Rooks <sebastian.rooks-AT-free.fr>.
1199
1206
1200 2007-03-22 Fernando Perez <Fernando.Perez@colorado.edu>
1207 2007-03-22 Fernando Perez <Fernando.Perez@colorado.edu>
1201
1208
1202 * IPython/iplib.py (raw_input): Fix mishandling of unicode at
1209 * IPython/iplib.py (raw_input): Fix mishandling of unicode at
1203 input. Patch sent by Stefan.
1210 input. Patch sent by Stefan.
1204
1211
1205 2007-03-20 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
1212 2007-03-20 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
1206 * IPython/Extensions/ipy_stock_completer.py
1213 * IPython/Extensions/ipy_stock_completer.py
1207 shlex_split, fix bug in shlex_split. len function
1214 shlex_split, fix bug in shlex_split. len function
1208 call was missing an if statement. Caused shlex_split to
1215 call was missing an if statement. Caused shlex_split to
1209 sometimes return "" as last element.
1216 sometimes return "" as last element.
1210
1217
1211 2007-03-18 Fernando Perez <Fernando.Perez@colorado.edu>
1218 2007-03-18 Fernando Perez <Fernando.Perez@colorado.edu>
1212
1219
1213 * IPython/completer.py
1220 * IPython/completer.py
1214 (IPCompleter.file_matches.single_dir_expand): fix a problem
1221 (IPCompleter.file_matches.single_dir_expand): fix a problem
1215 reported by Stefan, where directories containign a single subdir
1222 reported by Stefan, where directories containign a single subdir
1216 would be completed too early.
1223 would be completed too early.
1217
1224
1218 * IPython/Shell.py (_load_pylab): Make the execution of 'from
1225 * IPython/Shell.py (_load_pylab): Make the execution of 'from
1219 pylab import *' when -pylab is given be optional. A new flag,
1226 pylab import *' when -pylab is given be optional. A new flag,
1220 pylab_import_all controls this behavior, the default is True for
1227 pylab_import_all controls this behavior, the default is True for
1221 backwards compatibility.
1228 backwards compatibility.
1222
1229
1223 * IPython/ultraTB.py (_formatTracebackLines): Added (slightly
1230 * IPython/ultraTB.py (_formatTracebackLines): Added (slightly
1224 modified) R. Bernstein's patch for fully syntax highlighted
1231 modified) R. Bernstein's patch for fully syntax highlighted
1225 tracebacks. The functionality is also available under ultraTB for
1232 tracebacks. The functionality is also available under ultraTB for
1226 non-ipython users (someone using ultraTB but outside an ipython
1233 non-ipython users (someone using ultraTB but outside an ipython
1227 session). They can select the color scheme by setting the
1234 session). They can select the color scheme by setting the
1228 module-level global DEFAULT_SCHEME. The highlight functionality
1235 module-level global DEFAULT_SCHEME. The highlight functionality
1229 also works when debugging.
1236 also works when debugging.
1230
1237
1231 * IPython/genutils.py (IOStream.close): small patch by
1238 * IPython/genutils.py (IOStream.close): small patch by
1232 R. Bernstein for improved pydb support.
1239 R. Bernstein for improved pydb support.
1233
1240
1234 * IPython/Debugger.py (Pdb.format_stack_entry): Added patch by
1241 * IPython/Debugger.py (Pdb.format_stack_entry): Added patch by
1235 DaveS <davls@telus.net> to improve support of debugging under
1242 DaveS <davls@telus.net> to improve support of debugging under
1236 NTEmacs, including improved pydb behavior.
1243 NTEmacs, including improved pydb behavior.
1237
1244
1238 * IPython/Magic.py (magic_prun): Fix saving of profile info for
1245 * IPython/Magic.py (magic_prun): Fix saving of profile info for
1239 Python 2.5, where the stats object API changed a little. Thanks
1246 Python 2.5, where the stats object API changed a little. Thanks
1240 to a bug report by Paul Smith <paul.smith-AT-catugmt.com>.
1247 to a bug report by Paul Smith <paul.smith-AT-catugmt.com>.
1241
1248
1242 * IPython/ColorANSI.py (InputTermColors.Normal): applied Nicolas
1249 * IPython/ColorANSI.py (InputTermColors.Normal): applied Nicolas
1243 Pernetty's patch to improve support for (X)Emacs under Win32.
1250 Pernetty's patch to improve support for (X)Emacs under Win32.
1244
1251
1245 2007-03-17 Fernando Perez <Fernando.Perez@colorado.edu>
1252 2007-03-17 Fernando Perez <Fernando.Perez@colorado.edu>
1246
1253
1247 * IPython/Shell.py (hijack_wx): ipmort WX with current semantics
1254 * IPython/Shell.py (hijack_wx): ipmort WX with current semantics
1248 to quiet a deprecation warning that fires with Wx 2.8. Thanks to
1255 to quiet a deprecation warning that fires with Wx 2.8. Thanks to
1249 a report by Nik Tautenhahn.
1256 a report by Nik Tautenhahn.
1250
1257
1251 2007-03-16 Walter Doerwald <walter@livinglogic.de>
1258 2007-03-16 Walter Doerwald <walter@livinglogic.de>
1252
1259
1253 * setup.py: Add the igrid help files to the list of data files
1260 * setup.py: Add the igrid help files to the list of data files
1254 to be installed alongside igrid.
1261 to be installed alongside igrid.
1255 * IPython/Extensions/igrid.py: (Patch by Nik Tautenhahn)
1262 * IPython/Extensions/igrid.py: (Patch by Nik Tautenhahn)
1256 Show the input object of the igrid browser as the window tile.
1263 Show the input object of the igrid browser as the window tile.
1257 Show the object the cursor is on in the statusbar.
1264 Show the object the cursor is on in the statusbar.
1258
1265
1259 2007-03-15 Ville Vainio <vivainio@gmail.com>
1266 2007-03-15 Ville Vainio <vivainio@gmail.com>
1260
1267
1261 * Extensions/ipy_stock_completers.py: Fixed exception
1268 * Extensions/ipy_stock_completers.py: Fixed exception
1262 on mismatching quotes in %run completer. Patch by
1269 on mismatching quotes in %run completer. Patch by
1263 Jorgen Stenarson. Closes #127.
1270 Jorgen Stenarson. Closes #127.
1264
1271
1265 2007-03-14 Ville Vainio <vivainio@gmail.com>
1272 2007-03-14 Ville Vainio <vivainio@gmail.com>
1266
1273
1267 * Extensions/ext_rehashdir.py: Do not do auto_alias
1274 * Extensions/ext_rehashdir.py: Do not do auto_alias
1268 in %rehashdir, it clobbers %store'd aliases.
1275 in %rehashdir, it clobbers %store'd aliases.
1269
1276
1270 * UserConfig/ipy_profile_sh.py: envpersist.py extension
1277 * UserConfig/ipy_profile_sh.py: envpersist.py extension
1271 (beefed up %env) imported for sh profile.
1278 (beefed up %env) imported for sh profile.
1272
1279
1273 2007-03-10 Walter Doerwald <walter@livinglogic.de>
1280 2007-03-10 Walter Doerwald <walter@livinglogic.de>
1274
1281
1275 * IPython/Extensions/ipipe.py: Prefer ibrowse over igrid
1282 * IPython/Extensions/ipipe.py: Prefer ibrowse over igrid
1276 as the default browser.
1283 as the default browser.
1277 * IPython/Extensions/igrid.py: Make a few igrid attributes private.
1284 * IPython/Extensions/igrid.py: Make a few igrid attributes private.
1278 As igrid displays all attributes it ever encounters, fetch() (which has
1285 As igrid displays all attributes it ever encounters, fetch() (which has
1279 been renamed to _fetch()) doesn't have to recalculate the display attributes
1286 been renamed to _fetch()) doesn't have to recalculate the display attributes
1280 every time a new item is fetched. This should speed up scrolling.
1287 every time a new item is fetched. This should speed up scrolling.
1281
1288
1282 2007-03-10 Fernando Perez <Fernando.Perez@colorado.edu>
1289 2007-03-10 Fernando Perez <Fernando.Perez@colorado.edu>
1283
1290
1284 * IPython/iplib.py (InteractiveShell.__init__): fix for Alex
1291 * IPython/iplib.py (InteractiveShell.__init__): fix for Alex
1285 Schmolck's recently reported tab-completion bug (my previous one
1292 Schmolck's recently reported tab-completion bug (my previous one
1286 had a problem). Patch by Dan Milstein <danmil-AT-comcast.net>.
1293 had a problem). Patch by Dan Milstein <danmil-AT-comcast.net>.
1287
1294
1288 2007-03-09 Walter Doerwald <walter@livinglogic.de>
1295 2007-03-09 Walter Doerwald <walter@livinglogic.de>
1289
1296
1290 * IPython/Extensions/igrid.py: Patch by Nik Tautenhahn:
1297 * IPython/Extensions/igrid.py: Patch by Nik Tautenhahn:
1291 Close help window if exiting igrid.
1298 Close help window if exiting igrid.
1292
1299
1293 2007-03-02 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
1300 2007-03-02 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
1294
1301
1295 * IPython/Extensions/ipy_defaults.py: Check if readline is available
1302 * IPython/Extensions/ipy_defaults.py: Check if readline is available
1296 before calling functions from readline.
1303 before calling functions from readline.
1297
1304
1298 2007-03-02 Walter Doerwald <walter@livinglogic.de>
1305 2007-03-02 Walter Doerwald <walter@livinglogic.de>
1299
1306
1300 * IPython/Extensions/igrid.py: Add Nik Tautenhahns igrid extension.
1307 * IPython/Extensions/igrid.py: Add Nik Tautenhahns igrid extension.
1301 igrid is a wxPython-based display object for ipipe. If your system has
1308 igrid is a wxPython-based display object for ipipe. If your system has
1302 wx installed igrid will be the default display. Without wx ipipe falls
1309 wx installed igrid will be the default display. Without wx ipipe falls
1303 back to ibrowse (which needs curses). If no curses is installed ipipe
1310 back to ibrowse (which needs curses). If no curses is installed ipipe
1304 falls back to idump.
1311 falls back to idump.
1305
1312
1306 2007-03-01 Fernando Perez <Fernando.Perez@colorado.edu>
1313 2007-03-01 Fernando Perez <Fernando.Perez@colorado.edu>
1307
1314
1308 * IPython/iplib.py (split_user_inputBROKEN): temporarily disable
1315 * IPython/iplib.py (split_user_inputBROKEN): temporarily disable
1309 my changes from yesterday, they introduced bugs. Will reactivate
1316 my changes from yesterday, they introduced bugs. Will reactivate
1310 once I get a correct solution, which will be much easier thanks to
1317 once I get a correct solution, which will be much easier thanks to
1311 Dan Milstein's new prefilter test suite.
1318 Dan Milstein's new prefilter test suite.
1312
1319
1313 2007-02-28 Fernando Perez <Fernando.Perez@colorado.edu>
1320 2007-02-28 Fernando Perez <Fernando.Perez@colorado.edu>
1314
1321
1315 * IPython/iplib.py (split_user_input): fix input splitting so we
1322 * IPython/iplib.py (split_user_input): fix input splitting so we
1316 don't attempt attribute accesses on things that can't possibly be
1323 don't attempt attribute accesses on things that can't possibly be
1317 valid Python attributes. After a bug report by Alex Schmolck.
1324 valid Python attributes. After a bug report by Alex Schmolck.
1318 (InteractiveShell.__init__): brown-paper bag fix; regexp broke
1325 (InteractiveShell.__init__): brown-paper bag fix; regexp broke
1319 %magic with explicit % prefix.
1326 %magic with explicit % prefix.
1320
1327
1321 2007-02-27 Fernando Perez <Fernando.Perez@colorado.edu>
1328 2007-02-27 Fernando Perez <Fernando.Perez@colorado.edu>
1322
1329
1323 * IPython/Shell.py (IPShellGTK.mainloop): update threads calls to
1330 * IPython/Shell.py (IPShellGTK.mainloop): update threads calls to
1324 avoid a DeprecationWarning from GTK.
1331 avoid a DeprecationWarning from GTK.
1325
1332
1326 2007-02-22 Fernando Perez <Fernando.Perez@colorado.edu>
1333 2007-02-22 Fernando Perez <Fernando.Perez@colorado.edu>
1327
1334
1328 * IPython/genutils.py (clock): I modified clock() to return total
1335 * IPython/genutils.py (clock): I modified clock() to return total
1329 time, user+system. This is a more commonly needed metric. I also
1336 time, user+system. This is a more commonly needed metric. I also
1330 introduced the new clocku/clocks to get only user/system time if
1337 introduced the new clocku/clocks to get only user/system time if
1331 one wants those instead.
1338 one wants those instead.
1332
1339
1333 ***WARNING: API CHANGE*** clock() used to return only user time,
1340 ***WARNING: API CHANGE*** clock() used to return only user time,
1334 so if you want exactly the same results as before, use clocku
1341 so if you want exactly the same results as before, use clocku
1335 instead.
1342 instead.
1336
1343
1337 2007-02-22 Ville Vainio <vivainio@gmail.com>
1344 2007-02-22 Ville Vainio <vivainio@gmail.com>
1338
1345
1339 * IPython/Extensions/ipy_p4.py: Extension for improved
1346 * IPython/Extensions/ipy_p4.py: Extension for improved
1340 p4 (perforce version control system) experience.
1347 p4 (perforce version control system) experience.
1341 Adds %p4 magic with p4 command completion and
1348 Adds %p4 magic with p4 command completion and
1342 automatic -G argument (marshall output as python dict)
1349 automatic -G argument (marshall output as python dict)
1343
1350
1344 2007-02-19 Fernando Perez <Fernando.Perez@colorado.edu>
1351 2007-02-19 Fernando Perez <Fernando.Perez@colorado.edu>
1345
1352
1346 * IPython/demo.py (Demo.re_stop): make dashes optional in demo
1353 * IPython/demo.py (Demo.re_stop): make dashes optional in demo
1347 stop marks.
1354 stop marks.
1348 (ClearingMixin): a simple mixin to easily make a Demo class clear
1355 (ClearingMixin): a simple mixin to easily make a Demo class clear
1349 the screen in between blocks and have empty marquees. The
1356 the screen in between blocks and have empty marquees. The
1350 ClearDemo and ClearIPDemo classes that use it are included.
1357 ClearDemo and ClearIPDemo classes that use it are included.
1351
1358
1352 2007-02-18 Fernando Perez <Fernando.Perez@colorado.edu>
1359 2007-02-18 Fernando Perez <Fernando.Perez@colorado.edu>
1353
1360
1354 * IPython/irunner.py (pexpect_monkeypatch): patch pexpect to
1361 * IPython/irunner.py (pexpect_monkeypatch): patch pexpect to
1355 protect against exceptions at Python shutdown time. Patch
1362 protect against exceptions at Python shutdown time. Patch
1356 sumbmitted to upstream.
1363 sumbmitted to upstream.
1357
1364
1358 2007-02-14 Walter Doerwald <walter@livinglogic.de>
1365 2007-02-14 Walter Doerwald <walter@livinglogic.de>
1359
1366
1360 * IPython/Extensions/ibrowse.py: If entering the first object level
1367 * IPython/Extensions/ibrowse.py: If entering the first object level
1361 (i.e. the object for which the browser has been started) fails,
1368 (i.e. the object for which the browser has been started) fails,
1362 now the error is raised directly (aborting the browser) instead of
1369 now the error is raised directly (aborting the browser) instead of
1363 running into an empty levels list later.
1370 running into an empty levels list later.
1364
1371
1365 2007-02-03 Walter Doerwald <walter@livinglogic.de>
1372 2007-02-03 Walter Doerwald <walter@livinglogic.de>
1366
1373
1367 * IPython/Extensions/ipipe.py: Add an xrepr implementation
1374 * IPython/Extensions/ipipe.py: Add an xrepr implementation
1368 for the noitem object.
1375 for the noitem object.
1369
1376
1370 2007-01-31 Fernando Perez <Fernando.Perez@colorado.edu>
1377 2007-01-31 Fernando Perez <Fernando.Perez@colorado.edu>
1371
1378
1372 * IPython/completer.py (Completer.attr_matches): Fix small
1379 * IPython/completer.py (Completer.attr_matches): Fix small
1373 tab-completion bug with Enthought Traits objects with units.
1380 tab-completion bug with Enthought Traits objects with units.
1374 Thanks to a bug report by Tom Denniston
1381 Thanks to a bug report by Tom Denniston
1375 <tom.denniston-AT-alum.dartmouth.org>.
1382 <tom.denniston-AT-alum.dartmouth.org>.
1376
1383
1377 2007-01-27 Fernando Perez <Fernando.Perez@colorado.edu>
1384 2007-01-27 Fernando Perez <Fernando.Perez@colorado.edu>
1378
1385
1379 * IPython/Extensions/ipy_stock_completers.py (runlistpy): fix a
1386 * IPython/Extensions/ipy_stock_completers.py (runlistpy): fix a
1380 bug where only .ipy or .py would be completed. Once the first
1387 bug where only .ipy or .py would be completed. Once the first
1381 argument to %run has been given, all completions are valid because
1388 argument to %run has been given, all completions are valid because
1382 they are the arguments to the script, which may well be non-python
1389 they are the arguments to the script, which may well be non-python
1383 filenames.
1390 filenames.
1384
1391
1385 * IPython/irunner.py (InteractiveRunner.run_source): major updates
1392 * IPython/irunner.py (InteractiveRunner.run_source): major updates
1386 to irunner to allow it to correctly support real doctesting of
1393 to irunner to allow it to correctly support real doctesting of
1387 out-of-process ipython code.
1394 out-of-process ipython code.
1388
1395
1389 * IPython/Magic.py (magic_cd): Make the setting of the terminal
1396 * IPython/Magic.py (magic_cd): Make the setting of the terminal
1390 title an option (-noterm_title) because it completely breaks
1397 title an option (-noterm_title) because it completely breaks
1391 doctesting.
1398 doctesting.
1392
1399
1393 * IPython/demo.py: fix IPythonDemo class that was not actually working.
1400 * IPython/demo.py: fix IPythonDemo class that was not actually working.
1394
1401
1395 2007-01-24 Fernando Perez <Fernando.Perez@colorado.edu>
1402 2007-01-24 Fernando Perez <Fernando.Perez@colorado.edu>
1396
1403
1397 * IPython/irunner.py (main): fix small bug where extensions were
1404 * IPython/irunner.py (main): fix small bug where extensions were
1398 not being correctly recognized.
1405 not being correctly recognized.
1399
1406
1400 2007-01-23 Walter Doerwald <walter@livinglogic.de>
1407 2007-01-23 Walter Doerwald <walter@livinglogic.de>
1401
1408
1402 * IPython/Extensions/ipipe.py (xiter): Make sure that iterating
1409 * IPython/Extensions/ipipe.py (xiter): Make sure that iterating
1403 a string containing a single line yields the string itself as the
1410 a string containing a single line yields the string itself as the
1404 only item.
1411 only item.
1405
1412
1406 * IPython/Extensions/ibrowse.py (ibrowse): Avoid entering an
1413 * IPython/Extensions/ibrowse.py (ibrowse): Avoid entering an
1407 object if it's the same as the one on the last level (This avoids
1414 object if it's the same as the one on the last level (This avoids
1408 infinite recursion for one line strings).
1415 infinite recursion for one line strings).
1409
1416
1410 2007-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
1417 2007-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
1411
1418
1412 * IPython/ultraTB.py (AutoFormattedTB.__call__): properly flush
1419 * IPython/ultraTB.py (AutoFormattedTB.__call__): properly flush
1413 all output streams before printing tracebacks. This ensures that
1420 all output streams before printing tracebacks. This ensures that
1414 user output doesn't end up interleaved with traceback output.
1421 user output doesn't end up interleaved with traceback output.
1415
1422
1416 2007-01-10 Ville Vainio <vivainio@gmail.com>
1423 2007-01-10 Ville Vainio <vivainio@gmail.com>
1417
1424
1418 * Extensions/envpersist.py: Turbocharged %env that remembers
1425 * Extensions/envpersist.py: Turbocharged %env that remembers
1419 env vars across sessions; e.g. "%env PATH+=;/opt/scripts" or
1426 env vars across sessions; e.g. "%env PATH+=;/opt/scripts" or
1420 "%env VISUAL=jed".
1427 "%env VISUAL=jed".
1421
1428
1422 2007-01-05 Fernando Perez <Fernando.Perez@colorado.edu>
1429 2007-01-05 Fernando Perez <Fernando.Perez@colorado.edu>
1423
1430
1424 * IPython/iplib.py (showtraceback): ensure that we correctly call
1431 * IPython/iplib.py (showtraceback): ensure that we correctly call
1425 custom handlers in all cases (some with pdb were slipping through,
1432 custom handlers in all cases (some with pdb were slipping through,
1426 but I'm not exactly sure why).
1433 but I'm not exactly sure why).
1427
1434
1428 * IPython/Debugger.py (Tracer.__init__): added new class to
1435 * IPython/Debugger.py (Tracer.__init__): added new class to
1429 support set_trace-like usage of IPython's enhanced debugger.
1436 support set_trace-like usage of IPython's enhanced debugger.
1430
1437
1431 2006-12-24 Ville Vainio <vivainio@gmail.com>
1438 2006-12-24 Ville Vainio <vivainio@gmail.com>
1432
1439
1433 * ipmaker.py: more informative message when ipy_user_conf
1440 * ipmaker.py: more informative message when ipy_user_conf
1434 import fails (suggest running %upgrade).
1441 import fails (suggest running %upgrade).
1435
1442
1436 * tools/run_ipy_in_profiler.py: Utility to see where
1443 * tools/run_ipy_in_profiler.py: Utility to see where
1437 the time during IPython startup is spent.
1444 the time during IPython startup is spent.
1438
1445
1439 2006-12-20 Ville Vainio <vivainio@gmail.com>
1446 2006-12-20 Ville Vainio <vivainio@gmail.com>
1440
1447
1441 * 0.7.3 is out - merge all from 0.7.3 branch to trunk
1448 * 0.7.3 is out - merge all from 0.7.3 branch to trunk
1442
1449
1443 * ipapi.py: Add new ipapi method, expand_alias.
1450 * ipapi.py: Add new ipapi method, expand_alias.
1444
1451
1445 * Release.py: Bump up version to 0.7.4.svn
1452 * Release.py: Bump up version to 0.7.4.svn
1446
1453
1447 2006-12-17 Ville Vainio <vivainio@gmail.com>
1454 2006-12-17 Ville Vainio <vivainio@gmail.com>
1448
1455
1449 * Extensions/jobctrl.py: Fixed &cmd arg arg...
1456 * Extensions/jobctrl.py: Fixed &cmd arg arg...
1450 to work properly on posix too
1457 to work properly on posix too
1451
1458
1452 * Release.py: Update revnum (version is still just 0.7.3).
1459 * Release.py: Update revnum (version is still just 0.7.3).
1453
1460
1454 2006-12-15 Ville Vainio <vivainio@gmail.com>
1461 2006-12-15 Ville Vainio <vivainio@gmail.com>
1455
1462
1456 * scripts/ipython_win_post_install: create ipython.py in
1463 * scripts/ipython_win_post_install: create ipython.py in
1457 prefix + "/scripts".
1464 prefix + "/scripts".
1458
1465
1459 * Release.py: Update version to 0.7.3.
1466 * Release.py: Update version to 0.7.3.
1460
1467
1461 2006-12-14 Ville Vainio <vivainio@gmail.com>
1468 2006-12-14 Ville Vainio <vivainio@gmail.com>
1462
1469
1463 * scripts/ipython_win_post_install: Overwrite old shortcuts
1470 * scripts/ipython_win_post_install: Overwrite old shortcuts
1464 if they already exist
1471 if they already exist
1465
1472
1466 * Release.py: release 0.7.3rc2
1473 * Release.py: release 0.7.3rc2
1467
1474
1468 2006-12-13 Ville Vainio <vivainio@gmail.com>
1475 2006-12-13 Ville Vainio <vivainio@gmail.com>
1469
1476
1470 * Branch and update Release.py for 0.7.3rc1
1477 * Branch and update Release.py for 0.7.3rc1
1471
1478
1472 2006-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
1479 2006-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
1473
1480
1474 * IPython/Shell.py (IPShellWX): update for current WX naming
1481 * IPython/Shell.py (IPShellWX): update for current WX naming
1475 conventions, to avoid a deprecation warning with current WX
1482 conventions, to avoid a deprecation warning with current WX
1476 versions. Thanks to a report by Danny Shevitz.
1483 versions. Thanks to a report by Danny Shevitz.
1477
1484
1478 2006-12-12 Ville Vainio <vivainio@gmail.com>
1485 2006-12-12 Ville Vainio <vivainio@gmail.com>
1479
1486
1480 * ipmaker.py: apply david cournapeau's patch to make
1487 * ipmaker.py: apply david cournapeau's patch to make
1481 import_some work properly even when ipythonrc does
1488 import_some work properly even when ipythonrc does
1482 import_some on empty list (it was an old bug!).
1489 import_some on empty list (it was an old bug!).
1483
1490
1484 * UserConfig/ipy_user_conf.py, UserConfig/ipythonrc:
1491 * UserConfig/ipy_user_conf.py, UserConfig/ipythonrc:
1485 Add deprecation note to ipythonrc and a url to wiki
1492 Add deprecation note to ipythonrc and a url to wiki
1486 in ipy_user_conf.py
1493 in ipy_user_conf.py
1487
1494
1488
1495
1489 * Magic.py (%run): %run myscript.ipy now runs myscript.ipy
1496 * Magic.py (%run): %run myscript.ipy now runs myscript.ipy
1490 as if it was typed on IPython command prompt, i.e.
1497 as if it was typed on IPython command prompt, i.e.
1491 as IPython script.
1498 as IPython script.
1492
1499
1493 * example-magic.py, magic_grepl.py: remove outdated examples
1500 * example-magic.py, magic_grepl.py: remove outdated examples
1494
1501
1495 2006-12-11 Fernando Perez <Fernando.Perez@colorado.edu>
1502 2006-12-11 Fernando Perez <Fernando.Perez@colorado.edu>
1496
1503
1497 * IPython/iplib.py (debugger): prevent a nasty traceback if %debug
1504 * IPython/iplib.py (debugger): prevent a nasty traceback if %debug
1498 is called before any exception has occurred.
1505 is called before any exception has occurred.
1499
1506
1500 2006-12-08 Ville Vainio <vivainio@gmail.com>
1507 2006-12-08 Ville Vainio <vivainio@gmail.com>
1501
1508
1502 * Extensions/ipy_stock_completers.py: fix cd completer
1509 * Extensions/ipy_stock_completers.py: fix cd completer
1503 to translate /'s to \'s again.
1510 to translate /'s to \'s again.
1504
1511
1505 * completer.py: prevent traceback on file completions w/
1512 * completer.py: prevent traceback on file completions w/
1506 backslash.
1513 backslash.
1507
1514
1508 * Release.py: Update release number to 0.7.3b3 for release
1515 * Release.py: Update release number to 0.7.3b3 for release
1509
1516
1510 2006-12-07 Ville Vainio <vivainio@gmail.com>
1517 2006-12-07 Ville Vainio <vivainio@gmail.com>
1511
1518
1512 * Extensions/ipy_signals.py: Ignore ctrl+C in IPython process
1519 * Extensions/ipy_signals.py: Ignore ctrl+C in IPython process
1513 while executing external code. Provides more shell-like behaviour
1520 while executing external code. Provides more shell-like behaviour
1514 and overall better response to ctrl + C / ctrl + break.
1521 and overall better response to ctrl + C / ctrl + break.
1515
1522
1516 * tools/make_tarball.py: new script to create tarball straight from svn
1523 * tools/make_tarball.py: new script to create tarball straight from svn
1517 (setup.py sdist doesn't work on win32).
1524 (setup.py sdist doesn't work on win32).
1518
1525
1519 * Extensions/ipy_stock_completers.py: fix cd completer to give up
1526 * Extensions/ipy_stock_completers.py: fix cd completer to give up
1520 on dirnames with spaces and use the default completer instead.
1527 on dirnames with spaces and use the default completer instead.
1521
1528
1522 * Revision.py: Change version to 0.7.3b2 for release.
1529 * Revision.py: Change version to 0.7.3b2 for release.
1523
1530
1524 2006-12-05 Ville Vainio <vivainio@gmail.com>
1531 2006-12-05 Ville Vainio <vivainio@gmail.com>
1525
1532
1526 * Magic.py, iplib.py, completer.py: Apply R. Bernstein's
1533 * Magic.py, iplib.py, completer.py: Apply R. Bernstein's
1527 pydb patch 4 (rm debug printing, py 2.5 checking)
1534 pydb patch 4 (rm debug printing, py 2.5 checking)
1528
1535
1529 2006-11-30 Walter Doerwald <walter@livinglogic.de>
1536 2006-11-30 Walter Doerwald <walter@livinglogic.de>
1530 * IPython/Extensions/ibrowse.py: Add two new commands to ibrowse:
1537 * IPython/Extensions/ibrowse.py: Add two new commands to ibrowse:
1531 "refresh" (mapped to "r") refreshes the screen by restarting the iterator.
1538 "refresh" (mapped to "r") refreshes the screen by restarting the iterator.
1532 "refreshfind" (mapped to "R") does the same but tries to go back to the same
1539 "refreshfind" (mapped to "R") does the same but tries to go back to the same
1533 object the cursor was on before the refresh. The command "markrange" is
1540 object the cursor was on before the refresh. The command "markrange" is
1534 mapped to "%" now.
1541 mapped to "%" now.
1535 * IPython/Extensions/ibrowse.py: Make igrpentry and ipwdentry comparable.
1542 * IPython/Extensions/ibrowse.py: Make igrpentry and ipwdentry comparable.
1536
1543
1537 2006-11-29 Fernando Perez <Fernando.Perez@colorado.edu>
1544 2006-11-29 Fernando Perez <Fernando.Perez@colorado.edu>
1538
1545
1539 * IPython/Magic.py (magic_debug): new %debug magic to activate the
1546 * IPython/Magic.py (magic_debug): new %debug magic to activate the
1540 interactive debugger on the last traceback, without having to call
1547 interactive debugger on the last traceback, without having to call
1541 %pdb and rerun your code. Made minor changes in various modules,
1548 %pdb and rerun your code. Made minor changes in various modules,
1542 should automatically recognize pydb if available.
1549 should automatically recognize pydb if available.
1543
1550
1544 2006-11-28 Ville Vainio <vivainio@gmail.com>
1551 2006-11-28 Ville Vainio <vivainio@gmail.com>
1545
1552
1546 * completer.py: If the text start with !, show file completions
1553 * completer.py: If the text start with !, show file completions
1547 properly. This helps when trying to complete command name
1554 properly. This helps when trying to complete command name
1548 for shell escapes.
1555 for shell escapes.
1549
1556
1550 2006-11-27 Ville Vainio <vivainio@gmail.com>
1557 2006-11-27 Ville Vainio <vivainio@gmail.com>
1551
1558
1552 * ipy_stock_completers.py: bzr completer submitted by Stefan van
1559 * ipy_stock_completers.py: bzr completer submitted by Stefan van
1553 der Walt. Clean up svn and hg completers by using a common
1560 der Walt. Clean up svn and hg completers by using a common
1554 vcs_completer.
1561 vcs_completer.
1555
1562
1556 2006-11-26 Ville Vainio <vivainio@gmail.com>
1563 2006-11-26 Ville Vainio <vivainio@gmail.com>
1557
1564
1558 * Remove ipconfig and %config; you should use _ip.options structure
1565 * Remove ipconfig and %config; you should use _ip.options structure
1559 directly instead!
1566 directly instead!
1560
1567
1561 * genutils.py: add wrap_deprecated function for deprecating callables
1568 * genutils.py: add wrap_deprecated function for deprecating callables
1562
1569
1563 * iplib.py: deprecate ipmagic, ipsystem, ipalias. Use _ip.magic and
1570 * iplib.py: deprecate ipmagic, ipsystem, ipalias. Use _ip.magic and
1564 _ip.system instead. ipalias is redundant.
1571 _ip.system instead. ipalias is redundant.
1565
1572
1566 * Magic.py: %rehashdir no longer aliases 'cmdname' to 'cmdname.exe' on
1573 * Magic.py: %rehashdir no longer aliases 'cmdname' to 'cmdname.exe' on
1567 win32, but just 'cmdname'. Other extensions (non-'exe') are still made
1574 win32, but just 'cmdname'. Other extensions (non-'exe') are still made
1568 explicit.
1575 explicit.
1569
1576
1570 * ipy_stock_completers.py: 'hg' (mercurial VCS) now has a custom
1577 * ipy_stock_completers.py: 'hg' (mercurial VCS) now has a custom
1571 completer. Try it by entering 'hg ' and pressing tab.
1578 completer. Try it by entering 'hg ' and pressing tab.
1572
1579
1573 * macro.py: Give Macro a useful __repr__ method
1580 * macro.py: Give Macro a useful __repr__ method
1574
1581
1575 * Magic.py: %whos abbreviates the typename of Macro for brevity.
1582 * Magic.py: %whos abbreviates the typename of Macro for brevity.
1576
1583
1577 2006-11-24 Walter Doerwald <walter@livinglogic.de>
1584 2006-11-24 Walter Doerwald <walter@livinglogic.de>
1578 * IPython/Extensions/astyle.py: Do a relative import of ipipe, so that
1585 * IPython/Extensions/astyle.py: Do a relative import of ipipe, so that
1579 we don't get a duplicate ipipe module, where registration of the xrepr
1586 we don't get a duplicate ipipe module, where registration of the xrepr
1580 implementation for Text is useless.
1587 implementation for Text is useless.
1581
1588
1582 * IPython/Extensions/ipipe.py: Fix __xrepr__() implementation for ils.
1589 * IPython/Extensions/ipipe.py: Fix __xrepr__() implementation for ils.
1583
1590
1584 * IPython/Extensions/ibrowse.py: Fix keymapping for the enter command.
1591 * IPython/Extensions/ibrowse.py: Fix keymapping for the enter command.
1585
1592
1586 2006-11-24 Ville Vainio <vivainio@gmail.com>
1593 2006-11-24 Ville Vainio <vivainio@gmail.com>
1587
1594
1588 * Magic.py, manual_base.lyx: Kirill Smelkov patch:
1595 * Magic.py, manual_base.lyx: Kirill Smelkov patch:
1589 try to use "cProfile" instead of the slower pure python
1596 try to use "cProfile" instead of the slower pure python
1590 "profile"
1597 "profile"
1591
1598
1592 2006-11-23 Ville Vainio <vivainio@gmail.com>
1599 2006-11-23 Ville Vainio <vivainio@gmail.com>
1593
1600
1594 * manual_base.lyx: Kirill Smelkov patch: Fix wrong
1601 * manual_base.lyx: Kirill Smelkov patch: Fix wrong
1595 Qt+IPython+Designer link in documentation.
1602 Qt+IPython+Designer link in documentation.
1596
1603
1597 * Extensions/ipy_pydb.py: R. Bernstein's patch for passing
1604 * Extensions/ipy_pydb.py: R. Bernstein's patch for passing
1598 correct Pdb object to %pydb.
1605 correct Pdb object to %pydb.
1599
1606
1600
1607
1601 2006-11-22 Walter Doerwald <walter@livinglogic.de>
1608 2006-11-22 Walter Doerwald <walter@livinglogic.de>
1602 * IPython/Extensions/astyle.py: Text needs it's own implemenation of the
1609 * IPython/Extensions/astyle.py: Text needs it's own implemenation of the
1603 generic xrepr(), otherwise the list implementation would kick in.
1610 generic xrepr(), otherwise the list implementation would kick in.
1604
1611
1605 2006-11-21 Ville Vainio <vivainio@gmail.com>
1612 2006-11-21 Ville Vainio <vivainio@gmail.com>
1606
1613
1607 * upgrade_dir.py: Now actually overwrites a nonmodified user file
1614 * upgrade_dir.py: Now actually overwrites a nonmodified user file
1608 with one from UserConfig.
1615 with one from UserConfig.
1609
1616
1610 * ipy_profile_sh.py: Add dummy "depth" to var_expand lambda,
1617 * ipy_profile_sh.py: Add dummy "depth" to var_expand lambda,
1611 it was missing which broke the sh profile.
1618 it was missing which broke the sh profile.
1612
1619
1613 * completer.py: file completer now uses explicit '/' instead
1620 * completer.py: file completer now uses explicit '/' instead
1614 of os.path.join, expansion of 'foo' was broken on win32
1621 of os.path.join, expansion of 'foo' was broken on win32
1615 if there was one directory with name 'foobar'.
1622 if there was one directory with name 'foobar'.
1616
1623
1617 * A bunch of patches from Kirill Smelkov:
1624 * A bunch of patches from Kirill Smelkov:
1618
1625
1619 * [patch 9/9] doc: point bug-tracker URL to IPythons trac-tickets.
1626 * [patch 9/9] doc: point bug-tracker URL to IPythons trac-tickets.
1620
1627
1621 * [patch 7/9] Implement %page -r (page in raw mode) -
1628 * [patch 7/9] Implement %page -r (page in raw mode) -
1622
1629
1623 * [patch 5/9] ScientificPython webpage has moved
1630 * [patch 5/9] ScientificPython webpage has moved
1624
1631
1625 * [patch 4/9] The manual mentions %ds, should be %dhist
1632 * [patch 4/9] The manual mentions %ds, should be %dhist
1626
1633
1627 * [patch 3/9] Kill old bits from %prun doc.
1634 * [patch 3/9] Kill old bits from %prun doc.
1628
1635
1629 * [patch 1/9] Fix typos here and there.
1636 * [patch 1/9] Fix typos here and there.
1630
1637
1631 2006-11-08 Ville Vainio <vivainio@gmail.com>
1638 2006-11-08 Ville Vainio <vivainio@gmail.com>
1632
1639
1633 * completer.py (attr_matches): catch all exceptions raised
1640 * completer.py (attr_matches): catch all exceptions raised
1634 by eval of expr with dots.
1641 by eval of expr with dots.
1635
1642
1636 2006-11-07 Fernando Perez <Fernando.Perez@colorado.edu>
1643 2006-11-07 Fernando Perez <Fernando.Perez@colorado.edu>
1637
1644
1638 * IPython/iplib.py (runsource): Prepend an 'if 1:' to the user
1645 * IPython/iplib.py (runsource): Prepend an 'if 1:' to the user
1639 input if it starts with whitespace. This allows you to paste
1646 input if it starts with whitespace. This allows you to paste
1640 indented input from any editor without manually having to type in
1647 indented input from any editor without manually having to type in
1641 the 'if 1:', which is convenient when working interactively.
1648 the 'if 1:', which is convenient when working interactively.
1642 Slightly modifed version of a patch by Bo Peng
1649 Slightly modifed version of a patch by Bo Peng
1643 <bpeng-AT-rice.edu>.
1650 <bpeng-AT-rice.edu>.
1644
1651
1645 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
1652 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
1646
1653
1647 * IPython/irunner.py (main): modified irunner so it automatically
1654 * IPython/irunner.py (main): modified irunner so it automatically
1648 recognizes the right runner to use based on the extension (.py for
1655 recognizes the right runner to use based on the extension (.py for
1649 python, .ipy for ipython and .sage for sage).
1656 python, .ipy for ipython and .sage for sage).
1650
1657
1651 * IPython/iplib.py (InteractiveShell.ipconfig): new builtin, also
1658 * IPython/iplib.py (InteractiveShell.ipconfig): new builtin, also
1652 visible in ipapi as ip.config(), to programatically control the
1659 visible in ipapi as ip.config(), to programatically control the
1653 internal rc object. There's an accompanying %config magic for
1660 internal rc object. There's an accompanying %config magic for
1654 interactive use, which has been enhanced to match the
1661 interactive use, which has been enhanced to match the
1655 funtionality in ipconfig.
1662 funtionality in ipconfig.
1656
1663
1657 * IPython/Magic.py (magic_system_verbose): Change %system_verbose
1664 * IPython/Magic.py (magic_system_verbose): Change %system_verbose
1658 so it's not just a toggle, it now takes an argument. Add support
1665 so it's not just a toggle, it now takes an argument. Add support
1659 for a customizable header when making system calls, as the new
1666 for a customizable header when making system calls, as the new
1660 system_header variable in the ipythonrc file.
1667 system_header variable in the ipythonrc file.
1661
1668
1662 2006-11-03 Walter Doerwald <walter@livinglogic.de>
1669 2006-11-03 Walter Doerwald <walter@livinglogic.de>
1663
1670
1664 * IPython/Extensions/ipipe.py: xrepr(), xiter() and xattrs() are now
1671 * IPython/Extensions/ipipe.py: xrepr(), xiter() and xattrs() are now
1665 generic functions (using Philip J. Eby's simplegeneric package).
1672 generic functions (using Philip J. Eby's simplegeneric package).
1666 This makes it possible to customize the display of third-party classes
1673 This makes it possible to customize the display of third-party classes
1667 without having to monkeypatch them. xiter() no longer supports a mode
1674 without having to monkeypatch them. xiter() no longer supports a mode
1668 argument and the XMode class has been removed. The same functionality can
1675 argument and the XMode class has been removed. The same functionality can
1669 be implemented via IterAttributeDescriptor and IterMethodDescriptor.
1676 be implemented via IterAttributeDescriptor and IterMethodDescriptor.
1670 One consequence of the switch to generic functions is that xrepr() and
1677 One consequence of the switch to generic functions is that xrepr() and
1671 xattrs() implementation must define the default value for the mode
1678 xattrs() implementation must define the default value for the mode
1672 argument themselves and xattrs() implementations must return real
1679 argument themselves and xattrs() implementations must return real
1673 descriptors.
1680 descriptors.
1674
1681
1675 * IPython/external: This new subpackage will contain all third-party
1682 * IPython/external: This new subpackage will contain all third-party
1676 packages that are bundled with IPython. (The first one is simplegeneric).
1683 packages that are bundled with IPython. (The first one is simplegeneric).
1677
1684
1678 * IPython/Extensions/ipipe.py (ifile/ils): Readd output of the parent
1685 * IPython/Extensions/ipipe.py (ifile/ils): Readd output of the parent
1679 directory which as been dropped in r1703.
1686 directory which as been dropped in r1703.
1680
1687
1681 * IPython/Extensions/ipipe.py (iless): Fixed.
1688 * IPython/Extensions/ipipe.py (iless): Fixed.
1682
1689
1683 * IPython/Extensions/ibrowse: Fixed sorting under Python 2.3.
1690 * IPython/Extensions/ibrowse: Fixed sorting under Python 2.3.
1684
1691
1685 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
1692 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
1686
1693
1687 * IPython/iplib.py (InteractiveShell.var_expand): fix stack
1694 * IPython/iplib.py (InteractiveShell.var_expand): fix stack
1688 handling in variable expansion so that shells and magics recognize
1695 handling in variable expansion so that shells and magics recognize
1689 function local scopes correctly. Bug reported by Brian.
1696 function local scopes correctly. Bug reported by Brian.
1690
1697
1691 * scripts/ipython: remove the very first entry in sys.path which
1698 * scripts/ipython: remove the very first entry in sys.path which
1692 Python auto-inserts for scripts, so that sys.path under IPython is
1699 Python auto-inserts for scripts, so that sys.path under IPython is
1693 as similar as possible to that under plain Python.
1700 as similar as possible to that under plain Python.
1694
1701
1695 * IPython/completer.py (IPCompleter.file_matches): Fix
1702 * IPython/completer.py (IPCompleter.file_matches): Fix
1696 tab-completion so that quotes are not closed unless the completion
1703 tab-completion so that quotes are not closed unless the completion
1697 is unambiguous. After a request by Stefan. Minor cleanups in
1704 is unambiguous. After a request by Stefan. Minor cleanups in
1698 ipy_stock_completers.
1705 ipy_stock_completers.
1699
1706
1700 2006-11-02 Ville Vainio <vivainio@gmail.com>
1707 2006-11-02 Ville Vainio <vivainio@gmail.com>
1701
1708
1702 * ipy_stock_completers.py: Add %run and %cd completers.
1709 * ipy_stock_completers.py: Add %run and %cd completers.
1703
1710
1704 * completer.py: Try running custom completer for both
1711 * completer.py: Try running custom completer for both
1705 "foo" and "%foo" if the command is just "foo". Ignore case
1712 "foo" and "%foo" if the command is just "foo". Ignore case
1706 when filtering possible completions.
1713 when filtering possible completions.
1707
1714
1708 * UserConfig/ipy_user_conf.py: install stock completers as default
1715 * UserConfig/ipy_user_conf.py: install stock completers as default
1709
1716
1710 * iplib.py (history_saving_wrapper), debugger(), ipy_pydb.py:
1717 * iplib.py (history_saving_wrapper), debugger(), ipy_pydb.py:
1711 simplified readline history save / restore through a wrapper
1718 simplified readline history save / restore through a wrapper
1712 function
1719 function
1713
1720
1714
1721
1715 2006-10-31 Ville Vainio <vivainio@gmail.com>
1722 2006-10-31 Ville Vainio <vivainio@gmail.com>
1716
1723
1717 * strdispatch.py, completer.py, ipy_stock_completers.py:
1724 * strdispatch.py, completer.py, ipy_stock_completers.py:
1718 Allow str_key ("command") in completer hooks. Implement
1725 Allow str_key ("command") in completer hooks. Implement
1719 trivial completer for 'import' (stdlib modules only). Rename
1726 trivial completer for 'import' (stdlib modules only). Rename
1720 ipy_linux_package_managers.py to ipy_stock_completers.py.
1727 ipy_linux_package_managers.py to ipy_stock_completers.py.
1721 SVN completer.
1728 SVN completer.
1722
1729
1723 * Extensions/ledit.py: %magic line editor for easily and
1730 * Extensions/ledit.py: %magic line editor for easily and
1724 incrementally manipulating lists of strings. The magic command
1731 incrementally manipulating lists of strings. The magic command
1725 name is %led.
1732 name is %led.
1726
1733
1727 2006-10-30 Ville Vainio <vivainio@gmail.com>
1734 2006-10-30 Ville Vainio <vivainio@gmail.com>
1728
1735
1729 * Debugger.py, iplib.py (debugger()): Add last set of Rocky
1736 * Debugger.py, iplib.py (debugger()): Add last set of Rocky
1730 Bernsteins's patches for pydb integration.
1737 Bernsteins's patches for pydb integration.
1731 http://bashdb.sourceforge.net/pydb/
1738 http://bashdb.sourceforge.net/pydb/
1732
1739
1733 * strdispatch.py, iplib.py, completer.py, IPython/__init__.py,
1740 * strdispatch.py, iplib.py, completer.py, IPython/__init__.py,
1734 Extensions/ipy_linux_package_managers.py, hooks.py: Implement
1741 Extensions/ipy_linux_package_managers.py, hooks.py: Implement
1735 custom completer hook to allow the users to implement their own
1742 custom completer hook to allow the users to implement their own
1736 completers. See ipy_linux_package_managers.py for example. The
1743 completers. See ipy_linux_package_managers.py for example. The
1737 hook name is 'complete_command'.
1744 hook name is 'complete_command'.
1738
1745
1739 2006-10-28 Fernando Perez <Fernando.Perez@colorado.edu>
1746 2006-10-28 Fernando Perez <Fernando.Perez@colorado.edu>
1740
1747
1741 * IPython/UserConfig/ipythonrc-scipy: minor cleanups to remove old
1748 * IPython/UserConfig/ipythonrc-scipy: minor cleanups to remove old
1742 Numeric leftovers.
1749 Numeric leftovers.
1743
1750
1744 * ipython.el (py-execute-region): apply Stefan's patch to fix
1751 * ipython.el (py-execute-region): apply Stefan's patch to fix
1745 garbled results if the python shell hasn't been previously started.
1752 garbled results if the python shell hasn't been previously started.
1746
1753
1747 * IPython/genutils.py (arg_split): moved to genutils, since it's a
1754 * IPython/genutils.py (arg_split): moved to genutils, since it's a
1748 pretty generic function and useful for other things.
1755 pretty generic function and useful for other things.
1749
1756
1750 * IPython/OInspect.py (getsource): Add customizable source
1757 * IPython/OInspect.py (getsource): Add customizable source
1751 extractor. After a request/patch form W. Stein (SAGE).
1758 extractor. After a request/patch form W. Stein (SAGE).
1752
1759
1753 * IPython/irunner.py (InteractiveRunner.run_source): reset tty
1760 * IPython/irunner.py (InteractiveRunner.run_source): reset tty
1754 window size to a more reasonable value from what pexpect does,
1761 window size to a more reasonable value from what pexpect does,
1755 since their choice causes wrapping bugs with long input lines.
1762 since their choice causes wrapping bugs with long input lines.
1756
1763
1757 2006-10-28 Ville Vainio <vivainio@gmail.com>
1764 2006-10-28 Ville Vainio <vivainio@gmail.com>
1758
1765
1759 * Magic.py (%run): Save and restore the readline history from
1766 * Magic.py (%run): Save and restore the readline history from
1760 file around %run commands to prevent side effects from
1767 file around %run commands to prevent side effects from
1761 %runned programs that might use readline (e.g. pydb).
1768 %runned programs that might use readline (e.g. pydb).
1762
1769
1763 * extensions/ipy_pydb.py: Adds %pydb magic when imported, for
1770 * extensions/ipy_pydb.py: Adds %pydb magic when imported, for
1764 invoking the pydb enhanced debugger.
1771 invoking the pydb enhanced debugger.
1765
1772
1766 2006-10-23 Walter Doerwald <walter@livinglogic.de>
1773 2006-10-23 Walter Doerwald <walter@livinglogic.de>
1767
1774
1768 * IPython/Extensions/ipipe.py (ifile): Remove all methods that
1775 * IPython/Extensions/ipipe.py (ifile): Remove all methods that
1769 call the base class method and propagate the return value to
1776 call the base class method and propagate the return value to
1770 ifile. This is now done by path itself.
1777 ifile. This is now done by path itself.
1771
1778
1772 2006-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
1779 2006-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
1773
1780
1774 * IPython/ipapi.py (IPApi.__init__): Added new entry to public
1781 * IPython/ipapi.py (IPApi.__init__): Added new entry to public
1775 api: set_crash_handler(), to expose the ability to change the
1782 api: set_crash_handler(), to expose the ability to change the
1776 internal crash handler.
1783 internal crash handler.
1777
1784
1778 * IPython/CrashHandler.py (CrashHandler.__init__): abstract out
1785 * IPython/CrashHandler.py (CrashHandler.__init__): abstract out
1779 the various parameters of the crash handler so that apps using
1786 the various parameters of the crash handler so that apps using
1780 IPython as their engine can customize crash handling. Ipmlemented
1787 IPython as their engine can customize crash handling. Ipmlemented
1781 at the request of SAGE.
1788 at the request of SAGE.
1782
1789
1783 2006-10-14 Ville Vainio <vivainio@gmail.com>
1790 2006-10-14 Ville Vainio <vivainio@gmail.com>
1784
1791
1785 * Magic.py, ipython.el: applied first "safe" part of Rocky
1792 * Magic.py, ipython.el: applied first "safe" part of Rocky
1786 Bernstein's patch set for pydb integration.
1793 Bernstein's patch set for pydb integration.
1787
1794
1788 * Magic.py (%unalias, %alias): %store'd aliases can now be
1795 * Magic.py (%unalias, %alias): %store'd aliases can now be
1789 removed with '%unalias'. %alias w/o args now shows most
1796 removed with '%unalias'. %alias w/o args now shows most
1790 interesting (stored / manually defined) aliases last
1797 interesting (stored / manually defined) aliases last
1791 where they catch the eye w/o scrolling.
1798 where they catch the eye w/o scrolling.
1792
1799
1793 * Magic.py (%rehashx), ext_rehashdir.py: files with
1800 * Magic.py (%rehashx), ext_rehashdir.py: files with
1794 'py' extension are always considered executable, even
1801 'py' extension are always considered executable, even
1795 when not in PATHEXT environment variable.
1802 when not in PATHEXT environment variable.
1796
1803
1797 2006-10-12 Ville Vainio <vivainio@gmail.com>
1804 2006-10-12 Ville Vainio <vivainio@gmail.com>
1798
1805
1799 * jobctrl.py: Add new "jobctrl" extension for spawning background
1806 * jobctrl.py: Add new "jobctrl" extension for spawning background
1800 processes with "&find /". 'import jobctrl' to try it out. Requires
1807 processes with "&find /". 'import jobctrl' to try it out. Requires
1801 'subprocess' module, standard in python 2.4+.
1808 'subprocess' module, standard in python 2.4+.
1802
1809
1803 * iplib.py (expand_aliases, handle_alias): Aliases expand transitively,
1810 * iplib.py (expand_aliases, handle_alias): Aliases expand transitively,
1804 so if foo -> bar and bar -> baz, then foo -> baz.
1811 so if foo -> bar and bar -> baz, then foo -> baz.
1805
1812
1806 2006-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
1813 2006-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
1807
1814
1808 * IPython/Magic.py (Magic.parse_options): add a new posix option
1815 * IPython/Magic.py (Magic.parse_options): add a new posix option
1809 to allow parsing of input args in magics that doesn't strip quotes
1816 to allow parsing of input args in magics that doesn't strip quotes
1810 (if posix=False). This also closes %timeit bug reported by
1817 (if posix=False). This also closes %timeit bug reported by
1811 Stefan.
1818 Stefan.
1812
1819
1813 2006-10-03 Ville Vainio <vivainio@gmail.com>
1820 2006-10-03 Ville Vainio <vivainio@gmail.com>
1814
1821
1815 * iplib.py (raw_input, interact): Return ValueError catching for
1822 * iplib.py (raw_input, interact): Return ValueError catching for
1816 raw_input. Fixes infinite loop for sys.stdin.close() or
1823 raw_input. Fixes infinite loop for sys.stdin.close() or
1817 sys.stdout.close().
1824 sys.stdout.close().
1818
1825
1819 2006-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1826 2006-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1820
1827
1821 * IPython/irunner.py (InteractiveRunner.run_source): small fixes
1828 * IPython/irunner.py (InteractiveRunner.run_source): small fixes
1822 to help in handling doctests. irunner is now pretty useful for
1829 to help in handling doctests. irunner is now pretty useful for
1823 running standalone scripts and simulate a full interactive session
1830 running standalone scripts and simulate a full interactive session
1824 in a format that can be then pasted as a doctest.
1831 in a format that can be then pasted as a doctest.
1825
1832
1826 * IPython/iplib.py (InteractiveShell.__init__): Install exit/quit
1833 * IPython/iplib.py (InteractiveShell.__init__): Install exit/quit
1827 on top of the default (useless) ones. This also fixes the nasty
1834 on top of the default (useless) ones. This also fixes the nasty
1828 way in which 2.5's Quitter() exits (reverted [1785]).
1835 way in which 2.5's Quitter() exits (reverted [1785]).
1829
1836
1830 * IPython/Debugger.py (Pdb.__init__): Fix ipdb to work with python
1837 * IPython/Debugger.py (Pdb.__init__): Fix ipdb to work with python
1831 2.5.
1838 2.5.
1832
1839
1833 * IPython/ultraTB.py (TBTools.set_colors): Make sure that ipdb
1840 * IPython/ultraTB.py (TBTools.set_colors): Make sure that ipdb
1834 color scheme is updated as well when color scheme is changed
1841 color scheme is updated as well when color scheme is changed
1835 interactively.
1842 interactively.
1836
1843
1837 2006-09-27 Ville Vainio <vivainio@gmail.com>
1844 2006-09-27 Ville Vainio <vivainio@gmail.com>
1838
1845
1839 * iplib.py (raw_input): python 2.5 closes stdin on quit -> avoid
1846 * iplib.py (raw_input): python 2.5 closes stdin on quit -> avoid
1840 infinite loop and just exit. It's a hack, but will do for a while.
1847 infinite loop and just exit. It's a hack, but will do for a while.
1841
1848
1842 2006-08-25 Walter Doerwald <walter@livinglogic.de>
1849 2006-08-25 Walter Doerwald <walter@livinglogic.de>
1843
1850
1844 * IPython/Extensions/ipipe.py (ils): Add arguments dirs and files to
1851 * IPython/Extensions/ipipe.py (ils): Add arguments dirs and files to
1845 the constructor, this makes it possible to get a list of only directories
1852 the constructor, this makes it possible to get a list of only directories
1846 or only files.
1853 or only files.
1847
1854
1848 2006-08-12 Ville Vainio <vivainio@gmail.com>
1855 2006-08-12 Ville Vainio <vivainio@gmail.com>
1849
1856
1850 * Fakemodule.py, OInspect.py: Reverted 2006-08-11 mods,
1857 * Fakemodule.py, OInspect.py: Reverted 2006-08-11 mods,
1851 they broke unittest
1858 they broke unittest
1852
1859
1853 2006-08-11 Ville Vainio <vivainio@gmail.com>
1860 2006-08-11 Ville Vainio <vivainio@gmail.com>
1854
1861
1855 * Fakemodule.py, OInspect.py: remove 2006-08-09 monkepatch
1862 * Fakemodule.py, OInspect.py: remove 2006-08-09 monkepatch
1856 by resolving issue properly, i.e. by inheriting FakeModule
1863 by resolving issue properly, i.e. by inheriting FakeModule
1857 from types.ModuleType. Pickling ipython interactive data
1864 from types.ModuleType. Pickling ipython interactive data
1858 should still work as usual (testing appreciated).
1865 should still work as usual (testing appreciated).
1859
1866
1860 2006-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
1867 2006-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
1861
1868
1862 * IPython/OInspect.py: monkeypatch inspect from the stdlib if
1869 * IPython/OInspect.py: monkeypatch inspect from the stdlib if
1863 running under python 2.3 with code from 2.4 to fix a bug with
1870 running under python 2.3 with code from 2.4 to fix a bug with
1864 help(). Reported by the Debian maintainers, Norbert Tretkowski
1871 help(). Reported by the Debian maintainers, Norbert Tretkowski
1865 <norbert-AT-tretkowski.de> and Alexandre Fayolle
1872 <norbert-AT-tretkowski.de> and Alexandre Fayolle
1866 <afayolle-AT-debian.org>.
1873 <afayolle-AT-debian.org>.
1867
1874
1868 2006-08-04 Walter Doerwald <walter@livinglogic.de>
1875 2006-08-04 Walter Doerwald <walter@livinglogic.de>
1869
1876
1870 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
1877 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
1871 (which was displaying "quit" twice).
1878 (which was displaying "quit" twice).
1872
1879
1873 2006-07-28 Walter Doerwald <walter@livinglogic.de>
1880 2006-07-28 Walter Doerwald <walter@livinglogic.de>
1874
1881
1875 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
1882 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
1876 the mode argument).
1883 the mode argument).
1877
1884
1878 2006-07-27 Walter Doerwald <walter@livinglogic.de>
1885 2006-07-27 Walter Doerwald <walter@livinglogic.de>
1879
1886
1880 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
1887 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
1881 not running under IPython.
1888 not running under IPython.
1882
1889
1883 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
1890 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
1884 and make it iterable (iterating over the attribute itself). Add two new
1891 and make it iterable (iterating over the attribute itself). Add two new
1885 magic strings for __xattrs__(): If the string starts with "-", the attribute
1892 magic strings for __xattrs__(): If the string starts with "-", the attribute
1886 will not be displayed in ibrowse's detail view (but it can still be
1893 will not be displayed in ibrowse's detail view (but it can still be
1887 iterated over). This makes it possible to add attributes that are large
1894 iterated over). This makes it possible to add attributes that are large
1888 lists or generator methods to the detail view. Replace magic attribute names
1895 lists or generator methods to the detail view. Replace magic attribute names
1889 and _attrname() and _getattr() with "descriptors": For each type of magic
1896 and _attrname() and _getattr() with "descriptors": For each type of magic
1890 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
1897 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
1891 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
1898 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
1892 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
1899 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
1893 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
1900 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
1894 are still supported.
1901 are still supported.
1895
1902
1896 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
1903 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
1897 fails in ibrowse.fetch(), the exception object is added as the last item
1904 fails in ibrowse.fetch(), the exception object is added as the last item
1898 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
1905 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
1899 a generator throws an exception midway through execution.
1906 a generator throws an exception midway through execution.
1900
1907
1901 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
1908 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
1902 encoding into methods.
1909 encoding into methods.
1903
1910
1904 2006-07-26 Ville Vainio <vivainio@gmail.com>
1911 2006-07-26 Ville Vainio <vivainio@gmail.com>
1905
1912
1906 * iplib.py: history now stores multiline input as single
1913 * iplib.py: history now stores multiline input as single
1907 history entries. Patch by Jorgen Cederlof.
1914 history entries. Patch by Jorgen Cederlof.
1908
1915
1909 2006-07-18 Walter Doerwald <walter@livinglogic.de>
1916 2006-07-18 Walter Doerwald <walter@livinglogic.de>
1910
1917
1911 * IPython/Extensions/ibrowse.py: Make cursor visible over
1918 * IPython/Extensions/ibrowse.py: Make cursor visible over
1912 non existing attributes.
1919 non existing attributes.
1913
1920
1914 2006-07-14 Walter Doerwald <walter@livinglogic.de>
1921 2006-07-14 Walter Doerwald <walter@livinglogic.de>
1915
1922
1916 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
1923 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
1917 error output of the running command doesn't mess up the screen.
1924 error output of the running command doesn't mess up the screen.
1918
1925
1919 2006-07-13 Walter Doerwald <walter@livinglogic.de>
1926 2006-07-13 Walter Doerwald <walter@livinglogic.de>
1920
1927
1921 * IPython/Extensions/ipipe.py (isort): Make isort usable without
1928 * IPython/Extensions/ipipe.py (isort): Make isort usable without
1922 argument. This sorts the items themselves.
1929 argument. This sorts the items themselves.
1923
1930
1924 2006-07-12 Walter Doerwald <walter@livinglogic.de>
1931 2006-07-12 Walter Doerwald <walter@livinglogic.de>
1925
1932
1926 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
1933 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
1927 Compile expression strings into code objects. This should speed
1934 Compile expression strings into code objects. This should speed
1928 up ifilter and friends somewhat.
1935 up ifilter and friends somewhat.
1929
1936
1930 2006-07-08 Ville Vainio <vivainio@gmail.com>
1937 2006-07-08 Ville Vainio <vivainio@gmail.com>
1931
1938
1932 * Magic.py: %cpaste now strips > from the beginning of lines
1939 * Magic.py: %cpaste now strips > from the beginning of lines
1933 to ease pasting quoted code from emails. Contributed by
1940 to ease pasting quoted code from emails. Contributed by
1934 Stefan van der Walt.
1941 Stefan van der Walt.
1935
1942
1936 2006-06-29 Ville Vainio <vivainio@gmail.com>
1943 2006-06-29 Ville Vainio <vivainio@gmail.com>
1937
1944
1938 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
1945 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
1939 mode, patch contributed by Darren Dale. NEEDS TESTING!
1946 mode, patch contributed by Darren Dale. NEEDS TESTING!
1940
1947
1941 2006-06-28 Walter Doerwald <walter@livinglogic.de>
1948 2006-06-28 Walter Doerwald <walter@livinglogic.de>
1942
1949
1943 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
1950 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
1944 a blue background. Fix fetching new display rows when the browser
1951 a blue background. Fix fetching new display rows when the browser
1945 scrolls more than a screenful (e.g. by using the goto command).
1952 scrolls more than a screenful (e.g. by using the goto command).
1946
1953
1947 2006-06-27 Ville Vainio <vivainio@gmail.com>
1954 2006-06-27 Ville Vainio <vivainio@gmail.com>
1948
1955
1949 * Magic.py (_inspect, _ofind) Apply David Huard's
1956 * Magic.py (_inspect, _ofind) Apply David Huard's
1950 patch for displaying the correct docstring for 'property'
1957 patch for displaying the correct docstring for 'property'
1951 attributes.
1958 attributes.
1952
1959
1953 2006-06-23 Walter Doerwald <walter@livinglogic.de>
1960 2006-06-23 Walter Doerwald <walter@livinglogic.de>
1954
1961
1955 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
1962 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
1956 commands into the methods implementing them.
1963 commands into the methods implementing them.
1957
1964
1958 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
1965 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
1959
1966
1960 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
1967 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
1961 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
1968 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
1962 autoindent support was authored by Jin Liu.
1969 autoindent support was authored by Jin Liu.
1963
1970
1964 2006-06-22 Walter Doerwald <walter@livinglogic.de>
1971 2006-06-22 Walter Doerwald <walter@livinglogic.de>
1965
1972
1966 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
1973 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
1967 for keymaps with a custom class that simplifies handling.
1974 for keymaps with a custom class that simplifies handling.
1968
1975
1969 2006-06-19 Walter Doerwald <walter@livinglogic.de>
1976 2006-06-19 Walter Doerwald <walter@livinglogic.de>
1970
1977
1971 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
1978 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
1972 resizing. This requires Python 2.5 to work.
1979 resizing. This requires Python 2.5 to work.
1973
1980
1974 2006-06-16 Walter Doerwald <walter@livinglogic.de>
1981 2006-06-16 Walter Doerwald <walter@livinglogic.de>
1975
1982
1976 * IPython/Extensions/ibrowse.py: Add two new commands to
1983 * IPython/Extensions/ibrowse.py: Add two new commands to
1977 ibrowse: "hideattr" (mapped to "h") hides the attribute under
1984 ibrowse: "hideattr" (mapped to "h") hides the attribute under
1978 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
1985 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
1979 attributes again. Remapped the help command to "?". Display
1986 attributes again. Remapped the help command to "?". Display
1980 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
1987 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
1981 as keys for the "home" and "end" commands. Add three new commands
1988 as keys for the "home" and "end" commands. Add three new commands
1982 to the input mode for "find" and friends: "delend" (CTRL-K)
1989 to the input mode for "find" and friends: "delend" (CTRL-K)
1983 deletes to the end of line. "incsearchup" searches upwards in the
1990 deletes to the end of line. "incsearchup" searches upwards in the
1984 command history for an input that starts with the text before the cursor.
1991 command history for an input that starts with the text before the cursor.
1985 "incsearchdown" does the same downwards. Removed a bogus mapping of
1992 "incsearchdown" does the same downwards. Removed a bogus mapping of
1986 the x key to "delete".
1993 the x key to "delete".
1987
1994
1988 2006-06-15 Ville Vainio <vivainio@gmail.com>
1995 2006-06-15 Ville Vainio <vivainio@gmail.com>
1989
1996
1990 * iplib.py, hooks.py: Added new generate_prompt hook that can be
1997 * iplib.py, hooks.py: Added new generate_prompt hook that can be
1991 used to create prompts dynamically, instead of the "old" way of
1998 used to create prompts dynamically, instead of the "old" way of
1992 assigning "magic" strings to prompt_in1 and prompt_in2. The old
1999 assigning "magic" strings to prompt_in1 and prompt_in2. The old
1993 way still works (it's invoked by the default hook), of course.
2000 way still works (it's invoked by the default hook), of course.
1994
2001
1995 * Prompts.py: added generate_output_prompt hook for altering output
2002 * Prompts.py: added generate_output_prompt hook for altering output
1996 prompt
2003 prompt
1997
2004
1998 * Release.py: Changed version string to 0.7.3.svn.
2005 * Release.py: Changed version string to 0.7.3.svn.
1999
2006
2000 2006-06-15 Walter Doerwald <walter@livinglogic.de>
2007 2006-06-15 Walter Doerwald <walter@livinglogic.de>
2001
2008
2002 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
2009 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
2003 the call to fetch() always tries to fetch enough data for at least one
2010 the call to fetch() always tries to fetch enough data for at least one
2004 full screen. This makes it possible to simply call moveto(0,0,True) in
2011 full screen. This makes it possible to simply call moveto(0,0,True) in
2005 the constructor. Fix typos and removed the obsolete goto attribute.
2012 the constructor. Fix typos and removed the obsolete goto attribute.
2006
2013
2007 2006-06-12 Ville Vainio <vivainio@gmail.com>
2014 2006-06-12 Ville Vainio <vivainio@gmail.com>
2008
2015
2009 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
2016 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
2010 allowing $variable interpolation within multiline statements,
2017 allowing $variable interpolation within multiline statements,
2011 though so far only with "sh" profile for a testing period.
2018 though so far only with "sh" profile for a testing period.
2012 The patch also enables splitting long commands with \ but it
2019 The patch also enables splitting long commands with \ but it
2013 doesn't work properly yet.
2020 doesn't work properly yet.
2014
2021
2015 2006-06-12 Walter Doerwald <walter@livinglogic.de>
2022 2006-06-12 Walter Doerwald <walter@livinglogic.de>
2016
2023
2017 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
2024 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
2018 input history and the position of the cursor in the input history for
2025 input history and the position of the cursor in the input history for
2019 the find, findbackwards and goto command.
2026 the find, findbackwards and goto command.
2020
2027
2021 2006-06-10 Walter Doerwald <walter@livinglogic.de>
2028 2006-06-10 Walter Doerwald <walter@livinglogic.de>
2022
2029
2023 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
2030 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
2024 implements the basic functionality of browser commands that require
2031 implements the basic functionality of browser commands that require
2025 input. Reimplement the goto, find and findbackwards commands as
2032 input. Reimplement the goto, find and findbackwards commands as
2026 subclasses of _CommandInput. Add an input history and keymaps to those
2033 subclasses of _CommandInput. Add an input history and keymaps to those
2027 commands. Add "\r" as a keyboard shortcut for the enterdefault and
2034 commands. Add "\r" as a keyboard shortcut for the enterdefault and
2028 execute commands.
2035 execute commands.
2029
2036
2030 2006-06-07 Ville Vainio <vivainio@gmail.com>
2037 2006-06-07 Ville Vainio <vivainio@gmail.com>
2031
2038
2032 * iplib.py: ipython mybatch.ipy exits ipython immediately after
2039 * iplib.py: ipython mybatch.ipy exits ipython immediately after
2033 running the batch files instead of leaving the session open.
2040 running the batch files instead of leaving the session open.
2034
2041
2035 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
2042 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
2036
2043
2037 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
2044 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
2038 the original fix was incomplete. Patch submitted by W. Maier.
2045 the original fix was incomplete. Patch submitted by W. Maier.
2039
2046
2040 2006-06-07 Ville Vainio <vivainio@gmail.com>
2047 2006-06-07 Ville Vainio <vivainio@gmail.com>
2041
2048
2042 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
2049 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
2043 Confirmation prompts can be supressed by 'quiet' option.
2050 Confirmation prompts can be supressed by 'quiet' option.
2044 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
2051 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
2045
2052
2046 2006-06-06 *** Released version 0.7.2
2053 2006-06-06 *** Released version 0.7.2
2047
2054
2048 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
2055 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
2049
2056
2050 * IPython/Release.py (version): Made 0.7.2 final for release.
2057 * IPython/Release.py (version): Made 0.7.2 final for release.
2051 Repo tagged and release cut.
2058 Repo tagged and release cut.
2052
2059
2053 2006-06-05 Ville Vainio <vivainio@gmail.com>
2060 2006-06-05 Ville Vainio <vivainio@gmail.com>
2054
2061
2055 * Magic.py (magic_rehashx): Honor no_alias list earlier in
2062 * Magic.py (magic_rehashx): Honor no_alias list earlier in
2056 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
2063 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
2057
2064
2058 * upgrade_dir.py: try import 'path' module a bit harder
2065 * upgrade_dir.py: try import 'path' module a bit harder
2059 (for %upgrade)
2066 (for %upgrade)
2060
2067
2061 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
2068 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
2062
2069
2063 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
2070 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
2064 instead of looping 20 times.
2071 instead of looping 20 times.
2065
2072
2066 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
2073 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
2067 correctly at initialization time. Bug reported by Krishna Mohan
2074 correctly at initialization time. Bug reported by Krishna Mohan
2068 Gundu <gkmohan-AT-gmail.com> on the user list.
2075 Gundu <gkmohan-AT-gmail.com> on the user list.
2069
2076
2070 * IPython/Release.py (version): Mark 0.7.2 version to start
2077 * IPython/Release.py (version): Mark 0.7.2 version to start
2071 testing for release on 06/06.
2078 testing for release on 06/06.
2072
2079
2073 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
2080 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
2074
2081
2075 * scripts/irunner: thin script interface so users don't have to
2082 * scripts/irunner: thin script interface so users don't have to
2076 find the module and call it as an executable, since modules rarely
2083 find the module and call it as an executable, since modules rarely
2077 live in people's PATH.
2084 live in people's PATH.
2078
2085
2079 * IPython/irunner.py (InteractiveRunner.__init__): added
2086 * IPython/irunner.py (InteractiveRunner.__init__): added
2080 delaybeforesend attribute to control delays with newer versions of
2087 delaybeforesend attribute to control delays with newer versions of
2081 pexpect. Thanks to detailed help from pexpect's author, Noah
2088 pexpect. Thanks to detailed help from pexpect's author, Noah
2082 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
2089 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
2083 correctly (it works in NoColor mode).
2090 correctly (it works in NoColor mode).
2084
2091
2085 * IPython/iplib.py (handle_normal): fix nasty crash reported on
2092 * IPython/iplib.py (handle_normal): fix nasty crash reported on
2086 SAGE list, from improper log() calls.
2093 SAGE list, from improper log() calls.
2087
2094
2088 2006-05-31 Ville Vainio <vivainio@gmail.com>
2095 2006-05-31 Ville Vainio <vivainio@gmail.com>
2089
2096
2090 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
2097 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
2091 with args in parens to work correctly with dirs that have spaces.
2098 with args in parens to work correctly with dirs that have spaces.
2092
2099
2093 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
2100 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
2094
2101
2095 * IPython/Logger.py (Logger.logstart): add option to log raw input
2102 * IPython/Logger.py (Logger.logstart): add option to log raw input
2096 instead of the processed one. A -r flag was added to the
2103 instead of the processed one. A -r flag was added to the
2097 %logstart magic used for controlling logging.
2104 %logstart magic used for controlling logging.
2098
2105
2099 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
2106 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
2100
2107
2101 * IPython/iplib.py (InteractiveShell.__init__): add check for the
2108 * IPython/iplib.py (InteractiveShell.__init__): add check for the
2102 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
2109 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
2103 recognize the option. After a bug report by Will Maier. This
2110 recognize the option. After a bug report by Will Maier. This
2104 closes #64 (will do it after confirmation from W. Maier).
2111 closes #64 (will do it after confirmation from W. Maier).
2105
2112
2106 * IPython/irunner.py: New module to run scripts as if manually
2113 * IPython/irunner.py: New module to run scripts as if manually
2107 typed into an interactive environment, based on pexpect. After a
2114 typed into an interactive environment, based on pexpect. After a
2108 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
2115 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
2109 ipython-user list. Simple unittests in the tests/ directory.
2116 ipython-user list. Simple unittests in the tests/ directory.
2110
2117
2111 * tools/release: add Will Maier, OpenBSD port maintainer, to
2118 * tools/release: add Will Maier, OpenBSD port maintainer, to
2112 recepients list. We are now officially part of the OpenBSD ports:
2119 recepients list. We are now officially part of the OpenBSD ports:
2113 http://www.openbsd.org/ports.html ! Many thanks to Will for the
2120 http://www.openbsd.org/ports.html ! Many thanks to Will for the
2114 work.
2121 work.
2115
2122
2116 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
2123 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
2117
2124
2118 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
2125 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
2119 so that it doesn't break tkinter apps.
2126 so that it doesn't break tkinter apps.
2120
2127
2121 * IPython/iplib.py (_prefilter): fix bug where aliases would
2128 * IPython/iplib.py (_prefilter): fix bug where aliases would
2122 shadow variables when autocall was fully off. Reported by SAGE
2129 shadow variables when autocall was fully off. Reported by SAGE
2123 author William Stein.
2130 author William Stein.
2124
2131
2125 * IPython/OInspect.py (Inspector.__init__): add a flag to control
2132 * IPython/OInspect.py (Inspector.__init__): add a flag to control
2126 at what detail level strings are computed when foo? is requested.
2133 at what detail level strings are computed when foo? is requested.
2127 This allows users to ask for example that the string form of an
2134 This allows users to ask for example that the string form of an
2128 object is only computed when foo?? is called, or even never, by
2135 object is only computed when foo?? is called, or even never, by
2129 setting the object_info_string_level >= 2 in the configuration
2136 setting the object_info_string_level >= 2 in the configuration
2130 file. This new option has been added and documented. After a
2137 file. This new option has been added and documented. After a
2131 request by SAGE to be able to control the printing of very large
2138 request by SAGE to be able to control the printing of very large
2132 objects more easily.
2139 objects more easily.
2133
2140
2134 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
2141 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
2135
2142
2136 * IPython/ipmaker.py (make_IPython): remove the ipython call path
2143 * IPython/ipmaker.py (make_IPython): remove the ipython call path
2137 from sys.argv, to be 100% consistent with how Python itself works
2144 from sys.argv, to be 100% consistent with how Python itself works
2138 (as seen for example with python -i file.py). After a bug report
2145 (as seen for example with python -i file.py). After a bug report
2139 by Jeffrey Collins.
2146 by Jeffrey Collins.
2140
2147
2141 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
2148 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
2142 nasty bug which was preventing custom namespaces with -pylab,
2149 nasty bug which was preventing custom namespaces with -pylab,
2143 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
2150 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
2144 compatibility (long gone from mpl).
2151 compatibility (long gone from mpl).
2145
2152
2146 * IPython/ipapi.py (make_session): name change: create->make. We
2153 * IPython/ipapi.py (make_session): name change: create->make. We
2147 use make in other places (ipmaker,...), it's shorter and easier to
2154 use make in other places (ipmaker,...), it's shorter and easier to
2148 type and say, etc. I'm trying to clean things before 0.7.2 so
2155 type and say, etc. I'm trying to clean things before 0.7.2 so
2149 that I can keep things stable wrt to ipapi in the chainsaw branch.
2156 that I can keep things stable wrt to ipapi in the chainsaw branch.
2150
2157
2151 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
2158 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
2152 python-mode recognizes our debugger mode. Add support for
2159 python-mode recognizes our debugger mode. Add support for
2153 autoindent inside (X)emacs. After a patch sent in by Jin Liu
2160 autoindent inside (X)emacs. After a patch sent in by Jin Liu
2154 <m.liu.jin-AT-gmail.com> originally written by
2161 <m.liu.jin-AT-gmail.com> originally written by
2155 doxgen-AT-newsmth.net (with minor modifications for xemacs
2162 doxgen-AT-newsmth.net (with minor modifications for xemacs
2156 compatibility)
2163 compatibility)
2157
2164
2158 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
2165 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
2159 tracebacks when walking the stack so that the stack tracking system
2166 tracebacks when walking the stack so that the stack tracking system
2160 in emacs' python-mode can identify the frames correctly.
2167 in emacs' python-mode can identify the frames correctly.
2161
2168
2162 * IPython/ipmaker.py (make_IPython): make the internal (and
2169 * IPython/ipmaker.py (make_IPython): make the internal (and
2163 default config) autoedit_syntax value false by default. Too many
2170 default config) autoedit_syntax value false by default. Too many
2164 users have complained to me (both on and off-list) about problems
2171 users have complained to me (both on and off-list) about problems
2165 with this option being on by default, so I'm making it default to
2172 with this option being on by default, so I'm making it default to
2166 off. It can still be enabled by anyone via the usual mechanisms.
2173 off. It can still be enabled by anyone via the usual mechanisms.
2167
2174
2168 * IPython/completer.py (Completer.attr_matches): add support for
2175 * IPython/completer.py (Completer.attr_matches): add support for
2169 PyCrust-style _getAttributeNames magic method. Patch contributed
2176 PyCrust-style _getAttributeNames magic method. Patch contributed
2170 by <mscott-AT-goldenspud.com>. Closes #50.
2177 by <mscott-AT-goldenspud.com>. Closes #50.
2171
2178
2172 * IPython/iplib.py (InteractiveShell.__init__): remove the
2179 * IPython/iplib.py (InteractiveShell.__init__): remove the
2173 deletion of exit/quit from __builtin__, which can break
2180 deletion of exit/quit from __builtin__, which can break
2174 third-party tools like the Zope debugging console. The
2181 third-party tools like the Zope debugging console. The
2175 %exit/%quit magics remain. In general, it's probably a good idea
2182 %exit/%quit magics remain. In general, it's probably a good idea
2176 not to delete anything from __builtin__, since we never know what
2183 not to delete anything from __builtin__, since we never know what
2177 that will break. In any case, python now (for 2.5) will support
2184 that will break. In any case, python now (for 2.5) will support
2178 'real' exit/quit, so this issue is moot. Closes #55.
2185 'real' exit/quit, so this issue is moot. Closes #55.
2179
2186
2180 * IPython/genutils.py (with_obj): rename the 'with' function to
2187 * IPython/genutils.py (with_obj): rename the 'with' function to
2181 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
2188 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
2182 becomes a language keyword. Closes #53.
2189 becomes a language keyword. Closes #53.
2183
2190
2184 * IPython/FakeModule.py (FakeModule.__init__): add a proper
2191 * IPython/FakeModule.py (FakeModule.__init__): add a proper
2185 __file__ attribute to this so it fools more things into thinking
2192 __file__ attribute to this so it fools more things into thinking
2186 it is a real module. Closes #59.
2193 it is a real module. Closes #59.
2187
2194
2188 * IPython/Magic.py (magic_edit): add -n option to open the editor
2195 * IPython/Magic.py (magic_edit): add -n option to open the editor
2189 at a specific line number. After a patch by Stefan van der Walt.
2196 at a specific line number. After a patch by Stefan van der Walt.
2190
2197
2191 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
2198 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
2192
2199
2193 * IPython/iplib.py (edit_syntax_error): fix crash when for some
2200 * IPython/iplib.py (edit_syntax_error): fix crash when for some
2194 reason the file could not be opened. After automatic crash
2201 reason the file could not be opened. After automatic crash
2195 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
2202 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
2196 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
2203 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
2197 (_should_recompile): Don't fire editor if using %bg, since there
2204 (_should_recompile): Don't fire editor if using %bg, since there
2198 is no file in the first place. From the same report as above.
2205 is no file in the first place. From the same report as above.
2199 (raw_input): protect against faulty third-party prefilters. After
2206 (raw_input): protect against faulty third-party prefilters. After
2200 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
2207 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
2201 while running under SAGE.
2208 while running under SAGE.
2202
2209
2203 2006-05-23 Ville Vainio <vivainio@gmail.com>
2210 2006-05-23 Ville Vainio <vivainio@gmail.com>
2204
2211
2205 * ipapi.py: Stripped down ip.to_user_ns() to work only as
2212 * ipapi.py: Stripped down ip.to_user_ns() to work only as
2206 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
2213 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
2207 now returns None (again), unless dummy is specifically allowed by
2214 now returns None (again), unless dummy is specifically allowed by
2208 ipapi.get(allow_dummy=True).
2215 ipapi.get(allow_dummy=True).
2209
2216
2210 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
2217 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
2211
2218
2212 * IPython: remove all 2.2-compatibility objects and hacks from
2219 * IPython: remove all 2.2-compatibility objects and hacks from
2213 everywhere, since we only support 2.3 at this point. Docs
2220 everywhere, since we only support 2.3 at this point. Docs
2214 updated.
2221 updated.
2215
2222
2216 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
2223 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
2217 Anything requiring extra validation can be turned into a Python
2224 Anything requiring extra validation can be turned into a Python
2218 property in the future. I used a property for the db one b/c
2225 property in the future. I used a property for the db one b/c
2219 there was a nasty circularity problem with the initialization
2226 there was a nasty circularity problem with the initialization
2220 order, which right now I don't have time to clean up.
2227 order, which right now I don't have time to clean up.
2221
2228
2222 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
2229 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
2223 another locking bug reported by Jorgen. I'm not 100% sure though,
2230 another locking bug reported by Jorgen. I'm not 100% sure though,
2224 so more testing is needed...
2231 so more testing is needed...
2225
2232
2226 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
2233 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
2227
2234
2228 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
2235 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
2229 local variables from any routine in user code (typically executed
2236 local variables from any routine in user code (typically executed
2230 with %run) directly into the interactive namespace. Very useful
2237 with %run) directly into the interactive namespace. Very useful
2231 when doing complex debugging.
2238 when doing complex debugging.
2232 (IPythonNotRunning): Changed the default None object to a dummy
2239 (IPythonNotRunning): Changed the default None object to a dummy
2233 whose attributes can be queried as well as called without
2240 whose attributes can be queried as well as called without
2234 exploding, to ease writing code which works transparently both in
2241 exploding, to ease writing code which works transparently both in
2235 and out of ipython and uses some of this API.
2242 and out of ipython and uses some of this API.
2236
2243
2237 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
2244 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
2238
2245
2239 * IPython/hooks.py (result_display): Fix the fact that our display
2246 * IPython/hooks.py (result_display): Fix the fact that our display
2240 hook was using str() instead of repr(), as the default python
2247 hook was using str() instead of repr(), as the default python
2241 console does. This had gone unnoticed b/c it only happened if
2248 console does. This had gone unnoticed b/c it only happened if
2242 %Pprint was off, but the inconsistency was there.
2249 %Pprint was off, but the inconsistency was there.
2243
2250
2244 2006-05-15 Ville Vainio <vivainio@gmail.com>
2251 2006-05-15 Ville Vainio <vivainio@gmail.com>
2245
2252
2246 * Oinspect.py: Only show docstring for nonexisting/binary files
2253 * Oinspect.py: Only show docstring for nonexisting/binary files
2247 when doing object??, closing ticket #62
2254 when doing object??, closing ticket #62
2248
2255
2249 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
2256 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
2250
2257
2251 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
2258 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
2252 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
2259 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
2253 was being released in a routine which hadn't checked if it had
2260 was being released in a routine which hadn't checked if it had
2254 been the one to acquire it.
2261 been the one to acquire it.
2255
2262
2256 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
2263 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
2257
2264
2258 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
2265 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
2259
2266
2260 2006-04-11 Ville Vainio <vivainio@gmail.com>
2267 2006-04-11 Ville Vainio <vivainio@gmail.com>
2261
2268
2262 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
2269 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
2263 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
2270 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
2264 prefilters, allowing stuff like magics and aliases in the file.
2271 prefilters, allowing stuff like magics and aliases in the file.
2265
2272
2266 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
2273 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
2267 added. Supported now are "%clear in" and "%clear out" (clear input and
2274 added. Supported now are "%clear in" and "%clear out" (clear input and
2268 output history, respectively). Also fixed CachedOutput.flush to
2275 output history, respectively). Also fixed CachedOutput.flush to
2269 properly flush the output cache.
2276 properly flush the output cache.
2270
2277
2271 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
2278 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
2272 half-success (and fail explicitly).
2279 half-success (and fail explicitly).
2273
2280
2274 2006-03-28 Ville Vainio <vivainio@gmail.com>
2281 2006-03-28 Ville Vainio <vivainio@gmail.com>
2275
2282
2276 * iplib.py: Fix quoting of aliases so that only argless ones
2283 * iplib.py: Fix quoting of aliases so that only argless ones
2277 are quoted
2284 are quoted
2278
2285
2279 2006-03-28 Ville Vainio <vivainio@gmail.com>
2286 2006-03-28 Ville Vainio <vivainio@gmail.com>
2280
2287
2281 * iplib.py: Quote aliases with spaces in the name.
2288 * iplib.py: Quote aliases with spaces in the name.
2282 "c:\program files\blah\bin" is now legal alias target.
2289 "c:\program files\blah\bin" is now legal alias target.
2283
2290
2284 * ext_rehashdir.py: Space no longer allowed as arg
2291 * ext_rehashdir.py: Space no longer allowed as arg
2285 separator, since space is legal in path names.
2292 separator, since space is legal in path names.
2286
2293
2287 2006-03-16 Ville Vainio <vivainio@gmail.com>
2294 2006-03-16 Ville Vainio <vivainio@gmail.com>
2288
2295
2289 * upgrade_dir.py: Take path.py from Extensions, correcting
2296 * upgrade_dir.py: Take path.py from Extensions, correcting
2290 %upgrade magic
2297 %upgrade magic
2291
2298
2292 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
2299 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
2293
2300
2294 * hooks.py: Only enclose editor binary in quotes if legal and
2301 * hooks.py: Only enclose editor binary in quotes if legal and
2295 necessary (space in the name, and is an existing file). Fixes a bug
2302 necessary (space in the name, and is an existing file). Fixes a bug
2296 reported by Zachary Pincus.
2303 reported by Zachary Pincus.
2297
2304
2298 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
2305 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
2299
2306
2300 * Manual: thanks to a tip on proper color handling for Emacs, by
2307 * Manual: thanks to a tip on proper color handling for Emacs, by
2301 Eric J Haywiser <ejh1-AT-MIT.EDU>.
2308 Eric J Haywiser <ejh1-AT-MIT.EDU>.
2302
2309
2303 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
2310 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
2304 by applying the provided patch. Thanks to Liu Jin
2311 by applying the provided patch. Thanks to Liu Jin
2305 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
2312 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
2306 XEmacs/Linux, I'm trusting the submitter that it actually helps
2313 XEmacs/Linux, I'm trusting the submitter that it actually helps
2307 under win32/GNU Emacs. Will revisit if any problems are reported.
2314 under win32/GNU Emacs. Will revisit if any problems are reported.
2308
2315
2309 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
2316 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
2310
2317
2311 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
2318 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
2312 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
2319 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
2313
2320
2314 2006-03-12 Ville Vainio <vivainio@gmail.com>
2321 2006-03-12 Ville Vainio <vivainio@gmail.com>
2315
2322
2316 * Magic.py (magic_timeit): Added %timeit magic, contributed by
2323 * Magic.py (magic_timeit): Added %timeit magic, contributed by
2317 Torsten Marek.
2324 Torsten Marek.
2318
2325
2319 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
2326 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
2320
2327
2321 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
2328 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
2322 line ranges works again.
2329 line ranges works again.
2323
2330
2324 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
2331 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
2325
2332
2326 * IPython/iplib.py (showtraceback): add back sys.last_traceback
2333 * IPython/iplib.py (showtraceback): add back sys.last_traceback
2327 and friends, after a discussion with Zach Pincus on ipython-user.
2334 and friends, after a discussion with Zach Pincus on ipython-user.
2328 I'm not 100% sure, but after thinking about it quite a bit, it may
2335 I'm not 100% sure, but after thinking about it quite a bit, it may
2329 be OK. Testing with the multithreaded shells didn't reveal any
2336 be OK. Testing with the multithreaded shells didn't reveal any
2330 problems, but let's keep an eye out.
2337 problems, but let's keep an eye out.
2331
2338
2332 In the process, I fixed a few things which were calling
2339 In the process, I fixed a few things which were calling
2333 self.InteractiveTB() directly (like safe_execfile), which is a
2340 self.InteractiveTB() directly (like safe_execfile), which is a
2334 mistake: ALL exception reporting should be done by calling
2341 mistake: ALL exception reporting should be done by calling
2335 self.showtraceback(), which handles state and tab-completion and
2342 self.showtraceback(), which handles state and tab-completion and
2336 more.
2343 more.
2337
2344
2338 2006-03-01 Ville Vainio <vivainio@gmail.com>
2345 2006-03-01 Ville Vainio <vivainio@gmail.com>
2339
2346
2340 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
2347 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
2341 To use, do "from ipipe import *".
2348 To use, do "from ipipe import *".
2342
2349
2343 2006-02-24 Ville Vainio <vivainio@gmail.com>
2350 2006-02-24 Ville Vainio <vivainio@gmail.com>
2344
2351
2345 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
2352 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
2346 "cleanly" and safely than the older upgrade mechanism.
2353 "cleanly" and safely than the older upgrade mechanism.
2347
2354
2348 2006-02-21 Ville Vainio <vivainio@gmail.com>
2355 2006-02-21 Ville Vainio <vivainio@gmail.com>
2349
2356
2350 * Magic.py: %save works again.
2357 * Magic.py: %save works again.
2351
2358
2352 2006-02-15 Ville Vainio <vivainio@gmail.com>
2359 2006-02-15 Ville Vainio <vivainio@gmail.com>
2353
2360
2354 * Magic.py: %Pprint works again
2361 * Magic.py: %Pprint works again
2355
2362
2356 * Extensions/ipy_sane_defaults.py: Provide everything provided
2363 * Extensions/ipy_sane_defaults.py: Provide everything provided
2357 in default ipythonrc, to make it possible to have a completely empty
2364 in default ipythonrc, to make it possible to have a completely empty
2358 ipythonrc (and thus completely rc-file free configuration)
2365 ipythonrc (and thus completely rc-file free configuration)
2359
2366
2360 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
2367 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
2361
2368
2362 * IPython/hooks.py (editor): quote the call to the editor command,
2369 * IPython/hooks.py (editor): quote the call to the editor command,
2363 to allow commands with spaces in them. Problem noted by watching
2370 to allow commands with spaces in them. Problem noted by watching
2364 Ian Oswald's video about textpad under win32 at
2371 Ian Oswald's video about textpad under win32 at
2365 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
2372 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
2366
2373
2367 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
2374 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
2368 describing magics (we haven't used @ for a loong time).
2375 describing magics (we haven't used @ for a loong time).
2369
2376
2370 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
2377 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
2371 contributed by marienz to close
2378 contributed by marienz to close
2372 http://www.scipy.net/roundup/ipython/issue53.
2379 http://www.scipy.net/roundup/ipython/issue53.
2373
2380
2374 2006-02-10 Ville Vainio <vivainio@gmail.com>
2381 2006-02-10 Ville Vainio <vivainio@gmail.com>
2375
2382
2376 * genutils.py: getoutput now works in win32 too
2383 * genutils.py: getoutput now works in win32 too
2377
2384
2378 * completer.py: alias and magic completion only invoked
2385 * completer.py: alias and magic completion only invoked
2379 at the first "item" in the line, to avoid "cd %store"
2386 at the first "item" in the line, to avoid "cd %store"
2380 nonsense.
2387 nonsense.
2381
2388
2382 2006-02-09 Ville Vainio <vivainio@gmail.com>
2389 2006-02-09 Ville Vainio <vivainio@gmail.com>
2383
2390
2384 * test/*: Added a unit testing framework (finally).
2391 * test/*: Added a unit testing framework (finally).
2385 '%run runtests.py' to run test_*.
2392 '%run runtests.py' to run test_*.
2386
2393
2387 * ipapi.py: Exposed runlines and set_custom_exc
2394 * ipapi.py: Exposed runlines and set_custom_exc
2388
2395
2389 2006-02-07 Ville Vainio <vivainio@gmail.com>
2396 2006-02-07 Ville Vainio <vivainio@gmail.com>
2390
2397
2391 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
2398 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
2392 instead use "f(1 2)" as before.
2399 instead use "f(1 2)" as before.
2393
2400
2394 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
2401 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
2395
2402
2396 * IPython/demo.py (IPythonDemo): Add new classes to the demo
2403 * IPython/demo.py (IPythonDemo): Add new classes to the demo
2397 facilities, for demos processed by the IPython input filter
2404 facilities, for demos processed by the IPython input filter
2398 (IPythonDemo), and for running a script one-line-at-a-time as a
2405 (IPythonDemo), and for running a script one-line-at-a-time as a
2399 demo, both for pure Python (LineDemo) and for IPython-processed
2406 demo, both for pure Python (LineDemo) and for IPython-processed
2400 input (IPythonLineDemo). After a request by Dave Kohel, from the
2407 input (IPythonLineDemo). After a request by Dave Kohel, from the
2401 SAGE team.
2408 SAGE team.
2402 (Demo.edit): added an edit() method to the demo objects, to edit
2409 (Demo.edit): added an edit() method to the demo objects, to edit
2403 the in-memory copy of the last executed block.
2410 the in-memory copy of the last executed block.
2404
2411
2405 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
2412 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
2406 processing to %edit, %macro and %save. These commands can now be
2413 processing to %edit, %macro and %save. These commands can now be
2407 invoked on the unprocessed input as it was typed by the user
2414 invoked on the unprocessed input as it was typed by the user
2408 (without any prefilters applied). After requests by the SAGE team
2415 (without any prefilters applied). After requests by the SAGE team
2409 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
2416 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
2410
2417
2411 2006-02-01 Ville Vainio <vivainio@gmail.com>
2418 2006-02-01 Ville Vainio <vivainio@gmail.com>
2412
2419
2413 * setup.py, eggsetup.py: easy_install ipython==dev works
2420 * setup.py, eggsetup.py: easy_install ipython==dev works
2414 correctly now (on Linux)
2421 correctly now (on Linux)
2415
2422
2416 * ipy_user_conf,ipmaker: user config changes, removed spurious
2423 * ipy_user_conf,ipmaker: user config changes, removed spurious
2417 warnings
2424 warnings
2418
2425
2419 * iplib: if rc.banner is string, use it as is.
2426 * iplib: if rc.banner is string, use it as is.
2420
2427
2421 * Magic: %pycat accepts a string argument and pages it's contents.
2428 * Magic: %pycat accepts a string argument and pages it's contents.
2422
2429
2423
2430
2424 2006-01-30 Ville Vainio <vivainio@gmail.com>
2431 2006-01-30 Ville Vainio <vivainio@gmail.com>
2425
2432
2426 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
2433 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
2427 Now %store and bookmarks work through PickleShare, meaning that
2434 Now %store and bookmarks work through PickleShare, meaning that
2428 concurrent access is possible and all ipython sessions see the
2435 concurrent access is possible and all ipython sessions see the
2429 same database situation all the time, instead of snapshot of
2436 same database situation all the time, instead of snapshot of
2430 the situation when the session was started. Hence, %bookmark
2437 the situation when the session was started. Hence, %bookmark
2431 results are immediately accessible from othes sessions. The database
2438 results are immediately accessible from othes sessions. The database
2432 is also available for use by user extensions. See:
2439 is also available for use by user extensions. See:
2433 http://www.python.org/pypi/pickleshare
2440 http://www.python.org/pypi/pickleshare
2434
2441
2435 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
2442 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
2436
2443
2437 * aliases can now be %store'd
2444 * aliases can now be %store'd
2438
2445
2439 * path.py moved to Extensions so that pickleshare does not need
2446 * path.py moved to Extensions so that pickleshare does not need
2440 IPython-specific import. Extensions added to pythonpath right
2447 IPython-specific import. Extensions added to pythonpath right
2441 at __init__.
2448 at __init__.
2442
2449
2443 * iplib.py: ipalias deprecated/redundant; aliases are converted and
2450 * iplib.py: ipalias deprecated/redundant; aliases are converted and
2444 called with _ip.system and the pre-transformed command string.
2451 called with _ip.system and the pre-transformed command string.
2445
2452
2446 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
2453 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
2447
2454
2448 * IPython/iplib.py (interact): Fix that we were not catching
2455 * IPython/iplib.py (interact): Fix that we were not catching
2449 KeyboardInterrupt exceptions properly. I'm not quite sure why the
2456 KeyboardInterrupt exceptions properly. I'm not quite sure why the
2450 logic here had to change, but it's fixed now.
2457 logic here had to change, but it's fixed now.
2451
2458
2452 2006-01-29 Ville Vainio <vivainio@gmail.com>
2459 2006-01-29 Ville Vainio <vivainio@gmail.com>
2453
2460
2454 * iplib.py: Try to import pyreadline on Windows.
2461 * iplib.py: Try to import pyreadline on Windows.
2455
2462
2456 2006-01-27 Ville Vainio <vivainio@gmail.com>
2463 2006-01-27 Ville Vainio <vivainio@gmail.com>
2457
2464
2458 * iplib.py: Expose ipapi as _ip in builtin namespace.
2465 * iplib.py: Expose ipapi as _ip in builtin namespace.
2459 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
2466 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
2460 and ip_set_hook (-> _ip.set_hook) redundant. % and !
2467 and ip_set_hook (-> _ip.set_hook) redundant. % and !
2461 syntax now produce _ip.* variant of the commands.
2468 syntax now produce _ip.* variant of the commands.
2462
2469
2463 * "_ip.options().autoedit_syntax = 2" automatically throws
2470 * "_ip.options().autoedit_syntax = 2" automatically throws
2464 user to editor for syntax error correction without prompting.
2471 user to editor for syntax error correction without prompting.
2465
2472
2466 2006-01-27 Ville Vainio <vivainio@gmail.com>
2473 2006-01-27 Ville Vainio <vivainio@gmail.com>
2467
2474
2468 * ipmaker.py: Give "realistic" sys.argv for scripts (without
2475 * ipmaker.py: Give "realistic" sys.argv for scripts (without
2469 'ipython' at argv[0]) executed through command line.
2476 'ipython' at argv[0]) executed through command line.
2470 NOTE: this DEPRECATES calling ipython with multiple scripts
2477 NOTE: this DEPRECATES calling ipython with multiple scripts
2471 ("ipython a.py b.py c.py")
2478 ("ipython a.py b.py c.py")
2472
2479
2473 * iplib.py, hooks.py: Added configurable input prefilter,
2480 * iplib.py, hooks.py: Added configurable input prefilter,
2474 named 'input_prefilter'. See ext_rescapture.py for example
2481 named 'input_prefilter'. See ext_rescapture.py for example
2475 usage.
2482 usage.
2476
2483
2477 * ext_rescapture.py, Magic.py: Better system command output capture
2484 * ext_rescapture.py, Magic.py: Better system command output capture
2478 through 'var = !ls' (deprecates user-visible %sc). Same notation
2485 through 'var = !ls' (deprecates user-visible %sc). Same notation
2479 applies for magics, 'var = %alias' assigns alias list to var.
2486 applies for magics, 'var = %alias' assigns alias list to var.
2480
2487
2481 * ipapi.py: added meta() for accessing extension-usable data store.
2488 * ipapi.py: added meta() for accessing extension-usable data store.
2482
2489
2483 * iplib.py: added InteractiveShell.getapi(). New magics should be
2490 * iplib.py: added InteractiveShell.getapi(). New magics should be
2484 written doing self.getapi() instead of using the shell directly.
2491 written doing self.getapi() instead of using the shell directly.
2485
2492
2486 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
2493 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
2487 %store foo >> ~/myfoo.txt to store variables to files (in clean
2494 %store foo >> ~/myfoo.txt to store variables to files (in clean
2488 textual form, not a restorable pickle).
2495 textual form, not a restorable pickle).
2489
2496
2490 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
2497 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
2491
2498
2492 * usage.py, Magic.py: added %quickref
2499 * usage.py, Magic.py: added %quickref
2493
2500
2494 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
2501 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
2495
2502
2496 * GetoptErrors when invoking magics etc. with wrong args
2503 * GetoptErrors when invoking magics etc. with wrong args
2497 are now more helpful:
2504 are now more helpful:
2498 GetoptError: option -l not recognized (allowed: "qb" )
2505 GetoptError: option -l not recognized (allowed: "qb" )
2499
2506
2500 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
2507 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
2501
2508
2502 * IPython/demo.py (Demo.show): Flush stdout after each block, so
2509 * IPython/demo.py (Demo.show): Flush stdout after each block, so
2503 computationally intensive blocks don't appear to stall the demo.
2510 computationally intensive blocks don't appear to stall the demo.
2504
2511
2505 2006-01-24 Ville Vainio <vivainio@gmail.com>
2512 2006-01-24 Ville Vainio <vivainio@gmail.com>
2506
2513
2507 * iplib.py, hooks.py: 'result_display' hook can return a non-None
2514 * iplib.py, hooks.py: 'result_display' hook can return a non-None
2508 value to manipulate resulting history entry.
2515 value to manipulate resulting history entry.
2509
2516
2510 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
2517 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
2511 to instance methods of IPApi class, to make extending an embedded
2518 to instance methods of IPApi class, to make extending an embedded
2512 IPython feasible. See ext_rehashdir.py for example usage.
2519 IPython feasible. See ext_rehashdir.py for example usage.
2513
2520
2514 * Merged 1071-1076 from branches/0.7.1
2521 * Merged 1071-1076 from branches/0.7.1
2515
2522
2516
2523
2517 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
2524 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
2518
2525
2519 * tools/release (daystamp): Fix build tools to use the new
2526 * tools/release (daystamp): Fix build tools to use the new
2520 eggsetup.py script to build lightweight eggs.
2527 eggsetup.py script to build lightweight eggs.
2521
2528
2522 * Applied changesets 1062 and 1064 before 0.7.1 release.
2529 * Applied changesets 1062 and 1064 before 0.7.1 release.
2523
2530
2524 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
2531 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
2525 see the raw input history (without conversions like %ls ->
2532 see the raw input history (without conversions like %ls ->
2526 ipmagic("ls")). After a request from W. Stein, SAGE
2533 ipmagic("ls")). After a request from W. Stein, SAGE
2527 (http://modular.ucsd.edu/sage) developer. This information is
2534 (http://modular.ucsd.edu/sage) developer. This information is
2528 stored in the input_hist_raw attribute of the IPython instance, so
2535 stored in the input_hist_raw attribute of the IPython instance, so
2529 developers can access it if needed (it's an InputList instance).
2536 developers can access it if needed (it's an InputList instance).
2530
2537
2531 * Versionstring = 0.7.2.svn
2538 * Versionstring = 0.7.2.svn
2532
2539
2533 * eggsetup.py: A separate script for constructing eggs, creates
2540 * eggsetup.py: A separate script for constructing eggs, creates
2534 proper launch scripts even on Windows (an .exe file in
2541 proper launch scripts even on Windows (an .exe file in
2535 \python24\scripts).
2542 \python24\scripts).
2536
2543
2537 * ipapi.py: launch_new_instance, launch entry point needed for the
2544 * ipapi.py: launch_new_instance, launch entry point needed for the
2538 egg.
2545 egg.
2539
2546
2540 2006-01-23 Ville Vainio <vivainio@gmail.com>
2547 2006-01-23 Ville Vainio <vivainio@gmail.com>
2541
2548
2542 * Added %cpaste magic for pasting python code
2549 * Added %cpaste magic for pasting python code
2543
2550
2544 2006-01-22 Ville Vainio <vivainio@gmail.com>
2551 2006-01-22 Ville Vainio <vivainio@gmail.com>
2545
2552
2546 * Merge from branches/0.7.1 into trunk, revs 1052-1057
2553 * Merge from branches/0.7.1 into trunk, revs 1052-1057
2547
2554
2548 * Versionstring = 0.7.2.svn
2555 * Versionstring = 0.7.2.svn
2549
2556
2550 * eggsetup.py: A separate script for constructing eggs, creates
2557 * eggsetup.py: A separate script for constructing eggs, creates
2551 proper launch scripts even on Windows (an .exe file in
2558 proper launch scripts even on Windows (an .exe file in
2552 \python24\scripts).
2559 \python24\scripts).
2553
2560
2554 * ipapi.py: launch_new_instance, launch entry point needed for the
2561 * ipapi.py: launch_new_instance, launch entry point needed for the
2555 egg.
2562 egg.
2556
2563
2557 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
2564 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
2558
2565
2559 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
2566 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
2560 %pfile foo would print the file for foo even if it was a binary.
2567 %pfile foo would print the file for foo even if it was a binary.
2561 Now, extensions '.so' and '.dll' are skipped.
2568 Now, extensions '.so' and '.dll' are skipped.
2562
2569
2563 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
2570 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
2564 bug, where macros would fail in all threaded modes. I'm not 100%
2571 bug, where macros would fail in all threaded modes. I'm not 100%
2565 sure, so I'm going to put out an rc instead of making a release
2572 sure, so I'm going to put out an rc instead of making a release
2566 today, and wait for feedback for at least a few days.
2573 today, and wait for feedback for at least a few days.
2567
2574
2568 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
2575 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
2569 it...) the handling of pasting external code with autoindent on.
2576 it...) the handling of pasting external code with autoindent on.
2570 To get out of a multiline input, the rule will appear for most
2577 To get out of a multiline input, the rule will appear for most
2571 users unchanged: two blank lines or change the indent level
2578 users unchanged: two blank lines or change the indent level
2572 proposed by IPython. But there is a twist now: you can
2579 proposed by IPython. But there is a twist now: you can
2573 add/subtract only *one or two spaces*. If you add/subtract three
2580 add/subtract only *one or two spaces*. If you add/subtract three
2574 or more (unless you completely delete the line), IPython will
2581 or more (unless you completely delete the line), IPython will
2575 accept that line, and you'll need to enter a second one of pure
2582 accept that line, and you'll need to enter a second one of pure
2576 whitespace. I know it sounds complicated, but I can't find a
2583 whitespace. I know it sounds complicated, but I can't find a
2577 different solution that covers all the cases, with the right
2584 different solution that covers all the cases, with the right
2578 heuristics. Hopefully in actual use, nobody will really notice
2585 heuristics. Hopefully in actual use, nobody will really notice
2579 all these strange rules and things will 'just work'.
2586 all these strange rules and things will 'just work'.
2580
2587
2581 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
2588 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
2582
2589
2583 * IPython/iplib.py (interact): catch exceptions which can be
2590 * IPython/iplib.py (interact): catch exceptions which can be
2584 triggered asynchronously by signal handlers. Thanks to an
2591 triggered asynchronously by signal handlers. Thanks to an
2585 automatic crash report, submitted by Colin Kingsley
2592 automatic crash report, submitted by Colin Kingsley
2586 <tercel-AT-gentoo.org>.
2593 <tercel-AT-gentoo.org>.
2587
2594
2588 2006-01-20 Ville Vainio <vivainio@gmail.com>
2595 2006-01-20 Ville Vainio <vivainio@gmail.com>
2589
2596
2590 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
2597 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
2591 (%rehashdir, very useful, try it out) of how to extend ipython
2598 (%rehashdir, very useful, try it out) of how to extend ipython
2592 with new magics. Also added Extensions dir to pythonpath to make
2599 with new magics. Also added Extensions dir to pythonpath to make
2593 importing extensions easy.
2600 importing extensions easy.
2594
2601
2595 * %store now complains when trying to store interactively declared
2602 * %store now complains when trying to store interactively declared
2596 classes / instances of those classes.
2603 classes / instances of those classes.
2597
2604
2598 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
2605 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
2599 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
2606 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
2600 if they exist, and ipy_user_conf.py with some defaults is created for
2607 if they exist, and ipy_user_conf.py with some defaults is created for
2601 the user.
2608 the user.
2602
2609
2603 * Startup rehashing done by the config file, not InterpreterExec.
2610 * Startup rehashing done by the config file, not InterpreterExec.
2604 This means system commands are available even without selecting the
2611 This means system commands are available even without selecting the
2605 pysh profile. It's the sensible default after all.
2612 pysh profile. It's the sensible default after all.
2606
2613
2607 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
2614 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
2608
2615
2609 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
2616 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
2610 multiline code with autoindent on working. But I am really not
2617 multiline code with autoindent on working. But I am really not
2611 sure, so this needs more testing. Will commit a debug-enabled
2618 sure, so this needs more testing. Will commit a debug-enabled
2612 version for now, while I test it some more, so that Ville and
2619 version for now, while I test it some more, so that Ville and
2613 others may also catch any problems. Also made
2620 others may also catch any problems. Also made
2614 self.indent_current_str() a method, to ensure that there's no
2621 self.indent_current_str() a method, to ensure that there's no
2615 chance of the indent space count and the corresponding string
2622 chance of the indent space count and the corresponding string
2616 falling out of sync. All code needing the string should just call
2623 falling out of sync. All code needing the string should just call
2617 the method.
2624 the method.
2618
2625
2619 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
2626 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
2620
2627
2621 * IPython/Magic.py (magic_edit): fix check for when users don't
2628 * IPython/Magic.py (magic_edit): fix check for when users don't
2622 save their output files, the try/except was in the wrong section.
2629 save their output files, the try/except was in the wrong section.
2623
2630
2624 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
2631 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
2625
2632
2626 * IPython/Magic.py (magic_run): fix __file__ global missing from
2633 * IPython/Magic.py (magic_run): fix __file__ global missing from
2627 script's namespace when executed via %run. After a report by
2634 script's namespace when executed via %run. After a report by
2628 Vivian.
2635 Vivian.
2629
2636
2630 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
2637 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
2631 when using python 2.4. The parent constructor changed in 2.4, and
2638 when using python 2.4. The parent constructor changed in 2.4, and
2632 we need to track it directly (we can't call it, as it messes up
2639 we need to track it directly (we can't call it, as it messes up
2633 readline and tab-completion inside our pdb would stop working).
2640 readline and tab-completion inside our pdb would stop working).
2634 After a bug report by R. Bernstein <rocky-AT-panix.com>.
2641 After a bug report by R. Bernstein <rocky-AT-panix.com>.
2635
2642
2636 2006-01-16 Ville Vainio <vivainio@gmail.com>
2643 2006-01-16 Ville Vainio <vivainio@gmail.com>
2637
2644
2638 * Ipython/magic.py: Reverted back to old %edit functionality
2645 * Ipython/magic.py: Reverted back to old %edit functionality
2639 that returns file contents on exit.
2646 that returns file contents on exit.
2640
2647
2641 * IPython/path.py: Added Jason Orendorff's "path" module to
2648 * IPython/path.py: Added Jason Orendorff's "path" module to
2642 IPython tree, http://www.jorendorff.com/articles/python/path/.
2649 IPython tree, http://www.jorendorff.com/articles/python/path/.
2643 You can get path objects conveniently through %sc, and !!, e.g.:
2650 You can get path objects conveniently through %sc, and !!, e.g.:
2644 sc files=ls
2651 sc files=ls
2645 for p in files.paths: # or files.p
2652 for p in files.paths: # or files.p
2646 print p,p.mtime
2653 print p,p.mtime
2647
2654
2648 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
2655 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
2649 now work again without considering the exclusion regexp -
2656 now work again without considering the exclusion regexp -
2650 hence, things like ',foo my/path' turn to 'foo("my/path")'
2657 hence, things like ',foo my/path' turn to 'foo("my/path")'
2651 instead of syntax error.
2658 instead of syntax error.
2652
2659
2653
2660
2654 2006-01-14 Ville Vainio <vivainio@gmail.com>
2661 2006-01-14 Ville Vainio <vivainio@gmail.com>
2655
2662
2656 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
2663 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
2657 ipapi decorators for python 2.4 users, options() provides access to rc
2664 ipapi decorators for python 2.4 users, options() provides access to rc
2658 data.
2665 data.
2659
2666
2660 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
2667 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
2661 as path separators (even on Linux ;-). Space character after
2668 as path separators (even on Linux ;-). Space character after
2662 backslash (as yielded by tab completer) is still space;
2669 backslash (as yielded by tab completer) is still space;
2663 "%cd long\ name" works as expected.
2670 "%cd long\ name" works as expected.
2664
2671
2665 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
2672 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
2666 as "chain of command", with priority. API stays the same,
2673 as "chain of command", with priority. API stays the same,
2667 TryNext exception raised by a hook function signals that
2674 TryNext exception raised by a hook function signals that
2668 current hook failed and next hook should try handling it, as
2675 current hook failed and next hook should try handling it, as
2669 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
2676 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
2670 requested configurable display hook, which is now implemented.
2677 requested configurable display hook, which is now implemented.
2671
2678
2672 2006-01-13 Ville Vainio <vivainio@gmail.com>
2679 2006-01-13 Ville Vainio <vivainio@gmail.com>
2673
2680
2674 * IPython/platutils*.py: platform specific utility functions,
2681 * IPython/platutils*.py: platform specific utility functions,
2675 so far only set_term_title is implemented (change terminal
2682 so far only set_term_title is implemented (change terminal
2676 label in windowing systems). %cd now changes the title to
2683 label in windowing systems). %cd now changes the title to
2677 current dir.
2684 current dir.
2678
2685
2679 * IPython/Release.py: Added myself to "authors" list,
2686 * IPython/Release.py: Added myself to "authors" list,
2680 had to create new files.
2687 had to create new files.
2681
2688
2682 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
2689 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
2683 shell escape; not a known bug but had potential to be one in the
2690 shell escape; not a known bug but had potential to be one in the
2684 future.
2691 future.
2685
2692
2686 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
2693 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
2687 extension API for IPython! See the module for usage example. Fix
2694 extension API for IPython! See the module for usage example. Fix
2688 OInspect for docstring-less magic functions.
2695 OInspect for docstring-less magic functions.
2689
2696
2690
2697
2691 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
2698 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
2692
2699
2693 * IPython/iplib.py (raw_input): temporarily deactivate all
2700 * IPython/iplib.py (raw_input): temporarily deactivate all
2694 attempts at allowing pasting of code with autoindent on. It
2701 attempts at allowing pasting of code with autoindent on. It
2695 introduced bugs (reported by Prabhu) and I can't seem to find a
2702 introduced bugs (reported by Prabhu) and I can't seem to find a
2696 robust combination which works in all cases. Will have to revisit
2703 robust combination which works in all cases. Will have to revisit
2697 later.
2704 later.
2698
2705
2699 * IPython/genutils.py: remove isspace() function. We've dropped
2706 * IPython/genutils.py: remove isspace() function. We've dropped
2700 2.2 compatibility, so it's OK to use the string method.
2707 2.2 compatibility, so it's OK to use the string method.
2701
2708
2702 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
2709 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
2703
2710
2704 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
2711 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
2705 matching what NOT to autocall on, to include all python binary
2712 matching what NOT to autocall on, to include all python binary
2706 operators (including things like 'and', 'or', 'is' and 'in').
2713 operators (including things like 'and', 'or', 'is' and 'in').
2707 Prompted by a bug report on 'foo & bar', but I realized we had
2714 Prompted by a bug report on 'foo & bar', but I realized we had
2708 many more potential bug cases with other operators. The regexp is
2715 many more potential bug cases with other operators. The regexp is
2709 self.re_exclude_auto, it's fairly commented.
2716 self.re_exclude_auto, it's fairly commented.
2710
2717
2711 2006-01-12 Ville Vainio <vivainio@gmail.com>
2718 2006-01-12 Ville Vainio <vivainio@gmail.com>
2712
2719
2713 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
2720 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
2714 Prettified and hardened string/backslash quoting with ipsystem(),
2721 Prettified and hardened string/backslash quoting with ipsystem(),
2715 ipalias() and ipmagic(). Now even \ characters are passed to
2722 ipalias() and ipmagic(). Now even \ characters are passed to
2716 %magics, !shell escapes and aliases exactly as they are in the
2723 %magics, !shell escapes and aliases exactly as they are in the
2717 ipython command line. Should improve backslash experience,
2724 ipython command line. Should improve backslash experience,
2718 particularly in Windows (path delimiter for some commands that
2725 particularly in Windows (path delimiter for some commands that
2719 won't understand '/'), but Unix benefits as well (regexps). %cd
2726 won't understand '/'), but Unix benefits as well (regexps). %cd
2720 magic still doesn't support backslash path delimiters, though. Also
2727 magic still doesn't support backslash path delimiters, though. Also
2721 deleted all pretense of supporting multiline command strings in
2728 deleted all pretense of supporting multiline command strings in
2722 !system or %magic commands. Thanks to Jerry McRae for suggestions.
2729 !system or %magic commands. Thanks to Jerry McRae for suggestions.
2723
2730
2724 * doc/build_doc_instructions.txt added. Documentation on how to
2731 * doc/build_doc_instructions.txt added. Documentation on how to
2725 use doc/update_manual.py, added yesterday. Both files contributed
2732 use doc/update_manual.py, added yesterday. Both files contributed
2726 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
2733 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
2727 doc/*.sh for deprecation at a later date.
2734 doc/*.sh for deprecation at a later date.
2728
2735
2729 * /ipython.py Added ipython.py to root directory for
2736 * /ipython.py Added ipython.py to root directory for
2730 zero-installation (tar xzvf ipython.tgz; cd ipython; python
2737 zero-installation (tar xzvf ipython.tgz; cd ipython; python
2731 ipython.py) and development convenience (no need to keep doing
2738 ipython.py) and development convenience (no need to keep doing
2732 "setup.py install" between changes).
2739 "setup.py install" between changes).
2733
2740
2734 * Made ! and !! shell escapes work (again) in multiline expressions:
2741 * Made ! and !! shell escapes work (again) in multiline expressions:
2735 if 1:
2742 if 1:
2736 !ls
2743 !ls
2737 !!ls
2744 !!ls
2738
2745
2739 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
2746 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
2740
2747
2741 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
2748 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
2742 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
2749 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
2743 module in case-insensitive installation. Was causing crashes
2750 module in case-insensitive installation. Was causing crashes
2744 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
2751 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
2745
2752
2746 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
2753 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
2747 <marienz-AT-gentoo.org>, closes
2754 <marienz-AT-gentoo.org>, closes
2748 http://www.scipy.net/roundup/ipython/issue51.
2755 http://www.scipy.net/roundup/ipython/issue51.
2749
2756
2750 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
2757 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
2751
2758
2752 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
2759 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
2753 problem of excessive CPU usage under *nix and keyboard lag under
2760 problem of excessive CPU usage under *nix and keyboard lag under
2754 win32.
2761 win32.
2755
2762
2756 2006-01-10 *** Released version 0.7.0
2763 2006-01-10 *** Released version 0.7.0
2757
2764
2758 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
2765 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
2759
2766
2760 * IPython/Release.py (revision): tag version number to 0.7.0,
2767 * IPython/Release.py (revision): tag version number to 0.7.0,
2761 ready for release.
2768 ready for release.
2762
2769
2763 * IPython/Magic.py (magic_edit): Add print statement to %edit so
2770 * IPython/Magic.py (magic_edit): Add print statement to %edit so
2764 it informs the user of the name of the temp. file used. This can
2771 it informs the user of the name of the temp. file used. This can
2765 help if you decide later to reuse that same file, so you know
2772 help if you decide later to reuse that same file, so you know
2766 where to copy the info from.
2773 where to copy the info from.
2767
2774
2768 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
2775 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
2769
2776
2770 * setup_bdist_egg.py: little script to build an egg. Added
2777 * setup_bdist_egg.py: little script to build an egg. Added
2771 support in the release tools as well.
2778 support in the release tools as well.
2772
2779
2773 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
2780 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
2774
2781
2775 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
2782 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
2776 version selection (new -wxversion command line and ipythonrc
2783 version selection (new -wxversion command line and ipythonrc
2777 parameter). Patch contributed by Arnd Baecker
2784 parameter). Patch contributed by Arnd Baecker
2778 <arnd.baecker-AT-web.de>.
2785 <arnd.baecker-AT-web.de>.
2779
2786
2780 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2787 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2781 embedded instances, for variables defined at the interactive
2788 embedded instances, for variables defined at the interactive
2782 prompt of the embedded ipython. Reported by Arnd.
2789 prompt of the embedded ipython. Reported by Arnd.
2783
2790
2784 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
2791 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
2785 it can be used as a (stateful) toggle, or with a direct parameter.
2792 it can be used as a (stateful) toggle, or with a direct parameter.
2786
2793
2787 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
2794 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
2788 could be triggered in certain cases and cause the traceback
2795 could be triggered in certain cases and cause the traceback
2789 printer not to work.
2796 printer not to work.
2790
2797
2791 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
2798 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
2792
2799
2793 * IPython/iplib.py (_should_recompile): Small fix, closes
2800 * IPython/iplib.py (_should_recompile): Small fix, closes
2794 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
2801 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
2795
2802
2796 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
2803 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
2797
2804
2798 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
2805 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
2799 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
2806 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
2800 Moad for help with tracking it down.
2807 Moad for help with tracking it down.
2801
2808
2802 * IPython/iplib.py (handle_auto): fix autocall handling for
2809 * IPython/iplib.py (handle_auto): fix autocall handling for
2803 objects which support BOTH __getitem__ and __call__ (so that f [x]
2810 objects which support BOTH __getitem__ and __call__ (so that f [x]
2804 is left alone, instead of becoming f([x]) automatically).
2811 is left alone, instead of becoming f([x]) automatically).
2805
2812
2806 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
2813 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
2807 Ville's patch.
2814 Ville's patch.
2808
2815
2809 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
2816 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
2810
2817
2811 * IPython/iplib.py (handle_auto): changed autocall semantics to
2818 * IPython/iplib.py (handle_auto): changed autocall semantics to
2812 include 'smart' mode, where the autocall transformation is NOT
2819 include 'smart' mode, where the autocall transformation is NOT
2813 applied if there are no arguments on the line. This allows you to
2820 applied if there are no arguments on the line. This allows you to
2814 just type 'foo' if foo is a callable to see its internal form,
2821 just type 'foo' if foo is a callable to see its internal form,
2815 instead of having it called with no arguments (typically a
2822 instead of having it called with no arguments (typically a
2816 mistake). The old 'full' autocall still exists: for that, you
2823 mistake). The old 'full' autocall still exists: for that, you
2817 need to set the 'autocall' parameter to 2 in your ipythonrc file.
2824 need to set the 'autocall' parameter to 2 in your ipythonrc file.
2818
2825
2819 * IPython/completer.py (Completer.attr_matches): add
2826 * IPython/completer.py (Completer.attr_matches): add
2820 tab-completion support for Enthoughts' traits. After a report by
2827 tab-completion support for Enthoughts' traits. After a report by
2821 Arnd and a patch by Prabhu.
2828 Arnd and a patch by Prabhu.
2822
2829
2823 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
2830 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
2824
2831
2825 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
2832 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
2826 Schmolck's patch to fix inspect.getinnerframes().
2833 Schmolck's patch to fix inspect.getinnerframes().
2827
2834
2828 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
2835 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
2829 for embedded instances, regarding handling of namespaces and items
2836 for embedded instances, regarding handling of namespaces and items
2830 added to the __builtin__ one. Multiple embedded instances and
2837 added to the __builtin__ one. Multiple embedded instances and
2831 recursive embeddings should work better now (though I'm not sure
2838 recursive embeddings should work better now (though I'm not sure
2832 I've got all the corner cases fixed, that code is a bit of a brain
2839 I've got all the corner cases fixed, that code is a bit of a brain
2833 twister).
2840 twister).
2834
2841
2835 * IPython/Magic.py (magic_edit): added support to edit in-memory
2842 * IPython/Magic.py (magic_edit): added support to edit in-memory
2836 macros (automatically creates the necessary temp files). %edit
2843 macros (automatically creates the necessary temp files). %edit
2837 also doesn't return the file contents anymore, it's just noise.
2844 also doesn't return the file contents anymore, it's just noise.
2838
2845
2839 * IPython/completer.py (Completer.attr_matches): revert change to
2846 * IPython/completer.py (Completer.attr_matches): revert change to
2840 complete only on attributes listed in __all__. I realized it
2847 complete only on attributes listed in __all__. I realized it
2841 cripples the tab-completion system as a tool for exploring the
2848 cripples the tab-completion system as a tool for exploring the
2842 internals of unknown libraries (it renders any non-__all__
2849 internals of unknown libraries (it renders any non-__all__
2843 attribute off-limits). I got bit by this when trying to see
2850 attribute off-limits). I got bit by this when trying to see
2844 something inside the dis module.
2851 something inside the dis module.
2845
2852
2846 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
2853 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
2847
2854
2848 * IPython/iplib.py (InteractiveShell.__init__): add .meta
2855 * IPython/iplib.py (InteractiveShell.__init__): add .meta
2849 namespace for users and extension writers to hold data in. This
2856 namespace for users and extension writers to hold data in. This
2850 follows the discussion in
2857 follows the discussion in
2851 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
2858 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
2852
2859
2853 * IPython/completer.py (IPCompleter.complete): small patch to help
2860 * IPython/completer.py (IPCompleter.complete): small patch to help
2854 tab-completion under Emacs, after a suggestion by John Barnard
2861 tab-completion under Emacs, after a suggestion by John Barnard
2855 <barnarj-AT-ccf.org>.
2862 <barnarj-AT-ccf.org>.
2856
2863
2857 * IPython/Magic.py (Magic.extract_input_slices): added support for
2864 * IPython/Magic.py (Magic.extract_input_slices): added support for
2858 the slice notation in magics to use N-M to represent numbers N...M
2865 the slice notation in magics to use N-M to represent numbers N...M
2859 (closed endpoints). This is used by %macro and %save.
2866 (closed endpoints). This is used by %macro and %save.
2860
2867
2861 * IPython/completer.py (Completer.attr_matches): for modules which
2868 * IPython/completer.py (Completer.attr_matches): for modules which
2862 define __all__, complete only on those. After a patch by Jeffrey
2869 define __all__, complete only on those. After a patch by Jeffrey
2863 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
2870 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
2864 speed up this routine.
2871 speed up this routine.
2865
2872
2866 * IPython/Logger.py (Logger.log): fix a history handling bug. I
2873 * IPython/Logger.py (Logger.log): fix a history handling bug. I
2867 don't know if this is the end of it, but the behavior now is
2874 don't know if this is the end of it, but the behavior now is
2868 certainly much more correct. Note that coupled with macros,
2875 certainly much more correct. Note that coupled with macros,
2869 slightly surprising (at first) behavior may occur: a macro will in
2876 slightly surprising (at first) behavior may occur: a macro will in
2870 general expand to multiple lines of input, so upon exiting, the
2877 general expand to multiple lines of input, so upon exiting, the
2871 in/out counters will both be bumped by the corresponding amount
2878 in/out counters will both be bumped by the corresponding amount
2872 (as if the macro's contents had been typed interactively). Typing
2879 (as if the macro's contents had been typed interactively). Typing
2873 %hist will reveal the intermediate (silently processed) lines.
2880 %hist will reveal the intermediate (silently processed) lines.
2874
2881
2875 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
2882 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
2876 pickle to fail (%run was overwriting __main__ and not restoring
2883 pickle to fail (%run was overwriting __main__ and not restoring
2877 it, but pickle relies on __main__ to operate).
2884 it, but pickle relies on __main__ to operate).
2878
2885
2879 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
2886 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
2880 using properties, but forgot to make the main InteractiveShell
2887 using properties, but forgot to make the main InteractiveShell
2881 class a new-style class. Properties fail silently, and
2888 class a new-style class. Properties fail silently, and
2882 mysteriously, with old-style class (getters work, but
2889 mysteriously, with old-style class (getters work, but
2883 setters don't do anything).
2890 setters don't do anything).
2884
2891
2885 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
2892 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
2886
2893
2887 * IPython/Magic.py (magic_history): fix history reporting bug (I
2894 * IPython/Magic.py (magic_history): fix history reporting bug (I
2888 know some nasties are still there, I just can't seem to find a
2895 know some nasties are still there, I just can't seem to find a
2889 reproducible test case to track them down; the input history is
2896 reproducible test case to track them down; the input history is
2890 falling out of sync...)
2897 falling out of sync...)
2891
2898
2892 * IPython/iplib.py (handle_shell_escape): fix bug where both
2899 * IPython/iplib.py (handle_shell_escape): fix bug where both
2893 aliases and system accesses where broken for indented code (such
2900 aliases and system accesses where broken for indented code (such
2894 as loops).
2901 as loops).
2895
2902
2896 * IPython/genutils.py (shell): fix small but critical bug for
2903 * IPython/genutils.py (shell): fix small but critical bug for
2897 win32 system access.
2904 win32 system access.
2898
2905
2899 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
2906 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
2900
2907
2901 * IPython/iplib.py (showtraceback): remove use of the
2908 * IPython/iplib.py (showtraceback): remove use of the
2902 sys.last_{type/value/traceback} structures, which are non
2909 sys.last_{type/value/traceback} structures, which are non
2903 thread-safe.
2910 thread-safe.
2904 (_prefilter): change control flow to ensure that we NEVER
2911 (_prefilter): change control flow to ensure that we NEVER
2905 introspect objects when autocall is off. This will guarantee that
2912 introspect objects when autocall is off. This will guarantee that
2906 having an input line of the form 'x.y', where access to attribute
2913 having an input line of the form 'x.y', where access to attribute
2907 'y' has side effects, doesn't trigger the side effect TWICE. It
2914 'y' has side effects, doesn't trigger the side effect TWICE. It
2908 is important to note that, with autocall on, these side effects
2915 is important to note that, with autocall on, these side effects
2909 can still happen.
2916 can still happen.
2910 (ipsystem): new builtin, to complete the ip{magic/alias/system}
2917 (ipsystem): new builtin, to complete the ip{magic/alias/system}
2911 trio. IPython offers these three kinds of special calls which are
2918 trio. IPython offers these three kinds of special calls which are
2912 not python code, and it's a good thing to have their call method
2919 not python code, and it's a good thing to have their call method
2913 be accessible as pure python functions (not just special syntax at
2920 be accessible as pure python functions (not just special syntax at
2914 the command line). It gives us a better internal implementation
2921 the command line). It gives us a better internal implementation
2915 structure, as well as exposing these for user scripting more
2922 structure, as well as exposing these for user scripting more
2916 cleanly.
2923 cleanly.
2917
2924
2918 * IPython/macro.py (Macro.__init__): moved macros to a standalone
2925 * IPython/macro.py (Macro.__init__): moved macros to a standalone
2919 file. Now that they'll be more likely to be used with the
2926 file. Now that they'll be more likely to be used with the
2920 persistance system (%store), I want to make sure their module path
2927 persistance system (%store), I want to make sure their module path
2921 doesn't change in the future, so that we don't break things for
2928 doesn't change in the future, so that we don't break things for
2922 users' persisted data.
2929 users' persisted data.
2923
2930
2924 * IPython/iplib.py (autoindent_update): move indentation
2931 * IPython/iplib.py (autoindent_update): move indentation
2925 management into the _text_ processing loop, not the keyboard
2932 management into the _text_ processing loop, not the keyboard
2926 interactive one. This is necessary to correctly process non-typed
2933 interactive one. This is necessary to correctly process non-typed
2927 multiline input (such as macros).
2934 multiline input (such as macros).
2928
2935
2929 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
2936 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
2930 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
2937 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
2931 which was producing problems in the resulting manual.
2938 which was producing problems in the resulting manual.
2932 (magic_whos): improve reporting of instances (show their class,
2939 (magic_whos): improve reporting of instances (show their class,
2933 instead of simply printing 'instance' which isn't terribly
2940 instead of simply printing 'instance' which isn't terribly
2934 informative).
2941 informative).
2935
2942
2936 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
2943 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
2937 (minor mods) to support network shares under win32.
2944 (minor mods) to support network shares under win32.
2938
2945
2939 * IPython/winconsole.py (get_console_size): add new winconsole
2946 * IPython/winconsole.py (get_console_size): add new winconsole
2940 module and fixes to page_dumb() to improve its behavior under
2947 module and fixes to page_dumb() to improve its behavior under
2941 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
2948 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
2942
2949
2943 * IPython/Magic.py (Macro): simplified Macro class to just
2950 * IPython/Magic.py (Macro): simplified Macro class to just
2944 subclass list. We've had only 2.2 compatibility for a very long
2951 subclass list. We've had only 2.2 compatibility for a very long
2945 time, yet I was still avoiding subclassing the builtin types. No
2952 time, yet I was still avoiding subclassing the builtin types. No
2946 more (I'm also starting to use properties, though I won't shift to
2953 more (I'm also starting to use properties, though I won't shift to
2947 2.3-specific features quite yet).
2954 2.3-specific features quite yet).
2948 (magic_store): added Ville's patch for lightweight variable
2955 (magic_store): added Ville's patch for lightweight variable
2949 persistence, after a request on the user list by Matt Wilkie
2956 persistence, after a request on the user list by Matt Wilkie
2950 <maphew-AT-gmail.com>. The new %store magic's docstring has full
2957 <maphew-AT-gmail.com>. The new %store magic's docstring has full
2951 details.
2958 details.
2952
2959
2953 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2960 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2954 changed the default logfile name from 'ipython.log' to
2961 changed the default logfile name from 'ipython.log' to
2955 'ipython_log.py'. These logs are real python files, and now that
2962 'ipython_log.py'. These logs are real python files, and now that
2956 we have much better multiline support, people are more likely to
2963 we have much better multiline support, people are more likely to
2957 want to use them as such. Might as well name them correctly.
2964 want to use them as such. Might as well name them correctly.
2958
2965
2959 * IPython/Magic.py: substantial cleanup. While we can't stop
2966 * IPython/Magic.py: substantial cleanup. While we can't stop
2960 using magics as mixins, due to the existing customizations 'out
2967 using magics as mixins, due to the existing customizations 'out
2961 there' which rely on the mixin naming conventions, at least I
2968 there' which rely on the mixin naming conventions, at least I
2962 cleaned out all cross-class name usage. So once we are OK with
2969 cleaned out all cross-class name usage. So once we are OK with
2963 breaking compatibility, the two systems can be separated.
2970 breaking compatibility, the two systems can be separated.
2964
2971
2965 * IPython/Logger.py: major cleanup. This one is NOT a mixin
2972 * IPython/Logger.py: major cleanup. This one is NOT a mixin
2966 anymore, and the class is a fair bit less hideous as well. New
2973 anymore, and the class is a fair bit less hideous as well. New
2967 features were also introduced: timestamping of input, and logging
2974 features were also introduced: timestamping of input, and logging
2968 of output results. These are user-visible with the -t and -o
2975 of output results. These are user-visible with the -t and -o
2969 options to %logstart. Closes
2976 options to %logstart. Closes
2970 http://www.scipy.net/roundup/ipython/issue11 and a request by
2977 http://www.scipy.net/roundup/ipython/issue11 and a request by
2971 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
2978 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
2972
2979
2973 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
2980 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
2974
2981
2975 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
2982 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
2976 better handle backslashes in paths. See the thread 'More Windows
2983 better handle backslashes in paths. See the thread 'More Windows
2977 questions part 2 - \/ characters revisited' on the iypthon user
2984 questions part 2 - \/ characters revisited' on the iypthon user
2978 list:
2985 list:
2979 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
2986 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
2980
2987
2981 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
2988 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
2982
2989
2983 (InteractiveShell.__init__): change threaded shells to not use the
2990 (InteractiveShell.__init__): change threaded shells to not use the
2984 ipython crash handler. This was causing more problems than not,
2991 ipython crash handler. This was causing more problems than not,
2985 as exceptions in the main thread (GUI code, typically) would
2992 as exceptions in the main thread (GUI code, typically) would
2986 always show up as a 'crash', when they really weren't.
2993 always show up as a 'crash', when they really weren't.
2987
2994
2988 The colors and exception mode commands (%colors/%xmode) have been
2995 The colors and exception mode commands (%colors/%xmode) have been
2989 synchronized to also take this into account, so users can get
2996 synchronized to also take this into account, so users can get
2990 verbose exceptions for their threaded code as well. I also added
2997 verbose exceptions for their threaded code as well. I also added
2991 support for activating pdb inside this exception handler as well,
2998 support for activating pdb inside this exception handler as well,
2992 so now GUI authors can use IPython's enhanced pdb at runtime.
2999 so now GUI authors can use IPython's enhanced pdb at runtime.
2993
3000
2994 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
3001 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
2995 true by default, and add it to the shipped ipythonrc file. Since
3002 true by default, and add it to the shipped ipythonrc file. Since
2996 this asks the user before proceeding, I think it's OK to make it
3003 this asks the user before proceeding, I think it's OK to make it
2997 true by default.
3004 true by default.
2998
3005
2999 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
3006 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
3000 of the previous special-casing of input in the eval loop. I think
3007 of the previous special-casing of input in the eval loop. I think
3001 this is cleaner, as they really are commands and shouldn't have
3008 this is cleaner, as they really are commands and shouldn't have
3002 a special role in the middle of the core code.
3009 a special role in the middle of the core code.
3003
3010
3004 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
3011 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
3005
3012
3006 * IPython/iplib.py (edit_syntax_error): added support for
3013 * IPython/iplib.py (edit_syntax_error): added support for
3007 automatically reopening the editor if the file had a syntax error
3014 automatically reopening the editor if the file had a syntax error
3008 in it. Thanks to scottt who provided the patch at:
3015 in it. Thanks to scottt who provided the patch at:
3009 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
3016 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
3010 version committed).
3017 version committed).
3011
3018
3012 * IPython/iplib.py (handle_normal): add suport for multi-line
3019 * IPython/iplib.py (handle_normal): add suport for multi-line
3013 input with emtpy lines. This fixes
3020 input with emtpy lines. This fixes
3014 http://www.scipy.net/roundup/ipython/issue43 and a similar
3021 http://www.scipy.net/roundup/ipython/issue43 and a similar
3015 discussion on the user list.
3022 discussion on the user list.
3016
3023
3017 WARNING: a behavior change is necessarily introduced to support
3024 WARNING: a behavior change is necessarily introduced to support
3018 blank lines: now a single blank line with whitespace does NOT
3025 blank lines: now a single blank line with whitespace does NOT
3019 break the input loop, which means that when autoindent is on, by
3026 break the input loop, which means that when autoindent is on, by
3020 default hitting return on the next (indented) line does NOT exit.
3027 default hitting return on the next (indented) line does NOT exit.
3021
3028
3022 Instead, to exit a multiline input you can either have:
3029 Instead, to exit a multiline input you can either have:
3023
3030
3024 - TWO whitespace lines (just hit return again), or
3031 - TWO whitespace lines (just hit return again), or
3025 - a single whitespace line of a different length than provided
3032 - a single whitespace line of a different length than provided
3026 by the autoindent (add or remove a space).
3033 by the autoindent (add or remove a space).
3027
3034
3028 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
3035 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
3029 module to better organize all readline-related functionality.
3036 module to better organize all readline-related functionality.
3030 I've deleted FlexCompleter and put all completion clases here.
3037 I've deleted FlexCompleter and put all completion clases here.
3031
3038
3032 * IPython/iplib.py (raw_input): improve indentation management.
3039 * IPython/iplib.py (raw_input): improve indentation management.
3033 It is now possible to paste indented code with autoindent on, and
3040 It is now possible to paste indented code with autoindent on, and
3034 the code is interpreted correctly (though it still looks bad on
3041 the code is interpreted correctly (though it still looks bad on
3035 screen, due to the line-oriented nature of ipython).
3042 screen, due to the line-oriented nature of ipython).
3036 (MagicCompleter.complete): change behavior so that a TAB key on an
3043 (MagicCompleter.complete): change behavior so that a TAB key on an
3037 otherwise empty line actually inserts a tab, instead of completing
3044 otherwise empty line actually inserts a tab, instead of completing
3038 on the entire global namespace. This makes it easier to use the
3045 on the entire global namespace. This makes it easier to use the
3039 TAB key for indentation. After a request by Hans Meine
3046 TAB key for indentation. After a request by Hans Meine
3040 <hans_meine-AT-gmx.net>
3047 <hans_meine-AT-gmx.net>
3041 (_prefilter): add support so that typing plain 'exit' or 'quit'
3048 (_prefilter): add support so that typing plain 'exit' or 'quit'
3042 does a sensible thing. Originally I tried to deviate as little as
3049 does a sensible thing. Originally I tried to deviate as little as
3043 possible from the default python behavior, but even that one may
3050 possible from the default python behavior, but even that one may
3044 change in this direction (thread on python-dev to that effect).
3051 change in this direction (thread on python-dev to that effect).
3045 Regardless, ipython should do the right thing even if CPython's
3052 Regardless, ipython should do the right thing even if CPython's
3046 '>>>' prompt doesn't.
3053 '>>>' prompt doesn't.
3047 (InteractiveShell): removed subclassing code.InteractiveConsole
3054 (InteractiveShell): removed subclassing code.InteractiveConsole
3048 class. By now we'd overridden just about all of its methods: I've
3055 class. By now we'd overridden just about all of its methods: I've
3049 copied the remaining two over, and now ipython is a standalone
3056 copied the remaining two over, and now ipython is a standalone
3050 class. This will provide a clearer picture for the chainsaw
3057 class. This will provide a clearer picture for the chainsaw
3051 branch refactoring.
3058 branch refactoring.
3052
3059
3053 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
3060 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
3054
3061
3055 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
3062 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
3056 failures for objects which break when dir() is called on them.
3063 failures for objects which break when dir() is called on them.
3057
3064
3058 * IPython/FlexCompleter.py (Completer.__init__): Added support for
3065 * IPython/FlexCompleter.py (Completer.__init__): Added support for
3059 distinct local and global namespaces in the completer API. This
3066 distinct local and global namespaces in the completer API. This
3060 change allows us to properly handle completion with distinct
3067 change allows us to properly handle completion with distinct
3061 scopes, including in embedded instances (this had never really
3068 scopes, including in embedded instances (this had never really
3062 worked correctly).
3069 worked correctly).
3063
3070
3064 Note: this introduces a change in the constructor for
3071 Note: this introduces a change in the constructor for
3065 MagicCompleter, as a new global_namespace parameter is now the
3072 MagicCompleter, as a new global_namespace parameter is now the
3066 second argument (the others were bumped one position).
3073 second argument (the others were bumped one position).
3067
3074
3068 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
3075 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
3069
3076
3070 * IPython/iplib.py (embed_mainloop): fix tab-completion in
3077 * IPython/iplib.py (embed_mainloop): fix tab-completion in
3071 embedded instances (which can be done now thanks to Vivian's
3078 embedded instances (which can be done now thanks to Vivian's
3072 frame-handling fixes for pdb).
3079 frame-handling fixes for pdb).
3073 (InteractiveShell.__init__): Fix namespace handling problem in
3080 (InteractiveShell.__init__): Fix namespace handling problem in
3074 embedded instances. We were overwriting __main__ unconditionally,
3081 embedded instances. We were overwriting __main__ unconditionally,
3075 and this should only be done for 'full' (non-embedded) IPython;
3082 and this should only be done for 'full' (non-embedded) IPython;
3076 embedded instances must respect the caller's __main__. Thanks to
3083 embedded instances must respect the caller's __main__. Thanks to
3077 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
3084 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
3078
3085
3079 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
3086 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
3080
3087
3081 * setup.py: added download_url to setup(). This registers the
3088 * setup.py: added download_url to setup(). This registers the
3082 download address at PyPI, which is not only useful to humans
3089 download address at PyPI, which is not only useful to humans
3083 browsing the site, but is also picked up by setuptools (the Eggs
3090 browsing the site, but is also picked up by setuptools (the Eggs
3084 machinery). Thanks to Ville and R. Kern for the info/discussion
3091 machinery). Thanks to Ville and R. Kern for the info/discussion
3085 on this.
3092 on this.
3086
3093
3087 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
3094 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
3088
3095
3089 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
3096 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
3090 This brings a lot of nice functionality to the pdb mode, which now
3097 This brings a lot of nice functionality to the pdb mode, which now
3091 has tab-completion, syntax highlighting, and better stack handling
3098 has tab-completion, syntax highlighting, and better stack handling
3092 than before. Many thanks to Vivian De Smedt
3099 than before. Many thanks to Vivian De Smedt
3093 <vivian-AT-vdesmedt.com> for the original patches.
3100 <vivian-AT-vdesmedt.com> for the original patches.
3094
3101
3095 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
3102 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
3096
3103
3097 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
3104 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
3098 sequence to consistently accept the banner argument. The
3105 sequence to consistently accept the banner argument. The
3099 inconsistency was tripping SAGE, thanks to Gary Zablackis
3106 inconsistency was tripping SAGE, thanks to Gary Zablackis
3100 <gzabl-AT-yahoo.com> for the report.
3107 <gzabl-AT-yahoo.com> for the report.
3101
3108
3102 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
3109 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
3103
3110
3104 * IPython/iplib.py (InteractiveShell.post_config_initialization):
3111 * IPython/iplib.py (InteractiveShell.post_config_initialization):
3105 Fix bug where a naked 'alias' call in the ipythonrc file would
3112 Fix bug where a naked 'alias' call in the ipythonrc file would
3106 cause a crash. Bug reported by Jorgen Stenarson.
3113 cause a crash. Bug reported by Jorgen Stenarson.
3107
3114
3108 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
3115 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
3109
3116
3110 * IPython/ipmaker.py (make_IPython): cleanups which should improve
3117 * IPython/ipmaker.py (make_IPython): cleanups which should improve
3111 startup time.
3118 startup time.
3112
3119
3113 * IPython/iplib.py (runcode): my globals 'fix' for embedded
3120 * IPython/iplib.py (runcode): my globals 'fix' for embedded
3114 instances had introduced a bug with globals in normal code. Now
3121 instances had introduced a bug with globals in normal code. Now
3115 it's working in all cases.
3122 it's working in all cases.
3116
3123
3117 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
3124 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
3118 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
3125 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
3119 has been introduced to set the default case sensitivity of the
3126 has been introduced to set the default case sensitivity of the
3120 searches. Users can still select either mode at runtime on a
3127 searches. Users can still select either mode at runtime on a
3121 per-search basis.
3128 per-search basis.
3122
3129
3123 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
3130 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
3124
3131
3125 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
3132 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
3126 attributes in wildcard searches for subclasses. Modified version
3133 attributes in wildcard searches for subclasses. Modified version
3127 of a patch by Jorgen.
3134 of a patch by Jorgen.
3128
3135
3129 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
3136 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
3130
3137
3131 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
3138 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
3132 embedded instances. I added a user_global_ns attribute to the
3139 embedded instances. I added a user_global_ns attribute to the
3133 InteractiveShell class to handle this.
3140 InteractiveShell class to handle this.
3134
3141
3135 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
3142 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
3136
3143
3137 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
3144 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
3138 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
3145 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
3139 (reported under win32, but may happen also in other platforms).
3146 (reported under win32, but may happen also in other platforms).
3140 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
3147 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
3141
3148
3142 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
3149 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
3143
3150
3144 * IPython/Magic.py (magic_psearch): new support for wildcard
3151 * IPython/Magic.py (magic_psearch): new support for wildcard
3145 patterns. Now, typing ?a*b will list all names which begin with a
3152 patterns. Now, typing ?a*b will list all names which begin with a
3146 and end in b, for example. The %psearch magic has full
3153 and end in b, for example. The %psearch magic has full
3147 docstrings. Many thanks to JΓΆrgen Stenarson
3154 docstrings. Many thanks to JΓΆrgen Stenarson
3148 <jorgen.stenarson-AT-bostream.nu>, author of the patches
3155 <jorgen.stenarson-AT-bostream.nu>, author of the patches
3149 implementing this functionality.
3156 implementing this functionality.
3150
3157
3151 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
3158 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
3152
3159
3153 * Manual: fixed long-standing annoyance of double-dashes (as in
3160 * Manual: fixed long-standing annoyance of double-dashes (as in
3154 --prefix=~, for example) being stripped in the HTML version. This
3161 --prefix=~, for example) being stripped in the HTML version. This
3155 is a latex2html bug, but a workaround was provided. Many thanks
3162 is a latex2html bug, but a workaround was provided. Many thanks
3156 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
3163 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
3157 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
3164 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
3158 rolling. This seemingly small issue had tripped a number of users
3165 rolling. This seemingly small issue had tripped a number of users
3159 when first installing, so I'm glad to see it gone.
3166 when first installing, so I'm glad to see it gone.
3160
3167
3161 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
3168 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
3162
3169
3163 * IPython/Extensions/numeric_formats.py: fix missing import,
3170 * IPython/Extensions/numeric_formats.py: fix missing import,
3164 reported by Stephen Walton.
3171 reported by Stephen Walton.
3165
3172
3166 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
3173 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
3167
3174
3168 * IPython/demo.py: finish demo module, fully documented now.
3175 * IPython/demo.py: finish demo module, fully documented now.
3169
3176
3170 * IPython/genutils.py (file_read): simple little utility to read a
3177 * IPython/genutils.py (file_read): simple little utility to read a
3171 file and ensure it's closed afterwards.
3178 file and ensure it's closed afterwards.
3172
3179
3173 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
3180 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
3174
3181
3175 * IPython/demo.py (Demo.__init__): added support for individually
3182 * IPython/demo.py (Demo.__init__): added support for individually
3176 tagging blocks for automatic execution.
3183 tagging blocks for automatic execution.
3177
3184
3178 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
3185 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
3179 syntax-highlighted python sources, requested by John.
3186 syntax-highlighted python sources, requested by John.
3180
3187
3181 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
3188 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
3182
3189
3183 * IPython/demo.py (Demo.again): fix bug where again() blocks after
3190 * IPython/demo.py (Demo.again): fix bug where again() blocks after
3184 finishing.
3191 finishing.
3185
3192
3186 * IPython/genutils.py (shlex_split): moved from Magic to here,
3193 * IPython/genutils.py (shlex_split): moved from Magic to here,
3187 where all 2.2 compatibility stuff lives. I needed it for demo.py.
3194 where all 2.2 compatibility stuff lives. I needed it for demo.py.
3188
3195
3189 * IPython/demo.py (Demo.__init__): added support for silent
3196 * IPython/demo.py (Demo.__init__): added support for silent
3190 blocks, improved marks as regexps, docstrings written.
3197 blocks, improved marks as regexps, docstrings written.
3191 (Demo.__init__): better docstring, added support for sys.argv.
3198 (Demo.__init__): better docstring, added support for sys.argv.
3192
3199
3193 * IPython/genutils.py (marquee): little utility used by the demo
3200 * IPython/genutils.py (marquee): little utility used by the demo
3194 code, handy in general.
3201 code, handy in general.
3195
3202
3196 * IPython/demo.py (Demo.__init__): new class for interactive
3203 * IPython/demo.py (Demo.__init__): new class for interactive
3197 demos. Not documented yet, I just wrote it in a hurry for
3204 demos. Not documented yet, I just wrote it in a hurry for
3198 scipy'05. Will docstring later.
3205 scipy'05. Will docstring later.
3199
3206
3200 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
3207 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
3201
3208
3202 * IPython/Shell.py (sigint_handler): Drastic simplification which
3209 * IPython/Shell.py (sigint_handler): Drastic simplification which
3203 also seems to make Ctrl-C work correctly across threads! This is
3210 also seems to make Ctrl-C work correctly across threads! This is
3204 so simple, that I can't beleive I'd missed it before. Needs more
3211 so simple, that I can't beleive I'd missed it before. Needs more
3205 testing, though.
3212 testing, though.
3206 (KBINT): Never mind, revert changes. I'm sure I'd tried something
3213 (KBINT): Never mind, revert changes. I'm sure I'd tried something
3207 like this before...
3214 like this before...
3208
3215
3209 * IPython/genutils.py (get_home_dir): add protection against
3216 * IPython/genutils.py (get_home_dir): add protection against
3210 non-dirs in win32 registry.
3217 non-dirs in win32 registry.
3211
3218
3212 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
3219 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
3213 bug where dict was mutated while iterating (pysh crash).
3220 bug where dict was mutated while iterating (pysh crash).
3214
3221
3215 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
3222 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
3216
3223
3217 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
3224 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
3218 spurious newlines added by this routine. After a report by
3225 spurious newlines added by this routine. After a report by
3219 F. Mantegazza.
3226 F. Mantegazza.
3220
3227
3221 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
3228 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
3222
3229
3223 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
3230 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
3224 calls. These were a leftover from the GTK 1.x days, and can cause
3231 calls. These were a leftover from the GTK 1.x days, and can cause
3225 problems in certain cases (after a report by John Hunter).
3232 problems in certain cases (after a report by John Hunter).
3226
3233
3227 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
3234 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
3228 os.getcwd() fails at init time. Thanks to patch from David Remahl
3235 os.getcwd() fails at init time. Thanks to patch from David Remahl
3229 <chmod007-AT-mac.com>.
3236 <chmod007-AT-mac.com>.
3230 (InteractiveShell.__init__): prevent certain special magics from
3237 (InteractiveShell.__init__): prevent certain special magics from
3231 being shadowed by aliases. Closes
3238 being shadowed by aliases. Closes
3232 http://www.scipy.net/roundup/ipython/issue41.
3239 http://www.scipy.net/roundup/ipython/issue41.
3233
3240
3234 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
3241 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
3235
3242
3236 * IPython/iplib.py (InteractiveShell.complete): Added new
3243 * IPython/iplib.py (InteractiveShell.complete): Added new
3237 top-level completion method to expose the completion mechanism
3244 top-level completion method to expose the completion mechanism
3238 beyond readline-based environments.
3245 beyond readline-based environments.
3239
3246
3240 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
3247 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
3241
3248
3242 * tools/ipsvnc (svnversion): fix svnversion capture.
3249 * tools/ipsvnc (svnversion): fix svnversion capture.
3243
3250
3244 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
3251 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
3245 attribute to self, which was missing. Before, it was set by a
3252 attribute to self, which was missing. Before, it was set by a
3246 routine which in certain cases wasn't being called, so the
3253 routine which in certain cases wasn't being called, so the
3247 instance could end up missing the attribute. This caused a crash.
3254 instance could end up missing the attribute. This caused a crash.
3248 Closes http://www.scipy.net/roundup/ipython/issue40.
3255 Closes http://www.scipy.net/roundup/ipython/issue40.
3249
3256
3250 2005-08-16 Fernando Perez <fperez@colorado.edu>
3257 2005-08-16 Fernando Perez <fperez@colorado.edu>
3251
3258
3252 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
3259 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
3253 contains non-string attribute. Closes
3260 contains non-string attribute. Closes
3254 http://www.scipy.net/roundup/ipython/issue38.
3261 http://www.scipy.net/roundup/ipython/issue38.
3255
3262
3256 2005-08-14 Fernando Perez <fperez@colorado.edu>
3263 2005-08-14 Fernando Perez <fperez@colorado.edu>
3257
3264
3258 * tools/ipsvnc: Minor improvements, to add changeset info.
3265 * tools/ipsvnc: Minor improvements, to add changeset info.
3259
3266
3260 2005-08-12 Fernando Perez <fperez@colorado.edu>
3267 2005-08-12 Fernando Perez <fperez@colorado.edu>
3261
3268
3262 * IPython/iplib.py (runsource): remove self.code_to_run_src
3269 * IPython/iplib.py (runsource): remove self.code_to_run_src
3263 attribute. I realized this is nothing more than
3270 attribute. I realized this is nothing more than
3264 '\n'.join(self.buffer), and having the same data in two different
3271 '\n'.join(self.buffer), and having the same data in two different
3265 places is just asking for synchronization bugs. This may impact
3272 places is just asking for synchronization bugs. This may impact
3266 people who have custom exception handlers, so I need to warn
3273 people who have custom exception handlers, so I need to warn
3267 ipython-dev about it (F. Mantegazza may use them).
3274 ipython-dev about it (F. Mantegazza may use them).
3268
3275
3269 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
3276 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
3270
3277
3271 * IPython/genutils.py: fix 2.2 compatibility (generators)
3278 * IPython/genutils.py: fix 2.2 compatibility (generators)
3272
3279
3273 2005-07-18 Fernando Perez <fperez@colorado.edu>
3280 2005-07-18 Fernando Perez <fperez@colorado.edu>
3274
3281
3275 * IPython/genutils.py (get_home_dir): fix to help users with
3282 * IPython/genutils.py (get_home_dir): fix to help users with
3276 invalid $HOME under win32.
3283 invalid $HOME under win32.
3277
3284
3278 2005-07-17 Fernando Perez <fperez@colorado.edu>
3285 2005-07-17 Fernando Perez <fperez@colorado.edu>
3279
3286
3280 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
3287 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
3281 some old hacks and clean up a bit other routines; code should be
3288 some old hacks and clean up a bit other routines; code should be
3282 simpler and a bit faster.
3289 simpler and a bit faster.
3283
3290
3284 * IPython/iplib.py (interact): removed some last-resort attempts
3291 * IPython/iplib.py (interact): removed some last-resort attempts
3285 to survive broken stdout/stderr. That code was only making it
3292 to survive broken stdout/stderr. That code was only making it
3286 harder to abstract out the i/o (necessary for gui integration),
3293 harder to abstract out the i/o (necessary for gui integration),
3287 and the crashes it could prevent were extremely rare in practice
3294 and the crashes it could prevent were extremely rare in practice
3288 (besides being fully user-induced in a pretty violent manner).
3295 (besides being fully user-induced in a pretty violent manner).
3289
3296
3290 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
3297 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
3291 Nothing major yet, but the code is simpler to read; this should
3298 Nothing major yet, but the code is simpler to read; this should
3292 make it easier to do more serious modifications in the future.
3299 make it easier to do more serious modifications in the future.
3293
3300
3294 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
3301 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
3295 which broke in .15 (thanks to a report by Ville).
3302 which broke in .15 (thanks to a report by Ville).
3296
3303
3297 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
3304 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
3298 be quite correct, I know next to nothing about unicode). This
3305 be quite correct, I know next to nothing about unicode). This
3299 will allow unicode strings to be used in prompts, amongst other
3306 will allow unicode strings to be used in prompts, amongst other
3300 cases. It also will prevent ipython from crashing when unicode
3307 cases. It also will prevent ipython from crashing when unicode
3301 shows up unexpectedly in many places. If ascii encoding fails, we
3308 shows up unexpectedly in many places. If ascii encoding fails, we
3302 assume utf_8. Currently the encoding is not a user-visible
3309 assume utf_8. Currently the encoding is not a user-visible
3303 setting, though it could be made so if there is demand for it.
3310 setting, though it could be made so if there is demand for it.
3304
3311
3305 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
3312 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
3306
3313
3307 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
3314 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
3308
3315
3309 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
3316 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
3310
3317
3311 * IPython/genutils.py: Add 2.2 compatibility here, so all other
3318 * IPython/genutils.py: Add 2.2 compatibility here, so all other
3312 code can work transparently for 2.2/2.3.
3319 code can work transparently for 2.2/2.3.
3313
3320
3314 2005-07-16 Fernando Perez <fperez@colorado.edu>
3321 2005-07-16 Fernando Perez <fperez@colorado.edu>
3315
3322
3316 * IPython/ultraTB.py (ExceptionColors): Make a global variable
3323 * IPython/ultraTB.py (ExceptionColors): Make a global variable
3317 out of the color scheme table used for coloring exception
3324 out of the color scheme table used for coloring exception
3318 tracebacks. This allows user code to add new schemes at runtime.
3325 tracebacks. This allows user code to add new schemes at runtime.
3319 This is a minimally modified version of the patch at
3326 This is a minimally modified version of the patch at
3320 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
3327 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
3321 for the contribution.
3328 for the contribution.
3322
3329
3323 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
3330 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
3324 slightly modified version of the patch in
3331 slightly modified version of the patch in
3325 http://www.scipy.net/roundup/ipython/issue34, which also allows me
3332 http://www.scipy.net/roundup/ipython/issue34, which also allows me
3326 to remove the previous try/except solution (which was costlier).
3333 to remove the previous try/except solution (which was costlier).
3327 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
3334 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
3328
3335
3329 2005-06-08 Fernando Perez <fperez@colorado.edu>
3336 2005-06-08 Fernando Perez <fperez@colorado.edu>
3330
3337
3331 * IPython/iplib.py (write/write_err): Add methods to abstract all
3338 * IPython/iplib.py (write/write_err): Add methods to abstract all
3332 I/O a bit more.
3339 I/O a bit more.
3333
3340
3334 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
3341 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
3335 warning, reported by Aric Hagberg, fix by JD Hunter.
3342 warning, reported by Aric Hagberg, fix by JD Hunter.
3336
3343
3337 2005-06-02 *** Released version 0.6.15
3344 2005-06-02 *** Released version 0.6.15
3338
3345
3339 2005-06-01 Fernando Perez <fperez@colorado.edu>
3346 2005-06-01 Fernando Perez <fperez@colorado.edu>
3340
3347
3341 * IPython/iplib.py (MagicCompleter.file_matches): Fix
3348 * IPython/iplib.py (MagicCompleter.file_matches): Fix
3342 tab-completion of filenames within open-quoted strings. Note that
3349 tab-completion of filenames within open-quoted strings. Note that
3343 this requires that in ~/.ipython/ipythonrc, users change the
3350 this requires that in ~/.ipython/ipythonrc, users change the
3344 readline delimiters configuration to read:
3351 readline delimiters configuration to read:
3345
3352
3346 readline_remove_delims -/~
3353 readline_remove_delims -/~
3347
3354
3348
3355
3349 2005-05-31 *** Released version 0.6.14
3356 2005-05-31 *** Released version 0.6.14
3350
3357
3351 2005-05-29 Fernando Perez <fperez@colorado.edu>
3358 2005-05-29 Fernando Perez <fperez@colorado.edu>
3352
3359
3353 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
3360 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
3354 with files not on the filesystem. Reported by Eliyahu Sandler
3361 with files not on the filesystem. Reported by Eliyahu Sandler
3355 <eli@gondolin.net>
3362 <eli@gondolin.net>
3356
3363
3357 2005-05-22 Fernando Perez <fperez@colorado.edu>
3364 2005-05-22 Fernando Perez <fperez@colorado.edu>
3358
3365
3359 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
3366 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
3360 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
3367 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
3361
3368
3362 2005-05-19 Fernando Perez <fperez@colorado.edu>
3369 2005-05-19 Fernando Perez <fperez@colorado.edu>
3363
3370
3364 * IPython/iplib.py (safe_execfile): close a file which could be
3371 * IPython/iplib.py (safe_execfile): close a file which could be
3365 left open (causing problems in win32, which locks open files).
3372 left open (causing problems in win32, which locks open files).
3366 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
3373 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
3367
3374
3368 2005-05-18 Fernando Perez <fperez@colorado.edu>
3375 2005-05-18 Fernando Perez <fperez@colorado.edu>
3369
3376
3370 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
3377 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
3371 keyword arguments correctly to safe_execfile().
3378 keyword arguments correctly to safe_execfile().
3372
3379
3373 2005-05-13 Fernando Perez <fperez@colorado.edu>
3380 2005-05-13 Fernando Perez <fperez@colorado.edu>
3374
3381
3375 * ipython.1: Added info about Qt to manpage, and threads warning
3382 * ipython.1: Added info about Qt to manpage, and threads warning
3376 to usage page (invoked with --help).
3383 to usage page (invoked with --help).
3377
3384
3378 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
3385 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
3379 new matcher (it goes at the end of the priority list) to do
3386 new matcher (it goes at the end of the priority list) to do
3380 tab-completion on named function arguments. Submitted by George
3387 tab-completion on named function arguments. Submitted by George
3381 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
3388 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
3382 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
3389 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
3383 for more details.
3390 for more details.
3384
3391
3385 * IPython/Magic.py (magic_run): Added new -e flag to ignore
3392 * IPython/Magic.py (magic_run): Added new -e flag to ignore
3386 SystemExit exceptions in the script being run. Thanks to a report
3393 SystemExit exceptions in the script being run. Thanks to a report
3387 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
3394 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
3388 producing very annoying behavior when running unit tests.
3395 producing very annoying behavior when running unit tests.
3389
3396
3390 2005-05-12 Fernando Perez <fperez@colorado.edu>
3397 2005-05-12 Fernando Perez <fperez@colorado.edu>
3391
3398
3392 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
3399 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
3393 which I'd broken (again) due to a changed regexp. In the process,
3400 which I'd broken (again) due to a changed regexp. In the process,
3394 added ';' as an escape to auto-quote the whole line without
3401 added ';' as an escape to auto-quote the whole line without
3395 splitting its arguments. Thanks to a report by Jerry McRae
3402 splitting its arguments. Thanks to a report by Jerry McRae
3396 <qrs0xyc02-AT-sneakemail.com>.
3403 <qrs0xyc02-AT-sneakemail.com>.
3397
3404
3398 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
3405 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
3399 possible crashes caused by a TokenError. Reported by Ed Schofield
3406 possible crashes caused by a TokenError. Reported by Ed Schofield
3400 <schofield-AT-ftw.at>.
3407 <schofield-AT-ftw.at>.
3401
3408
3402 2005-05-06 Fernando Perez <fperez@colorado.edu>
3409 2005-05-06 Fernando Perez <fperez@colorado.edu>
3403
3410
3404 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
3411 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
3405
3412
3406 2005-04-29 Fernando Perez <fperez@colorado.edu>
3413 2005-04-29 Fernando Perez <fperez@colorado.edu>
3407
3414
3408 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
3415 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
3409 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
3416 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
3410 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
3417 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
3411 which provides support for Qt interactive usage (similar to the
3418 which provides support for Qt interactive usage (similar to the
3412 existing one for WX and GTK). This had been often requested.
3419 existing one for WX and GTK). This had been often requested.
3413
3420
3414 2005-04-14 *** Released version 0.6.13
3421 2005-04-14 *** Released version 0.6.13
3415
3422
3416 2005-04-08 Fernando Perez <fperez@colorado.edu>
3423 2005-04-08 Fernando Perez <fperez@colorado.edu>
3417
3424
3418 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
3425 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
3419 from _ofind, which gets called on almost every input line. Now,
3426 from _ofind, which gets called on almost every input line. Now,
3420 we only try to get docstrings if they are actually going to be
3427 we only try to get docstrings if they are actually going to be
3421 used (the overhead of fetching unnecessary docstrings can be
3428 used (the overhead of fetching unnecessary docstrings can be
3422 noticeable for certain objects, such as Pyro proxies).
3429 noticeable for certain objects, such as Pyro proxies).
3423
3430
3424 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
3431 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
3425 for completers. For some reason I had been passing them the state
3432 for completers. For some reason I had been passing them the state
3426 variable, which completers never actually need, and was in
3433 variable, which completers never actually need, and was in
3427 conflict with the rlcompleter API. Custom completers ONLY need to
3434 conflict with the rlcompleter API. Custom completers ONLY need to
3428 take the text parameter.
3435 take the text parameter.
3429
3436
3430 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
3437 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
3431 work correctly in pysh. I've also moved all the logic which used
3438 work correctly in pysh. I've also moved all the logic which used
3432 to be in pysh.py here, which will prevent problems with future
3439 to be in pysh.py here, which will prevent problems with future
3433 upgrades. However, this time I must warn users to update their
3440 upgrades. However, this time I must warn users to update their
3434 pysh profile to include the line
3441 pysh profile to include the line
3435
3442
3436 import_all IPython.Extensions.InterpreterExec
3443 import_all IPython.Extensions.InterpreterExec
3437
3444
3438 because otherwise things won't work for them. They MUST also
3445 because otherwise things won't work for them. They MUST also
3439 delete pysh.py and the line
3446 delete pysh.py and the line
3440
3447
3441 execfile pysh.py
3448 execfile pysh.py
3442
3449
3443 from their ipythonrc-pysh.
3450 from their ipythonrc-pysh.
3444
3451
3445 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
3452 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
3446 robust in the face of objects whose dir() returns non-strings
3453 robust in the face of objects whose dir() returns non-strings
3447 (which it shouldn't, but some broken libs like ITK do). Thanks to
3454 (which it shouldn't, but some broken libs like ITK do). Thanks to
3448 a patch by John Hunter (implemented differently, though). Also
3455 a patch by John Hunter (implemented differently, though). Also
3449 minor improvements by using .extend instead of + on lists.
3456 minor improvements by using .extend instead of + on lists.
3450
3457
3451 * pysh.py:
3458 * pysh.py:
3452
3459
3453 2005-04-06 Fernando Perez <fperez@colorado.edu>
3460 2005-04-06 Fernando Perez <fperez@colorado.edu>
3454
3461
3455 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
3462 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
3456 by default, so that all users benefit from it. Those who don't
3463 by default, so that all users benefit from it. Those who don't
3457 want it can still turn it off.
3464 want it can still turn it off.
3458
3465
3459 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
3466 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
3460 config file, I'd forgotten about this, so users were getting it
3467 config file, I'd forgotten about this, so users were getting it
3461 off by default.
3468 off by default.
3462
3469
3463 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
3470 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
3464 consistency. Now magics can be called in multiline statements,
3471 consistency. Now magics can be called in multiline statements,
3465 and python variables can be expanded in magic calls via $var.
3472 and python variables can be expanded in magic calls via $var.
3466 This makes the magic system behave just like aliases or !system
3473 This makes the magic system behave just like aliases or !system
3467 calls.
3474 calls.
3468
3475
3469 2005-03-28 Fernando Perez <fperez@colorado.edu>
3476 2005-03-28 Fernando Perez <fperez@colorado.edu>
3470
3477
3471 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
3478 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
3472 expensive string additions for building command. Add support for
3479 expensive string additions for building command. Add support for
3473 trailing ';' when autocall is used.
3480 trailing ';' when autocall is used.
3474
3481
3475 2005-03-26 Fernando Perez <fperez@colorado.edu>
3482 2005-03-26 Fernando Perez <fperez@colorado.edu>
3476
3483
3477 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
3484 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
3478 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
3485 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
3479 ipython.el robust against prompts with any number of spaces
3486 ipython.el robust against prompts with any number of spaces
3480 (including 0) after the ':' character.
3487 (including 0) after the ':' character.
3481
3488
3482 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
3489 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
3483 continuation prompt, which misled users to think the line was
3490 continuation prompt, which misled users to think the line was
3484 already indented. Closes debian Bug#300847, reported to me by
3491 already indented. Closes debian Bug#300847, reported to me by
3485 Norbert Tretkowski <tretkowski-AT-inittab.de>.
3492 Norbert Tretkowski <tretkowski-AT-inittab.de>.
3486
3493
3487 2005-03-23 Fernando Perez <fperez@colorado.edu>
3494 2005-03-23 Fernando Perez <fperez@colorado.edu>
3488
3495
3489 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
3496 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
3490 properly aligned if they have embedded newlines.
3497 properly aligned if they have embedded newlines.
3491
3498
3492 * IPython/iplib.py (runlines): Add a public method to expose
3499 * IPython/iplib.py (runlines): Add a public method to expose
3493 IPython's code execution machinery, so that users can run strings
3500 IPython's code execution machinery, so that users can run strings
3494 as if they had been typed at the prompt interactively.
3501 as if they had been typed at the prompt interactively.
3495 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
3502 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
3496 methods which can call the system shell, but with python variable
3503 methods which can call the system shell, but with python variable
3497 expansion. The three such methods are: __IPYTHON__.system,
3504 expansion. The three such methods are: __IPYTHON__.system,
3498 .getoutput and .getoutputerror. These need to be documented in a
3505 .getoutput and .getoutputerror. These need to be documented in a
3499 'public API' section (to be written) of the manual.
3506 'public API' section (to be written) of the manual.
3500
3507
3501 2005-03-20 Fernando Perez <fperez@colorado.edu>
3508 2005-03-20 Fernando Perez <fperez@colorado.edu>
3502
3509
3503 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
3510 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
3504 for custom exception handling. This is quite powerful, and it
3511 for custom exception handling. This is quite powerful, and it
3505 allows for user-installable exception handlers which can trap
3512 allows for user-installable exception handlers which can trap
3506 custom exceptions at runtime and treat them separately from
3513 custom exceptions at runtime and treat them separately from
3507 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
3514 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
3508 Mantegazza <mantegazza-AT-ill.fr>.
3515 Mantegazza <mantegazza-AT-ill.fr>.
3509 (InteractiveShell.set_custom_completer): public API function to
3516 (InteractiveShell.set_custom_completer): public API function to
3510 add new completers at runtime.
3517 add new completers at runtime.
3511
3518
3512 2005-03-19 Fernando Perez <fperez@colorado.edu>
3519 2005-03-19 Fernando Perez <fperez@colorado.edu>
3513
3520
3514 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
3521 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
3515 allow objects which provide their docstrings via non-standard
3522 allow objects which provide their docstrings via non-standard
3516 mechanisms (like Pyro proxies) to still be inspected by ipython's
3523 mechanisms (like Pyro proxies) to still be inspected by ipython's
3517 ? system.
3524 ? system.
3518
3525
3519 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
3526 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
3520 automatic capture system. I tried quite hard to make it work
3527 automatic capture system. I tried quite hard to make it work
3521 reliably, and simply failed. I tried many combinations with the
3528 reliably, and simply failed. I tried many combinations with the
3522 subprocess module, but eventually nothing worked in all needed
3529 subprocess module, but eventually nothing worked in all needed
3523 cases (not blocking stdin for the child, duplicating stdout
3530 cases (not blocking stdin for the child, duplicating stdout
3524 without blocking, etc). The new %sc/%sx still do capture to these
3531 without blocking, etc). The new %sc/%sx still do capture to these
3525 magical list/string objects which make shell use much more
3532 magical list/string objects which make shell use much more
3526 conveninent, so not all is lost.
3533 conveninent, so not all is lost.
3527
3534
3528 XXX - FIX MANUAL for the change above!
3535 XXX - FIX MANUAL for the change above!
3529
3536
3530 (runsource): I copied code.py's runsource() into ipython to modify
3537 (runsource): I copied code.py's runsource() into ipython to modify
3531 it a bit. Now the code object and source to be executed are
3538 it a bit. Now the code object and source to be executed are
3532 stored in ipython. This makes this info accessible to third-party
3539 stored in ipython. This makes this info accessible to third-party
3533 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
3540 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
3534 Mantegazza <mantegazza-AT-ill.fr>.
3541 Mantegazza <mantegazza-AT-ill.fr>.
3535
3542
3536 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
3543 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
3537 history-search via readline (like C-p/C-n). I'd wanted this for a
3544 history-search via readline (like C-p/C-n). I'd wanted this for a
3538 long time, but only recently found out how to do it. For users
3545 long time, but only recently found out how to do it. For users
3539 who already have their ipythonrc files made and want this, just
3546 who already have their ipythonrc files made and want this, just
3540 add:
3547 add:
3541
3548
3542 readline_parse_and_bind "\e[A": history-search-backward
3549 readline_parse_and_bind "\e[A": history-search-backward
3543 readline_parse_and_bind "\e[B": history-search-forward
3550 readline_parse_and_bind "\e[B": history-search-forward
3544
3551
3545 2005-03-18 Fernando Perez <fperez@colorado.edu>
3552 2005-03-18 Fernando Perez <fperez@colorado.edu>
3546
3553
3547 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
3554 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
3548 LSString and SList classes which allow transparent conversions
3555 LSString and SList classes which allow transparent conversions
3549 between list mode and whitespace-separated string.
3556 between list mode and whitespace-separated string.
3550 (magic_r): Fix recursion problem in %r.
3557 (magic_r): Fix recursion problem in %r.
3551
3558
3552 * IPython/genutils.py (LSString): New class to be used for
3559 * IPython/genutils.py (LSString): New class to be used for
3553 automatic storage of the results of all alias/system calls in _o
3560 automatic storage of the results of all alias/system calls in _o
3554 and _e (stdout/err). These provide a .l/.list attribute which
3561 and _e (stdout/err). These provide a .l/.list attribute which
3555 does automatic splitting on newlines. This means that for most
3562 does automatic splitting on newlines. This means that for most
3556 uses, you'll never need to do capturing of output with %sc/%sx
3563 uses, you'll never need to do capturing of output with %sc/%sx
3557 anymore, since ipython keeps this always done for you. Note that
3564 anymore, since ipython keeps this always done for you. Note that
3558 only the LAST results are stored, the _o/e variables are
3565 only the LAST results are stored, the _o/e variables are
3559 overwritten on each call. If you need to save their contents
3566 overwritten on each call. If you need to save their contents
3560 further, simply bind them to any other name.
3567 further, simply bind them to any other name.
3561
3568
3562 2005-03-17 Fernando Perez <fperez@colorado.edu>
3569 2005-03-17 Fernando Perez <fperez@colorado.edu>
3563
3570
3564 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
3571 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
3565 prompt namespace handling.
3572 prompt namespace handling.
3566
3573
3567 2005-03-16 Fernando Perez <fperez@colorado.edu>
3574 2005-03-16 Fernando Perez <fperez@colorado.edu>
3568
3575
3569 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
3576 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
3570 classic prompts to be '>>> ' (final space was missing, and it
3577 classic prompts to be '>>> ' (final space was missing, and it
3571 trips the emacs python mode).
3578 trips the emacs python mode).
3572 (BasePrompt.__str__): Added safe support for dynamic prompt
3579 (BasePrompt.__str__): Added safe support for dynamic prompt
3573 strings. Now you can set your prompt string to be '$x', and the
3580 strings. Now you can set your prompt string to be '$x', and the
3574 value of x will be printed from your interactive namespace. The
3581 value of x will be printed from your interactive namespace. The
3575 interpolation syntax includes the full Itpl support, so
3582 interpolation syntax includes the full Itpl support, so
3576 ${foo()+x+bar()} is a valid prompt string now, and the function
3583 ${foo()+x+bar()} is a valid prompt string now, and the function
3577 calls will be made at runtime.
3584 calls will be made at runtime.
3578
3585
3579 2005-03-15 Fernando Perez <fperez@colorado.edu>
3586 2005-03-15 Fernando Perez <fperez@colorado.edu>
3580
3587
3581 * IPython/Magic.py (magic_history): renamed %hist to %history, to
3588 * IPython/Magic.py (magic_history): renamed %hist to %history, to
3582 avoid name clashes in pylab. %hist still works, it just forwards
3589 avoid name clashes in pylab. %hist still works, it just forwards
3583 the call to %history.
3590 the call to %history.
3584
3591
3585 2005-03-02 *** Released version 0.6.12
3592 2005-03-02 *** Released version 0.6.12
3586
3593
3587 2005-03-02 Fernando Perez <fperez@colorado.edu>
3594 2005-03-02 Fernando Perez <fperez@colorado.edu>
3588
3595
3589 * IPython/iplib.py (handle_magic): log magic calls properly as
3596 * IPython/iplib.py (handle_magic): log magic calls properly as
3590 ipmagic() function calls.
3597 ipmagic() function calls.
3591
3598
3592 * IPython/Magic.py (magic_time): Improved %time to support
3599 * IPython/Magic.py (magic_time): Improved %time to support
3593 statements and provide wall-clock as well as CPU time.
3600 statements and provide wall-clock as well as CPU time.
3594
3601
3595 2005-02-27 Fernando Perez <fperez@colorado.edu>
3602 2005-02-27 Fernando Perez <fperez@colorado.edu>
3596
3603
3597 * IPython/hooks.py: New hooks module, to expose user-modifiable
3604 * IPython/hooks.py: New hooks module, to expose user-modifiable
3598 IPython functionality in a clean manner. For now only the editor
3605 IPython functionality in a clean manner. For now only the editor
3599 hook is actually written, and other thigns which I intend to turn
3606 hook is actually written, and other thigns which I intend to turn
3600 into proper hooks aren't yet there. The display and prefilter
3607 into proper hooks aren't yet there. The display and prefilter
3601 stuff, for example, should be hooks. But at least now the
3608 stuff, for example, should be hooks. But at least now the
3602 framework is in place, and the rest can be moved here with more
3609 framework is in place, and the rest can be moved here with more
3603 time later. IPython had had a .hooks variable for a long time for
3610 time later. IPython had had a .hooks variable for a long time for
3604 this purpose, but I'd never actually used it for anything.
3611 this purpose, but I'd never actually used it for anything.
3605
3612
3606 2005-02-26 Fernando Perez <fperez@colorado.edu>
3613 2005-02-26 Fernando Perez <fperez@colorado.edu>
3607
3614
3608 * IPython/ipmaker.py (make_IPython): make the default ipython
3615 * IPython/ipmaker.py (make_IPython): make the default ipython
3609 directory be called _ipython under win32, to follow more the
3616 directory be called _ipython under win32, to follow more the
3610 naming peculiarities of that platform (where buggy software like
3617 naming peculiarities of that platform (where buggy software like
3611 Visual Sourcesafe breaks with .named directories). Reported by
3618 Visual Sourcesafe breaks with .named directories). Reported by
3612 Ville Vainio.
3619 Ville Vainio.
3613
3620
3614 2005-02-23 Fernando Perez <fperez@colorado.edu>
3621 2005-02-23 Fernando Perez <fperez@colorado.edu>
3615
3622
3616 * IPython/iplib.py (InteractiveShell.__init__): removed a few
3623 * IPython/iplib.py (InteractiveShell.__init__): removed a few
3617 auto_aliases for win32 which were causing problems. Users can
3624 auto_aliases for win32 which were causing problems. Users can
3618 define the ones they personally like.
3625 define the ones they personally like.
3619
3626
3620 2005-02-21 Fernando Perez <fperez@colorado.edu>
3627 2005-02-21 Fernando Perez <fperez@colorado.edu>
3621
3628
3622 * IPython/Magic.py (magic_time): new magic to time execution of
3629 * IPython/Magic.py (magic_time): new magic to time execution of
3623 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
3630 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
3624
3631
3625 2005-02-19 Fernando Perez <fperez@colorado.edu>
3632 2005-02-19 Fernando Perez <fperez@colorado.edu>
3626
3633
3627 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
3634 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
3628 into keys (for prompts, for example).
3635 into keys (for prompts, for example).
3629
3636
3630 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
3637 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
3631 prompts in case users want them. This introduces a small behavior
3638 prompts in case users want them. This introduces a small behavior
3632 change: ipython does not automatically add a space to all prompts
3639 change: ipython does not automatically add a space to all prompts
3633 anymore. To get the old prompts with a space, users should add it
3640 anymore. To get the old prompts with a space, users should add it
3634 manually to their ipythonrc file, so for example prompt_in1 should
3641 manually to their ipythonrc file, so for example prompt_in1 should
3635 now read 'In [\#]: ' instead of 'In [\#]:'.
3642 now read 'In [\#]: ' instead of 'In [\#]:'.
3636 (BasePrompt.__init__): New option prompts_pad_left (only in rc
3643 (BasePrompt.__init__): New option prompts_pad_left (only in rc
3637 file) to control left-padding of secondary prompts.
3644 file) to control left-padding of secondary prompts.
3638
3645
3639 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
3646 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
3640 the profiler can't be imported. Fix for Debian, which removed
3647 the profiler can't be imported. Fix for Debian, which removed
3641 profile.py because of License issues. I applied a slightly
3648 profile.py because of License issues. I applied a slightly
3642 modified version of the original Debian patch at
3649 modified version of the original Debian patch at
3643 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
3650 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
3644
3651
3645 2005-02-17 Fernando Perez <fperez@colorado.edu>
3652 2005-02-17 Fernando Perez <fperez@colorado.edu>
3646
3653
3647 * IPython/genutils.py (native_line_ends): Fix bug which would
3654 * IPython/genutils.py (native_line_ends): Fix bug which would
3648 cause improper line-ends under win32 b/c I was not opening files
3655 cause improper line-ends under win32 b/c I was not opening files
3649 in binary mode. Bug report and fix thanks to Ville.
3656 in binary mode. Bug report and fix thanks to Ville.
3650
3657
3651 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
3658 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
3652 trying to catch spurious foo[1] autocalls. My fix actually broke
3659 trying to catch spurious foo[1] autocalls. My fix actually broke
3653 ',/' autoquote/call with explicit escape (bad regexp).
3660 ',/' autoquote/call with explicit escape (bad regexp).
3654
3661
3655 2005-02-15 *** Released version 0.6.11
3662 2005-02-15 *** Released version 0.6.11
3656
3663
3657 2005-02-14 Fernando Perez <fperez@colorado.edu>
3664 2005-02-14 Fernando Perez <fperez@colorado.edu>
3658
3665
3659 * IPython/background_jobs.py: New background job management
3666 * IPython/background_jobs.py: New background job management
3660 subsystem. This is implemented via a new set of classes, and
3667 subsystem. This is implemented via a new set of classes, and
3661 IPython now provides a builtin 'jobs' object for background job
3668 IPython now provides a builtin 'jobs' object for background job
3662 execution. A convenience %bg magic serves as a lightweight
3669 execution. A convenience %bg magic serves as a lightweight
3663 frontend for starting the more common type of calls. This was
3670 frontend for starting the more common type of calls. This was
3664 inspired by discussions with B. Granger and the BackgroundCommand
3671 inspired by discussions with B. Granger and the BackgroundCommand
3665 class described in the book Python Scripting for Computational
3672 class described in the book Python Scripting for Computational
3666 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
3673 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
3667 (although ultimately no code from this text was used, as IPython's
3674 (although ultimately no code from this text was used, as IPython's
3668 system is a separate implementation).
3675 system is a separate implementation).
3669
3676
3670 * IPython/iplib.py (MagicCompleter.python_matches): add new option
3677 * IPython/iplib.py (MagicCompleter.python_matches): add new option
3671 to control the completion of single/double underscore names
3678 to control the completion of single/double underscore names
3672 separately. As documented in the example ipytonrc file, the
3679 separately. As documented in the example ipytonrc file, the
3673 readline_omit__names variable can now be set to 2, to omit even
3680 readline_omit__names variable can now be set to 2, to omit even
3674 single underscore names. Thanks to a patch by Brian Wong
3681 single underscore names. Thanks to a patch by Brian Wong
3675 <BrianWong-AT-AirgoNetworks.Com>.
3682 <BrianWong-AT-AirgoNetworks.Com>.
3676 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
3683 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
3677 be autocalled as foo([1]) if foo were callable. A problem for
3684 be autocalled as foo([1]) if foo were callable. A problem for
3678 things which are both callable and implement __getitem__.
3685 things which are both callable and implement __getitem__.
3679 (init_readline): Fix autoindentation for win32. Thanks to a patch
3686 (init_readline): Fix autoindentation for win32. Thanks to a patch
3680 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
3687 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
3681
3688
3682 2005-02-12 Fernando Perez <fperez@colorado.edu>
3689 2005-02-12 Fernando Perez <fperez@colorado.edu>
3683
3690
3684 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
3691 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
3685 which I had written long ago to sort out user error messages which
3692 which I had written long ago to sort out user error messages which
3686 may occur during startup. This seemed like a good idea initially,
3693 may occur during startup. This seemed like a good idea initially,
3687 but it has proven a disaster in retrospect. I don't want to
3694 but it has proven a disaster in retrospect. I don't want to
3688 change much code for now, so my fix is to set the internal 'debug'
3695 change much code for now, so my fix is to set the internal 'debug'
3689 flag to true everywhere, whose only job was precisely to control
3696 flag to true everywhere, whose only job was precisely to control
3690 this subsystem. This closes issue 28 (as well as avoiding all
3697 this subsystem. This closes issue 28 (as well as avoiding all
3691 sorts of strange hangups which occur from time to time).
3698 sorts of strange hangups which occur from time to time).
3692
3699
3693 2005-02-07 Fernando Perez <fperez@colorado.edu>
3700 2005-02-07 Fernando Perez <fperez@colorado.edu>
3694
3701
3695 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
3702 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
3696 previous call produced a syntax error.
3703 previous call produced a syntax error.
3697
3704
3698 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3705 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3699 classes without constructor.
3706 classes without constructor.
3700
3707
3701 2005-02-06 Fernando Perez <fperez@colorado.edu>
3708 2005-02-06 Fernando Perez <fperez@colorado.edu>
3702
3709
3703 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
3710 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
3704 completions with the results of each matcher, so we return results
3711 completions with the results of each matcher, so we return results
3705 to the user from all namespaces. This breaks with ipython
3712 to the user from all namespaces. This breaks with ipython
3706 tradition, but I think it's a nicer behavior. Now you get all
3713 tradition, but I think it's a nicer behavior. Now you get all
3707 possible completions listed, from all possible namespaces (python,
3714 possible completions listed, from all possible namespaces (python,
3708 filesystem, magics...) After a request by John Hunter
3715 filesystem, magics...) After a request by John Hunter
3709 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3716 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3710
3717
3711 2005-02-05 Fernando Perez <fperez@colorado.edu>
3718 2005-02-05 Fernando Perez <fperez@colorado.edu>
3712
3719
3713 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
3720 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
3714 the call had quote characters in it (the quotes were stripped).
3721 the call had quote characters in it (the quotes were stripped).
3715
3722
3716 2005-01-31 Fernando Perez <fperez@colorado.edu>
3723 2005-01-31 Fernando Perez <fperez@colorado.edu>
3717
3724
3718 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
3725 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
3719 Itpl.itpl() to make the code more robust against psyco
3726 Itpl.itpl() to make the code more robust against psyco
3720 optimizations.
3727 optimizations.
3721
3728
3722 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
3729 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
3723 of causing an exception. Quicker, cleaner.
3730 of causing an exception. Quicker, cleaner.
3724
3731
3725 2005-01-28 Fernando Perez <fperez@colorado.edu>
3732 2005-01-28 Fernando Perez <fperez@colorado.edu>
3726
3733
3727 * scripts/ipython_win_post_install.py (install): hardcode
3734 * scripts/ipython_win_post_install.py (install): hardcode
3728 sys.prefix+'python.exe' as the executable path. It turns out that
3735 sys.prefix+'python.exe' as the executable path. It turns out that
3729 during the post-installation run, sys.executable resolves to the
3736 during the post-installation run, sys.executable resolves to the
3730 name of the binary installer! I should report this as a distutils
3737 name of the binary installer! I should report this as a distutils
3731 bug, I think. I updated the .10 release with this tiny fix, to
3738 bug, I think. I updated the .10 release with this tiny fix, to
3732 avoid annoying the lists further.
3739 avoid annoying the lists further.
3733
3740
3734 2005-01-27 *** Released version 0.6.10
3741 2005-01-27 *** Released version 0.6.10
3735
3742
3736 2005-01-27 Fernando Perez <fperez@colorado.edu>
3743 2005-01-27 Fernando Perez <fperez@colorado.edu>
3737
3744
3738 * IPython/numutils.py (norm): Added 'inf' as optional name for
3745 * IPython/numutils.py (norm): Added 'inf' as optional name for
3739 L-infinity norm, included references to mathworld.com for vector
3746 L-infinity norm, included references to mathworld.com for vector
3740 norm definitions.
3747 norm definitions.
3741 (amin/amax): added amin/amax for array min/max. Similar to what
3748 (amin/amax): added amin/amax for array min/max. Similar to what
3742 pylab ships with after the recent reorganization of names.
3749 pylab ships with after the recent reorganization of names.
3743 (spike/spike_odd): removed deprecated spike/spike_odd functions.
3750 (spike/spike_odd): removed deprecated spike/spike_odd functions.
3744
3751
3745 * ipython.el: committed Alex's recent fixes and improvements.
3752 * ipython.el: committed Alex's recent fixes and improvements.
3746 Tested with python-mode from CVS, and it looks excellent. Since
3753 Tested with python-mode from CVS, and it looks excellent. Since
3747 python-mode hasn't released anything in a while, I'm temporarily
3754 python-mode hasn't released anything in a while, I'm temporarily
3748 putting a copy of today's CVS (v 4.70) of python-mode in:
3755 putting a copy of today's CVS (v 4.70) of python-mode in:
3749 http://ipython.scipy.org/tmp/python-mode.el
3756 http://ipython.scipy.org/tmp/python-mode.el
3750
3757
3751 * scripts/ipython_win_post_install.py (install): Win32 fix to use
3758 * scripts/ipython_win_post_install.py (install): Win32 fix to use
3752 sys.executable for the executable name, instead of assuming it's
3759 sys.executable for the executable name, instead of assuming it's
3753 called 'python.exe' (the post-installer would have produced broken
3760 called 'python.exe' (the post-installer would have produced broken
3754 setups on systems with a differently named python binary).
3761 setups on systems with a differently named python binary).
3755
3762
3756 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
3763 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
3757 references to os.linesep, to make the code more
3764 references to os.linesep, to make the code more
3758 platform-independent. This is also part of the win32 coloring
3765 platform-independent. This is also part of the win32 coloring
3759 fixes.
3766 fixes.
3760
3767
3761 * IPython/genutils.py (page_dumb): Remove attempts to chop long
3768 * IPython/genutils.py (page_dumb): Remove attempts to chop long
3762 lines, which actually cause coloring bugs because the length of
3769 lines, which actually cause coloring bugs because the length of
3763 the line is very difficult to correctly compute with embedded
3770 the line is very difficult to correctly compute with embedded
3764 escapes. This was the source of all the coloring problems under
3771 escapes. This was the source of all the coloring problems under
3765 Win32. I think that _finally_, Win32 users have a properly
3772 Win32. I think that _finally_, Win32 users have a properly
3766 working ipython in all respects. This would never have happened
3773 working ipython in all respects. This would never have happened
3767 if not for Gary Bishop and Viktor Ransmayr's great help and work.
3774 if not for Gary Bishop and Viktor Ransmayr's great help and work.
3768
3775
3769 2005-01-26 *** Released version 0.6.9
3776 2005-01-26 *** Released version 0.6.9
3770
3777
3771 2005-01-25 Fernando Perez <fperez@colorado.edu>
3778 2005-01-25 Fernando Perez <fperez@colorado.edu>
3772
3779
3773 * setup.py: finally, we have a true Windows installer, thanks to
3780 * setup.py: finally, we have a true Windows installer, thanks to
3774 the excellent work of Viktor Ransmayr
3781 the excellent work of Viktor Ransmayr
3775 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
3782 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
3776 Windows users. The setup routine is quite a bit cleaner thanks to
3783 Windows users. The setup routine is quite a bit cleaner thanks to
3777 this, and the post-install script uses the proper functions to
3784 this, and the post-install script uses the proper functions to
3778 allow a clean de-installation using the standard Windows Control
3785 allow a clean de-installation using the standard Windows Control
3779 Panel.
3786 Panel.
3780
3787
3781 * IPython/genutils.py (get_home_dir): changed to use the $HOME
3788 * IPython/genutils.py (get_home_dir): changed to use the $HOME
3782 environment variable under all OSes (including win32) if
3789 environment variable under all OSes (including win32) if
3783 available. This will give consistency to win32 users who have set
3790 available. This will give consistency to win32 users who have set
3784 this variable for any reason. If os.environ['HOME'] fails, the
3791 this variable for any reason. If os.environ['HOME'] fails, the
3785 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
3792 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
3786
3793
3787 2005-01-24 Fernando Perez <fperez@colorado.edu>
3794 2005-01-24 Fernando Perez <fperez@colorado.edu>
3788
3795
3789 * IPython/numutils.py (empty_like): add empty_like(), similar to
3796 * IPython/numutils.py (empty_like): add empty_like(), similar to
3790 zeros_like() but taking advantage of the new empty() Numeric routine.
3797 zeros_like() but taking advantage of the new empty() Numeric routine.
3791
3798
3792 2005-01-23 *** Released version 0.6.8
3799 2005-01-23 *** Released version 0.6.8
3793
3800
3794 2005-01-22 Fernando Perez <fperez@colorado.edu>
3801 2005-01-22 Fernando Perez <fperez@colorado.edu>
3795
3802
3796 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
3803 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
3797 automatic show() calls. After discussing things with JDH, it
3804 automatic show() calls. After discussing things with JDH, it
3798 turns out there are too many corner cases where this can go wrong.
3805 turns out there are too many corner cases where this can go wrong.
3799 It's best not to try to be 'too smart', and simply have ipython
3806 It's best not to try to be 'too smart', and simply have ipython
3800 reproduce as much as possible the default behavior of a normal
3807 reproduce as much as possible the default behavior of a normal
3801 python shell.
3808 python shell.
3802
3809
3803 * IPython/iplib.py (InteractiveShell.__init__): Modified the
3810 * IPython/iplib.py (InteractiveShell.__init__): Modified the
3804 line-splitting regexp and _prefilter() to avoid calling getattr()
3811 line-splitting regexp and _prefilter() to avoid calling getattr()
3805 on assignments. This closes
3812 on assignments. This closes
3806 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
3813 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
3807 readline uses getattr(), so a simple <TAB> keypress is still
3814 readline uses getattr(), so a simple <TAB> keypress is still
3808 enough to trigger getattr() calls on an object.
3815 enough to trigger getattr() calls on an object.
3809
3816
3810 2005-01-21 Fernando Perez <fperez@colorado.edu>
3817 2005-01-21 Fernando Perez <fperez@colorado.edu>
3811
3818
3812 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
3819 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
3813 docstring under pylab so it doesn't mask the original.
3820 docstring under pylab so it doesn't mask the original.
3814
3821
3815 2005-01-21 *** Released version 0.6.7
3822 2005-01-21 *** Released version 0.6.7
3816
3823
3817 2005-01-21 Fernando Perez <fperez@colorado.edu>
3824 2005-01-21 Fernando Perez <fperez@colorado.edu>
3818
3825
3819 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
3826 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
3820 signal handling for win32 users in multithreaded mode.
3827 signal handling for win32 users in multithreaded mode.
3821
3828
3822 2005-01-17 Fernando Perez <fperez@colorado.edu>
3829 2005-01-17 Fernando Perez <fperez@colorado.edu>
3823
3830
3824 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3831 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3825 instances with no __init__. After a crash report by Norbert Nemec
3832 instances with no __init__. After a crash report by Norbert Nemec
3826 <Norbert-AT-nemec-online.de>.
3833 <Norbert-AT-nemec-online.de>.
3827
3834
3828 2005-01-14 Fernando Perez <fperez@colorado.edu>
3835 2005-01-14 Fernando Perez <fperez@colorado.edu>
3829
3836
3830 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
3837 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
3831 names for verbose exceptions, when multiple dotted names and the
3838 names for verbose exceptions, when multiple dotted names and the
3832 'parent' object were present on the same line.
3839 'parent' object were present on the same line.
3833
3840
3834 2005-01-11 Fernando Perez <fperez@colorado.edu>
3841 2005-01-11 Fernando Perez <fperez@colorado.edu>
3835
3842
3836 * IPython/genutils.py (flag_calls): new utility to trap and flag
3843 * IPython/genutils.py (flag_calls): new utility to trap and flag
3837 calls in functions. I need it to clean up matplotlib support.
3844 calls in functions. I need it to clean up matplotlib support.
3838 Also removed some deprecated code in genutils.
3845 Also removed some deprecated code in genutils.
3839
3846
3840 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
3847 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
3841 that matplotlib scripts called with %run, which don't call show()
3848 that matplotlib scripts called with %run, which don't call show()
3842 themselves, still have their plotting windows open.
3849 themselves, still have their plotting windows open.
3843
3850
3844 2005-01-05 Fernando Perez <fperez@colorado.edu>
3851 2005-01-05 Fernando Perez <fperez@colorado.edu>
3845
3852
3846 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
3853 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
3847 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
3854 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
3848
3855
3849 2004-12-19 Fernando Perez <fperez@colorado.edu>
3856 2004-12-19 Fernando Perez <fperez@colorado.edu>
3850
3857
3851 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
3858 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
3852 parent_runcode, which was an eyesore. The same result can be
3859 parent_runcode, which was an eyesore. The same result can be
3853 obtained with Python's regular superclass mechanisms.
3860 obtained with Python's regular superclass mechanisms.
3854
3861
3855 2004-12-17 Fernando Perez <fperez@colorado.edu>
3862 2004-12-17 Fernando Perez <fperez@colorado.edu>
3856
3863
3857 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
3864 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
3858 reported by Prabhu.
3865 reported by Prabhu.
3859 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
3866 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
3860 sys.stderr) instead of explicitly calling sys.stderr. This helps
3867 sys.stderr) instead of explicitly calling sys.stderr. This helps
3861 maintain our I/O abstractions clean, for future GUI embeddings.
3868 maintain our I/O abstractions clean, for future GUI embeddings.
3862
3869
3863 * IPython/genutils.py (info): added new utility for sys.stderr
3870 * IPython/genutils.py (info): added new utility for sys.stderr
3864 unified info message handling (thin wrapper around warn()).
3871 unified info message handling (thin wrapper around warn()).
3865
3872
3866 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
3873 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
3867 composite (dotted) names on verbose exceptions.
3874 composite (dotted) names on verbose exceptions.
3868 (VerboseTB.nullrepr): harden against another kind of errors which
3875 (VerboseTB.nullrepr): harden against another kind of errors which
3869 Python's inspect module can trigger, and which were crashing
3876 Python's inspect module can trigger, and which were crashing
3870 IPython. Thanks to a report by Marco Lombardi
3877 IPython. Thanks to a report by Marco Lombardi
3871 <mlombard-AT-ma010192.hq.eso.org>.
3878 <mlombard-AT-ma010192.hq.eso.org>.
3872
3879
3873 2004-12-13 *** Released version 0.6.6
3880 2004-12-13 *** Released version 0.6.6
3874
3881
3875 2004-12-12 Fernando Perez <fperez@colorado.edu>
3882 2004-12-12 Fernando Perez <fperez@colorado.edu>
3876
3883
3877 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
3884 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
3878 generated by pygtk upon initialization if it was built without
3885 generated by pygtk upon initialization if it was built without
3879 threads (for matplotlib users). After a crash reported by
3886 threads (for matplotlib users). After a crash reported by
3880 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
3887 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
3881
3888
3882 * IPython/ipmaker.py (make_IPython): fix small bug in the
3889 * IPython/ipmaker.py (make_IPython): fix small bug in the
3883 import_some parameter for multiple imports.
3890 import_some parameter for multiple imports.
3884
3891
3885 * IPython/iplib.py (ipmagic): simplified the interface of
3892 * IPython/iplib.py (ipmagic): simplified the interface of
3886 ipmagic() to take a single string argument, just as it would be
3893 ipmagic() to take a single string argument, just as it would be
3887 typed at the IPython cmd line.
3894 typed at the IPython cmd line.
3888 (ipalias): Added new ipalias() with an interface identical to
3895 (ipalias): Added new ipalias() with an interface identical to
3889 ipmagic(). This completes exposing a pure python interface to the
3896 ipmagic(). This completes exposing a pure python interface to the
3890 alias and magic system, which can be used in loops or more complex
3897 alias and magic system, which can be used in loops or more complex
3891 code where IPython's automatic line mangling is not active.
3898 code where IPython's automatic line mangling is not active.
3892
3899
3893 * IPython/genutils.py (timing): changed interface of timing to
3900 * IPython/genutils.py (timing): changed interface of timing to
3894 simply run code once, which is the most common case. timings()
3901 simply run code once, which is the most common case. timings()
3895 remains unchanged, for the cases where you want multiple runs.
3902 remains unchanged, for the cases where you want multiple runs.
3896
3903
3897 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
3904 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
3898 bug where Python2.2 crashes with exec'ing code which does not end
3905 bug where Python2.2 crashes with exec'ing code which does not end
3899 in a single newline. Python 2.3 is OK, so I hadn't noticed this
3906 in a single newline. Python 2.3 is OK, so I hadn't noticed this
3900 before.
3907 before.
3901
3908
3902 2004-12-10 Fernando Perez <fperez@colorado.edu>
3909 2004-12-10 Fernando Perez <fperez@colorado.edu>
3903
3910
3904 * IPython/Magic.py (Magic.magic_prun): changed name of option from
3911 * IPython/Magic.py (Magic.magic_prun): changed name of option from
3905 -t to -T, to accomodate the new -t flag in %run (the %run and
3912 -t to -T, to accomodate the new -t flag in %run (the %run and
3906 %prun options are kind of intermixed, and it's not easy to change
3913 %prun options are kind of intermixed, and it's not easy to change
3907 this with the limitations of python's getopt).
3914 this with the limitations of python's getopt).
3908
3915
3909 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
3916 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
3910 the execution of scripts. It's not as fine-tuned as timeit.py,
3917 the execution of scripts. It's not as fine-tuned as timeit.py,
3911 but it works from inside ipython (and under 2.2, which lacks
3918 but it works from inside ipython (and under 2.2, which lacks
3912 timeit.py). Optionally a number of runs > 1 can be given for
3919 timeit.py). Optionally a number of runs > 1 can be given for
3913 timing very short-running code.
3920 timing very short-running code.
3914
3921
3915 * IPython/genutils.py (uniq_stable): new routine which returns a
3922 * IPython/genutils.py (uniq_stable): new routine which returns a
3916 list of unique elements in any iterable, but in stable order of
3923 list of unique elements in any iterable, but in stable order of
3917 appearance. I needed this for the ultraTB fixes, and it's a handy
3924 appearance. I needed this for the ultraTB fixes, and it's a handy
3918 utility.
3925 utility.
3919
3926
3920 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
3927 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
3921 dotted names in Verbose exceptions. This had been broken since
3928 dotted names in Verbose exceptions. This had been broken since
3922 the very start, now x.y will properly be printed in a Verbose
3929 the very start, now x.y will properly be printed in a Verbose
3923 traceback, instead of x being shown and y appearing always as an
3930 traceback, instead of x being shown and y appearing always as an
3924 'undefined global'. Getting this to work was a bit tricky,
3931 'undefined global'. Getting this to work was a bit tricky,
3925 because by default python tokenizers are stateless. Saved by
3932 because by default python tokenizers are stateless. Saved by
3926 python's ability to easily add a bit of state to an arbitrary
3933 python's ability to easily add a bit of state to an arbitrary
3927 function (without needing to build a full-blown callable object).
3934 function (without needing to build a full-blown callable object).
3928
3935
3929 Also big cleanup of this code, which had horrendous runtime
3936 Also big cleanup of this code, which had horrendous runtime
3930 lookups of zillions of attributes for colorization. Moved all
3937 lookups of zillions of attributes for colorization. Moved all
3931 this code into a few templates, which make it cleaner and quicker.
3938 this code into a few templates, which make it cleaner and quicker.
3932
3939
3933 Printout quality was also improved for Verbose exceptions: one
3940 Printout quality was also improved for Verbose exceptions: one
3934 variable per line, and memory addresses are printed (this can be
3941 variable per line, and memory addresses are printed (this can be
3935 quite handy in nasty debugging situations, which is what Verbose
3942 quite handy in nasty debugging situations, which is what Verbose
3936 is for).
3943 is for).
3937
3944
3938 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
3945 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
3939 the command line as scripts to be loaded by embedded instances.
3946 the command line as scripts to be loaded by embedded instances.
3940 Doing so has the potential for an infinite recursion if there are
3947 Doing so has the potential for an infinite recursion if there are
3941 exceptions thrown in the process. This fixes a strange crash
3948 exceptions thrown in the process. This fixes a strange crash
3942 reported by Philippe MULLER <muller-AT-irit.fr>.
3949 reported by Philippe MULLER <muller-AT-irit.fr>.
3943
3950
3944 2004-12-09 Fernando Perez <fperez@colorado.edu>
3951 2004-12-09 Fernando Perez <fperez@colorado.edu>
3945
3952
3946 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
3953 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
3947 to reflect new names in matplotlib, which now expose the
3954 to reflect new names in matplotlib, which now expose the
3948 matlab-compatible interface via a pylab module instead of the
3955 matlab-compatible interface via a pylab module instead of the
3949 'matlab' name. The new code is backwards compatible, so users of
3956 'matlab' name. The new code is backwards compatible, so users of
3950 all matplotlib versions are OK. Patch by J. Hunter.
3957 all matplotlib versions are OK. Patch by J. Hunter.
3951
3958
3952 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
3959 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
3953 of __init__ docstrings for instances (class docstrings are already
3960 of __init__ docstrings for instances (class docstrings are already
3954 automatically printed). Instances with customized docstrings
3961 automatically printed). Instances with customized docstrings
3955 (indep. of the class) are also recognized and all 3 separate
3962 (indep. of the class) are also recognized and all 3 separate
3956 docstrings are printed (instance, class, constructor). After some
3963 docstrings are printed (instance, class, constructor). After some
3957 comments/suggestions by J. Hunter.
3964 comments/suggestions by J. Hunter.
3958
3965
3959 2004-12-05 Fernando Perez <fperez@colorado.edu>
3966 2004-12-05 Fernando Perez <fperez@colorado.edu>
3960
3967
3961 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
3968 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
3962 warnings when tab-completion fails and triggers an exception.
3969 warnings when tab-completion fails and triggers an exception.
3963
3970
3964 2004-12-03 Fernando Perez <fperez@colorado.edu>
3971 2004-12-03 Fernando Perez <fperez@colorado.edu>
3965
3972
3966 * IPython/Magic.py (magic_prun): Fix bug where an exception would
3973 * IPython/Magic.py (magic_prun): Fix bug where an exception would
3967 be triggered when using 'run -p'. An incorrect option flag was
3974 be triggered when using 'run -p'. An incorrect option flag was
3968 being set ('d' instead of 'D').
3975 being set ('d' instead of 'D').
3969 (manpage): fix missing escaped \- sign.
3976 (manpage): fix missing escaped \- sign.
3970
3977
3971 2004-11-30 *** Released version 0.6.5
3978 2004-11-30 *** Released version 0.6.5
3972
3979
3973 2004-11-30 Fernando Perez <fperez@colorado.edu>
3980 2004-11-30 Fernando Perez <fperez@colorado.edu>
3974
3981
3975 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
3982 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
3976 setting with -d option.
3983 setting with -d option.
3977
3984
3978 * setup.py (docfiles): Fix problem where the doc glob I was using
3985 * setup.py (docfiles): Fix problem where the doc glob I was using
3979 was COMPLETELY BROKEN. It was giving the right files by pure
3986 was COMPLETELY BROKEN. It was giving the right files by pure
3980 accident, but failed once I tried to include ipython.el. Note:
3987 accident, but failed once I tried to include ipython.el. Note:
3981 glob() does NOT allow you to do exclusion on multiple endings!
3988 glob() does NOT allow you to do exclusion on multiple endings!
3982
3989
3983 2004-11-29 Fernando Perez <fperez@colorado.edu>
3990 2004-11-29 Fernando Perez <fperez@colorado.edu>
3984
3991
3985 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
3992 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
3986 the manpage as the source. Better formatting & consistency.
3993 the manpage as the source. Better formatting & consistency.
3987
3994
3988 * IPython/Magic.py (magic_run): Added new -d option, to run
3995 * IPython/Magic.py (magic_run): Added new -d option, to run
3989 scripts under the control of the python pdb debugger. Note that
3996 scripts under the control of the python pdb debugger. Note that
3990 this required changing the %prun option -d to -D, to avoid a clash
3997 this required changing the %prun option -d to -D, to avoid a clash
3991 (since %run must pass options to %prun, and getopt is too dumb to
3998 (since %run must pass options to %prun, and getopt is too dumb to
3992 handle options with string values with embedded spaces). Thanks
3999 handle options with string values with embedded spaces). Thanks
3993 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
4000 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
3994 (magic_who_ls): added type matching to %who and %whos, so that one
4001 (magic_who_ls): added type matching to %who and %whos, so that one
3995 can filter their output to only include variables of certain
4002 can filter their output to only include variables of certain
3996 types. Another suggestion by Matthew.
4003 types. Another suggestion by Matthew.
3997 (magic_whos): Added memory summaries in kb and Mb for arrays.
4004 (magic_whos): Added memory summaries in kb and Mb for arrays.
3998 (magic_who): Improve formatting (break lines every 9 vars).
4005 (magic_who): Improve formatting (break lines every 9 vars).
3999
4006
4000 2004-11-28 Fernando Perez <fperez@colorado.edu>
4007 2004-11-28 Fernando Perez <fperez@colorado.edu>
4001
4008
4002 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
4009 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
4003 cache when empty lines were present.
4010 cache when empty lines were present.
4004
4011
4005 2004-11-24 Fernando Perez <fperez@colorado.edu>
4012 2004-11-24 Fernando Perez <fperez@colorado.edu>
4006
4013
4007 * IPython/usage.py (__doc__): document the re-activated threading
4014 * IPython/usage.py (__doc__): document the re-activated threading
4008 options for WX and GTK.
4015 options for WX and GTK.
4009
4016
4010 2004-11-23 Fernando Perez <fperez@colorado.edu>
4017 2004-11-23 Fernando Perez <fperez@colorado.edu>
4011
4018
4012 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
4019 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
4013 the -wthread and -gthread options, along with a new -tk one to try
4020 the -wthread and -gthread options, along with a new -tk one to try
4014 and coordinate Tk threading with wx/gtk. The tk support is very
4021 and coordinate Tk threading with wx/gtk. The tk support is very
4015 platform dependent, since it seems to require Tcl and Tk to be
4022 platform dependent, since it seems to require Tcl and Tk to be
4016 built with threads (Fedora1/2 appears NOT to have it, but in
4023 built with threads (Fedora1/2 appears NOT to have it, but in
4017 Prabhu's Debian boxes it works OK). But even with some Tk
4024 Prabhu's Debian boxes it works OK). But even with some Tk
4018 limitations, this is a great improvement.
4025 limitations, this is a great improvement.
4019
4026
4020 * IPython/Prompts.py (prompt_specials_color): Added \t for time
4027 * IPython/Prompts.py (prompt_specials_color): Added \t for time
4021 info in user prompts. Patch by Prabhu.
4028 info in user prompts. Patch by Prabhu.
4022
4029
4023 2004-11-18 Fernando Perez <fperez@colorado.edu>
4030 2004-11-18 Fernando Perez <fperez@colorado.edu>
4024
4031
4025 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
4032 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
4026 EOFErrors and bail, to avoid infinite loops if a non-terminating
4033 EOFErrors and bail, to avoid infinite loops if a non-terminating
4027 file is fed into ipython. Patch submitted in issue 19 by user,
4034 file is fed into ipython. Patch submitted in issue 19 by user,
4028 many thanks.
4035 many thanks.
4029
4036
4030 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
4037 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
4031 autoquote/parens in continuation prompts, which can cause lots of
4038 autoquote/parens in continuation prompts, which can cause lots of
4032 problems. Closes roundup issue 20.
4039 problems. Closes roundup issue 20.
4033
4040
4034 2004-11-17 Fernando Perez <fperez@colorado.edu>
4041 2004-11-17 Fernando Perez <fperez@colorado.edu>
4035
4042
4036 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
4043 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
4037 reported as debian bug #280505. I'm not sure my local changelog
4044 reported as debian bug #280505. I'm not sure my local changelog
4038 entry has the proper debian format (Jack?).
4045 entry has the proper debian format (Jack?).
4039
4046
4040 2004-11-08 *** Released version 0.6.4
4047 2004-11-08 *** Released version 0.6.4
4041
4048
4042 2004-11-08 Fernando Perez <fperez@colorado.edu>
4049 2004-11-08 Fernando Perez <fperez@colorado.edu>
4043
4050
4044 * IPython/iplib.py (init_readline): Fix exit message for Windows
4051 * IPython/iplib.py (init_readline): Fix exit message for Windows
4045 when readline is active. Thanks to a report by Eric Jones
4052 when readline is active. Thanks to a report by Eric Jones
4046 <eric-AT-enthought.com>.
4053 <eric-AT-enthought.com>.
4047
4054
4048 2004-11-07 Fernando Perez <fperez@colorado.edu>
4055 2004-11-07 Fernando Perez <fperez@colorado.edu>
4049
4056
4050 * IPython/genutils.py (page): Add a trap for OSError exceptions,
4057 * IPython/genutils.py (page): Add a trap for OSError exceptions,
4051 sometimes seen by win2k/cygwin users.
4058 sometimes seen by win2k/cygwin users.
4052
4059
4053 2004-11-06 Fernando Perez <fperez@colorado.edu>
4060 2004-11-06 Fernando Perez <fperez@colorado.edu>
4054
4061
4055 * IPython/iplib.py (interact): Change the handling of %Exit from
4062 * IPython/iplib.py (interact): Change the handling of %Exit from
4056 trying to propagate a SystemExit to an internal ipython flag.
4063 trying to propagate a SystemExit to an internal ipython flag.
4057 This is less elegant than using Python's exception mechanism, but
4064 This is less elegant than using Python's exception mechanism, but
4058 I can't get that to work reliably with threads, so under -pylab
4065 I can't get that to work reliably with threads, so under -pylab
4059 %Exit was hanging IPython. Cross-thread exception handling is
4066 %Exit was hanging IPython. Cross-thread exception handling is
4060 really a bitch. Thaks to a bug report by Stephen Walton
4067 really a bitch. Thaks to a bug report by Stephen Walton
4061 <stephen.walton-AT-csun.edu>.
4068 <stephen.walton-AT-csun.edu>.
4062
4069
4063 2004-11-04 Fernando Perez <fperez@colorado.edu>
4070 2004-11-04 Fernando Perez <fperez@colorado.edu>
4064
4071
4065 * IPython/iplib.py (raw_input_original): store a pointer to the
4072 * IPython/iplib.py (raw_input_original): store a pointer to the
4066 true raw_input to harden against code which can modify it
4073 true raw_input to harden against code which can modify it
4067 (wx.py.PyShell does this and would otherwise crash ipython).
4074 (wx.py.PyShell does this and would otherwise crash ipython).
4068 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
4075 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
4069
4076
4070 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
4077 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
4071 Ctrl-C problem, which does not mess up the input line.
4078 Ctrl-C problem, which does not mess up the input line.
4072
4079
4073 2004-11-03 Fernando Perez <fperez@colorado.edu>
4080 2004-11-03 Fernando Perez <fperez@colorado.edu>
4074
4081
4075 * IPython/Release.py: Changed licensing to BSD, in all files.
4082 * IPython/Release.py: Changed licensing to BSD, in all files.
4076 (name): lowercase name for tarball/RPM release.
4083 (name): lowercase name for tarball/RPM release.
4077
4084
4078 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
4085 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
4079 use throughout ipython.
4086 use throughout ipython.
4080
4087
4081 * IPython/Magic.py (Magic._ofind): Switch to using the new
4088 * IPython/Magic.py (Magic._ofind): Switch to using the new
4082 OInspect.getdoc() function.
4089 OInspect.getdoc() function.
4083
4090
4084 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
4091 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
4085 of the line currently being canceled via Ctrl-C. It's extremely
4092 of the line currently being canceled via Ctrl-C. It's extremely
4086 ugly, but I don't know how to do it better (the problem is one of
4093 ugly, but I don't know how to do it better (the problem is one of
4087 handling cross-thread exceptions).
4094 handling cross-thread exceptions).
4088
4095
4089 2004-10-28 Fernando Perez <fperez@colorado.edu>
4096 2004-10-28 Fernando Perez <fperez@colorado.edu>
4090
4097
4091 * IPython/Shell.py (signal_handler): add signal handlers to trap
4098 * IPython/Shell.py (signal_handler): add signal handlers to trap
4092 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
4099 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
4093 report by Francesc Alted.
4100 report by Francesc Alted.
4094
4101
4095 2004-10-21 Fernando Perez <fperez@colorado.edu>
4102 2004-10-21 Fernando Perez <fperez@colorado.edu>
4096
4103
4097 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
4104 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
4098 to % for pysh syntax extensions.
4105 to % for pysh syntax extensions.
4099
4106
4100 2004-10-09 Fernando Perez <fperez@colorado.edu>
4107 2004-10-09 Fernando Perez <fperez@colorado.edu>
4101
4108
4102 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
4109 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
4103 arrays to print a more useful summary, without calling str(arr).
4110 arrays to print a more useful summary, without calling str(arr).
4104 This avoids the problem of extremely lengthy computations which
4111 This avoids the problem of extremely lengthy computations which
4105 occur if arr is large, and appear to the user as a system lockup
4112 occur if arr is large, and appear to the user as a system lockup
4106 with 100% cpu activity. After a suggestion by Kristian Sandberg
4113 with 100% cpu activity. After a suggestion by Kristian Sandberg
4107 <Kristian.Sandberg@colorado.edu>.
4114 <Kristian.Sandberg@colorado.edu>.
4108 (Magic.__init__): fix bug in global magic escapes not being
4115 (Magic.__init__): fix bug in global magic escapes not being
4109 correctly set.
4116 correctly set.
4110
4117
4111 2004-10-08 Fernando Perez <fperez@colorado.edu>
4118 2004-10-08 Fernando Perez <fperez@colorado.edu>
4112
4119
4113 * IPython/Magic.py (__license__): change to absolute imports of
4120 * IPython/Magic.py (__license__): change to absolute imports of
4114 ipython's own internal packages, to start adapting to the absolute
4121 ipython's own internal packages, to start adapting to the absolute
4115 import requirement of PEP-328.
4122 import requirement of PEP-328.
4116
4123
4117 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
4124 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
4118 files, and standardize author/license marks through the Release
4125 files, and standardize author/license marks through the Release
4119 module instead of having per/file stuff (except for files with
4126 module instead of having per/file stuff (except for files with
4120 particular licenses, like the MIT/PSF-licensed codes).
4127 particular licenses, like the MIT/PSF-licensed codes).
4121
4128
4122 * IPython/Debugger.py: remove dead code for python 2.1
4129 * IPython/Debugger.py: remove dead code for python 2.1
4123
4130
4124 2004-10-04 Fernando Perez <fperez@colorado.edu>
4131 2004-10-04 Fernando Perez <fperez@colorado.edu>
4125
4132
4126 * IPython/iplib.py (ipmagic): New function for accessing magics
4133 * IPython/iplib.py (ipmagic): New function for accessing magics
4127 via a normal python function call.
4134 via a normal python function call.
4128
4135
4129 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
4136 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
4130 from '@' to '%', to accomodate the new @decorator syntax of python
4137 from '@' to '%', to accomodate the new @decorator syntax of python
4131 2.4.
4138 2.4.
4132
4139
4133 2004-09-29 Fernando Perez <fperez@colorado.edu>
4140 2004-09-29 Fernando Perez <fperez@colorado.edu>
4134
4141
4135 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
4142 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
4136 matplotlib.use to prevent running scripts which try to switch
4143 matplotlib.use to prevent running scripts which try to switch
4137 interactive backends from within ipython. This will just crash
4144 interactive backends from within ipython. This will just crash
4138 the python interpreter, so we can't allow it (but a detailed error
4145 the python interpreter, so we can't allow it (but a detailed error
4139 is given to the user).
4146 is given to the user).
4140
4147
4141 2004-09-28 Fernando Perez <fperez@colorado.edu>
4148 2004-09-28 Fernando Perez <fperez@colorado.edu>
4142
4149
4143 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
4150 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
4144 matplotlib-related fixes so that using @run with non-matplotlib
4151 matplotlib-related fixes so that using @run with non-matplotlib
4145 scripts doesn't pop up spurious plot windows. This requires
4152 scripts doesn't pop up spurious plot windows. This requires
4146 matplotlib >= 0.63, where I had to make some changes as well.
4153 matplotlib >= 0.63, where I had to make some changes as well.
4147
4154
4148 * IPython/ipmaker.py (make_IPython): update version requirement to
4155 * IPython/ipmaker.py (make_IPython): update version requirement to
4149 python 2.2.
4156 python 2.2.
4150
4157
4151 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
4158 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
4152 banner arg for embedded customization.
4159 banner arg for embedded customization.
4153
4160
4154 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
4161 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
4155 explicit uses of __IP as the IPython's instance name. Now things
4162 explicit uses of __IP as the IPython's instance name. Now things
4156 are properly handled via the shell.name value. The actual code
4163 are properly handled via the shell.name value. The actual code
4157 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
4164 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
4158 is much better than before. I'll clean things completely when the
4165 is much better than before. I'll clean things completely when the
4159 magic stuff gets a real overhaul.
4166 magic stuff gets a real overhaul.
4160
4167
4161 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
4168 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
4162 minor changes to debian dir.
4169 minor changes to debian dir.
4163
4170
4164 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
4171 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
4165 pointer to the shell itself in the interactive namespace even when
4172 pointer to the shell itself in the interactive namespace even when
4166 a user-supplied dict is provided. This is needed for embedding
4173 a user-supplied dict is provided. This is needed for embedding
4167 purposes (found by tests with Michel Sanner).
4174 purposes (found by tests with Michel Sanner).
4168
4175
4169 2004-09-27 Fernando Perez <fperez@colorado.edu>
4176 2004-09-27 Fernando Perez <fperez@colorado.edu>
4170
4177
4171 * IPython/UserConfig/ipythonrc: remove []{} from
4178 * IPython/UserConfig/ipythonrc: remove []{} from
4172 readline_remove_delims, so that things like [modname.<TAB> do
4179 readline_remove_delims, so that things like [modname.<TAB> do
4173 proper completion. This disables [].TAB, but that's a less common
4180 proper completion. This disables [].TAB, but that's a less common
4174 case than module names in list comprehensions, for example.
4181 case than module names in list comprehensions, for example.
4175 Thanks to a report by Andrea Riciputi.
4182 Thanks to a report by Andrea Riciputi.
4176
4183
4177 2004-09-09 Fernando Perez <fperez@colorado.edu>
4184 2004-09-09 Fernando Perez <fperez@colorado.edu>
4178
4185
4179 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
4186 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
4180 blocking problems in win32 and osx. Fix by John.
4187 blocking problems in win32 and osx. Fix by John.
4181
4188
4182 2004-09-08 Fernando Perez <fperez@colorado.edu>
4189 2004-09-08 Fernando Perez <fperez@colorado.edu>
4183
4190
4184 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
4191 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
4185 for Win32 and OSX. Fix by John Hunter.
4192 for Win32 and OSX. Fix by John Hunter.
4186
4193
4187 2004-08-30 *** Released version 0.6.3
4194 2004-08-30 *** Released version 0.6.3
4188
4195
4189 2004-08-30 Fernando Perez <fperez@colorado.edu>
4196 2004-08-30 Fernando Perez <fperez@colorado.edu>
4190
4197
4191 * setup.py (isfile): Add manpages to list of dependent files to be
4198 * setup.py (isfile): Add manpages to list of dependent files to be
4192 updated.
4199 updated.
4193
4200
4194 2004-08-27 Fernando Perez <fperez@colorado.edu>
4201 2004-08-27 Fernando Perez <fperez@colorado.edu>
4195
4202
4196 * IPython/Shell.py (start): I've disabled -wthread and -gthread
4203 * IPython/Shell.py (start): I've disabled -wthread and -gthread
4197 for now. They don't really work with standalone WX/GTK code
4204 for now. They don't really work with standalone WX/GTK code
4198 (though matplotlib IS working fine with both of those backends).
4205 (though matplotlib IS working fine with both of those backends).
4199 This will neeed much more testing. I disabled most things with
4206 This will neeed much more testing. I disabled most things with
4200 comments, so turning it back on later should be pretty easy.
4207 comments, so turning it back on later should be pretty easy.
4201
4208
4202 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
4209 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
4203 autocalling of expressions like r'foo', by modifying the line
4210 autocalling of expressions like r'foo', by modifying the line
4204 split regexp. Closes
4211 split regexp. Closes
4205 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
4212 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
4206 Riley <ipythonbugs-AT-sabi.net>.
4213 Riley <ipythonbugs-AT-sabi.net>.
4207 (InteractiveShell.mainloop): honor --nobanner with banner
4214 (InteractiveShell.mainloop): honor --nobanner with banner
4208 extensions.
4215 extensions.
4209
4216
4210 * IPython/Shell.py: Significant refactoring of all classes, so
4217 * IPython/Shell.py: Significant refactoring of all classes, so
4211 that we can really support ALL matplotlib backends and threading
4218 that we can really support ALL matplotlib backends and threading
4212 models (John spotted a bug with Tk which required this). Now we
4219 models (John spotted a bug with Tk which required this). Now we
4213 should support single-threaded, WX-threads and GTK-threads, both
4220 should support single-threaded, WX-threads and GTK-threads, both
4214 for generic code and for matplotlib.
4221 for generic code and for matplotlib.
4215
4222
4216 * IPython/ipmaker.py (__call__): Changed -mpthread option to
4223 * IPython/ipmaker.py (__call__): Changed -mpthread option to
4217 -pylab, to simplify things for users. Will also remove the pylab
4224 -pylab, to simplify things for users. Will also remove the pylab
4218 profile, since now all of matplotlib configuration is directly
4225 profile, since now all of matplotlib configuration is directly
4219 handled here. This also reduces startup time.
4226 handled here. This also reduces startup time.
4220
4227
4221 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
4228 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
4222 shell wasn't being correctly called. Also in IPShellWX.
4229 shell wasn't being correctly called. Also in IPShellWX.
4223
4230
4224 * IPython/iplib.py (InteractiveShell.__init__): Added option to
4231 * IPython/iplib.py (InteractiveShell.__init__): Added option to
4225 fine-tune banner.
4232 fine-tune banner.
4226
4233
4227 * IPython/numutils.py (spike): Deprecate these spike functions,
4234 * IPython/numutils.py (spike): Deprecate these spike functions,
4228 delete (long deprecated) gnuplot_exec handler.
4235 delete (long deprecated) gnuplot_exec handler.
4229
4236
4230 2004-08-26 Fernando Perez <fperez@colorado.edu>
4237 2004-08-26 Fernando Perez <fperez@colorado.edu>
4231
4238
4232 * ipython.1: Update for threading options, plus some others which
4239 * ipython.1: Update for threading options, plus some others which
4233 were missing.
4240 were missing.
4234
4241
4235 * IPython/ipmaker.py (__call__): Added -wthread option for
4242 * IPython/ipmaker.py (__call__): Added -wthread option for
4236 wxpython thread handling. Make sure threading options are only
4243 wxpython thread handling. Make sure threading options are only
4237 valid at the command line.
4244 valid at the command line.
4238
4245
4239 * scripts/ipython: moved shell selection into a factory function
4246 * scripts/ipython: moved shell selection into a factory function
4240 in Shell.py, to keep the starter script to a minimum.
4247 in Shell.py, to keep the starter script to a minimum.
4241
4248
4242 2004-08-25 Fernando Perez <fperez@colorado.edu>
4249 2004-08-25 Fernando Perez <fperez@colorado.edu>
4243
4250
4244 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
4251 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
4245 John. Along with some recent changes he made to matplotlib, the
4252 John. Along with some recent changes he made to matplotlib, the
4246 next versions of both systems should work very well together.
4253 next versions of both systems should work very well together.
4247
4254
4248 2004-08-24 Fernando Perez <fperez@colorado.edu>
4255 2004-08-24 Fernando Perez <fperez@colorado.edu>
4249
4256
4250 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
4257 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
4251 tried to switch the profiling to using hotshot, but I'm getting
4258 tried to switch the profiling to using hotshot, but I'm getting
4252 strange errors from prof.runctx() there. I may be misreading the
4259 strange errors from prof.runctx() there. I may be misreading the
4253 docs, but it looks weird. For now the profiling code will
4260 docs, but it looks weird. For now the profiling code will
4254 continue to use the standard profiler.
4261 continue to use the standard profiler.
4255
4262
4256 2004-08-23 Fernando Perez <fperez@colorado.edu>
4263 2004-08-23 Fernando Perez <fperez@colorado.edu>
4257
4264
4258 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
4265 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
4259 threaded shell, by John Hunter. It's not quite ready yet, but
4266 threaded shell, by John Hunter. It's not quite ready yet, but
4260 close.
4267 close.
4261
4268
4262 2004-08-22 Fernando Perez <fperez@colorado.edu>
4269 2004-08-22 Fernando Perez <fperez@colorado.edu>
4263
4270
4264 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
4271 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
4265 in Magic and ultraTB.
4272 in Magic and ultraTB.
4266
4273
4267 * ipython.1: document threading options in manpage.
4274 * ipython.1: document threading options in manpage.
4268
4275
4269 * scripts/ipython: Changed name of -thread option to -gthread,
4276 * scripts/ipython: Changed name of -thread option to -gthread,
4270 since this is GTK specific. I want to leave the door open for a
4277 since this is GTK specific. I want to leave the door open for a
4271 -wthread option for WX, which will most likely be necessary. This
4278 -wthread option for WX, which will most likely be necessary. This
4272 change affects usage and ipmaker as well.
4279 change affects usage and ipmaker as well.
4273
4280
4274 * IPython/Shell.py (matplotlib_shell): Add a factory function to
4281 * IPython/Shell.py (matplotlib_shell): Add a factory function to
4275 handle the matplotlib shell issues. Code by John Hunter
4282 handle the matplotlib shell issues. Code by John Hunter
4276 <jdhunter-AT-nitace.bsd.uchicago.edu>.
4283 <jdhunter-AT-nitace.bsd.uchicago.edu>.
4277 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
4284 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
4278 broken (and disabled for end users) for now, but it puts the
4285 broken (and disabled for end users) for now, but it puts the
4279 infrastructure in place.
4286 infrastructure in place.
4280
4287
4281 2004-08-21 Fernando Perez <fperez@colorado.edu>
4288 2004-08-21 Fernando Perez <fperez@colorado.edu>
4282
4289
4283 * ipythonrc-pylab: Add matplotlib support.
4290 * ipythonrc-pylab: Add matplotlib support.
4284
4291
4285 * matplotlib_config.py: new files for matplotlib support, part of
4292 * matplotlib_config.py: new files for matplotlib support, part of
4286 the pylab profile.
4293 the pylab profile.
4287
4294
4288 * IPython/usage.py (__doc__): documented the threading options.
4295 * IPython/usage.py (__doc__): documented the threading options.
4289
4296
4290 2004-08-20 Fernando Perez <fperez@colorado.edu>
4297 2004-08-20 Fernando Perez <fperez@colorado.edu>
4291
4298
4292 * ipython: Modified the main calling routine to handle the -thread
4299 * ipython: Modified the main calling routine to handle the -thread
4293 and -mpthread options. This needs to be done as a top-level hack,
4300 and -mpthread options. This needs to be done as a top-level hack,
4294 because it determines which class to instantiate for IPython
4301 because it determines which class to instantiate for IPython
4295 itself.
4302 itself.
4296
4303
4297 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
4304 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
4298 classes to support multithreaded GTK operation without blocking,
4305 classes to support multithreaded GTK operation without blocking,
4299 and matplotlib with all backends. This is a lot of still very
4306 and matplotlib with all backends. This is a lot of still very
4300 experimental code, and threads are tricky. So it may still have a
4307 experimental code, and threads are tricky. So it may still have a
4301 few rough edges... This code owes a lot to
4308 few rough edges... This code owes a lot to
4302 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
4309 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
4303 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
4310 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
4304 to John Hunter for all the matplotlib work.
4311 to John Hunter for all the matplotlib work.
4305
4312
4306 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
4313 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
4307 options for gtk thread and matplotlib support.
4314 options for gtk thread and matplotlib support.
4308
4315
4309 2004-08-16 Fernando Perez <fperez@colorado.edu>
4316 2004-08-16 Fernando Perez <fperez@colorado.edu>
4310
4317
4311 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
4318 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
4312 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
4319 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
4313 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
4320 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
4314
4321
4315 2004-08-11 Fernando Perez <fperez@colorado.edu>
4322 2004-08-11 Fernando Perez <fperez@colorado.edu>
4316
4323
4317 * setup.py (isfile): Fix build so documentation gets updated for
4324 * setup.py (isfile): Fix build so documentation gets updated for
4318 rpms (it was only done for .tgz builds).
4325 rpms (it was only done for .tgz builds).
4319
4326
4320 2004-08-10 Fernando Perez <fperez@colorado.edu>
4327 2004-08-10 Fernando Perez <fperez@colorado.edu>
4321
4328
4322 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
4329 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
4323
4330
4324 * iplib.py : Silence syntax error exceptions in tab-completion.
4331 * iplib.py : Silence syntax error exceptions in tab-completion.
4325
4332
4326 2004-08-05 Fernando Perez <fperez@colorado.edu>
4333 2004-08-05 Fernando Perez <fperez@colorado.edu>
4327
4334
4328 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
4335 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
4329 'color off' mark for continuation prompts. This was causing long
4336 'color off' mark for continuation prompts. This was causing long
4330 continuation lines to mis-wrap.
4337 continuation lines to mis-wrap.
4331
4338
4332 2004-08-01 Fernando Perez <fperez@colorado.edu>
4339 2004-08-01 Fernando Perez <fperez@colorado.edu>
4333
4340
4334 * IPython/ipmaker.py (make_IPython): Allow the shell class used
4341 * IPython/ipmaker.py (make_IPython): Allow the shell class used
4335 for building ipython to be a parameter. All this is necessary
4342 for building ipython to be a parameter. All this is necessary
4336 right now to have a multithreaded version, but this insane
4343 right now to have a multithreaded version, but this insane
4337 non-design will be cleaned up soon. For now, it's a hack that
4344 non-design will be cleaned up soon. For now, it's a hack that
4338 works.
4345 works.
4339
4346
4340 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
4347 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
4341 args in various places. No bugs so far, but it's a dangerous
4348 args in various places. No bugs so far, but it's a dangerous
4342 practice.
4349 practice.
4343
4350
4344 2004-07-31 Fernando Perez <fperez@colorado.edu>
4351 2004-07-31 Fernando Perez <fperez@colorado.edu>
4345
4352
4346 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
4353 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
4347 fix completion of files with dots in their names under most
4354 fix completion of files with dots in their names under most
4348 profiles (pysh was OK because the completion order is different).
4355 profiles (pysh was OK because the completion order is different).
4349
4356
4350 2004-07-27 Fernando Perez <fperez@colorado.edu>
4357 2004-07-27 Fernando Perez <fperez@colorado.edu>
4351
4358
4352 * IPython/iplib.py (InteractiveShell.__init__): build dict of
4359 * IPython/iplib.py (InteractiveShell.__init__): build dict of
4353 keywords manually, b/c the one in keyword.py was removed in python
4360 keywords manually, b/c the one in keyword.py was removed in python
4354 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
4361 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
4355 This is NOT a bug under python 2.3 and earlier.
4362 This is NOT a bug under python 2.3 and earlier.
4356
4363
4357 2004-07-26 Fernando Perez <fperez@colorado.edu>
4364 2004-07-26 Fernando Perez <fperez@colorado.edu>
4358
4365
4359 * IPython/ultraTB.py (VerboseTB.text): Add another
4366 * IPython/ultraTB.py (VerboseTB.text): Add another
4360 linecache.checkcache() call to try to prevent inspect.py from
4367 linecache.checkcache() call to try to prevent inspect.py from
4361 crashing under python 2.3. I think this fixes
4368 crashing under python 2.3. I think this fixes
4362 http://www.scipy.net/roundup/ipython/issue17.
4369 http://www.scipy.net/roundup/ipython/issue17.
4363
4370
4364 2004-07-26 *** Released version 0.6.2
4371 2004-07-26 *** Released version 0.6.2
4365
4372
4366 2004-07-26 Fernando Perez <fperez@colorado.edu>
4373 2004-07-26 Fernando Perez <fperez@colorado.edu>
4367
4374
4368 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
4375 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
4369 fail for any number.
4376 fail for any number.
4370 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
4377 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
4371 empty bookmarks.
4378 empty bookmarks.
4372
4379
4373 2004-07-26 *** Released version 0.6.1
4380 2004-07-26 *** Released version 0.6.1
4374
4381
4375 2004-07-26 Fernando Perez <fperez@colorado.edu>
4382 2004-07-26 Fernando Perez <fperez@colorado.edu>
4376
4383
4377 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
4384 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
4378
4385
4379 * IPython/iplib.py (protect_filename): Applied Ville's patch for
4386 * IPython/iplib.py (protect_filename): Applied Ville's patch for
4380 escaping '()[]{}' in filenames.
4387 escaping '()[]{}' in filenames.
4381
4388
4382 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
4389 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
4383 Python 2.2 users who lack a proper shlex.split.
4390 Python 2.2 users who lack a proper shlex.split.
4384
4391
4385 2004-07-19 Fernando Perez <fperez@colorado.edu>
4392 2004-07-19 Fernando Perez <fperez@colorado.edu>
4386
4393
4387 * IPython/iplib.py (InteractiveShell.init_readline): Add support
4394 * IPython/iplib.py (InteractiveShell.init_readline): Add support
4388 for reading readline's init file. I follow the normal chain:
4395 for reading readline's init file. I follow the normal chain:
4389 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
4396 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
4390 report by Mike Heeter. This closes
4397 report by Mike Heeter. This closes
4391 http://www.scipy.net/roundup/ipython/issue16.
4398 http://www.scipy.net/roundup/ipython/issue16.
4392
4399
4393 2004-07-18 Fernando Perez <fperez@colorado.edu>
4400 2004-07-18 Fernando Perez <fperez@colorado.edu>
4394
4401
4395 * IPython/iplib.py (__init__): Add better handling of '\' under
4402 * IPython/iplib.py (__init__): Add better handling of '\' under
4396 Win32 for filenames. After a patch by Ville.
4403 Win32 for filenames. After a patch by Ville.
4397
4404
4398 2004-07-17 Fernando Perez <fperez@colorado.edu>
4405 2004-07-17 Fernando Perez <fperez@colorado.edu>
4399
4406
4400 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
4407 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
4401 autocalling would be triggered for 'foo is bar' if foo is
4408 autocalling would be triggered for 'foo is bar' if foo is
4402 callable. I also cleaned up the autocall detection code to use a
4409 callable. I also cleaned up the autocall detection code to use a
4403 regexp, which is faster. Bug reported by Alexander Schmolck.
4410 regexp, which is faster. Bug reported by Alexander Schmolck.
4404
4411
4405 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
4412 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
4406 '?' in them would confuse the help system. Reported by Alex
4413 '?' in them would confuse the help system. Reported by Alex
4407 Schmolck.
4414 Schmolck.
4408
4415
4409 2004-07-16 Fernando Perez <fperez@colorado.edu>
4416 2004-07-16 Fernando Perez <fperez@colorado.edu>
4410
4417
4411 * IPython/GnuplotInteractive.py (__all__): added plot2.
4418 * IPython/GnuplotInteractive.py (__all__): added plot2.
4412
4419
4413 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
4420 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
4414 plotting dictionaries, lists or tuples of 1d arrays.
4421 plotting dictionaries, lists or tuples of 1d arrays.
4415
4422
4416 * IPython/Magic.py (Magic.magic_hist): small clenaups and
4423 * IPython/Magic.py (Magic.magic_hist): small clenaups and
4417 optimizations.
4424 optimizations.
4418
4425
4419 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
4426 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
4420 the information which was there from Janko's original IPP code:
4427 the information which was there from Janko's original IPP code:
4421
4428
4422 03.05.99 20:53 porto.ifm.uni-kiel.de
4429 03.05.99 20:53 porto.ifm.uni-kiel.de
4423 --Started changelog.
4430 --Started changelog.
4424 --make clear do what it say it does
4431 --make clear do what it say it does
4425 --added pretty output of lines from inputcache
4432 --added pretty output of lines from inputcache
4426 --Made Logger a mixin class, simplifies handling of switches
4433 --Made Logger a mixin class, simplifies handling of switches
4427 --Added own completer class. .string<TAB> expands to last history
4434 --Added own completer class. .string<TAB> expands to last history
4428 line which starts with string. The new expansion is also present
4435 line which starts with string. The new expansion is also present
4429 with Ctrl-r from the readline library. But this shows, who this
4436 with Ctrl-r from the readline library. But this shows, who this
4430 can be done for other cases.
4437 can be done for other cases.
4431 --Added convention that all shell functions should accept a
4438 --Added convention that all shell functions should accept a
4432 parameter_string This opens the door for different behaviour for
4439 parameter_string This opens the door for different behaviour for
4433 each function. @cd is a good example of this.
4440 each function. @cd is a good example of this.
4434
4441
4435 04.05.99 12:12 porto.ifm.uni-kiel.de
4442 04.05.99 12:12 porto.ifm.uni-kiel.de
4436 --added logfile rotation
4443 --added logfile rotation
4437 --added new mainloop method which freezes first the namespace
4444 --added new mainloop method which freezes first the namespace
4438
4445
4439 07.05.99 21:24 porto.ifm.uni-kiel.de
4446 07.05.99 21:24 porto.ifm.uni-kiel.de
4440 --added the docreader classes. Now there is a help system.
4447 --added the docreader classes. Now there is a help system.
4441 -This is only a first try. Currently it's not easy to put new
4448 -This is only a first try. Currently it's not easy to put new
4442 stuff in the indices. But this is the way to go. Info would be
4449 stuff in the indices. But this is the way to go. Info would be
4443 better, but HTML is every where and not everybody has an info
4450 better, but HTML is every where and not everybody has an info
4444 system installed and it's not so easy to change html-docs to info.
4451 system installed and it's not so easy to change html-docs to info.
4445 --added global logfile option
4452 --added global logfile option
4446 --there is now a hook for object inspection method pinfo needs to
4453 --there is now a hook for object inspection method pinfo needs to
4447 be provided for this. Can be reached by two '??'.
4454 be provided for this. Can be reached by two '??'.
4448
4455
4449 08.05.99 20:51 porto.ifm.uni-kiel.de
4456 08.05.99 20:51 porto.ifm.uni-kiel.de
4450 --added a README
4457 --added a README
4451 --bug in rc file. Something has changed so functions in the rc
4458 --bug in rc file. Something has changed so functions in the rc
4452 file need to reference the shell and not self. Not clear if it's a
4459 file need to reference the shell and not self. Not clear if it's a
4453 bug or feature.
4460 bug or feature.
4454 --changed rc file for new behavior
4461 --changed rc file for new behavior
4455
4462
4456 2004-07-15 Fernando Perez <fperez@colorado.edu>
4463 2004-07-15 Fernando Perez <fperez@colorado.edu>
4457
4464
4458 * IPython/Logger.py (Logger.log): fixed recent bug where the input
4465 * IPython/Logger.py (Logger.log): fixed recent bug where the input
4459 cache was falling out of sync in bizarre manners when multi-line
4466 cache was falling out of sync in bizarre manners when multi-line
4460 input was present. Minor optimizations and cleanup.
4467 input was present. Minor optimizations and cleanup.
4461
4468
4462 (Logger): Remove old Changelog info for cleanup. This is the
4469 (Logger): Remove old Changelog info for cleanup. This is the
4463 information which was there from Janko's original code:
4470 information which was there from Janko's original code:
4464
4471
4465 Changes to Logger: - made the default log filename a parameter
4472 Changes to Logger: - made the default log filename a parameter
4466
4473
4467 - put a check for lines beginning with !@? in log(). Needed
4474 - put a check for lines beginning with !@? in log(). Needed
4468 (even if the handlers properly log their lines) for mid-session
4475 (even if the handlers properly log their lines) for mid-session
4469 logging activation to work properly. Without this, lines logged
4476 logging activation to work properly. Without this, lines logged
4470 in mid session, which get read from the cache, would end up
4477 in mid session, which get read from the cache, would end up
4471 'bare' (with !@? in the open) in the log. Now they are caught
4478 'bare' (with !@? in the open) in the log. Now they are caught
4472 and prepended with a #.
4479 and prepended with a #.
4473
4480
4474 * IPython/iplib.py (InteractiveShell.init_readline): added check
4481 * IPython/iplib.py (InteractiveShell.init_readline): added check
4475 in case MagicCompleter fails to be defined, so we don't crash.
4482 in case MagicCompleter fails to be defined, so we don't crash.
4476
4483
4477 2004-07-13 Fernando Perez <fperez@colorado.edu>
4484 2004-07-13 Fernando Perez <fperez@colorado.edu>
4478
4485
4479 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
4486 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
4480 of EPS if the requested filename ends in '.eps'.
4487 of EPS if the requested filename ends in '.eps'.
4481
4488
4482 2004-07-04 Fernando Perez <fperez@colorado.edu>
4489 2004-07-04 Fernando Perez <fperez@colorado.edu>
4483
4490
4484 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
4491 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
4485 escaping of quotes when calling the shell.
4492 escaping of quotes when calling the shell.
4486
4493
4487 2004-07-02 Fernando Perez <fperez@colorado.edu>
4494 2004-07-02 Fernando Perez <fperez@colorado.edu>
4488
4495
4489 * IPython/Prompts.py (CachedOutput.update): Fix problem with
4496 * IPython/Prompts.py (CachedOutput.update): Fix problem with
4490 gettext not working because we were clobbering '_'. Fixes
4497 gettext not working because we were clobbering '_'. Fixes
4491 http://www.scipy.net/roundup/ipython/issue6.
4498 http://www.scipy.net/roundup/ipython/issue6.
4492
4499
4493 2004-07-01 Fernando Perez <fperez@colorado.edu>
4500 2004-07-01 Fernando Perez <fperez@colorado.edu>
4494
4501
4495 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
4502 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
4496 into @cd. Patch by Ville.
4503 into @cd. Patch by Ville.
4497
4504
4498 * IPython/iplib.py (InteractiveShell.post_config_initialization):
4505 * IPython/iplib.py (InteractiveShell.post_config_initialization):
4499 new function to store things after ipmaker runs. Patch by Ville.
4506 new function to store things after ipmaker runs. Patch by Ville.
4500 Eventually this will go away once ipmaker is removed and the class
4507 Eventually this will go away once ipmaker is removed and the class
4501 gets cleaned up, but for now it's ok. Key functionality here is
4508 gets cleaned up, but for now it's ok. Key functionality here is
4502 the addition of the persistent storage mechanism, a dict for
4509 the addition of the persistent storage mechanism, a dict for
4503 keeping data across sessions (for now just bookmarks, but more can
4510 keeping data across sessions (for now just bookmarks, but more can
4504 be implemented later).
4511 be implemented later).
4505
4512
4506 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
4513 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
4507 persistent across sections. Patch by Ville, I modified it
4514 persistent across sections. Patch by Ville, I modified it
4508 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
4515 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
4509 added a '-l' option to list all bookmarks.
4516 added a '-l' option to list all bookmarks.
4510
4517
4511 * IPython/iplib.py (InteractiveShell.atexit_operations): new
4518 * IPython/iplib.py (InteractiveShell.atexit_operations): new
4512 center for cleanup. Registered with atexit.register(). I moved
4519 center for cleanup. Registered with atexit.register(). I moved
4513 here the old exit_cleanup(). After a patch by Ville.
4520 here the old exit_cleanup(). After a patch by Ville.
4514
4521
4515 * IPython/Magic.py (get_py_filename): added '~' to the accepted
4522 * IPython/Magic.py (get_py_filename): added '~' to the accepted
4516 characters in the hacked shlex_split for python 2.2.
4523 characters in the hacked shlex_split for python 2.2.
4517
4524
4518 * IPython/iplib.py (file_matches): more fixes to filenames with
4525 * IPython/iplib.py (file_matches): more fixes to filenames with
4519 whitespace in them. It's not perfect, but limitations in python's
4526 whitespace in them. It's not perfect, but limitations in python's
4520 readline make it impossible to go further.
4527 readline make it impossible to go further.
4521
4528
4522 2004-06-29 Fernando Perez <fperez@colorado.edu>
4529 2004-06-29 Fernando Perez <fperez@colorado.edu>
4523
4530
4524 * IPython/iplib.py (file_matches): escape whitespace correctly in
4531 * IPython/iplib.py (file_matches): escape whitespace correctly in
4525 filename completions. Bug reported by Ville.
4532 filename completions. Bug reported by Ville.
4526
4533
4527 2004-06-28 Fernando Perez <fperez@colorado.edu>
4534 2004-06-28 Fernando Perez <fperez@colorado.edu>
4528
4535
4529 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
4536 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
4530 the history file will be called 'history-PROFNAME' (or just
4537 the history file will be called 'history-PROFNAME' (or just
4531 'history' if no profile is loaded). I was getting annoyed at
4538 'history' if no profile is loaded). I was getting annoyed at
4532 getting my Numerical work history clobbered by pysh sessions.
4539 getting my Numerical work history clobbered by pysh sessions.
4533
4540
4534 * IPython/iplib.py (InteractiveShell.__init__): Internal
4541 * IPython/iplib.py (InteractiveShell.__init__): Internal
4535 getoutputerror() function so that we can honor the system_verbose
4542 getoutputerror() function so that we can honor the system_verbose
4536 flag for _all_ system calls. I also added escaping of #
4543 flag for _all_ system calls. I also added escaping of #
4537 characters here to avoid confusing Itpl.
4544 characters here to avoid confusing Itpl.
4538
4545
4539 * IPython/Magic.py (shlex_split): removed call to shell in
4546 * IPython/Magic.py (shlex_split): removed call to shell in
4540 parse_options and replaced it with shlex.split(). The annoying
4547 parse_options and replaced it with shlex.split(). The annoying
4541 part was that in Python 2.2, shlex.split() doesn't exist, so I had
4548 part was that in Python 2.2, shlex.split() doesn't exist, so I had
4542 to backport it from 2.3, with several frail hacks (the shlex
4549 to backport it from 2.3, with several frail hacks (the shlex
4543 module is rather limited in 2.2). Thanks to a suggestion by Ville
4550 module is rather limited in 2.2). Thanks to a suggestion by Ville
4544 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
4551 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
4545 problem.
4552 problem.
4546
4553
4547 (Magic.magic_system_verbose): new toggle to print the actual
4554 (Magic.magic_system_verbose): new toggle to print the actual
4548 system calls made by ipython. Mainly for debugging purposes.
4555 system calls made by ipython. Mainly for debugging purposes.
4549
4556
4550 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
4557 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
4551 doesn't support persistence. Reported (and fix suggested) by
4558 doesn't support persistence. Reported (and fix suggested) by
4552 Travis Caldwell <travis_caldwell2000@yahoo.com>.
4559 Travis Caldwell <travis_caldwell2000@yahoo.com>.
4553
4560
4554 2004-06-26 Fernando Perez <fperez@colorado.edu>
4561 2004-06-26 Fernando Perez <fperez@colorado.edu>
4555
4562
4556 * IPython/Logger.py (Logger.log): fix to handle correctly empty
4563 * IPython/Logger.py (Logger.log): fix to handle correctly empty
4557 continue prompts.
4564 continue prompts.
4558
4565
4559 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
4566 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
4560 function (basically a big docstring) and a few more things here to
4567 function (basically a big docstring) and a few more things here to
4561 speedup startup. pysh.py is now very lightweight. We want because
4568 speedup startup. pysh.py is now very lightweight. We want because
4562 it gets execfile'd, while InterpreterExec gets imported, so
4569 it gets execfile'd, while InterpreterExec gets imported, so
4563 byte-compilation saves time.
4570 byte-compilation saves time.
4564
4571
4565 2004-06-25 Fernando Perez <fperez@colorado.edu>
4572 2004-06-25 Fernando Perez <fperez@colorado.edu>
4566
4573
4567 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
4574 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
4568 -NUM', which was recently broken.
4575 -NUM', which was recently broken.
4569
4576
4570 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
4577 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
4571 in multi-line input (but not !!, which doesn't make sense there).
4578 in multi-line input (but not !!, which doesn't make sense there).
4572
4579
4573 * IPython/UserConfig/ipythonrc: made autoindent on by default.
4580 * IPython/UserConfig/ipythonrc: made autoindent on by default.
4574 It's just too useful, and people can turn it off in the less
4581 It's just too useful, and people can turn it off in the less
4575 common cases where it's a problem.
4582 common cases where it's a problem.
4576
4583
4577 2004-06-24 Fernando Perez <fperez@colorado.edu>
4584 2004-06-24 Fernando Perez <fperez@colorado.edu>
4578
4585
4579 * IPython/iplib.py (InteractiveShell._prefilter): big change -
4586 * IPython/iplib.py (InteractiveShell._prefilter): big change -
4580 special syntaxes (like alias calling) is now allied in multi-line
4587 special syntaxes (like alias calling) is now allied in multi-line
4581 input. This is still _very_ experimental, but it's necessary for
4588 input. This is still _very_ experimental, but it's necessary for
4582 efficient shell usage combining python looping syntax with system
4589 efficient shell usage combining python looping syntax with system
4583 calls. For now it's restricted to aliases, I don't think it
4590 calls. For now it's restricted to aliases, I don't think it
4584 really even makes sense to have this for magics.
4591 really even makes sense to have this for magics.
4585
4592
4586 2004-06-23 Fernando Perez <fperez@colorado.edu>
4593 2004-06-23 Fernando Perez <fperez@colorado.edu>
4587
4594
4588 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
4595 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
4589 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
4596 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
4590
4597
4591 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
4598 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
4592 extensions under Windows (after code sent by Gary Bishop). The
4599 extensions under Windows (after code sent by Gary Bishop). The
4593 extensions considered 'executable' are stored in IPython's rc
4600 extensions considered 'executable' are stored in IPython's rc
4594 structure as win_exec_ext.
4601 structure as win_exec_ext.
4595
4602
4596 * IPython/genutils.py (shell): new function, like system() but
4603 * IPython/genutils.py (shell): new function, like system() but
4597 without return value. Very useful for interactive shell work.
4604 without return value. Very useful for interactive shell work.
4598
4605
4599 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
4606 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
4600 delete aliases.
4607 delete aliases.
4601
4608
4602 * IPython/iplib.py (InteractiveShell.alias_table_update): make
4609 * IPython/iplib.py (InteractiveShell.alias_table_update): make
4603 sure that the alias table doesn't contain python keywords.
4610 sure that the alias table doesn't contain python keywords.
4604
4611
4605 2004-06-21 Fernando Perez <fperez@colorado.edu>
4612 2004-06-21 Fernando Perez <fperez@colorado.edu>
4606
4613
4607 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
4614 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
4608 non-existent items are found in $PATH. Reported by Thorsten.
4615 non-existent items are found in $PATH. Reported by Thorsten.
4609
4616
4610 2004-06-20 Fernando Perez <fperez@colorado.edu>
4617 2004-06-20 Fernando Perez <fperez@colorado.edu>
4611
4618
4612 * IPython/iplib.py (complete): modified the completer so that the
4619 * IPython/iplib.py (complete): modified the completer so that the
4613 order of priorities can be easily changed at runtime.
4620 order of priorities can be easily changed at runtime.
4614
4621
4615 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
4622 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
4616 Modified to auto-execute all lines beginning with '~', '/' or '.'.
4623 Modified to auto-execute all lines beginning with '~', '/' or '.'.
4617
4624
4618 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
4625 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
4619 expand Python variables prepended with $ in all system calls. The
4626 expand Python variables prepended with $ in all system calls. The
4620 same was done to InteractiveShell.handle_shell_escape. Now all
4627 same was done to InteractiveShell.handle_shell_escape. Now all
4621 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
4628 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
4622 expansion of python variables and expressions according to the
4629 expansion of python variables and expressions according to the
4623 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
4630 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
4624
4631
4625 Though PEP-215 has been rejected, a similar (but simpler) one
4632 Though PEP-215 has been rejected, a similar (but simpler) one
4626 seems like it will go into Python 2.4, PEP-292 -
4633 seems like it will go into Python 2.4, PEP-292 -
4627 http://www.python.org/peps/pep-0292.html.
4634 http://www.python.org/peps/pep-0292.html.
4628
4635
4629 I'll keep the full syntax of PEP-215, since IPython has since the
4636 I'll keep the full syntax of PEP-215, since IPython has since the
4630 start used Ka-Ping Yee's reference implementation discussed there
4637 start used Ka-Ping Yee's reference implementation discussed there
4631 (Itpl), and I actually like the powerful semantics it offers.
4638 (Itpl), and I actually like the powerful semantics it offers.
4632
4639
4633 In order to access normal shell variables, the $ has to be escaped
4640 In order to access normal shell variables, the $ has to be escaped
4634 via an extra $. For example:
4641 via an extra $. For example:
4635
4642
4636 In [7]: PATH='a python variable'
4643 In [7]: PATH='a python variable'
4637
4644
4638 In [8]: !echo $PATH
4645 In [8]: !echo $PATH
4639 a python variable
4646 a python variable
4640
4647
4641 In [9]: !echo $$PATH
4648 In [9]: !echo $$PATH
4642 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
4649 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
4643
4650
4644 (Magic.parse_options): escape $ so the shell doesn't evaluate
4651 (Magic.parse_options): escape $ so the shell doesn't evaluate
4645 things prematurely.
4652 things prematurely.
4646
4653
4647 * IPython/iplib.py (InteractiveShell.call_alias): added the
4654 * IPython/iplib.py (InteractiveShell.call_alias): added the
4648 ability for aliases to expand python variables via $.
4655 ability for aliases to expand python variables via $.
4649
4656
4650 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
4657 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
4651 system, now there's a @rehash/@rehashx pair of magics. These work
4658 system, now there's a @rehash/@rehashx pair of magics. These work
4652 like the csh rehash command, and can be invoked at any time. They
4659 like the csh rehash command, and can be invoked at any time. They
4653 build a table of aliases to everything in the user's $PATH
4660 build a table of aliases to everything in the user's $PATH
4654 (@rehash uses everything, @rehashx is slower but only adds
4661 (@rehash uses everything, @rehashx is slower but only adds
4655 executable files). With this, the pysh.py-based shell profile can
4662 executable files). With this, the pysh.py-based shell profile can
4656 now simply call rehash upon startup, and full access to all
4663 now simply call rehash upon startup, and full access to all
4657 programs in the user's path is obtained.
4664 programs in the user's path is obtained.
4658
4665
4659 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
4666 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
4660 functionality is now fully in place. I removed the old dynamic
4667 functionality is now fully in place. I removed the old dynamic
4661 code generation based approach, in favor of a much lighter one
4668 code generation based approach, in favor of a much lighter one
4662 based on a simple dict. The advantage is that this allows me to
4669 based on a simple dict. The advantage is that this allows me to
4663 now have thousands of aliases with negligible cost (unthinkable
4670 now have thousands of aliases with negligible cost (unthinkable
4664 with the old system).
4671 with the old system).
4665
4672
4666 2004-06-19 Fernando Perez <fperez@colorado.edu>
4673 2004-06-19 Fernando Perez <fperez@colorado.edu>
4667
4674
4668 * IPython/iplib.py (__init__): extended MagicCompleter class to
4675 * IPython/iplib.py (__init__): extended MagicCompleter class to
4669 also complete (last in priority) on user aliases.
4676 also complete (last in priority) on user aliases.
4670
4677
4671 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
4678 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
4672 call to eval.
4679 call to eval.
4673 (ItplNS.__init__): Added a new class which functions like Itpl,
4680 (ItplNS.__init__): Added a new class which functions like Itpl,
4674 but allows configuring the namespace for the evaluation to occur
4681 but allows configuring the namespace for the evaluation to occur
4675 in.
4682 in.
4676
4683
4677 2004-06-18 Fernando Perez <fperez@colorado.edu>
4684 2004-06-18 Fernando Perez <fperez@colorado.edu>
4678
4685
4679 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
4686 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
4680 better message when 'exit' or 'quit' are typed (a common newbie
4687 better message when 'exit' or 'quit' are typed (a common newbie
4681 confusion).
4688 confusion).
4682
4689
4683 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
4690 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
4684 check for Windows users.
4691 check for Windows users.
4685
4692
4686 * IPython/iplib.py (InteractiveShell.user_setup): removed
4693 * IPython/iplib.py (InteractiveShell.user_setup): removed
4687 disabling of colors for Windows. I'll test at runtime and issue a
4694 disabling of colors for Windows. I'll test at runtime and issue a
4688 warning if Gary's readline isn't found, as to nudge users to
4695 warning if Gary's readline isn't found, as to nudge users to
4689 download it.
4696 download it.
4690
4697
4691 2004-06-16 Fernando Perez <fperez@colorado.edu>
4698 2004-06-16 Fernando Perez <fperez@colorado.edu>
4692
4699
4693 * IPython/genutils.py (Stream.__init__): changed to print errors
4700 * IPython/genutils.py (Stream.__init__): changed to print errors
4694 to sys.stderr. I had a circular dependency here. Now it's
4701 to sys.stderr. I had a circular dependency here. Now it's
4695 possible to run ipython as IDLE's shell (consider this pre-alpha,
4702 possible to run ipython as IDLE's shell (consider this pre-alpha,
4696 since true stdout things end up in the starting terminal instead
4703 since true stdout things end up in the starting terminal instead
4697 of IDLE's out).
4704 of IDLE's out).
4698
4705
4699 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
4706 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
4700 users who haven't # updated their prompt_in2 definitions. Remove
4707 users who haven't # updated their prompt_in2 definitions. Remove
4701 eventually.
4708 eventually.
4702 (multiple_replace): added credit to original ASPN recipe.
4709 (multiple_replace): added credit to original ASPN recipe.
4703
4710
4704 2004-06-15 Fernando Perez <fperez@colorado.edu>
4711 2004-06-15 Fernando Perez <fperez@colorado.edu>
4705
4712
4706 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
4713 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
4707 list of auto-defined aliases.
4714 list of auto-defined aliases.
4708
4715
4709 2004-06-13 Fernando Perez <fperez@colorado.edu>
4716 2004-06-13 Fernando Perez <fperez@colorado.edu>
4710
4717
4711 * setup.py (scriptfiles): Don't trigger win_post_install unless an
4718 * setup.py (scriptfiles): Don't trigger win_post_install unless an
4712 install was really requested (so setup.py can be used for other
4719 install was really requested (so setup.py can be used for other
4713 things under Windows).
4720 things under Windows).
4714
4721
4715 2004-06-10 Fernando Perez <fperez@colorado.edu>
4722 2004-06-10 Fernando Perez <fperez@colorado.edu>
4716
4723
4717 * IPython/Logger.py (Logger.create_log): Manually remove any old
4724 * IPython/Logger.py (Logger.create_log): Manually remove any old
4718 backup, since os.remove may fail under Windows. Fixes bug
4725 backup, since os.remove may fail under Windows. Fixes bug
4719 reported by Thorsten.
4726 reported by Thorsten.
4720
4727
4721 2004-06-09 Fernando Perez <fperez@colorado.edu>
4728 2004-06-09 Fernando Perez <fperez@colorado.edu>
4722
4729
4723 * examples/example-embed.py: fixed all references to %n (replaced
4730 * examples/example-embed.py: fixed all references to %n (replaced
4724 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
4731 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
4725 for all examples and the manual as well.
4732 for all examples and the manual as well.
4726
4733
4727 2004-06-08 Fernando Perez <fperez@colorado.edu>
4734 2004-06-08 Fernando Perez <fperez@colorado.edu>
4728
4735
4729 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
4736 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
4730 alignment and color management. All 3 prompt subsystems now
4737 alignment and color management. All 3 prompt subsystems now
4731 inherit from BasePrompt.
4738 inherit from BasePrompt.
4732
4739
4733 * tools/release: updates for windows installer build and tag rpms
4740 * tools/release: updates for windows installer build and tag rpms
4734 with python version (since paths are fixed).
4741 with python version (since paths are fixed).
4735
4742
4736 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
4743 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
4737 which will become eventually obsolete. Also fixed the default
4744 which will become eventually obsolete. Also fixed the default
4738 prompt_in2 to use \D, so at least new users start with the correct
4745 prompt_in2 to use \D, so at least new users start with the correct
4739 defaults.
4746 defaults.
4740 WARNING: Users with existing ipythonrc files will need to apply
4747 WARNING: Users with existing ipythonrc files will need to apply
4741 this fix manually!
4748 this fix manually!
4742
4749
4743 * setup.py: make windows installer (.exe). This is finally the
4750 * setup.py: make windows installer (.exe). This is finally the
4744 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
4751 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
4745 which I hadn't included because it required Python 2.3 (or recent
4752 which I hadn't included because it required Python 2.3 (or recent
4746 distutils).
4753 distutils).
4747
4754
4748 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
4755 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
4749 usage of new '\D' escape.
4756 usage of new '\D' escape.
4750
4757
4751 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
4758 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
4752 lacks os.getuid())
4759 lacks os.getuid())
4753 (CachedOutput.set_colors): Added the ability to turn coloring
4760 (CachedOutput.set_colors): Added the ability to turn coloring
4754 on/off with @colors even for manually defined prompt colors. It
4761 on/off with @colors even for manually defined prompt colors. It
4755 uses a nasty global, but it works safely and via the generic color
4762 uses a nasty global, but it works safely and via the generic color
4756 handling mechanism.
4763 handling mechanism.
4757 (Prompt2.__init__): Introduced new escape '\D' for continuation
4764 (Prompt2.__init__): Introduced new escape '\D' for continuation
4758 prompts. It represents the counter ('\#') as dots.
4765 prompts. It represents the counter ('\#') as dots.
4759 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
4766 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
4760 need to update their ipythonrc files and replace '%n' with '\D' in
4767 need to update their ipythonrc files and replace '%n' with '\D' in
4761 their prompt_in2 settings everywhere. Sorry, but there's
4768 their prompt_in2 settings everywhere. Sorry, but there's
4762 otherwise no clean way to get all prompts to properly align. The
4769 otherwise no clean way to get all prompts to properly align. The
4763 ipythonrc shipped with IPython has been updated.
4770 ipythonrc shipped with IPython has been updated.
4764
4771
4765 2004-06-07 Fernando Perez <fperez@colorado.edu>
4772 2004-06-07 Fernando Perez <fperez@colorado.edu>
4766
4773
4767 * setup.py (isfile): Pass local_icons option to latex2html, so the
4774 * setup.py (isfile): Pass local_icons option to latex2html, so the
4768 resulting HTML file is self-contained. Thanks to
4775 resulting HTML file is self-contained. Thanks to
4769 dryice-AT-liu.com.cn for the tip.
4776 dryice-AT-liu.com.cn for the tip.
4770
4777
4771 * pysh.py: I created a new profile 'shell', which implements a
4778 * pysh.py: I created a new profile 'shell', which implements a
4772 _rudimentary_ IPython-based shell. This is in NO WAY a realy
4779 _rudimentary_ IPython-based shell. This is in NO WAY a realy
4773 system shell, nor will it become one anytime soon. It's mainly
4780 system shell, nor will it become one anytime soon. It's mainly
4774 meant to illustrate the use of the new flexible bash-like prompts.
4781 meant to illustrate the use of the new flexible bash-like prompts.
4775 I guess it could be used by hardy souls for true shell management,
4782 I guess it could be used by hardy souls for true shell management,
4776 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
4783 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
4777 profile. This uses the InterpreterExec extension provided by
4784 profile. This uses the InterpreterExec extension provided by
4778 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
4785 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
4779
4786
4780 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
4787 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
4781 auto-align itself with the length of the previous input prompt
4788 auto-align itself with the length of the previous input prompt
4782 (taking into account the invisible color escapes).
4789 (taking into account the invisible color escapes).
4783 (CachedOutput.__init__): Large restructuring of this class. Now
4790 (CachedOutput.__init__): Large restructuring of this class. Now
4784 all three prompts (primary1, primary2, output) are proper objects,
4791 all three prompts (primary1, primary2, output) are proper objects,
4785 managed by the 'parent' CachedOutput class. The code is still a
4792 managed by the 'parent' CachedOutput class. The code is still a
4786 bit hackish (all prompts share state via a pointer to the cache),
4793 bit hackish (all prompts share state via a pointer to the cache),
4787 but it's overall far cleaner than before.
4794 but it's overall far cleaner than before.
4788
4795
4789 * IPython/genutils.py (getoutputerror): modified to add verbose,
4796 * IPython/genutils.py (getoutputerror): modified to add verbose,
4790 debug and header options. This makes the interface of all getout*
4797 debug and header options. This makes the interface of all getout*
4791 functions uniform.
4798 functions uniform.
4792 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
4799 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
4793
4800
4794 * IPython/Magic.py (Magic.default_option): added a function to
4801 * IPython/Magic.py (Magic.default_option): added a function to
4795 allow registering default options for any magic command. This
4802 allow registering default options for any magic command. This
4796 makes it easy to have profiles which customize the magics globally
4803 makes it easy to have profiles which customize the magics globally
4797 for a certain use. The values set through this function are
4804 for a certain use. The values set through this function are
4798 picked up by the parse_options() method, which all magics should
4805 picked up by the parse_options() method, which all magics should
4799 use to parse their options.
4806 use to parse their options.
4800
4807
4801 * IPython/genutils.py (warn): modified the warnings framework to
4808 * IPython/genutils.py (warn): modified the warnings framework to
4802 use the Term I/O class. I'm trying to slowly unify all of
4809 use the Term I/O class. I'm trying to slowly unify all of
4803 IPython's I/O operations to pass through Term.
4810 IPython's I/O operations to pass through Term.
4804
4811
4805 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
4812 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
4806 the secondary prompt to correctly match the length of the primary
4813 the secondary prompt to correctly match the length of the primary
4807 one for any prompt. Now multi-line code will properly line up
4814 one for any prompt. Now multi-line code will properly line up
4808 even for path dependent prompts, such as the new ones available
4815 even for path dependent prompts, such as the new ones available
4809 via the prompt_specials.
4816 via the prompt_specials.
4810
4817
4811 2004-06-06 Fernando Perez <fperez@colorado.edu>
4818 2004-06-06 Fernando Perez <fperez@colorado.edu>
4812
4819
4813 * IPython/Prompts.py (prompt_specials): Added the ability to have
4820 * IPython/Prompts.py (prompt_specials): Added the ability to have
4814 bash-like special sequences in the prompts, which get
4821 bash-like special sequences in the prompts, which get
4815 automatically expanded. Things like hostname, current working
4822 automatically expanded. Things like hostname, current working
4816 directory and username are implemented already, but it's easy to
4823 directory and username are implemented already, but it's easy to
4817 add more in the future. Thanks to a patch by W.J. van der Laan
4824 add more in the future. Thanks to a patch by W.J. van der Laan
4818 <gnufnork-AT-hetdigitalegat.nl>
4825 <gnufnork-AT-hetdigitalegat.nl>
4819 (prompt_specials): Added color support for prompt strings, so
4826 (prompt_specials): Added color support for prompt strings, so
4820 users can define arbitrary color setups for their prompts.
4827 users can define arbitrary color setups for their prompts.
4821
4828
4822 2004-06-05 Fernando Perez <fperez@colorado.edu>
4829 2004-06-05 Fernando Perez <fperez@colorado.edu>
4823
4830
4824 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
4831 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
4825 code to load Gary Bishop's readline and configure it
4832 code to load Gary Bishop's readline and configure it
4826 automatically. Thanks to Gary for help on this.
4833 automatically. Thanks to Gary for help on this.
4827
4834
4828 2004-06-01 Fernando Perez <fperez@colorado.edu>
4835 2004-06-01 Fernando Perez <fperez@colorado.edu>
4829
4836
4830 * IPython/Logger.py (Logger.create_log): fix bug for logging
4837 * IPython/Logger.py (Logger.create_log): fix bug for logging
4831 with no filename (previous fix was incomplete).
4838 with no filename (previous fix was incomplete).
4832
4839
4833 2004-05-25 Fernando Perez <fperez@colorado.edu>
4840 2004-05-25 Fernando Perez <fperez@colorado.edu>
4834
4841
4835 * IPython/Magic.py (Magic.parse_options): fix bug where naked
4842 * IPython/Magic.py (Magic.parse_options): fix bug where naked
4836 parens would get passed to the shell.
4843 parens would get passed to the shell.
4837
4844
4838 2004-05-20 Fernando Perez <fperez@colorado.edu>
4845 2004-05-20 Fernando Perez <fperez@colorado.edu>
4839
4846
4840 * IPython/Magic.py (Magic.magic_prun): changed default profile
4847 * IPython/Magic.py (Magic.magic_prun): changed default profile
4841 sort order to 'time' (the more common profiling need).
4848 sort order to 'time' (the more common profiling need).
4842
4849
4843 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
4850 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
4844 so that source code shown is guaranteed in sync with the file on
4851 so that source code shown is guaranteed in sync with the file on
4845 disk (also changed in psource). Similar fix to the one for
4852 disk (also changed in psource). Similar fix to the one for
4846 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
4853 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
4847 <yann.ledu-AT-noos.fr>.
4854 <yann.ledu-AT-noos.fr>.
4848
4855
4849 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
4856 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
4850 with a single option would not be correctly parsed. Closes
4857 with a single option would not be correctly parsed. Closes
4851 http://www.scipy.net/roundup/ipython/issue14. This bug had been
4858 http://www.scipy.net/roundup/ipython/issue14. This bug had been
4852 introduced in 0.6.0 (on 2004-05-06).
4859 introduced in 0.6.0 (on 2004-05-06).
4853
4860
4854 2004-05-13 *** Released version 0.6.0
4861 2004-05-13 *** Released version 0.6.0
4855
4862
4856 2004-05-13 Fernando Perez <fperez@colorado.edu>
4863 2004-05-13 Fernando Perez <fperez@colorado.edu>
4857
4864
4858 * debian/: Added debian/ directory to CVS, so that debian support
4865 * debian/: Added debian/ directory to CVS, so that debian support
4859 is publicly accessible. The debian package is maintained by Jack
4866 is publicly accessible. The debian package is maintained by Jack
4860 Moffit <jack-AT-xiph.org>.
4867 Moffit <jack-AT-xiph.org>.
4861
4868
4862 * Documentation: included the notes about an ipython-based system
4869 * Documentation: included the notes about an ipython-based system
4863 shell (the hypothetical 'pysh') into the new_design.pdf document,
4870 shell (the hypothetical 'pysh') into the new_design.pdf document,
4864 so that these ideas get distributed to users along with the
4871 so that these ideas get distributed to users along with the
4865 official documentation.
4872 official documentation.
4866
4873
4867 2004-05-10 Fernando Perez <fperez@colorado.edu>
4874 2004-05-10 Fernando Perez <fperez@colorado.edu>
4868
4875
4869 * IPython/Logger.py (Logger.create_log): fix recently introduced
4876 * IPython/Logger.py (Logger.create_log): fix recently introduced
4870 bug (misindented line) where logstart would fail when not given an
4877 bug (misindented line) where logstart would fail when not given an
4871 explicit filename.
4878 explicit filename.
4872
4879
4873 2004-05-09 Fernando Perez <fperez@colorado.edu>
4880 2004-05-09 Fernando Perez <fperez@colorado.edu>
4874
4881
4875 * IPython/Magic.py (Magic.parse_options): skip system call when
4882 * IPython/Magic.py (Magic.parse_options): skip system call when
4876 there are no options to look for. Faster, cleaner for the common
4883 there are no options to look for. Faster, cleaner for the common
4877 case.
4884 case.
4878
4885
4879 * Documentation: many updates to the manual: describing Windows
4886 * Documentation: many updates to the manual: describing Windows
4880 support better, Gnuplot updates, credits, misc small stuff. Also
4887 support better, Gnuplot updates, credits, misc small stuff. Also
4881 updated the new_design doc a bit.
4888 updated the new_design doc a bit.
4882
4889
4883 2004-05-06 *** Released version 0.6.0.rc1
4890 2004-05-06 *** Released version 0.6.0.rc1
4884
4891
4885 2004-05-06 Fernando Perez <fperez@colorado.edu>
4892 2004-05-06 Fernando Perez <fperez@colorado.edu>
4886
4893
4887 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
4894 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
4888 operations to use the vastly more efficient list/''.join() method.
4895 operations to use the vastly more efficient list/''.join() method.
4889 (FormattedTB.text): Fix
4896 (FormattedTB.text): Fix
4890 http://www.scipy.net/roundup/ipython/issue12 - exception source
4897 http://www.scipy.net/roundup/ipython/issue12 - exception source
4891 extract not updated after reload. Thanks to Mike Salib
4898 extract not updated after reload. Thanks to Mike Salib
4892 <msalib-AT-mit.edu> for pinning the source of the problem.
4899 <msalib-AT-mit.edu> for pinning the source of the problem.
4893 Fortunately, the solution works inside ipython and doesn't require
4900 Fortunately, the solution works inside ipython and doesn't require
4894 any changes to python proper.
4901 any changes to python proper.
4895
4902
4896 * IPython/Magic.py (Magic.parse_options): Improved to process the
4903 * IPython/Magic.py (Magic.parse_options): Improved to process the
4897 argument list as a true shell would (by actually using the
4904 argument list as a true shell would (by actually using the
4898 underlying system shell). This way, all @magics automatically get
4905 underlying system shell). This way, all @magics automatically get
4899 shell expansion for variables. Thanks to a comment by Alex
4906 shell expansion for variables. Thanks to a comment by Alex
4900 Schmolck.
4907 Schmolck.
4901
4908
4902 2004-04-04 Fernando Perez <fperez@colorado.edu>
4909 2004-04-04 Fernando Perez <fperez@colorado.edu>
4903
4910
4904 * IPython/iplib.py (InteractiveShell.interact): Added a special
4911 * IPython/iplib.py (InteractiveShell.interact): Added a special
4905 trap for a debugger quit exception, which is basically impossible
4912 trap for a debugger quit exception, which is basically impossible
4906 to handle by normal mechanisms, given what pdb does to the stack.
4913 to handle by normal mechanisms, given what pdb does to the stack.
4907 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
4914 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
4908
4915
4909 2004-04-03 Fernando Perez <fperez@colorado.edu>
4916 2004-04-03 Fernando Perez <fperez@colorado.edu>
4910
4917
4911 * IPython/genutils.py (Term): Standardized the names of the Term
4918 * IPython/genutils.py (Term): Standardized the names of the Term
4912 class streams to cin/cout/cerr, following C++ naming conventions
4919 class streams to cin/cout/cerr, following C++ naming conventions
4913 (I can't use in/out/err because 'in' is not a valid attribute
4920 (I can't use in/out/err because 'in' is not a valid attribute
4914 name).
4921 name).
4915
4922
4916 * IPython/iplib.py (InteractiveShell.interact): don't increment
4923 * IPython/iplib.py (InteractiveShell.interact): don't increment
4917 the prompt if there's no user input. By Daniel 'Dang' Griffith
4924 the prompt if there's no user input. By Daniel 'Dang' Griffith
4918 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
4925 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
4919 Francois Pinard.
4926 Francois Pinard.
4920
4927
4921 2004-04-02 Fernando Perez <fperez@colorado.edu>
4928 2004-04-02 Fernando Perez <fperez@colorado.edu>
4922
4929
4923 * IPython/genutils.py (Stream.__init__): Modified to survive at
4930 * IPython/genutils.py (Stream.__init__): Modified to survive at
4924 least importing in contexts where stdin/out/err aren't true file
4931 least importing in contexts where stdin/out/err aren't true file
4925 objects, such as PyCrust (they lack fileno() and mode). However,
4932 objects, such as PyCrust (they lack fileno() and mode). However,
4926 the recovery facilities which rely on these things existing will
4933 the recovery facilities which rely on these things existing will
4927 not work.
4934 not work.
4928
4935
4929 2004-04-01 Fernando Perez <fperez@colorado.edu>
4936 2004-04-01 Fernando Perez <fperez@colorado.edu>
4930
4937
4931 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
4938 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
4932 use the new getoutputerror() function, so it properly
4939 use the new getoutputerror() function, so it properly
4933 distinguishes stdout/err.
4940 distinguishes stdout/err.
4934
4941
4935 * IPython/genutils.py (getoutputerror): added a function to
4942 * IPython/genutils.py (getoutputerror): added a function to
4936 capture separately the standard output and error of a command.
4943 capture separately the standard output and error of a command.
4937 After a comment from dang on the mailing lists. This code is
4944 After a comment from dang on the mailing lists. This code is
4938 basically a modified version of commands.getstatusoutput(), from
4945 basically a modified version of commands.getstatusoutput(), from
4939 the standard library.
4946 the standard library.
4940
4947
4941 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
4948 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
4942 '!!' as a special syntax (shorthand) to access @sx.
4949 '!!' as a special syntax (shorthand) to access @sx.
4943
4950
4944 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
4951 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
4945 command and return its output as a list split on '\n'.
4952 command and return its output as a list split on '\n'.
4946
4953
4947 2004-03-31 Fernando Perez <fperez@colorado.edu>
4954 2004-03-31 Fernando Perez <fperez@colorado.edu>
4948
4955
4949 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
4956 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
4950 method to dictionaries used as FakeModule instances if they lack
4957 method to dictionaries used as FakeModule instances if they lack
4951 it. At least pydoc in python2.3 breaks for runtime-defined
4958 it. At least pydoc in python2.3 breaks for runtime-defined
4952 functions without this hack. At some point I need to _really_
4959 functions without this hack. At some point I need to _really_
4953 understand what FakeModule is doing, because it's a gross hack.
4960 understand what FakeModule is doing, because it's a gross hack.
4954 But it solves Arnd's problem for now...
4961 But it solves Arnd's problem for now...
4955
4962
4956 2004-02-27 Fernando Perez <fperez@colorado.edu>
4963 2004-02-27 Fernando Perez <fperez@colorado.edu>
4957
4964
4958 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
4965 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
4959 mode would behave erratically. Also increased the number of
4966 mode would behave erratically. Also increased the number of
4960 possible logs in rotate mod to 999. Thanks to Rod Holland
4967 possible logs in rotate mod to 999. Thanks to Rod Holland
4961 <rhh@StructureLABS.com> for the report and fixes.
4968 <rhh@StructureLABS.com> for the report and fixes.
4962
4969
4963 2004-02-26 Fernando Perez <fperez@colorado.edu>
4970 2004-02-26 Fernando Perez <fperez@colorado.edu>
4964
4971
4965 * IPython/genutils.py (page): Check that the curses module really
4972 * IPython/genutils.py (page): Check that the curses module really
4966 has the initscr attribute before trying to use it. For some
4973 has the initscr attribute before trying to use it. For some
4967 reason, the Solaris curses module is missing this. I think this
4974 reason, the Solaris curses module is missing this. I think this
4968 should be considered a Solaris python bug, but I'm not sure.
4975 should be considered a Solaris python bug, but I'm not sure.
4969
4976
4970 2004-01-17 Fernando Perez <fperez@colorado.edu>
4977 2004-01-17 Fernando Perez <fperez@colorado.edu>
4971
4978
4972 * IPython/genutils.py (Stream.__init__): Changes to try to make
4979 * IPython/genutils.py (Stream.__init__): Changes to try to make
4973 ipython robust against stdin/out/err being closed by the user.
4980 ipython robust against stdin/out/err being closed by the user.
4974 This is 'user error' (and blocks a normal python session, at least
4981 This is 'user error' (and blocks a normal python session, at least
4975 the stdout case). However, Ipython should be able to survive such
4982 the stdout case). However, Ipython should be able to survive such
4976 instances of abuse as gracefully as possible. To simplify the
4983 instances of abuse as gracefully as possible. To simplify the
4977 coding and maintain compatibility with Gary Bishop's Term
4984 coding and maintain compatibility with Gary Bishop's Term
4978 contributions, I've made use of classmethods for this. I think
4985 contributions, I've made use of classmethods for this. I think
4979 this introduces a dependency on python 2.2.
4986 this introduces a dependency on python 2.2.
4980
4987
4981 2004-01-13 Fernando Perez <fperez@colorado.edu>
4988 2004-01-13 Fernando Perez <fperez@colorado.edu>
4982
4989
4983 * IPython/numutils.py (exp_safe): simplified the code a bit and
4990 * IPython/numutils.py (exp_safe): simplified the code a bit and
4984 removed the need for importing the kinds module altogether.
4991 removed the need for importing the kinds module altogether.
4985
4992
4986 2004-01-06 Fernando Perez <fperez@colorado.edu>
4993 2004-01-06 Fernando Perez <fperez@colorado.edu>
4987
4994
4988 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
4995 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
4989 a magic function instead, after some community feedback. No
4996 a magic function instead, after some community feedback. No
4990 special syntax will exist for it, but its name is deliberately
4997 special syntax will exist for it, but its name is deliberately
4991 very short.
4998 very short.
4992
4999
4993 2003-12-20 Fernando Perez <fperez@colorado.edu>
5000 2003-12-20 Fernando Perez <fperez@colorado.edu>
4994
5001
4995 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
5002 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
4996 new functionality, to automagically assign the result of a shell
5003 new functionality, to automagically assign the result of a shell
4997 command to a variable. I'll solicit some community feedback on
5004 command to a variable. I'll solicit some community feedback on
4998 this before making it permanent.
5005 this before making it permanent.
4999
5006
5000 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
5007 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
5001 requested about callables for which inspect couldn't obtain a
5008 requested about callables for which inspect couldn't obtain a
5002 proper argspec. Thanks to a crash report sent by Etienne
5009 proper argspec. Thanks to a crash report sent by Etienne
5003 Posthumus <etienne-AT-apple01.cs.vu.nl>.
5010 Posthumus <etienne-AT-apple01.cs.vu.nl>.
5004
5011
5005 2003-12-09 Fernando Perez <fperez@colorado.edu>
5012 2003-12-09 Fernando Perez <fperez@colorado.edu>
5006
5013
5007 * IPython/genutils.py (page): patch for the pager to work across
5014 * IPython/genutils.py (page): patch for the pager to work across
5008 various versions of Windows. By Gary Bishop.
5015 various versions of Windows. By Gary Bishop.
5009
5016
5010 2003-12-04 Fernando Perez <fperez@colorado.edu>
5017 2003-12-04 Fernando Perez <fperez@colorado.edu>
5011
5018
5012 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
5019 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
5013 Gnuplot.py version 1.7, whose internal names changed quite a bit.
5020 Gnuplot.py version 1.7, whose internal names changed quite a bit.
5014 While I tested this and it looks ok, there may still be corner
5021 While I tested this and it looks ok, there may still be corner
5015 cases I've missed.
5022 cases I've missed.
5016
5023
5017 2003-12-01 Fernando Perez <fperez@colorado.edu>
5024 2003-12-01 Fernando Perez <fperez@colorado.edu>
5018
5025
5019 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
5026 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
5020 where a line like 'p,q=1,2' would fail because the automagic
5027 where a line like 'p,q=1,2' would fail because the automagic
5021 system would be triggered for @p.
5028 system would be triggered for @p.
5022
5029
5023 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
5030 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
5024 cleanups, code unmodified.
5031 cleanups, code unmodified.
5025
5032
5026 * IPython/genutils.py (Term): added a class for IPython to handle
5033 * IPython/genutils.py (Term): added a class for IPython to handle
5027 output. In most cases it will just be a proxy for stdout/err, but
5034 output. In most cases it will just be a proxy for stdout/err, but
5028 having this allows modifications to be made for some platforms,
5035 having this allows modifications to be made for some platforms,
5029 such as handling color escapes under Windows. All of this code
5036 such as handling color escapes under Windows. All of this code
5030 was contributed by Gary Bishop, with minor modifications by me.
5037 was contributed by Gary Bishop, with minor modifications by me.
5031 The actual changes affect many files.
5038 The actual changes affect many files.
5032
5039
5033 2003-11-30 Fernando Perez <fperez@colorado.edu>
5040 2003-11-30 Fernando Perez <fperez@colorado.edu>
5034
5041
5035 * IPython/iplib.py (file_matches): new completion code, courtesy
5042 * IPython/iplib.py (file_matches): new completion code, courtesy
5036 of Jeff Collins. This enables filename completion again under
5043 of Jeff Collins. This enables filename completion again under
5037 python 2.3, which disabled it at the C level.
5044 python 2.3, which disabled it at the C level.
5038
5045
5039 2003-11-11 Fernando Perez <fperez@colorado.edu>
5046 2003-11-11 Fernando Perez <fperez@colorado.edu>
5040
5047
5041 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
5048 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
5042 for Numeric.array(map(...)), but often convenient.
5049 for Numeric.array(map(...)), but often convenient.
5043
5050
5044 2003-11-05 Fernando Perez <fperez@colorado.edu>
5051 2003-11-05 Fernando Perez <fperez@colorado.edu>
5045
5052
5046 * IPython/numutils.py (frange): Changed a call from int() to
5053 * IPython/numutils.py (frange): Changed a call from int() to
5047 int(round()) to prevent a problem reported with arange() in the
5054 int(round()) to prevent a problem reported with arange() in the
5048 numpy list.
5055 numpy list.
5049
5056
5050 2003-10-06 Fernando Perez <fperez@colorado.edu>
5057 2003-10-06 Fernando Perez <fperez@colorado.edu>
5051
5058
5052 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
5059 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
5053 prevent crashes if sys lacks an argv attribute (it happens with
5060 prevent crashes if sys lacks an argv attribute (it happens with
5054 embedded interpreters which build a bare-bones sys module).
5061 embedded interpreters which build a bare-bones sys module).
5055 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
5062 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
5056
5063
5057 2003-09-24 Fernando Perez <fperez@colorado.edu>
5064 2003-09-24 Fernando Perez <fperez@colorado.edu>
5058
5065
5059 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
5066 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
5060 to protect against poorly written user objects where __getattr__
5067 to protect against poorly written user objects where __getattr__
5061 raises exceptions other than AttributeError. Thanks to a bug
5068 raises exceptions other than AttributeError. Thanks to a bug
5062 report by Oliver Sander <osander-AT-gmx.de>.
5069 report by Oliver Sander <osander-AT-gmx.de>.
5063
5070
5064 * IPython/FakeModule.py (FakeModule.__repr__): this method was
5071 * IPython/FakeModule.py (FakeModule.__repr__): this method was
5065 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
5072 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
5066
5073
5067 2003-09-09 Fernando Perez <fperez@colorado.edu>
5074 2003-09-09 Fernando Perez <fperez@colorado.edu>
5068
5075
5069 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
5076 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
5070 unpacking a list whith a callable as first element would
5077 unpacking a list whith a callable as first element would
5071 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
5078 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
5072 Collins.
5079 Collins.
5073
5080
5074 2003-08-25 *** Released version 0.5.0
5081 2003-08-25 *** Released version 0.5.0
5075
5082
5076 2003-08-22 Fernando Perez <fperez@colorado.edu>
5083 2003-08-22 Fernando Perez <fperez@colorado.edu>
5077
5084
5078 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
5085 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
5079 improperly defined user exceptions. Thanks to feedback from Mark
5086 improperly defined user exceptions. Thanks to feedback from Mark
5080 Russell <mrussell-AT-verio.net>.
5087 Russell <mrussell-AT-verio.net>.
5081
5088
5082 2003-08-20 Fernando Perez <fperez@colorado.edu>
5089 2003-08-20 Fernando Perez <fperez@colorado.edu>
5083
5090
5084 * IPython/OInspect.py (Inspector.pinfo): changed String Form
5091 * IPython/OInspect.py (Inspector.pinfo): changed String Form
5085 printing so that it would print multi-line string forms starting
5092 printing so that it would print multi-line string forms starting
5086 with a new line. This way the formatting is better respected for
5093 with a new line. This way the formatting is better respected for
5087 objects which work hard to make nice string forms.
5094 objects which work hard to make nice string forms.
5088
5095
5089 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
5096 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
5090 autocall would overtake data access for objects with both
5097 autocall would overtake data access for objects with both
5091 __getitem__ and __call__.
5098 __getitem__ and __call__.
5092
5099
5093 2003-08-19 *** Released version 0.5.0-rc1
5100 2003-08-19 *** Released version 0.5.0-rc1
5094
5101
5095 2003-08-19 Fernando Perez <fperez@colorado.edu>
5102 2003-08-19 Fernando Perez <fperez@colorado.edu>
5096
5103
5097 * IPython/deep_reload.py (load_tail): single tiny change here
5104 * IPython/deep_reload.py (load_tail): single tiny change here
5098 seems to fix the long-standing bug of dreload() failing to work
5105 seems to fix the long-standing bug of dreload() failing to work
5099 for dotted names. But this module is pretty tricky, so I may have
5106 for dotted names. But this module is pretty tricky, so I may have
5100 missed some subtlety. Needs more testing!.
5107 missed some subtlety. Needs more testing!.
5101
5108
5102 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
5109 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
5103 exceptions which have badly implemented __str__ methods.
5110 exceptions which have badly implemented __str__ methods.
5104 (VerboseTB.text): harden against inspect.getinnerframes crashing,
5111 (VerboseTB.text): harden against inspect.getinnerframes crashing,
5105 which I've been getting reports about from Python 2.3 users. I
5112 which I've been getting reports about from Python 2.3 users. I
5106 wish I had a simple test case to reproduce the problem, so I could
5113 wish I had a simple test case to reproduce the problem, so I could
5107 either write a cleaner workaround or file a bug report if
5114 either write a cleaner workaround or file a bug report if
5108 necessary.
5115 necessary.
5109
5116
5110 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
5117 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
5111 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
5118 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
5112 a bug report by Tjabo Kloppenburg.
5119 a bug report by Tjabo Kloppenburg.
5113
5120
5114 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
5121 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
5115 crashes. Wrapped the pdb call in a blanket try/except, since pdb
5122 crashes. Wrapped the pdb call in a blanket try/except, since pdb
5116 seems rather unstable. Thanks to a bug report by Tjabo
5123 seems rather unstable. Thanks to a bug report by Tjabo
5117 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
5124 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
5118
5125
5119 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
5126 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
5120 this out soon because of the critical fixes in the inner loop for
5127 this out soon because of the critical fixes in the inner loop for
5121 generators.
5128 generators.
5122
5129
5123 * IPython/Magic.py (Magic.getargspec): removed. This (and
5130 * IPython/Magic.py (Magic.getargspec): removed. This (and
5124 _get_def) have been obsoleted by OInspect for a long time, I
5131 _get_def) have been obsoleted by OInspect for a long time, I
5125 hadn't noticed that they were dead code.
5132 hadn't noticed that they were dead code.
5126 (Magic._ofind): restored _ofind functionality for a few literals
5133 (Magic._ofind): restored _ofind functionality for a few literals
5127 (those in ["''",'""','[]','{}','()']). But it won't work anymore
5134 (those in ["''",'""','[]','{}','()']). But it won't work anymore
5128 for things like "hello".capitalize?, since that would require a
5135 for things like "hello".capitalize?, since that would require a
5129 potentially dangerous eval() again.
5136 potentially dangerous eval() again.
5130
5137
5131 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
5138 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
5132 logic a bit more to clean up the escapes handling and minimize the
5139 logic a bit more to clean up the escapes handling and minimize the
5133 use of _ofind to only necessary cases. The interactive 'feel' of
5140 use of _ofind to only necessary cases. The interactive 'feel' of
5134 IPython should have improved quite a bit with the changes in
5141 IPython should have improved quite a bit with the changes in
5135 _prefilter and _ofind (besides being far safer than before).
5142 _prefilter and _ofind (besides being far safer than before).
5136
5143
5137 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
5144 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
5138 obscure, never reported). Edit would fail to find the object to
5145 obscure, never reported). Edit would fail to find the object to
5139 edit under some circumstances.
5146 edit under some circumstances.
5140 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
5147 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
5141 which were causing double-calling of generators. Those eval calls
5148 which were causing double-calling of generators. Those eval calls
5142 were _very_ dangerous, since code with side effects could be
5149 were _very_ dangerous, since code with side effects could be
5143 triggered. As they say, 'eval is evil'... These were the
5150 triggered. As they say, 'eval is evil'... These were the
5144 nastiest evals in IPython. Besides, _ofind is now far simpler,
5151 nastiest evals in IPython. Besides, _ofind is now far simpler,
5145 and it should also be quite a bit faster. Its use of inspect is
5152 and it should also be quite a bit faster. Its use of inspect is
5146 also safer, so perhaps some of the inspect-related crashes I've
5153 also safer, so perhaps some of the inspect-related crashes I've
5147 seen lately with Python 2.3 might be taken care of. That will
5154 seen lately with Python 2.3 might be taken care of. That will
5148 need more testing.
5155 need more testing.
5149
5156
5150 2003-08-17 Fernando Perez <fperez@colorado.edu>
5157 2003-08-17 Fernando Perez <fperez@colorado.edu>
5151
5158
5152 * IPython/iplib.py (InteractiveShell._prefilter): significant
5159 * IPython/iplib.py (InteractiveShell._prefilter): significant
5153 simplifications to the logic for handling user escapes. Faster
5160 simplifications to the logic for handling user escapes. Faster
5154 and simpler code.
5161 and simpler code.
5155
5162
5156 2003-08-14 Fernando Perez <fperez@colorado.edu>
5163 2003-08-14 Fernando Perez <fperez@colorado.edu>
5157
5164
5158 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
5165 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
5159 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
5166 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
5160 but it should be quite a bit faster. And the recursive version
5167 but it should be quite a bit faster. And the recursive version
5161 generated O(log N) intermediate storage for all rank>1 arrays,
5168 generated O(log N) intermediate storage for all rank>1 arrays,
5162 even if they were contiguous.
5169 even if they were contiguous.
5163 (l1norm): Added this function.
5170 (l1norm): Added this function.
5164 (norm): Added this function for arbitrary norms (including
5171 (norm): Added this function for arbitrary norms (including
5165 l-infinity). l1 and l2 are still special cases for convenience
5172 l-infinity). l1 and l2 are still special cases for convenience
5166 and speed.
5173 and speed.
5167
5174
5168 2003-08-03 Fernando Perez <fperez@colorado.edu>
5175 2003-08-03 Fernando Perez <fperez@colorado.edu>
5169
5176
5170 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
5177 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
5171 exceptions, which now raise PendingDeprecationWarnings in Python
5178 exceptions, which now raise PendingDeprecationWarnings in Python
5172 2.3. There were some in Magic and some in Gnuplot2.
5179 2.3. There were some in Magic and some in Gnuplot2.
5173
5180
5174 2003-06-30 Fernando Perez <fperez@colorado.edu>
5181 2003-06-30 Fernando Perez <fperez@colorado.edu>
5175
5182
5176 * IPython/genutils.py (page): modified to call curses only for
5183 * IPython/genutils.py (page): modified to call curses only for
5177 terminals where TERM=='xterm'. After problems under many other
5184 terminals where TERM=='xterm'. After problems under many other
5178 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
5185 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
5179
5186
5180 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
5187 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
5181 would be triggered when readline was absent. This was just an old
5188 would be triggered when readline was absent. This was just an old
5182 debugging statement I'd forgotten to take out.
5189 debugging statement I'd forgotten to take out.
5183
5190
5184 2003-06-20 Fernando Perez <fperez@colorado.edu>
5191 2003-06-20 Fernando Perez <fperez@colorado.edu>
5185
5192
5186 * IPython/genutils.py (clock): modified to return only user time
5193 * IPython/genutils.py (clock): modified to return only user time
5187 (not counting system time), after a discussion on scipy. While
5194 (not counting system time), after a discussion on scipy. While
5188 system time may be a useful quantity occasionally, it may much
5195 system time may be a useful quantity occasionally, it may much
5189 more easily be skewed by occasional swapping or other similar
5196 more easily be skewed by occasional swapping or other similar
5190 activity.
5197 activity.
5191
5198
5192 2003-06-05 Fernando Perez <fperez@colorado.edu>
5199 2003-06-05 Fernando Perez <fperez@colorado.edu>
5193
5200
5194 * IPython/numutils.py (identity): new function, for building
5201 * IPython/numutils.py (identity): new function, for building
5195 arbitrary rank Kronecker deltas (mostly backwards compatible with
5202 arbitrary rank Kronecker deltas (mostly backwards compatible with
5196 Numeric.identity)
5203 Numeric.identity)
5197
5204
5198 2003-06-03 Fernando Perez <fperez@colorado.edu>
5205 2003-06-03 Fernando Perez <fperez@colorado.edu>
5199
5206
5200 * IPython/iplib.py (InteractiveShell.handle_magic): protect
5207 * IPython/iplib.py (InteractiveShell.handle_magic): protect
5201 arguments passed to magics with spaces, to allow trailing '\' to
5208 arguments passed to magics with spaces, to allow trailing '\' to
5202 work normally (mainly for Windows users).
5209 work normally (mainly for Windows users).
5203
5210
5204 2003-05-29 Fernando Perez <fperez@colorado.edu>
5211 2003-05-29 Fernando Perez <fperez@colorado.edu>
5205
5212
5206 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
5213 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
5207 instead of pydoc.help. This fixes a bizarre behavior where
5214 instead of pydoc.help. This fixes a bizarre behavior where
5208 printing '%s' % locals() would trigger the help system. Now
5215 printing '%s' % locals() would trigger the help system. Now
5209 ipython behaves like normal python does.
5216 ipython behaves like normal python does.
5210
5217
5211 Note that if one does 'from pydoc import help', the bizarre
5218 Note that if one does 'from pydoc import help', the bizarre
5212 behavior returns, but this will also happen in normal python, so
5219 behavior returns, but this will also happen in normal python, so
5213 it's not an ipython bug anymore (it has to do with how pydoc.help
5220 it's not an ipython bug anymore (it has to do with how pydoc.help
5214 is implemented).
5221 is implemented).
5215
5222
5216 2003-05-22 Fernando Perez <fperez@colorado.edu>
5223 2003-05-22 Fernando Perez <fperez@colorado.edu>
5217
5224
5218 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
5225 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
5219 return [] instead of None when nothing matches, also match to end
5226 return [] instead of None when nothing matches, also match to end
5220 of line. Patch by Gary Bishop.
5227 of line. Patch by Gary Bishop.
5221
5228
5222 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
5229 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
5223 protection as before, for files passed on the command line. This
5230 protection as before, for files passed on the command line. This
5224 prevents the CrashHandler from kicking in if user files call into
5231 prevents the CrashHandler from kicking in if user files call into
5225 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
5232 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
5226 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
5233 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
5227
5234
5228 2003-05-20 *** Released version 0.4.0
5235 2003-05-20 *** Released version 0.4.0
5229
5236
5230 2003-05-20 Fernando Perez <fperez@colorado.edu>
5237 2003-05-20 Fernando Perez <fperez@colorado.edu>
5231
5238
5232 * setup.py: added support for manpages. It's a bit hackish b/c of
5239 * setup.py: added support for manpages. It's a bit hackish b/c of
5233 a bug in the way the bdist_rpm distutils target handles gzipped
5240 a bug in the way the bdist_rpm distutils target handles gzipped
5234 manpages, but it works. After a patch by Jack.
5241 manpages, but it works. After a patch by Jack.
5235
5242
5236 2003-05-19 Fernando Perez <fperez@colorado.edu>
5243 2003-05-19 Fernando Perez <fperez@colorado.edu>
5237
5244
5238 * IPython/numutils.py: added a mockup of the kinds module, since
5245 * IPython/numutils.py: added a mockup of the kinds module, since
5239 it was recently removed from Numeric. This way, numutils will
5246 it was recently removed from Numeric. This way, numutils will
5240 work for all users even if they are missing kinds.
5247 work for all users even if they are missing kinds.
5241
5248
5242 * IPython/Magic.py (Magic._ofind): Harden against an inspect
5249 * IPython/Magic.py (Magic._ofind): Harden against an inspect
5243 failure, which can occur with SWIG-wrapped extensions. After a
5250 failure, which can occur with SWIG-wrapped extensions. After a
5244 crash report from Prabhu.
5251 crash report from Prabhu.
5245
5252
5246 2003-05-16 Fernando Perez <fperez@colorado.edu>
5253 2003-05-16 Fernando Perez <fperez@colorado.edu>
5247
5254
5248 * IPython/iplib.py (InteractiveShell.excepthook): New method to
5255 * IPython/iplib.py (InteractiveShell.excepthook): New method to
5249 protect ipython from user code which may call directly
5256 protect ipython from user code which may call directly
5250 sys.excepthook (this looks like an ipython crash to the user, even
5257 sys.excepthook (this looks like an ipython crash to the user, even
5251 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
5258 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
5252 This is especially important to help users of WxWindows, but may
5259 This is especially important to help users of WxWindows, but may
5253 also be useful in other cases.
5260 also be useful in other cases.
5254
5261
5255 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
5262 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
5256 an optional tb_offset to be specified, and to preserve exception
5263 an optional tb_offset to be specified, and to preserve exception
5257 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
5264 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
5258
5265
5259 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
5266 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
5260
5267
5261 2003-05-15 Fernando Perez <fperez@colorado.edu>
5268 2003-05-15 Fernando Perez <fperez@colorado.edu>
5262
5269
5263 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
5270 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
5264 installing for a new user under Windows.
5271 installing for a new user under Windows.
5265
5272
5266 2003-05-12 Fernando Perez <fperez@colorado.edu>
5273 2003-05-12 Fernando Perez <fperez@colorado.edu>
5267
5274
5268 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
5275 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
5269 handler for Emacs comint-based lines. Currently it doesn't do
5276 handler for Emacs comint-based lines. Currently it doesn't do
5270 much (but importantly, it doesn't update the history cache). In
5277 much (but importantly, it doesn't update the history cache). In
5271 the future it may be expanded if Alex needs more functionality
5278 the future it may be expanded if Alex needs more functionality
5272 there.
5279 there.
5273
5280
5274 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
5281 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
5275 info to crash reports.
5282 info to crash reports.
5276
5283
5277 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
5284 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
5278 just like Python's -c. Also fixed crash with invalid -color
5285 just like Python's -c. Also fixed crash with invalid -color
5279 option value at startup. Thanks to Will French
5286 option value at startup. Thanks to Will French
5280 <wfrench-AT-bestweb.net> for the bug report.
5287 <wfrench-AT-bestweb.net> for the bug report.
5281
5288
5282 2003-05-09 Fernando Perez <fperez@colorado.edu>
5289 2003-05-09 Fernando Perez <fperez@colorado.edu>
5283
5290
5284 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
5291 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
5285 to EvalDict (it's a mapping, after all) and simplified its code
5292 to EvalDict (it's a mapping, after all) and simplified its code
5286 quite a bit, after a nice discussion on c.l.py where Gustavo
5293 quite a bit, after a nice discussion on c.l.py where Gustavo
5287 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
5294 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
5288
5295
5289 2003-04-30 Fernando Perez <fperez@colorado.edu>
5296 2003-04-30 Fernando Perez <fperez@colorado.edu>
5290
5297
5291 * IPython/genutils.py (timings_out): modified it to reduce its
5298 * IPython/genutils.py (timings_out): modified it to reduce its
5292 overhead in the common reps==1 case.
5299 overhead in the common reps==1 case.
5293
5300
5294 2003-04-29 Fernando Perez <fperez@colorado.edu>
5301 2003-04-29 Fernando Perez <fperez@colorado.edu>
5295
5302
5296 * IPython/genutils.py (timings_out): Modified to use the resource
5303 * IPython/genutils.py (timings_out): Modified to use the resource
5297 module, which avoids the wraparound problems of time.clock().
5304 module, which avoids the wraparound problems of time.clock().
5298
5305
5299 2003-04-17 *** Released version 0.2.15pre4
5306 2003-04-17 *** Released version 0.2.15pre4
5300
5307
5301 2003-04-17 Fernando Perez <fperez@colorado.edu>
5308 2003-04-17 Fernando Perez <fperez@colorado.edu>
5302
5309
5303 * setup.py (scriptfiles): Split windows-specific stuff over to a
5310 * setup.py (scriptfiles): Split windows-specific stuff over to a
5304 separate file, in an attempt to have a Windows GUI installer.
5311 separate file, in an attempt to have a Windows GUI installer.
5305 That didn't work, but part of the groundwork is done.
5312 That didn't work, but part of the groundwork is done.
5306
5313
5307 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
5314 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
5308 indent/unindent with 4 spaces. Particularly useful in combination
5315 indent/unindent with 4 spaces. Particularly useful in combination
5309 with the new auto-indent option.
5316 with the new auto-indent option.
5310
5317
5311 2003-04-16 Fernando Perez <fperez@colorado.edu>
5318 2003-04-16 Fernando Perez <fperez@colorado.edu>
5312
5319
5313 * IPython/Magic.py: various replacements of self.rc for
5320 * IPython/Magic.py: various replacements of self.rc for
5314 self.shell.rc. A lot more remains to be done to fully disentangle
5321 self.shell.rc. A lot more remains to be done to fully disentangle
5315 this class from the main Shell class.
5322 this class from the main Shell class.
5316
5323
5317 * IPython/GnuplotRuntime.py: added checks for mouse support so
5324 * IPython/GnuplotRuntime.py: added checks for mouse support so
5318 that we don't try to enable it if the current gnuplot doesn't
5325 that we don't try to enable it if the current gnuplot doesn't
5319 really support it. Also added checks so that we don't try to
5326 really support it. Also added checks so that we don't try to
5320 enable persist under Windows (where Gnuplot doesn't recognize the
5327 enable persist under Windows (where Gnuplot doesn't recognize the
5321 option).
5328 option).
5322
5329
5323 * IPython/iplib.py (InteractiveShell.interact): Added optional
5330 * IPython/iplib.py (InteractiveShell.interact): Added optional
5324 auto-indenting code, after a patch by King C. Shu
5331 auto-indenting code, after a patch by King C. Shu
5325 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
5332 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
5326 get along well with pasting indented code. If I ever figure out
5333 get along well with pasting indented code. If I ever figure out
5327 how to make that part go well, it will become on by default.
5334 how to make that part go well, it will become on by default.
5328
5335
5329 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
5336 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
5330 crash ipython if there was an unmatched '%' in the user's prompt
5337 crash ipython if there was an unmatched '%' in the user's prompt
5331 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
5338 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
5332
5339
5333 * IPython/iplib.py (InteractiveShell.interact): removed the
5340 * IPython/iplib.py (InteractiveShell.interact): removed the
5334 ability to ask the user whether he wants to crash or not at the
5341 ability to ask the user whether he wants to crash or not at the
5335 'last line' exception handler. Calling functions at that point
5342 'last line' exception handler. Calling functions at that point
5336 changes the stack, and the error reports would have incorrect
5343 changes the stack, and the error reports would have incorrect
5337 tracebacks.
5344 tracebacks.
5338
5345
5339 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
5346 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
5340 pass through a peger a pretty-printed form of any object. After a
5347 pass through a peger a pretty-printed form of any object. After a
5341 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
5348 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
5342
5349
5343 2003-04-14 Fernando Perez <fperez@colorado.edu>
5350 2003-04-14 Fernando Perez <fperez@colorado.edu>
5344
5351
5345 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
5352 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
5346 all files in ~ would be modified at first install (instead of
5353 all files in ~ would be modified at first install (instead of
5347 ~/.ipython). This could be potentially disastrous, as the
5354 ~/.ipython). This could be potentially disastrous, as the
5348 modification (make line-endings native) could damage binary files.
5355 modification (make line-endings native) could damage binary files.
5349
5356
5350 2003-04-10 Fernando Perez <fperez@colorado.edu>
5357 2003-04-10 Fernando Perez <fperez@colorado.edu>
5351
5358
5352 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
5359 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
5353 handle only lines which are invalid python. This now means that
5360 handle only lines which are invalid python. This now means that
5354 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
5361 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
5355 for the bug report.
5362 for the bug report.
5356
5363
5357 2003-04-01 Fernando Perez <fperez@colorado.edu>
5364 2003-04-01 Fernando Perez <fperez@colorado.edu>
5358
5365
5359 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
5366 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
5360 where failing to set sys.last_traceback would crash pdb.pm().
5367 where failing to set sys.last_traceback would crash pdb.pm().
5361 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
5368 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
5362 report.
5369 report.
5363
5370
5364 2003-03-25 Fernando Perez <fperez@colorado.edu>
5371 2003-03-25 Fernando Perez <fperez@colorado.edu>
5365
5372
5366 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
5373 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
5367 before printing it (it had a lot of spurious blank lines at the
5374 before printing it (it had a lot of spurious blank lines at the
5368 end).
5375 end).
5369
5376
5370 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
5377 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
5371 output would be sent 21 times! Obviously people don't use this
5378 output would be sent 21 times! Obviously people don't use this
5372 too often, or I would have heard about it.
5379 too often, or I would have heard about it.
5373
5380
5374 2003-03-24 Fernando Perez <fperez@colorado.edu>
5381 2003-03-24 Fernando Perez <fperez@colorado.edu>
5375
5382
5376 * setup.py (scriptfiles): renamed the data_files parameter from
5383 * setup.py (scriptfiles): renamed the data_files parameter from
5377 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
5384 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
5378 for the patch.
5385 for the patch.
5379
5386
5380 2003-03-20 Fernando Perez <fperez@colorado.edu>
5387 2003-03-20 Fernando Perez <fperez@colorado.edu>
5381
5388
5382 * IPython/genutils.py (error): added error() and fatal()
5389 * IPython/genutils.py (error): added error() and fatal()
5383 functions.
5390 functions.
5384
5391
5385 2003-03-18 *** Released version 0.2.15pre3
5392 2003-03-18 *** Released version 0.2.15pre3
5386
5393
5387 2003-03-18 Fernando Perez <fperez@colorado.edu>
5394 2003-03-18 Fernando Perez <fperez@colorado.edu>
5388
5395
5389 * setupext/install_data_ext.py
5396 * setupext/install_data_ext.py
5390 (install_data_ext.initialize_options): Class contributed by Jack
5397 (install_data_ext.initialize_options): Class contributed by Jack
5391 Moffit for fixing the old distutils hack. He is sending this to
5398 Moffit for fixing the old distutils hack. He is sending this to
5392 the distutils folks so in the future we may not need it as a
5399 the distutils folks so in the future we may not need it as a
5393 private fix.
5400 private fix.
5394
5401
5395 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
5402 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
5396 changes for Debian packaging. See his patch for full details.
5403 changes for Debian packaging. See his patch for full details.
5397 The old distutils hack of making the ipythonrc* files carry a
5404 The old distutils hack of making the ipythonrc* files carry a
5398 bogus .py extension is gone, at last. Examples were moved to a
5405 bogus .py extension is gone, at last. Examples were moved to a
5399 separate subdir under doc/, and the separate executable scripts
5406 separate subdir under doc/, and the separate executable scripts
5400 now live in their own directory. Overall a great cleanup. The
5407 now live in their own directory. Overall a great cleanup. The
5401 manual was updated to use the new files, and setup.py has been
5408 manual was updated to use the new files, and setup.py has been
5402 fixed for this setup.
5409 fixed for this setup.
5403
5410
5404 * IPython/PyColorize.py (Parser.usage): made non-executable and
5411 * IPython/PyColorize.py (Parser.usage): made non-executable and
5405 created a pycolor wrapper around it to be included as a script.
5412 created a pycolor wrapper around it to be included as a script.
5406
5413
5407 2003-03-12 *** Released version 0.2.15pre2
5414 2003-03-12 *** Released version 0.2.15pre2
5408
5415
5409 2003-03-12 Fernando Perez <fperez@colorado.edu>
5416 2003-03-12 Fernando Perez <fperez@colorado.edu>
5410
5417
5411 * IPython/ColorANSI.py (make_color_table): Finally fixed the
5418 * IPython/ColorANSI.py (make_color_table): Finally fixed the
5412 long-standing problem with garbage characters in some terminals.
5419 long-standing problem with garbage characters in some terminals.
5413 The issue was really that the \001 and \002 escapes must _only_ be
5420 The issue was really that the \001 and \002 escapes must _only_ be
5414 passed to input prompts (which call readline), but _never_ to
5421 passed to input prompts (which call readline), but _never_ to
5415 normal text to be printed on screen. I changed ColorANSI to have
5422 normal text to be printed on screen. I changed ColorANSI to have
5416 two classes: TermColors and InputTermColors, each with the
5423 two classes: TermColors and InputTermColors, each with the
5417 appropriate escapes for input prompts or normal text. The code in
5424 appropriate escapes for input prompts or normal text. The code in
5418 Prompts.py got slightly more complicated, but this very old and
5425 Prompts.py got slightly more complicated, but this very old and
5419 annoying bug is finally fixed.
5426 annoying bug is finally fixed.
5420
5427
5421 All the credit for nailing down the real origin of this problem
5428 All the credit for nailing down the real origin of this problem
5422 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
5429 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
5423 *Many* thanks to him for spending quite a bit of effort on this.
5430 *Many* thanks to him for spending quite a bit of effort on this.
5424
5431
5425 2003-03-05 *** Released version 0.2.15pre1
5432 2003-03-05 *** Released version 0.2.15pre1
5426
5433
5427 2003-03-03 Fernando Perez <fperez@colorado.edu>
5434 2003-03-03 Fernando Perez <fperez@colorado.edu>
5428
5435
5429 * IPython/FakeModule.py: Moved the former _FakeModule to a
5436 * IPython/FakeModule.py: Moved the former _FakeModule to a
5430 separate file, because it's also needed by Magic (to fix a similar
5437 separate file, because it's also needed by Magic (to fix a similar
5431 pickle-related issue in @run).
5438 pickle-related issue in @run).
5432
5439
5433 2003-03-02 Fernando Perez <fperez@colorado.edu>
5440 2003-03-02 Fernando Perez <fperez@colorado.edu>
5434
5441
5435 * IPython/Magic.py (Magic.magic_autocall): new magic to control
5442 * IPython/Magic.py (Magic.magic_autocall): new magic to control
5436 the autocall option at runtime.
5443 the autocall option at runtime.
5437 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
5444 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
5438 across Magic.py to start separating Magic from InteractiveShell.
5445 across Magic.py to start separating Magic from InteractiveShell.
5439 (Magic._ofind): Fixed to return proper namespace for dotted
5446 (Magic._ofind): Fixed to return proper namespace for dotted
5440 names. Before, a dotted name would always return 'not currently
5447 names. Before, a dotted name would always return 'not currently
5441 defined', because it would find the 'parent'. s.x would be found,
5448 defined', because it would find the 'parent'. s.x would be found,
5442 but since 'x' isn't defined by itself, it would get confused.
5449 but since 'x' isn't defined by itself, it would get confused.
5443 (Magic.magic_run): Fixed pickling problems reported by Ralf
5450 (Magic.magic_run): Fixed pickling problems reported by Ralf
5444 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
5451 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
5445 that I'd used when Mike Heeter reported similar issues at the
5452 that I'd used when Mike Heeter reported similar issues at the
5446 top-level, but now for @run. It boils down to injecting the
5453 top-level, but now for @run. It boils down to injecting the
5447 namespace where code is being executed with something that looks
5454 namespace where code is being executed with something that looks
5448 enough like a module to fool pickle.dump(). Since a pickle stores
5455 enough like a module to fool pickle.dump(). Since a pickle stores
5449 a named reference to the importing module, we need this for
5456 a named reference to the importing module, we need this for
5450 pickles to save something sensible.
5457 pickles to save something sensible.
5451
5458
5452 * IPython/ipmaker.py (make_IPython): added an autocall option.
5459 * IPython/ipmaker.py (make_IPython): added an autocall option.
5453
5460
5454 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
5461 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
5455 the auto-eval code. Now autocalling is an option, and the code is
5462 the auto-eval code. Now autocalling is an option, and the code is
5456 also vastly safer. There is no more eval() involved at all.
5463 also vastly safer. There is no more eval() involved at all.
5457
5464
5458 2003-03-01 Fernando Perez <fperez@colorado.edu>
5465 2003-03-01 Fernando Perez <fperez@colorado.edu>
5459
5466
5460 * IPython/Magic.py (Magic._ofind): Changed interface to return a
5467 * IPython/Magic.py (Magic._ofind): Changed interface to return a
5461 dict with named keys instead of a tuple.
5468 dict with named keys instead of a tuple.
5462
5469
5463 * IPython: Started using CVS for IPython as of 0.2.15pre1.
5470 * IPython: Started using CVS for IPython as of 0.2.15pre1.
5464
5471
5465 * setup.py (make_shortcut): Fixed message about directories
5472 * setup.py (make_shortcut): Fixed message about directories
5466 created during Windows installation (the directories were ok, just
5473 created during Windows installation (the directories were ok, just
5467 the printed message was misleading). Thanks to Chris Liechti
5474 the printed message was misleading). Thanks to Chris Liechti
5468 <cliechti-AT-gmx.net> for the heads up.
5475 <cliechti-AT-gmx.net> for the heads up.
5469
5476
5470 2003-02-21 Fernando Perez <fperez@colorado.edu>
5477 2003-02-21 Fernando Perez <fperez@colorado.edu>
5471
5478
5472 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
5479 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
5473 of ValueError exception when checking for auto-execution. This
5480 of ValueError exception when checking for auto-execution. This
5474 one is raised by things like Numeric arrays arr.flat when the
5481 one is raised by things like Numeric arrays arr.flat when the
5475 array is non-contiguous.
5482 array is non-contiguous.
5476
5483
5477 2003-01-31 Fernando Perez <fperez@colorado.edu>
5484 2003-01-31 Fernando Perez <fperez@colorado.edu>
5478
5485
5479 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
5486 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
5480 not return any value at all (even though the command would get
5487 not return any value at all (even though the command would get
5481 executed).
5488 executed).
5482 (xsys): Flush stdout right after printing the command to ensure
5489 (xsys): Flush stdout right after printing the command to ensure
5483 proper ordering of commands and command output in the total
5490 proper ordering of commands and command output in the total
5484 output.
5491 output.
5485 (SystemExec/xsys/bq): Switched the names of xsys/bq and
5492 (SystemExec/xsys/bq): Switched the names of xsys/bq and
5486 system/getoutput as defaults. The old ones are kept for
5493 system/getoutput as defaults. The old ones are kept for
5487 compatibility reasons, so no code which uses this library needs
5494 compatibility reasons, so no code which uses this library needs
5488 changing.
5495 changing.
5489
5496
5490 2003-01-27 *** Released version 0.2.14
5497 2003-01-27 *** Released version 0.2.14
5491
5498
5492 2003-01-25 Fernando Perez <fperez@colorado.edu>
5499 2003-01-25 Fernando Perez <fperez@colorado.edu>
5493
5500
5494 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
5501 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
5495 functions defined in previous edit sessions could not be re-edited
5502 functions defined in previous edit sessions could not be re-edited
5496 (because the temp files were immediately removed). Now temp files
5503 (because the temp files were immediately removed). Now temp files
5497 are removed only at IPython's exit.
5504 are removed only at IPython's exit.
5498 (Magic.magic_run): Improved @run to perform shell-like expansions
5505 (Magic.magic_run): Improved @run to perform shell-like expansions
5499 on its arguments (~users and $VARS). With this, @run becomes more
5506 on its arguments (~users and $VARS). With this, @run becomes more
5500 like a normal command-line.
5507 like a normal command-line.
5501
5508
5502 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
5509 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
5503 bugs related to embedding and cleaned up that code. A fairly
5510 bugs related to embedding and cleaned up that code. A fairly
5504 important one was the impossibility to access the global namespace
5511 important one was the impossibility to access the global namespace
5505 through the embedded IPython (only local variables were visible).
5512 through the embedded IPython (only local variables were visible).
5506
5513
5507 2003-01-14 Fernando Perez <fperez@colorado.edu>
5514 2003-01-14 Fernando Perez <fperez@colorado.edu>
5508
5515
5509 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
5516 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
5510 auto-calling to be a bit more conservative. Now it doesn't get
5517 auto-calling to be a bit more conservative. Now it doesn't get
5511 triggered if any of '!=()<>' are in the rest of the input line, to
5518 triggered if any of '!=()<>' are in the rest of the input line, to
5512 allow comparing callables. Thanks to Alex for the heads up.
5519 allow comparing callables. Thanks to Alex for the heads up.
5513
5520
5514 2003-01-07 Fernando Perez <fperez@colorado.edu>
5521 2003-01-07 Fernando Perez <fperez@colorado.edu>
5515
5522
5516 * IPython/genutils.py (page): fixed estimation of the number of
5523 * IPython/genutils.py (page): fixed estimation of the number of
5517 lines in a string to be paged to simply count newlines. This
5524 lines in a string to be paged to simply count newlines. This
5518 prevents over-guessing due to embedded escape sequences. A better
5525 prevents over-guessing due to embedded escape sequences. A better
5519 long-term solution would involve stripping out the control chars
5526 long-term solution would involve stripping out the control chars
5520 for the count, but it's potentially so expensive I just don't
5527 for the count, but it's potentially so expensive I just don't
5521 think it's worth doing.
5528 think it's worth doing.
5522
5529
5523 2002-12-19 *** Released version 0.2.14pre50
5530 2002-12-19 *** Released version 0.2.14pre50
5524
5531
5525 2002-12-19 Fernando Perez <fperez@colorado.edu>
5532 2002-12-19 Fernando Perez <fperez@colorado.edu>
5526
5533
5527 * tools/release (version): Changed release scripts to inform
5534 * tools/release (version): Changed release scripts to inform
5528 Andrea and build a NEWS file with a list of recent changes.
5535 Andrea and build a NEWS file with a list of recent changes.
5529
5536
5530 * IPython/ColorANSI.py (__all__): changed terminal detection
5537 * IPython/ColorANSI.py (__all__): changed terminal detection
5531 code. Seems to work better for xterms without breaking
5538 code. Seems to work better for xterms without breaking
5532 konsole. Will need more testing to determine if WinXP and Mac OSX
5539 konsole. Will need more testing to determine if WinXP and Mac OSX
5533 also work ok.
5540 also work ok.
5534
5541
5535 2002-12-18 *** Released version 0.2.14pre49
5542 2002-12-18 *** Released version 0.2.14pre49
5536
5543
5537 2002-12-18 Fernando Perez <fperez@colorado.edu>
5544 2002-12-18 Fernando Perez <fperez@colorado.edu>
5538
5545
5539 * Docs: added new info about Mac OSX, from Andrea.
5546 * Docs: added new info about Mac OSX, from Andrea.
5540
5547
5541 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
5548 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
5542 allow direct plotting of python strings whose format is the same
5549 allow direct plotting of python strings whose format is the same
5543 of gnuplot data files.
5550 of gnuplot data files.
5544
5551
5545 2002-12-16 Fernando Perez <fperez@colorado.edu>
5552 2002-12-16 Fernando Perez <fperez@colorado.edu>
5546
5553
5547 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
5554 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
5548 value of exit question to be acknowledged.
5555 value of exit question to be acknowledged.
5549
5556
5550 2002-12-03 Fernando Perez <fperez@colorado.edu>
5557 2002-12-03 Fernando Perez <fperez@colorado.edu>
5551
5558
5552 * IPython/ipmaker.py: removed generators, which had been added
5559 * IPython/ipmaker.py: removed generators, which had been added
5553 by mistake in an earlier debugging run. This was causing trouble
5560 by mistake in an earlier debugging run. This was causing trouble
5554 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
5561 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
5555 for pointing this out.
5562 for pointing this out.
5556
5563
5557 2002-11-17 Fernando Perez <fperez@colorado.edu>
5564 2002-11-17 Fernando Perez <fperez@colorado.edu>
5558
5565
5559 * Manual: updated the Gnuplot section.
5566 * Manual: updated the Gnuplot section.
5560
5567
5561 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
5568 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
5562 a much better split of what goes in Runtime and what goes in
5569 a much better split of what goes in Runtime and what goes in
5563 Interactive.
5570 Interactive.
5564
5571
5565 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
5572 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
5566 being imported from iplib.
5573 being imported from iplib.
5567
5574
5568 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
5575 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
5569 for command-passing. Now the global Gnuplot instance is called
5576 for command-passing. Now the global Gnuplot instance is called
5570 'gp' instead of 'g', which was really a far too fragile and
5577 'gp' instead of 'g', which was really a far too fragile and
5571 common name.
5578 common name.
5572
5579
5573 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
5580 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
5574 bounding boxes generated by Gnuplot for square plots.
5581 bounding boxes generated by Gnuplot for square plots.
5575
5582
5576 * IPython/genutils.py (popkey): new function added. I should
5583 * IPython/genutils.py (popkey): new function added. I should
5577 suggest this on c.l.py as a dict method, it seems useful.
5584 suggest this on c.l.py as a dict method, it seems useful.
5578
5585
5579 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
5586 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
5580 to transparently handle PostScript generation. MUCH better than
5587 to transparently handle PostScript generation. MUCH better than
5581 the previous plot_eps/replot_eps (which I removed now). The code
5588 the previous plot_eps/replot_eps (which I removed now). The code
5582 is also fairly clean and well documented now (including
5589 is also fairly clean and well documented now (including
5583 docstrings).
5590 docstrings).
5584
5591
5585 2002-11-13 Fernando Perez <fperez@colorado.edu>
5592 2002-11-13 Fernando Perez <fperez@colorado.edu>
5586
5593
5587 * IPython/Magic.py (Magic.magic_edit): fixed docstring
5594 * IPython/Magic.py (Magic.magic_edit): fixed docstring
5588 (inconsistent with options).
5595 (inconsistent with options).
5589
5596
5590 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
5597 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
5591 manually disabled, I don't know why. Fixed it.
5598 manually disabled, I don't know why. Fixed it.
5592 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
5599 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
5593 eps output.
5600 eps output.
5594
5601
5595 2002-11-12 Fernando Perez <fperez@colorado.edu>
5602 2002-11-12 Fernando Perez <fperez@colorado.edu>
5596
5603
5597 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
5604 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
5598 don't propagate up to caller. Fixes crash reported by François
5605 don't propagate up to caller. Fixes crash reported by François
5599 Pinard.
5606 Pinard.
5600
5607
5601 2002-11-09 Fernando Perez <fperez@colorado.edu>
5608 2002-11-09 Fernando Perez <fperez@colorado.edu>
5602
5609
5603 * IPython/ipmaker.py (make_IPython): fixed problem with writing
5610 * IPython/ipmaker.py (make_IPython): fixed problem with writing
5604 history file for new users.
5611 history file for new users.
5605 (make_IPython): fixed bug where initial install would leave the
5612 (make_IPython): fixed bug where initial install would leave the
5606 user running in the .ipython dir.
5613 user running in the .ipython dir.
5607 (make_IPython): fixed bug where config dir .ipython would be
5614 (make_IPython): fixed bug where config dir .ipython would be
5608 created regardless of the given -ipythondir option. Thanks to Cory
5615 created regardless of the given -ipythondir option. Thanks to Cory
5609 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
5616 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
5610
5617
5611 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
5618 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
5612 type confirmations. Will need to use it in all of IPython's code
5619 type confirmations. Will need to use it in all of IPython's code
5613 consistently.
5620 consistently.
5614
5621
5615 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
5622 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
5616 context to print 31 lines instead of the default 5. This will make
5623 context to print 31 lines instead of the default 5. This will make
5617 the crash reports extremely detailed in case the problem is in
5624 the crash reports extremely detailed in case the problem is in
5618 libraries I don't have access to.
5625 libraries I don't have access to.
5619
5626
5620 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
5627 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
5621 line of defense' code to still crash, but giving users fair
5628 line of defense' code to still crash, but giving users fair
5622 warning. I don't want internal errors to go unreported: if there's
5629 warning. I don't want internal errors to go unreported: if there's
5623 an internal problem, IPython should crash and generate a full
5630 an internal problem, IPython should crash and generate a full
5624 report.
5631 report.
5625
5632
5626 2002-11-08 Fernando Perez <fperez@colorado.edu>
5633 2002-11-08 Fernando Perez <fperez@colorado.edu>
5627
5634
5628 * IPython/iplib.py (InteractiveShell.interact): added code to trap
5635 * IPython/iplib.py (InteractiveShell.interact): added code to trap
5629 otherwise uncaught exceptions which can appear if people set
5636 otherwise uncaught exceptions which can appear if people set
5630 sys.stdout to something badly broken. Thanks to a crash report
5637 sys.stdout to something badly broken. Thanks to a crash report
5631 from henni-AT-mail.brainbot.com.
5638 from henni-AT-mail.brainbot.com.
5632
5639
5633 2002-11-04 Fernando Perez <fperez@colorado.edu>
5640 2002-11-04 Fernando Perez <fperez@colorado.edu>
5634
5641
5635 * IPython/iplib.py (InteractiveShell.interact): added
5642 * IPython/iplib.py (InteractiveShell.interact): added
5636 __IPYTHON__active to the builtins. It's a flag which goes on when
5643 __IPYTHON__active to the builtins. It's a flag which goes on when
5637 the interaction starts and goes off again when it stops. This
5644 the interaction starts and goes off again when it stops. This
5638 allows embedding code to detect being inside IPython. Before this
5645 allows embedding code to detect being inside IPython. Before this
5639 was done via __IPYTHON__, but that only shows that an IPython
5646 was done via __IPYTHON__, but that only shows that an IPython
5640 instance has been created.
5647 instance has been created.
5641
5648
5642 * IPython/Magic.py (Magic.magic_env): I realized that in a
5649 * IPython/Magic.py (Magic.magic_env): I realized that in a
5643 UserDict, instance.data holds the data as a normal dict. So I
5650 UserDict, instance.data holds the data as a normal dict. So I
5644 modified @env to return os.environ.data instead of rebuilding a
5651 modified @env to return os.environ.data instead of rebuilding a
5645 dict by hand.
5652 dict by hand.
5646
5653
5647 2002-11-02 Fernando Perez <fperez@colorado.edu>
5654 2002-11-02 Fernando Perez <fperez@colorado.edu>
5648
5655
5649 * IPython/genutils.py (warn): changed so that level 1 prints no
5656 * IPython/genutils.py (warn): changed so that level 1 prints no
5650 header. Level 2 is now the default (with 'WARNING' header, as
5657 header. Level 2 is now the default (with 'WARNING' header, as
5651 before). I think I tracked all places where changes were needed in
5658 before). I think I tracked all places where changes were needed in
5652 IPython, but outside code using the old level numbering may have
5659 IPython, but outside code using the old level numbering may have
5653 broken.
5660 broken.
5654
5661
5655 * IPython/iplib.py (InteractiveShell.runcode): added this to
5662 * IPython/iplib.py (InteractiveShell.runcode): added this to
5656 handle the tracebacks in SystemExit traps correctly. The previous
5663 handle the tracebacks in SystemExit traps correctly. The previous
5657 code (through interact) was printing more of the stack than
5664 code (through interact) was printing more of the stack than
5658 necessary, showing IPython internal code to the user.
5665 necessary, showing IPython internal code to the user.
5659
5666
5660 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
5667 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
5661 default. Now that the default at the confirmation prompt is yes,
5668 default. Now that the default at the confirmation prompt is yes,
5662 it's not so intrusive. François' argument that ipython sessions
5669 it's not so intrusive. François' argument that ipython sessions
5663 tend to be complex enough not to lose them from an accidental C-d,
5670 tend to be complex enough not to lose them from an accidental C-d,
5664 is a valid one.
5671 is a valid one.
5665
5672
5666 * IPython/iplib.py (InteractiveShell.interact): added a
5673 * IPython/iplib.py (InteractiveShell.interact): added a
5667 showtraceback() call to the SystemExit trap, and modified the exit
5674 showtraceback() call to the SystemExit trap, and modified the exit
5668 confirmation to have yes as the default.
5675 confirmation to have yes as the default.
5669
5676
5670 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
5677 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
5671 this file. It's been gone from the code for a long time, this was
5678 this file. It's been gone from the code for a long time, this was
5672 simply leftover junk.
5679 simply leftover junk.
5673
5680
5674 2002-11-01 Fernando Perez <fperez@colorado.edu>
5681 2002-11-01 Fernando Perez <fperez@colorado.edu>
5675
5682
5676 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
5683 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
5677 added. If set, IPython now traps EOF and asks for
5684 added. If set, IPython now traps EOF and asks for
5678 confirmation. After a request by François Pinard.
5685 confirmation. After a request by François Pinard.
5679
5686
5680 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
5687 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
5681 of @abort, and with a new (better) mechanism for handling the
5688 of @abort, and with a new (better) mechanism for handling the
5682 exceptions.
5689 exceptions.
5683
5690
5684 2002-10-27 Fernando Perez <fperez@colorado.edu>
5691 2002-10-27 Fernando Perez <fperez@colorado.edu>
5685
5692
5686 * IPython/usage.py (__doc__): updated the --help information and
5693 * IPython/usage.py (__doc__): updated the --help information and
5687 the ipythonrc file to indicate that -log generates
5694 the ipythonrc file to indicate that -log generates
5688 ./ipython.log. Also fixed the corresponding info in @logstart.
5695 ./ipython.log. Also fixed the corresponding info in @logstart.
5689 This and several other fixes in the manuals thanks to reports by
5696 This and several other fixes in the manuals thanks to reports by
5690 François Pinard <pinard-AT-iro.umontreal.ca>.
5697 François Pinard <pinard-AT-iro.umontreal.ca>.
5691
5698
5692 * IPython/Logger.py (Logger.switch_log): Fixed error message to
5699 * IPython/Logger.py (Logger.switch_log): Fixed error message to
5693 refer to @logstart (instead of @log, which doesn't exist).
5700 refer to @logstart (instead of @log, which doesn't exist).
5694
5701
5695 * IPython/iplib.py (InteractiveShell._prefilter): fixed
5702 * IPython/iplib.py (InteractiveShell._prefilter): fixed
5696 AttributeError crash. Thanks to Christopher Armstrong
5703 AttributeError crash. Thanks to Christopher Armstrong
5697 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
5704 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
5698 introduced recently (in 0.2.14pre37) with the fix to the eval
5705 introduced recently (in 0.2.14pre37) with the fix to the eval
5699 problem mentioned below.
5706 problem mentioned below.
5700
5707
5701 2002-10-17 Fernando Perez <fperez@colorado.edu>
5708 2002-10-17 Fernando Perez <fperez@colorado.edu>
5702
5709
5703 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
5710 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
5704 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
5711 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
5705
5712
5706 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
5713 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
5707 this function to fix a problem reported by Alex Schmolck. He saw
5714 this function to fix a problem reported by Alex Schmolck. He saw
5708 it with list comprehensions and generators, which were getting
5715 it with list comprehensions and generators, which were getting
5709 called twice. The real problem was an 'eval' call in testing for
5716 called twice. The real problem was an 'eval' call in testing for
5710 automagic which was evaluating the input line silently.
5717 automagic which was evaluating the input line silently.
5711
5718
5712 This is a potentially very nasty bug, if the input has side
5719 This is a potentially very nasty bug, if the input has side
5713 effects which must not be repeated. The code is much cleaner now,
5720 effects which must not be repeated. The code is much cleaner now,
5714 without any blanket 'except' left and with a regexp test for
5721 without any blanket 'except' left and with a regexp test for
5715 actual function names.
5722 actual function names.
5716
5723
5717 But an eval remains, which I'm not fully comfortable with. I just
5724 But an eval remains, which I'm not fully comfortable with. I just
5718 don't know how to find out if an expression could be a callable in
5725 don't know how to find out if an expression could be a callable in
5719 the user's namespace without doing an eval on the string. However
5726 the user's namespace without doing an eval on the string. However
5720 that string is now much more strictly checked so that no code
5727 that string is now much more strictly checked so that no code
5721 slips by, so the eval should only happen for things that can
5728 slips by, so the eval should only happen for things that can
5722 really be only function/method names.
5729 really be only function/method names.
5723
5730
5724 2002-10-15 Fernando Perez <fperez@colorado.edu>
5731 2002-10-15 Fernando Perez <fperez@colorado.edu>
5725
5732
5726 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
5733 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
5727 OSX information to main manual, removed README_Mac_OSX file from
5734 OSX information to main manual, removed README_Mac_OSX file from
5728 distribution. Also updated credits for recent additions.
5735 distribution. Also updated credits for recent additions.
5729
5736
5730 2002-10-10 Fernando Perez <fperez@colorado.edu>
5737 2002-10-10 Fernando Perez <fperez@colorado.edu>
5731
5738
5732 * README_Mac_OSX: Added a README for Mac OSX users for fixing
5739 * README_Mac_OSX: Added a README for Mac OSX users for fixing
5733 terminal-related issues. Many thanks to Andrea Riciputi
5740 terminal-related issues. Many thanks to Andrea Riciputi
5734 <andrea.riciputi-AT-libero.it> for writing it.
5741 <andrea.riciputi-AT-libero.it> for writing it.
5735
5742
5736 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
5743 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
5737 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
5744 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
5738
5745
5739 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
5746 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
5740 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
5747 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
5741 <syver-en-AT-online.no> who both submitted patches for this problem.
5748 <syver-en-AT-online.no> who both submitted patches for this problem.
5742
5749
5743 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
5750 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
5744 global embedding to make sure that things don't overwrite user
5751 global embedding to make sure that things don't overwrite user
5745 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
5752 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
5746
5753
5747 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
5754 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
5748 compatibility. Thanks to Hayden Callow
5755 compatibility. Thanks to Hayden Callow
5749 <h.callow-AT-elec.canterbury.ac.nz>
5756 <h.callow-AT-elec.canterbury.ac.nz>
5750
5757
5751 2002-10-04 Fernando Perez <fperez@colorado.edu>
5758 2002-10-04 Fernando Perez <fperez@colorado.edu>
5752
5759
5753 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
5760 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
5754 Gnuplot.File objects.
5761 Gnuplot.File objects.
5755
5762
5756 2002-07-23 Fernando Perez <fperez@colorado.edu>
5763 2002-07-23 Fernando Perez <fperez@colorado.edu>
5757
5764
5758 * IPython/genutils.py (timing): Added timings() and timing() for
5765 * IPython/genutils.py (timing): Added timings() and timing() for
5759 quick access to the most commonly needed data, the execution
5766 quick access to the most commonly needed data, the execution
5760 times. Old timing() renamed to timings_out().
5767 times. Old timing() renamed to timings_out().
5761
5768
5762 2002-07-18 Fernando Perez <fperez@colorado.edu>
5769 2002-07-18 Fernando Perez <fperez@colorado.edu>
5763
5770
5764 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
5771 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
5765 bug with nested instances disrupting the parent's tab completion.
5772 bug with nested instances disrupting the parent's tab completion.
5766
5773
5767 * IPython/iplib.py (all_completions): Added Alex Schmolck's
5774 * IPython/iplib.py (all_completions): Added Alex Schmolck's
5768 all_completions code to begin the emacs integration.
5775 all_completions code to begin the emacs integration.
5769
5776
5770 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
5777 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
5771 argument to allow titling individual arrays when plotting.
5778 argument to allow titling individual arrays when plotting.
5772
5779
5773 2002-07-15 Fernando Perez <fperez@colorado.edu>
5780 2002-07-15 Fernando Perez <fperez@colorado.edu>
5774
5781
5775 * setup.py (make_shortcut): changed to retrieve the value of
5782 * setup.py (make_shortcut): changed to retrieve the value of
5776 'Program Files' directory from the registry (this value changes in
5783 'Program Files' directory from the registry (this value changes in
5777 non-english versions of Windows). Thanks to Thomas Fanslau
5784 non-english versions of Windows). Thanks to Thomas Fanslau
5778 <tfanslau-AT-gmx.de> for the report.
5785 <tfanslau-AT-gmx.de> for the report.
5779
5786
5780 2002-07-10 Fernando Perez <fperez@colorado.edu>
5787 2002-07-10 Fernando Perez <fperez@colorado.edu>
5781
5788
5782 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
5789 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
5783 a bug in pdb, which crashes if a line with only whitespace is
5790 a bug in pdb, which crashes if a line with only whitespace is
5784 entered. Bug report submitted to sourceforge.
5791 entered. Bug report submitted to sourceforge.
5785
5792
5786 2002-07-09 Fernando Perez <fperez@colorado.edu>
5793 2002-07-09 Fernando Perez <fperez@colorado.edu>
5787
5794
5788 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
5795 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
5789 reporting exceptions (it's a bug in inspect.py, I just set a
5796 reporting exceptions (it's a bug in inspect.py, I just set a
5790 workaround).
5797 workaround).
5791
5798
5792 2002-07-08 Fernando Perez <fperez@colorado.edu>
5799 2002-07-08 Fernando Perez <fperez@colorado.edu>
5793
5800
5794 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
5801 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
5795 __IPYTHON__ in __builtins__ to show up in user_ns.
5802 __IPYTHON__ in __builtins__ to show up in user_ns.
5796
5803
5797 2002-07-03 Fernando Perez <fperez@colorado.edu>
5804 2002-07-03 Fernando Perez <fperez@colorado.edu>
5798
5805
5799 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
5806 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
5800 name from @gp_set_instance to @gp_set_default.
5807 name from @gp_set_instance to @gp_set_default.
5801
5808
5802 * IPython/ipmaker.py (make_IPython): default editor value set to
5809 * IPython/ipmaker.py (make_IPython): default editor value set to
5803 '0' (a string), to match the rc file. Otherwise will crash when
5810 '0' (a string), to match the rc file. Otherwise will crash when
5804 .strip() is called on it.
5811 .strip() is called on it.
5805
5812
5806
5813
5807 2002-06-28 Fernando Perez <fperez@colorado.edu>
5814 2002-06-28 Fernando Perez <fperez@colorado.edu>
5808
5815
5809 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
5816 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
5810 of files in current directory when a file is executed via
5817 of files in current directory when a file is executed via
5811 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
5818 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
5812
5819
5813 * setup.py (manfiles): fix for rpm builds, submitted by RA
5820 * setup.py (manfiles): fix for rpm builds, submitted by RA
5814 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
5821 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
5815
5822
5816 * IPython/ipmaker.py (make_IPython): fixed lookup of default
5823 * IPython/ipmaker.py (make_IPython): fixed lookup of default
5817 editor when set to '0'. Problem was, '0' evaluates to True (it's a
5824 editor when set to '0'. Problem was, '0' evaluates to True (it's a
5818 string!). A. Schmolck caught this one.
5825 string!). A. Schmolck caught this one.
5819
5826
5820 2002-06-27 Fernando Perez <fperez@colorado.edu>
5827 2002-06-27 Fernando Perez <fperez@colorado.edu>
5821
5828
5822 * IPython/ipmaker.py (make_IPython): fixed bug when running user
5829 * IPython/ipmaker.py (make_IPython): fixed bug when running user
5823 defined files at the cmd line. __name__ wasn't being set to
5830 defined files at the cmd line. __name__ wasn't being set to
5824 __main__.
5831 __main__.
5825
5832
5826 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
5833 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
5827 regular lists and tuples besides Numeric arrays.
5834 regular lists and tuples besides Numeric arrays.
5828
5835
5829 * IPython/Prompts.py (CachedOutput.__call__): Added output
5836 * IPython/Prompts.py (CachedOutput.__call__): Added output
5830 supression for input ending with ';'. Similar to Mathematica and
5837 supression for input ending with ';'. Similar to Mathematica and
5831 Matlab. The _* vars and Out[] list are still updated, just like
5838 Matlab. The _* vars and Out[] list are still updated, just like
5832 Mathematica behaves.
5839 Mathematica behaves.
5833
5840
5834 2002-06-25 Fernando Perez <fperez@colorado.edu>
5841 2002-06-25 Fernando Perez <fperez@colorado.edu>
5835
5842
5836 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
5843 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
5837 .ini extensions for profiels under Windows.
5844 .ini extensions for profiels under Windows.
5838
5845
5839 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
5846 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
5840 string form. Fix contributed by Alexander Schmolck
5847 string form. Fix contributed by Alexander Schmolck
5841 <a.schmolck-AT-gmx.net>
5848 <a.schmolck-AT-gmx.net>
5842
5849
5843 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
5850 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
5844 pre-configured Gnuplot instance.
5851 pre-configured Gnuplot instance.
5845
5852
5846 2002-06-21 Fernando Perez <fperez@colorado.edu>
5853 2002-06-21 Fernando Perez <fperez@colorado.edu>
5847
5854
5848 * IPython/numutils.py (exp_safe): new function, works around the
5855 * IPython/numutils.py (exp_safe): new function, works around the
5849 underflow problems in Numeric.
5856 underflow problems in Numeric.
5850 (log2): New fn. Safe log in base 2: returns exact integer answer
5857 (log2): New fn. Safe log in base 2: returns exact integer answer
5851 for exact integer powers of 2.
5858 for exact integer powers of 2.
5852
5859
5853 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
5860 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
5854 properly.
5861 properly.
5855
5862
5856 2002-06-20 Fernando Perez <fperez@colorado.edu>
5863 2002-06-20 Fernando Perez <fperez@colorado.edu>
5857
5864
5858 * IPython/genutils.py (timing): new function like
5865 * IPython/genutils.py (timing): new function like
5859 Mathematica's. Similar to time_test, but returns more info.
5866 Mathematica's. Similar to time_test, but returns more info.
5860
5867
5861 2002-06-18 Fernando Perez <fperez@colorado.edu>
5868 2002-06-18 Fernando Perez <fperez@colorado.edu>
5862
5869
5863 * IPython/Magic.py (Magic.magic_save): modified @save and @r
5870 * IPython/Magic.py (Magic.magic_save): modified @save and @r
5864 according to Mike Heeter's suggestions.
5871 according to Mike Heeter's suggestions.
5865
5872
5866 2002-06-16 Fernando Perez <fperez@colorado.edu>
5873 2002-06-16 Fernando Perez <fperez@colorado.edu>
5867
5874
5868 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
5875 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
5869 system. GnuplotMagic is gone as a user-directory option. New files
5876 system. GnuplotMagic is gone as a user-directory option. New files
5870 make it easier to use all the gnuplot stuff both from external
5877 make it easier to use all the gnuplot stuff both from external
5871 programs as well as from IPython. Had to rewrite part of
5878 programs as well as from IPython. Had to rewrite part of
5872 hardcopy() b/c of a strange bug: often the ps files simply don't
5879 hardcopy() b/c of a strange bug: often the ps files simply don't
5873 get created, and require a repeat of the command (often several
5880 get created, and require a repeat of the command (often several
5874 times).
5881 times).
5875
5882
5876 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
5883 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
5877 resolve output channel at call time, so that if sys.stderr has
5884 resolve output channel at call time, so that if sys.stderr has
5878 been redirected by user this gets honored.
5885 been redirected by user this gets honored.
5879
5886
5880 2002-06-13 Fernando Perez <fperez@colorado.edu>
5887 2002-06-13 Fernando Perez <fperez@colorado.edu>
5881
5888
5882 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
5889 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
5883 IPShell. Kept a copy with the old names to avoid breaking people's
5890 IPShell. Kept a copy with the old names to avoid breaking people's
5884 embedded code.
5891 embedded code.
5885
5892
5886 * IPython/ipython: simplified it to the bare minimum after
5893 * IPython/ipython: simplified it to the bare minimum after
5887 Holger's suggestions. Added info about how to use it in
5894 Holger's suggestions. Added info about how to use it in
5888 PYTHONSTARTUP.
5895 PYTHONSTARTUP.
5889
5896
5890 * IPython/Shell.py (IPythonShell): changed the options passing
5897 * IPython/Shell.py (IPythonShell): changed the options passing
5891 from a string with funky %s replacements to a straight list. Maybe
5898 from a string with funky %s replacements to a straight list. Maybe
5892 a bit more typing, but it follows sys.argv conventions, so there's
5899 a bit more typing, but it follows sys.argv conventions, so there's
5893 less special-casing to remember.
5900 less special-casing to remember.
5894
5901
5895 2002-06-12 Fernando Perez <fperez@colorado.edu>
5902 2002-06-12 Fernando Perez <fperez@colorado.edu>
5896
5903
5897 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
5904 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
5898 command. Thanks to a suggestion by Mike Heeter.
5905 command. Thanks to a suggestion by Mike Heeter.
5899 (Magic.magic_pfile): added behavior to look at filenames if given
5906 (Magic.magic_pfile): added behavior to look at filenames if given
5900 arg is not a defined object.
5907 arg is not a defined object.
5901 (Magic.magic_save): New @save function to save code snippets. Also
5908 (Magic.magic_save): New @save function to save code snippets. Also
5902 a Mike Heeter idea.
5909 a Mike Heeter idea.
5903
5910
5904 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
5911 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
5905 plot() and replot(). Much more convenient now, especially for
5912 plot() and replot(). Much more convenient now, especially for
5906 interactive use.
5913 interactive use.
5907
5914
5908 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
5915 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
5909 filenames.
5916 filenames.
5910
5917
5911 2002-06-02 Fernando Perez <fperez@colorado.edu>
5918 2002-06-02 Fernando Perez <fperez@colorado.edu>
5912
5919
5913 * IPython/Struct.py (Struct.__init__): modified to admit
5920 * IPython/Struct.py (Struct.__init__): modified to admit
5914 initialization via another struct.
5921 initialization via another struct.
5915
5922
5916 * IPython/genutils.py (SystemExec.__init__): New stateful
5923 * IPython/genutils.py (SystemExec.__init__): New stateful
5917 interface to xsys and bq. Useful for writing system scripts.
5924 interface to xsys and bq. Useful for writing system scripts.
5918
5925
5919 2002-05-30 Fernando Perez <fperez@colorado.edu>
5926 2002-05-30 Fernando Perez <fperez@colorado.edu>
5920
5927
5921 * MANIFEST.in: Changed docfile selection to exclude all the lyx
5928 * MANIFEST.in: Changed docfile selection to exclude all the lyx
5922 documents. This will make the user download smaller (it's getting
5929 documents. This will make the user download smaller (it's getting
5923 too big).
5930 too big).
5924
5931
5925 2002-05-29 Fernando Perez <fperez@colorado.edu>
5932 2002-05-29 Fernando Perez <fperez@colorado.edu>
5926
5933
5927 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
5934 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
5928 fix problems with shelve and pickle. Seems to work, but I don't
5935 fix problems with shelve and pickle. Seems to work, but I don't
5929 know if corner cases break it. Thanks to Mike Heeter
5936 know if corner cases break it. Thanks to Mike Heeter
5930 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
5937 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
5931
5938
5932 2002-05-24 Fernando Perez <fperez@colorado.edu>
5939 2002-05-24 Fernando Perez <fperez@colorado.edu>
5933
5940
5934 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
5941 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
5935 macros having broken.
5942 macros having broken.
5936
5943
5937 2002-05-21 Fernando Perez <fperez@colorado.edu>
5944 2002-05-21 Fernando Perez <fperez@colorado.edu>
5938
5945
5939 * IPython/Magic.py (Magic.magic_logstart): fixed recently
5946 * IPython/Magic.py (Magic.magic_logstart): fixed recently
5940 introduced logging bug: all history before logging started was
5947 introduced logging bug: all history before logging started was
5941 being written one character per line! This came from the redesign
5948 being written one character per line! This came from the redesign
5942 of the input history as a special list which slices to strings,
5949 of the input history as a special list which slices to strings,
5943 not to lists.
5950 not to lists.
5944
5951
5945 2002-05-20 Fernando Perez <fperez@colorado.edu>
5952 2002-05-20 Fernando Perez <fperez@colorado.edu>
5946
5953
5947 * IPython/Prompts.py (CachedOutput.__init__): made the color table
5954 * IPython/Prompts.py (CachedOutput.__init__): made the color table
5948 be an attribute of all classes in this module. The design of these
5955 be an attribute of all classes in this module. The design of these
5949 classes needs some serious overhauling.
5956 classes needs some serious overhauling.
5950
5957
5951 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
5958 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
5952 which was ignoring '_' in option names.
5959 which was ignoring '_' in option names.
5953
5960
5954 * IPython/ultraTB.py (FormattedTB.__init__): Changed
5961 * IPython/ultraTB.py (FormattedTB.__init__): Changed
5955 'Verbose_novars' to 'Context' and made it the new default. It's a
5962 'Verbose_novars' to 'Context' and made it the new default. It's a
5956 bit more readable and also safer than verbose.
5963 bit more readable and also safer than verbose.
5957
5964
5958 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
5965 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
5959 triple-quoted strings.
5966 triple-quoted strings.
5960
5967
5961 * IPython/OInspect.py (__all__): new module exposing the object
5968 * IPython/OInspect.py (__all__): new module exposing the object
5962 introspection facilities. Now the corresponding magics are dummy
5969 introspection facilities. Now the corresponding magics are dummy
5963 wrappers around this. Having this module will make it much easier
5970 wrappers around this. Having this module will make it much easier
5964 to put these functions into our modified pdb.
5971 to put these functions into our modified pdb.
5965 This new object inspector system uses the new colorizing module,
5972 This new object inspector system uses the new colorizing module,
5966 so source code and other things are nicely syntax highlighted.
5973 so source code and other things are nicely syntax highlighted.
5967
5974
5968 2002-05-18 Fernando Perez <fperez@colorado.edu>
5975 2002-05-18 Fernando Perez <fperez@colorado.edu>
5969
5976
5970 * IPython/ColorANSI.py: Split the coloring tools into a separate
5977 * IPython/ColorANSI.py: Split the coloring tools into a separate
5971 module so I can use them in other code easier (they were part of
5978 module so I can use them in other code easier (they were part of
5972 ultraTB).
5979 ultraTB).
5973
5980
5974 2002-05-17 Fernando Perez <fperez@colorado.edu>
5981 2002-05-17 Fernando Perez <fperez@colorado.edu>
5975
5982
5976 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5983 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5977 fixed it to set the global 'g' also to the called instance, as
5984 fixed it to set the global 'g' also to the called instance, as
5978 long as 'g' was still a gnuplot instance (so it doesn't overwrite
5985 long as 'g' was still a gnuplot instance (so it doesn't overwrite
5979 user's 'g' variables).
5986 user's 'g' variables).
5980
5987
5981 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
5988 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
5982 global variables (aliases to _ih,_oh) so that users which expect
5989 global variables (aliases to _ih,_oh) so that users which expect
5983 In[5] or Out[7] to work aren't unpleasantly surprised.
5990 In[5] or Out[7] to work aren't unpleasantly surprised.
5984 (InputList.__getslice__): new class to allow executing slices of
5991 (InputList.__getslice__): new class to allow executing slices of
5985 input history directly. Very simple class, complements the use of
5992 input history directly. Very simple class, complements the use of
5986 macros.
5993 macros.
5987
5994
5988 2002-05-16 Fernando Perez <fperez@colorado.edu>
5995 2002-05-16 Fernando Perez <fperez@colorado.edu>
5989
5996
5990 * setup.py (docdirbase): make doc directory be just doc/IPython
5997 * setup.py (docdirbase): make doc directory be just doc/IPython
5991 without version numbers, it will reduce clutter for users.
5998 without version numbers, it will reduce clutter for users.
5992
5999
5993 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
6000 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
5994 execfile call to prevent possible memory leak. See for details:
6001 execfile call to prevent possible memory leak. See for details:
5995 http://mail.python.org/pipermail/python-list/2002-February/088476.html
6002 http://mail.python.org/pipermail/python-list/2002-February/088476.html
5996
6003
5997 2002-05-15 Fernando Perez <fperez@colorado.edu>
6004 2002-05-15 Fernando Perez <fperez@colorado.edu>
5998
6005
5999 * IPython/Magic.py (Magic.magic_psource): made the object
6006 * IPython/Magic.py (Magic.magic_psource): made the object
6000 introspection names be more standard: pdoc, pdef, pfile and
6007 introspection names be more standard: pdoc, pdef, pfile and
6001 psource. They all print/page their output, and it makes
6008 psource. They all print/page their output, and it makes
6002 remembering them easier. Kept old names for compatibility as
6009 remembering them easier. Kept old names for compatibility as
6003 aliases.
6010 aliases.
6004
6011
6005 2002-05-14 Fernando Perez <fperez@colorado.edu>
6012 2002-05-14 Fernando Perez <fperez@colorado.edu>
6006
6013
6007 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
6014 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
6008 what the mouse problem was. The trick is to use gnuplot with temp
6015 what the mouse problem was. The trick is to use gnuplot with temp
6009 files and NOT with pipes (for data communication), because having
6016 files and NOT with pipes (for data communication), because having
6010 both pipes and the mouse on is bad news.
6017 both pipes and the mouse on is bad news.
6011
6018
6012 2002-05-13 Fernando Perez <fperez@colorado.edu>
6019 2002-05-13 Fernando Perez <fperez@colorado.edu>
6013
6020
6014 * IPython/Magic.py (Magic._ofind): fixed namespace order search
6021 * IPython/Magic.py (Magic._ofind): fixed namespace order search
6015 bug. Information would be reported about builtins even when
6022 bug. Information would be reported about builtins even when
6016 user-defined functions overrode them.
6023 user-defined functions overrode them.
6017
6024
6018 2002-05-11 Fernando Perez <fperez@colorado.edu>
6025 2002-05-11 Fernando Perez <fperez@colorado.edu>
6019
6026
6020 * IPython/__init__.py (__all__): removed FlexCompleter from
6027 * IPython/__init__.py (__all__): removed FlexCompleter from
6021 __all__ so that things don't fail in platforms without readline.
6028 __all__ so that things don't fail in platforms without readline.
6022
6029
6023 2002-05-10 Fernando Perez <fperez@colorado.edu>
6030 2002-05-10 Fernando Perez <fperez@colorado.edu>
6024
6031
6025 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
6032 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
6026 it requires Numeric, effectively making Numeric a dependency for
6033 it requires Numeric, effectively making Numeric a dependency for
6027 IPython.
6034 IPython.
6028
6035
6029 * Released 0.2.13
6036 * Released 0.2.13
6030
6037
6031 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
6038 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
6032 profiler interface. Now all the major options from the profiler
6039 profiler interface. Now all the major options from the profiler
6033 module are directly supported in IPython, both for single
6040 module are directly supported in IPython, both for single
6034 expressions (@prun) and for full programs (@run -p).
6041 expressions (@prun) and for full programs (@run -p).
6035
6042
6036 2002-05-09 Fernando Perez <fperez@colorado.edu>
6043 2002-05-09 Fernando Perez <fperez@colorado.edu>
6037
6044
6038 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
6045 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
6039 magic properly formatted for screen.
6046 magic properly formatted for screen.
6040
6047
6041 * setup.py (make_shortcut): Changed things to put pdf version in
6048 * setup.py (make_shortcut): Changed things to put pdf version in
6042 doc/ instead of doc/manual (had to change lyxport a bit).
6049 doc/ instead of doc/manual (had to change lyxport a bit).
6043
6050
6044 * IPython/Magic.py (Profile.string_stats): made profile runs go
6051 * IPython/Magic.py (Profile.string_stats): made profile runs go
6045 through pager (they are long and a pager allows searching, saving,
6052 through pager (they are long and a pager allows searching, saving,
6046 etc.)
6053 etc.)
6047
6054
6048 2002-05-08 Fernando Perez <fperez@colorado.edu>
6055 2002-05-08 Fernando Perez <fperez@colorado.edu>
6049
6056
6050 * Released 0.2.12
6057 * Released 0.2.12
6051
6058
6052 2002-05-06 Fernando Perez <fperez@colorado.edu>
6059 2002-05-06 Fernando Perez <fperez@colorado.edu>
6053
6060
6054 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
6061 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
6055 introduced); 'hist n1 n2' was broken.
6062 introduced); 'hist n1 n2' was broken.
6056 (Magic.magic_pdb): added optional on/off arguments to @pdb
6063 (Magic.magic_pdb): added optional on/off arguments to @pdb
6057 (Magic.magic_run): added option -i to @run, which executes code in
6064 (Magic.magic_run): added option -i to @run, which executes code in
6058 the IPython namespace instead of a clean one. Also added @irun as
6065 the IPython namespace instead of a clean one. Also added @irun as
6059 an alias to @run -i.
6066 an alias to @run -i.
6060
6067
6061 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
6068 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
6062 fixed (it didn't really do anything, the namespaces were wrong).
6069 fixed (it didn't really do anything, the namespaces were wrong).
6063
6070
6064 * IPython/Debugger.py (__init__): Added workaround for python 2.1
6071 * IPython/Debugger.py (__init__): Added workaround for python 2.1
6065
6072
6066 * IPython/__init__.py (__all__): Fixed package namespace, now
6073 * IPython/__init__.py (__all__): Fixed package namespace, now
6067 'import IPython' does give access to IPython.<all> as
6074 'import IPython' does give access to IPython.<all> as
6068 expected. Also renamed __release__ to Release.
6075 expected. Also renamed __release__ to Release.
6069
6076
6070 * IPython/Debugger.py (__license__): created new Pdb class which
6077 * IPython/Debugger.py (__license__): created new Pdb class which
6071 functions like a drop-in for the normal pdb.Pdb but does NOT
6078 functions like a drop-in for the normal pdb.Pdb but does NOT
6072 import readline by default. This way it doesn't muck up IPython's
6079 import readline by default. This way it doesn't muck up IPython's
6073 readline handling, and now tab-completion finally works in the
6080 readline handling, and now tab-completion finally works in the
6074 debugger -- sort of. It completes things globally visible, but the
6081 debugger -- sort of. It completes things globally visible, but the
6075 completer doesn't track the stack as pdb walks it. That's a bit
6082 completer doesn't track the stack as pdb walks it. That's a bit
6076 tricky, and I'll have to implement it later.
6083 tricky, and I'll have to implement it later.
6077
6084
6078 2002-05-05 Fernando Perez <fperez@colorado.edu>
6085 2002-05-05 Fernando Perez <fperez@colorado.edu>
6079
6086
6080 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
6087 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
6081 magic docstrings when printed via ? (explicit \'s were being
6088 magic docstrings when printed via ? (explicit \'s were being
6082 printed).
6089 printed).
6083
6090
6084 * IPython/ipmaker.py (make_IPython): fixed namespace
6091 * IPython/ipmaker.py (make_IPython): fixed namespace
6085 identification bug. Now variables loaded via logs or command-line
6092 identification bug. Now variables loaded via logs or command-line
6086 files are recognized in the interactive namespace by @who.
6093 files are recognized in the interactive namespace by @who.
6087
6094
6088 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
6095 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
6089 log replay system stemming from the string form of Structs.
6096 log replay system stemming from the string form of Structs.
6090
6097
6091 * IPython/Magic.py (Macro.__init__): improved macros to properly
6098 * IPython/Magic.py (Macro.__init__): improved macros to properly
6092 handle magic commands in them.
6099 handle magic commands in them.
6093 (Magic.magic_logstart): usernames are now expanded so 'logstart
6100 (Magic.magic_logstart): usernames are now expanded so 'logstart
6094 ~/mylog' now works.
6101 ~/mylog' now works.
6095
6102
6096 * IPython/iplib.py (complete): fixed bug where paths starting with
6103 * IPython/iplib.py (complete): fixed bug where paths starting with
6097 '/' would be completed as magic names.
6104 '/' would be completed as magic names.
6098
6105
6099 2002-05-04 Fernando Perez <fperez@colorado.edu>
6106 2002-05-04 Fernando Perez <fperez@colorado.edu>
6100
6107
6101 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
6108 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
6102 allow running full programs under the profiler's control.
6109 allow running full programs under the profiler's control.
6103
6110
6104 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
6111 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
6105 mode to report exceptions verbosely but without formatting
6112 mode to report exceptions verbosely but without formatting
6106 variables. This addresses the issue of ipython 'freezing' (it's
6113 variables. This addresses the issue of ipython 'freezing' (it's
6107 not frozen, but caught in an expensive formatting loop) when huge
6114 not frozen, but caught in an expensive formatting loop) when huge
6108 variables are in the context of an exception.
6115 variables are in the context of an exception.
6109 (VerboseTB.text): Added '--->' markers at line where exception was
6116 (VerboseTB.text): Added '--->' markers at line where exception was
6110 triggered. Much clearer to read, especially in NoColor modes.
6117 triggered. Much clearer to read, especially in NoColor modes.
6111
6118
6112 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
6119 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
6113 implemented in reverse when changing to the new parse_options().
6120 implemented in reverse when changing to the new parse_options().
6114
6121
6115 2002-05-03 Fernando Perez <fperez@colorado.edu>
6122 2002-05-03 Fernando Perez <fperez@colorado.edu>
6116
6123
6117 * IPython/Magic.py (Magic.parse_options): new function so that
6124 * IPython/Magic.py (Magic.parse_options): new function so that
6118 magics can parse options easier.
6125 magics can parse options easier.
6119 (Magic.magic_prun): new function similar to profile.run(),
6126 (Magic.magic_prun): new function similar to profile.run(),
6120 suggested by Chris Hart.
6127 suggested by Chris Hart.
6121 (Magic.magic_cd): fixed behavior so that it only changes if
6128 (Magic.magic_cd): fixed behavior so that it only changes if
6122 directory actually is in history.
6129 directory actually is in history.
6123
6130
6124 * IPython/usage.py (__doc__): added information about potential
6131 * IPython/usage.py (__doc__): added information about potential
6125 slowness of Verbose exception mode when there are huge data
6132 slowness of Verbose exception mode when there are huge data
6126 structures to be formatted (thanks to Archie Paulson).
6133 structures to be formatted (thanks to Archie Paulson).
6127
6134
6128 * IPython/ipmaker.py (make_IPython): Changed default logging
6135 * IPython/ipmaker.py (make_IPython): Changed default logging
6129 (when simply called with -log) to use curr_dir/ipython.log in
6136 (when simply called with -log) to use curr_dir/ipython.log in
6130 rotate mode. Fixed crash which was occuring with -log before
6137 rotate mode. Fixed crash which was occuring with -log before
6131 (thanks to Jim Boyle).
6138 (thanks to Jim Boyle).
6132
6139
6133 2002-05-01 Fernando Perez <fperez@colorado.edu>
6140 2002-05-01 Fernando Perez <fperez@colorado.edu>
6134
6141
6135 * Released 0.2.11 for these fixes (mainly the ultraTB one which
6142 * Released 0.2.11 for these fixes (mainly the ultraTB one which
6136 was nasty -- though somewhat of a corner case).
6143 was nasty -- though somewhat of a corner case).
6137
6144
6138 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
6145 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
6139 text (was a bug).
6146 text (was a bug).
6140
6147
6141 2002-04-30 Fernando Perez <fperez@colorado.edu>
6148 2002-04-30 Fernando Perez <fperez@colorado.edu>
6142
6149
6143 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
6150 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
6144 a print after ^D or ^C from the user so that the In[] prompt
6151 a print after ^D or ^C from the user so that the In[] prompt
6145 doesn't over-run the gnuplot one.
6152 doesn't over-run the gnuplot one.
6146
6153
6147 2002-04-29 Fernando Perez <fperez@colorado.edu>
6154 2002-04-29 Fernando Perez <fperez@colorado.edu>
6148
6155
6149 * Released 0.2.10
6156 * Released 0.2.10
6150
6157
6151 * IPython/__release__.py (version): get date dynamically.
6158 * IPython/__release__.py (version): get date dynamically.
6152
6159
6153 * Misc. documentation updates thanks to Arnd's comments. Also ran
6160 * Misc. documentation updates thanks to Arnd's comments. Also ran
6154 a full spellcheck on the manual (hadn't been done in a while).
6161 a full spellcheck on the manual (hadn't been done in a while).
6155
6162
6156 2002-04-27 Fernando Perez <fperez@colorado.edu>
6163 2002-04-27 Fernando Perez <fperez@colorado.edu>
6157
6164
6158 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
6165 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
6159 starting a log in mid-session would reset the input history list.
6166 starting a log in mid-session would reset the input history list.
6160
6167
6161 2002-04-26 Fernando Perez <fperez@colorado.edu>
6168 2002-04-26 Fernando Perez <fperez@colorado.edu>
6162
6169
6163 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
6170 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
6164 all files were being included in an update. Now anything in
6171 all files were being included in an update. Now anything in
6165 UserConfig that matches [A-Za-z]*.py will go (this excludes
6172 UserConfig that matches [A-Za-z]*.py will go (this excludes
6166 __init__.py)
6173 __init__.py)
6167
6174
6168 2002-04-25 Fernando Perez <fperez@colorado.edu>
6175 2002-04-25 Fernando Perez <fperez@colorado.edu>
6169
6176
6170 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
6177 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
6171 to __builtins__ so that any form of embedded or imported code can
6178 to __builtins__ so that any form of embedded or imported code can
6172 test for being inside IPython.
6179 test for being inside IPython.
6173
6180
6174 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
6181 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
6175 changed to GnuplotMagic because it's now an importable module,
6182 changed to GnuplotMagic because it's now an importable module,
6176 this makes the name follow that of the standard Gnuplot module.
6183 this makes the name follow that of the standard Gnuplot module.
6177 GnuplotMagic can now be loaded at any time in mid-session.
6184 GnuplotMagic can now be loaded at any time in mid-session.
6178
6185
6179 2002-04-24 Fernando Perez <fperez@colorado.edu>
6186 2002-04-24 Fernando Perez <fperez@colorado.edu>
6180
6187
6181 * IPython/numutils.py: removed SIUnits. It doesn't properly set
6188 * IPython/numutils.py: removed SIUnits. It doesn't properly set
6182 the globals (IPython has its own namespace) and the
6189 the globals (IPython has its own namespace) and the
6183 PhysicalQuantity stuff is much better anyway.
6190 PhysicalQuantity stuff is much better anyway.
6184
6191
6185 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
6192 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
6186 embedding example to standard user directory for
6193 embedding example to standard user directory for
6187 distribution. Also put it in the manual.
6194 distribution. Also put it in the manual.
6188
6195
6189 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
6196 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
6190 instance as first argument (so it doesn't rely on some obscure
6197 instance as first argument (so it doesn't rely on some obscure
6191 hidden global).
6198 hidden global).
6192
6199
6193 * IPython/UserConfig/ipythonrc.py: put () back in accepted
6200 * IPython/UserConfig/ipythonrc.py: put () back in accepted
6194 delimiters. While it prevents ().TAB from working, it allows
6201 delimiters. While it prevents ().TAB from working, it allows
6195 completions in open (... expressions. This is by far a more common
6202 completions in open (... expressions. This is by far a more common
6196 case.
6203 case.
6197
6204
6198 2002-04-23 Fernando Perez <fperez@colorado.edu>
6205 2002-04-23 Fernando Perez <fperez@colorado.edu>
6199
6206
6200 * IPython/Extensions/InterpreterPasteInput.py: new
6207 * IPython/Extensions/InterpreterPasteInput.py: new
6201 syntax-processing module for pasting lines with >>> or ... at the
6208 syntax-processing module for pasting lines with >>> or ... at the
6202 start.
6209 start.
6203
6210
6204 * IPython/Extensions/PhysicalQ_Interactive.py
6211 * IPython/Extensions/PhysicalQ_Interactive.py
6205 (PhysicalQuantityInteractive.__int__): fixed to work with either
6212 (PhysicalQuantityInteractive.__int__): fixed to work with either
6206 Numeric or math.
6213 Numeric or math.
6207
6214
6208 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
6215 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
6209 provided profiles. Now we have:
6216 provided profiles. Now we have:
6210 -math -> math module as * and cmath with its own namespace.
6217 -math -> math module as * and cmath with its own namespace.
6211 -numeric -> Numeric as *, plus gnuplot & grace
6218 -numeric -> Numeric as *, plus gnuplot & grace
6212 -physics -> same as before
6219 -physics -> same as before
6213
6220
6214 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
6221 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
6215 user-defined magics wouldn't be found by @magic if they were
6222 user-defined magics wouldn't be found by @magic if they were
6216 defined as class methods. Also cleaned up the namespace search
6223 defined as class methods. Also cleaned up the namespace search
6217 logic and the string building (to use %s instead of many repeated
6224 logic and the string building (to use %s instead of many repeated
6218 string adds).
6225 string adds).
6219
6226
6220 * IPython/UserConfig/example-magic.py (magic_foo): updated example
6227 * IPython/UserConfig/example-magic.py (magic_foo): updated example
6221 of user-defined magics to operate with class methods (cleaner, in
6228 of user-defined magics to operate with class methods (cleaner, in
6222 line with the gnuplot code).
6229 line with the gnuplot code).
6223
6230
6224 2002-04-22 Fernando Perez <fperez@colorado.edu>
6231 2002-04-22 Fernando Perez <fperez@colorado.edu>
6225
6232
6226 * setup.py: updated dependency list so that manual is updated when
6233 * setup.py: updated dependency list so that manual is updated when
6227 all included files change.
6234 all included files change.
6228
6235
6229 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
6236 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
6230 the delimiter removal option (the fix is ugly right now).
6237 the delimiter removal option (the fix is ugly right now).
6231
6238
6232 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
6239 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
6233 all of the math profile (quicker loading, no conflict between
6240 all of the math profile (quicker loading, no conflict between
6234 g-9.8 and g-gnuplot).
6241 g-9.8 and g-gnuplot).
6235
6242
6236 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
6243 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
6237 name of post-mortem files to IPython_crash_report.txt.
6244 name of post-mortem files to IPython_crash_report.txt.
6238
6245
6239 * Cleanup/update of the docs. Added all the new readline info and
6246 * Cleanup/update of the docs. Added all the new readline info and
6240 formatted all lists as 'real lists'.
6247 formatted all lists as 'real lists'.
6241
6248
6242 * IPython/ipmaker.py (make_IPython): removed now-obsolete
6249 * IPython/ipmaker.py (make_IPython): removed now-obsolete
6243 tab-completion options, since the full readline parse_and_bind is
6250 tab-completion options, since the full readline parse_and_bind is
6244 now accessible.
6251 now accessible.
6245
6252
6246 * IPython/iplib.py (InteractiveShell.init_readline): Changed
6253 * IPython/iplib.py (InteractiveShell.init_readline): Changed
6247 handling of readline options. Now users can specify any string to
6254 handling of readline options. Now users can specify any string to
6248 be passed to parse_and_bind(), as well as the delimiters to be
6255 be passed to parse_and_bind(), as well as the delimiters to be
6249 removed.
6256 removed.
6250 (InteractiveShell.__init__): Added __name__ to the global
6257 (InteractiveShell.__init__): Added __name__ to the global
6251 namespace so that things like Itpl which rely on its existence
6258 namespace so that things like Itpl which rely on its existence
6252 don't crash.
6259 don't crash.
6253 (InteractiveShell._prefilter): Defined the default with a _ so
6260 (InteractiveShell._prefilter): Defined the default with a _ so
6254 that prefilter() is easier to override, while the default one
6261 that prefilter() is easier to override, while the default one
6255 remains available.
6262 remains available.
6256
6263
6257 2002-04-18 Fernando Perez <fperez@colorado.edu>
6264 2002-04-18 Fernando Perez <fperez@colorado.edu>
6258
6265
6259 * Added information about pdb in the docs.
6266 * Added information about pdb in the docs.
6260
6267
6261 2002-04-17 Fernando Perez <fperez@colorado.edu>
6268 2002-04-17 Fernando Perez <fperez@colorado.edu>
6262
6269
6263 * IPython/ipmaker.py (make_IPython): added rc_override option to
6270 * IPython/ipmaker.py (make_IPython): added rc_override option to
6264 allow passing config options at creation time which may override
6271 allow passing config options at creation time which may override
6265 anything set in the config files or command line. This is
6272 anything set in the config files or command line. This is
6266 particularly useful for configuring embedded instances.
6273 particularly useful for configuring embedded instances.
6267
6274
6268 2002-04-15 Fernando Perez <fperez@colorado.edu>
6275 2002-04-15 Fernando Perez <fperez@colorado.edu>
6269
6276
6270 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
6277 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
6271 crash embedded instances because of the input cache falling out of
6278 crash embedded instances because of the input cache falling out of
6272 sync with the output counter.
6279 sync with the output counter.
6273
6280
6274 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
6281 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
6275 mode which calls pdb after an uncaught exception in IPython itself.
6282 mode which calls pdb after an uncaught exception in IPython itself.
6276
6283
6277 2002-04-14 Fernando Perez <fperez@colorado.edu>
6284 2002-04-14 Fernando Perez <fperez@colorado.edu>
6278
6285
6279 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
6286 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
6280 readline, fix it back after each call.
6287 readline, fix it back after each call.
6281
6288
6282 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
6289 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
6283 method to force all access via __call__(), which guarantees that
6290 method to force all access via __call__(), which guarantees that
6284 traceback references are properly deleted.
6291 traceback references are properly deleted.
6285
6292
6286 * IPython/Prompts.py (CachedOutput._display): minor fixes to
6293 * IPython/Prompts.py (CachedOutput._display): minor fixes to
6287 improve printing when pprint is in use.
6294 improve printing when pprint is in use.
6288
6295
6289 2002-04-13 Fernando Perez <fperez@colorado.edu>
6296 2002-04-13 Fernando Perez <fperez@colorado.edu>
6290
6297
6291 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
6298 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
6292 exceptions aren't caught anymore. If the user triggers one, he
6299 exceptions aren't caught anymore. If the user triggers one, he
6293 should know why he's doing it and it should go all the way up,
6300 should know why he's doing it and it should go all the way up,
6294 just like any other exception. So now @abort will fully kill the
6301 just like any other exception. So now @abort will fully kill the
6295 embedded interpreter and the embedding code (unless that happens
6302 embedded interpreter and the embedding code (unless that happens
6296 to catch SystemExit).
6303 to catch SystemExit).
6297
6304
6298 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
6305 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
6299 and a debugger() method to invoke the interactive pdb debugger
6306 and a debugger() method to invoke the interactive pdb debugger
6300 after printing exception information. Also added the corresponding
6307 after printing exception information. Also added the corresponding
6301 -pdb option and @pdb magic to control this feature, and updated
6308 -pdb option and @pdb magic to control this feature, and updated
6302 the docs. After a suggestion from Christopher Hart
6309 the docs. After a suggestion from Christopher Hart
6303 (hart-AT-caltech.edu).
6310 (hart-AT-caltech.edu).
6304
6311
6305 2002-04-12 Fernando Perez <fperez@colorado.edu>
6312 2002-04-12 Fernando Perez <fperez@colorado.edu>
6306
6313
6307 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
6314 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
6308 the exception handlers defined by the user (not the CrashHandler)
6315 the exception handlers defined by the user (not the CrashHandler)
6309 so that user exceptions don't trigger an ipython bug report.
6316 so that user exceptions don't trigger an ipython bug report.
6310
6317
6311 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
6318 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
6312 configurable (it should have always been so).
6319 configurable (it should have always been so).
6313
6320
6314 2002-03-26 Fernando Perez <fperez@colorado.edu>
6321 2002-03-26 Fernando Perez <fperez@colorado.edu>
6315
6322
6316 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
6323 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
6317 and there to fix embedding namespace issues. This should all be
6324 and there to fix embedding namespace issues. This should all be
6318 done in a more elegant way.
6325 done in a more elegant way.
6319
6326
6320 2002-03-25 Fernando Perez <fperez@colorado.edu>
6327 2002-03-25 Fernando Perez <fperez@colorado.edu>
6321
6328
6322 * IPython/genutils.py (get_home_dir): Try to make it work under
6329 * IPython/genutils.py (get_home_dir): Try to make it work under
6323 win9x also.
6330 win9x also.
6324
6331
6325 2002-03-20 Fernando Perez <fperez@colorado.edu>
6332 2002-03-20 Fernando Perez <fperez@colorado.edu>
6326
6333
6327 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
6334 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
6328 sys.displayhook untouched upon __init__.
6335 sys.displayhook untouched upon __init__.
6329
6336
6330 2002-03-19 Fernando Perez <fperez@colorado.edu>
6337 2002-03-19 Fernando Perez <fperez@colorado.edu>
6331
6338
6332 * Released 0.2.9 (for embedding bug, basically).
6339 * Released 0.2.9 (for embedding bug, basically).
6333
6340
6334 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
6341 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
6335 exceptions so that enclosing shell's state can be restored.
6342 exceptions so that enclosing shell's state can be restored.
6336
6343
6337 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
6344 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
6338 naming conventions in the .ipython/ dir.
6345 naming conventions in the .ipython/ dir.
6339
6346
6340 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
6347 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
6341 from delimiters list so filenames with - in them get expanded.
6348 from delimiters list so filenames with - in them get expanded.
6342
6349
6343 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
6350 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
6344 sys.displayhook not being properly restored after an embedded call.
6351 sys.displayhook not being properly restored after an embedded call.
6345
6352
6346 2002-03-18 Fernando Perez <fperez@colorado.edu>
6353 2002-03-18 Fernando Perez <fperez@colorado.edu>
6347
6354
6348 * Released 0.2.8
6355 * Released 0.2.8
6349
6356
6350 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
6357 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
6351 some files weren't being included in a -upgrade.
6358 some files weren't being included in a -upgrade.
6352 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
6359 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
6353 on' so that the first tab completes.
6360 on' so that the first tab completes.
6354 (InteractiveShell.handle_magic): fixed bug with spaces around
6361 (InteractiveShell.handle_magic): fixed bug with spaces around
6355 quotes breaking many magic commands.
6362 quotes breaking many magic commands.
6356
6363
6357 * setup.py: added note about ignoring the syntax error messages at
6364 * setup.py: added note about ignoring the syntax error messages at
6358 installation.
6365 installation.
6359
6366
6360 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
6367 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
6361 streamlining the gnuplot interface, now there's only one magic @gp.
6368 streamlining the gnuplot interface, now there's only one magic @gp.
6362
6369
6363 2002-03-17 Fernando Perez <fperez@colorado.edu>
6370 2002-03-17 Fernando Perez <fperez@colorado.edu>
6364
6371
6365 * IPython/UserConfig/magic_gnuplot.py: new name for the
6372 * IPython/UserConfig/magic_gnuplot.py: new name for the
6366 example-magic_pm.py file. Much enhanced system, now with a shell
6373 example-magic_pm.py file. Much enhanced system, now with a shell
6367 for communicating directly with gnuplot, one command at a time.
6374 for communicating directly with gnuplot, one command at a time.
6368
6375
6369 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
6376 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
6370 setting __name__=='__main__'.
6377 setting __name__=='__main__'.
6371
6378
6372 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
6379 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
6373 mini-shell for accessing gnuplot from inside ipython. Should
6380 mini-shell for accessing gnuplot from inside ipython. Should
6374 extend it later for grace access too. Inspired by Arnd's
6381 extend it later for grace access too. Inspired by Arnd's
6375 suggestion.
6382 suggestion.
6376
6383
6377 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
6384 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
6378 calling magic functions with () in their arguments. Thanks to Arnd
6385 calling magic functions with () in their arguments. Thanks to Arnd
6379 Baecker for pointing this to me.
6386 Baecker for pointing this to me.
6380
6387
6381 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
6388 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
6382 infinitely for integer or complex arrays (only worked with floats).
6389 infinitely for integer or complex arrays (only worked with floats).
6383
6390
6384 2002-03-16 Fernando Perez <fperez@colorado.edu>
6391 2002-03-16 Fernando Perez <fperez@colorado.edu>
6385
6392
6386 * setup.py: Merged setup and setup_windows into a single script
6393 * setup.py: Merged setup and setup_windows into a single script
6387 which properly handles things for windows users.
6394 which properly handles things for windows users.
6388
6395
6389 2002-03-15 Fernando Perez <fperez@colorado.edu>
6396 2002-03-15 Fernando Perez <fperez@colorado.edu>
6390
6397
6391 * Big change to the manual: now the magics are all automatically
6398 * Big change to the manual: now the magics are all automatically
6392 documented. This information is generated from their docstrings
6399 documented. This information is generated from their docstrings
6393 and put in a latex file included by the manual lyx file. This way
6400 and put in a latex file included by the manual lyx file. This way
6394 we get always up to date information for the magics. The manual
6401 we get always up to date information for the magics. The manual
6395 now also has proper version information, also auto-synced.
6402 now also has proper version information, also auto-synced.
6396
6403
6397 For this to work, an undocumented --magic_docstrings option was added.
6404 For this to work, an undocumented --magic_docstrings option was added.
6398
6405
6399 2002-03-13 Fernando Perez <fperez@colorado.edu>
6406 2002-03-13 Fernando Perez <fperez@colorado.edu>
6400
6407
6401 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
6408 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
6402 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
6409 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
6403
6410
6404 2002-03-12 Fernando Perez <fperez@colorado.edu>
6411 2002-03-12 Fernando Perez <fperez@colorado.edu>
6405
6412
6406 * IPython/ultraTB.py (TermColors): changed color escapes again to
6413 * IPython/ultraTB.py (TermColors): changed color escapes again to
6407 fix the (old, reintroduced) line-wrapping bug. Basically, if
6414 fix the (old, reintroduced) line-wrapping bug. Basically, if
6408 \001..\002 aren't given in the color escapes, lines get wrapped
6415 \001..\002 aren't given in the color escapes, lines get wrapped
6409 weirdly. But giving those screws up old xterms and emacs terms. So
6416 weirdly. But giving those screws up old xterms and emacs terms. So
6410 I added some logic for emacs terms to be ok, but I can't identify old
6417 I added some logic for emacs terms to be ok, but I can't identify old
6411 xterms separately ($TERM=='xterm' for many terminals, like konsole).
6418 xterms separately ($TERM=='xterm' for many terminals, like konsole).
6412
6419
6413 2002-03-10 Fernando Perez <fperez@colorado.edu>
6420 2002-03-10 Fernando Perez <fperez@colorado.edu>
6414
6421
6415 * IPython/usage.py (__doc__): Various documentation cleanups and
6422 * IPython/usage.py (__doc__): Various documentation cleanups and
6416 updates, both in usage docstrings and in the manual.
6423 updates, both in usage docstrings and in the manual.
6417
6424
6418 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
6425 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
6419 handling of caching. Set minimum acceptabe value for having a
6426 handling of caching. Set minimum acceptabe value for having a
6420 cache at 20 values.
6427 cache at 20 values.
6421
6428
6422 * IPython/iplib.py (InteractiveShell.user_setup): moved the
6429 * IPython/iplib.py (InteractiveShell.user_setup): moved the
6423 install_first_time function to a method, renamed it and added an
6430 install_first_time function to a method, renamed it and added an
6424 'upgrade' mode. Now people can update their config directory with
6431 'upgrade' mode. Now people can update their config directory with
6425 a simple command line switch (-upgrade, also new).
6432 a simple command line switch (-upgrade, also new).
6426
6433
6427 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
6434 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
6428 @file (convenient for automagic users under Python >= 2.2).
6435 @file (convenient for automagic users under Python >= 2.2).
6429 Removed @files (it seemed more like a plural than an abbrev. of
6436 Removed @files (it seemed more like a plural than an abbrev. of
6430 'file show').
6437 'file show').
6431
6438
6432 * IPython/iplib.py (install_first_time): Fixed crash if there were
6439 * IPython/iplib.py (install_first_time): Fixed crash if there were
6433 backup files ('~') in .ipython/ install directory.
6440 backup files ('~') in .ipython/ install directory.
6434
6441
6435 * IPython/ipmaker.py (make_IPython): fixes for new prompt
6442 * IPython/ipmaker.py (make_IPython): fixes for new prompt
6436 system. Things look fine, but these changes are fairly
6443 system. Things look fine, but these changes are fairly
6437 intrusive. Test them for a few days.
6444 intrusive. Test them for a few days.
6438
6445
6439 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
6446 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
6440 the prompts system. Now all in/out prompt strings are user
6447 the prompts system. Now all in/out prompt strings are user
6441 controllable. This is particularly useful for embedding, as one
6448 controllable. This is particularly useful for embedding, as one
6442 can tag embedded instances with particular prompts.
6449 can tag embedded instances with particular prompts.
6443
6450
6444 Also removed global use of sys.ps1/2, which now allows nested
6451 Also removed global use of sys.ps1/2, which now allows nested
6445 embeddings without any problems. Added command-line options for
6452 embeddings without any problems. Added command-line options for
6446 the prompt strings.
6453 the prompt strings.
6447
6454
6448 2002-03-08 Fernando Perez <fperez@colorado.edu>
6455 2002-03-08 Fernando Perez <fperez@colorado.edu>
6449
6456
6450 * IPython/UserConfig/example-embed-short.py (ipshell): added
6457 * IPython/UserConfig/example-embed-short.py (ipshell): added
6451 example file with the bare minimum code for embedding.
6458 example file with the bare minimum code for embedding.
6452
6459
6453 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
6460 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
6454 functionality for the embeddable shell to be activated/deactivated
6461 functionality for the embeddable shell to be activated/deactivated
6455 either globally or at each call.
6462 either globally or at each call.
6456
6463
6457 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
6464 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
6458 rewriting the prompt with '--->' for auto-inputs with proper
6465 rewriting the prompt with '--->' for auto-inputs with proper
6459 coloring. Now the previous UGLY hack in handle_auto() is gone, and
6466 coloring. Now the previous UGLY hack in handle_auto() is gone, and
6460 this is handled by the prompts class itself, as it should.
6467 this is handled by the prompts class itself, as it should.
6461
6468
6462 2002-03-05 Fernando Perez <fperez@colorado.edu>
6469 2002-03-05 Fernando Perez <fperez@colorado.edu>
6463
6470
6464 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
6471 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
6465 @logstart to avoid name clashes with the math log function.
6472 @logstart to avoid name clashes with the math log function.
6466
6473
6467 * Big updates to X/Emacs section of the manual.
6474 * Big updates to X/Emacs section of the manual.
6468
6475
6469 * Removed ipython_emacs. Milan explained to me how to pass
6476 * Removed ipython_emacs. Milan explained to me how to pass
6470 arguments to ipython through Emacs. Some day I'm going to end up
6477 arguments to ipython through Emacs. Some day I'm going to end up
6471 learning some lisp...
6478 learning some lisp...
6472
6479
6473 2002-03-04 Fernando Perez <fperez@colorado.edu>
6480 2002-03-04 Fernando Perez <fperez@colorado.edu>
6474
6481
6475 * IPython/ipython_emacs: Created script to be used as the
6482 * IPython/ipython_emacs: Created script to be used as the
6476 py-python-command Emacs variable so we can pass IPython
6483 py-python-command Emacs variable so we can pass IPython
6477 parameters. I can't figure out how to tell Emacs directly to pass
6484 parameters. I can't figure out how to tell Emacs directly to pass
6478 parameters to IPython, so a dummy shell script will do it.
6485 parameters to IPython, so a dummy shell script will do it.
6479
6486
6480 Other enhancements made for things to work better under Emacs'
6487 Other enhancements made for things to work better under Emacs'
6481 various types of terminals. Many thanks to Milan Zamazal
6488 various types of terminals. Many thanks to Milan Zamazal
6482 <pdm-AT-zamazal.org> for all the suggestions and pointers.
6489 <pdm-AT-zamazal.org> for all the suggestions and pointers.
6483
6490
6484 2002-03-01 Fernando Perez <fperez@colorado.edu>
6491 2002-03-01 Fernando Perez <fperez@colorado.edu>
6485
6492
6486 * IPython/ipmaker.py (make_IPython): added a --readline! option so
6493 * IPython/ipmaker.py (make_IPython): added a --readline! option so
6487 that loading of readline is now optional. This gives better
6494 that loading of readline is now optional. This gives better
6488 control to emacs users.
6495 control to emacs users.
6489
6496
6490 * IPython/ultraTB.py (__date__): Modified color escape sequences
6497 * IPython/ultraTB.py (__date__): Modified color escape sequences
6491 and now things work fine under xterm and in Emacs' term buffers
6498 and now things work fine under xterm and in Emacs' term buffers
6492 (though not shell ones). Well, in emacs you get colors, but all
6499 (though not shell ones). Well, in emacs you get colors, but all
6493 seem to be 'light' colors (no difference between dark and light
6500 seem to be 'light' colors (no difference between dark and light
6494 ones). But the garbage chars are gone, and also in xterms. It
6501 ones). But the garbage chars are gone, and also in xterms. It
6495 seems that now I'm using 'cleaner' ansi sequences.
6502 seems that now I'm using 'cleaner' ansi sequences.
6496
6503
6497 2002-02-21 Fernando Perez <fperez@colorado.edu>
6504 2002-02-21 Fernando Perez <fperez@colorado.edu>
6498
6505
6499 * Released 0.2.7 (mainly to publish the scoping fix).
6506 * Released 0.2.7 (mainly to publish the scoping fix).
6500
6507
6501 * IPython/Logger.py (Logger.logstate): added. A corresponding
6508 * IPython/Logger.py (Logger.logstate): added. A corresponding
6502 @logstate magic was created.
6509 @logstate magic was created.
6503
6510
6504 * IPython/Magic.py: fixed nested scoping problem under Python
6511 * IPython/Magic.py: fixed nested scoping problem under Python
6505 2.1.x (automagic wasn't working).
6512 2.1.x (automagic wasn't working).
6506
6513
6507 2002-02-20 Fernando Perez <fperez@colorado.edu>
6514 2002-02-20 Fernando Perez <fperez@colorado.edu>
6508
6515
6509 * Released 0.2.6.
6516 * Released 0.2.6.
6510
6517
6511 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
6518 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
6512 option so that logs can come out without any headers at all.
6519 option so that logs can come out without any headers at all.
6513
6520
6514 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
6521 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
6515 SciPy.
6522 SciPy.
6516
6523
6517 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
6524 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
6518 that embedded IPython calls don't require vars() to be explicitly
6525 that embedded IPython calls don't require vars() to be explicitly
6519 passed. Now they are extracted from the caller's frame (code
6526 passed. Now they are extracted from the caller's frame (code
6520 snatched from Eric Jones' weave). Added better documentation to
6527 snatched from Eric Jones' weave). Added better documentation to
6521 the section on embedding and the example file.
6528 the section on embedding and the example file.
6522
6529
6523 * IPython/genutils.py (page): Changed so that under emacs, it just
6530 * IPython/genutils.py (page): Changed so that under emacs, it just
6524 prints the string. You can then page up and down in the emacs
6531 prints the string. You can then page up and down in the emacs
6525 buffer itself. This is how the builtin help() works.
6532 buffer itself. This is how the builtin help() works.
6526
6533
6527 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
6534 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
6528 macro scoping: macros need to be executed in the user's namespace
6535 macro scoping: macros need to be executed in the user's namespace
6529 to work as if they had been typed by the user.
6536 to work as if they had been typed by the user.
6530
6537
6531 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
6538 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
6532 execute automatically (no need to type 'exec...'). They then
6539 execute automatically (no need to type 'exec...'). They then
6533 behave like 'true macros'. The printing system was also modified
6540 behave like 'true macros'. The printing system was also modified
6534 for this to work.
6541 for this to work.
6535
6542
6536 2002-02-19 Fernando Perez <fperez@colorado.edu>
6543 2002-02-19 Fernando Perez <fperez@colorado.edu>
6537
6544
6538 * IPython/genutils.py (page_file): new function for paging files
6545 * IPython/genutils.py (page_file): new function for paging files
6539 in an OS-independent way. Also necessary for file viewing to work
6546 in an OS-independent way. Also necessary for file viewing to work
6540 well inside Emacs buffers.
6547 well inside Emacs buffers.
6541 (page): Added checks for being in an emacs buffer.
6548 (page): Added checks for being in an emacs buffer.
6542 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
6549 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
6543 same bug in iplib.
6550 same bug in iplib.
6544
6551
6545 2002-02-18 Fernando Perez <fperez@colorado.edu>
6552 2002-02-18 Fernando Perez <fperez@colorado.edu>
6546
6553
6547 * IPython/iplib.py (InteractiveShell.init_readline): modified use
6554 * IPython/iplib.py (InteractiveShell.init_readline): modified use
6548 of readline so that IPython can work inside an Emacs buffer.
6555 of readline so that IPython can work inside an Emacs buffer.
6549
6556
6550 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
6557 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
6551 method signatures (they weren't really bugs, but it looks cleaner
6558 method signatures (they weren't really bugs, but it looks cleaner
6552 and keeps PyChecker happy).
6559 and keeps PyChecker happy).
6553
6560
6554 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
6561 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
6555 for implementing various user-defined hooks. Currently only
6562 for implementing various user-defined hooks. Currently only
6556 display is done.
6563 display is done.
6557
6564
6558 * IPython/Prompts.py (CachedOutput._display): changed display
6565 * IPython/Prompts.py (CachedOutput._display): changed display
6559 functions so that they can be dynamically changed by users easily.
6566 functions so that they can be dynamically changed by users easily.
6560
6567
6561 * IPython/Extensions/numeric_formats.py (num_display): added an
6568 * IPython/Extensions/numeric_formats.py (num_display): added an
6562 extension for printing NumPy arrays in flexible manners. It
6569 extension for printing NumPy arrays in flexible manners. It
6563 doesn't do anything yet, but all the structure is in
6570 doesn't do anything yet, but all the structure is in
6564 place. Ultimately the plan is to implement output format control
6571 place. Ultimately the plan is to implement output format control
6565 like in Octave.
6572 like in Octave.
6566
6573
6567 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
6574 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
6568 methods are found at run-time by all the automatic machinery.
6575 methods are found at run-time by all the automatic machinery.
6569
6576
6570 2002-02-17 Fernando Perez <fperez@colorado.edu>
6577 2002-02-17 Fernando Perez <fperez@colorado.edu>
6571
6578
6572 * setup_Windows.py (make_shortcut): documented. Cleaned up the
6579 * setup_Windows.py (make_shortcut): documented. Cleaned up the
6573 whole file a little.
6580 whole file a little.
6574
6581
6575 * ToDo: closed this document. Now there's a new_design.lyx
6582 * ToDo: closed this document. Now there's a new_design.lyx
6576 document for all new ideas. Added making a pdf of it for the
6583 document for all new ideas. Added making a pdf of it for the
6577 end-user distro.
6584 end-user distro.
6578
6585
6579 * IPython/Logger.py (Logger.switch_log): Created this to replace
6586 * IPython/Logger.py (Logger.switch_log): Created this to replace
6580 logon() and logoff(). It also fixes a nasty crash reported by
6587 logon() and logoff(). It also fixes a nasty crash reported by
6581 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
6588 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
6582
6589
6583 * IPython/iplib.py (complete): got auto-completion to work with
6590 * IPython/iplib.py (complete): got auto-completion to work with
6584 automagic (I had wanted this for a long time).
6591 automagic (I had wanted this for a long time).
6585
6592
6586 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
6593 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
6587 to @file, since file() is now a builtin and clashes with automagic
6594 to @file, since file() is now a builtin and clashes with automagic
6588 for @file.
6595 for @file.
6589
6596
6590 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
6597 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
6591 of this was previously in iplib, which had grown to more than 2000
6598 of this was previously in iplib, which had grown to more than 2000
6592 lines, way too long. No new functionality, but it makes managing
6599 lines, way too long. No new functionality, but it makes managing
6593 the code a bit easier.
6600 the code a bit easier.
6594
6601
6595 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
6602 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
6596 information to crash reports.
6603 information to crash reports.
6597
6604
6598 2002-02-12 Fernando Perez <fperez@colorado.edu>
6605 2002-02-12 Fernando Perez <fperez@colorado.edu>
6599
6606
6600 * Released 0.2.5.
6607 * Released 0.2.5.
6601
6608
6602 2002-02-11 Fernando Perez <fperez@colorado.edu>
6609 2002-02-11 Fernando Perez <fperez@colorado.edu>
6603
6610
6604 * Wrote a relatively complete Windows installer. It puts
6611 * Wrote a relatively complete Windows installer. It puts
6605 everything in place, creates Start Menu entries and fixes the
6612 everything in place, creates Start Menu entries and fixes the
6606 color issues. Nothing fancy, but it works.
6613 color issues. Nothing fancy, but it works.
6607
6614
6608 2002-02-10 Fernando Perez <fperez@colorado.edu>
6615 2002-02-10 Fernando Perez <fperez@colorado.edu>
6609
6616
6610 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
6617 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
6611 os.path.expanduser() call so that we can type @run ~/myfile.py and
6618 os.path.expanduser() call so that we can type @run ~/myfile.py and
6612 have thigs work as expected.
6619 have thigs work as expected.
6613
6620
6614 * IPython/genutils.py (page): fixed exception handling so things
6621 * IPython/genutils.py (page): fixed exception handling so things
6615 work both in Unix and Windows correctly. Quitting a pager triggers
6622 work both in Unix and Windows correctly. Quitting a pager triggers
6616 an IOError/broken pipe in Unix, and in windows not finding a pager
6623 an IOError/broken pipe in Unix, and in windows not finding a pager
6617 is also an IOError, so I had to actually look at the return value
6624 is also an IOError, so I had to actually look at the return value
6618 of the exception, not just the exception itself. Should be ok now.
6625 of the exception, not just the exception itself. Should be ok now.
6619
6626
6620 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
6627 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
6621 modified to allow case-insensitive color scheme changes.
6628 modified to allow case-insensitive color scheme changes.
6622
6629
6623 2002-02-09 Fernando Perez <fperez@colorado.edu>
6630 2002-02-09 Fernando Perez <fperez@colorado.edu>
6624
6631
6625 * IPython/genutils.py (native_line_ends): new function to leave
6632 * IPython/genutils.py (native_line_ends): new function to leave
6626 user config files with os-native line-endings.
6633 user config files with os-native line-endings.
6627
6634
6628 * README and manual updates.
6635 * README and manual updates.
6629
6636
6630 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
6637 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
6631 instead of StringType to catch Unicode strings.
6638 instead of StringType to catch Unicode strings.
6632
6639
6633 * IPython/genutils.py (filefind): fixed bug for paths with
6640 * IPython/genutils.py (filefind): fixed bug for paths with
6634 embedded spaces (very common in Windows).
6641 embedded spaces (very common in Windows).
6635
6642
6636 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
6643 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
6637 files under Windows, so that they get automatically associated
6644 files under Windows, so that they get automatically associated
6638 with a text editor. Windows makes it a pain to handle
6645 with a text editor. Windows makes it a pain to handle
6639 extension-less files.
6646 extension-less files.
6640
6647
6641 * IPython/iplib.py (InteractiveShell.init_readline): Made the
6648 * IPython/iplib.py (InteractiveShell.init_readline): Made the
6642 warning about readline only occur for Posix. In Windows there's no
6649 warning about readline only occur for Posix. In Windows there's no
6643 way to get readline, so why bother with the warning.
6650 way to get readline, so why bother with the warning.
6644
6651
6645 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
6652 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
6646 for __str__ instead of dir(self), since dir() changed in 2.2.
6653 for __str__ instead of dir(self), since dir() changed in 2.2.
6647
6654
6648 * Ported to Windows! Tested on XP, I suspect it should work fine
6655 * Ported to Windows! Tested on XP, I suspect it should work fine
6649 on NT/2000, but I don't think it will work on 98 et al. That
6656 on NT/2000, but I don't think it will work on 98 et al. That
6650 series of Windows is such a piece of junk anyway that I won't try
6657 series of Windows is such a piece of junk anyway that I won't try
6651 porting it there. The XP port was straightforward, showed a few
6658 porting it there. The XP port was straightforward, showed a few
6652 bugs here and there (fixed all), in particular some string
6659 bugs here and there (fixed all), in particular some string
6653 handling stuff which required considering Unicode strings (which
6660 handling stuff which required considering Unicode strings (which
6654 Windows uses). This is good, but hasn't been too tested :) No
6661 Windows uses). This is good, but hasn't been too tested :) No
6655 fancy installer yet, I'll put a note in the manual so people at
6662 fancy installer yet, I'll put a note in the manual so people at
6656 least make manually a shortcut.
6663 least make manually a shortcut.
6657
6664
6658 * IPython/iplib.py (Magic.magic_colors): Unified the color options
6665 * IPython/iplib.py (Magic.magic_colors): Unified the color options
6659 into a single one, "colors". This now controls both prompt and
6666 into a single one, "colors". This now controls both prompt and
6660 exception color schemes, and can be changed both at startup
6667 exception color schemes, and can be changed both at startup
6661 (either via command-line switches or via ipythonrc files) and at
6668 (either via command-line switches or via ipythonrc files) and at
6662 runtime, with @colors.
6669 runtime, with @colors.
6663 (Magic.magic_run): renamed @prun to @run and removed the old
6670 (Magic.magic_run): renamed @prun to @run and removed the old
6664 @run. The two were too similar to warrant keeping both.
6671 @run. The two were too similar to warrant keeping both.
6665
6672
6666 2002-02-03 Fernando Perez <fperez@colorado.edu>
6673 2002-02-03 Fernando Perez <fperez@colorado.edu>
6667
6674
6668 * IPython/iplib.py (install_first_time): Added comment on how to
6675 * IPython/iplib.py (install_first_time): Added comment on how to
6669 configure the color options for first-time users. Put a <return>
6676 configure the color options for first-time users. Put a <return>
6670 request at the end so that small-terminal users get a chance to
6677 request at the end so that small-terminal users get a chance to
6671 read the startup info.
6678 read the startup info.
6672
6679
6673 2002-01-23 Fernando Perez <fperez@colorado.edu>
6680 2002-01-23 Fernando Perez <fperez@colorado.edu>
6674
6681
6675 * IPython/iplib.py (CachedOutput.update): Changed output memory
6682 * IPython/iplib.py (CachedOutput.update): Changed output memory
6676 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
6683 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
6677 input history we still use _i. Did this b/c these variable are
6684 input history we still use _i. Did this b/c these variable are
6678 very commonly used in interactive work, so the less we need to
6685 very commonly used in interactive work, so the less we need to
6679 type the better off we are.
6686 type the better off we are.
6680 (Magic.magic_prun): updated @prun to better handle the namespaces
6687 (Magic.magic_prun): updated @prun to better handle the namespaces
6681 the file will run in, including a fix for __name__ not being set
6688 the file will run in, including a fix for __name__ not being set
6682 before.
6689 before.
6683
6690
6684 2002-01-20 Fernando Perez <fperez@colorado.edu>
6691 2002-01-20 Fernando Perez <fperez@colorado.edu>
6685
6692
6686 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
6693 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
6687 extra garbage for Python 2.2. Need to look more carefully into
6694 extra garbage for Python 2.2. Need to look more carefully into
6688 this later.
6695 this later.
6689
6696
6690 2002-01-19 Fernando Perez <fperez@colorado.edu>
6697 2002-01-19 Fernando Perez <fperez@colorado.edu>
6691
6698
6692 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
6699 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
6693 display SyntaxError exceptions properly formatted when they occur
6700 display SyntaxError exceptions properly formatted when they occur
6694 (they can be triggered by imported code).
6701 (they can be triggered by imported code).
6695
6702
6696 2002-01-18 Fernando Perez <fperez@colorado.edu>
6703 2002-01-18 Fernando Perez <fperez@colorado.edu>
6697
6704
6698 * IPython/iplib.py (InteractiveShell.safe_execfile): now
6705 * IPython/iplib.py (InteractiveShell.safe_execfile): now
6699 SyntaxError exceptions are reported nicely formatted, instead of
6706 SyntaxError exceptions are reported nicely formatted, instead of
6700 spitting out only offset information as before.
6707 spitting out only offset information as before.
6701 (Magic.magic_prun): Added the @prun function for executing
6708 (Magic.magic_prun): Added the @prun function for executing
6702 programs with command line args inside IPython.
6709 programs with command line args inside IPython.
6703
6710
6704 2002-01-16 Fernando Perez <fperez@colorado.edu>
6711 2002-01-16 Fernando Perez <fperez@colorado.edu>
6705
6712
6706 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
6713 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
6707 to *not* include the last item given in a range. This brings their
6714 to *not* include the last item given in a range. This brings their
6708 behavior in line with Python's slicing:
6715 behavior in line with Python's slicing:
6709 a[n1:n2] -> a[n1]...a[n2-1]
6716 a[n1:n2] -> a[n1]...a[n2-1]
6710 It may be a bit less convenient, but I prefer to stick to Python's
6717 It may be a bit less convenient, but I prefer to stick to Python's
6711 conventions *everywhere*, so users never have to wonder.
6718 conventions *everywhere*, so users never have to wonder.
6712 (Magic.magic_macro): Added @macro function to ease the creation of
6719 (Magic.magic_macro): Added @macro function to ease the creation of
6713 macros.
6720 macros.
6714
6721
6715 2002-01-05 Fernando Perez <fperez@colorado.edu>
6722 2002-01-05 Fernando Perez <fperez@colorado.edu>
6716
6723
6717 * Released 0.2.4.
6724 * Released 0.2.4.
6718
6725
6719 * IPython/iplib.py (Magic.magic_pdef):
6726 * IPython/iplib.py (Magic.magic_pdef):
6720 (InteractiveShell.safe_execfile): report magic lines and error
6727 (InteractiveShell.safe_execfile): report magic lines and error
6721 lines without line numbers so one can easily copy/paste them for
6728 lines without line numbers so one can easily copy/paste them for
6722 re-execution.
6729 re-execution.
6723
6730
6724 * Updated manual with recent changes.
6731 * Updated manual with recent changes.
6725
6732
6726 * IPython/iplib.py (Magic.magic_oinfo): added constructor
6733 * IPython/iplib.py (Magic.magic_oinfo): added constructor
6727 docstring printing when class? is called. Very handy for knowing
6734 docstring printing when class? is called. Very handy for knowing
6728 how to create class instances (as long as __init__ is well
6735 how to create class instances (as long as __init__ is well
6729 documented, of course :)
6736 documented, of course :)
6730 (Magic.magic_doc): print both class and constructor docstrings.
6737 (Magic.magic_doc): print both class and constructor docstrings.
6731 (Magic.magic_pdef): give constructor info if passed a class and
6738 (Magic.magic_pdef): give constructor info if passed a class and
6732 __call__ info for callable object instances.
6739 __call__ info for callable object instances.
6733
6740
6734 2002-01-04 Fernando Perez <fperez@colorado.edu>
6741 2002-01-04 Fernando Perez <fperez@colorado.edu>
6735
6742
6736 * Made deep_reload() off by default. It doesn't always work
6743 * Made deep_reload() off by default. It doesn't always work
6737 exactly as intended, so it's probably safer to have it off. It's
6744 exactly as intended, so it's probably safer to have it off. It's
6738 still available as dreload() anyway, so nothing is lost.
6745 still available as dreload() anyway, so nothing is lost.
6739
6746
6740 2002-01-02 Fernando Perez <fperez@colorado.edu>
6747 2002-01-02 Fernando Perez <fperez@colorado.edu>
6741
6748
6742 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
6749 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
6743 so I wanted an updated release).
6750 so I wanted an updated release).
6744
6751
6745 2001-12-27 Fernando Perez <fperez@colorado.edu>
6752 2001-12-27 Fernando Perez <fperez@colorado.edu>
6746
6753
6747 * IPython/iplib.py (InteractiveShell.interact): Added the original
6754 * IPython/iplib.py (InteractiveShell.interact): Added the original
6748 code from 'code.py' for this module in order to change the
6755 code from 'code.py' for this module in order to change the
6749 handling of a KeyboardInterrupt. This was necessary b/c otherwise
6756 handling of a KeyboardInterrupt. This was necessary b/c otherwise
6750 the history cache would break when the user hit Ctrl-C, and
6757 the history cache would break when the user hit Ctrl-C, and
6751 interact() offers no way to add any hooks to it.
6758 interact() offers no way to add any hooks to it.
6752
6759
6753 2001-12-23 Fernando Perez <fperez@colorado.edu>
6760 2001-12-23 Fernando Perez <fperez@colorado.edu>
6754
6761
6755 * setup.py: added check for 'MANIFEST' before trying to remove
6762 * setup.py: added check for 'MANIFEST' before trying to remove
6756 it. Thanks to Sean Reifschneider.
6763 it. Thanks to Sean Reifschneider.
6757
6764
6758 2001-12-22 Fernando Perez <fperez@colorado.edu>
6765 2001-12-22 Fernando Perez <fperez@colorado.edu>
6759
6766
6760 * Released 0.2.2.
6767 * Released 0.2.2.
6761
6768
6762 * Finished (reasonably) writing the manual. Later will add the
6769 * Finished (reasonably) writing the manual. Later will add the
6763 python-standard navigation stylesheets, but for the time being
6770 python-standard navigation stylesheets, but for the time being
6764 it's fairly complete. Distribution will include html and pdf
6771 it's fairly complete. Distribution will include html and pdf
6765 versions.
6772 versions.
6766
6773
6767 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
6774 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
6768 (MayaVi author).
6775 (MayaVi author).
6769
6776
6770 2001-12-21 Fernando Perez <fperez@colorado.edu>
6777 2001-12-21 Fernando Perez <fperez@colorado.edu>
6771
6778
6772 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
6779 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
6773 good public release, I think (with the manual and the distutils
6780 good public release, I think (with the manual and the distutils
6774 installer). The manual can use some work, but that can go
6781 installer). The manual can use some work, but that can go
6775 slowly. Otherwise I think it's quite nice for end users. Next
6782 slowly. Otherwise I think it's quite nice for end users. Next
6776 summer, rewrite the guts of it...
6783 summer, rewrite the guts of it...
6777
6784
6778 * Changed format of ipythonrc files to use whitespace as the
6785 * Changed format of ipythonrc files to use whitespace as the
6779 separator instead of an explicit '='. Cleaner.
6786 separator instead of an explicit '='. Cleaner.
6780
6787
6781 2001-12-20 Fernando Perez <fperez@colorado.edu>
6788 2001-12-20 Fernando Perez <fperez@colorado.edu>
6782
6789
6783 * Started a manual in LyX. For now it's just a quick merge of the
6790 * Started a manual in LyX. For now it's just a quick merge of the
6784 various internal docstrings and READMEs. Later it may grow into a
6791 various internal docstrings and READMEs. Later it may grow into a
6785 nice, full-blown manual.
6792 nice, full-blown manual.
6786
6793
6787 * Set up a distutils based installer. Installation should now be
6794 * Set up a distutils based installer. Installation should now be
6788 trivially simple for end-users.
6795 trivially simple for end-users.
6789
6796
6790 2001-12-11 Fernando Perez <fperez@colorado.edu>
6797 2001-12-11 Fernando Perez <fperez@colorado.edu>
6791
6798
6792 * Released 0.2.0. First public release, announced it at
6799 * Released 0.2.0. First public release, announced it at
6793 comp.lang.python. From now on, just bugfixes...
6800 comp.lang.python. From now on, just bugfixes...
6794
6801
6795 * Went through all the files, set copyright/license notices and
6802 * Went through all the files, set copyright/license notices and
6796 cleaned up things. Ready for release.
6803 cleaned up things. Ready for release.
6797
6804
6798 2001-12-10 Fernando Perez <fperez@colorado.edu>
6805 2001-12-10 Fernando Perez <fperez@colorado.edu>
6799
6806
6800 * Changed the first-time installer not to use tarfiles. It's more
6807 * Changed the first-time installer not to use tarfiles. It's more
6801 robust now and less unix-dependent. Also makes it easier for
6808 robust now and less unix-dependent. Also makes it easier for
6802 people to later upgrade versions.
6809 people to later upgrade versions.
6803
6810
6804 * Changed @exit to @abort to reflect the fact that it's pretty
6811 * Changed @exit to @abort to reflect the fact that it's pretty
6805 brutal (a sys.exit()). The difference between @abort and Ctrl-D
6812 brutal (a sys.exit()). The difference between @abort and Ctrl-D
6806 becomes significant only when IPyhton is embedded: in that case,
6813 becomes significant only when IPyhton is embedded: in that case,
6807 C-D closes IPython only, but @abort kills the enclosing program
6814 C-D closes IPython only, but @abort kills the enclosing program
6808 too (unless it had called IPython inside a try catching
6815 too (unless it had called IPython inside a try catching
6809 SystemExit).
6816 SystemExit).
6810
6817
6811 * Created Shell module which exposes the actuall IPython Shell
6818 * Created Shell module which exposes the actuall IPython Shell
6812 classes, currently the normal and the embeddable one. This at
6819 classes, currently the normal and the embeddable one. This at
6813 least offers a stable interface we won't need to change when
6820 least offers a stable interface we won't need to change when
6814 (later) the internals are rewritten. That rewrite will be confined
6821 (later) the internals are rewritten. That rewrite will be confined
6815 to iplib and ipmaker, but the Shell interface should remain as is.
6822 to iplib and ipmaker, but the Shell interface should remain as is.
6816
6823
6817 * Added embed module which offers an embeddable IPShell object,
6824 * Added embed module which offers an embeddable IPShell object,
6818 useful to fire up IPython *inside* a running program. Great for
6825 useful to fire up IPython *inside* a running program. Great for
6819 debugging or dynamical data analysis.
6826 debugging or dynamical data analysis.
6820
6827
6821 2001-12-08 Fernando Perez <fperez@colorado.edu>
6828 2001-12-08 Fernando Perez <fperez@colorado.edu>
6822
6829
6823 * Fixed small bug preventing seeing info from methods of defined
6830 * Fixed small bug preventing seeing info from methods of defined
6824 objects (incorrect namespace in _ofind()).
6831 objects (incorrect namespace in _ofind()).
6825
6832
6826 * Documentation cleanup. Moved the main usage docstrings to a
6833 * Documentation cleanup. Moved the main usage docstrings to a
6827 separate file, usage.py (cleaner to maintain, and hopefully in the
6834 separate file, usage.py (cleaner to maintain, and hopefully in the
6828 future some perlpod-like way of producing interactive, man and
6835 future some perlpod-like way of producing interactive, man and
6829 html docs out of it will be found).
6836 html docs out of it will be found).
6830
6837
6831 * Added @profile to see your profile at any time.
6838 * Added @profile to see your profile at any time.
6832
6839
6833 * Added @p as an alias for 'print'. It's especially convenient if
6840 * Added @p as an alias for 'print'. It's especially convenient if
6834 using automagic ('p x' prints x).
6841 using automagic ('p x' prints x).
6835
6842
6836 * Small cleanups and fixes after a pychecker run.
6843 * Small cleanups and fixes after a pychecker run.
6837
6844
6838 * Changed the @cd command to handle @cd - and @cd -<n> for
6845 * Changed the @cd command to handle @cd - and @cd -<n> for
6839 visiting any directory in _dh.
6846 visiting any directory in _dh.
6840
6847
6841 * Introduced _dh, a history of visited directories. @dhist prints
6848 * Introduced _dh, a history of visited directories. @dhist prints
6842 it out with numbers.
6849 it out with numbers.
6843
6850
6844 2001-12-07 Fernando Perez <fperez@colorado.edu>
6851 2001-12-07 Fernando Perez <fperez@colorado.edu>
6845
6852
6846 * Released 0.1.22
6853 * Released 0.1.22
6847
6854
6848 * Made initialization a bit more robust against invalid color
6855 * Made initialization a bit more robust against invalid color
6849 options in user input (exit, not traceback-crash).
6856 options in user input (exit, not traceback-crash).
6850
6857
6851 * Changed the bug crash reporter to write the report only in the
6858 * Changed the bug crash reporter to write the report only in the
6852 user's .ipython directory. That way IPython won't litter people's
6859 user's .ipython directory. That way IPython won't litter people's
6853 hard disks with crash files all over the place. Also print on
6860 hard disks with crash files all over the place. Also print on
6854 screen the necessary mail command.
6861 screen the necessary mail command.
6855
6862
6856 * With the new ultraTB, implemented LightBG color scheme for light
6863 * With the new ultraTB, implemented LightBG color scheme for light
6857 background terminals. A lot of people like white backgrounds, so I
6864 background terminals. A lot of people like white backgrounds, so I
6858 guess we should at least give them something readable.
6865 guess we should at least give them something readable.
6859
6866
6860 2001-12-06 Fernando Perez <fperez@colorado.edu>
6867 2001-12-06 Fernando Perez <fperez@colorado.edu>
6861
6868
6862 * Modified the structure of ultraTB. Now there's a proper class
6869 * Modified the structure of ultraTB. Now there's a proper class
6863 for tables of color schemes which allow adding schemes easily and
6870 for tables of color schemes which allow adding schemes easily and
6864 switching the active scheme without creating a new instance every
6871 switching the active scheme without creating a new instance every
6865 time (which was ridiculous). The syntax for creating new schemes
6872 time (which was ridiculous). The syntax for creating new schemes
6866 is also cleaner. I think ultraTB is finally done, with a clean
6873 is also cleaner. I think ultraTB is finally done, with a clean
6867 class structure. Names are also much cleaner (now there's proper
6874 class structure. Names are also much cleaner (now there's proper
6868 color tables, no need for every variable to also have 'color' in
6875 color tables, no need for every variable to also have 'color' in
6869 its name).
6876 its name).
6870
6877
6871 * Broke down genutils into separate files. Now genutils only
6878 * Broke down genutils into separate files. Now genutils only
6872 contains utility functions, and classes have been moved to their
6879 contains utility functions, and classes have been moved to their
6873 own files (they had enough independent functionality to warrant
6880 own files (they had enough independent functionality to warrant
6874 it): ConfigLoader, OutputTrap, Struct.
6881 it): ConfigLoader, OutputTrap, Struct.
6875
6882
6876 2001-12-05 Fernando Perez <fperez@colorado.edu>
6883 2001-12-05 Fernando Perez <fperez@colorado.edu>
6877
6884
6878 * IPython turns 21! Released version 0.1.21, as a candidate for
6885 * IPython turns 21! Released version 0.1.21, as a candidate for
6879 public consumption. If all goes well, release in a few days.
6886 public consumption. If all goes well, release in a few days.
6880
6887
6881 * Fixed path bug (files in Extensions/ directory wouldn't be found
6888 * Fixed path bug (files in Extensions/ directory wouldn't be found
6882 unless IPython/ was explicitly in sys.path).
6889 unless IPython/ was explicitly in sys.path).
6883
6890
6884 * Extended the FlexCompleter class as MagicCompleter to allow
6891 * Extended the FlexCompleter class as MagicCompleter to allow
6885 completion of @-starting lines.
6892 completion of @-starting lines.
6886
6893
6887 * Created __release__.py file as a central repository for release
6894 * Created __release__.py file as a central repository for release
6888 info that other files can read from.
6895 info that other files can read from.
6889
6896
6890 * Fixed small bug in logging: when logging was turned on in
6897 * Fixed small bug in logging: when logging was turned on in
6891 mid-session, old lines with special meanings (!@?) were being
6898 mid-session, old lines with special meanings (!@?) were being
6892 logged without the prepended comment, which is necessary since
6899 logged without the prepended comment, which is necessary since
6893 they are not truly valid python syntax. This should make session
6900 they are not truly valid python syntax. This should make session
6894 restores produce less errors.
6901 restores produce less errors.
6895
6902
6896 * The namespace cleanup forced me to make a FlexCompleter class
6903 * The namespace cleanup forced me to make a FlexCompleter class
6897 which is nothing but a ripoff of rlcompleter, but with selectable
6904 which is nothing but a ripoff of rlcompleter, but with selectable
6898 namespace (rlcompleter only works in __main__.__dict__). I'll try
6905 namespace (rlcompleter only works in __main__.__dict__). I'll try
6899 to submit a note to the authors to see if this change can be
6906 to submit a note to the authors to see if this change can be
6900 incorporated in future rlcompleter releases (Dec.6: done)
6907 incorporated in future rlcompleter releases (Dec.6: done)
6901
6908
6902 * More fixes to namespace handling. It was a mess! Now all
6909 * More fixes to namespace handling. It was a mess! Now all
6903 explicit references to __main__.__dict__ are gone (except when
6910 explicit references to __main__.__dict__ are gone (except when
6904 really needed) and everything is handled through the namespace
6911 really needed) and everything is handled through the namespace
6905 dicts in the IPython instance. We seem to be getting somewhere
6912 dicts in the IPython instance. We seem to be getting somewhere
6906 with this, finally...
6913 with this, finally...
6907
6914
6908 * Small documentation updates.
6915 * Small documentation updates.
6909
6916
6910 * Created the Extensions directory under IPython (with an
6917 * Created the Extensions directory under IPython (with an
6911 __init__.py). Put the PhysicalQ stuff there. This directory should
6918 __init__.py). Put the PhysicalQ stuff there. This directory should
6912 be used for all special-purpose extensions.
6919 be used for all special-purpose extensions.
6913
6920
6914 * File renaming:
6921 * File renaming:
6915 ipythonlib --> ipmaker
6922 ipythonlib --> ipmaker
6916 ipplib --> iplib
6923 ipplib --> iplib
6917 This makes a bit more sense in terms of what these files actually do.
6924 This makes a bit more sense in terms of what these files actually do.
6918
6925
6919 * Moved all the classes and functions in ipythonlib to ipplib, so
6926 * Moved all the classes and functions in ipythonlib to ipplib, so
6920 now ipythonlib only has make_IPython(). This will ease up its
6927 now ipythonlib only has make_IPython(). This will ease up its
6921 splitting in smaller functional chunks later.
6928 splitting in smaller functional chunks later.
6922
6929
6923 * Cleaned up (done, I think) output of @whos. Better column
6930 * Cleaned up (done, I think) output of @whos. Better column
6924 formatting, and now shows str(var) for as much as it can, which is
6931 formatting, and now shows str(var) for as much as it can, which is
6925 typically what one gets with a 'print var'.
6932 typically what one gets with a 'print var'.
6926
6933
6927 2001-12-04 Fernando Perez <fperez@colorado.edu>
6934 2001-12-04 Fernando Perez <fperez@colorado.edu>
6928
6935
6929 * Fixed namespace problems. Now builtin/IPyhton/user names get
6936 * Fixed namespace problems. Now builtin/IPyhton/user names get
6930 properly reported in their namespace. Internal namespace handling
6937 properly reported in their namespace. Internal namespace handling
6931 is finally getting decent (not perfect yet, but much better than
6938 is finally getting decent (not perfect yet, but much better than
6932 the ad-hoc mess we had).
6939 the ad-hoc mess we had).
6933
6940
6934 * Removed -exit option. If people just want to run a python
6941 * Removed -exit option. If people just want to run a python
6935 script, that's what the normal interpreter is for. Less
6942 script, that's what the normal interpreter is for. Less
6936 unnecessary options, less chances for bugs.
6943 unnecessary options, less chances for bugs.
6937
6944
6938 * Added a crash handler which generates a complete post-mortem if
6945 * Added a crash handler which generates a complete post-mortem if
6939 IPython crashes. This will help a lot in tracking bugs down the
6946 IPython crashes. This will help a lot in tracking bugs down the
6940 road.
6947 road.
6941
6948
6942 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
6949 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
6943 which were boud to functions being reassigned would bypass the
6950 which were boud to functions being reassigned would bypass the
6944 logger, breaking the sync of _il with the prompt counter. This
6951 logger, breaking the sync of _il with the prompt counter. This
6945 would then crash IPython later when a new line was logged.
6952 would then crash IPython later when a new line was logged.
6946
6953
6947 2001-12-02 Fernando Perez <fperez@colorado.edu>
6954 2001-12-02 Fernando Perez <fperez@colorado.edu>
6948
6955
6949 * Made IPython a package. This means people don't have to clutter
6956 * Made IPython a package. This means people don't have to clutter
6950 their sys.path with yet another directory. Changed the INSTALL
6957 their sys.path with yet another directory. Changed the INSTALL
6951 file accordingly.
6958 file accordingly.
6952
6959
6953 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
6960 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
6954 sorts its output (so @who shows it sorted) and @whos formats the
6961 sorts its output (so @who shows it sorted) and @whos formats the
6955 table according to the width of the first column. Nicer, easier to
6962 table according to the width of the first column. Nicer, easier to
6956 read. Todo: write a generic table_format() which takes a list of
6963 read. Todo: write a generic table_format() which takes a list of
6957 lists and prints it nicely formatted, with optional row/column
6964 lists and prints it nicely formatted, with optional row/column
6958 separators and proper padding and justification.
6965 separators and proper padding and justification.
6959
6966
6960 * Released 0.1.20
6967 * Released 0.1.20
6961
6968
6962 * Fixed bug in @log which would reverse the inputcache list (a
6969 * Fixed bug in @log which would reverse the inputcache list (a
6963 copy operation was missing).
6970 copy operation was missing).
6964
6971
6965 * Code cleanup. @config was changed to use page(). Better, since
6972 * Code cleanup. @config was changed to use page(). Better, since
6966 its output is always quite long.
6973 its output is always quite long.
6967
6974
6968 * Itpl is back as a dependency. I was having too many problems
6975 * Itpl is back as a dependency. I was having too many problems
6969 getting the parametric aliases to work reliably, and it's just
6976 getting the parametric aliases to work reliably, and it's just
6970 easier to code weird string operations with it than playing %()s
6977 easier to code weird string operations with it than playing %()s
6971 games. It's only ~6k, so I don't think it's too big a deal.
6978 games. It's only ~6k, so I don't think it's too big a deal.
6972
6979
6973 * Found (and fixed) a very nasty bug with history. !lines weren't
6980 * Found (and fixed) a very nasty bug with history. !lines weren't
6974 getting cached, and the out of sync caches would crash
6981 getting cached, and the out of sync caches would crash
6975 IPython. Fixed it by reorganizing the prefilter/handlers/logger
6982 IPython. Fixed it by reorganizing the prefilter/handlers/logger
6976 division of labor a bit better. Bug fixed, cleaner structure.
6983 division of labor a bit better. Bug fixed, cleaner structure.
6977
6984
6978 2001-12-01 Fernando Perez <fperez@colorado.edu>
6985 2001-12-01 Fernando Perez <fperez@colorado.edu>
6979
6986
6980 * Released 0.1.19
6987 * Released 0.1.19
6981
6988
6982 * Added option -n to @hist to prevent line number printing. Much
6989 * Added option -n to @hist to prevent line number printing. Much
6983 easier to copy/paste code this way.
6990 easier to copy/paste code this way.
6984
6991
6985 * Created global _il to hold the input list. Allows easy
6992 * Created global _il to hold the input list. Allows easy
6986 re-execution of blocks of code by slicing it (inspired by Janko's
6993 re-execution of blocks of code by slicing it (inspired by Janko's
6987 comment on 'macros').
6994 comment on 'macros').
6988
6995
6989 * Small fixes and doc updates.
6996 * Small fixes and doc updates.
6990
6997
6991 * Rewrote @history function (was @h). Renamed it to @hist, @h is
6998 * Rewrote @history function (was @h). Renamed it to @hist, @h is
6992 much too fragile with automagic. Handles properly multi-line
6999 much too fragile with automagic. Handles properly multi-line
6993 statements and takes parameters.
7000 statements and takes parameters.
6994
7001
6995 2001-11-30 Fernando Perez <fperez@colorado.edu>
7002 2001-11-30 Fernando Perez <fperez@colorado.edu>
6996
7003
6997 * Version 0.1.18 released.
7004 * Version 0.1.18 released.
6998
7005
6999 * Fixed nasty namespace bug in initial module imports.
7006 * Fixed nasty namespace bug in initial module imports.
7000
7007
7001 * Added copyright/license notes to all code files (except
7008 * Added copyright/license notes to all code files (except
7002 DPyGetOpt). For the time being, LGPL. That could change.
7009 DPyGetOpt). For the time being, LGPL. That could change.
7003
7010
7004 * Rewrote a much nicer README, updated INSTALL, cleaned up
7011 * Rewrote a much nicer README, updated INSTALL, cleaned up
7005 ipythonrc-* samples.
7012 ipythonrc-* samples.
7006
7013
7007 * Overall code/documentation cleanup. Basically ready for
7014 * Overall code/documentation cleanup. Basically ready for
7008 release. Only remaining thing: licence decision (LGPL?).
7015 release. Only remaining thing: licence decision (LGPL?).
7009
7016
7010 * Converted load_config to a class, ConfigLoader. Now recursion
7017 * Converted load_config to a class, ConfigLoader. Now recursion
7011 control is better organized. Doesn't include the same file twice.
7018 control is better organized. Doesn't include the same file twice.
7012
7019
7013 2001-11-29 Fernando Perez <fperez@colorado.edu>
7020 2001-11-29 Fernando Perez <fperez@colorado.edu>
7014
7021
7015 * Got input history working. Changed output history variables from
7022 * Got input history working. Changed output history variables from
7016 _p to _o so that _i is for input and _o for output. Just cleaner
7023 _p to _o so that _i is for input and _o for output. Just cleaner
7017 convention.
7024 convention.
7018
7025
7019 * Implemented parametric aliases. This pretty much allows the
7026 * Implemented parametric aliases. This pretty much allows the
7020 alias system to offer full-blown shell convenience, I think.
7027 alias system to offer full-blown shell convenience, I think.
7021
7028
7022 * Version 0.1.17 released, 0.1.18 opened.
7029 * Version 0.1.17 released, 0.1.18 opened.
7023
7030
7024 * dot_ipython/ipythonrc (alias): added documentation.
7031 * dot_ipython/ipythonrc (alias): added documentation.
7025 (xcolor): Fixed small bug (xcolors -> xcolor)
7032 (xcolor): Fixed small bug (xcolors -> xcolor)
7026
7033
7027 * Changed the alias system. Now alias is a magic command to define
7034 * Changed the alias system. Now alias is a magic command to define
7028 aliases just like the shell. Rationale: the builtin magics should
7035 aliases just like the shell. Rationale: the builtin magics should
7029 be there for things deeply connected to IPython's
7036 be there for things deeply connected to IPython's
7030 architecture. And this is a much lighter system for what I think
7037 architecture. And this is a much lighter system for what I think
7031 is the really important feature: allowing users to define quickly
7038 is the really important feature: allowing users to define quickly
7032 magics that will do shell things for them, so they can customize
7039 magics that will do shell things for them, so they can customize
7033 IPython easily to match their work habits. If someone is really
7040 IPython easily to match their work habits. If someone is really
7034 desperate to have another name for a builtin alias, they can
7041 desperate to have another name for a builtin alias, they can
7035 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
7042 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
7036 works.
7043 works.
7037
7044
7038 2001-11-28 Fernando Perez <fperez@colorado.edu>
7045 2001-11-28 Fernando Perez <fperez@colorado.edu>
7039
7046
7040 * Changed @file so that it opens the source file at the proper
7047 * Changed @file so that it opens the source file at the proper
7041 line. Since it uses less, if your EDITOR environment is
7048 line. Since it uses less, if your EDITOR environment is
7042 configured, typing v will immediately open your editor of choice
7049 configured, typing v will immediately open your editor of choice
7043 right at the line where the object is defined. Not as quick as
7050 right at the line where the object is defined. Not as quick as
7044 having a direct @edit command, but for all intents and purposes it
7051 having a direct @edit command, but for all intents and purposes it
7045 works. And I don't have to worry about writing @edit to deal with
7052 works. And I don't have to worry about writing @edit to deal with
7046 all the editors, less does that.
7053 all the editors, less does that.
7047
7054
7048 * Version 0.1.16 released, 0.1.17 opened.
7055 * Version 0.1.16 released, 0.1.17 opened.
7049
7056
7050 * Fixed some nasty bugs in the page/page_dumb combo that could
7057 * Fixed some nasty bugs in the page/page_dumb combo that could
7051 crash IPython.
7058 crash IPython.
7052
7059
7053 2001-11-27 Fernando Perez <fperez@colorado.edu>
7060 2001-11-27 Fernando Perez <fperez@colorado.edu>
7054
7061
7055 * Version 0.1.15 released, 0.1.16 opened.
7062 * Version 0.1.15 released, 0.1.16 opened.
7056
7063
7057 * Finally got ? and ?? to work for undefined things: now it's
7064 * Finally got ? and ?? to work for undefined things: now it's
7058 possible to type {}.get? and get information about the get method
7065 possible to type {}.get? and get information about the get method
7059 of dicts, or os.path? even if only os is defined (so technically
7066 of dicts, or os.path? even if only os is defined (so technically
7060 os.path isn't). Works at any level. For example, after import os,
7067 os.path isn't). Works at any level. For example, after import os,
7061 os?, os.path?, os.path.abspath? all work. This is great, took some
7068 os?, os.path?, os.path.abspath? all work. This is great, took some
7062 work in _ofind.
7069 work in _ofind.
7063
7070
7064 * Fixed more bugs with logging. The sanest way to do it was to add
7071 * Fixed more bugs with logging. The sanest way to do it was to add
7065 to @log a 'mode' parameter. Killed two in one shot (this mode
7072 to @log a 'mode' parameter. Killed two in one shot (this mode
7066 option was a request of Janko's). I think it's finally clean
7073 option was a request of Janko's). I think it's finally clean
7067 (famous last words).
7074 (famous last words).
7068
7075
7069 * Added a page_dumb() pager which does a decent job of paging on
7076 * Added a page_dumb() pager which does a decent job of paging on
7070 screen, if better things (like less) aren't available. One less
7077 screen, if better things (like less) aren't available. One less
7071 unix dependency (someday maybe somebody will port this to
7078 unix dependency (someday maybe somebody will port this to
7072 windows).
7079 windows).
7073
7080
7074 * Fixed problem in magic_log: would lock of logging out if log
7081 * Fixed problem in magic_log: would lock of logging out if log
7075 creation failed (because it would still think it had succeeded).
7082 creation failed (because it would still think it had succeeded).
7076
7083
7077 * Improved the page() function using curses to auto-detect screen
7084 * Improved the page() function using curses to auto-detect screen
7078 size. Now it can make a much better decision on whether to print
7085 size. Now it can make a much better decision on whether to print
7079 or page a string. Option screen_length was modified: a value 0
7086 or page a string. Option screen_length was modified: a value 0
7080 means auto-detect, and that's the default now.
7087 means auto-detect, and that's the default now.
7081
7088
7082 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
7089 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
7083 go out. I'll test it for a few days, then talk to Janko about
7090 go out. I'll test it for a few days, then talk to Janko about
7084 licences and announce it.
7091 licences and announce it.
7085
7092
7086 * Fixed the length of the auto-generated ---> prompt which appears
7093 * Fixed the length of the auto-generated ---> prompt which appears
7087 for auto-parens and auto-quotes. Getting this right isn't trivial,
7094 for auto-parens and auto-quotes. Getting this right isn't trivial,
7088 with all the color escapes, different prompt types and optional
7095 with all the color escapes, different prompt types and optional
7089 separators. But it seems to be working in all the combinations.
7096 separators. But it seems to be working in all the combinations.
7090
7097
7091 2001-11-26 Fernando Perez <fperez@colorado.edu>
7098 2001-11-26 Fernando Perez <fperez@colorado.edu>
7092
7099
7093 * Wrote a regexp filter to get option types from the option names
7100 * Wrote a regexp filter to get option types from the option names
7094 string. This eliminates the need to manually keep two duplicate
7101 string. This eliminates the need to manually keep two duplicate
7095 lists.
7102 lists.
7096
7103
7097 * Removed the unneeded check_option_names. Now options are handled
7104 * Removed the unneeded check_option_names. Now options are handled
7098 in a much saner manner and it's easy to visually check that things
7105 in a much saner manner and it's easy to visually check that things
7099 are ok.
7106 are ok.
7100
7107
7101 * Updated version numbers on all files I modified to carry a
7108 * Updated version numbers on all files I modified to carry a
7102 notice so Janko and Nathan have clear version markers.
7109 notice so Janko and Nathan have clear version markers.
7103
7110
7104 * Updated docstring for ultraTB with my changes. I should send
7111 * Updated docstring for ultraTB with my changes. I should send
7105 this to Nathan.
7112 this to Nathan.
7106
7113
7107 * Lots of small fixes. Ran everything through pychecker again.
7114 * Lots of small fixes. Ran everything through pychecker again.
7108
7115
7109 * Made loading of deep_reload an cmd line option. If it's not too
7116 * Made loading of deep_reload an cmd line option. If it's not too
7110 kosher, now people can just disable it. With -nodeep_reload it's
7117 kosher, now people can just disable it. With -nodeep_reload it's
7111 still available as dreload(), it just won't overwrite reload().
7118 still available as dreload(), it just won't overwrite reload().
7112
7119
7113 * Moved many options to the no| form (-opt and -noopt
7120 * Moved many options to the no| form (-opt and -noopt
7114 accepted). Cleaner.
7121 accepted). Cleaner.
7115
7122
7116 * Changed magic_log so that if called with no parameters, it uses
7123 * Changed magic_log so that if called with no parameters, it uses
7117 'rotate' mode. That way auto-generated logs aren't automatically
7124 'rotate' mode. That way auto-generated logs aren't automatically
7118 over-written. For normal logs, now a backup is made if it exists
7125 over-written. For normal logs, now a backup is made if it exists
7119 (only 1 level of backups). A new 'backup' mode was added to the
7126 (only 1 level of backups). A new 'backup' mode was added to the
7120 Logger class to support this. This was a request by Janko.
7127 Logger class to support this. This was a request by Janko.
7121
7128
7122 * Added @logoff/@logon to stop/restart an active log.
7129 * Added @logoff/@logon to stop/restart an active log.
7123
7130
7124 * Fixed a lot of bugs in log saving/replay. It was pretty
7131 * Fixed a lot of bugs in log saving/replay. It was pretty
7125 broken. Now special lines (!@,/) appear properly in the command
7132 broken. Now special lines (!@,/) appear properly in the command
7126 history after a log replay.
7133 history after a log replay.
7127
7134
7128 * Tried and failed to implement full session saving via pickle. My
7135 * Tried and failed to implement full session saving via pickle. My
7129 idea was to pickle __main__.__dict__, but modules can't be
7136 idea was to pickle __main__.__dict__, but modules can't be
7130 pickled. This would be a better alternative to replaying logs, but
7137 pickled. This would be a better alternative to replaying logs, but
7131 seems quite tricky to get to work. Changed -session to be called
7138 seems quite tricky to get to work. Changed -session to be called
7132 -logplay, which more accurately reflects what it does. And if we
7139 -logplay, which more accurately reflects what it does. And if we
7133 ever get real session saving working, -session is now available.
7140 ever get real session saving working, -session is now available.
7134
7141
7135 * Implemented color schemes for prompts also. As for tracebacks,
7142 * Implemented color schemes for prompts also. As for tracebacks,
7136 currently only NoColor and Linux are supported. But now the
7143 currently only NoColor and Linux are supported. But now the
7137 infrastructure is in place, based on a generic ColorScheme
7144 infrastructure is in place, based on a generic ColorScheme
7138 class. So writing and activating new schemes both for the prompts
7145 class. So writing and activating new schemes both for the prompts
7139 and the tracebacks should be straightforward.
7146 and the tracebacks should be straightforward.
7140
7147
7141 * Version 0.1.13 released, 0.1.14 opened.
7148 * Version 0.1.13 released, 0.1.14 opened.
7142
7149
7143 * Changed handling of options for output cache. Now counter is
7150 * Changed handling of options for output cache. Now counter is
7144 hardwired starting at 1 and one specifies the maximum number of
7151 hardwired starting at 1 and one specifies the maximum number of
7145 entries *in the outcache* (not the max prompt counter). This is
7152 entries *in the outcache* (not the max prompt counter). This is
7146 much better, since many statements won't increase the cache
7153 much better, since many statements won't increase the cache
7147 count. It also eliminated some confusing options, now there's only
7154 count. It also eliminated some confusing options, now there's only
7148 one: cache_size.
7155 one: cache_size.
7149
7156
7150 * Added 'alias' magic function and magic_alias option in the
7157 * Added 'alias' magic function and magic_alias option in the
7151 ipythonrc file. Now the user can easily define whatever names he
7158 ipythonrc file. Now the user can easily define whatever names he
7152 wants for the magic functions without having to play weird
7159 wants for the magic functions without having to play weird
7153 namespace games. This gives IPython a real shell-like feel.
7160 namespace games. This gives IPython a real shell-like feel.
7154
7161
7155 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
7162 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
7156 @ or not).
7163 @ or not).
7157
7164
7158 This was one of the last remaining 'visible' bugs (that I know
7165 This was one of the last remaining 'visible' bugs (that I know
7159 of). I think if I can clean up the session loading so it works
7166 of). I think if I can clean up the session loading so it works
7160 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
7167 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
7161 about licensing).
7168 about licensing).
7162
7169
7163 2001-11-25 Fernando Perez <fperez@colorado.edu>
7170 2001-11-25 Fernando Perez <fperez@colorado.edu>
7164
7171
7165 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
7172 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
7166 there's a cleaner distinction between what ? and ?? show.
7173 there's a cleaner distinction between what ? and ?? show.
7167
7174
7168 * Added screen_length option. Now the user can define his own
7175 * Added screen_length option. Now the user can define his own
7169 screen size for page() operations.
7176 screen size for page() operations.
7170
7177
7171 * Implemented magic shell-like functions with automatic code
7178 * Implemented magic shell-like functions with automatic code
7172 generation. Now adding another function is just a matter of adding
7179 generation. Now adding another function is just a matter of adding
7173 an entry to a dict, and the function is dynamically generated at
7180 an entry to a dict, and the function is dynamically generated at
7174 run-time. Python has some really cool features!
7181 run-time. Python has some really cool features!
7175
7182
7176 * Renamed many options to cleanup conventions a little. Now all
7183 * Renamed many options to cleanup conventions a little. Now all
7177 are lowercase, and only underscores where needed. Also in the code
7184 are lowercase, and only underscores where needed. Also in the code
7178 option name tables are clearer.
7185 option name tables are clearer.
7179
7186
7180 * Changed prompts a little. Now input is 'In [n]:' instead of
7187 * Changed prompts a little. Now input is 'In [n]:' instead of
7181 'In[n]:='. This allows it the numbers to be aligned with the
7188 'In[n]:='. This allows it the numbers to be aligned with the
7182 Out[n] numbers, and removes usage of ':=' which doesn't exist in
7189 Out[n] numbers, and removes usage of ':=' which doesn't exist in
7183 Python (it was a Mathematica thing). The '...' continuation prompt
7190 Python (it was a Mathematica thing). The '...' continuation prompt
7184 was also changed a little to align better.
7191 was also changed a little to align better.
7185
7192
7186 * Fixed bug when flushing output cache. Not all _p<n> variables
7193 * Fixed bug when flushing output cache. Not all _p<n> variables
7187 exist, so their deletion needs to be wrapped in a try:
7194 exist, so their deletion needs to be wrapped in a try:
7188
7195
7189 * Figured out how to properly use inspect.formatargspec() (it
7196 * Figured out how to properly use inspect.formatargspec() (it
7190 requires the args preceded by *). So I removed all the code from
7197 requires the args preceded by *). So I removed all the code from
7191 _get_pdef in Magic, which was just replicating that.
7198 _get_pdef in Magic, which was just replicating that.
7192
7199
7193 * Added test to prefilter to allow redefining magic function names
7200 * Added test to prefilter to allow redefining magic function names
7194 as variables. This is ok, since the @ form is always available,
7201 as variables. This is ok, since the @ form is always available,
7195 but whe should allow the user to define a variable called 'ls' if
7202 but whe should allow the user to define a variable called 'ls' if
7196 he needs it.
7203 he needs it.
7197
7204
7198 * Moved the ToDo information from README into a separate ToDo.
7205 * Moved the ToDo information from README into a separate ToDo.
7199
7206
7200 * General code cleanup and small bugfixes. I think it's close to a
7207 * General code cleanup and small bugfixes. I think it's close to a
7201 state where it can be released, obviously with a big 'beta'
7208 state where it can be released, obviously with a big 'beta'
7202 warning on it.
7209 warning on it.
7203
7210
7204 * Got the magic function split to work. Now all magics are defined
7211 * Got the magic function split to work. Now all magics are defined
7205 in a separate class. It just organizes things a bit, and now
7212 in a separate class. It just organizes things a bit, and now
7206 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
7213 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
7207 was too long).
7214 was too long).
7208
7215
7209 * Changed @clear to @reset to avoid potential confusions with
7216 * Changed @clear to @reset to avoid potential confusions with
7210 the shell command clear. Also renamed @cl to @clear, which does
7217 the shell command clear. Also renamed @cl to @clear, which does
7211 exactly what people expect it to from their shell experience.
7218 exactly what people expect it to from their shell experience.
7212
7219
7213 Added a check to the @reset command (since it's so
7220 Added a check to the @reset command (since it's so
7214 destructive, it's probably a good idea to ask for confirmation).
7221 destructive, it's probably a good idea to ask for confirmation).
7215 But now reset only works for full namespace resetting. Since the
7222 But now reset only works for full namespace resetting. Since the
7216 del keyword is already there for deleting a few specific
7223 del keyword is already there for deleting a few specific
7217 variables, I don't see the point of having a redundant magic
7224 variables, I don't see the point of having a redundant magic
7218 function for the same task.
7225 function for the same task.
7219
7226
7220 2001-11-24 Fernando Perez <fperez@colorado.edu>
7227 2001-11-24 Fernando Perez <fperez@colorado.edu>
7221
7228
7222 * Updated the builtin docs (esp. the ? ones).
7229 * Updated the builtin docs (esp. the ? ones).
7223
7230
7224 * Ran all the code through pychecker. Not terribly impressed with
7231 * Ran all the code through pychecker. Not terribly impressed with
7225 it: lots of spurious warnings and didn't really find anything of
7232 it: lots of spurious warnings and didn't really find anything of
7226 substance (just a few modules being imported and not used).
7233 substance (just a few modules being imported and not used).
7227
7234
7228 * Implemented the new ultraTB functionality into IPython. New
7235 * Implemented the new ultraTB functionality into IPython. New
7229 option: xcolors. This chooses color scheme. xmode now only selects
7236 option: xcolors. This chooses color scheme. xmode now only selects
7230 between Plain and Verbose. Better orthogonality.
7237 between Plain and Verbose. Better orthogonality.
7231
7238
7232 * Large rewrite of ultraTB. Much cleaner now, with a separation of
7239 * Large rewrite of ultraTB. Much cleaner now, with a separation of
7233 mode and color scheme for the exception handlers. Now it's
7240 mode and color scheme for the exception handlers. Now it's
7234 possible to have the verbose traceback with no coloring.
7241 possible to have the verbose traceback with no coloring.
7235
7242
7236 2001-11-23 Fernando Perez <fperez@colorado.edu>
7243 2001-11-23 Fernando Perez <fperez@colorado.edu>
7237
7244
7238 * Version 0.1.12 released, 0.1.13 opened.
7245 * Version 0.1.12 released, 0.1.13 opened.
7239
7246
7240 * Removed option to set auto-quote and auto-paren escapes by
7247 * Removed option to set auto-quote and auto-paren escapes by
7241 user. The chances of breaking valid syntax are just too high. If
7248 user. The chances of breaking valid syntax are just too high. If
7242 someone *really* wants, they can always dig into the code.
7249 someone *really* wants, they can always dig into the code.
7243
7250
7244 * Made prompt separators configurable.
7251 * Made prompt separators configurable.
7245
7252
7246 2001-11-22 Fernando Perez <fperez@colorado.edu>
7253 2001-11-22 Fernando Perez <fperez@colorado.edu>
7247
7254
7248 * Small bugfixes in many places.
7255 * Small bugfixes in many places.
7249
7256
7250 * Removed the MyCompleter class from ipplib. It seemed redundant
7257 * Removed the MyCompleter class from ipplib. It seemed redundant
7251 with the C-p,C-n history search functionality. Less code to
7258 with the C-p,C-n history search functionality. Less code to
7252 maintain.
7259 maintain.
7253
7260
7254 * Moved all the original ipython.py code into ipythonlib.py. Right
7261 * Moved all the original ipython.py code into ipythonlib.py. Right
7255 now it's just one big dump into a function called make_IPython, so
7262 now it's just one big dump into a function called make_IPython, so
7256 no real modularity has been gained. But at least it makes the
7263 no real modularity has been gained. But at least it makes the
7257 wrapper script tiny, and since ipythonlib is a module, it gets
7264 wrapper script tiny, and since ipythonlib is a module, it gets
7258 compiled and startup is much faster.
7265 compiled and startup is much faster.
7259
7266
7260 This is a reasobably 'deep' change, so we should test it for a
7267 This is a reasobably 'deep' change, so we should test it for a
7261 while without messing too much more with the code.
7268 while without messing too much more with the code.
7262
7269
7263 2001-11-21 Fernando Perez <fperez@colorado.edu>
7270 2001-11-21 Fernando Perez <fperez@colorado.edu>
7264
7271
7265 * Version 0.1.11 released, 0.1.12 opened for further work.
7272 * Version 0.1.11 released, 0.1.12 opened for further work.
7266
7273
7267 * Removed dependency on Itpl. It was only needed in one place. It
7274 * Removed dependency on Itpl. It was only needed in one place. It
7268 would be nice if this became part of python, though. It makes life
7275 would be nice if this became part of python, though. It makes life
7269 *a lot* easier in some cases.
7276 *a lot* easier in some cases.
7270
7277
7271 * Simplified the prefilter code a bit. Now all handlers are
7278 * Simplified the prefilter code a bit. Now all handlers are
7272 expected to explicitly return a value (at least a blank string).
7279 expected to explicitly return a value (at least a blank string).
7273
7280
7274 * Heavy edits in ipplib. Removed the help system altogether. Now
7281 * Heavy edits in ipplib. Removed the help system altogether. Now
7275 obj?/?? is used for inspecting objects, a magic @doc prints
7282 obj?/?? is used for inspecting objects, a magic @doc prints
7276 docstrings, and full-blown Python help is accessed via the 'help'
7283 docstrings, and full-blown Python help is accessed via the 'help'
7277 keyword. This cleans up a lot of code (less to maintain) and does
7284 keyword. This cleans up a lot of code (less to maintain) and does
7278 the job. Since 'help' is now a standard Python component, might as
7285 the job. Since 'help' is now a standard Python component, might as
7279 well use it and remove duplicate functionality.
7286 well use it and remove duplicate functionality.
7280
7287
7281 Also removed the option to use ipplib as a standalone program. By
7288 Also removed the option to use ipplib as a standalone program. By
7282 now it's too dependent on other parts of IPython to function alone.
7289 now it's too dependent on other parts of IPython to function alone.
7283
7290
7284 * Fixed bug in genutils.pager. It would crash if the pager was
7291 * Fixed bug in genutils.pager. It would crash if the pager was
7285 exited immediately after opening (broken pipe).
7292 exited immediately after opening (broken pipe).
7286
7293
7287 * Trimmed down the VerboseTB reporting a little. The header is
7294 * Trimmed down the VerboseTB reporting a little. The header is
7288 much shorter now and the repeated exception arguments at the end
7295 much shorter now and the repeated exception arguments at the end
7289 have been removed. For interactive use the old header seemed a bit
7296 have been removed. For interactive use the old header seemed a bit
7290 excessive.
7297 excessive.
7291
7298
7292 * Fixed small bug in output of @whos for variables with multi-word
7299 * Fixed small bug in output of @whos for variables with multi-word
7293 types (only first word was displayed).
7300 types (only first word was displayed).
7294
7301
7295 2001-11-17 Fernando Perez <fperez@colorado.edu>
7302 2001-11-17 Fernando Perez <fperez@colorado.edu>
7296
7303
7297 * Version 0.1.10 released, 0.1.11 opened for further work.
7304 * Version 0.1.10 released, 0.1.11 opened for further work.
7298
7305
7299 * Modified dirs and friends. dirs now *returns* the stack (not
7306 * Modified dirs and friends. dirs now *returns* the stack (not
7300 prints), so one can manipulate it as a variable. Convenient to
7307 prints), so one can manipulate it as a variable. Convenient to
7301 travel along many directories.
7308 travel along many directories.
7302
7309
7303 * Fixed bug in magic_pdef: would only work with functions with
7310 * Fixed bug in magic_pdef: would only work with functions with
7304 arguments with default values.
7311 arguments with default values.
7305
7312
7306 2001-11-14 Fernando Perez <fperez@colorado.edu>
7313 2001-11-14 Fernando Perez <fperez@colorado.edu>
7307
7314
7308 * Added the PhysicsInput stuff to dot_ipython so it ships as an
7315 * Added the PhysicsInput stuff to dot_ipython so it ships as an
7309 example with IPython. Various other minor fixes and cleanups.
7316 example with IPython. Various other minor fixes and cleanups.
7310
7317
7311 * Version 0.1.9 released, 0.1.10 opened for further work.
7318 * Version 0.1.9 released, 0.1.10 opened for further work.
7312
7319
7313 * Added sys.path to the list of directories searched in the
7320 * Added sys.path to the list of directories searched in the
7314 execfile= option. It used to be the current directory and the
7321 execfile= option. It used to be the current directory and the
7315 user's IPYTHONDIR only.
7322 user's IPYTHONDIR only.
7316
7323
7317 2001-11-13 Fernando Perez <fperez@colorado.edu>
7324 2001-11-13 Fernando Perez <fperez@colorado.edu>
7318
7325
7319 * Reinstated the raw_input/prefilter separation that Janko had
7326 * Reinstated the raw_input/prefilter separation that Janko had
7320 initially. This gives a more convenient setup for extending the
7327 initially. This gives a more convenient setup for extending the
7321 pre-processor from the outside: raw_input always gets a string,
7328 pre-processor from the outside: raw_input always gets a string,
7322 and prefilter has to process it. We can then redefine prefilter
7329 and prefilter has to process it. We can then redefine prefilter
7323 from the outside and implement extensions for special
7330 from the outside and implement extensions for special
7324 purposes.
7331 purposes.
7325
7332
7326 Today I got one for inputting PhysicalQuantity objects
7333 Today I got one for inputting PhysicalQuantity objects
7327 (from Scientific) without needing any function calls at
7334 (from Scientific) without needing any function calls at
7328 all. Extremely convenient, and it's all done as a user-level
7335 all. Extremely convenient, and it's all done as a user-level
7329 extension (no IPython code was touched). Now instead of:
7336 extension (no IPython code was touched). Now instead of:
7330 a = PhysicalQuantity(4.2,'m/s**2')
7337 a = PhysicalQuantity(4.2,'m/s**2')
7331 one can simply say
7338 one can simply say
7332 a = 4.2 m/s**2
7339 a = 4.2 m/s**2
7333 or even
7340 or even
7334 a = 4.2 m/s^2
7341 a = 4.2 m/s^2
7335
7342
7336 I use this, but it's also a proof of concept: IPython really is
7343 I use this, but it's also a proof of concept: IPython really is
7337 fully user-extensible, even at the level of the parsing of the
7344 fully user-extensible, even at the level of the parsing of the
7338 command line. It's not trivial, but it's perfectly doable.
7345 command line. It's not trivial, but it's perfectly doable.
7339
7346
7340 * Added 'add_flip' method to inclusion conflict resolver. Fixes
7347 * Added 'add_flip' method to inclusion conflict resolver. Fixes
7341 the problem of modules being loaded in the inverse order in which
7348 the problem of modules being loaded in the inverse order in which
7342 they were defined in
7349 they were defined in
7343
7350
7344 * Version 0.1.8 released, 0.1.9 opened for further work.
7351 * Version 0.1.8 released, 0.1.9 opened for further work.
7345
7352
7346 * Added magics pdef, source and file. They respectively show the
7353 * Added magics pdef, source and file. They respectively show the
7347 definition line ('prototype' in C), source code and full python
7354 definition line ('prototype' in C), source code and full python
7348 file for any callable object. The object inspector oinfo uses
7355 file for any callable object. The object inspector oinfo uses
7349 these to show the same information.
7356 these to show the same information.
7350
7357
7351 * Version 0.1.7 released, 0.1.8 opened for further work.
7358 * Version 0.1.7 released, 0.1.8 opened for further work.
7352
7359
7353 * Separated all the magic functions into a class called Magic. The
7360 * Separated all the magic functions into a class called Magic. The
7354 InteractiveShell class was becoming too big for Xemacs to handle
7361 InteractiveShell class was becoming too big for Xemacs to handle
7355 (de-indenting a line would lock it up for 10 seconds while it
7362 (de-indenting a line would lock it up for 10 seconds while it
7356 backtracked on the whole class!)
7363 backtracked on the whole class!)
7357
7364
7358 FIXME: didn't work. It can be done, but right now namespaces are
7365 FIXME: didn't work. It can be done, but right now namespaces are
7359 all messed up. Do it later (reverted it for now, so at least
7366 all messed up. Do it later (reverted it for now, so at least
7360 everything works as before).
7367 everything works as before).
7361
7368
7362 * Got the object introspection system (magic_oinfo) working! I
7369 * Got the object introspection system (magic_oinfo) working! I
7363 think this is pretty much ready for release to Janko, so he can
7370 think this is pretty much ready for release to Janko, so he can
7364 test it for a while and then announce it. Pretty much 100% of what
7371 test it for a while and then announce it. Pretty much 100% of what
7365 I wanted for the 'phase 1' release is ready. Happy, tired.
7372 I wanted for the 'phase 1' release is ready. Happy, tired.
7366
7373
7367 2001-11-12 Fernando Perez <fperez@colorado.edu>
7374 2001-11-12 Fernando Perez <fperez@colorado.edu>
7368
7375
7369 * Version 0.1.6 released, 0.1.7 opened for further work.
7376 * Version 0.1.6 released, 0.1.7 opened for further work.
7370
7377
7371 * Fixed bug in printing: it used to test for truth before
7378 * Fixed bug in printing: it used to test for truth before
7372 printing, so 0 wouldn't print. Now checks for None.
7379 printing, so 0 wouldn't print. Now checks for None.
7373
7380
7374 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
7381 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
7375 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
7382 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
7376 reaches by hand into the outputcache. Think of a better way to do
7383 reaches by hand into the outputcache. Think of a better way to do
7377 this later.
7384 this later.
7378
7385
7379 * Various small fixes thanks to Nathan's comments.
7386 * Various small fixes thanks to Nathan's comments.
7380
7387
7381 * Changed magic_pprint to magic_Pprint. This way it doesn't
7388 * Changed magic_pprint to magic_Pprint. This way it doesn't
7382 collide with pprint() and the name is consistent with the command
7389 collide with pprint() and the name is consistent with the command
7383 line option.
7390 line option.
7384
7391
7385 * Changed prompt counter behavior to be fully like
7392 * Changed prompt counter behavior to be fully like
7386 Mathematica's. That is, even input that doesn't return a result
7393 Mathematica's. That is, even input that doesn't return a result
7387 raises the prompt counter. The old behavior was kind of confusing
7394 raises the prompt counter. The old behavior was kind of confusing
7388 (getting the same prompt number several times if the operation
7395 (getting the same prompt number several times if the operation
7389 didn't return a result).
7396 didn't return a result).
7390
7397
7391 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
7398 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
7392
7399
7393 * Fixed -Classic mode (wasn't working anymore).
7400 * Fixed -Classic mode (wasn't working anymore).
7394
7401
7395 * Added colored prompts using Nathan's new code. Colors are
7402 * Added colored prompts using Nathan's new code. Colors are
7396 currently hardwired, they can be user-configurable. For
7403 currently hardwired, they can be user-configurable. For
7397 developers, they can be chosen in file ipythonlib.py, at the
7404 developers, they can be chosen in file ipythonlib.py, at the
7398 beginning of the CachedOutput class def.
7405 beginning of the CachedOutput class def.
7399
7406
7400 2001-11-11 Fernando Perez <fperez@colorado.edu>
7407 2001-11-11 Fernando Perez <fperez@colorado.edu>
7401
7408
7402 * Version 0.1.5 released, 0.1.6 opened for further work.
7409 * Version 0.1.5 released, 0.1.6 opened for further work.
7403
7410
7404 * Changed magic_env to *return* the environment as a dict (not to
7411 * Changed magic_env to *return* the environment as a dict (not to
7405 print it). This way it prints, but it can also be processed.
7412 print it). This way it prints, but it can also be processed.
7406
7413
7407 * Added Verbose exception reporting to interactive
7414 * Added Verbose exception reporting to interactive
7408 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
7415 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
7409 traceback. Had to make some changes to the ultraTB file. This is
7416 traceback. Had to make some changes to the ultraTB file. This is
7410 probably the last 'big' thing in my mental todo list. This ties
7417 probably the last 'big' thing in my mental todo list. This ties
7411 in with the next entry:
7418 in with the next entry:
7412
7419
7413 * Changed -Xi and -Xf to a single -xmode option. Now all the user
7420 * Changed -Xi and -Xf to a single -xmode option. Now all the user
7414 has to specify is Plain, Color or Verbose for all exception
7421 has to specify is Plain, Color or Verbose for all exception
7415 handling.
7422 handling.
7416
7423
7417 * Removed ShellServices option. All this can really be done via
7424 * Removed ShellServices option. All this can really be done via
7418 the magic system. It's easier to extend, cleaner and has automatic
7425 the magic system. It's easier to extend, cleaner and has automatic
7419 namespace protection and documentation.
7426 namespace protection and documentation.
7420
7427
7421 2001-11-09 Fernando Perez <fperez@colorado.edu>
7428 2001-11-09 Fernando Perez <fperez@colorado.edu>
7422
7429
7423 * Fixed bug in output cache flushing (missing parameter to
7430 * Fixed bug in output cache flushing (missing parameter to
7424 __init__). Other small bugs fixed (found using pychecker).
7431 __init__). Other small bugs fixed (found using pychecker).
7425
7432
7426 * Version 0.1.4 opened for bugfixing.
7433 * Version 0.1.4 opened for bugfixing.
7427
7434
7428 2001-11-07 Fernando Perez <fperez@colorado.edu>
7435 2001-11-07 Fernando Perez <fperez@colorado.edu>
7429
7436
7430 * Version 0.1.3 released, mainly because of the raw_input bug.
7437 * Version 0.1.3 released, mainly because of the raw_input bug.
7431
7438
7432 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
7439 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
7433 and when testing for whether things were callable, a call could
7440 and when testing for whether things were callable, a call could
7434 actually be made to certain functions. They would get called again
7441 actually be made to certain functions. They would get called again
7435 once 'really' executed, with a resulting double call. A disaster
7442 once 'really' executed, with a resulting double call. A disaster
7436 in many cases (list.reverse() would never work!).
7443 in many cases (list.reverse() would never work!).
7437
7444
7438 * Removed prefilter() function, moved its code to raw_input (which
7445 * Removed prefilter() function, moved its code to raw_input (which
7439 after all was just a near-empty caller for prefilter). This saves
7446 after all was just a near-empty caller for prefilter). This saves
7440 a function call on every prompt, and simplifies the class a tiny bit.
7447 a function call on every prompt, and simplifies the class a tiny bit.
7441
7448
7442 * Fix _ip to __ip name in magic example file.
7449 * Fix _ip to __ip name in magic example file.
7443
7450
7444 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
7451 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
7445 work with non-gnu versions of tar.
7452 work with non-gnu versions of tar.
7446
7453
7447 2001-11-06 Fernando Perez <fperez@colorado.edu>
7454 2001-11-06 Fernando Perez <fperez@colorado.edu>
7448
7455
7449 * Version 0.1.2. Just to keep track of the recent changes.
7456 * Version 0.1.2. Just to keep track of the recent changes.
7450
7457
7451 * Fixed nasty bug in output prompt routine. It used to check 'if
7458 * Fixed nasty bug in output prompt routine. It used to check 'if
7452 arg != None...'. Problem is, this fails if arg implements a
7459 arg != None...'. Problem is, this fails if arg implements a
7453 special comparison (__cmp__) which disallows comparing to
7460 special comparison (__cmp__) which disallows comparing to
7454 None. Found it when trying to use the PhysicalQuantity module from
7461 None. Found it when trying to use the PhysicalQuantity module from
7455 ScientificPython.
7462 ScientificPython.
7456
7463
7457 2001-11-05 Fernando Perez <fperez@colorado.edu>
7464 2001-11-05 Fernando Perez <fperez@colorado.edu>
7458
7465
7459 * Also added dirs. Now the pushd/popd/dirs family functions
7466 * Also added dirs. Now the pushd/popd/dirs family functions
7460 basically like the shell, with the added convenience of going home
7467 basically like the shell, with the added convenience of going home
7461 when called with no args.
7468 when called with no args.
7462
7469
7463 * pushd/popd slightly modified to mimic shell behavior more
7470 * pushd/popd slightly modified to mimic shell behavior more
7464 closely.
7471 closely.
7465
7472
7466 * Added env,pushd,popd from ShellServices as magic functions. I
7473 * Added env,pushd,popd from ShellServices as magic functions. I
7467 think the cleanest will be to port all desired functions from
7474 think the cleanest will be to port all desired functions from
7468 ShellServices as magics and remove ShellServices altogether. This
7475 ShellServices as magics and remove ShellServices altogether. This
7469 will provide a single, clean way of adding functionality
7476 will provide a single, clean way of adding functionality
7470 (shell-type or otherwise) to IP.
7477 (shell-type or otherwise) to IP.
7471
7478
7472 2001-11-04 Fernando Perez <fperez@colorado.edu>
7479 2001-11-04 Fernando Perez <fperez@colorado.edu>
7473
7480
7474 * Added .ipython/ directory to sys.path. This way users can keep
7481 * Added .ipython/ directory to sys.path. This way users can keep
7475 customizations there and access them via import.
7482 customizations there and access them via import.
7476
7483
7477 2001-11-03 Fernando Perez <fperez@colorado.edu>
7484 2001-11-03 Fernando Perez <fperez@colorado.edu>
7478
7485
7479 * Opened version 0.1.1 for new changes.
7486 * Opened version 0.1.1 for new changes.
7480
7487
7481 * Changed version number to 0.1.0: first 'public' release, sent to
7488 * Changed version number to 0.1.0: first 'public' release, sent to
7482 Nathan and Janko.
7489 Nathan and Janko.
7483
7490
7484 * Lots of small fixes and tweaks.
7491 * Lots of small fixes and tweaks.
7485
7492
7486 * Minor changes to whos format. Now strings are shown, snipped if
7493 * Minor changes to whos format. Now strings are shown, snipped if
7487 too long.
7494 too long.
7488
7495
7489 * Changed ShellServices to work on __main__ so they show up in @who
7496 * Changed ShellServices to work on __main__ so they show up in @who
7490
7497
7491 * Help also works with ? at the end of a line:
7498 * Help also works with ? at the end of a line:
7492 ?sin and sin?
7499 ?sin and sin?
7493 both produce the same effect. This is nice, as often I use the
7500 both produce the same effect. This is nice, as often I use the
7494 tab-complete to find the name of a method, but I used to then have
7501 tab-complete to find the name of a method, but I used to then have
7495 to go to the beginning of the line to put a ? if I wanted more
7502 to go to the beginning of the line to put a ? if I wanted more
7496 info. Now I can just add the ? and hit return. Convenient.
7503 info. Now I can just add the ? and hit return. Convenient.
7497
7504
7498 2001-11-02 Fernando Perez <fperez@colorado.edu>
7505 2001-11-02 Fernando Perez <fperez@colorado.edu>
7499
7506
7500 * Python version check (>=2.1) added.
7507 * Python version check (>=2.1) added.
7501
7508
7502 * Added LazyPython documentation. At this point the docs are quite
7509 * Added LazyPython documentation. At this point the docs are quite
7503 a mess. A cleanup is in order.
7510 a mess. A cleanup is in order.
7504
7511
7505 * Auto-installer created. For some bizarre reason, the zipfiles
7512 * Auto-installer created. For some bizarre reason, the zipfiles
7506 module isn't working on my system. So I made a tar version
7513 module isn't working on my system. So I made a tar version
7507 (hopefully the command line options in various systems won't kill
7514 (hopefully the command line options in various systems won't kill
7508 me).
7515 me).
7509
7516
7510 * Fixes to Struct in genutils. Now all dictionary-like methods are
7517 * Fixes to Struct in genutils. Now all dictionary-like methods are
7511 protected (reasonably).
7518 protected (reasonably).
7512
7519
7513 * Added pager function to genutils and changed ? to print usage
7520 * Added pager function to genutils and changed ? to print usage
7514 note through it (it was too long).
7521 note through it (it was too long).
7515
7522
7516 * Added the LazyPython functionality. Works great! I changed the
7523 * Added the LazyPython functionality. Works great! I changed the
7517 auto-quote escape to ';', it's on home row and next to '. But
7524 auto-quote escape to ';', it's on home row and next to '. But
7518 both auto-quote and auto-paren (still /) escapes are command-line
7525 both auto-quote and auto-paren (still /) escapes are command-line
7519 parameters.
7526 parameters.
7520
7527
7521
7528
7522 2001-11-01 Fernando Perez <fperez@colorado.edu>
7529 2001-11-01 Fernando Perez <fperez@colorado.edu>
7523
7530
7524 * Version changed to 0.0.7. Fairly large change: configuration now
7531 * Version changed to 0.0.7. Fairly large change: configuration now
7525 is all stored in a directory, by default .ipython. There, all
7532 is all stored in a directory, by default .ipython. There, all
7526 config files have normal looking names (not .names)
7533 config files have normal looking names (not .names)
7527
7534
7528 * Version 0.0.6 Released first to Lucas and Archie as a test
7535 * Version 0.0.6 Released first to Lucas and Archie as a test
7529 run. Since it's the first 'semi-public' release, change version to
7536 run. Since it's the first 'semi-public' release, change version to
7530 > 0.0.6 for any changes now.
7537 > 0.0.6 for any changes now.
7531
7538
7532 * Stuff I had put in the ipplib.py changelog:
7539 * Stuff I had put in the ipplib.py changelog:
7533
7540
7534 Changes to InteractiveShell:
7541 Changes to InteractiveShell:
7535
7542
7536 - Made the usage message a parameter.
7543 - Made the usage message a parameter.
7537
7544
7538 - Require the name of the shell variable to be given. It's a bit
7545 - Require the name of the shell variable to be given. It's a bit
7539 of a hack, but allows the name 'shell' not to be hardwired in the
7546 of a hack, but allows the name 'shell' not to be hardwired in the
7540 magic (@) handler, which is problematic b/c it requires
7547 magic (@) handler, which is problematic b/c it requires
7541 polluting the global namespace with 'shell'. This in turn is
7548 polluting the global namespace with 'shell'. This in turn is
7542 fragile: if a user redefines a variable called shell, things
7549 fragile: if a user redefines a variable called shell, things
7543 break.
7550 break.
7544
7551
7545 - magic @: all functions available through @ need to be defined
7552 - magic @: all functions available through @ need to be defined
7546 as magic_<name>, even though they can be called simply as
7553 as magic_<name>, even though they can be called simply as
7547 @<name>. This allows the special command @magic to gather
7554 @<name>. This allows the special command @magic to gather
7548 information automatically about all existing magic functions,
7555 information automatically about all existing magic functions,
7549 even if they are run-time user extensions, by parsing the shell
7556 even if they are run-time user extensions, by parsing the shell
7550 instance __dict__ looking for special magic_ names.
7557 instance __dict__ looking for special magic_ names.
7551
7558
7552 - mainloop: added *two* local namespace parameters. This allows
7559 - mainloop: added *two* local namespace parameters. This allows
7553 the class to differentiate between parameters which were there
7560 the class to differentiate between parameters which were there
7554 before and after command line initialization was processed. This
7561 before and after command line initialization was processed. This
7555 way, later @who can show things loaded at startup by the
7562 way, later @who can show things loaded at startup by the
7556 user. This trick was necessary to make session saving/reloading
7563 user. This trick was necessary to make session saving/reloading
7557 really work: ideally after saving/exiting/reloading a session,
7564 really work: ideally after saving/exiting/reloading a session,
7558 *everything* should look the same, including the output of @who. I
7565 *everything* should look the same, including the output of @who. I
7559 was only able to make this work with this double namespace
7566 was only able to make this work with this double namespace
7560 trick.
7567 trick.
7561
7568
7562 - added a header to the logfile which allows (almost) full
7569 - added a header to the logfile which allows (almost) full
7563 session restoring.
7570 session restoring.
7564
7571
7565 - prepend lines beginning with @ or !, with a and log
7572 - prepend lines beginning with @ or !, with a and log
7566 them. Why? !lines: may be useful to know what you did @lines:
7573 them. Why? !lines: may be useful to know what you did @lines:
7567 they may affect session state. So when restoring a session, at
7574 they may affect session state. So when restoring a session, at
7568 least inform the user of their presence. I couldn't quite get
7575 least inform the user of their presence. I couldn't quite get
7569 them to properly re-execute, but at least the user is warned.
7576 them to properly re-execute, but at least the user is warned.
7570
7577
7571 * Started ChangeLog.
7578 * Started ChangeLog.
General Comments 0
You need to be logged in to leave comments. Login now