##// END OF EJS Templates
Fixed the help message in the footer (which was displaying "quit" twice).
walter.doerwald -
Show More
@@ -1,1679 +1,1679
1 # -*- coding: iso-8859-1 -*-
1 # -*- coding: iso-8859-1 -*-
2
2
3 import curses, fcntl, signal, struct, tty, textwrap, inspect
3 import curses, fcntl, signal, struct, tty, textwrap, inspect
4
4
5 import astyle, ipipe
5 import astyle, ipipe
6
6
7
7
8 # Python 2.3 compatibility
8 # Python 2.3 compatibility
9 try:
9 try:
10 set
10 set
11 except NameError:
11 except NameError:
12 import sets
12 import sets
13 set = sets.Set
13 set = sets.Set
14
14
15
15
16 class UnassignedKeyError(Exception):
16 class UnassignedKeyError(Exception):
17 """
17 """
18 Exception that is used for reporting unassigned keys.
18 Exception that is used for reporting unassigned keys.
19 """
19 """
20
20
21
21
22 class UnknownCommandError(Exception):
22 class UnknownCommandError(Exception):
23 """
23 """
24 Exception that is used for reporting unknown command (this should never
24 Exception that is used for reporting unknown command (this should never
25 happen).
25 happen).
26 """
26 """
27
27
28
28
29 class CommandError(Exception):
29 class CommandError(Exception):
30 """
30 """
31 Exception that is used for reporting that a command can't be executed.
31 Exception that is used for reporting that a command can't be executed.
32 """
32 """
33
33
34
34
35 class Keymap(dict):
35 class Keymap(dict):
36 """
36 """
37 Stores mapping of keys to commands.
37 Stores mapping of keys to commands.
38 """
38 """
39 def __init__(self):
39 def __init__(self):
40 self._keymap = {}
40 self._keymap = {}
41
41
42 def __setitem__(self, key, command):
42 def __setitem__(self, key, command):
43 if isinstance(key, str):
43 if isinstance(key, str):
44 for c in key:
44 for c in key:
45 dict.__setitem__(self, ord(c), command)
45 dict.__setitem__(self, ord(c), command)
46 else:
46 else:
47 dict.__setitem__(self, key, command)
47 dict.__setitem__(self, key, command)
48
48
49 def __getitem__(self, key):
49 def __getitem__(self, key):
50 if isinstance(key, str):
50 if isinstance(key, str):
51 key = ord(key)
51 key = ord(key)
52 return dict.__getitem__(self, key)
52 return dict.__getitem__(self, key)
53
53
54 def __detitem__(self, key):
54 def __detitem__(self, key):
55 if isinstance(key, str):
55 if isinstance(key, str):
56 key = ord(key)
56 key = ord(key)
57 dict.__detitem__(self, key)
57 dict.__detitem__(self, key)
58
58
59 def register(self, command, *keys):
59 def register(self, command, *keys):
60 for key in keys:
60 for key in keys:
61 self[key] = command
61 self[key] = command
62
62
63 def get(self, key, default=None):
63 def get(self, key, default=None):
64 if isinstance(key, str):
64 if isinstance(key, str):
65 key = ord(key)
65 key = ord(key)
66 return dict.get(self, key, default)
66 return dict.get(self, key, default)
67
67
68 def findkey(self, command, default=ipipe.noitem):
68 def findkey(self, command, default=ipipe.noitem):
69 for (key, commandcandidate) in self.iteritems():
69 for (key, commandcandidate) in self.iteritems():
70 if commandcandidate == command:
70 if commandcandidate == command:
71 return key
71 return key
72 if default is ipipe.noitem:
72 if default is ipipe.noitem:
73 raise KeyError(command)
73 raise KeyError(command)
74 return default
74 return default
75
75
76
76
77 class _BrowserCachedItem(object):
77 class _BrowserCachedItem(object):
78 # This is used internally by ``ibrowse`` to store a item together with its
78 # This is used internally by ``ibrowse`` to store a item together with its
79 # marked status.
79 # marked status.
80 __slots__ = ("item", "marked")
80 __slots__ = ("item", "marked")
81
81
82 def __init__(self, item):
82 def __init__(self, item):
83 self.item = item
83 self.item = item
84 self.marked = False
84 self.marked = False
85
85
86
86
87 class _BrowserHelp(object):
87 class _BrowserHelp(object):
88 style_header = astyle.Style.fromstr("yellow:black:bold")
88 style_header = astyle.Style.fromstr("yellow:black:bold")
89 # This is used internally by ``ibrowse`` for displaying the help screen.
89 # This is used internally by ``ibrowse`` for displaying the help screen.
90 def __init__(self, browser):
90 def __init__(self, browser):
91 self.browser = browser
91 self.browser = browser
92
92
93 def __xrepr__(self, mode):
93 def __xrepr__(self, mode):
94 yield (-1, True)
94 yield (-1, True)
95 if mode == "header" or mode == "footer":
95 if mode == "header" or mode == "footer":
96 yield (astyle.style_default, "ibrowse help screen")
96 yield (astyle.style_default, "ibrowse help screen")
97 else:
97 else:
98 yield (astyle.style_default, repr(self))
98 yield (astyle.style_default, repr(self))
99
99
100 def __iter__(self):
100 def __iter__(self):
101 # Get reverse key mapping
101 # Get reverse key mapping
102 allkeys = {}
102 allkeys = {}
103 for (key, cmd) in self.browser.keymap.iteritems():
103 for (key, cmd) in self.browser.keymap.iteritems():
104 allkeys.setdefault(cmd, []).append(key)
104 allkeys.setdefault(cmd, []).append(key)
105
105
106 fields = ("key", "description")
106 fields = ("key", "description")
107
107
108 commands = []
108 commands = []
109 for name in dir(self.browser):
109 for name in dir(self.browser):
110 if name.startswith("cmd_"):
110 if name.startswith("cmd_"):
111 command = getattr(self.browser, name)
111 command = getattr(self.browser, name)
112 commands.append((inspect.getsourcelines(command)[-1], name[4:], command))
112 commands.append((inspect.getsourcelines(command)[-1], name[4:], command))
113 commands.sort()
113 commands.sort()
114 commands = [(c[1], c[2]) for c in commands]
114 commands = [(c[1], c[2]) for c in commands]
115 for (i, (name, command)) in enumerate(commands):
115 for (i, (name, command)) in enumerate(commands):
116 if i:
116 if i:
117 yield ipipe.Fields(fields, key="", description="")
117 yield ipipe.Fields(fields, key="", description="")
118
118
119 description = command.__doc__
119 description = command.__doc__
120 if description is None:
120 if description is None:
121 lines = []
121 lines = []
122 else:
122 else:
123 lines = [l.strip() for l in description.splitlines() if l.strip()]
123 lines = [l.strip() for l in description.splitlines() if l.strip()]
124 description = "\n".join(lines)
124 description = "\n".join(lines)
125 lines = textwrap.wrap(description, 60)
125 lines = textwrap.wrap(description, 60)
126 keys = allkeys.get(name, [])
126 keys = allkeys.get(name, [])
127
127
128 yield ipipe.Fields(fields, key="", description=astyle.Text((self.style_header, name)))
128 yield ipipe.Fields(fields, key="", description=astyle.Text((self.style_header, name)))
129 for i in xrange(max(len(keys), len(lines))):
129 for i in xrange(max(len(keys), len(lines))):
130 try:
130 try:
131 key = self.browser.keylabel(keys[i])
131 key = self.browser.keylabel(keys[i])
132 except IndexError:
132 except IndexError:
133 key = ""
133 key = ""
134 try:
134 try:
135 line = lines[i]
135 line = lines[i]
136 except IndexError:
136 except IndexError:
137 line = ""
137 line = ""
138 yield ipipe.Fields(fields, key=key, description=line)
138 yield ipipe.Fields(fields, key=key, description=line)
139
139
140
140
141 class _BrowserLevel(object):
141 class _BrowserLevel(object):
142 # This is used internally to store the state (iterator, fetch items,
142 # This is used internally to store the state (iterator, fetch items,
143 # position of cursor and screen, etc.) of one browser level
143 # position of cursor and screen, etc.) of one browser level
144 # An ``ibrowse`` object keeps multiple ``_BrowserLevel`` objects in
144 # An ``ibrowse`` object keeps multiple ``_BrowserLevel`` objects in
145 # a stack.
145 # a stack.
146 def __init__(self, browser, input, iterator, mainsizey, *attrs):
146 def __init__(self, browser, input, iterator, mainsizey, *attrs):
147 self.browser = browser
147 self.browser = browser
148 self.input = input
148 self.input = input
149 self.header = [x for x in ipipe.xrepr(input, "header") if not isinstance(x[0], int)]
149 self.header = [x for x in ipipe.xrepr(input, "header") if not isinstance(x[0], int)]
150 # iterator for the input
150 # iterator for the input
151 self.iterator = iterator
151 self.iterator = iterator
152
152
153 # is the iterator exhausted?
153 # is the iterator exhausted?
154 self.exhausted = False
154 self.exhausted = False
155
155
156 # attributes to be display (autodetected if empty)
156 # attributes to be display (autodetected if empty)
157 self.attrs = attrs
157 self.attrs = attrs
158
158
159 # fetched items (+ marked flag)
159 # fetched items (+ marked flag)
160 self.items = ipipe.deque()
160 self.items = ipipe.deque()
161
161
162 # Number of marked objects
162 # Number of marked objects
163 self.marked = 0
163 self.marked = 0
164
164
165 # Vertical cursor position
165 # Vertical cursor position
166 self.cury = 0
166 self.cury = 0
167
167
168 # Horizontal cursor position
168 # Horizontal cursor position
169 self.curx = 0
169 self.curx = 0
170
170
171 # Index of first data column
171 # Index of first data column
172 self.datastartx = 0
172 self.datastartx = 0
173
173
174 # Index of first data line
174 # Index of first data line
175 self.datastarty = 0
175 self.datastarty = 0
176
176
177 # height of the data display area
177 # height of the data display area
178 self.mainsizey = mainsizey
178 self.mainsizey = mainsizey
179
179
180 # width of the data display area (changes when scrolling)
180 # width of the data display area (changes when scrolling)
181 self.mainsizex = 0
181 self.mainsizex = 0
182
182
183 # Size of row number (changes when scrolling)
183 # Size of row number (changes when scrolling)
184 self.numbersizex = 0
184 self.numbersizex = 0
185
185
186 # Attributes to display (in this order)
186 # Attributes to display (in this order)
187 self.displayattrs = []
187 self.displayattrs = []
188
188
189 # index and attribute under the cursor
189 # index and attribute under the cursor
190 self.displayattr = (None, ipipe.noitem)
190 self.displayattr = (None, ipipe.noitem)
191
191
192 # Maps attributes to column widths
192 # Maps attributes to column widths
193 self.colwidths = {}
193 self.colwidths = {}
194
194
195 # Set of hidden attributes
195 # Set of hidden attributes
196 self.hiddenattrs = set()
196 self.hiddenattrs = set()
197
197
198 # This takes care of all the caches etc.
198 # This takes care of all the caches etc.
199 self.moveto(0, 0, refresh=True)
199 self.moveto(0, 0, refresh=True)
200
200
201 def fetch(self, count):
201 def fetch(self, count):
202 # Try to fill ``self.items`` with at least ``count`` objects.
202 # Try to fill ``self.items`` with at least ``count`` objects.
203 have = len(self.items)
203 have = len(self.items)
204 while not self.exhausted and have < count:
204 while not self.exhausted and have < count:
205 try:
205 try:
206 item = self.iterator.next()
206 item = self.iterator.next()
207 except StopIteration:
207 except StopIteration:
208 self.exhausted = True
208 self.exhausted = True
209 break
209 break
210 except (KeyboardInterrupt, SystemExit):
210 except (KeyboardInterrupt, SystemExit):
211 raise
211 raise
212 except Exception, exc:
212 except Exception, exc:
213 have += 1
213 have += 1
214 self.items.append(_BrowserCachedItem(exc))
214 self.items.append(_BrowserCachedItem(exc))
215 self.exhausted = True
215 self.exhausted = True
216 break
216 break
217 else:
217 else:
218 have += 1
218 have += 1
219 self.items.append(_BrowserCachedItem(item))
219 self.items.append(_BrowserCachedItem(item))
220
220
221 def calcdisplayattrs(self):
221 def calcdisplayattrs(self):
222 # Calculate which attributes are available from the objects that are
222 # Calculate which attributes are available from the objects that are
223 # currently visible on screen (and store it in ``self.displayattrs``)
223 # currently visible on screen (and store it in ``self.displayattrs``)
224
224
225 attrs = set()
225 attrs = set()
226 self.displayattrs = []
226 self.displayattrs = []
227 if self.attrs:
227 if self.attrs:
228 # If the browser object specifies a fixed list of attributes,
228 # If the browser object specifies a fixed list of attributes,
229 # simply use it (removing hidden attributes).
229 # simply use it (removing hidden attributes).
230 for attr in self.attrs:
230 for attr in self.attrs:
231 attr = ipipe.upgradexattr(attr)
231 attr = ipipe.upgradexattr(attr)
232 if attr not in attrs and attr not in self.hiddenattrs:
232 if attr not in attrs and attr not in self.hiddenattrs:
233 self.displayattrs.append(attr)
233 self.displayattrs.append(attr)
234 attrs.add(attr)
234 attrs.add(attr)
235 else:
235 else:
236 endy = min(self.datastarty+self.mainsizey, len(self.items))
236 endy = min(self.datastarty+self.mainsizey, len(self.items))
237 for i in xrange(self.datastarty, endy):
237 for i in xrange(self.datastarty, endy):
238 for attr in ipipe.xattrs(self.items[i].item, "default"):
238 for attr in ipipe.xattrs(self.items[i].item, "default"):
239 if attr not in attrs and attr not in self.hiddenattrs:
239 if attr not in attrs and attr not in self.hiddenattrs:
240 self.displayattrs.append(attr)
240 self.displayattrs.append(attr)
241 attrs.add(attr)
241 attrs.add(attr)
242
242
243 def getrow(self, i):
243 def getrow(self, i):
244 # Return a dictinary with the attributes for the object
244 # Return a dictinary with the attributes for the object
245 # ``self.items[i]``. Attribute names are taken from
245 # ``self.items[i]``. Attribute names are taken from
246 # ``self.displayattrs`` so ``calcdisplayattrs()`` must have been
246 # ``self.displayattrs`` so ``calcdisplayattrs()`` must have been
247 # called before.
247 # called before.
248 row = {}
248 row = {}
249 item = self.items[i].item
249 item = self.items[i].item
250 for attr in self.displayattrs:
250 for attr in self.displayattrs:
251 try:
251 try:
252 value = attr.value(item)
252 value = attr.value(item)
253 except (KeyboardInterrupt, SystemExit):
253 except (KeyboardInterrupt, SystemExit):
254 raise
254 raise
255 except Exception, exc:
255 except Exception, exc:
256 value = exc
256 value = exc
257 # only store attribute if it exists (or we got an exception)
257 # only store attribute if it exists (or we got an exception)
258 if value is not ipipe.noitem:
258 if value is not ipipe.noitem:
259 # remember alignment, length and colored text
259 # remember alignment, length and colored text
260 row[attr] = ipipe.xformat(value, "cell", self.browser.maxattrlength)
260 row[attr] = ipipe.xformat(value, "cell", self.browser.maxattrlength)
261 return row
261 return row
262
262
263 def calcwidths(self):
263 def calcwidths(self):
264 # Recalculate the displayed fields and their widths.
264 # Recalculate the displayed fields and their widths.
265 # ``calcdisplayattrs()'' must have been called and the cache
265 # ``calcdisplayattrs()'' must have been called and the cache
266 # for attributes of the objects on screen (``self.displayrows``)
266 # for attributes of the objects on screen (``self.displayrows``)
267 # must have been filled. This returns a dictionary mapping
267 # must have been filled. This returns a dictionary mapping
268 # column names to widths.
268 # column names to widths.
269 self.colwidths = {}
269 self.colwidths = {}
270 for row in self.displayrows:
270 for row in self.displayrows:
271 for attr in self.displayattrs:
271 for attr in self.displayattrs:
272 try:
272 try:
273 length = row[attr][1]
273 length = row[attr][1]
274 except KeyError:
274 except KeyError:
275 length = 0
275 length = 0
276 # always add attribute to colwidths, even if it doesn't exist
276 # always add attribute to colwidths, even if it doesn't exist
277 if attr not in self.colwidths:
277 if attr not in self.colwidths:
278 self.colwidths[attr] = len(attr.name())
278 self.colwidths[attr] = len(attr.name())
279 newwidth = max(self.colwidths[attr], length)
279 newwidth = max(self.colwidths[attr], length)
280 self.colwidths[attr] = newwidth
280 self.colwidths[attr] = newwidth
281
281
282 # How many characters do we need to paint the largest item number?
282 # How many characters do we need to paint the largest item number?
283 self.numbersizex = len(str(self.datastarty+self.mainsizey-1))
283 self.numbersizex = len(str(self.datastarty+self.mainsizey-1))
284 # How must space have we got to display data?
284 # How must space have we got to display data?
285 self.mainsizex = self.browser.scrsizex-self.numbersizex-3
285 self.mainsizex = self.browser.scrsizex-self.numbersizex-3
286 # width of all columns
286 # width of all columns
287 self.datasizex = sum(self.colwidths.itervalues()) + len(self.colwidths)
287 self.datasizex = sum(self.colwidths.itervalues()) + len(self.colwidths)
288
288
289 def calcdisplayattr(self):
289 def calcdisplayattr(self):
290 # Find out which attribute the cursor is on and store this
290 # Find out which attribute the cursor is on and store this
291 # information in ``self.displayattr``.
291 # information in ``self.displayattr``.
292 pos = 0
292 pos = 0
293 for (i, attr) in enumerate(self.displayattrs):
293 for (i, attr) in enumerate(self.displayattrs):
294 if pos+self.colwidths[attr] >= self.curx:
294 if pos+self.colwidths[attr] >= self.curx:
295 self.displayattr = (i, attr)
295 self.displayattr = (i, attr)
296 break
296 break
297 pos += self.colwidths[attr]+1
297 pos += self.colwidths[attr]+1
298 else:
298 else:
299 self.displayattr = (None, ipipe.noitem)
299 self.displayattr = (None, ipipe.noitem)
300
300
301 def moveto(self, x, y, refresh=False):
301 def moveto(self, x, y, refresh=False):
302 # Move the cursor to the position ``(x,y)`` (in data coordinates,
302 # Move the cursor to the position ``(x,y)`` (in data coordinates,
303 # not in screen coordinates). If ``refresh`` is true, all cached
303 # not in screen coordinates). If ``refresh`` is true, all cached
304 # values will be recalculated (e.g. because the list has been
304 # values will be recalculated (e.g. because the list has been
305 # resorted, so screen positions etc. are no longer valid).
305 # resorted, so screen positions etc. are no longer valid).
306 olddatastarty = self.datastarty
306 olddatastarty = self.datastarty
307 oldx = self.curx
307 oldx = self.curx
308 oldy = self.cury
308 oldy = self.cury
309 x = int(x+0.5)
309 x = int(x+0.5)
310 y = int(y+0.5)
310 y = int(y+0.5)
311 newx = x # remember where we wanted to move
311 newx = x # remember where we wanted to move
312 newy = y # remember where we wanted to move
312 newy = y # remember where we wanted to move
313
313
314 scrollbordery = min(self.browser.scrollbordery, self.mainsizey//2)
314 scrollbordery = min(self.browser.scrollbordery, self.mainsizey//2)
315 scrollborderx = min(self.browser.scrollborderx, self.mainsizex//2)
315 scrollborderx = min(self.browser.scrollborderx, self.mainsizex//2)
316
316
317 # Make sure that the cursor didn't leave the main area vertically
317 # Make sure that the cursor didn't leave the main area vertically
318 if y < 0:
318 if y < 0:
319 y = 0
319 y = 0
320 # try to get enough items to fill the screen
320 # try to get enough items to fill the screen
321 self.fetch(max(y+scrollbordery+1, self.mainsizey))
321 self.fetch(max(y+scrollbordery+1, self.mainsizey))
322 if y >= len(self.items):
322 if y >= len(self.items):
323 y = max(0, len(self.items)-1)
323 y = max(0, len(self.items)-1)
324
324
325 # Make sure that the cursor stays on screen vertically
325 # Make sure that the cursor stays on screen vertically
326 if y < self.datastarty+scrollbordery:
326 if y < self.datastarty+scrollbordery:
327 self.datastarty = max(0, y-scrollbordery)
327 self.datastarty = max(0, y-scrollbordery)
328 elif y >= self.datastarty+self.mainsizey-scrollbordery:
328 elif y >= self.datastarty+self.mainsizey-scrollbordery:
329 self.datastarty = max(0, min(y-self.mainsizey+scrollbordery+1,
329 self.datastarty = max(0, min(y-self.mainsizey+scrollbordery+1,
330 len(self.items)-self.mainsizey))
330 len(self.items)-self.mainsizey))
331
331
332 if refresh: # Do we need to refresh the complete display?
332 if refresh: # Do we need to refresh the complete display?
333 self.calcdisplayattrs()
333 self.calcdisplayattrs()
334 endy = min(self.datastarty+self.mainsizey, len(self.items))
334 endy = min(self.datastarty+self.mainsizey, len(self.items))
335 self.displayrows = map(self.getrow, xrange(self.datastarty, endy))
335 self.displayrows = map(self.getrow, xrange(self.datastarty, endy))
336 self.calcwidths()
336 self.calcwidths()
337 # Did we scroll vertically => update displayrows
337 # Did we scroll vertically => update displayrows
338 # and various other attributes
338 # and various other attributes
339 elif self.datastarty != olddatastarty:
339 elif self.datastarty != olddatastarty:
340 # Recalculate which attributes we have to display
340 # Recalculate which attributes we have to display
341 olddisplayattrs = self.displayattrs
341 olddisplayattrs = self.displayattrs
342 self.calcdisplayattrs()
342 self.calcdisplayattrs()
343 # If there are new attributes, recreate the cache
343 # If there are new attributes, recreate the cache
344 if self.displayattrs != olddisplayattrs:
344 if self.displayattrs != olddisplayattrs:
345 endy = min(self.datastarty+self.mainsizey, len(self.items))
345 endy = min(self.datastarty+self.mainsizey, len(self.items))
346 self.displayrows = map(self.getrow, xrange(self.datastarty, endy))
346 self.displayrows = map(self.getrow, xrange(self.datastarty, endy))
347 elif self.datastarty<olddatastarty: # we did scroll up
347 elif self.datastarty<olddatastarty: # we did scroll up
348 # drop rows from the end
348 # drop rows from the end
349 del self.displayrows[self.datastarty-olddatastarty:]
349 del self.displayrows[self.datastarty-olddatastarty:]
350 # fetch new items
350 # fetch new items
351 for i in xrange(min(olddatastarty, self.datastarty+self.mainsizey)-1,
351 for i in xrange(min(olddatastarty, self.datastarty+self.mainsizey)-1,
352 self.datastarty-1, -1):
352 self.datastarty-1, -1):
353 try:
353 try:
354 row = self.getrow(i)
354 row = self.getrow(i)
355 except IndexError:
355 except IndexError:
356 # we didn't have enough objects to fill the screen
356 # we didn't have enough objects to fill the screen
357 break
357 break
358 self.displayrows.insert(0, row)
358 self.displayrows.insert(0, row)
359 else: # we did scroll down
359 else: # we did scroll down
360 # drop rows from the start
360 # drop rows from the start
361 del self.displayrows[:self.datastarty-olddatastarty]
361 del self.displayrows[:self.datastarty-olddatastarty]
362 # fetch new items
362 # fetch new items
363 for i in xrange(max(olddatastarty+self.mainsizey, self.datastarty),
363 for i in xrange(max(olddatastarty+self.mainsizey, self.datastarty),
364 self.datastarty+self.mainsizey):
364 self.datastarty+self.mainsizey):
365 try:
365 try:
366 row = self.getrow(i)
366 row = self.getrow(i)
367 except IndexError:
367 except IndexError:
368 # we didn't have enough objects to fill the screen
368 # we didn't have enough objects to fill the screen
369 break
369 break
370 self.displayrows.append(row)
370 self.displayrows.append(row)
371 self.calcwidths()
371 self.calcwidths()
372
372
373 # Make sure that the cursor didn't leave the data area horizontally
373 # Make sure that the cursor didn't leave the data area horizontally
374 if x < 0:
374 if x < 0:
375 x = 0
375 x = 0
376 elif x >= self.datasizex:
376 elif x >= self.datasizex:
377 x = max(0, self.datasizex-1)
377 x = max(0, self.datasizex-1)
378
378
379 # Make sure that the cursor stays on screen horizontally
379 # Make sure that the cursor stays on screen horizontally
380 if x < self.datastartx+scrollborderx:
380 if x < self.datastartx+scrollborderx:
381 self.datastartx = max(0, x-scrollborderx)
381 self.datastartx = max(0, x-scrollborderx)
382 elif x >= self.datastartx+self.mainsizex-scrollborderx:
382 elif x >= self.datastartx+self.mainsizex-scrollborderx:
383 self.datastartx = max(0, min(x-self.mainsizex+scrollborderx+1,
383 self.datastartx = max(0, min(x-self.mainsizex+scrollborderx+1,
384 self.datasizex-self.mainsizex))
384 self.datasizex-self.mainsizex))
385
385
386 if x == oldx and y == oldy and (x != newx or y != newy): # couldn't move
386 if x == oldx and y == oldy and (x != newx or y != newy): # couldn't move
387 self.browser.beep()
387 self.browser.beep()
388 else:
388 else:
389 self.curx = x
389 self.curx = x
390 self.cury = y
390 self.cury = y
391 self.calcdisplayattr()
391 self.calcdisplayattr()
392
392
393 def sort(self, key, reverse=False):
393 def sort(self, key, reverse=False):
394 """
394 """
395 Sort the currently list of items using the key function ``key``. If
395 Sort the currently list of items using the key function ``key``. If
396 ``reverse`` is true the sort order is reversed.
396 ``reverse`` is true the sort order is reversed.
397 """
397 """
398 curitem = self.items[self.cury] # Remember where the cursor is now
398 curitem = self.items[self.cury] # Remember where the cursor is now
399
399
400 # Sort items
400 # Sort items
401 def realkey(item):
401 def realkey(item):
402 return key(item.item)
402 return key(item.item)
403 self.items = ipipe.deque(sorted(self.items, key=realkey, reverse=reverse))
403 self.items = ipipe.deque(sorted(self.items, key=realkey, reverse=reverse))
404
404
405 # Find out where the object under the cursor went
405 # Find out where the object under the cursor went
406 cury = self.cury
406 cury = self.cury
407 for (i, item) in enumerate(self.items):
407 for (i, item) in enumerate(self.items):
408 if item is curitem:
408 if item is curitem:
409 cury = i
409 cury = i
410 break
410 break
411
411
412 self.moveto(self.curx, cury, refresh=True)
412 self.moveto(self.curx, cury, refresh=True)
413
413
414
414
415 class _CommandInput(object):
415 class _CommandInput(object):
416 keymap = Keymap()
416 keymap = Keymap()
417 keymap.register("left", curses.KEY_LEFT)
417 keymap.register("left", curses.KEY_LEFT)
418 keymap.register("right", curses.KEY_RIGHT)
418 keymap.register("right", curses.KEY_RIGHT)
419 keymap.register("home", curses.KEY_HOME, "\x01") # Ctrl-A
419 keymap.register("home", curses.KEY_HOME, "\x01") # Ctrl-A
420 keymap.register("end", curses.KEY_END, "\x05") # Ctrl-E
420 keymap.register("end", curses.KEY_END, "\x05") # Ctrl-E
421 # FIXME: What's happening here?
421 # FIXME: What's happening here?
422 keymap.register("backspace", curses.KEY_BACKSPACE, "\x08\x7f")
422 keymap.register("backspace", curses.KEY_BACKSPACE, "\x08\x7f")
423 keymap.register("delete", curses.KEY_DC)
423 keymap.register("delete", curses.KEY_DC)
424 keymap.register("delend", 0x0b) # Ctrl-K
424 keymap.register("delend", 0x0b) # Ctrl-K
425 keymap.register("execute", "\r\n")
425 keymap.register("execute", "\r\n")
426 keymap.register("up", curses.KEY_UP)
426 keymap.register("up", curses.KEY_UP)
427 keymap.register("down", curses.KEY_DOWN)
427 keymap.register("down", curses.KEY_DOWN)
428 keymap.register("incsearchup", curses.KEY_PPAGE)
428 keymap.register("incsearchup", curses.KEY_PPAGE)
429 keymap.register("incsearchdown", curses.KEY_NPAGE)
429 keymap.register("incsearchdown", curses.KEY_NPAGE)
430 keymap.register("exit", "\x18"), # Ctrl-X
430 keymap.register("exit", "\x18"), # Ctrl-X
431
431
432 def __init__(self, prompt):
432 def __init__(self, prompt):
433 self.prompt = prompt
433 self.prompt = prompt
434 self.history = []
434 self.history = []
435 self.maxhistory = 100
435 self.maxhistory = 100
436 self.input = ""
436 self.input = ""
437 self.curx = 0
437 self.curx = 0
438 self.cury = -1 # blank line
438 self.cury = -1 # blank line
439
439
440 def start(self):
440 def start(self):
441 self.input = ""
441 self.input = ""
442 self.curx = 0
442 self.curx = 0
443 self.cury = -1 # blank line
443 self.cury = -1 # blank line
444
444
445 def handlekey(self, browser, key):
445 def handlekey(self, browser, key):
446 cmdname = self.keymap.get(key, None)
446 cmdname = self.keymap.get(key, None)
447 if cmdname is not None:
447 if cmdname is not None:
448 cmdfunc = getattr(self, "cmd_%s" % cmdname, None)
448 cmdfunc = getattr(self, "cmd_%s" % cmdname, None)
449 if cmdfunc is not None:
449 if cmdfunc is not None:
450 return cmdfunc(browser)
450 return cmdfunc(browser)
451 curses.beep()
451 curses.beep()
452 elif key != -1:
452 elif key != -1:
453 try:
453 try:
454 char = chr(key)
454 char = chr(key)
455 except ValueError:
455 except ValueError:
456 curses.beep()
456 curses.beep()
457 else:
457 else:
458 return self.handlechar(browser, char)
458 return self.handlechar(browser, char)
459
459
460 def handlechar(self, browser, char):
460 def handlechar(self, browser, char):
461 self.input = self.input[:self.curx] + char + self.input[self.curx:]
461 self.input = self.input[:self.curx] + char + self.input[self.curx:]
462 self.curx += 1
462 self.curx += 1
463 return True
463 return True
464
464
465 def dohistory(self):
465 def dohistory(self):
466 self.history.insert(0, self.input)
466 self.history.insert(0, self.input)
467 del self.history[:-self.maxhistory]
467 del self.history[:-self.maxhistory]
468
468
469 def cmd_backspace(self, browser):
469 def cmd_backspace(self, browser):
470 if self.curx:
470 if self.curx:
471 self.input = self.input[:self.curx-1] + self.input[self.curx:]
471 self.input = self.input[:self.curx-1] + self.input[self.curx:]
472 self.curx -= 1
472 self.curx -= 1
473 return True
473 return True
474 else:
474 else:
475 curses.beep()
475 curses.beep()
476
476
477 def cmd_delete(self, browser):
477 def cmd_delete(self, browser):
478 if self.curx<len(self.input):
478 if self.curx<len(self.input):
479 self.input = self.input[:self.curx] + self.input[self.curx+1:]
479 self.input = self.input[:self.curx] + self.input[self.curx+1:]
480 return True
480 return True
481 else:
481 else:
482 curses.beep()
482 curses.beep()
483
483
484 def cmd_delend(self, browser):
484 def cmd_delend(self, browser):
485 if self.curx<len(self.input):
485 if self.curx<len(self.input):
486 self.input = self.input[:self.curx]
486 self.input = self.input[:self.curx]
487 return True
487 return True
488
488
489 def cmd_left(self, browser):
489 def cmd_left(self, browser):
490 if self.curx:
490 if self.curx:
491 self.curx -= 1
491 self.curx -= 1
492 return True
492 return True
493 else:
493 else:
494 curses.beep()
494 curses.beep()
495
495
496 def cmd_right(self, browser):
496 def cmd_right(self, browser):
497 if self.curx < len(self.input):
497 if self.curx < len(self.input):
498 self.curx += 1
498 self.curx += 1
499 return True
499 return True
500 else:
500 else:
501 curses.beep()
501 curses.beep()
502
502
503 def cmd_home(self, browser):
503 def cmd_home(self, browser):
504 if self.curx:
504 if self.curx:
505 self.curx = 0
505 self.curx = 0
506 return True
506 return True
507 else:
507 else:
508 curses.beep()
508 curses.beep()
509
509
510 def cmd_end(self, browser):
510 def cmd_end(self, browser):
511 if self.curx < len(self.input):
511 if self.curx < len(self.input):
512 self.curx = len(self.input)
512 self.curx = len(self.input)
513 return True
513 return True
514 else:
514 else:
515 curses.beep()
515 curses.beep()
516
516
517 def cmd_up(self, browser):
517 def cmd_up(self, browser):
518 if self.cury < len(self.history)-1:
518 if self.cury < len(self.history)-1:
519 self.cury += 1
519 self.cury += 1
520 self.input = self.history[self.cury]
520 self.input = self.history[self.cury]
521 self.curx = len(self.input)
521 self.curx = len(self.input)
522 return True
522 return True
523 else:
523 else:
524 curses.beep()
524 curses.beep()
525
525
526 def cmd_down(self, browser):
526 def cmd_down(self, browser):
527 if self.cury >= 0:
527 if self.cury >= 0:
528 self.cury -= 1
528 self.cury -= 1
529 if self.cury>=0:
529 if self.cury>=0:
530 self.input = self.history[self.cury]
530 self.input = self.history[self.cury]
531 else:
531 else:
532 self.input = ""
532 self.input = ""
533 self.curx = len(self.input)
533 self.curx = len(self.input)
534 return True
534 return True
535 else:
535 else:
536 curses.beep()
536 curses.beep()
537
537
538 def cmd_incsearchup(self, browser):
538 def cmd_incsearchup(self, browser):
539 prefix = self.input[:self.curx]
539 prefix = self.input[:self.curx]
540 cury = self.cury
540 cury = self.cury
541 while True:
541 while True:
542 cury += 1
542 cury += 1
543 if cury >= len(self.history):
543 if cury >= len(self.history):
544 break
544 break
545 if self.history[cury].startswith(prefix):
545 if self.history[cury].startswith(prefix):
546 self.input = self.history[cury]
546 self.input = self.history[cury]
547 self.cury = cury
547 self.cury = cury
548 return True
548 return True
549 curses.beep()
549 curses.beep()
550
550
551 def cmd_incsearchdown(self, browser):
551 def cmd_incsearchdown(self, browser):
552 prefix = self.input[:self.curx]
552 prefix = self.input[:self.curx]
553 cury = self.cury
553 cury = self.cury
554 while True:
554 while True:
555 cury -= 1
555 cury -= 1
556 if cury <= 0:
556 if cury <= 0:
557 break
557 break
558 if self.history[cury].startswith(prefix):
558 if self.history[cury].startswith(prefix):
559 self.input = self.history[self.cury]
559 self.input = self.history[self.cury]
560 self.cury = cury
560 self.cury = cury
561 return True
561 return True
562 curses.beep()
562 curses.beep()
563
563
564 def cmd_exit(self, browser):
564 def cmd_exit(self, browser):
565 browser.mode = "default"
565 browser.mode = "default"
566 return True
566 return True
567
567
568 def cmd_execute(self, browser):
568 def cmd_execute(self, browser):
569 raise NotImplementedError
569 raise NotImplementedError
570
570
571
571
572 class _CommandGoto(_CommandInput):
572 class _CommandGoto(_CommandInput):
573 def __init__(self):
573 def __init__(self):
574 _CommandInput.__init__(self, "goto object #")
574 _CommandInput.__init__(self, "goto object #")
575
575
576 def handlechar(self, browser, char):
576 def handlechar(self, browser, char):
577 # Only accept digits
577 # Only accept digits
578 if not "0" <= char <= "9":
578 if not "0" <= char <= "9":
579 curses.beep()
579 curses.beep()
580 else:
580 else:
581 return _CommandInput.handlechar(self, browser, char)
581 return _CommandInput.handlechar(self, browser, char)
582
582
583 def cmd_execute(self, browser):
583 def cmd_execute(self, browser):
584 level = browser.levels[-1]
584 level = browser.levels[-1]
585 if self.input:
585 if self.input:
586 self.dohistory()
586 self.dohistory()
587 level.moveto(level.curx, int(self.input))
587 level.moveto(level.curx, int(self.input))
588 browser.mode = "default"
588 browser.mode = "default"
589 return True
589 return True
590
590
591
591
592 class _CommandFind(_CommandInput):
592 class _CommandFind(_CommandInput):
593 def __init__(self):
593 def __init__(self):
594 _CommandInput.__init__(self, "find expression")
594 _CommandInput.__init__(self, "find expression")
595
595
596 def cmd_execute(self, browser):
596 def cmd_execute(self, browser):
597 level = browser.levels[-1]
597 level = browser.levels[-1]
598 if self.input:
598 if self.input:
599 self.dohistory()
599 self.dohistory()
600 while True:
600 while True:
601 cury = level.cury
601 cury = level.cury
602 level.moveto(level.curx, cury+1)
602 level.moveto(level.curx, cury+1)
603 if cury == level.cury:
603 if cury == level.cury:
604 curses.beep()
604 curses.beep()
605 break # hit end
605 break # hit end
606 item = level.items[level.cury].item
606 item = level.items[level.cury].item
607 try:
607 try:
608 globals = ipipe.getglobals(None)
608 globals = ipipe.getglobals(None)
609 if eval(self.input, globals, ipipe.AttrNamespace(item)):
609 if eval(self.input, globals, ipipe.AttrNamespace(item)):
610 break # found something
610 break # found something
611 except (KeyboardInterrupt, SystemExit):
611 except (KeyboardInterrupt, SystemExit):
612 raise
612 raise
613 except Exception, exc:
613 except Exception, exc:
614 browser.report(exc)
614 browser.report(exc)
615 curses.beep()
615 curses.beep()
616 break # break on error
616 break # break on error
617 browser.mode = "default"
617 browser.mode = "default"
618 return True
618 return True
619
619
620
620
621 class _CommandFindBackwards(_CommandInput):
621 class _CommandFindBackwards(_CommandInput):
622 def __init__(self):
622 def __init__(self):
623 _CommandInput.__init__(self, "find backwards expression")
623 _CommandInput.__init__(self, "find backwards expression")
624
624
625 def cmd_execute(self, browser):
625 def cmd_execute(self, browser):
626 level = browser.levels[-1]
626 level = browser.levels[-1]
627 if self.input:
627 if self.input:
628 self.dohistory()
628 self.dohistory()
629 while level.cury:
629 while level.cury:
630 level.moveto(level.curx, level.cury-1)
630 level.moveto(level.curx, level.cury-1)
631 item = level.items[level.cury].item
631 item = level.items[level.cury].item
632 try:
632 try:
633 globals = ipipe.getglobals(None)
633 globals = ipipe.getglobals(None)
634 if eval(self.input, globals, ipipe.AttrNamespace(item)):
634 if eval(self.input, globals, ipipe.AttrNamespace(item)):
635 break # found something
635 break # found something
636 except (KeyboardInterrupt, SystemExit):
636 except (KeyboardInterrupt, SystemExit):
637 raise
637 raise
638 except Exception, exc:
638 except Exception, exc:
639 browser.report(exc)
639 browser.report(exc)
640 curses.beep()
640 curses.beep()
641 break # break on error
641 break # break on error
642 else:
642 else:
643 curses.beep()
643 curses.beep()
644 browser.mode = "default"
644 browser.mode = "default"
645 return True
645 return True
646
646
647
647
648 class ibrowse(ipipe.Display):
648 class ibrowse(ipipe.Display):
649 # Show this many lines from the previous screen when paging horizontally
649 # Show this many lines from the previous screen when paging horizontally
650 pageoverlapx = 1
650 pageoverlapx = 1
651
651
652 # Show this many lines from the previous screen when paging vertically
652 # Show this many lines from the previous screen when paging vertically
653 pageoverlapy = 1
653 pageoverlapy = 1
654
654
655 # Start scrolling when the cursor is less than this number of columns
655 # Start scrolling when the cursor is less than this number of columns
656 # away from the left or right screen edge
656 # away from the left or right screen edge
657 scrollborderx = 10
657 scrollborderx = 10
658
658
659 # Start scrolling when the cursor is less than this number of lines
659 # Start scrolling when the cursor is less than this number of lines
660 # away from the top or bottom screen edge
660 # away from the top or bottom screen edge
661 scrollbordery = 5
661 scrollbordery = 5
662
662
663 # Accelerate by this factor when scrolling horizontally
663 # Accelerate by this factor when scrolling horizontally
664 acceleratex = 1.05
664 acceleratex = 1.05
665
665
666 # Accelerate by this factor when scrolling vertically
666 # Accelerate by this factor when scrolling vertically
667 acceleratey = 1.05
667 acceleratey = 1.05
668
668
669 # The maximum horizontal scroll speed
669 # The maximum horizontal scroll speed
670 # (as a factor of the screen width (i.e. 0.5 == half a screen width)
670 # (as a factor of the screen width (i.e. 0.5 == half a screen width)
671 maxspeedx = 0.5
671 maxspeedx = 0.5
672
672
673 # The maximum vertical scroll speed
673 # The maximum vertical scroll speed
674 # (as a factor of the screen height (i.e. 0.5 == half a screen height)
674 # (as a factor of the screen height (i.e. 0.5 == half a screen height)
675 maxspeedy = 0.5
675 maxspeedy = 0.5
676
676
677 # The maximum number of header lines for browser level
677 # The maximum number of header lines for browser level
678 # if the nesting is deeper, only the innermost levels are displayed
678 # if the nesting is deeper, only the innermost levels are displayed
679 maxheaders = 5
679 maxheaders = 5
680
680
681 # The approximate maximum length of a column entry
681 # The approximate maximum length of a column entry
682 maxattrlength = 200
682 maxattrlength = 200
683
683
684 # Styles for various parts of the GUI
684 # Styles for various parts of the GUI
685 style_objheadertext = astyle.Style.fromstr("white:black:bold|reverse")
685 style_objheadertext = astyle.Style.fromstr("white:black:bold|reverse")
686 style_objheadernumber = astyle.Style.fromstr("white:blue:bold|reverse")
686 style_objheadernumber = astyle.Style.fromstr("white:blue:bold|reverse")
687 style_objheaderobject = astyle.Style.fromstr("white:black:reverse")
687 style_objheaderobject = astyle.Style.fromstr("white:black:reverse")
688 style_colheader = astyle.Style.fromstr("blue:white:reverse")
688 style_colheader = astyle.Style.fromstr("blue:white:reverse")
689 style_colheaderhere = astyle.Style.fromstr("green:black:bold|reverse")
689 style_colheaderhere = astyle.Style.fromstr("green:black:bold|reverse")
690 style_colheadersep = astyle.Style.fromstr("blue:black:reverse")
690 style_colheadersep = astyle.Style.fromstr("blue:black:reverse")
691 style_number = astyle.Style.fromstr("blue:white:reverse")
691 style_number = astyle.Style.fromstr("blue:white:reverse")
692 style_numberhere = astyle.Style.fromstr("green:black:bold|reverse")
692 style_numberhere = astyle.Style.fromstr("green:black:bold|reverse")
693 style_sep = astyle.Style.fromstr("blue:black")
693 style_sep = astyle.Style.fromstr("blue:black")
694 style_data = astyle.Style.fromstr("white:black")
694 style_data = astyle.Style.fromstr("white:black")
695 style_datapad = astyle.Style.fromstr("blue:black:bold")
695 style_datapad = astyle.Style.fromstr("blue:black:bold")
696 style_footer = astyle.Style.fromstr("black:white")
696 style_footer = astyle.Style.fromstr("black:white")
697 style_report = astyle.Style.fromstr("white:black")
697 style_report = astyle.Style.fromstr("white:black")
698
698
699 # Column separator in header
699 # Column separator in header
700 headersepchar = "|"
700 headersepchar = "|"
701
701
702 # Character for padding data cell entries
702 # Character for padding data cell entries
703 datapadchar = "."
703 datapadchar = "."
704
704
705 # Column separator in data area
705 # Column separator in data area
706 datasepchar = "|"
706 datasepchar = "|"
707
707
708 # Character to use for "empty" cell (i.e. for non-existing attributes)
708 # Character to use for "empty" cell (i.e. for non-existing attributes)
709 nodatachar = "-"
709 nodatachar = "-"
710
710
711 # Prompts for modes that require keyboard input
711 # Prompts for modes that require keyboard input
712 prompts = {
712 prompts = {
713 "goto": _CommandGoto(),
713 "goto": _CommandGoto(),
714 "find": _CommandFind(),
714 "find": _CommandFind(),
715 "findbackwards": _CommandFindBackwards()
715 "findbackwards": _CommandFindBackwards()
716 }
716 }
717
717
718 # Maps curses key codes to "function" names
718 # Maps curses key codes to "function" names
719 keymap = Keymap()
719 keymap = Keymap()
720 keymap.register("quit", "q")
720 keymap.register("quit", "q")
721 keymap.register("up", curses.KEY_UP)
721 keymap.register("up", curses.KEY_UP)
722 keymap.register("down", curses.KEY_DOWN)
722 keymap.register("down", curses.KEY_DOWN)
723 keymap.register("pageup", curses.KEY_PPAGE)
723 keymap.register("pageup", curses.KEY_PPAGE)
724 keymap.register("pagedown", curses.KEY_NPAGE)
724 keymap.register("pagedown", curses.KEY_NPAGE)
725 keymap.register("left", curses.KEY_LEFT)
725 keymap.register("left", curses.KEY_LEFT)
726 keymap.register("right", curses.KEY_RIGHT)
726 keymap.register("right", curses.KEY_RIGHT)
727 keymap.register("home", curses.KEY_HOME, "\x01")
727 keymap.register("home", curses.KEY_HOME, "\x01")
728 keymap.register("end", curses.KEY_END, "\x05")
728 keymap.register("end", curses.KEY_END, "\x05")
729 keymap.register("prevattr", "<\x1b")
729 keymap.register("prevattr", "<\x1b")
730 keymap.register("nextattr", ">\t")
730 keymap.register("nextattr", ">\t")
731 keymap.register("pick", "p")
731 keymap.register("pick", "p")
732 keymap.register("pickattr", "P")
732 keymap.register("pickattr", "P")
733 keymap.register("pickallattrs", "C")
733 keymap.register("pickallattrs", "C")
734 keymap.register("pickmarked", "m")
734 keymap.register("pickmarked", "m")
735 keymap.register("pickmarkedattr", "M")
735 keymap.register("pickmarkedattr", "M")
736 keymap.register("enterdefault", "\r\n")
736 keymap.register("enterdefault", "\r\n")
737 # FIXME: What's happening here?
737 # FIXME: What's happening here?
738 keymap.register("leave", curses.KEY_BACKSPACE, "x\x08\x7f")
738 keymap.register("leave", curses.KEY_BACKSPACE, "x\x08\x7f")
739 keymap.register("hideattr", "h")
739 keymap.register("hideattr", "h")
740 keymap.register("unhideattrs", "H")
740 keymap.register("unhideattrs", "H")
741 keymap.register("help", "?")
741 keymap.register("help", "?")
742 keymap.register("enter", "e")
742 keymap.register("enter", "e")
743 keymap.register("enterattr", "E")
743 keymap.register("enterattr", "E")
744 keymap.register("detail", "d")
744 keymap.register("detail", "d")
745 keymap.register("detailattr", "D")
745 keymap.register("detailattr", "D")
746 keymap.register("tooglemark", " ")
746 keymap.register("tooglemark", " ")
747 keymap.register("markrange", "r")
747 keymap.register("markrange", "r")
748 keymap.register("sortattrasc", "v")
748 keymap.register("sortattrasc", "v")
749 keymap.register("sortattrdesc", "V")
749 keymap.register("sortattrdesc", "V")
750 keymap.register("goto", "g")
750 keymap.register("goto", "g")
751 keymap.register("find", "f")
751 keymap.register("find", "f")
752 keymap.register("findbackwards", "b")
752 keymap.register("findbackwards", "b")
753
753
754 def __init__(self, *attrs):
754 def __init__(self, *attrs):
755 """
755 """
756 Create a new browser. If ``attrs`` is not empty, it is the list
756 Create a new browser. If ``attrs`` is not empty, it is the list
757 of attributes that will be displayed in the browser, otherwise
757 of attributes that will be displayed in the browser, otherwise
758 these will be determined by the objects on screen.
758 these will be determined by the objects on screen.
759 """
759 """
760 self.attrs = attrs
760 self.attrs = attrs
761
761
762 # Stack of browser levels
762 # Stack of browser levels
763 self.levels = []
763 self.levels = []
764 # how many colums to scroll (Changes when accelerating)
764 # how many colums to scroll (Changes when accelerating)
765 self.stepx = 1.
765 self.stepx = 1.
766
766
767 # how many rows to scroll (Changes when accelerating)
767 # how many rows to scroll (Changes when accelerating)
768 self.stepy = 1.
768 self.stepy = 1.
769
769
770 # Beep on the edges of the data area? (Will be set to ``False``
770 # Beep on the edges of the data area? (Will be set to ``False``
771 # once the cursor hits the edge of the screen, so we don't get
771 # once the cursor hits the edge of the screen, so we don't get
772 # multiple beeps).
772 # multiple beeps).
773 self._dobeep = True
773 self._dobeep = True
774
774
775 # Cache for registered ``curses`` colors and styles.
775 # Cache for registered ``curses`` colors and styles.
776 self._styles = {}
776 self._styles = {}
777 self._colors = {}
777 self._colors = {}
778 self._maxcolor = 1
778 self._maxcolor = 1
779
779
780 # How many header lines do we want to paint (the numbers of levels
780 # How many header lines do we want to paint (the numbers of levels
781 # we have, but with an upper bound)
781 # we have, but with an upper bound)
782 self._headerlines = 1
782 self._headerlines = 1
783
783
784 # Index of first header line
784 # Index of first header line
785 self._firstheaderline = 0
785 self._firstheaderline = 0
786
786
787 # curses window
787 # curses window
788 self.scr = None
788 self.scr = None
789 # report in the footer line (error, executed command etc.)
789 # report in the footer line (error, executed command etc.)
790 self._report = None
790 self._report = None
791
791
792 # value to be returned to the caller (set by commands)
792 # value to be returned to the caller (set by commands)
793 self.returnvalue = None
793 self.returnvalue = None
794
794
795 # The mode the browser is in
795 # The mode the browser is in
796 # e.g. normal browsing or entering an argument for a command
796 # e.g. normal browsing or entering an argument for a command
797 self.mode = "default"
797 self.mode = "default"
798
798
799 # set by the SIGWINCH signal handler
799 # set by the SIGWINCH signal handler
800 self.resized = False
800 self.resized = False
801
801
802 def nextstepx(self, step):
802 def nextstepx(self, step):
803 """
803 """
804 Accelerate horizontally.
804 Accelerate horizontally.
805 """
805 """
806 return max(1., min(step*self.acceleratex,
806 return max(1., min(step*self.acceleratex,
807 self.maxspeedx*self.levels[-1].mainsizex))
807 self.maxspeedx*self.levels[-1].mainsizex))
808
808
809 def nextstepy(self, step):
809 def nextstepy(self, step):
810 """
810 """
811 Accelerate vertically.
811 Accelerate vertically.
812 """
812 """
813 return max(1., min(step*self.acceleratey,
813 return max(1., min(step*self.acceleratey,
814 self.maxspeedy*self.levels[-1].mainsizey))
814 self.maxspeedy*self.levels[-1].mainsizey))
815
815
816 def getstyle(self, style):
816 def getstyle(self, style):
817 """
817 """
818 Register the ``style`` with ``curses`` or get it from the cache,
818 Register the ``style`` with ``curses`` or get it from the cache,
819 if it has been registered before.
819 if it has been registered before.
820 """
820 """
821 try:
821 try:
822 return self._styles[style.fg, style.bg, style.attrs]
822 return self._styles[style.fg, style.bg, style.attrs]
823 except KeyError:
823 except KeyError:
824 attrs = 0
824 attrs = 0
825 for b in astyle.A2CURSES:
825 for b in astyle.A2CURSES:
826 if style.attrs & b:
826 if style.attrs & b:
827 attrs |= astyle.A2CURSES[b]
827 attrs |= astyle.A2CURSES[b]
828 try:
828 try:
829 color = self._colors[style.fg, style.bg]
829 color = self._colors[style.fg, style.bg]
830 except KeyError:
830 except KeyError:
831 curses.init_pair(
831 curses.init_pair(
832 self._maxcolor,
832 self._maxcolor,
833 astyle.COLOR2CURSES[style.fg],
833 astyle.COLOR2CURSES[style.fg],
834 astyle.COLOR2CURSES[style.bg]
834 astyle.COLOR2CURSES[style.bg]
835 )
835 )
836 color = curses.color_pair(self._maxcolor)
836 color = curses.color_pair(self._maxcolor)
837 self._colors[style.fg, style.bg] = color
837 self._colors[style.fg, style.bg] = color
838 self._maxcolor += 1
838 self._maxcolor += 1
839 c = color | attrs
839 c = color | attrs
840 self._styles[style.fg, style.bg, style.attrs] = c
840 self._styles[style.fg, style.bg, style.attrs] = c
841 return c
841 return c
842
842
843 def addstr(self, y, x, begx, endx, text, style):
843 def addstr(self, y, x, begx, endx, text, style):
844 """
844 """
845 A version of ``curses.addstr()`` that can handle ``x`` coordinates
845 A version of ``curses.addstr()`` that can handle ``x`` coordinates
846 that are outside the screen.
846 that are outside the screen.
847 """
847 """
848 text2 = text[max(0, begx-x):max(0, endx-x)]
848 text2 = text[max(0, begx-x):max(0, endx-x)]
849 if text2:
849 if text2:
850 self.scr.addstr(y, max(x, begx), text2, self.getstyle(style))
850 self.scr.addstr(y, max(x, begx), text2, self.getstyle(style))
851 return len(text)
851 return len(text)
852
852
853 def addchr(self, y, x, begx, endx, c, l, style):
853 def addchr(self, y, x, begx, endx, c, l, style):
854 x0 = max(x, begx)
854 x0 = max(x, begx)
855 x1 = min(x+l, endx)
855 x1 = min(x+l, endx)
856 if x1>x0:
856 if x1>x0:
857 self.scr.addstr(y, x0, c*(x1-x0), self.getstyle(style))
857 self.scr.addstr(y, x0, c*(x1-x0), self.getstyle(style))
858 return l
858 return l
859
859
860 def _calcheaderlines(self, levels):
860 def _calcheaderlines(self, levels):
861 # Calculate how many headerlines do we have to display, if we have
861 # Calculate how many headerlines do we have to display, if we have
862 # ``levels`` browser levels
862 # ``levels`` browser levels
863 if levels is None:
863 if levels is None:
864 levels = len(self.levels)
864 levels = len(self.levels)
865 self._headerlines = min(self.maxheaders, levels)
865 self._headerlines = min(self.maxheaders, levels)
866 self._firstheaderline = levels-self._headerlines
866 self._firstheaderline = levels-self._headerlines
867
867
868 def getstylehere(self, style):
868 def getstylehere(self, style):
869 """
869 """
870 Return a style for displaying the original style ``style``
870 Return a style for displaying the original style ``style``
871 in the row the cursor is on.
871 in the row the cursor is on.
872 """
872 """
873 return astyle.Style(style.fg, astyle.COLOR_BLUE, style.attrs | astyle.A_BOLD)
873 return astyle.Style(style.fg, astyle.COLOR_BLUE, style.attrs | astyle.A_BOLD)
874
874
875 def report(self, msg):
875 def report(self, msg):
876 """
876 """
877 Store the message ``msg`` for display below the footer line. This
877 Store the message ``msg`` for display below the footer line. This
878 will be displayed as soon as the screen is redrawn.
878 will be displayed as soon as the screen is redrawn.
879 """
879 """
880 self._report = msg
880 self._report = msg
881
881
882 def enter(self, item, mode, *attrs):
882 def enter(self, item, mode, *attrs):
883 """
883 """
884 Enter the object ``item`` in the mode ``mode``. If ``attrs`` is
884 Enter the object ``item`` in the mode ``mode``. If ``attrs`` is
885 specified, it will be used as a fixed list of attributes to display.
885 specified, it will be used as a fixed list of attributes to display.
886 """
886 """
887 try:
887 try:
888 iterator = ipipe.xiter(item, mode)
888 iterator = ipipe.xiter(item, mode)
889 except (KeyboardInterrupt, SystemExit):
889 except (KeyboardInterrupt, SystemExit):
890 raise
890 raise
891 except Exception, exc:
891 except Exception, exc:
892 curses.beep()
892 curses.beep()
893 self.report(exc)
893 self.report(exc)
894 else:
894 else:
895 self._calcheaderlines(len(self.levels)+1)
895 self._calcheaderlines(len(self.levels)+1)
896 level = _BrowserLevel(
896 level = _BrowserLevel(
897 self,
897 self,
898 item,
898 item,
899 iterator,
899 iterator,
900 self.scrsizey-1-self._headerlines-2,
900 self.scrsizey-1-self._headerlines-2,
901 *attrs
901 *attrs
902 )
902 )
903 self.levels.append(level)
903 self.levels.append(level)
904
904
905 def startkeyboardinput(self, mode):
905 def startkeyboardinput(self, mode):
906 """
906 """
907 Enter mode ``mode``, which requires keyboard input.
907 Enter mode ``mode``, which requires keyboard input.
908 """
908 """
909 self.mode = mode
909 self.mode = mode
910 self.prompts[mode].start()
910 self.prompts[mode].start()
911
911
912 def keylabel(self, keycode):
912 def keylabel(self, keycode):
913 """
913 """
914 Return a pretty name for the ``curses`` key ``keycode`` (used in the
914 Return a pretty name for the ``curses`` key ``keycode`` (used in the
915 help screen and in reports about unassigned keys).
915 help screen and in reports about unassigned keys).
916 """
916 """
917 if keycode <= 0xff:
917 if keycode <= 0xff:
918 specialsnames = {
918 specialsnames = {
919 ord("\n"): "RETURN",
919 ord("\n"): "RETURN",
920 ord(" "): "SPACE",
920 ord(" "): "SPACE",
921 ord("\t"): "TAB",
921 ord("\t"): "TAB",
922 ord("\x7f"): "DELETE",
922 ord("\x7f"): "DELETE",
923 ord("\x08"): "BACKSPACE",
923 ord("\x08"): "BACKSPACE",
924 }
924 }
925 if keycode in specialsnames:
925 if keycode in specialsnames:
926 return specialsnames[keycode]
926 return specialsnames[keycode]
927 elif 0x00 < keycode < 0x20:
927 elif 0x00 < keycode < 0x20:
928 return "CTRL-%s" % chr(keycode + 64)
928 return "CTRL-%s" % chr(keycode + 64)
929 return repr(chr(keycode))
929 return repr(chr(keycode))
930 for name in dir(curses):
930 for name in dir(curses):
931 if name.startswith("KEY_") and getattr(curses, name) == keycode:
931 if name.startswith("KEY_") and getattr(curses, name) == keycode:
932 return name
932 return name
933 return str(keycode)
933 return str(keycode)
934
934
935 def beep(self, force=False):
935 def beep(self, force=False):
936 if force or self._dobeep:
936 if force or self._dobeep:
937 curses.beep()
937 curses.beep()
938 # don't beep again (as long as the same key is pressed)
938 # don't beep again (as long as the same key is pressed)
939 self._dobeep = False
939 self._dobeep = False
940
940
941 def cmd_up(self):
941 def cmd_up(self):
942 """
942 """
943 Move the cursor to the previous row.
943 Move the cursor to the previous row.
944 """
944 """
945 level = self.levels[-1]
945 level = self.levels[-1]
946 self.report("up")
946 self.report("up")
947 level.moveto(level.curx, level.cury-self.stepy)
947 level.moveto(level.curx, level.cury-self.stepy)
948
948
949 def cmd_down(self):
949 def cmd_down(self):
950 """
950 """
951 Move the cursor to the next row.
951 Move the cursor to the next row.
952 """
952 """
953 level = self.levels[-1]
953 level = self.levels[-1]
954 self.report("down")
954 self.report("down")
955 level.moveto(level.curx, level.cury+self.stepy)
955 level.moveto(level.curx, level.cury+self.stepy)
956
956
957 def cmd_pageup(self):
957 def cmd_pageup(self):
958 """
958 """
959 Move the cursor up one page.
959 Move the cursor up one page.
960 """
960 """
961 level = self.levels[-1]
961 level = self.levels[-1]
962 self.report("page up")
962 self.report("page up")
963 level.moveto(level.curx, level.cury-level.mainsizey+self.pageoverlapy)
963 level.moveto(level.curx, level.cury-level.mainsizey+self.pageoverlapy)
964
964
965 def cmd_pagedown(self):
965 def cmd_pagedown(self):
966 """
966 """
967 Move the cursor down one page.
967 Move the cursor down one page.
968 """
968 """
969 level = self.levels[-1]
969 level = self.levels[-1]
970 self.report("page down")
970 self.report("page down")
971 level.moveto(level.curx, level.cury+level.mainsizey-self.pageoverlapy)
971 level.moveto(level.curx, level.cury+level.mainsizey-self.pageoverlapy)
972
972
973 def cmd_left(self):
973 def cmd_left(self):
974 """
974 """
975 Move the cursor left.
975 Move the cursor left.
976 """
976 """
977 level = self.levels[-1]
977 level = self.levels[-1]
978 self.report("left")
978 self.report("left")
979 level.moveto(level.curx-self.stepx, level.cury)
979 level.moveto(level.curx-self.stepx, level.cury)
980
980
981 def cmd_right(self):
981 def cmd_right(self):
982 """
982 """
983 Move the cursor right.
983 Move the cursor right.
984 """
984 """
985 level = self.levels[-1]
985 level = self.levels[-1]
986 self.report("right")
986 self.report("right")
987 level.moveto(level.curx+self.stepx, level.cury)
987 level.moveto(level.curx+self.stepx, level.cury)
988
988
989 def cmd_home(self):
989 def cmd_home(self):
990 """
990 """
991 Move the cursor to the first column.
991 Move the cursor to the first column.
992 """
992 """
993 level = self.levels[-1]
993 level = self.levels[-1]
994 self.report("home")
994 self.report("home")
995 level.moveto(0, level.cury)
995 level.moveto(0, level.cury)
996
996
997 def cmd_end(self):
997 def cmd_end(self):
998 """
998 """
999 Move the cursor to the last column.
999 Move the cursor to the last column.
1000 """
1000 """
1001 level = self.levels[-1]
1001 level = self.levels[-1]
1002 self.report("end")
1002 self.report("end")
1003 level.moveto(level.datasizex+level.mainsizey-self.pageoverlapx, level.cury)
1003 level.moveto(level.datasizex+level.mainsizey-self.pageoverlapx, level.cury)
1004
1004
1005 def cmd_prevattr(self):
1005 def cmd_prevattr(self):
1006 """
1006 """
1007 Move the cursor one attribute column to the left.
1007 Move the cursor one attribute column to the left.
1008 """
1008 """
1009 level = self.levels[-1]
1009 level = self.levels[-1]
1010 if level.displayattr[0] is None or level.displayattr[0] == 0:
1010 if level.displayattr[0] is None or level.displayattr[0] == 0:
1011 self.beep()
1011 self.beep()
1012 else:
1012 else:
1013 self.report("prevattr")
1013 self.report("prevattr")
1014 pos = 0
1014 pos = 0
1015 for (i, attrname) in enumerate(level.displayattrs):
1015 for (i, attrname) in enumerate(level.displayattrs):
1016 if i == level.displayattr[0]-1:
1016 if i == level.displayattr[0]-1:
1017 break
1017 break
1018 pos += level.colwidths[attrname] + 1
1018 pos += level.colwidths[attrname] + 1
1019 level.moveto(pos, level.cury)
1019 level.moveto(pos, level.cury)
1020
1020
1021 def cmd_nextattr(self):
1021 def cmd_nextattr(self):
1022 """
1022 """
1023 Move the cursor one attribute column to the right.
1023 Move the cursor one attribute column to the right.
1024 """
1024 """
1025 level = self.levels[-1]
1025 level = self.levels[-1]
1026 if level.displayattr[0] is None or level.displayattr[0] == len(level.displayattrs)-1:
1026 if level.displayattr[0] is None or level.displayattr[0] == len(level.displayattrs)-1:
1027 self.beep()
1027 self.beep()
1028 else:
1028 else:
1029 self.report("nextattr")
1029 self.report("nextattr")
1030 pos = 0
1030 pos = 0
1031 for (i, attrname) in enumerate(level.displayattrs):
1031 for (i, attrname) in enumerate(level.displayattrs):
1032 if i == level.displayattr[0]+1:
1032 if i == level.displayattr[0]+1:
1033 break
1033 break
1034 pos += level.colwidths[attrname] + 1
1034 pos += level.colwidths[attrname] + 1
1035 level.moveto(pos, level.cury)
1035 level.moveto(pos, level.cury)
1036
1036
1037 def cmd_pick(self):
1037 def cmd_pick(self):
1038 """
1038 """
1039 'Pick' the object under the cursor (i.e. the row the cursor is on).
1039 'Pick' the object under the cursor (i.e. the row the cursor is on).
1040 This leaves the browser and returns the picked object to the caller.
1040 This leaves the browser and returns the picked object to the caller.
1041 (In IPython this object will be available as the ``_`` variable.)
1041 (In IPython this object will be available as the ``_`` variable.)
1042 """
1042 """
1043 level = self.levels[-1]
1043 level = self.levels[-1]
1044 self.returnvalue = level.items[level.cury].item
1044 self.returnvalue = level.items[level.cury].item
1045 return True
1045 return True
1046
1046
1047 def cmd_pickattr(self):
1047 def cmd_pickattr(self):
1048 """
1048 """
1049 'Pick' the attribute under the cursor (i.e. the row/column the
1049 'Pick' the attribute under the cursor (i.e. the row/column the
1050 cursor is on).
1050 cursor is on).
1051 """
1051 """
1052 level = self.levels[-1]
1052 level = self.levels[-1]
1053 attr = level.displayattr[1]
1053 attr = level.displayattr[1]
1054 if attr is ipipe.noitem:
1054 if attr is ipipe.noitem:
1055 curses.beep()
1055 curses.beep()
1056 self.report(CommandError("no column under cursor"))
1056 self.report(CommandError("no column under cursor"))
1057 return
1057 return
1058 value = attr.value(level.items[level.cury].item)
1058 value = attr.value(level.items[level.cury].item)
1059 if value is ipipe.noitem:
1059 if value is ipipe.noitem:
1060 curses.beep()
1060 curses.beep()
1061 self.report(AttributeError(attr.name()))
1061 self.report(AttributeError(attr.name()))
1062 else:
1062 else:
1063 self.returnvalue = value
1063 self.returnvalue = value
1064 return True
1064 return True
1065
1065
1066 def cmd_pickallattrs(self):
1066 def cmd_pickallattrs(self):
1067 """
1067 """
1068 Pick' the complete column under the cursor (i.e. the attribute under
1068 Pick' the complete column under the cursor (i.e. the attribute under
1069 the cursor) from all currently fetched objects. These attributes
1069 the cursor) from all currently fetched objects. These attributes
1070 will be returned as a list.
1070 will be returned as a list.
1071 """
1071 """
1072 level = self.levels[-1]
1072 level = self.levels[-1]
1073 attr = level.displayattr[1]
1073 attr = level.displayattr[1]
1074 if attr is ipipe.noitem:
1074 if attr is ipipe.noitem:
1075 curses.beep()
1075 curses.beep()
1076 self.report(CommandError("no column under cursor"))
1076 self.report(CommandError("no column under cursor"))
1077 return
1077 return
1078 result = []
1078 result = []
1079 for cache in level.items:
1079 for cache in level.items:
1080 value = attr.value(cache.item)
1080 value = attr.value(cache.item)
1081 if value is not ipipe.noitem:
1081 if value is not ipipe.noitem:
1082 result.append(value)
1082 result.append(value)
1083 self.returnvalue = result
1083 self.returnvalue = result
1084 return True
1084 return True
1085
1085
1086 def cmd_pickmarked(self):
1086 def cmd_pickmarked(self):
1087 """
1087 """
1088 'Pick' marked objects. Marked objects will be returned as a list.
1088 'Pick' marked objects. Marked objects will be returned as a list.
1089 """
1089 """
1090 level = self.levels[-1]
1090 level = self.levels[-1]
1091 self.returnvalue = [cache.item for cache in level.items if cache.marked]
1091 self.returnvalue = [cache.item for cache in level.items if cache.marked]
1092 return True
1092 return True
1093
1093
1094 def cmd_pickmarkedattr(self):
1094 def cmd_pickmarkedattr(self):
1095 """
1095 """
1096 'Pick' the attribute under the cursor from all marked objects
1096 'Pick' the attribute under the cursor from all marked objects
1097 (This returns a list).
1097 (This returns a list).
1098 """
1098 """
1099
1099
1100 level = self.levels[-1]
1100 level = self.levels[-1]
1101 attr = level.displayattr[1]
1101 attr = level.displayattr[1]
1102 if attr is ipipe.noitem:
1102 if attr is ipipe.noitem:
1103 curses.beep()
1103 curses.beep()
1104 self.report(CommandError("no column under cursor"))
1104 self.report(CommandError("no column under cursor"))
1105 return
1105 return
1106 result = []
1106 result = []
1107 for cache in level.items:
1107 for cache in level.items:
1108 if cache.marked:
1108 if cache.marked:
1109 value = attr.value(cache.item)
1109 value = attr.value(cache.item)
1110 if value is not ipipe.noitem:
1110 if value is not ipipe.noitem:
1111 result.append(value)
1111 result.append(value)
1112 self.returnvalue = result
1112 self.returnvalue = result
1113 return True
1113 return True
1114
1114
1115 def cmd_markrange(self):
1115 def cmd_markrange(self):
1116 """
1116 """
1117 Mark all objects from the last marked object before the current cursor
1117 Mark all objects from the last marked object before the current cursor
1118 position to the cursor position.
1118 position to the cursor position.
1119 """
1119 """
1120 level = self.levels[-1]
1120 level = self.levels[-1]
1121 self.report("markrange")
1121 self.report("markrange")
1122 start = None
1122 start = None
1123 if level.items:
1123 if level.items:
1124 for i in xrange(level.cury, -1, -1):
1124 for i in xrange(level.cury, -1, -1):
1125 if level.items[i].marked:
1125 if level.items[i].marked:
1126 start = i
1126 start = i
1127 break
1127 break
1128 if start is None:
1128 if start is None:
1129 self.report(CommandError("no mark before cursor"))
1129 self.report(CommandError("no mark before cursor"))
1130 curses.beep()
1130 curses.beep()
1131 else:
1131 else:
1132 for i in xrange(start, level.cury+1):
1132 for i in xrange(start, level.cury+1):
1133 cache = level.items[i]
1133 cache = level.items[i]
1134 if not cache.marked:
1134 if not cache.marked:
1135 cache.marked = True
1135 cache.marked = True
1136 level.marked += 1
1136 level.marked += 1
1137
1137
1138 def cmd_enterdefault(self):
1138 def cmd_enterdefault(self):
1139 """
1139 """
1140 Enter the object under the cursor. (what this mean depends on the object
1140 Enter the object under the cursor. (what this mean depends on the object
1141 itself (i.e. how it implements the ``__xiter__`` method). This opens a new
1141 itself (i.e. how it implements the ``__xiter__`` method). This opens a new
1142 browser 'level'.
1142 browser 'level'.
1143 """
1143 """
1144 level = self.levels[-1]
1144 level = self.levels[-1]
1145 try:
1145 try:
1146 item = level.items[level.cury].item
1146 item = level.items[level.cury].item
1147 except IndexError:
1147 except IndexError:
1148 self.report(CommandError("No object"))
1148 self.report(CommandError("No object"))
1149 curses.beep()
1149 curses.beep()
1150 else:
1150 else:
1151 self.report("entering object (default mode)...")
1151 self.report("entering object (default mode)...")
1152 self.enter(item, "default")
1152 self.enter(item, "default")
1153
1153
1154 def cmd_leave(self):
1154 def cmd_leave(self):
1155 """
1155 """
1156 Leave the current browser level and go back to the previous one.
1156 Leave the current browser level and go back to the previous one.
1157 """
1157 """
1158 self.report("leave")
1158 self.report("leave")
1159 if len(self.levels) > 1:
1159 if len(self.levels) > 1:
1160 self._calcheaderlines(len(self.levels)-1)
1160 self._calcheaderlines(len(self.levels)-1)
1161 self.levels.pop(-1)
1161 self.levels.pop(-1)
1162 else:
1162 else:
1163 self.report(CommandError("This is the last level"))
1163 self.report(CommandError("This is the last level"))
1164 curses.beep()
1164 curses.beep()
1165
1165
1166 def cmd_enter(self):
1166 def cmd_enter(self):
1167 """
1167 """
1168 Enter the object under the cursor. If the object provides different
1168 Enter the object under the cursor. If the object provides different
1169 enter modes a menu of all modes will be presented; choose one and enter
1169 enter modes a menu of all modes will be presented; choose one and enter
1170 it (via the 'enter' or 'enterdefault' command).
1170 it (via the 'enter' or 'enterdefault' command).
1171 """
1171 """
1172 level = self.levels[-1]
1172 level = self.levels[-1]
1173 try:
1173 try:
1174 item = level.items[level.cury].item
1174 item = level.items[level.cury].item
1175 except IndexError:
1175 except IndexError:
1176 self.report(CommandError("No object"))
1176 self.report(CommandError("No object"))
1177 curses.beep()
1177 curses.beep()
1178 else:
1178 else:
1179 self.report("entering object...")
1179 self.report("entering object...")
1180 self.enter(item, None)
1180 self.enter(item, None)
1181
1181
1182 def cmd_enterattr(self):
1182 def cmd_enterattr(self):
1183 """
1183 """
1184 Enter the attribute under the cursor.
1184 Enter the attribute under the cursor.
1185 """
1185 """
1186 level = self.levels[-1]
1186 level = self.levels[-1]
1187 attr = level.displayattr[1]
1187 attr = level.displayattr[1]
1188 if attr is ipipe.noitem:
1188 if attr is ipipe.noitem:
1189 curses.beep()
1189 curses.beep()
1190 self.report(CommandError("no column under cursor"))
1190 self.report(CommandError("no column under cursor"))
1191 return
1191 return
1192 try:
1192 try:
1193 item = level.items[level.cury].item
1193 item = level.items[level.cury].item
1194 except IndexError:
1194 except IndexError:
1195 self.report(CommandError("No object"))
1195 self.report(CommandError("No object"))
1196 curses.beep()
1196 curses.beep()
1197 else:
1197 else:
1198 value = attr.value(item)
1198 value = attr.value(item)
1199 name = attr.name()
1199 name = attr.name()
1200 if value is ipipe.noitem:
1200 if value is ipipe.noitem:
1201 self.report(AttributeError(name))
1201 self.report(AttributeError(name))
1202 else:
1202 else:
1203 self.report("entering object attribute %s..." % name)
1203 self.report("entering object attribute %s..." % name)
1204 self.enter(value, None)
1204 self.enter(value, None)
1205
1205
1206 def cmd_detail(self):
1206 def cmd_detail(self):
1207 """
1207 """
1208 Show a detail view of the object under the cursor. This shows the
1208 Show a detail view of the object under the cursor. This shows the
1209 name, type, doc string and value of the object attributes (and it
1209 name, type, doc string and value of the object attributes (and it
1210 might show more attributes than in the list view, depending on
1210 might show more attributes than in the list view, depending on
1211 the object).
1211 the object).
1212 """
1212 """
1213 level = self.levels[-1]
1213 level = self.levels[-1]
1214 try:
1214 try:
1215 item = level.items[level.cury].item
1215 item = level.items[level.cury].item
1216 except IndexError:
1216 except IndexError:
1217 self.report(CommandError("No object"))
1217 self.report(CommandError("No object"))
1218 curses.beep()
1218 curses.beep()
1219 else:
1219 else:
1220 self.report("entering detail view for object...")
1220 self.report("entering detail view for object...")
1221 attrs = [ipipe.AttributeDetail(item, attr) for attr in ipipe.xattrs(item, "detail")]
1221 attrs = [ipipe.AttributeDetail(item, attr) for attr in ipipe.xattrs(item, "detail")]
1222 self.enter(attrs, "detail")
1222 self.enter(attrs, "detail")
1223
1223
1224 def cmd_detailattr(self):
1224 def cmd_detailattr(self):
1225 """
1225 """
1226 Show a detail view of the attribute under the cursor.
1226 Show a detail view of the attribute under the cursor.
1227 """
1227 """
1228 level = self.levels[-1]
1228 level = self.levels[-1]
1229 attr = level.displayattr[1]
1229 attr = level.displayattr[1]
1230 if attr is ipipe.noitem:
1230 if attr is ipipe.noitem:
1231 curses.beep()
1231 curses.beep()
1232 self.report(CommandError("no attribute"))
1232 self.report(CommandError("no attribute"))
1233 return
1233 return
1234 try:
1234 try:
1235 item = level.items[level.cury].item
1235 item = level.items[level.cury].item
1236 except IndexError:
1236 except IndexError:
1237 self.report(CommandError("No object"))
1237 self.report(CommandError("No object"))
1238 curses.beep()
1238 curses.beep()
1239 else:
1239 else:
1240 try:
1240 try:
1241 item = attr.value(item)
1241 item = attr.value(item)
1242 except (KeyboardInterrupt, SystemExit):
1242 except (KeyboardInterrupt, SystemExit):
1243 raise
1243 raise
1244 except Exception, exc:
1244 except Exception, exc:
1245 self.report(exc)
1245 self.report(exc)
1246 else:
1246 else:
1247 self.report("entering detail view for attribute %s..." % attr.name())
1247 self.report("entering detail view for attribute %s..." % attr.name())
1248 attrs = [ipipe.AttributeDetail(item, attr) for attr in ipipe.xattrs(item, "detail")]
1248 attrs = [ipipe.AttributeDetail(item, attr) for attr in ipipe.xattrs(item, "detail")]
1249 self.enter(attrs, "detail")
1249 self.enter(attrs, "detail")
1250
1250
1251 def cmd_tooglemark(self):
1251 def cmd_tooglemark(self):
1252 """
1252 """
1253 Mark/unmark the object under the cursor. Marked objects have a '!'
1253 Mark/unmark the object under the cursor. Marked objects have a '!'
1254 after the row number).
1254 after the row number).
1255 """
1255 """
1256 level = self.levels[-1]
1256 level = self.levels[-1]
1257 self.report("toggle mark")
1257 self.report("toggle mark")
1258 try:
1258 try:
1259 item = level.items[level.cury]
1259 item = level.items[level.cury]
1260 except IndexError: # no items?
1260 except IndexError: # no items?
1261 pass
1261 pass
1262 else:
1262 else:
1263 if item.marked:
1263 if item.marked:
1264 item.marked = False
1264 item.marked = False
1265 level.marked -= 1
1265 level.marked -= 1
1266 else:
1266 else:
1267 item.marked = True
1267 item.marked = True
1268 level.marked += 1
1268 level.marked += 1
1269
1269
1270 def cmd_sortattrasc(self):
1270 def cmd_sortattrasc(self):
1271 """
1271 """
1272 Sort the objects (in ascending order) using the attribute under
1272 Sort the objects (in ascending order) using the attribute under
1273 the cursor as the sort key.
1273 the cursor as the sort key.
1274 """
1274 """
1275 level = self.levels[-1]
1275 level = self.levels[-1]
1276 attr = level.displayattr[1]
1276 attr = level.displayattr[1]
1277 if attr is ipipe.noitem:
1277 if attr is ipipe.noitem:
1278 curses.beep()
1278 curses.beep()
1279 self.report(CommandError("no column under cursor"))
1279 self.report(CommandError("no column under cursor"))
1280 return
1280 return
1281 self.report("sort by %s (ascending)" % attr.name())
1281 self.report("sort by %s (ascending)" % attr.name())
1282 def key(item):
1282 def key(item):
1283 try:
1283 try:
1284 return attr.value(item)
1284 return attr.value(item)
1285 except (KeyboardInterrupt, SystemExit):
1285 except (KeyboardInterrupt, SystemExit):
1286 raise
1286 raise
1287 except Exception:
1287 except Exception:
1288 return None
1288 return None
1289 level.sort(key)
1289 level.sort(key)
1290
1290
1291 def cmd_sortattrdesc(self):
1291 def cmd_sortattrdesc(self):
1292 """
1292 """
1293 Sort the objects (in descending order) using the attribute under
1293 Sort the objects (in descending order) using the attribute under
1294 the cursor as the sort key.
1294 the cursor as the sort key.
1295 """
1295 """
1296 level = self.levels[-1]
1296 level = self.levels[-1]
1297 attr = level.displayattr[1]
1297 attr = level.displayattr[1]
1298 if attr is ipipe.noitem:
1298 if attr is ipipe.noitem:
1299 curses.beep()
1299 curses.beep()
1300 self.report(CommandError("no column under cursor"))
1300 self.report(CommandError("no column under cursor"))
1301 return
1301 return
1302 self.report("sort by %s (descending)" % attr.name())
1302 self.report("sort by %s (descending)" % attr.name())
1303 def key(item):
1303 def key(item):
1304 try:
1304 try:
1305 return attr.value(item)
1305 return attr.value(item)
1306 except (KeyboardInterrupt, SystemExit):
1306 except (KeyboardInterrupt, SystemExit):
1307 raise
1307 raise
1308 except Exception:
1308 except Exception:
1309 return None
1309 return None
1310 level.sort(key, reverse=True)
1310 level.sort(key, reverse=True)
1311
1311
1312 def cmd_hideattr(self):
1312 def cmd_hideattr(self):
1313 """
1313 """
1314 Hide the attribute under the cursor.
1314 Hide the attribute under the cursor.
1315 """
1315 """
1316 level = self.levels[-1]
1316 level = self.levels[-1]
1317 if level.displayattr[0] is None:
1317 if level.displayattr[0] is None:
1318 self.beep()
1318 self.beep()
1319 else:
1319 else:
1320 self.report("hideattr")
1320 self.report("hideattr")
1321 level.hiddenattrs.add(level.displayattr[1])
1321 level.hiddenattrs.add(level.displayattr[1])
1322 level.moveto(level.curx, level.cury, refresh=True)
1322 level.moveto(level.curx, level.cury, refresh=True)
1323
1323
1324 def cmd_unhideattrs(self):
1324 def cmd_unhideattrs(self):
1325 """
1325 """
1326 Make all attributes visible again.
1326 Make all attributes visible again.
1327 """
1327 """
1328 level = self.levels[-1]
1328 level = self.levels[-1]
1329 self.report("unhideattrs")
1329 self.report("unhideattrs")
1330 level.hiddenattrs.clear()
1330 level.hiddenattrs.clear()
1331 level.moveto(level.curx, level.cury, refresh=True)
1331 level.moveto(level.curx, level.cury, refresh=True)
1332
1332
1333 def cmd_goto(self):
1333 def cmd_goto(self):
1334 """
1334 """
1335 Jump to a row. The row number can be entered at the
1335 Jump to a row. The row number can be entered at the
1336 bottom of the screen.
1336 bottom of the screen.
1337 """
1337 """
1338 self.startkeyboardinput("goto")
1338 self.startkeyboardinput("goto")
1339
1339
1340 def cmd_find(self):
1340 def cmd_find(self):
1341 """
1341 """
1342 Search forward for a row. The search condition can be entered at the
1342 Search forward for a row. The search condition can be entered at the
1343 bottom of the screen.
1343 bottom of the screen.
1344 """
1344 """
1345 self.startkeyboardinput("find")
1345 self.startkeyboardinput("find")
1346
1346
1347 def cmd_findbackwards(self):
1347 def cmd_findbackwards(self):
1348 """
1348 """
1349 Search backward for a row. The search condition can be entered at the
1349 Search backward for a row. The search condition can be entered at the
1350 bottom of the screen.
1350 bottom of the screen.
1351 """
1351 """
1352 self.startkeyboardinput("findbackwards")
1352 self.startkeyboardinput("findbackwards")
1353
1353
1354 def cmd_help(self):
1354 def cmd_help(self):
1355 """
1355 """
1356 Opens the help screen as a new browser level, describing keyboard
1356 Opens the help screen as a new browser level, describing keyboard
1357 shortcuts.
1357 shortcuts.
1358 """
1358 """
1359 for level in self.levels:
1359 for level in self.levels:
1360 if isinstance(level.input, _BrowserHelp):
1360 if isinstance(level.input, _BrowserHelp):
1361 curses.beep()
1361 curses.beep()
1362 self.report(CommandError("help already active"))
1362 self.report(CommandError("help already active"))
1363 return
1363 return
1364
1364
1365 self.enter(_BrowserHelp(self), "default")
1365 self.enter(_BrowserHelp(self), "default")
1366
1366
1367 def cmd_quit(self):
1367 def cmd_quit(self):
1368 """
1368 """
1369 Quit the browser and return to the IPython prompt.
1369 Quit the browser and return to the IPython prompt.
1370 """
1370 """
1371 self.returnvalue = None
1371 self.returnvalue = None
1372 return True
1372 return True
1373
1373
1374 def sigwinchhandler(self, signal, frame):
1374 def sigwinchhandler(self, signal, frame):
1375 self.resized = True
1375 self.resized = True
1376
1376
1377 def _dodisplay(self, scr):
1377 def _dodisplay(self, scr):
1378 """
1378 """
1379 This method is the workhorse of the browser. It handles screen
1379 This method is the workhorse of the browser. It handles screen
1380 drawing and the keyboard.
1380 drawing and the keyboard.
1381 """
1381 """
1382 self.scr = scr
1382 self.scr = scr
1383 curses.halfdelay(1)
1383 curses.halfdelay(1)
1384 footery = 2
1384 footery = 2
1385
1385
1386 keys = []
1386 keys = []
1387 for key in ("quit", "help"):
1387 for cmd in ("quit", "help"):
1388 key = self.keymap.findkey(key, None)
1388 key = self.keymap.findkey(cmd, None)
1389 if key is not None:
1389 if key is not None:
1390 keys.append("%s=quit" % self.keylabel(key))
1390 keys.append("%s=%s" % (self.keylabel(key), cmd))
1391 helpmsg = " | %s" % " ".join(keys)
1391 helpmsg = " | %s" % " ".join(keys)
1392
1392
1393 scr.clear()
1393 scr.clear()
1394 msg = "Fetching first batch of objects..."
1394 msg = "Fetching first batch of objects..."
1395 (self.scrsizey, self.scrsizex) = scr.getmaxyx()
1395 (self.scrsizey, self.scrsizex) = scr.getmaxyx()
1396 scr.addstr(self.scrsizey//2, (self.scrsizex-len(msg))//2, msg)
1396 scr.addstr(self.scrsizey//2, (self.scrsizex-len(msg))//2, msg)
1397 scr.refresh()
1397 scr.refresh()
1398
1398
1399 lastc = -1
1399 lastc = -1
1400
1400
1401 self.levels = []
1401 self.levels = []
1402 # enter the first level
1402 # enter the first level
1403 self.enter(self.input, ipipe.xiter(self.input, "default"), *self.attrs)
1403 self.enter(self.input, ipipe.xiter(self.input, "default"), *self.attrs)
1404
1404
1405 self._calcheaderlines(None)
1405 self._calcheaderlines(None)
1406
1406
1407 while True:
1407 while True:
1408 level = self.levels[-1]
1408 level = self.levels[-1]
1409 (self.scrsizey, self.scrsizex) = scr.getmaxyx()
1409 (self.scrsizey, self.scrsizex) = scr.getmaxyx()
1410 level.mainsizey = self.scrsizey-1-self._headerlines-footery
1410 level.mainsizey = self.scrsizey-1-self._headerlines-footery
1411
1411
1412 # Paint object header
1412 # Paint object header
1413 for i in xrange(self._firstheaderline, self._firstheaderline+self._headerlines):
1413 for i in xrange(self._firstheaderline, self._firstheaderline+self._headerlines):
1414 lv = self.levels[i]
1414 lv = self.levels[i]
1415 posx = 0
1415 posx = 0
1416 posy = i-self._firstheaderline
1416 posy = i-self._firstheaderline
1417 endx = self.scrsizex
1417 endx = self.scrsizex
1418 if i: # not the first level
1418 if i: # not the first level
1419 msg = " (%d/%d" % (self.levels[i-1].cury, len(self.levels[i-1].items))
1419 msg = " (%d/%d" % (self.levels[i-1].cury, len(self.levels[i-1].items))
1420 if not self.levels[i-1].exhausted:
1420 if not self.levels[i-1].exhausted:
1421 msg += "+"
1421 msg += "+"
1422 msg += ") "
1422 msg += ") "
1423 endx -= len(msg)+1
1423 endx -= len(msg)+1
1424 posx += self.addstr(posy, posx, 0, endx, " ibrowse #%d: " % i, self.style_objheadertext)
1424 posx += self.addstr(posy, posx, 0, endx, " ibrowse #%d: " % i, self.style_objheadertext)
1425 for (style, text) in lv.header:
1425 for (style, text) in lv.header:
1426 posx += self.addstr(posy, posx, 0, endx, text, self.style_objheaderobject)
1426 posx += self.addstr(posy, posx, 0, endx, text, self.style_objheaderobject)
1427 if posx >= endx:
1427 if posx >= endx:
1428 break
1428 break
1429 if i:
1429 if i:
1430 posx += self.addstr(posy, posx, 0, self.scrsizex, msg, self.style_objheadernumber)
1430 posx += self.addstr(posy, posx, 0, self.scrsizex, msg, self.style_objheadernumber)
1431 posx += self.addchr(posy, posx, 0, self.scrsizex, " ", self.scrsizex-posx, self.style_objheadernumber)
1431 posx += self.addchr(posy, posx, 0, self.scrsizex, " ", self.scrsizex-posx, self.style_objheadernumber)
1432
1432
1433 if not level.items:
1433 if not level.items:
1434 self.addchr(self._headerlines, 0, 0, self.scrsizex, " ", self.scrsizex, self.style_colheader)
1434 self.addchr(self._headerlines, 0, 0, self.scrsizex, " ", self.scrsizex, self.style_colheader)
1435 self.addstr(self._headerlines+1, 0, 0, self.scrsizex, " <empty>", astyle.style_error)
1435 self.addstr(self._headerlines+1, 0, 0, self.scrsizex, " <empty>", astyle.style_error)
1436 scr.clrtobot()
1436 scr.clrtobot()
1437 else:
1437 else:
1438 # Paint column headers
1438 # Paint column headers
1439 scr.move(self._headerlines, 0)
1439 scr.move(self._headerlines, 0)
1440 scr.addstr(" %*s " % (level.numbersizex, "#"), self.getstyle(self.style_colheader))
1440 scr.addstr(" %*s " % (level.numbersizex, "#"), self.getstyle(self.style_colheader))
1441 scr.addstr(self.headersepchar, self.getstyle(self.style_colheadersep))
1441 scr.addstr(self.headersepchar, self.getstyle(self.style_colheadersep))
1442 begx = level.numbersizex+3
1442 begx = level.numbersizex+3
1443 posx = begx-level.datastartx
1443 posx = begx-level.datastartx
1444 for attr in level.displayattrs:
1444 for attr in level.displayattrs:
1445 attrname = attr.name()
1445 attrname = attr.name()
1446 cwidth = level.colwidths[attr]
1446 cwidth = level.colwidths[attr]
1447 header = attrname.ljust(cwidth)
1447 header = attrname.ljust(cwidth)
1448 if attr is level.displayattr[1]:
1448 if attr is level.displayattr[1]:
1449 style = self.style_colheaderhere
1449 style = self.style_colheaderhere
1450 else:
1450 else:
1451 style = self.style_colheader
1451 style = self.style_colheader
1452 posx += self.addstr(self._headerlines, posx, begx, self.scrsizex, header, style)
1452 posx += self.addstr(self._headerlines, posx, begx, self.scrsizex, header, style)
1453 posx += self.addstr(self._headerlines, posx, begx, self.scrsizex, self.headersepchar, self.style_colheadersep)
1453 posx += self.addstr(self._headerlines, posx, begx, self.scrsizex, self.headersepchar, self.style_colheadersep)
1454 if posx >= self.scrsizex:
1454 if posx >= self.scrsizex:
1455 break
1455 break
1456 else:
1456 else:
1457 scr.addstr(" "*(self.scrsizex-posx), self.getstyle(self.style_colheader))
1457 scr.addstr(" "*(self.scrsizex-posx), self.getstyle(self.style_colheader))
1458
1458
1459 # Paint rows
1459 # Paint rows
1460 posy = self._headerlines+1+level.datastarty
1460 posy = self._headerlines+1+level.datastarty
1461 for i in xrange(level.datastarty, min(level.datastarty+level.mainsizey, len(level.items))):
1461 for i in xrange(level.datastarty, min(level.datastarty+level.mainsizey, len(level.items))):
1462 cache = level.items[i]
1462 cache = level.items[i]
1463 if i == level.cury:
1463 if i == level.cury:
1464 style = self.style_numberhere
1464 style = self.style_numberhere
1465 else:
1465 else:
1466 style = self.style_number
1466 style = self.style_number
1467
1467
1468 posy = self._headerlines+1+i-level.datastarty
1468 posy = self._headerlines+1+i-level.datastarty
1469 posx = begx-level.datastartx
1469 posx = begx-level.datastartx
1470
1470
1471 scr.move(posy, 0)
1471 scr.move(posy, 0)
1472 scr.addstr(" %*d%s" % (level.numbersizex, i, " !"[cache.marked]), self.getstyle(style))
1472 scr.addstr(" %*d%s" % (level.numbersizex, i, " !"[cache.marked]), self.getstyle(style))
1473 scr.addstr(self.headersepchar, self.getstyle(self.style_sep))
1473 scr.addstr(self.headersepchar, self.getstyle(self.style_sep))
1474
1474
1475 for attrname in level.displayattrs:
1475 for attrname in level.displayattrs:
1476 cwidth = level.colwidths[attrname]
1476 cwidth = level.colwidths[attrname]
1477 try:
1477 try:
1478 (align, length, parts) = level.displayrows[i-level.datastarty][attrname]
1478 (align, length, parts) = level.displayrows[i-level.datastarty][attrname]
1479 except KeyError:
1479 except KeyError:
1480 align = 2
1480 align = 2
1481 style = astyle.style_nodata
1481 style = astyle.style_nodata
1482 if i == level.cury:
1482 if i == level.cury:
1483 style = self.getstylehere(style)
1483 style = self.getstylehere(style)
1484 padstyle = self.style_datapad
1484 padstyle = self.style_datapad
1485 sepstyle = self.style_sep
1485 sepstyle = self.style_sep
1486 if i == level.cury:
1486 if i == level.cury:
1487 padstyle = self.getstylehere(padstyle)
1487 padstyle = self.getstylehere(padstyle)
1488 sepstyle = self.getstylehere(sepstyle)
1488 sepstyle = self.getstylehere(sepstyle)
1489 if align == 2:
1489 if align == 2:
1490 posx += self.addchr(posy, posx, begx, self.scrsizex, self.nodatachar, cwidth, style)
1490 posx += self.addchr(posy, posx, begx, self.scrsizex, self.nodatachar, cwidth, style)
1491 else:
1491 else:
1492 if align == 1:
1492 if align == 1:
1493 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, cwidth-length, padstyle)
1493 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, cwidth-length, padstyle)
1494 elif align == 0:
1494 elif align == 0:
1495 pad1 = (cwidth-length)//2
1495 pad1 = (cwidth-length)//2
1496 pad2 = cwidth-length-len(pad1)
1496 pad2 = cwidth-length-len(pad1)
1497 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, pad1, padstyle)
1497 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, pad1, padstyle)
1498 for (style, text) in parts:
1498 for (style, text) in parts:
1499 if i == level.cury:
1499 if i == level.cury:
1500 style = self.getstylehere(style)
1500 style = self.getstylehere(style)
1501 posx += self.addstr(posy, posx, begx, self.scrsizex, text, style)
1501 posx += self.addstr(posy, posx, begx, self.scrsizex, text, style)
1502 if posx >= self.scrsizex:
1502 if posx >= self.scrsizex:
1503 break
1503 break
1504 if align == -1:
1504 if align == -1:
1505 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, cwidth-length, padstyle)
1505 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, cwidth-length, padstyle)
1506 elif align == 0:
1506 elif align == 0:
1507 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, pad2, padstyle)
1507 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, pad2, padstyle)
1508 posx += self.addstr(posy, posx, begx, self.scrsizex, self.datasepchar, sepstyle)
1508 posx += self.addstr(posy, posx, begx, self.scrsizex, self.datasepchar, sepstyle)
1509 else:
1509 else:
1510 scr.clrtoeol()
1510 scr.clrtoeol()
1511
1511
1512 # Add blank row headers for the rest of the screen
1512 # Add blank row headers for the rest of the screen
1513 for posy in xrange(posy+1, self.scrsizey-2):
1513 for posy in xrange(posy+1, self.scrsizey-2):
1514 scr.addstr(posy, 0, " " * (level.numbersizex+2), self.getstyle(self.style_colheader))
1514 scr.addstr(posy, 0, " " * (level.numbersizex+2), self.getstyle(self.style_colheader))
1515 scr.clrtoeol()
1515 scr.clrtoeol()
1516
1516
1517 posy = self.scrsizey-footery
1517 posy = self.scrsizey-footery
1518 # Display footer
1518 # Display footer
1519 scr.addstr(posy, 0, " "*self.scrsizex, self.getstyle(self.style_footer))
1519 scr.addstr(posy, 0, " "*self.scrsizex, self.getstyle(self.style_footer))
1520
1520
1521 if level.exhausted:
1521 if level.exhausted:
1522 flag = ""
1522 flag = ""
1523 else:
1523 else:
1524 flag = "+"
1524 flag = "+"
1525
1525
1526 endx = self.scrsizex-len(helpmsg)-1
1526 endx = self.scrsizex-len(helpmsg)-1
1527 scr.addstr(posy, endx, helpmsg, self.getstyle(self.style_footer))
1527 scr.addstr(posy, endx, helpmsg, self.getstyle(self.style_footer))
1528
1528
1529 posx = 0
1529 posx = 0
1530 msg = " %d%s objects (%d marked): " % (len(level.items), flag, level.marked)
1530 msg = " %d%s objects (%d marked): " % (len(level.items), flag, level.marked)
1531 posx += self.addstr(posy, posx, 0, endx, msg, self.style_footer)
1531 posx += self.addstr(posy, posx, 0, endx, msg, self.style_footer)
1532 try:
1532 try:
1533 item = level.items[level.cury].item
1533 item = level.items[level.cury].item
1534 except IndexError: # empty
1534 except IndexError: # empty
1535 pass
1535 pass
1536 else:
1536 else:
1537 for (nostyle, text) in ipipe.xrepr(item, "footer"):
1537 for (nostyle, text) in ipipe.xrepr(item, "footer"):
1538 if not isinstance(nostyle, int):
1538 if not isinstance(nostyle, int):
1539 posx += self.addstr(posy, posx, 0, endx, text, self.style_footer)
1539 posx += self.addstr(posy, posx, 0, endx, text, self.style_footer)
1540 if posx >= endx:
1540 if posx >= endx:
1541 break
1541 break
1542
1542
1543 attrstyle = [(astyle.style_default, "no attribute")]
1543 attrstyle = [(astyle.style_default, "no attribute")]
1544 attr = level.displayattr[1]
1544 attr = level.displayattr[1]
1545 if attr is not ipipe.noitem and not isinstance(attr, ipipe.SelfDescriptor):
1545 if attr is not ipipe.noitem and not isinstance(attr, ipipe.SelfDescriptor):
1546 posx += self.addstr(posy, posx, 0, endx, " | ", self.style_footer)
1546 posx += self.addstr(posy, posx, 0, endx, " | ", self.style_footer)
1547 posx += self.addstr(posy, posx, 0, endx, attr.name(), self.style_footer)
1547 posx += self.addstr(posy, posx, 0, endx, attr.name(), self.style_footer)
1548 posx += self.addstr(posy, posx, 0, endx, ": ", self.style_footer)
1548 posx += self.addstr(posy, posx, 0, endx, ": ", self.style_footer)
1549 try:
1549 try:
1550 value = attr.value(item)
1550 value = attr.value(item)
1551 except (SystemExit, KeyboardInterrupt):
1551 except (SystemExit, KeyboardInterrupt):
1552 raise
1552 raise
1553 except Exception, exc:
1553 except Exception, exc:
1554 attr = exc
1554 attr = exc
1555 if value is not ipipe.noitem:
1555 if value is not ipipe.noitem:
1556 attrstyle = ipipe.xrepr(value, "footer")
1556 attrstyle = ipipe.xrepr(value, "footer")
1557 for (nostyle, text) in attrstyle:
1557 for (nostyle, text) in attrstyle:
1558 if not isinstance(nostyle, int):
1558 if not isinstance(nostyle, int):
1559 posx += self.addstr(posy, posx, 0, endx, text, self.style_footer)
1559 posx += self.addstr(posy, posx, 0, endx, text, self.style_footer)
1560 if posx >= endx:
1560 if posx >= endx:
1561 break
1561 break
1562
1562
1563 try:
1563 try:
1564 # Display input prompt
1564 # Display input prompt
1565 if self.mode in self.prompts:
1565 if self.mode in self.prompts:
1566 history = self.prompts[self.mode]
1566 history = self.prompts[self.mode]
1567 posx = 0
1567 posx = 0
1568 posy = self.scrsizey-1
1568 posy = self.scrsizey-1
1569 posx += self.addstr(posy, posx, 0, endx, history.prompt, astyle.style_default)
1569 posx += self.addstr(posy, posx, 0, endx, history.prompt, astyle.style_default)
1570 posx += self.addstr(posy, posx, 0, endx, " [", astyle.style_default)
1570 posx += self.addstr(posy, posx, 0, endx, " [", astyle.style_default)
1571 if history.cury==-1:
1571 if history.cury==-1:
1572 text = "new"
1572 text = "new"
1573 else:
1573 else:
1574 text = str(history.cury+1)
1574 text = str(history.cury+1)
1575 posx += self.addstr(posy, posx, 0, endx, text, astyle.style_type_number)
1575 posx += self.addstr(posy, posx, 0, endx, text, astyle.style_type_number)
1576 if history.history:
1576 if history.history:
1577 posx += self.addstr(posy, posx, 0, endx, "/", astyle.style_default)
1577 posx += self.addstr(posy, posx, 0, endx, "/", astyle.style_default)
1578 posx += self.addstr(posy, posx, 0, endx, str(len(history.history)), astyle.style_type_number)
1578 posx += self.addstr(posy, posx, 0, endx, str(len(history.history)), astyle.style_type_number)
1579 posx += self.addstr(posy, posx, 0, endx, "]: ", astyle.style_default)
1579 posx += self.addstr(posy, posx, 0, endx, "]: ", astyle.style_default)
1580 inputstartx = posx
1580 inputstartx = posx
1581 posx += self.addstr(posy, posx, 0, endx, history.input, astyle.style_default)
1581 posx += self.addstr(posy, posx, 0, endx, history.input, astyle.style_default)
1582 # Display report
1582 # Display report
1583 else:
1583 else:
1584 if self._report is not None:
1584 if self._report is not None:
1585 if isinstance(self._report, Exception):
1585 if isinstance(self._report, Exception):
1586 style = self.getstyle(astyle.style_error)
1586 style = self.getstyle(astyle.style_error)
1587 if self._report.__class__.__module__ == "exceptions":
1587 if self._report.__class__.__module__ == "exceptions":
1588 msg = "%s: %s" % \
1588 msg = "%s: %s" % \
1589 (self._report.__class__.__name__, self._report)
1589 (self._report.__class__.__name__, self._report)
1590 else:
1590 else:
1591 msg = "%s.%s: %s" % \
1591 msg = "%s.%s: %s" % \
1592 (self._report.__class__.__module__,
1592 (self._report.__class__.__module__,
1593 self._report.__class__.__name__, self._report)
1593 self._report.__class__.__name__, self._report)
1594 else:
1594 else:
1595 style = self.getstyle(self.style_report)
1595 style = self.getstyle(self.style_report)
1596 msg = self._report
1596 msg = self._report
1597 scr.addstr(self.scrsizey-1, 0, msg[:self.scrsizex], style)
1597 scr.addstr(self.scrsizey-1, 0, msg[:self.scrsizex], style)
1598 self._report = None
1598 self._report = None
1599 else:
1599 else:
1600 scr.move(self.scrsizey-1, 0)
1600 scr.move(self.scrsizey-1, 0)
1601 except curses.error:
1601 except curses.error:
1602 # Protect against errors from writing to the last line
1602 # Protect against errors from writing to the last line
1603 pass
1603 pass
1604 scr.clrtoeol()
1604 scr.clrtoeol()
1605
1605
1606 # Position cursor
1606 # Position cursor
1607 if self.mode in self.prompts:
1607 if self.mode in self.prompts:
1608 history = self.prompts[self.mode]
1608 history = self.prompts[self.mode]
1609 scr.move(self.scrsizey-1, inputstartx+history.curx)
1609 scr.move(self.scrsizey-1, inputstartx+history.curx)
1610 else:
1610 else:
1611 scr.move(
1611 scr.move(
1612 1+self._headerlines+level.cury-level.datastarty,
1612 1+self._headerlines+level.cury-level.datastarty,
1613 level.numbersizex+3+level.curx-level.datastartx
1613 level.numbersizex+3+level.curx-level.datastartx
1614 )
1614 )
1615 scr.refresh()
1615 scr.refresh()
1616
1616
1617 # Check keyboard
1617 # Check keyboard
1618 while True:
1618 while True:
1619 c = scr.getch()
1619 c = scr.getch()
1620 if self.resized:
1620 if self.resized:
1621 size = fcntl.ioctl(0, tty.TIOCGWINSZ, "12345678")
1621 size = fcntl.ioctl(0, tty.TIOCGWINSZ, "12345678")
1622 size = struct.unpack("4H", size)
1622 size = struct.unpack("4H", size)
1623 oldsize = scr.getmaxyx()
1623 oldsize = scr.getmaxyx()
1624 scr.erase()
1624 scr.erase()
1625 curses.resize_term(size[0], size[1])
1625 curses.resize_term(size[0], size[1])
1626 newsize = scr.getmaxyx()
1626 newsize = scr.getmaxyx()
1627 scr.erase()
1627 scr.erase()
1628 for l in self.levels:
1628 for l in self.levels:
1629 l.mainsizey += newsize[0]-oldsize[0]
1629 l.mainsizey += newsize[0]-oldsize[0]
1630 l.moveto(l.curx, l.cury, refresh=True)
1630 l.moveto(l.curx, l.cury, refresh=True)
1631 scr.refresh()
1631 scr.refresh()
1632 self.resized = False
1632 self.resized = False
1633 break # Redisplay
1633 break # Redisplay
1634 if self.mode in self.prompts:
1634 if self.mode in self.prompts:
1635 if self.prompts[self.mode].handlekey(self, c):
1635 if self.prompts[self.mode].handlekey(self, c):
1636 break # Redisplay
1636 break # Redisplay
1637 else:
1637 else:
1638 # if no key is pressed slow down and beep again
1638 # if no key is pressed slow down and beep again
1639 if c == -1:
1639 if c == -1:
1640 self.stepx = 1.
1640 self.stepx = 1.
1641 self.stepy = 1.
1641 self.stepy = 1.
1642 self._dobeep = True
1642 self._dobeep = True
1643 else:
1643 else:
1644 # if a different key was pressed slow down and beep too
1644 # if a different key was pressed slow down and beep too
1645 if c != lastc:
1645 if c != lastc:
1646 lastc = c
1646 lastc = c
1647 self.stepx = 1.
1647 self.stepx = 1.
1648 self.stepy = 1.
1648 self.stepy = 1.
1649 self._dobeep = True
1649 self._dobeep = True
1650 cmdname = self.keymap.get(c, None)
1650 cmdname = self.keymap.get(c, None)
1651 if cmdname is None:
1651 if cmdname is None:
1652 self.report(
1652 self.report(
1653 UnassignedKeyError("Unassigned key %s" %
1653 UnassignedKeyError("Unassigned key %s" %
1654 self.keylabel(c)))
1654 self.keylabel(c)))
1655 else:
1655 else:
1656 cmdfunc = getattr(self, "cmd_%s" % cmdname, None)
1656 cmdfunc = getattr(self, "cmd_%s" % cmdname, None)
1657 if cmdfunc is None:
1657 if cmdfunc is None:
1658 self.report(
1658 self.report(
1659 UnknownCommandError("Unknown command %r" %
1659 UnknownCommandError("Unknown command %r" %
1660 (cmdname,)))
1660 (cmdname,)))
1661 elif cmdfunc():
1661 elif cmdfunc():
1662 returnvalue = self.returnvalue
1662 returnvalue = self.returnvalue
1663 self.returnvalue = None
1663 self.returnvalue = None
1664 return returnvalue
1664 return returnvalue
1665 self.stepx = self.nextstepx(self.stepx)
1665 self.stepx = self.nextstepx(self.stepx)
1666 self.stepy = self.nextstepy(self.stepy)
1666 self.stepy = self.nextstepy(self.stepy)
1667 curses.flushinp() # get rid of type ahead
1667 curses.flushinp() # get rid of type ahead
1668 break # Redisplay
1668 break # Redisplay
1669 self.scr = None
1669 self.scr = None
1670
1670
1671 def display(self):
1671 def display(self):
1672 if hasattr(curses, "resize_term"):
1672 if hasattr(curses, "resize_term"):
1673 oldhandler = signal.signal(signal.SIGWINCH, self.sigwinchhandler)
1673 oldhandler = signal.signal(signal.SIGWINCH, self.sigwinchhandler)
1674 try:
1674 try:
1675 return curses.wrapper(self._dodisplay)
1675 return curses.wrapper(self._dodisplay)
1676 finally:
1676 finally:
1677 signal.signal(signal.SIGWINCH, oldhandler)
1677 signal.signal(signal.SIGWINCH, oldhandler)
1678 else:
1678 else:
1679 return curses.wrapper(self._dodisplay)
1679 return curses.wrapper(self._dodisplay)
@@ -1,5699 +1,5704
1 2006-08-04 Walter Doerwald <walter@livinglogic.de>
2
3 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
4 (which was displaying "quit" twice).
5
1 2006-07-28 Walter Doerwald <walter@livinglogic.de>
6 2006-07-28 Walter Doerwald <walter@livinglogic.de>
2
7
3 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
8 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
4 the mode argument).
9 the mode argument).
5
10
6 2006-07-27 Walter Doerwald <walter@livinglogic.de>
11 2006-07-27 Walter Doerwald <walter@livinglogic.de>
7
12
8 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
13 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
9 not running under IPython.
14 not running under IPython.
10
15
11 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
16 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
12 and make it iterable (iterating over the attribute itself). Add two new
17 and make it iterable (iterating over the attribute itself). Add two new
13 magic strings for __xattrs__(): If the string starts with "-", the attribute
18 magic strings for __xattrs__(): If the string starts with "-", the attribute
14 will not be displayed in ibrowse's detail view (but it can still be
19 will not be displayed in ibrowse's detail view (but it can still be
15 iterated over). This makes it possible to add attributes that are large
20 iterated over). This makes it possible to add attributes that are large
16 lists or generator methods to the detail view. Replace magic attribute names
21 lists or generator methods to the detail view. Replace magic attribute names
17 and _attrname() and _getattr() with "descriptors": For each type of magic
22 and _attrname() and _getattr() with "descriptors": For each type of magic
18 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
23 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
19 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
24 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
20 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
25 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
21 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
26 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
22 are still supported.
27 are still supported.
23
28
24 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
29 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
25 fails in ibrowse.fetch(), the exception object is added as the last item
30 fails in ibrowse.fetch(), the exception object is added as the last item
26 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
31 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
27 a generator throws an exception midway through execution.
32 a generator throws an exception midway through execution.
28
33
29 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
34 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
30 encoding into methods.
35 encoding into methods.
31
36
32 2006-07-26 Ville Vainio <vivainio@gmail.com>
37 2006-07-26 Ville Vainio <vivainio@gmail.com>
33
38
34 * iplib.py: history now stores multiline input as single
39 * iplib.py: history now stores multiline input as single
35 history entries. Patch by Jorgen Cederlof.
40 history entries. Patch by Jorgen Cederlof.
36
41
37 2006-07-18 Walter Doerwald <walter@livinglogic.de>
42 2006-07-18 Walter Doerwald <walter@livinglogic.de>
38
43
39 * IPython/Extensions/ibrowse.py: Make cursor visible over
44 * IPython/Extensions/ibrowse.py: Make cursor visible over
40 non existing attributes.
45 non existing attributes.
41
46
42 2006-07-14 Walter Doerwald <walter@livinglogic.de>
47 2006-07-14 Walter Doerwald <walter@livinglogic.de>
43
48
44 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
49 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
45 error output of the running command doesn't mess up the screen.
50 error output of the running command doesn't mess up the screen.
46
51
47 2006-07-13 Walter Doerwald <walter@livinglogic.de>
52 2006-07-13 Walter Doerwald <walter@livinglogic.de>
48
53
49 * IPython/Extensions/ipipe.py (isort): Make isort usable without
54 * IPython/Extensions/ipipe.py (isort): Make isort usable without
50 argument. This sorts the items themselves.
55 argument. This sorts the items themselves.
51
56
52 2006-07-12 Walter Doerwald <walter@livinglogic.de>
57 2006-07-12 Walter Doerwald <walter@livinglogic.de>
53
58
54 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
59 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
55 Compile expression strings into code objects. This should speed
60 Compile expression strings into code objects. This should speed
56 up ifilter and friends somewhat.
61 up ifilter and friends somewhat.
57
62
58 2006-07-08 Ville Vainio <vivainio@gmail.com>
63 2006-07-08 Ville Vainio <vivainio@gmail.com>
59
64
60 * Magic.py: %cpaste now strips > from the beginning of lines
65 * Magic.py: %cpaste now strips > from the beginning of lines
61 to ease pasting quoted code from emails. Contributed by
66 to ease pasting quoted code from emails. Contributed by
62 Stefan van der Walt.
67 Stefan van der Walt.
63
68
64 2006-06-29 Ville Vainio <vivainio@gmail.com>
69 2006-06-29 Ville Vainio <vivainio@gmail.com>
65
70
66 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
71 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
67 mode, patch contributed by Darren Dale. NEEDS TESTING!
72 mode, patch contributed by Darren Dale. NEEDS TESTING!
68
73
69 2006-06-28 Walter Doerwald <walter@livinglogic.de>
74 2006-06-28 Walter Doerwald <walter@livinglogic.de>
70
75
71 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
76 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
72 a blue background. Fix fetching new display rows when the browser
77 a blue background. Fix fetching new display rows when the browser
73 scrolls more than a screenful (e.g. by using the goto command).
78 scrolls more than a screenful (e.g. by using the goto command).
74
79
75 2006-06-27 Ville Vainio <vivainio@gmail.com>
80 2006-06-27 Ville Vainio <vivainio@gmail.com>
76
81
77 * Magic.py (_inspect, _ofind) Apply David Huard's
82 * Magic.py (_inspect, _ofind) Apply David Huard's
78 patch for displaying the correct docstring for 'property'
83 patch for displaying the correct docstring for 'property'
79 attributes.
84 attributes.
80
85
81 2006-06-23 Walter Doerwald <walter@livinglogic.de>
86 2006-06-23 Walter Doerwald <walter@livinglogic.de>
82
87
83 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
88 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
84 commands into the methods implementing them.
89 commands into the methods implementing them.
85
90
86 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
91 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
87
92
88 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
93 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
89 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
94 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
90 autoindent support was authored by Jin Liu.
95 autoindent support was authored by Jin Liu.
91
96
92 2006-06-22 Walter Doerwald <walter@livinglogic.de>
97 2006-06-22 Walter Doerwald <walter@livinglogic.de>
93
98
94 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
99 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
95 for keymaps with a custom class that simplifies handling.
100 for keymaps with a custom class that simplifies handling.
96
101
97 2006-06-19 Walter Doerwald <walter@livinglogic.de>
102 2006-06-19 Walter Doerwald <walter@livinglogic.de>
98
103
99 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
104 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
100 resizing. This requires Python 2.5 to work.
105 resizing. This requires Python 2.5 to work.
101
106
102 2006-06-16 Walter Doerwald <walter@livinglogic.de>
107 2006-06-16 Walter Doerwald <walter@livinglogic.de>
103
108
104 * IPython/Extensions/ibrowse.py: Add two new commands to
109 * IPython/Extensions/ibrowse.py: Add two new commands to
105 ibrowse: "hideattr" (mapped to "h") hides the attribute under
110 ibrowse: "hideattr" (mapped to "h") hides the attribute under
106 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
111 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
107 attributes again. Remapped the help command to "?". Display
112 attributes again. Remapped the help command to "?". Display
108 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
113 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
109 as keys for the "home" and "end" commands. Add three new commands
114 as keys for the "home" and "end" commands. Add three new commands
110 to the input mode for "find" and friends: "delend" (CTRL-K)
115 to the input mode for "find" and friends: "delend" (CTRL-K)
111 deletes to the end of line. "incsearchup" searches upwards in the
116 deletes to the end of line. "incsearchup" searches upwards in the
112 command history for an input that starts with the text before the cursor.
117 command history for an input that starts with the text before the cursor.
113 "incsearchdown" does the same downwards. Removed a bogus mapping of
118 "incsearchdown" does the same downwards. Removed a bogus mapping of
114 the x key to "delete".
119 the x key to "delete".
115
120
116 2006-06-15 Ville Vainio <vivainio@gmail.com>
121 2006-06-15 Ville Vainio <vivainio@gmail.com>
117
122
118 * iplib.py, hooks.py: Added new generate_prompt hook that can be
123 * iplib.py, hooks.py: Added new generate_prompt hook that can be
119 used to create prompts dynamically, instead of the "old" way of
124 used to create prompts dynamically, instead of the "old" way of
120 assigning "magic" strings to prompt_in1 and prompt_in2. The old
125 assigning "magic" strings to prompt_in1 and prompt_in2. The old
121 way still works (it's invoked by the default hook), of course.
126 way still works (it's invoked by the default hook), of course.
122
127
123 * Prompts.py: added generate_output_prompt hook for altering output
128 * Prompts.py: added generate_output_prompt hook for altering output
124 prompt
129 prompt
125
130
126 * Release.py: Changed version string to 0.7.3.svn.
131 * Release.py: Changed version string to 0.7.3.svn.
127
132
128 2006-06-15 Walter Doerwald <walter@livinglogic.de>
133 2006-06-15 Walter Doerwald <walter@livinglogic.de>
129
134
130 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
135 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
131 the call to fetch() always tries to fetch enough data for at least one
136 the call to fetch() always tries to fetch enough data for at least one
132 full screen. This makes it possible to simply call moveto(0,0,True) in
137 full screen. This makes it possible to simply call moveto(0,0,True) in
133 the constructor. Fix typos and removed the obsolete goto attribute.
138 the constructor. Fix typos and removed the obsolete goto attribute.
134
139
135 2006-06-12 Ville Vainio <vivainio@gmail.com>
140 2006-06-12 Ville Vainio <vivainio@gmail.com>
136
141
137 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
142 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
138 allowing $variable interpolation within multiline statements,
143 allowing $variable interpolation within multiline statements,
139 though so far only with "sh" profile for a testing period.
144 though so far only with "sh" profile for a testing period.
140 The patch also enables splitting long commands with \ but it
145 The patch also enables splitting long commands with \ but it
141 doesn't work properly yet.
146 doesn't work properly yet.
142
147
143 2006-06-12 Walter Doerwald <walter@livinglogic.de>
148 2006-06-12 Walter Doerwald <walter@livinglogic.de>
144
149
145 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
150 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
146 input history and the position of the cursor in the input history for
151 input history and the position of the cursor in the input history for
147 the find, findbackwards and goto command.
152 the find, findbackwards and goto command.
148
153
149 2006-06-10 Walter Doerwald <walter@livinglogic.de>
154 2006-06-10 Walter Doerwald <walter@livinglogic.de>
150
155
151 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
156 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
152 implements the basic functionality of browser commands that require
157 implements the basic functionality of browser commands that require
153 input. Reimplement the goto, find and findbackwards commands as
158 input. Reimplement the goto, find and findbackwards commands as
154 subclasses of _CommandInput. Add an input history and keymaps to those
159 subclasses of _CommandInput. Add an input history and keymaps to those
155 commands. Add "\r" as a keyboard shortcut for the enterdefault and
160 commands. Add "\r" as a keyboard shortcut for the enterdefault and
156 execute commands.
161 execute commands.
157
162
158 2006-06-07 Ville Vainio <vivainio@gmail.com>
163 2006-06-07 Ville Vainio <vivainio@gmail.com>
159
164
160 * iplib.py: ipython mybatch.ipy exits ipython immediately after
165 * iplib.py: ipython mybatch.ipy exits ipython immediately after
161 running the batch files instead of leaving the session open.
166 running the batch files instead of leaving the session open.
162
167
163 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
168 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
164
169
165 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
170 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
166 the original fix was incomplete. Patch submitted by W. Maier.
171 the original fix was incomplete. Patch submitted by W. Maier.
167
172
168 2006-06-07 Ville Vainio <vivainio@gmail.com>
173 2006-06-07 Ville Vainio <vivainio@gmail.com>
169
174
170 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
175 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
171 Confirmation prompts can be supressed by 'quiet' option.
176 Confirmation prompts can be supressed by 'quiet' option.
172 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
177 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
173
178
174 2006-06-06 *** Released version 0.7.2
179 2006-06-06 *** Released version 0.7.2
175
180
176 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
181 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
177
182
178 * IPython/Release.py (version): Made 0.7.2 final for release.
183 * IPython/Release.py (version): Made 0.7.2 final for release.
179 Repo tagged and release cut.
184 Repo tagged and release cut.
180
185
181 2006-06-05 Ville Vainio <vivainio@gmail.com>
186 2006-06-05 Ville Vainio <vivainio@gmail.com>
182
187
183 * Magic.py (magic_rehashx): Honor no_alias list earlier in
188 * Magic.py (magic_rehashx): Honor no_alias list earlier in
184 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
189 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
185
190
186 * upgrade_dir.py: try import 'path' module a bit harder
191 * upgrade_dir.py: try import 'path' module a bit harder
187 (for %upgrade)
192 (for %upgrade)
188
193
189 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
194 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
190
195
191 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
196 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
192 instead of looping 20 times.
197 instead of looping 20 times.
193
198
194 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
199 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
195 correctly at initialization time. Bug reported by Krishna Mohan
200 correctly at initialization time. Bug reported by Krishna Mohan
196 Gundu <gkmohan-AT-gmail.com> on the user list.
201 Gundu <gkmohan-AT-gmail.com> on the user list.
197
202
198 * IPython/Release.py (version): Mark 0.7.2 version to start
203 * IPython/Release.py (version): Mark 0.7.2 version to start
199 testing for release on 06/06.
204 testing for release on 06/06.
200
205
201 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
206 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
202
207
203 * scripts/irunner: thin script interface so users don't have to
208 * scripts/irunner: thin script interface so users don't have to
204 find the module and call it as an executable, since modules rarely
209 find the module and call it as an executable, since modules rarely
205 live in people's PATH.
210 live in people's PATH.
206
211
207 * IPython/irunner.py (InteractiveRunner.__init__): added
212 * IPython/irunner.py (InteractiveRunner.__init__): added
208 delaybeforesend attribute to control delays with newer versions of
213 delaybeforesend attribute to control delays with newer versions of
209 pexpect. Thanks to detailed help from pexpect's author, Noah
214 pexpect. Thanks to detailed help from pexpect's author, Noah
210 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
215 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
211 correctly (it works in NoColor mode).
216 correctly (it works in NoColor mode).
212
217
213 * IPython/iplib.py (handle_normal): fix nasty crash reported on
218 * IPython/iplib.py (handle_normal): fix nasty crash reported on
214 SAGE list, from improper log() calls.
219 SAGE list, from improper log() calls.
215
220
216 2006-05-31 Ville Vainio <vivainio@gmail.com>
221 2006-05-31 Ville Vainio <vivainio@gmail.com>
217
222
218 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
223 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
219 with args in parens to work correctly with dirs that have spaces.
224 with args in parens to work correctly with dirs that have spaces.
220
225
221 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
226 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
222
227
223 * IPython/Logger.py (Logger.logstart): add option to log raw input
228 * IPython/Logger.py (Logger.logstart): add option to log raw input
224 instead of the processed one. A -r flag was added to the
229 instead of the processed one. A -r flag was added to the
225 %logstart magic used for controlling logging.
230 %logstart magic used for controlling logging.
226
231
227 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
232 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
228
233
229 * IPython/iplib.py (InteractiveShell.__init__): add check for the
234 * IPython/iplib.py (InteractiveShell.__init__): add check for the
230 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
235 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
231 recognize the option. After a bug report by Will Maier. This
236 recognize the option. After a bug report by Will Maier. This
232 closes #64 (will do it after confirmation from W. Maier).
237 closes #64 (will do it after confirmation from W. Maier).
233
238
234 * IPython/irunner.py: New module to run scripts as if manually
239 * IPython/irunner.py: New module to run scripts as if manually
235 typed into an interactive environment, based on pexpect. After a
240 typed into an interactive environment, based on pexpect. After a
236 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
241 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
237 ipython-user list. Simple unittests in the tests/ directory.
242 ipython-user list. Simple unittests in the tests/ directory.
238
243
239 * tools/release: add Will Maier, OpenBSD port maintainer, to
244 * tools/release: add Will Maier, OpenBSD port maintainer, to
240 recepients list. We are now officially part of the OpenBSD ports:
245 recepients list. We are now officially part of the OpenBSD ports:
241 http://www.openbsd.org/ports.html ! Many thanks to Will for the
246 http://www.openbsd.org/ports.html ! Many thanks to Will for the
242 work.
247 work.
243
248
244 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
249 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
245
250
246 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
251 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
247 so that it doesn't break tkinter apps.
252 so that it doesn't break tkinter apps.
248
253
249 * IPython/iplib.py (_prefilter): fix bug where aliases would
254 * IPython/iplib.py (_prefilter): fix bug where aliases would
250 shadow variables when autocall was fully off. Reported by SAGE
255 shadow variables when autocall was fully off. Reported by SAGE
251 author William Stein.
256 author William Stein.
252
257
253 * IPython/OInspect.py (Inspector.__init__): add a flag to control
258 * IPython/OInspect.py (Inspector.__init__): add a flag to control
254 at what detail level strings are computed when foo? is requested.
259 at what detail level strings are computed when foo? is requested.
255 This allows users to ask for example that the string form of an
260 This allows users to ask for example that the string form of an
256 object is only computed when foo?? is called, or even never, by
261 object is only computed when foo?? is called, or even never, by
257 setting the object_info_string_level >= 2 in the configuration
262 setting the object_info_string_level >= 2 in the configuration
258 file. This new option has been added and documented. After a
263 file. This new option has been added and documented. After a
259 request by SAGE to be able to control the printing of very large
264 request by SAGE to be able to control the printing of very large
260 objects more easily.
265 objects more easily.
261
266
262 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
267 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
263
268
264 * IPython/ipmaker.py (make_IPython): remove the ipython call path
269 * IPython/ipmaker.py (make_IPython): remove the ipython call path
265 from sys.argv, to be 100% consistent with how Python itself works
270 from sys.argv, to be 100% consistent with how Python itself works
266 (as seen for example with python -i file.py). After a bug report
271 (as seen for example with python -i file.py). After a bug report
267 by Jeffrey Collins.
272 by Jeffrey Collins.
268
273
269 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
274 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
270 nasty bug which was preventing custom namespaces with -pylab,
275 nasty bug which was preventing custom namespaces with -pylab,
271 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
276 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
272 compatibility (long gone from mpl).
277 compatibility (long gone from mpl).
273
278
274 * IPython/ipapi.py (make_session): name change: create->make. We
279 * IPython/ipapi.py (make_session): name change: create->make. We
275 use make in other places (ipmaker,...), it's shorter and easier to
280 use make in other places (ipmaker,...), it's shorter and easier to
276 type and say, etc. I'm trying to clean things before 0.7.2 so
281 type and say, etc. I'm trying to clean things before 0.7.2 so
277 that I can keep things stable wrt to ipapi in the chainsaw branch.
282 that I can keep things stable wrt to ipapi in the chainsaw branch.
278
283
279 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
284 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
280 python-mode recognizes our debugger mode. Add support for
285 python-mode recognizes our debugger mode. Add support for
281 autoindent inside (X)emacs. After a patch sent in by Jin Liu
286 autoindent inside (X)emacs. After a patch sent in by Jin Liu
282 <m.liu.jin-AT-gmail.com> originally written by
287 <m.liu.jin-AT-gmail.com> originally written by
283 doxgen-AT-newsmth.net (with minor modifications for xemacs
288 doxgen-AT-newsmth.net (with minor modifications for xemacs
284 compatibility)
289 compatibility)
285
290
286 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
291 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
287 tracebacks when walking the stack so that the stack tracking system
292 tracebacks when walking the stack so that the stack tracking system
288 in emacs' python-mode can identify the frames correctly.
293 in emacs' python-mode can identify the frames correctly.
289
294
290 * IPython/ipmaker.py (make_IPython): make the internal (and
295 * IPython/ipmaker.py (make_IPython): make the internal (and
291 default config) autoedit_syntax value false by default. Too many
296 default config) autoedit_syntax value false by default. Too many
292 users have complained to me (both on and off-list) about problems
297 users have complained to me (both on and off-list) about problems
293 with this option being on by default, so I'm making it default to
298 with this option being on by default, so I'm making it default to
294 off. It can still be enabled by anyone via the usual mechanisms.
299 off. It can still be enabled by anyone via the usual mechanisms.
295
300
296 * IPython/completer.py (Completer.attr_matches): add support for
301 * IPython/completer.py (Completer.attr_matches): add support for
297 PyCrust-style _getAttributeNames magic method. Patch contributed
302 PyCrust-style _getAttributeNames magic method. Patch contributed
298 by <mscott-AT-goldenspud.com>. Closes #50.
303 by <mscott-AT-goldenspud.com>. Closes #50.
299
304
300 * IPython/iplib.py (InteractiveShell.__init__): remove the
305 * IPython/iplib.py (InteractiveShell.__init__): remove the
301 deletion of exit/quit from __builtin__, which can break
306 deletion of exit/quit from __builtin__, which can break
302 third-party tools like the Zope debugging console. The
307 third-party tools like the Zope debugging console. The
303 %exit/%quit magics remain. In general, it's probably a good idea
308 %exit/%quit magics remain. In general, it's probably a good idea
304 not to delete anything from __builtin__, since we never know what
309 not to delete anything from __builtin__, since we never know what
305 that will break. In any case, python now (for 2.5) will support
310 that will break. In any case, python now (for 2.5) will support
306 'real' exit/quit, so this issue is moot. Closes #55.
311 'real' exit/quit, so this issue is moot. Closes #55.
307
312
308 * IPython/genutils.py (with_obj): rename the 'with' function to
313 * IPython/genutils.py (with_obj): rename the 'with' function to
309 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
314 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
310 becomes a language keyword. Closes #53.
315 becomes a language keyword. Closes #53.
311
316
312 * IPython/FakeModule.py (FakeModule.__init__): add a proper
317 * IPython/FakeModule.py (FakeModule.__init__): add a proper
313 __file__ attribute to this so it fools more things into thinking
318 __file__ attribute to this so it fools more things into thinking
314 it is a real module. Closes #59.
319 it is a real module. Closes #59.
315
320
316 * IPython/Magic.py (magic_edit): add -n option to open the editor
321 * IPython/Magic.py (magic_edit): add -n option to open the editor
317 at a specific line number. After a patch by Stefan van der Walt.
322 at a specific line number. After a patch by Stefan van der Walt.
318
323
319 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
324 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
320
325
321 * IPython/iplib.py (edit_syntax_error): fix crash when for some
326 * IPython/iplib.py (edit_syntax_error): fix crash when for some
322 reason the file could not be opened. After automatic crash
327 reason the file could not be opened. After automatic crash
323 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
328 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
324 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
329 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
325 (_should_recompile): Don't fire editor if using %bg, since there
330 (_should_recompile): Don't fire editor if using %bg, since there
326 is no file in the first place. From the same report as above.
331 is no file in the first place. From the same report as above.
327 (raw_input): protect against faulty third-party prefilters. After
332 (raw_input): protect against faulty third-party prefilters. After
328 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
333 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
329 while running under SAGE.
334 while running under SAGE.
330
335
331 2006-05-23 Ville Vainio <vivainio@gmail.com>
336 2006-05-23 Ville Vainio <vivainio@gmail.com>
332
337
333 * ipapi.py: Stripped down ip.to_user_ns() to work only as
338 * ipapi.py: Stripped down ip.to_user_ns() to work only as
334 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
339 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
335 now returns None (again), unless dummy is specifically allowed by
340 now returns None (again), unless dummy is specifically allowed by
336 ipapi.get(allow_dummy=True).
341 ipapi.get(allow_dummy=True).
337
342
338 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
343 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
339
344
340 * IPython: remove all 2.2-compatibility objects and hacks from
345 * IPython: remove all 2.2-compatibility objects and hacks from
341 everywhere, since we only support 2.3 at this point. Docs
346 everywhere, since we only support 2.3 at this point. Docs
342 updated.
347 updated.
343
348
344 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
349 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
345 Anything requiring extra validation can be turned into a Python
350 Anything requiring extra validation can be turned into a Python
346 property in the future. I used a property for the db one b/c
351 property in the future. I used a property for the db one b/c
347 there was a nasty circularity problem with the initialization
352 there was a nasty circularity problem with the initialization
348 order, which right now I don't have time to clean up.
353 order, which right now I don't have time to clean up.
349
354
350 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
355 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
351 another locking bug reported by Jorgen. I'm not 100% sure though,
356 another locking bug reported by Jorgen. I'm not 100% sure though,
352 so more testing is needed...
357 so more testing is needed...
353
358
354 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
359 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
355
360
356 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
361 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
357 local variables from any routine in user code (typically executed
362 local variables from any routine in user code (typically executed
358 with %run) directly into the interactive namespace. Very useful
363 with %run) directly into the interactive namespace. Very useful
359 when doing complex debugging.
364 when doing complex debugging.
360 (IPythonNotRunning): Changed the default None object to a dummy
365 (IPythonNotRunning): Changed the default None object to a dummy
361 whose attributes can be queried as well as called without
366 whose attributes can be queried as well as called without
362 exploding, to ease writing code which works transparently both in
367 exploding, to ease writing code which works transparently both in
363 and out of ipython and uses some of this API.
368 and out of ipython and uses some of this API.
364
369
365 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
370 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
366
371
367 * IPython/hooks.py (result_display): Fix the fact that our display
372 * IPython/hooks.py (result_display): Fix the fact that our display
368 hook was using str() instead of repr(), as the default python
373 hook was using str() instead of repr(), as the default python
369 console does. This had gone unnoticed b/c it only happened if
374 console does. This had gone unnoticed b/c it only happened if
370 %Pprint was off, but the inconsistency was there.
375 %Pprint was off, but the inconsistency was there.
371
376
372 2006-05-15 Ville Vainio <vivainio@gmail.com>
377 2006-05-15 Ville Vainio <vivainio@gmail.com>
373
378
374 * Oinspect.py: Only show docstring for nonexisting/binary files
379 * Oinspect.py: Only show docstring for nonexisting/binary files
375 when doing object??, closing ticket #62
380 when doing object??, closing ticket #62
376
381
377 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
382 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
378
383
379 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
384 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
380 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
385 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
381 was being released in a routine which hadn't checked if it had
386 was being released in a routine which hadn't checked if it had
382 been the one to acquire it.
387 been the one to acquire it.
383
388
384 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
389 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
385
390
386 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
391 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
387
392
388 2006-04-11 Ville Vainio <vivainio@gmail.com>
393 2006-04-11 Ville Vainio <vivainio@gmail.com>
389
394
390 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
395 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
391 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
396 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
392 prefilters, allowing stuff like magics and aliases in the file.
397 prefilters, allowing stuff like magics and aliases in the file.
393
398
394 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
399 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
395 added. Supported now are "%clear in" and "%clear out" (clear input and
400 added. Supported now are "%clear in" and "%clear out" (clear input and
396 output history, respectively). Also fixed CachedOutput.flush to
401 output history, respectively). Also fixed CachedOutput.flush to
397 properly flush the output cache.
402 properly flush the output cache.
398
403
399 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
404 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
400 half-success (and fail explicitly).
405 half-success (and fail explicitly).
401
406
402 2006-03-28 Ville Vainio <vivainio@gmail.com>
407 2006-03-28 Ville Vainio <vivainio@gmail.com>
403
408
404 * iplib.py: Fix quoting of aliases so that only argless ones
409 * iplib.py: Fix quoting of aliases so that only argless ones
405 are quoted
410 are quoted
406
411
407 2006-03-28 Ville Vainio <vivainio@gmail.com>
412 2006-03-28 Ville Vainio <vivainio@gmail.com>
408
413
409 * iplib.py: Quote aliases with spaces in the name.
414 * iplib.py: Quote aliases with spaces in the name.
410 "c:\program files\blah\bin" is now legal alias target.
415 "c:\program files\blah\bin" is now legal alias target.
411
416
412 * ext_rehashdir.py: Space no longer allowed as arg
417 * ext_rehashdir.py: Space no longer allowed as arg
413 separator, since space is legal in path names.
418 separator, since space is legal in path names.
414
419
415 2006-03-16 Ville Vainio <vivainio@gmail.com>
420 2006-03-16 Ville Vainio <vivainio@gmail.com>
416
421
417 * upgrade_dir.py: Take path.py from Extensions, correcting
422 * upgrade_dir.py: Take path.py from Extensions, correcting
418 %upgrade magic
423 %upgrade magic
419
424
420 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
425 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
421
426
422 * hooks.py: Only enclose editor binary in quotes if legal and
427 * hooks.py: Only enclose editor binary in quotes if legal and
423 necessary (space in the name, and is an existing file). Fixes a bug
428 necessary (space in the name, and is an existing file). Fixes a bug
424 reported by Zachary Pincus.
429 reported by Zachary Pincus.
425
430
426 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
431 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
427
432
428 * Manual: thanks to a tip on proper color handling for Emacs, by
433 * Manual: thanks to a tip on proper color handling for Emacs, by
429 Eric J Haywiser <ejh1-AT-MIT.EDU>.
434 Eric J Haywiser <ejh1-AT-MIT.EDU>.
430
435
431 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
436 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
432 by applying the provided patch. Thanks to Liu Jin
437 by applying the provided patch. Thanks to Liu Jin
433 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
438 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
434 XEmacs/Linux, I'm trusting the submitter that it actually helps
439 XEmacs/Linux, I'm trusting the submitter that it actually helps
435 under win32/GNU Emacs. Will revisit if any problems are reported.
440 under win32/GNU Emacs. Will revisit if any problems are reported.
436
441
437 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
442 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
438
443
439 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
444 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
440 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
445 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
441
446
442 2006-03-12 Ville Vainio <vivainio@gmail.com>
447 2006-03-12 Ville Vainio <vivainio@gmail.com>
443
448
444 * Magic.py (magic_timeit): Added %timeit magic, contributed by
449 * Magic.py (magic_timeit): Added %timeit magic, contributed by
445 Torsten Marek.
450 Torsten Marek.
446
451
447 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
452 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
448
453
449 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
454 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
450 line ranges works again.
455 line ranges works again.
451
456
452 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
457 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
453
458
454 * IPython/iplib.py (showtraceback): add back sys.last_traceback
459 * IPython/iplib.py (showtraceback): add back sys.last_traceback
455 and friends, after a discussion with Zach Pincus on ipython-user.
460 and friends, after a discussion with Zach Pincus on ipython-user.
456 I'm not 100% sure, but after thinking about it quite a bit, it may
461 I'm not 100% sure, but after thinking about it quite a bit, it may
457 be OK. Testing with the multithreaded shells didn't reveal any
462 be OK. Testing with the multithreaded shells didn't reveal any
458 problems, but let's keep an eye out.
463 problems, but let's keep an eye out.
459
464
460 In the process, I fixed a few things which were calling
465 In the process, I fixed a few things which were calling
461 self.InteractiveTB() directly (like safe_execfile), which is a
466 self.InteractiveTB() directly (like safe_execfile), which is a
462 mistake: ALL exception reporting should be done by calling
467 mistake: ALL exception reporting should be done by calling
463 self.showtraceback(), which handles state and tab-completion and
468 self.showtraceback(), which handles state and tab-completion and
464 more.
469 more.
465
470
466 2006-03-01 Ville Vainio <vivainio@gmail.com>
471 2006-03-01 Ville Vainio <vivainio@gmail.com>
467
472
468 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
473 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
469 To use, do "from ipipe import *".
474 To use, do "from ipipe import *".
470
475
471 2006-02-24 Ville Vainio <vivainio@gmail.com>
476 2006-02-24 Ville Vainio <vivainio@gmail.com>
472
477
473 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
478 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
474 "cleanly" and safely than the older upgrade mechanism.
479 "cleanly" and safely than the older upgrade mechanism.
475
480
476 2006-02-21 Ville Vainio <vivainio@gmail.com>
481 2006-02-21 Ville Vainio <vivainio@gmail.com>
477
482
478 * Magic.py: %save works again.
483 * Magic.py: %save works again.
479
484
480 2006-02-15 Ville Vainio <vivainio@gmail.com>
485 2006-02-15 Ville Vainio <vivainio@gmail.com>
481
486
482 * Magic.py: %Pprint works again
487 * Magic.py: %Pprint works again
483
488
484 * Extensions/ipy_sane_defaults.py: Provide everything provided
489 * Extensions/ipy_sane_defaults.py: Provide everything provided
485 in default ipythonrc, to make it possible to have a completely empty
490 in default ipythonrc, to make it possible to have a completely empty
486 ipythonrc (and thus completely rc-file free configuration)
491 ipythonrc (and thus completely rc-file free configuration)
487
492
488 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
493 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
489
494
490 * IPython/hooks.py (editor): quote the call to the editor command,
495 * IPython/hooks.py (editor): quote the call to the editor command,
491 to allow commands with spaces in them. Problem noted by watching
496 to allow commands with spaces in them. Problem noted by watching
492 Ian Oswald's video about textpad under win32 at
497 Ian Oswald's video about textpad under win32 at
493 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
498 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
494
499
495 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
500 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
496 describing magics (we haven't used @ for a loong time).
501 describing magics (we haven't used @ for a loong time).
497
502
498 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
503 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
499 contributed by marienz to close
504 contributed by marienz to close
500 http://www.scipy.net/roundup/ipython/issue53.
505 http://www.scipy.net/roundup/ipython/issue53.
501
506
502 2006-02-10 Ville Vainio <vivainio@gmail.com>
507 2006-02-10 Ville Vainio <vivainio@gmail.com>
503
508
504 * genutils.py: getoutput now works in win32 too
509 * genutils.py: getoutput now works in win32 too
505
510
506 * completer.py: alias and magic completion only invoked
511 * completer.py: alias and magic completion only invoked
507 at the first "item" in the line, to avoid "cd %store"
512 at the first "item" in the line, to avoid "cd %store"
508 nonsense.
513 nonsense.
509
514
510 2006-02-09 Ville Vainio <vivainio@gmail.com>
515 2006-02-09 Ville Vainio <vivainio@gmail.com>
511
516
512 * test/*: Added a unit testing framework (finally).
517 * test/*: Added a unit testing framework (finally).
513 '%run runtests.py' to run test_*.
518 '%run runtests.py' to run test_*.
514
519
515 * ipapi.py: Exposed runlines and set_custom_exc
520 * ipapi.py: Exposed runlines and set_custom_exc
516
521
517 2006-02-07 Ville Vainio <vivainio@gmail.com>
522 2006-02-07 Ville Vainio <vivainio@gmail.com>
518
523
519 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
524 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
520 instead use "f(1 2)" as before.
525 instead use "f(1 2)" as before.
521
526
522 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
527 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
523
528
524 * IPython/demo.py (IPythonDemo): Add new classes to the demo
529 * IPython/demo.py (IPythonDemo): Add new classes to the demo
525 facilities, for demos processed by the IPython input filter
530 facilities, for demos processed by the IPython input filter
526 (IPythonDemo), and for running a script one-line-at-a-time as a
531 (IPythonDemo), and for running a script one-line-at-a-time as a
527 demo, both for pure Python (LineDemo) and for IPython-processed
532 demo, both for pure Python (LineDemo) and for IPython-processed
528 input (IPythonLineDemo). After a request by Dave Kohel, from the
533 input (IPythonLineDemo). After a request by Dave Kohel, from the
529 SAGE team.
534 SAGE team.
530 (Demo.edit): added an edit() method to the demo objects, to edit
535 (Demo.edit): added an edit() method to the demo objects, to edit
531 the in-memory copy of the last executed block.
536 the in-memory copy of the last executed block.
532
537
533 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
538 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
534 processing to %edit, %macro and %save. These commands can now be
539 processing to %edit, %macro and %save. These commands can now be
535 invoked on the unprocessed input as it was typed by the user
540 invoked on the unprocessed input as it was typed by the user
536 (without any prefilters applied). After requests by the SAGE team
541 (without any prefilters applied). After requests by the SAGE team
537 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
542 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
538
543
539 2006-02-01 Ville Vainio <vivainio@gmail.com>
544 2006-02-01 Ville Vainio <vivainio@gmail.com>
540
545
541 * setup.py, eggsetup.py: easy_install ipython==dev works
546 * setup.py, eggsetup.py: easy_install ipython==dev works
542 correctly now (on Linux)
547 correctly now (on Linux)
543
548
544 * ipy_user_conf,ipmaker: user config changes, removed spurious
549 * ipy_user_conf,ipmaker: user config changes, removed spurious
545 warnings
550 warnings
546
551
547 * iplib: if rc.banner is string, use it as is.
552 * iplib: if rc.banner is string, use it as is.
548
553
549 * Magic: %pycat accepts a string argument and pages it's contents.
554 * Magic: %pycat accepts a string argument and pages it's contents.
550
555
551
556
552 2006-01-30 Ville Vainio <vivainio@gmail.com>
557 2006-01-30 Ville Vainio <vivainio@gmail.com>
553
558
554 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
559 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
555 Now %store and bookmarks work through PickleShare, meaning that
560 Now %store and bookmarks work through PickleShare, meaning that
556 concurrent access is possible and all ipython sessions see the
561 concurrent access is possible and all ipython sessions see the
557 same database situation all the time, instead of snapshot of
562 same database situation all the time, instead of snapshot of
558 the situation when the session was started. Hence, %bookmark
563 the situation when the session was started. Hence, %bookmark
559 results are immediately accessible from othes sessions. The database
564 results are immediately accessible from othes sessions. The database
560 is also available for use by user extensions. See:
565 is also available for use by user extensions. See:
561 http://www.python.org/pypi/pickleshare
566 http://www.python.org/pypi/pickleshare
562
567
563 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
568 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
564
569
565 * aliases can now be %store'd
570 * aliases can now be %store'd
566
571
567 * path.py moved to Extensions so that pickleshare does not need
572 * path.py moved to Extensions so that pickleshare does not need
568 IPython-specific import. Extensions added to pythonpath right
573 IPython-specific import. Extensions added to pythonpath right
569 at __init__.
574 at __init__.
570
575
571 * iplib.py: ipalias deprecated/redundant; aliases are converted and
576 * iplib.py: ipalias deprecated/redundant; aliases are converted and
572 called with _ip.system and the pre-transformed command string.
577 called with _ip.system and the pre-transformed command string.
573
578
574 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
579 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
575
580
576 * IPython/iplib.py (interact): Fix that we were not catching
581 * IPython/iplib.py (interact): Fix that we were not catching
577 KeyboardInterrupt exceptions properly. I'm not quite sure why the
582 KeyboardInterrupt exceptions properly. I'm not quite sure why the
578 logic here had to change, but it's fixed now.
583 logic here had to change, but it's fixed now.
579
584
580 2006-01-29 Ville Vainio <vivainio@gmail.com>
585 2006-01-29 Ville Vainio <vivainio@gmail.com>
581
586
582 * iplib.py: Try to import pyreadline on Windows.
587 * iplib.py: Try to import pyreadline on Windows.
583
588
584 2006-01-27 Ville Vainio <vivainio@gmail.com>
589 2006-01-27 Ville Vainio <vivainio@gmail.com>
585
590
586 * iplib.py: Expose ipapi as _ip in builtin namespace.
591 * iplib.py: Expose ipapi as _ip in builtin namespace.
587 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
592 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
588 and ip_set_hook (-> _ip.set_hook) redundant. % and !
593 and ip_set_hook (-> _ip.set_hook) redundant. % and !
589 syntax now produce _ip.* variant of the commands.
594 syntax now produce _ip.* variant of the commands.
590
595
591 * "_ip.options().autoedit_syntax = 2" automatically throws
596 * "_ip.options().autoedit_syntax = 2" automatically throws
592 user to editor for syntax error correction without prompting.
597 user to editor for syntax error correction without prompting.
593
598
594 2006-01-27 Ville Vainio <vivainio@gmail.com>
599 2006-01-27 Ville Vainio <vivainio@gmail.com>
595
600
596 * ipmaker.py: Give "realistic" sys.argv for scripts (without
601 * ipmaker.py: Give "realistic" sys.argv for scripts (without
597 'ipython' at argv[0]) executed through command line.
602 'ipython' at argv[0]) executed through command line.
598 NOTE: this DEPRECATES calling ipython with multiple scripts
603 NOTE: this DEPRECATES calling ipython with multiple scripts
599 ("ipython a.py b.py c.py")
604 ("ipython a.py b.py c.py")
600
605
601 * iplib.py, hooks.py: Added configurable input prefilter,
606 * iplib.py, hooks.py: Added configurable input prefilter,
602 named 'input_prefilter'. See ext_rescapture.py for example
607 named 'input_prefilter'. See ext_rescapture.py for example
603 usage.
608 usage.
604
609
605 * ext_rescapture.py, Magic.py: Better system command output capture
610 * ext_rescapture.py, Magic.py: Better system command output capture
606 through 'var = !ls' (deprecates user-visible %sc). Same notation
611 through 'var = !ls' (deprecates user-visible %sc). Same notation
607 applies for magics, 'var = %alias' assigns alias list to var.
612 applies for magics, 'var = %alias' assigns alias list to var.
608
613
609 * ipapi.py: added meta() for accessing extension-usable data store.
614 * ipapi.py: added meta() for accessing extension-usable data store.
610
615
611 * iplib.py: added InteractiveShell.getapi(). New magics should be
616 * iplib.py: added InteractiveShell.getapi(). New magics should be
612 written doing self.getapi() instead of using the shell directly.
617 written doing self.getapi() instead of using the shell directly.
613
618
614 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
619 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
615 %store foo >> ~/myfoo.txt to store variables to files (in clean
620 %store foo >> ~/myfoo.txt to store variables to files (in clean
616 textual form, not a restorable pickle).
621 textual form, not a restorable pickle).
617
622
618 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
623 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
619
624
620 * usage.py, Magic.py: added %quickref
625 * usage.py, Magic.py: added %quickref
621
626
622 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
627 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
623
628
624 * GetoptErrors when invoking magics etc. with wrong args
629 * GetoptErrors when invoking magics etc. with wrong args
625 are now more helpful:
630 are now more helpful:
626 GetoptError: option -l not recognized (allowed: "qb" )
631 GetoptError: option -l not recognized (allowed: "qb" )
627
632
628 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
633 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
629
634
630 * IPython/demo.py (Demo.show): Flush stdout after each block, so
635 * IPython/demo.py (Demo.show): Flush stdout after each block, so
631 computationally intensive blocks don't appear to stall the demo.
636 computationally intensive blocks don't appear to stall the demo.
632
637
633 2006-01-24 Ville Vainio <vivainio@gmail.com>
638 2006-01-24 Ville Vainio <vivainio@gmail.com>
634
639
635 * iplib.py, hooks.py: 'result_display' hook can return a non-None
640 * iplib.py, hooks.py: 'result_display' hook can return a non-None
636 value to manipulate resulting history entry.
641 value to manipulate resulting history entry.
637
642
638 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
643 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
639 to instance methods of IPApi class, to make extending an embedded
644 to instance methods of IPApi class, to make extending an embedded
640 IPython feasible. See ext_rehashdir.py for example usage.
645 IPython feasible. See ext_rehashdir.py for example usage.
641
646
642 * Merged 1071-1076 from branches/0.7.1
647 * Merged 1071-1076 from branches/0.7.1
643
648
644
649
645 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
650 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
646
651
647 * tools/release (daystamp): Fix build tools to use the new
652 * tools/release (daystamp): Fix build tools to use the new
648 eggsetup.py script to build lightweight eggs.
653 eggsetup.py script to build lightweight eggs.
649
654
650 * Applied changesets 1062 and 1064 before 0.7.1 release.
655 * Applied changesets 1062 and 1064 before 0.7.1 release.
651
656
652 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
657 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
653 see the raw input history (without conversions like %ls ->
658 see the raw input history (without conversions like %ls ->
654 ipmagic("ls")). After a request from W. Stein, SAGE
659 ipmagic("ls")). After a request from W. Stein, SAGE
655 (http://modular.ucsd.edu/sage) developer. This information is
660 (http://modular.ucsd.edu/sage) developer. This information is
656 stored in the input_hist_raw attribute of the IPython instance, so
661 stored in the input_hist_raw attribute of the IPython instance, so
657 developers can access it if needed (it's an InputList instance).
662 developers can access it if needed (it's an InputList instance).
658
663
659 * Versionstring = 0.7.2.svn
664 * Versionstring = 0.7.2.svn
660
665
661 * eggsetup.py: A separate script for constructing eggs, creates
666 * eggsetup.py: A separate script for constructing eggs, creates
662 proper launch scripts even on Windows (an .exe file in
667 proper launch scripts even on Windows (an .exe file in
663 \python24\scripts).
668 \python24\scripts).
664
669
665 * ipapi.py: launch_new_instance, launch entry point needed for the
670 * ipapi.py: launch_new_instance, launch entry point needed for the
666 egg.
671 egg.
667
672
668 2006-01-23 Ville Vainio <vivainio@gmail.com>
673 2006-01-23 Ville Vainio <vivainio@gmail.com>
669
674
670 * Added %cpaste magic for pasting python code
675 * Added %cpaste magic for pasting python code
671
676
672 2006-01-22 Ville Vainio <vivainio@gmail.com>
677 2006-01-22 Ville Vainio <vivainio@gmail.com>
673
678
674 * Merge from branches/0.7.1 into trunk, revs 1052-1057
679 * Merge from branches/0.7.1 into trunk, revs 1052-1057
675
680
676 * Versionstring = 0.7.2.svn
681 * Versionstring = 0.7.2.svn
677
682
678 * eggsetup.py: A separate script for constructing eggs, creates
683 * eggsetup.py: A separate script for constructing eggs, creates
679 proper launch scripts even on Windows (an .exe file in
684 proper launch scripts even on Windows (an .exe file in
680 \python24\scripts).
685 \python24\scripts).
681
686
682 * ipapi.py: launch_new_instance, launch entry point needed for the
687 * ipapi.py: launch_new_instance, launch entry point needed for the
683 egg.
688 egg.
684
689
685 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
690 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
686
691
687 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
692 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
688 %pfile foo would print the file for foo even if it was a binary.
693 %pfile foo would print the file for foo even if it was a binary.
689 Now, extensions '.so' and '.dll' are skipped.
694 Now, extensions '.so' and '.dll' are skipped.
690
695
691 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
696 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
692 bug, where macros would fail in all threaded modes. I'm not 100%
697 bug, where macros would fail in all threaded modes. I'm not 100%
693 sure, so I'm going to put out an rc instead of making a release
698 sure, so I'm going to put out an rc instead of making a release
694 today, and wait for feedback for at least a few days.
699 today, and wait for feedback for at least a few days.
695
700
696 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
701 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
697 it...) the handling of pasting external code with autoindent on.
702 it...) the handling of pasting external code with autoindent on.
698 To get out of a multiline input, the rule will appear for most
703 To get out of a multiline input, the rule will appear for most
699 users unchanged: two blank lines or change the indent level
704 users unchanged: two blank lines or change the indent level
700 proposed by IPython. But there is a twist now: you can
705 proposed by IPython. But there is a twist now: you can
701 add/subtract only *one or two spaces*. If you add/subtract three
706 add/subtract only *one or two spaces*. If you add/subtract three
702 or more (unless you completely delete the line), IPython will
707 or more (unless you completely delete the line), IPython will
703 accept that line, and you'll need to enter a second one of pure
708 accept that line, and you'll need to enter a second one of pure
704 whitespace. I know it sounds complicated, but I can't find a
709 whitespace. I know it sounds complicated, but I can't find a
705 different solution that covers all the cases, with the right
710 different solution that covers all the cases, with the right
706 heuristics. Hopefully in actual use, nobody will really notice
711 heuristics. Hopefully in actual use, nobody will really notice
707 all these strange rules and things will 'just work'.
712 all these strange rules and things will 'just work'.
708
713
709 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
714 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
710
715
711 * IPython/iplib.py (interact): catch exceptions which can be
716 * IPython/iplib.py (interact): catch exceptions which can be
712 triggered asynchronously by signal handlers. Thanks to an
717 triggered asynchronously by signal handlers. Thanks to an
713 automatic crash report, submitted by Colin Kingsley
718 automatic crash report, submitted by Colin Kingsley
714 <tercel-AT-gentoo.org>.
719 <tercel-AT-gentoo.org>.
715
720
716 2006-01-20 Ville Vainio <vivainio@gmail.com>
721 2006-01-20 Ville Vainio <vivainio@gmail.com>
717
722
718 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
723 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
719 (%rehashdir, very useful, try it out) of how to extend ipython
724 (%rehashdir, very useful, try it out) of how to extend ipython
720 with new magics. Also added Extensions dir to pythonpath to make
725 with new magics. Also added Extensions dir to pythonpath to make
721 importing extensions easy.
726 importing extensions easy.
722
727
723 * %store now complains when trying to store interactively declared
728 * %store now complains when trying to store interactively declared
724 classes / instances of those classes.
729 classes / instances of those classes.
725
730
726 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
731 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
727 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
732 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
728 if they exist, and ipy_user_conf.py with some defaults is created for
733 if they exist, and ipy_user_conf.py with some defaults is created for
729 the user.
734 the user.
730
735
731 * Startup rehashing done by the config file, not InterpreterExec.
736 * Startup rehashing done by the config file, not InterpreterExec.
732 This means system commands are available even without selecting the
737 This means system commands are available even without selecting the
733 pysh profile. It's the sensible default after all.
738 pysh profile. It's the sensible default after all.
734
739
735 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
740 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
736
741
737 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
742 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
738 multiline code with autoindent on working. But I am really not
743 multiline code with autoindent on working. But I am really not
739 sure, so this needs more testing. Will commit a debug-enabled
744 sure, so this needs more testing. Will commit a debug-enabled
740 version for now, while I test it some more, so that Ville and
745 version for now, while I test it some more, so that Ville and
741 others may also catch any problems. Also made
746 others may also catch any problems. Also made
742 self.indent_current_str() a method, to ensure that there's no
747 self.indent_current_str() a method, to ensure that there's no
743 chance of the indent space count and the corresponding string
748 chance of the indent space count and the corresponding string
744 falling out of sync. All code needing the string should just call
749 falling out of sync. All code needing the string should just call
745 the method.
750 the method.
746
751
747 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
752 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
748
753
749 * IPython/Magic.py (magic_edit): fix check for when users don't
754 * IPython/Magic.py (magic_edit): fix check for when users don't
750 save their output files, the try/except was in the wrong section.
755 save their output files, the try/except was in the wrong section.
751
756
752 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
757 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
753
758
754 * IPython/Magic.py (magic_run): fix __file__ global missing from
759 * IPython/Magic.py (magic_run): fix __file__ global missing from
755 script's namespace when executed via %run. After a report by
760 script's namespace when executed via %run. After a report by
756 Vivian.
761 Vivian.
757
762
758 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
763 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
759 when using python 2.4. The parent constructor changed in 2.4, and
764 when using python 2.4. The parent constructor changed in 2.4, and
760 we need to track it directly (we can't call it, as it messes up
765 we need to track it directly (we can't call it, as it messes up
761 readline and tab-completion inside our pdb would stop working).
766 readline and tab-completion inside our pdb would stop working).
762 After a bug report by R. Bernstein <rocky-AT-panix.com>.
767 After a bug report by R. Bernstein <rocky-AT-panix.com>.
763
768
764 2006-01-16 Ville Vainio <vivainio@gmail.com>
769 2006-01-16 Ville Vainio <vivainio@gmail.com>
765
770
766 * Ipython/magic.py: Reverted back to old %edit functionality
771 * Ipython/magic.py: Reverted back to old %edit functionality
767 that returns file contents on exit.
772 that returns file contents on exit.
768
773
769 * IPython/path.py: Added Jason Orendorff's "path" module to
774 * IPython/path.py: Added Jason Orendorff's "path" module to
770 IPython tree, http://www.jorendorff.com/articles/python/path/.
775 IPython tree, http://www.jorendorff.com/articles/python/path/.
771 You can get path objects conveniently through %sc, and !!, e.g.:
776 You can get path objects conveniently through %sc, and !!, e.g.:
772 sc files=ls
777 sc files=ls
773 for p in files.paths: # or files.p
778 for p in files.paths: # or files.p
774 print p,p.mtime
779 print p,p.mtime
775
780
776 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
781 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
777 now work again without considering the exclusion regexp -
782 now work again without considering the exclusion regexp -
778 hence, things like ',foo my/path' turn to 'foo("my/path")'
783 hence, things like ',foo my/path' turn to 'foo("my/path")'
779 instead of syntax error.
784 instead of syntax error.
780
785
781
786
782 2006-01-14 Ville Vainio <vivainio@gmail.com>
787 2006-01-14 Ville Vainio <vivainio@gmail.com>
783
788
784 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
789 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
785 ipapi decorators for python 2.4 users, options() provides access to rc
790 ipapi decorators for python 2.4 users, options() provides access to rc
786 data.
791 data.
787
792
788 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
793 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
789 as path separators (even on Linux ;-). Space character after
794 as path separators (even on Linux ;-). Space character after
790 backslash (as yielded by tab completer) is still space;
795 backslash (as yielded by tab completer) is still space;
791 "%cd long\ name" works as expected.
796 "%cd long\ name" works as expected.
792
797
793 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
798 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
794 as "chain of command", with priority. API stays the same,
799 as "chain of command", with priority. API stays the same,
795 TryNext exception raised by a hook function signals that
800 TryNext exception raised by a hook function signals that
796 current hook failed and next hook should try handling it, as
801 current hook failed and next hook should try handling it, as
797 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
802 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
798 requested configurable display hook, which is now implemented.
803 requested configurable display hook, which is now implemented.
799
804
800 2006-01-13 Ville Vainio <vivainio@gmail.com>
805 2006-01-13 Ville Vainio <vivainio@gmail.com>
801
806
802 * IPython/platutils*.py: platform specific utility functions,
807 * IPython/platutils*.py: platform specific utility functions,
803 so far only set_term_title is implemented (change terminal
808 so far only set_term_title is implemented (change terminal
804 label in windowing systems). %cd now changes the title to
809 label in windowing systems). %cd now changes the title to
805 current dir.
810 current dir.
806
811
807 * IPython/Release.py: Added myself to "authors" list,
812 * IPython/Release.py: Added myself to "authors" list,
808 had to create new files.
813 had to create new files.
809
814
810 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
815 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
811 shell escape; not a known bug but had potential to be one in the
816 shell escape; not a known bug but had potential to be one in the
812 future.
817 future.
813
818
814 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
819 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
815 extension API for IPython! See the module for usage example. Fix
820 extension API for IPython! See the module for usage example. Fix
816 OInspect for docstring-less magic functions.
821 OInspect for docstring-less magic functions.
817
822
818
823
819 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
824 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
820
825
821 * IPython/iplib.py (raw_input): temporarily deactivate all
826 * IPython/iplib.py (raw_input): temporarily deactivate all
822 attempts at allowing pasting of code with autoindent on. It
827 attempts at allowing pasting of code with autoindent on. It
823 introduced bugs (reported by Prabhu) and I can't seem to find a
828 introduced bugs (reported by Prabhu) and I can't seem to find a
824 robust combination which works in all cases. Will have to revisit
829 robust combination which works in all cases. Will have to revisit
825 later.
830 later.
826
831
827 * IPython/genutils.py: remove isspace() function. We've dropped
832 * IPython/genutils.py: remove isspace() function. We've dropped
828 2.2 compatibility, so it's OK to use the string method.
833 2.2 compatibility, so it's OK to use the string method.
829
834
830 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
835 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
831
836
832 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
837 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
833 matching what NOT to autocall on, to include all python binary
838 matching what NOT to autocall on, to include all python binary
834 operators (including things like 'and', 'or', 'is' and 'in').
839 operators (including things like 'and', 'or', 'is' and 'in').
835 Prompted by a bug report on 'foo & bar', but I realized we had
840 Prompted by a bug report on 'foo & bar', but I realized we had
836 many more potential bug cases with other operators. The regexp is
841 many more potential bug cases with other operators. The regexp is
837 self.re_exclude_auto, it's fairly commented.
842 self.re_exclude_auto, it's fairly commented.
838
843
839 2006-01-12 Ville Vainio <vivainio@gmail.com>
844 2006-01-12 Ville Vainio <vivainio@gmail.com>
840
845
841 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
846 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
842 Prettified and hardened string/backslash quoting with ipsystem(),
847 Prettified and hardened string/backslash quoting with ipsystem(),
843 ipalias() and ipmagic(). Now even \ characters are passed to
848 ipalias() and ipmagic(). Now even \ characters are passed to
844 %magics, !shell escapes and aliases exactly as they are in the
849 %magics, !shell escapes and aliases exactly as they are in the
845 ipython command line. Should improve backslash experience,
850 ipython command line. Should improve backslash experience,
846 particularly in Windows (path delimiter for some commands that
851 particularly in Windows (path delimiter for some commands that
847 won't understand '/'), but Unix benefits as well (regexps). %cd
852 won't understand '/'), but Unix benefits as well (regexps). %cd
848 magic still doesn't support backslash path delimiters, though. Also
853 magic still doesn't support backslash path delimiters, though. Also
849 deleted all pretense of supporting multiline command strings in
854 deleted all pretense of supporting multiline command strings in
850 !system or %magic commands. Thanks to Jerry McRae for suggestions.
855 !system or %magic commands. Thanks to Jerry McRae for suggestions.
851
856
852 * doc/build_doc_instructions.txt added. Documentation on how to
857 * doc/build_doc_instructions.txt added. Documentation on how to
853 use doc/update_manual.py, added yesterday. Both files contributed
858 use doc/update_manual.py, added yesterday. Both files contributed
854 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
859 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
855 doc/*.sh for deprecation at a later date.
860 doc/*.sh for deprecation at a later date.
856
861
857 * /ipython.py Added ipython.py to root directory for
862 * /ipython.py Added ipython.py to root directory for
858 zero-installation (tar xzvf ipython.tgz; cd ipython; python
863 zero-installation (tar xzvf ipython.tgz; cd ipython; python
859 ipython.py) and development convenience (no need to keep doing
864 ipython.py) and development convenience (no need to keep doing
860 "setup.py install" between changes).
865 "setup.py install" between changes).
861
866
862 * Made ! and !! shell escapes work (again) in multiline expressions:
867 * Made ! and !! shell escapes work (again) in multiline expressions:
863 if 1:
868 if 1:
864 !ls
869 !ls
865 !!ls
870 !!ls
866
871
867 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
872 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
868
873
869 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
874 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
870 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
875 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
871 module in case-insensitive installation. Was causing crashes
876 module in case-insensitive installation. Was causing crashes
872 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
877 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
873
878
874 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
879 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
875 <marienz-AT-gentoo.org>, closes
880 <marienz-AT-gentoo.org>, closes
876 http://www.scipy.net/roundup/ipython/issue51.
881 http://www.scipy.net/roundup/ipython/issue51.
877
882
878 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
883 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
879
884
880 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
885 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
881 problem of excessive CPU usage under *nix and keyboard lag under
886 problem of excessive CPU usage under *nix and keyboard lag under
882 win32.
887 win32.
883
888
884 2006-01-10 *** Released version 0.7.0
889 2006-01-10 *** Released version 0.7.0
885
890
886 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
891 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
887
892
888 * IPython/Release.py (revision): tag version number to 0.7.0,
893 * IPython/Release.py (revision): tag version number to 0.7.0,
889 ready for release.
894 ready for release.
890
895
891 * IPython/Magic.py (magic_edit): Add print statement to %edit so
896 * IPython/Magic.py (magic_edit): Add print statement to %edit so
892 it informs the user of the name of the temp. file used. This can
897 it informs the user of the name of the temp. file used. This can
893 help if you decide later to reuse that same file, so you know
898 help if you decide later to reuse that same file, so you know
894 where to copy the info from.
899 where to copy the info from.
895
900
896 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
901 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
897
902
898 * setup_bdist_egg.py: little script to build an egg. Added
903 * setup_bdist_egg.py: little script to build an egg. Added
899 support in the release tools as well.
904 support in the release tools as well.
900
905
901 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
906 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
902
907
903 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
908 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
904 version selection (new -wxversion command line and ipythonrc
909 version selection (new -wxversion command line and ipythonrc
905 parameter). Patch contributed by Arnd Baecker
910 parameter). Patch contributed by Arnd Baecker
906 <arnd.baecker-AT-web.de>.
911 <arnd.baecker-AT-web.de>.
907
912
908 * IPython/iplib.py (embed_mainloop): fix tab-completion in
913 * IPython/iplib.py (embed_mainloop): fix tab-completion in
909 embedded instances, for variables defined at the interactive
914 embedded instances, for variables defined at the interactive
910 prompt of the embedded ipython. Reported by Arnd.
915 prompt of the embedded ipython. Reported by Arnd.
911
916
912 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
917 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
913 it can be used as a (stateful) toggle, or with a direct parameter.
918 it can be used as a (stateful) toggle, or with a direct parameter.
914
919
915 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
920 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
916 could be triggered in certain cases and cause the traceback
921 could be triggered in certain cases and cause the traceback
917 printer not to work.
922 printer not to work.
918
923
919 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
924 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
920
925
921 * IPython/iplib.py (_should_recompile): Small fix, closes
926 * IPython/iplib.py (_should_recompile): Small fix, closes
922 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
927 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
923
928
924 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
929 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
925
930
926 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
931 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
927 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
932 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
928 Moad for help with tracking it down.
933 Moad for help with tracking it down.
929
934
930 * IPython/iplib.py (handle_auto): fix autocall handling for
935 * IPython/iplib.py (handle_auto): fix autocall handling for
931 objects which support BOTH __getitem__ and __call__ (so that f [x]
936 objects which support BOTH __getitem__ and __call__ (so that f [x]
932 is left alone, instead of becoming f([x]) automatically).
937 is left alone, instead of becoming f([x]) automatically).
933
938
934 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
939 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
935 Ville's patch.
940 Ville's patch.
936
941
937 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
942 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
938
943
939 * IPython/iplib.py (handle_auto): changed autocall semantics to
944 * IPython/iplib.py (handle_auto): changed autocall semantics to
940 include 'smart' mode, where the autocall transformation is NOT
945 include 'smart' mode, where the autocall transformation is NOT
941 applied if there are no arguments on the line. This allows you to
946 applied if there are no arguments on the line. This allows you to
942 just type 'foo' if foo is a callable to see its internal form,
947 just type 'foo' if foo is a callable to see its internal form,
943 instead of having it called with no arguments (typically a
948 instead of having it called with no arguments (typically a
944 mistake). The old 'full' autocall still exists: for that, you
949 mistake). The old 'full' autocall still exists: for that, you
945 need to set the 'autocall' parameter to 2 in your ipythonrc file.
950 need to set the 'autocall' parameter to 2 in your ipythonrc file.
946
951
947 * IPython/completer.py (Completer.attr_matches): add
952 * IPython/completer.py (Completer.attr_matches): add
948 tab-completion support for Enthoughts' traits. After a report by
953 tab-completion support for Enthoughts' traits. After a report by
949 Arnd and a patch by Prabhu.
954 Arnd and a patch by Prabhu.
950
955
951 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
956 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
952
957
953 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
958 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
954 Schmolck's patch to fix inspect.getinnerframes().
959 Schmolck's patch to fix inspect.getinnerframes().
955
960
956 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
961 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
957 for embedded instances, regarding handling of namespaces and items
962 for embedded instances, regarding handling of namespaces and items
958 added to the __builtin__ one. Multiple embedded instances and
963 added to the __builtin__ one. Multiple embedded instances and
959 recursive embeddings should work better now (though I'm not sure
964 recursive embeddings should work better now (though I'm not sure
960 I've got all the corner cases fixed, that code is a bit of a brain
965 I've got all the corner cases fixed, that code is a bit of a brain
961 twister).
966 twister).
962
967
963 * IPython/Magic.py (magic_edit): added support to edit in-memory
968 * IPython/Magic.py (magic_edit): added support to edit in-memory
964 macros (automatically creates the necessary temp files). %edit
969 macros (automatically creates the necessary temp files). %edit
965 also doesn't return the file contents anymore, it's just noise.
970 also doesn't return the file contents anymore, it's just noise.
966
971
967 * IPython/completer.py (Completer.attr_matches): revert change to
972 * IPython/completer.py (Completer.attr_matches): revert change to
968 complete only on attributes listed in __all__. I realized it
973 complete only on attributes listed in __all__. I realized it
969 cripples the tab-completion system as a tool for exploring the
974 cripples the tab-completion system as a tool for exploring the
970 internals of unknown libraries (it renders any non-__all__
975 internals of unknown libraries (it renders any non-__all__
971 attribute off-limits). I got bit by this when trying to see
976 attribute off-limits). I got bit by this when trying to see
972 something inside the dis module.
977 something inside the dis module.
973
978
974 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
979 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
975
980
976 * IPython/iplib.py (InteractiveShell.__init__): add .meta
981 * IPython/iplib.py (InteractiveShell.__init__): add .meta
977 namespace for users and extension writers to hold data in. This
982 namespace for users and extension writers to hold data in. This
978 follows the discussion in
983 follows the discussion in
979 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
984 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
980
985
981 * IPython/completer.py (IPCompleter.complete): small patch to help
986 * IPython/completer.py (IPCompleter.complete): small patch to help
982 tab-completion under Emacs, after a suggestion by John Barnard
987 tab-completion under Emacs, after a suggestion by John Barnard
983 <barnarj-AT-ccf.org>.
988 <barnarj-AT-ccf.org>.
984
989
985 * IPython/Magic.py (Magic.extract_input_slices): added support for
990 * IPython/Magic.py (Magic.extract_input_slices): added support for
986 the slice notation in magics to use N-M to represent numbers N...M
991 the slice notation in magics to use N-M to represent numbers N...M
987 (closed endpoints). This is used by %macro and %save.
992 (closed endpoints). This is used by %macro and %save.
988
993
989 * IPython/completer.py (Completer.attr_matches): for modules which
994 * IPython/completer.py (Completer.attr_matches): for modules which
990 define __all__, complete only on those. After a patch by Jeffrey
995 define __all__, complete only on those. After a patch by Jeffrey
991 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
996 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
992 speed up this routine.
997 speed up this routine.
993
998
994 * IPython/Logger.py (Logger.log): fix a history handling bug. I
999 * IPython/Logger.py (Logger.log): fix a history handling bug. I
995 don't know if this is the end of it, but the behavior now is
1000 don't know if this is the end of it, but the behavior now is
996 certainly much more correct. Note that coupled with macros,
1001 certainly much more correct. Note that coupled with macros,
997 slightly surprising (at first) behavior may occur: a macro will in
1002 slightly surprising (at first) behavior may occur: a macro will in
998 general expand to multiple lines of input, so upon exiting, the
1003 general expand to multiple lines of input, so upon exiting, the
999 in/out counters will both be bumped by the corresponding amount
1004 in/out counters will both be bumped by the corresponding amount
1000 (as if the macro's contents had been typed interactively). Typing
1005 (as if the macro's contents had been typed interactively). Typing
1001 %hist will reveal the intermediate (silently processed) lines.
1006 %hist will reveal the intermediate (silently processed) lines.
1002
1007
1003 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
1008 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
1004 pickle to fail (%run was overwriting __main__ and not restoring
1009 pickle to fail (%run was overwriting __main__ and not restoring
1005 it, but pickle relies on __main__ to operate).
1010 it, but pickle relies on __main__ to operate).
1006
1011
1007 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
1012 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
1008 using properties, but forgot to make the main InteractiveShell
1013 using properties, but forgot to make the main InteractiveShell
1009 class a new-style class. Properties fail silently, and
1014 class a new-style class. Properties fail silently, and
1010 mysteriously, with old-style class (getters work, but
1015 mysteriously, with old-style class (getters work, but
1011 setters don't do anything).
1016 setters don't do anything).
1012
1017
1013 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
1018 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
1014
1019
1015 * IPython/Magic.py (magic_history): fix history reporting bug (I
1020 * IPython/Magic.py (magic_history): fix history reporting bug (I
1016 know some nasties are still there, I just can't seem to find a
1021 know some nasties are still there, I just can't seem to find a
1017 reproducible test case to track them down; the input history is
1022 reproducible test case to track them down; the input history is
1018 falling out of sync...)
1023 falling out of sync...)
1019
1024
1020 * IPython/iplib.py (handle_shell_escape): fix bug where both
1025 * IPython/iplib.py (handle_shell_escape): fix bug where both
1021 aliases and system accesses where broken for indented code (such
1026 aliases and system accesses where broken for indented code (such
1022 as loops).
1027 as loops).
1023
1028
1024 * IPython/genutils.py (shell): fix small but critical bug for
1029 * IPython/genutils.py (shell): fix small but critical bug for
1025 win32 system access.
1030 win32 system access.
1026
1031
1027 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
1032 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
1028
1033
1029 * IPython/iplib.py (showtraceback): remove use of the
1034 * IPython/iplib.py (showtraceback): remove use of the
1030 sys.last_{type/value/traceback} structures, which are non
1035 sys.last_{type/value/traceback} structures, which are non
1031 thread-safe.
1036 thread-safe.
1032 (_prefilter): change control flow to ensure that we NEVER
1037 (_prefilter): change control flow to ensure that we NEVER
1033 introspect objects when autocall is off. This will guarantee that
1038 introspect objects when autocall is off. This will guarantee that
1034 having an input line of the form 'x.y', where access to attribute
1039 having an input line of the form 'x.y', where access to attribute
1035 'y' has side effects, doesn't trigger the side effect TWICE. It
1040 'y' has side effects, doesn't trigger the side effect TWICE. It
1036 is important to note that, with autocall on, these side effects
1041 is important to note that, with autocall on, these side effects
1037 can still happen.
1042 can still happen.
1038 (ipsystem): new builtin, to complete the ip{magic/alias/system}
1043 (ipsystem): new builtin, to complete the ip{magic/alias/system}
1039 trio. IPython offers these three kinds of special calls which are
1044 trio. IPython offers these three kinds of special calls which are
1040 not python code, and it's a good thing to have their call method
1045 not python code, and it's a good thing to have their call method
1041 be accessible as pure python functions (not just special syntax at
1046 be accessible as pure python functions (not just special syntax at
1042 the command line). It gives us a better internal implementation
1047 the command line). It gives us a better internal implementation
1043 structure, as well as exposing these for user scripting more
1048 structure, as well as exposing these for user scripting more
1044 cleanly.
1049 cleanly.
1045
1050
1046 * IPython/macro.py (Macro.__init__): moved macros to a standalone
1051 * IPython/macro.py (Macro.__init__): moved macros to a standalone
1047 file. Now that they'll be more likely to be used with the
1052 file. Now that they'll be more likely to be used with the
1048 persistance system (%store), I want to make sure their module path
1053 persistance system (%store), I want to make sure their module path
1049 doesn't change in the future, so that we don't break things for
1054 doesn't change in the future, so that we don't break things for
1050 users' persisted data.
1055 users' persisted data.
1051
1056
1052 * IPython/iplib.py (autoindent_update): move indentation
1057 * IPython/iplib.py (autoindent_update): move indentation
1053 management into the _text_ processing loop, not the keyboard
1058 management into the _text_ processing loop, not the keyboard
1054 interactive one. This is necessary to correctly process non-typed
1059 interactive one. This is necessary to correctly process non-typed
1055 multiline input (such as macros).
1060 multiline input (such as macros).
1056
1061
1057 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
1062 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
1058 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
1063 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
1059 which was producing problems in the resulting manual.
1064 which was producing problems in the resulting manual.
1060 (magic_whos): improve reporting of instances (show their class,
1065 (magic_whos): improve reporting of instances (show their class,
1061 instead of simply printing 'instance' which isn't terribly
1066 instead of simply printing 'instance' which isn't terribly
1062 informative).
1067 informative).
1063
1068
1064 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
1069 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
1065 (minor mods) to support network shares under win32.
1070 (minor mods) to support network shares under win32.
1066
1071
1067 * IPython/winconsole.py (get_console_size): add new winconsole
1072 * IPython/winconsole.py (get_console_size): add new winconsole
1068 module and fixes to page_dumb() to improve its behavior under
1073 module and fixes to page_dumb() to improve its behavior under
1069 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
1074 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
1070
1075
1071 * IPython/Magic.py (Macro): simplified Macro class to just
1076 * IPython/Magic.py (Macro): simplified Macro class to just
1072 subclass list. We've had only 2.2 compatibility for a very long
1077 subclass list. We've had only 2.2 compatibility for a very long
1073 time, yet I was still avoiding subclassing the builtin types. No
1078 time, yet I was still avoiding subclassing the builtin types. No
1074 more (I'm also starting to use properties, though I won't shift to
1079 more (I'm also starting to use properties, though I won't shift to
1075 2.3-specific features quite yet).
1080 2.3-specific features quite yet).
1076 (magic_store): added Ville's patch for lightweight variable
1081 (magic_store): added Ville's patch for lightweight variable
1077 persistence, after a request on the user list by Matt Wilkie
1082 persistence, after a request on the user list by Matt Wilkie
1078 <maphew-AT-gmail.com>. The new %store magic's docstring has full
1083 <maphew-AT-gmail.com>. The new %store magic's docstring has full
1079 details.
1084 details.
1080
1085
1081 * IPython/iplib.py (InteractiveShell.post_config_initialization):
1086 * IPython/iplib.py (InteractiveShell.post_config_initialization):
1082 changed the default logfile name from 'ipython.log' to
1087 changed the default logfile name from 'ipython.log' to
1083 'ipython_log.py'. These logs are real python files, and now that
1088 'ipython_log.py'. These logs are real python files, and now that
1084 we have much better multiline support, people are more likely to
1089 we have much better multiline support, people are more likely to
1085 want to use them as such. Might as well name them correctly.
1090 want to use them as such. Might as well name them correctly.
1086
1091
1087 * IPython/Magic.py: substantial cleanup. While we can't stop
1092 * IPython/Magic.py: substantial cleanup. While we can't stop
1088 using magics as mixins, due to the existing customizations 'out
1093 using magics as mixins, due to the existing customizations 'out
1089 there' which rely on the mixin naming conventions, at least I
1094 there' which rely on the mixin naming conventions, at least I
1090 cleaned out all cross-class name usage. So once we are OK with
1095 cleaned out all cross-class name usage. So once we are OK with
1091 breaking compatibility, the two systems can be separated.
1096 breaking compatibility, the two systems can be separated.
1092
1097
1093 * IPython/Logger.py: major cleanup. This one is NOT a mixin
1098 * IPython/Logger.py: major cleanup. This one is NOT a mixin
1094 anymore, and the class is a fair bit less hideous as well. New
1099 anymore, and the class is a fair bit less hideous as well. New
1095 features were also introduced: timestamping of input, and logging
1100 features were also introduced: timestamping of input, and logging
1096 of output results. These are user-visible with the -t and -o
1101 of output results. These are user-visible with the -t and -o
1097 options to %logstart. Closes
1102 options to %logstart. Closes
1098 http://www.scipy.net/roundup/ipython/issue11 and a request by
1103 http://www.scipy.net/roundup/ipython/issue11 and a request by
1099 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
1104 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
1100
1105
1101 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
1106 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
1102
1107
1103 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
1108 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
1104 better handle backslashes in paths. See the thread 'More Windows
1109 better handle backslashes in paths. See the thread 'More Windows
1105 questions part 2 - \/ characters revisited' on the iypthon user
1110 questions part 2 - \/ characters revisited' on the iypthon user
1106 list:
1111 list:
1107 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
1112 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
1108
1113
1109 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
1114 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
1110
1115
1111 (InteractiveShell.__init__): change threaded shells to not use the
1116 (InteractiveShell.__init__): change threaded shells to not use the
1112 ipython crash handler. This was causing more problems than not,
1117 ipython crash handler. This was causing more problems than not,
1113 as exceptions in the main thread (GUI code, typically) would
1118 as exceptions in the main thread (GUI code, typically) would
1114 always show up as a 'crash', when they really weren't.
1119 always show up as a 'crash', when they really weren't.
1115
1120
1116 The colors and exception mode commands (%colors/%xmode) have been
1121 The colors and exception mode commands (%colors/%xmode) have been
1117 synchronized to also take this into account, so users can get
1122 synchronized to also take this into account, so users can get
1118 verbose exceptions for their threaded code as well. I also added
1123 verbose exceptions for their threaded code as well. I also added
1119 support for activating pdb inside this exception handler as well,
1124 support for activating pdb inside this exception handler as well,
1120 so now GUI authors can use IPython's enhanced pdb at runtime.
1125 so now GUI authors can use IPython's enhanced pdb at runtime.
1121
1126
1122 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
1127 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
1123 true by default, and add it to the shipped ipythonrc file. Since
1128 true by default, and add it to the shipped ipythonrc file. Since
1124 this asks the user before proceeding, I think it's OK to make it
1129 this asks the user before proceeding, I think it's OK to make it
1125 true by default.
1130 true by default.
1126
1131
1127 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
1132 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
1128 of the previous special-casing of input in the eval loop. I think
1133 of the previous special-casing of input in the eval loop. I think
1129 this is cleaner, as they really are commands and shouldn't have
1134 this is cleaner, as they really are commands and shouldn't have
1130 a special role in the middle of the core code.
1135 a special role in the middle of the core code.
1131
1136
1132 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
1137 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
1133
1138
1134 * IPython/iplib.py (edit_syntax_error): added support for
1139 * IPython/iplib.py (edit_syntax_error): added support for
1135 automatically reopening the editor if the file had a syntax error
1140 automatically reopening the editor if the file had a syntax error
1136 in it. Thanks to scottt who provided the patch at:
1141 in it. Thanks to scottt who provided the patch at:
1137 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
1142 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
1138 version committed).
1143 version committed).
1139
1144
1140 * IPython/iplib.py (handle_normal): add suport for multi-line
1145 * IPython/iplib.py (handle_normal): add suport for multi-line
1141 input with emtpy lines. This fixes
1146 input with emtpy lines. This fixes
1142 http://www.scipy.net/roundup/ipython/issue43 and a similar
1147 http://www.scipy.net/roundup/ipython/issue43 and a similar
1143 discussion on the user list.
1148 discussion on the user list.
1144
1149
1145 WARNING: a behavior change is necessarily introduced to support
1150 WARNING: a behavior change is necessarily introduced to support
1146 blank lines: now a single blank line with whitespace does NOT
1151 blank lines: now a single blank line with whitespace does NOT
1147 break the input loop, which means that when autoindent is on, by
1152 break the input loop, which means that when autoindent is on, by
1148 default hitting return on the next (indented) line does NOT exit.
1153 default hitting return on the next (indented) line does NOT exit.
1149
1154
1150 Instead, to exit a multiline input you can either have:
1155 Instead, to exit a multiline input you can either have:
1151
1156
1152 - TWO whitespace lines (just hit return again), or
1157 - TWO whitespace lines (just hit return again), or
1153 - a single whitespace line of a different length than provided
1158 - a single whitespace line of a different length than provided
1154 by the autoindent (add or remove a space).
1159 by the autoindent (add or remove a space).
1155
1160
1156 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
1161 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
1157 module to better organize all readline-related functionality.
1162 module to better organize all readline-related functionality.
1158 I've deleted FlexCompleter and put all completion clases here.
1163 I've deleted FlexCompleter and put all completion clases here.
1159
1164
1160 * IPython/iplib.py (raw_input): improve indentation management.
1165 * IPython/iplib.py (raw_input): improve indentation management.
1161 It is now possible to paste indented code with autoindent on, and
1166 It is now possible to paste indented code with autoindent on, and
1162 the code is interpreted correctly (though it still looks bad on
1167 the code is interpreted correctly (though it still looks bad on
1163 screen, due to the line-oriented nature of ipython).
1168 screen, due to the line-oriented nature of ipython).
1164 (MagicCompleter.complete): change behavior so that a TAB key on an
1169 (MagicCompleter.complete): change behavior so that a TAB key on an
1165 otherwise empty line actually inserts a tab, instead of completing
1170 otherwise empty line actually inserts a tab, instead of completing
1166 on the entire global namespace. This makes it easier to use the
1171 on the entire global namespace. This makes it easier to use the
1167 TAB key for indentation. After a request by Hans Meine
1172 TAB key for indentation. After a request by Hans Meine
1168 <hans_meine-AT-gmx.net>
1173 <hans_meine-AT-gmx.net>
1169 (_prefilter): add support so that typing plain 'exit' or 'quit'
1174 (_prefilter): add support so that typing plain 'exit' or 'quit'
1170 does a sensible thing. Originally I tried to deviate as little as
1175 does a sensible thing. Originally I tried to deviate as little as
1171 possible from the default python behavior, but even that one may
1176 possible from the default python behavior, but even that one may
1172 change in this direction (thread on python-dev to that effect).
1177 change in this direction (thread on python-dev to that effect).
1173 Regardless, ipython should do the right thing even if CPython's
1178 Regardless, ipython should do the right thing even if CPython's
1174 '>>>' prompt doesn't.
1179 '>>>' prompt doesn't.
1175 (InteractiveShell): removed subclassing code.InteractiveConsole
1180 (InteractiveShell): removed subclassing code.InteractiveConsole
1176 class. By now we'd overridden just about all of its methods: I've
1181 class. By now we'd overridden just about all of its methods: I've
1177 copied the remaining two over, and now ipython is a standalone
1182 copied the remaining two over, and now ipython is a standalone
1178 class. This will provide a clearer picture for the chainsaw
1183 class. This will provide a clearer picture for the chainsaw
1179 branch refactoring.
1184 branch refactoring.
1180
1185
1181 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
1186 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
1182
1187
1183 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
1188 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
1184 failures for objects which break when dir() is called on them.
1189 failures for objects which break when dir() is called on them.
1185
1190
1186 * IPython/FlexCompleter.py (Completer.__init__): Added support for
1191 * IPython/FlexCompleter.py (Completer.__init__): Added support for
1187 distinct local and global namespaces in the completer API. This
1192 distinct local and global namespaces in the completer API. This
1188 change allows us to properly handle completion with distinct
1193 change allows us to properly handle completion with distinct
1189 scopes, including in embedded instances (this had never really
1194 scopes, including in embedded instances (this had never really
1190 worked correctly).
1195 worked correctly).
1191
1196
1192 Note: this introduces a change in the constructor for
1197 Note: this introduces a change in the constructor for
1193 MagicCompleter, as a new global_namespace parameter is now the
1198 MagicCompleter, as a new global_namespace parameter is now the
1194 second argument (the others were bumped one position).
1199 second argument (the others were bumped one position).
1195
1200
1196 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
1201 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
1197
1202
1198 * IPython/iplib.py (embed_mainloop): fix tab-completion in
1203 * IPython/iplib.py (embed_mainloop): fix tab-completion in
1199 embedded instances (which can be done now thanks to Vivian's
1204 embedded instances (which can be done now thanks to Vivian's
1200 frame-handling fixes for pdb).
1205 frame-handling fixes for pdb).
1201 (InteractiveShell.__init__): Fix namespace handling problem in
1206 (InteractiveShell.__init__): Fix namespace handling problem in
1202 embedded instances. We were overwriting __main__ unconditionally,
1207 embedded instances. We were overwriting __main__ unconditionally,
1203 and this should only be done for 'full' (non-embedded) IPython;
1208 and this should only be done for 'full' (non-embedded) IPython;
1204 embedded instances must respect the caller's __main__. Thanks to
1209 embedded instances must respect the caller's __main__. Thanks to
1205 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
1210 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
1206
1211
1207 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
1212 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
1208
1213
1209 * setup.py: added download_url to setup(). This registers the
1214 * setup.py: added download_url to setup(). This registers the
1210 download address at PyPI, which is not only useful to humans
1215 download address at PyPI, which is not only useful to humans
1211 browsing the site, but is also picked up by setuptools (the Eggs
1216 browsing the site, but is also picked up by setuptools (the Eggs
1212 machinery). Thanks to Ville and R. Kern for the info/discussion
1217 machinery). Thanks to Ville and R. Kern for the info/discussion
1213 on this.
1218 on this.
1214
1219
1215 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
1220 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
1216
1221
1217 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
1222 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
1218 This brings a lot of nice functionality to the pdb mode, which now
1223 This brings a lot of nice functionality to the pdb mode, which now
1219 has tab-completion, syntax highlighting, and better stack handling
1224 has tab-completion, syntax highlighting, and better stack handling
1220 than before. Many thanks to Vivian De Smedt
1225 than before. Many thanks to Vivian De Smedt
1221 <vivian-AT-vdesmedt.com> for the original patches.
1226 <vivian-AT-vdesmedt.com> for the original patches.
1222
1227
1223 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
1228 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
1224
1229
1225 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
1230 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
1226 sequence to consistently accept the banner argument. The
1231 sequence to consistently accept the banner argument. The
1227 inconsistency was tripping SAGE, thanks to Gary Zablackis
1232 inconsistency was tripping SAGE, thanks to Gary Zablackis
1228 <gzabl-AT-yahoo.com> for the report.
1233 <gzabl-AT-yahoo.com> for the report.
1229
1234
1230 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
1235 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
1231
1236
1232 * IPython/iplib.py (InteractiveShell.post_config_initialization):
1237 * IPython/iplib.py (InteractiveShell.post_config_initialization):
1233 Fix bug where a naked 'alias' call in the ipythonrc file would
1238 Fix bug where a naked 'alias' call in the ipythonrc file would
1234 cause a crash. Bug reported by Jorgen Stenarson.
1239 cause a crash. Bug reported by Jorgen Stenarson.
1235
1240
1236 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
1241 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
1237
1242
1238 * IPython/ipmaker.py (make_IPython): cleanups which should improve
1243 * IPython/ipmaker.py (make_IPython): cleanups which should improve
1239 startup time.
1244 startup time.
1240
1245
1241 * IPython/iplib.py (runcode): my globals 'fix' for embedded
1246 * IPython/iplib.py (runcode): my globals 'fix' for embedded
1242 instances had introduced a bug with globals in normal code. Now
1247 instances had introduced a bug with globals in normal code. Now
1243 it's working in all cases.
1248 it's working in all cases.
1244
1249
1245 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
1250 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
1246 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
1251 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
1247 has been introduced to set the default case sensitivity of the
1252 has been introduced to set the default case sensitivity of the
1248 searches. Users can still select either mode at runtime on a
1253 searches. Users can still select either mode at runtime on a
1249 per-search basis.
1254 per-search basis.
1250
1255
1251 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
1256 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
1252
1257
1253 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
1258 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
1254 attributes in wildcard searches for subclasses. Modified version
1259 attributes in wildcard searches for subclasses. Modified version
1255 of a patch by Jorgen.
1260 of a patch by Jorgen.
1256
1261
1257 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
1262 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
1258
1263
1259 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
1264 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
1260 embedded instances. I added a user_global_ns attribute to the
1265 embedded instances. I added a user_global_ns attribute to the
1261 InteractiveShell class to handle this.
1266 InteractiveShell class to handle this.
1262
1267
1263 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
1268 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
1264
1269
1265 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
1270 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
1266 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
1271 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
1267 (reported under win32, but may happen also in other platforms).
1272 (reported under win32, but may happen also in other platforms).
1268 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
1273 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
1269
1274
1270 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
1275 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
1271
1276
1272 * IPython/Magic.py (magic_psearch): new support for wildcard
1277 * IPython/Magic.py (magic_psearch): new support for wildcard
1273 patterns. Now, typing ?a*b will list all names which begin with a
1278 patterns. Now, typing ?a*b will list all names which begin with a
1274 and end in b, for example. The %psearch magic has full
1279 and end in b, for example. The %psearch magic has full
1275 docstrings. Many thanks to JΓΆrgen Stenarson
1280 docstrings. Many thanks to JΓΆrgen Stenarson
1276 <jorgen.stenarson-AT-bostream.nu>, author of the patches
1281 <jorgen.stenarson-AT-bostream.nu>, author of the patches
1277 implementing this functionality.
1282 implementing this functionality.
1278
1283
1279 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1284 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1280
1285
1281 * Manual: fixed long-standing annoyance of double-dashes (as in
1286 * Manual: fixed long-standing annoyance of double-dashes (as in
1282 --prefix=~, for example) being stripped in the HTML version. This
1287 --prefix=~, for example) being stripped in the HTML version. This
1283 is a latex2html bug, but a workaround was provided. Many thanks
1288 is a latex2html bug, but a workaround was provided. Many thanks
1284 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
1289 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
1285 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
1290 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
1286 rolling. This seemingly small issue had tripped a number of users
1291 rolling. This seemingly small issue had tripped a number of users
1287 when first installing, so I'm glad to see it gone.
1292 when first installing, so I'm glad to see it gone.
1288
1293
1289 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1294 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1290
1295
1291 * IPython/Extensions/numeric_formats.py: fix missing import,
1296 * IPython/Extensions/numeric_formats.py: fix missing import,
1292 reported by Stephen Walton.
1297 reported by Stephen Walton.
1293
1298
1294 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
1299 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
1295
1300
1296 * IPython/demo.py: finish demo module, fully documented now.
1301 * IPython/demo.py: finish demo module, fully documented now.
1297
1302
1298 * IPython/genutils.py (file_read): simple little utility to read a
1303 * IPython/genutils.py (file_read): simple little utility to read a
1299 file and ensure it's closed afterwards.
1304 file and ensure it's closed afterwards.
1300
1305
1301 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
1306 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
1302
1307
1303 * IPython/demo.py (Demo.__init__): added support for individually
1308 * IPython/demo.py (Demo.__init__): added support for individually
1304 tagging blocks for automatic execution.
1309 tagging blocks for automatic execution.
1305
1310
1306 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
1311 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
1307 syntax-highlighted python sources, requested by John.
1312 syntax-highlighted python sources, requested by John.
1308
1313
1309 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
1314 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
1310
1315
1311 * IPython/demo.py (Demo.again): fix bug where again() blocks after
1316 * IPython/demo.py (Demo.again): fix bug where again() blocks after
1312 finishing.
1317 finishing.
1313
1318
1314 * IPython/genutils.py (shlex_split): moved from Magic to here,
1319 * IPython/genutils.py (shlex_split): moved from Magic to here,
1315 where all 2.2 compatibility stuff lives. I needed it for demo.py.
1320 where all 2.2 compatibility stuff lives. I needed it for demo.py.
1316
1321
1317 * IPython/demo.py (Demo.__init__): added support for silent
1322 * IPython/demo.py (Demo.__init__): added support for silent
1318 blocks, improved marks as regexps, docstrings written.
1323 blocks, improved marks as regexps, docstrings written.
1319 (Demo.__init__): better docstring, added support for sys.argv.
1324 (Demo.__init__): better docstring, added support for sys.argv.
1320
1325
1321 * IPython/genutils.py (marquee): little utility used by the demo
1326 * IPython/genutils.py (marquee): little utility used by the demo
1322 code, handy in general.
1327 code, handy in general.
1323
1328
1324 * IPython/demo.py (Demo.__init__): new class for interactive
1329 * IPython/demo.py (Demo.__init__): new class for interactive
1325 demos. Not documented yet, I just wrote it in a hurry for
1330 demos. Not documented yet, I just wrote it in a hurry for
1326 scipy'05. Will docstring later.
1331 scipy'05. Will docstring later.
1327
1332
1328 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
1333 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
1329
1334
1330 * IPython/Shell.py (sigint_handler): Drastic simplification which
1335 * IPython/Shell.py (sigint_handler): Drastic simplification which
1331 also seems to make Ctrl-C work correctly across threads! This is
1336 also seems to make Ctrl-C work correctly across threads! This is
1332 so simple, that I can't beleive I'd missed it before. Needs more
1337 so simple, that I can't beleive I'd missed it before. Needs more
1333 testing, though.
1338 testing, though.
1334 (KBINT): Never mind, revert changes. I'm sure I'd tried something
1339 (KBINT): Never mind, revert changes. I'm sure I'd tried something
1335 like this before...
1340 like this before...
1336
1341
1337 * IPython/genutils.py (get_home_dir): add protection against
1342 * IPython/genutils.py (get_home_dir): add protection against
1338 non-dirs in win32 registry.
1343 non-dirs in win32 registry.
1339
1344
1340 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
1345 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
1341 bug where dict was mutated while iterating (pysh crash).
1346 bug where dict was mutated while iterating (pysh crash).
1342
1347
1343 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
1348 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
1344
1349
1345 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
1350 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
1346 spurious newlines added by this routine. After a report by
1351 spurious newlines added by this routine. After a report by
1347 F. Mantegazza.
1352 F. Mantegazza.
1348
1353
1349 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
1354 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
1350
1355
1351 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
1356 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
1352 calls. These were a leftover from the GTK 1.x days, and can cause
1357 calls. These were a leftover from the GTK 1.x days, and can cause
1353 problems in certain cases (after a report by John Hunter).
1358 problems in certain cases (after a report by John Hunter).
1354
1359
1355 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
1360 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
1356 os.getcwd() fails at init time. Thanks to patch from David Remahl
1361 os.getcwd() fails at init time. Thanks to patch from David Remahl
1357 <chmod007-AT-mac.com>.
1362 <chmod007-AT-mac.com>.
1358 (InteractiveShell.__init__): prevent certain special magics from
1363 (InteractiveShell.__init__): prevent certain special magics from
1359 being shadowed by aliases. Closes
1364 being shadowed by aliases. Closes
1360 http://www.scipy.net/roundup/ipython/issue41.
1365 http://www.scipy.net/roundup/ipython/issue41.
1361
1366
1362 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
1367 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
1363
1368
1364 * IPython/iplib.py (InteractiveShell.complete): Added new
1369 * IPython/iplib.py (InteractiveShell.complete): Added new
1365 top-level completion method to expose the completion mechanism
1370 top-level completion method to expose the completion mechanism
1366 beyond readline-based environments.
1371 beyond readline-based environments.
1367
1372
1368 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
1373 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
1369
1374
1370 * tools/ipsvnc (svnversion): fix svnversion capture.
1375 * tools/ipsvnc (svnversion): fix svnversion capture.
1371
1376
1372 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
1377 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
1373 attribute to self, which was missing. Before, it was set by a
1378 attribute to self, which was missing. Before, it was set by a
1374 routine which in certain cases wasn't being called, so the
1379 routine which in certain cases wasn't being called, so the
1375 instance could end up missing the attribute. This caused a crash.
1380 instance could end up missing the attribute. This caused a crash.
1376 Closes http://www.scipy.net/roundup/ipython/issue40.
1381 Closes http://www.scipy.net/roundup/ipython/issue40.
1377
1382
1378 2005-08-16 Fernando Perez <fperez@colorado.edu>
1383 2005-08-16 Fernando Perez <fperez@colorado.edu>
1379
1384
1380 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
1385 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
1381 contains non-string attribute. Closes
1386 contains non-string attribute. Closes
1382 http://www.scipy.net/roundup/ipython/issue38.
1387 http://www.scipy.net/roundup/ipython/issue38.
1383
1388
1384 2005-08-14 Fernando Perez <fperez@colorado.edu>
1389 2005-08-14 Fernando Perez <fperez@colorado.edu>
1385
1390
1386 * tools/ipsvnc: Minor improvements, to add changeset info.
1391 * tools/ipsvnc: Minor improvements, to add changeset info.
1387
1392
1388 2005-08-12 Fernando Perez <fperez@colorado.edu>
1393 2005-08-12 Fernando Perez <fperez@colorado.edu>
1389
1394
1390 * IPython/iplib.py (runsource): remove self.code_to_run_src
1395 * IPython/iplib.py (runsource): remove self.code_to_run_src
1391 attribute. I realized this is nothing more than
1396 attribute. I realized this is nothing more than
1392 '\n'.join(self.buffer), and having the same data in two different
1397 '\n'.join(self.buffer), and having the same data in two different
1393 places is just asking for synchronization bugs. This may impact
1398 places is just asking for synchronization bugs. This may impact
1394 people who have custom exception handlers, so I need to warn
1399 people who have custom exception handlers, so I need to warn
1395 ipython-dev about it (F. Mantegazza may use them).
1400 ipython-dev about it (F. Mantegazza may use them).
1396
1401
1397 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
1402 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
1398
1403
1399 * IPython/genutils.py: fix 2.2 compatibility (generators)
1404 * IPython/genutils.py: fix 2.2 compatibility (generators)
1400
1405
1401 2005-07-18 Fernando Perez <fperez@colorado.edu>
1406 2005-07-18 Fernando Perez <fperez@colorado.edu>
1402
1407
1403 * IPython/genutils.py (get_home_dir): fix to help users with
1408 * IPython/genutils.py (get_home_dir): fix to help users with
1404 invalid $HOME under win32.
1409 invalid $HOME under win32.
1405
1410
1406 2005-07-17 Fernando Perez <fperez@colorado.edu>
1411 2005-07-17 Fernando Perez <fperez@colorado.edu>
1407
1412
1408 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
1413 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
1409 some old hacks and clean up a bit other routines; code should be
1414 some old hacks and clean up a bit other routines; code should be
1410 simpler and a bit faster.
1415 simpler and a bit faster.
1411
1416
1412 * IPython/iplib.py (interact): removed some last-resort attempts
1417 * IPython/iplib.py (interact): removed some last-resort attempts
1413 to survive broken stdout/stderr. That code was only making it
1418 to survive broken stdout/stderr. That code was only making it
1414 harder to abstract out the i/o (necessary for gui integration),
1419 harder to abstract out the i/o (necessary for gui integration),
1415 and the crashes it could prevent were extremely rare in practice
1420 and the crashes it could prevent were extremely rare in practice
1416 (besides being fully user-induced in a pretty violent manner).
1421 (besides being fully user-induced in a pretty violent manner).
1417
1422
1418 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
1423 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
1419 Nothing major yet, but the code is simpler to read; this should
1424 Nothing major yet, but the code is simpler to read; this should
1420 make it easier to do more serious modifications in the future.
1425 make it easier to do more serious modifications in the future.
1421
1426
1422 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
1427 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
1423 which broke in .15 (thanks to a report by Ville).
1428 which broke in .15 (thanks to a report by Ville).
1424
1429
1425 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
1430 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
1426 be quite correct, I know next to nothing about unicode). This
1431 be quite correct, I know next to nothing about unicode). This
1427 will allow unicode strings to be used in prompts, amongst other
1432 will allow unicode strings to be used in prompts, amongst other
1428 cases. It also will prevent ipython from crashing when unicode
1433 cases. It also will prevent ipython from crashing when unicode
1429 shows up unexpectedly in many places. If ascii encoding fails, we
1434 shows up unexpectedly in many places. If ascii encoding fails, we
1430 assume utf_8. Currently the encoding is not a user-visible
1435 assume utf_8. Currently the encoding is not a user-visible
1431 setting, though it could be made so if there is demand for it.
1436 setting, though it could be made so if there is demand for it.
1432
1437
1433 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
1438 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
1434
1439
1435 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
1440 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
1436
1441
1437 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
1442 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
1438
1443
1439 * IPython/genutils.py: Add 2.2 compatibility here, so all other
1444 * IPython/genutils.py: Add 2.2 compatibility here, so all other
1440 code can work transparently for 2.2/2.3.
1445 code can work transparently for 2.2/2.3.
1441
1446
1442 2005-07-16 Fernando Perez <fperez@colorado.edu>
1447 2005-07-16 Fernando Perez <fperez@colorado.edu>
1443
1448
1444 * IPython/ultraTB.py (ExceptionColors): Make a global variable
1449 * IPython/ultraTB.py (ExceptionColors): Make a global variable
1445 out of the color scheme table used for coloring exception
1450 out of the color scheme table used for coloring exception
1446 tracebacks. This allows user code to add new schemes at runtime.
1451 tracebacks. This allows user code to add new schemes at runtime.
1447 This is a minimally modified version of the patch at
1452 This is a minimally modified version of the patch at
1448 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
1453 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
1449 for the contribution.
1454 for the contribution.
1450
1455
1451 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
1456 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
1452 slightly modified version of the patch in
1457 slightly modified version of the patch in
1453 http://www.scipy.net/roundup/ipython/issue34, which also allows me
1458 http://www.scipy.net/roundup/ipython/issue34, which also allows me
1454 to remove the previous try/except solution (which was costlier).
1459 to remove the previous try/except solution (which was costlier).
1455 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
1460 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
1456
1461
1457 2005-06-08 Fernando Perez <fperez@colorado.edu>
1462 2005-06-08 Fernando Perez <fperez@colorado.edu>
1458
1463
1459 * IPython/iplib.py (write/write_err): Add methods to abstract all
1464 * IPython/iplib.py (write/write_err): Add methods to abstract all
1460 I/O a bit more.
1465 I/O a bit more.
1461
1466
1462 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
1467 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
1463 warning, reported by Aric Hagberg, fix by JD Hunter.
1468 warning, reported by Aric Hagberg, fix by JD Hunter.
1464
1469
1465 2005-06-02 *** Released version 0.6.15
1470 2005-06-02 *** Released version 0.6.15
1466
1471
1467 2005-06-01 Fernando Perez <fperez@colorado.edu>
1472 2005-06-01 Fernando Perez <fperez@colorado.edu>
1468
1473
1469 * IPython/iplib.py (MagicCompleter.file_matches): Fix
1474 * IPython/iplib.py (MagicCompleter.file_matches): Fix
1470 tab-completion of filenames within open-quoted strings. Note that
1475 tab-completion of filenames within open-quoted strings. Note that
1471 this requires that in ~/.ipython/ipythonrc, users change the
1476 this requires that in ~/.ipython/ipythonrc, users change the
1472 readline delimiters configuration to read:
1477 readline delimiters configuration to read:
1473
1478
1474 readline_remove_delims -/~
1479 readline_remove_delims -/~
1475
1480
1476
1481
1477 2005-05-31 *** Released version 0.6.14
1482 2005-05-31 *** Released version 0.6.14
1478
1483
1479 2005-05-29 Fernando Perez <fperez@colorado.edu>
1484 2005-05-29 Fernando Perez <fperez@colorado.edu>
1480
1485
1481 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
1486 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
1482 with files not on the filesystem. Reported by Eliyahu Sandler
1487 with files not on the filesystem. Reported by Eliyahu Sandler
1483 <eli@gondolin.net>
1488 <eli@gondolin.net>
1484
1489
1485 2005-05-22 Fernando Perez <fperez@colorado.edu>
1490 2005-05-22 Fernando Perez <fperez@colorado.edu>
1486
1491
1487 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
1492 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
1488 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
1493 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
1489
1494
1490 2005-05-19 Fernando Perez <fperez@colorado.edu>
1495 2005-05-19 Fernando Perez <fperez@colorado.edu>
1491
1496
1492 * IPython/iplib.py (safe_execfile): close a file which could be
1497 * IPython/iplib.py (safe_execfile): close a file which could be
1493 left open (causing problems in win32, which locks open files).
1498 left open (causing problems in win32, which locks open files).
1494 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
1499 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
1495
1500
1496 2005-05-18 Fernando Perez <fperez@colorado.edu>
1501 2005-05-18 Fernando Perez <fperez@colorado.edu>
1497
1502
1498 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
1503 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
1499 keyword arguments correctly to safe_execfile().
1504 keyword arguments correctly to safe_execfile().
1500
1505
1501 2005-05-13 Fernando Perez <fperez@colorado.edu>
1506 2005-05-13 Fernando Perez <fperez@colorado.edu>
1502
1507
1503 * ipython.1: Added info about Qt to manpage, and threads warning
1508 * ipython.1: Added info about Qt to manpage, and threads warning
1504 to usage page (invoked with --help).
1509 to usage page (invoked with --help).
1505
1510
1506 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
1511 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
1507 new matcher (it goes at the end of the priority list) to do
1512 new matcher (it goes at the end of the priority list) to do
1508 tab-completion on named function arguments. Submitted by George
1513 tab-completion on named function arguments. Submitted by George
1509 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
1514 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
1510 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
1515 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
1511 for more details.
1516 for more details.
1512
1517
1513 * IPython/Magic.py (magic_run): Added new -e flag to ignore
1518 * IPython/Magic.py (magic_run): Added new -e flag to ignore
1514 SystemExit exceptions in the script being run. Thanks to a report
1519 SystemExit exceptions in the script being run. Thanks to a report
1515 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
1520 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
1516 producing very annoying behavior when running unit tests.
1521 producing very annoying behavior when running unit tests.
1517
1522
1518 2005-05-12 Fernando Perez <fperez@colorado.edu>
1523 2005-05-12 Fernando Perez <fperez@colorado.edu>
1519
1524
1520 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
1525 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
1521 which I'd broken (again) due to a changed regexp. In the process,
1526 which I'd broken (again) due to a changed regexp. In the process,
1522 added ';' as an escape to auto-quote the whole line without
1527 added ';' as an escape to auto-quote the whole line without
1523 splitting its arguments. Thanks to a report by Jerry McRae
1528 splitting its arguments. Thanks to a report by Jerry McRae
1524 <qrs0xyc02-AT-sneakemail.com>.
1529 <qrs0xyc02-AT-sneakemail.com>.
1525
1530
1526 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
1531 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
1527 possible crashes caused by a TokenError. Reported by Ed Schofield
1532 possible crashes caused by a TokenError. Reported by Ed Schofield
1528 <schofield-AT-ftw.at>.
1533 <schofield-AT-ftw.at>.
1529
1534
1530 2005-05-06 Fernando Perez <fperez@colorado.edu>
1535 2005-05-06 Fernando Perez <fperez@colorado.edu>
1531
1536
1532 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
1537 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
1533
1538
1534 2005-04-29 Fernando Perez <fperez@colorado.edu>
1539 2005-04-29 Fernando Perez <fperez@colorado.edu>
1535
1540
1536 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
1541 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
1537 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
1542 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
1538 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
1543 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
1539 which provides support for Qt interactive usage (similar to the
1544 which provides support for Qt interactive usage (similar to the
1540 existing one for WX and GTK). This had been often requested.
1545 existing one for WX and GTK). This had been often requested.
1541
1546
1542 2005-04-14 *** Released version 0.6.13
1547 2005-04-14 *** Released version 0.6.13
1543
1548
1544 2005-04-08 Fernando Perez <fperez@colorado.edu>
1549 2005-04-08 Fernando Perez <fperez@colorado.edu>
1545
1550
1546 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
1551 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
1547 from _ofind, which gets called on almost every input line. Now,
1552 from _ofind, which gets called on almost every input line. Now,
1548 we only try to get docstrings if they are actually going to be
1553 we only try to get docstrings if they are actually going to be
1549 used (the overhead of fetching unnecessary docstrings can be
1554 used (the overhead of fetching unnecessary docstrings can be
1550 noticeable for certain objects, such as Pyro proxies).
1555 noticeable for certain objects, such as Pyro proxies).
1551
1556
1552 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
1557 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
1553 for completers. For some reason I had been passing them the state
1558 for completers. For some reason I had been passing them the state
1554 variable, which completers never actually need, and was in
1559 variable, which completers never actually need, and was in
1555 conflict with the rlcompleter API. Custom completers ONLY need to
1560 conflict with the rlcompleter API. Custom completers ONLY need to
1556 take the text parameter.
1561 take the text parameter.
1557
1562
1558 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
1563 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
1559 work correctly in pysh. I've also moved all the logic which used
1564 work correctly in pysh. I've also moved all the logic which used
1560 to be in pysh.py here, which will prevent problems with future
1565 to be in pysh.py here, which will prevent problems with future
1561 upgrades. However, this time I must warn users to update their
1566 upgrades. However, this time I must warn users to update their
1562 pysh profile to include the line
1567 pysh profile to include the line
1563
1568
1564 import_all IPython.Extensions.InterpreterExec
1569 import_all IPython.Extensions.InterpreterExec
1565
1570
1566 because otherwise things won't work for them. They MUST also
1571 because otherwise things won't work for them. They MUST also
1567 delete pysh.py and the line
1572 delete pysh.py and the line
1568
1573
1569 execfile pysh.py
1574 execfile pysh.py
1570
1575
1571 from their ipythonrc-pysh.
1576 from their ipythonrc-pysh.
1572
1577
1573 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
1578 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
1574 robust in the face of objects whose dir() returns non-strings
1579 robust in the face of objects whose dir() returns non-strings
1575 (which it shouldn't, but some broken libs like ITK do). Thanks to
1580 (which it shouldn't, but some broken libs like ITK do). Thanks to
1576 a patch by John Hunter (implemented differently, though). Also
1581 a patch by John Hunter (implemented differently, though). Also
1577 minor improvements by using .extend instead of + on lists.
1582 minor improvements by using .extend instead of + on lists.
1578
1583
1579 * pysh.py:
1584 * pysh.py:
1580
1585
1581 2005-04-06 Fernando Perez <fperez@colorado.edu>
1586 2005-04-06 Fernando Perez <fperez@colorado.edu>
1582
1587
1583 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
1588 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
1584 by default, so that all users benefit from it. Those who don't
1589 by default, so that all users benefit from it. Those who don't
1585 want it can still turn it off.
1590 want it can still turn it off.
1586
1591
1587 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
1592 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
1588 config file, I'd forgotten about this, so users were getting it
1593 config file, I'd forgotten about this, so users were getting it
1589 off by default.
1594 off by default.
1590
1595
1591 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
1596 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
1592 consistency. Now magics can be called in multiline statements,
1597 consistency. Now magics can be called in multiline statements,
1593 and python variables can be expanded in magic calls via $var.
1598 and python variables can be expanded in magic calls via $var.
1594 This makes the magic system behave just like aliases or !system
1599 This makes the magic system behave just like aliases or !system
1595 calls.
1600 calls.
1596
1601
1597 2005-03-28 Fernando Perez <fperez@colorado.edu>
1602 2005-03-28 Fernando Perez <fperez@colorado.edu>
1598
1603
1599 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
1604 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
1600 expensive string additions for building command. Add support for
1605 expensive string additions for building command. Add support for
1601 trailing ';' when autocall is used.
1606 trailing ';' when autocall is used.
1602
1607
1603 2005-03-26 Fernando Perez <fperez@colorado.edu>
1608 2005-03-26 Fernando Perez <fperez@colorado.edu>
1604
1609
1605 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
1610 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
1606 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
1611 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
1607 ipython.el robust against prompts with any number of spaces
1612 ipython.el robust against prompts with any number of spaces
1608 (including 0) after the ':' character.
1613 (including 0) after the ':' character.
1609
1614
1610 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
1615 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
1611 continuation prompt, which misled users to think the line was
1616 continuation prompt, which misled users to think the line was
1612 already indented. Closes debian Bug#300847, reported to me by
1617 already indented. Closes debian Bug#300847, reported to me by
1613 Norbert Tretkowski <tretkowski-AT-inittab.de>.
1618 Norbert Tretkowski <tretkowski-AT-inittab.de>.
1614
1619
1615 2005-03-23 Fernando Perez <fperez@colorado.edu>
1620 2005-03-23 Fernando Perez <fperez@colorado.edu>
1616
1621
1617 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
1622 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
1618 properly aligned if they have embedded newlines.
1623 properly aligned if they have embedded newlines.
1619
1624
1620 * IPython/iplib.py (runlines): Add a public method to expose
1625 * IPython/iplib.py (runlines): Add a public method to expose
1621 IPython's code execution machinery, so that users can run strings
1626 IPython's code execution machinery, so that users can run strings
1622 as if they had been typed at the prompt interactively.
1627 as if they had been typed at the prompt interactively.
1623 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
1628 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
1624 methods which can call the system shell, but with python variable
1629 methods which can call the system shell, but with python variable
1625 expansion. The three such methods are: __IPYTHON__.system,
1630 expansion. The three such methods are: __IPYTHON__.system,
1626 .getoutput and .getoutputerror. These need to be documented in a
1631 .getoutput and .getoutputerror. These need to be documented in a
1627 'public API' section (to be written) of the manual.
1632 'public API' section (to be written) of the manual.
1628
1633
1629 2005-03-20 Fernando Perez <fperez@colorado.edu>
1634 2005-03-20 Fernando Perez <fperez@colorado.edu>
1630
1635
1631 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
1636 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
1632 for custom exception handling. This is quite powerful, and it
1637 for custom exception handling. This is quite powerful, and it
1633 allows for user-installable exception handlers which can trap
1638 allows for user-installable exception handlers which can trap
1634 custom exceptions at runtime and treat them separately from
1639 custom exceptions at runtime and treat them separately from
1635 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
1640 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
1636 Mantegazza <mantegazza-AT-ill.fr>.
1641 Mantegazza <mantegazza-AT-ill.fr>.
1637 (InteractiveShell.set_custom_completer): public API function to
1642 (InteractiveShell.set_custom_completer): public API function to
1638 add new completers at runtime.
1643 add new completers at runtime.
1639
1644
1640 2005-03-19 Fernando Perez <fperez@colorado.edu>
1645 2005-03-19 Fernando Perez <fperez@colorado.edu>
1641
1646
1642 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
1647 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
1643 allow objects which provide their docstrings via non-standard
1648 allow objects which provide their docstrings via non-standard
1644 mechanisms (like Pyro proxies) to still be inspected by ipython's
1649 mechanisms (like Pyro proxies) to still be inspected by ipython's
1645 ? system.
1650 ? system.
1646
1651
1647 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
1652 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
1648 automatic capture system. I tried quite hard to make it work
1653 automatic capture system. I tried quite hard to make it work
1649 reliably, and simply failed. I tried many combinations with the
1654 reliably, and simply failed. I tried many combinations with the
1650 subprocess module, but eventually nothing worked in all needed
1655 subprocess module, but eventually nothing worked in all needed
1651 cases (not blocking stdin for the child, duplicating stdout
1656 cases (not blocking stdin for the child, duplicating stdout
1652 without blocking, etc). The new %sc/%sx still do capture to these
1657 without blocking, etc). The new %sc/%sx still do capture to these
1653 magical list/string objects which make shell use much more
1658 magical list/string objects which make shell use much more
1654 conveninent, so not all is lost.
1659 conveninent, so not all is lost.
1655
1660
1656 XXX - FIX MANUAL for the change above!
1661 XXX - FIX MANUAL for the change above!
1657
1662
1658 (runsource): I copied code.py's runsource() into ipython to modify
1663 (runsource): I copied code.py's runsource() into ipython to modify
1659 it a bit. Now the code object and source to be executed are
1664 it a bit. Now the code object and source to be executed are
1660 stored in ipython. This makes this info accessible to third-party
1665 stored in ipython. This makes this info accessible to third-party
1661 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
1666 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
1662 Mantegazza <mantegazza-AT-ill.fr>.
1667 Mantegazza <mantegazza-AT-ill.fr>.
1663
1668
1664 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
1669 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
1665 history-search via readline (like C-p/C-n). I'd wanted this for a
1670 history-search via readline (like C-p/C-n). I'd wanted this for a
1666 long time, but only recently found out how to do it. For users
1671 long time, but only recently found out how to do it. For users
1667 who already have their ipythonrc files made and want this, just
1672 who already have their ipythonrc files made and want this, just
1668 add:
1673 add:
1669
1674
1670 readline_parse_and_bind "\e[A": history-search-backward
1675 readline_parse_and_bind "\e[A": history-search-backward
1671 readline_parse_and_bind "\e[B": history-search-forward
1676 readline_parse_and_bind "\e[B": history-search-forward
1672
1677
1673 2005-03-18 Fernando Perez <fperez@colorado.edu>
1678 2005-03-18 Fernando Perez <fperez@colorado.edu>
1674
1679
1675 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
1680 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
1676 LSString and SList classes which allow transparent conversions
1681 LSString and SList classes which allow transparent conversions
1677 between list mode and whitespace-separated string.
1682 between list mode and whitespace-separated string.
1678 (magic_r): Fix recursion problem in %r.
1683 (magic_r): Fix recursion problem in %r.
1679
1684
1680 * IPython/genutils.py (LSString): New class to be used for
1685 * IPython/genutils.py (LSString): New class to be used for
1681 automatic storage of the results of all alias/system calls in _o
1686 automatic storage of the results of all alias/system calls in _o
1682 and _e (stdout/err). These provide a .l/.list attribute which
1687 and _e (stdout/err). These provide a .l/.list attribute which
1683 does automatic splitting on newlines. This means that for most
1688 does automatic splitting on newlines. This means that for most
1684 uses, you'll never need to do capturing of output with %sc/%sx
1689 uses, you'll never need to do capturing of output with %sc/%sx
1685 anymore, since ipython keeps this always done for you. Note that
1690 anymore, since ipython keeps this always done for you. Note that
1686 only the LAST results are stored, the _o/e variables are
1691 only the LAST results are stored, the _o/e variables are
1687 overwritten on each call. If you need to save their contents
1692 overwritten on each call. If you need to save their contents
1688 further, simply bind them to any other name.
1693 further, simply bind them to any other name.
1689
1694
1690 2005-03-17 Fernando Perez <fperez@colorado.edu>
1695 2005-03-17 Fernando Perez <fperez@colorado.edu>
1691
1696
1692 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
1697 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
1693 prompt namespace handling.
1698 prompt namespace handling.
1694
1699
1695 2005-03-16 Fernando Perez <fperez@colorado.edu>
1700 2005-03-16 Fernando Perez <fperez@colorado.edu>
1696
1701
1697 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
1702 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
1698 classic prompts to be '>>> ' (final space was missing, and it
1703 classic prompts to be '>>> ' (final space was missing, and it
1699 trips the emacs python mode).
1704 trips the emacs python mode).
1700 (BasePrompt.__str__): Added safe support for dynamic prompt
1705 (BasePrompt.__str__): Added safe support for dynamic prompt
1701 strings. Now you can set your prompt string to be '$x', and the
1706 strings. Now you can set your prompt string to be '$x', and the
1702 value of x will be printed from your interactive namespace. The
1707 value of x will be printed from your interactive namespace. The
1703 interpolation syntax includes the full Itpl support, so
1708 interpolation syntax includes the full Itpl support, so
1704 ${foo()+x+bar()} is a valid prompt string now, and the function
1709 ${foo()+x+bar()} is a valid prompt string now, and the function
1705 calls will be made at runtime.
1710 calls will be made at runtime.
1706
1711
1707 2005-03-15 Fernando Perez <fperez@colorado.edu>
1712 2005-03-15 Fernando Perez <fperez@colorado.edu>
1708
1713
1709 * IPython/Magic.py (magic_history): renamed %hist to %history, to
1714 * IPython/Magic.py (magic_history): renamed %hist to %history, to
1710 avoid name clashes in pylab. %hist still works, it just forwards
1715 avoid name clashes in pylab. %hist still works, it just forwards
1711 the call to %history.
1716 the call to %history.
1712
1717
1713 2005-03-02 *** Released version 0.6.12
1718 2005-03-02 *** Released version 0.6.12
1714
1719
1715 2005-03-02 Fernando Perez <fperez@colorado.edu>
1720 2005-03-02 Fernando Perez <fperez@colorado.edu>
1716
1721
1717 * IPython/iplib.py (handle_magic): log magic calls properly as
1722 * IPython/iplib.py (handle_magic): log magic calls properly as
1718 ipmagic() function calls.
1723 ipmagic() function calls.
1719
1724
1720 * IPython/Magic.py (magic_time): Improved %time to support
1725 * IPython/Magic.py (magic_time): Improved %time to support
1721 statements and provide wall-clock as well as CPU time.
1726 statements and provide wall-clock as well as CPU time.
1722
1727
1723 2005-02-27 Fernando Perez <fperez@colorado.edu>
1728 2005-02-27 Fernando Perez <fperez@colorado.edu>
1724
1729
1725 * IPython/hooks.py: New hooks module, to expose user-modifiable
1730 * IPython/hooks.py: New hooks module, to expose user-modifiable
1726 IPython functionality in a clean manner. For now only the editor
1731 IPython functionality in a clean manner. For now only the editor
1727 hook is actually written, and other thigns which I intend to turn
1732 hook is actually written, and other thigns which I intend to turn
1728 into proper hooks aren't yet there. The display and prefilter
1733 into proper hooks aren't yet there. The display and prefilter
1729 stuff, for example, should be hooks. But at least now the
1734 stuff, for example, should be hooks. But at least now the
1730 framework is in place, and the rest can be moved here with more
1735 framework is in place, and the rest can be moved here with more
1731 time later. IPython had had a .hooks variable for a long time for
1736 time later. IPython had had a .hooks variable for a long time for
1732 this purpose, but I'd never actually used it for anything.
1737 this purpose, but I'd never actually used it for anything.
1733
1738
1734 2005-02-26 Fernando Perez <fperez@colorado.edu>
1739 2005-02-26 Fernando Perez <fperez@colorado.edu>
1735
1740
1736 * IPython/ipmaker.py (make_IPython): make the default ipython
1741 * IPython/ipmaker.py (make_IPython): make the default ipython
1737 directory be called _ipython under win32, to follow more the
1742 directory be called _ipython under win32, to follow more the
1738 naming peculiarities of that platform (where buggy software like
1743 naming peculiarities of that platform (where buggy software like
1739 Visual Sourcesafe breaks with .named directories). Reported by
1744 Visual Sourcesafe breaks with .named directories). Reported by
1740 Ville Vainio.
1745 Ville Vainio.
1741
1746
1742 2005-02-23 Fernando Perez <fperez@colorado.edu>
1747 2005-02-23 Fernando Perez <fperez@colorado.edu>
1743
1748
1744 * IPython/iplib.py (InteractiveShell.__init__): removed a few
1749 * IPython/iplib.py (InteractiveShell.__init__): removed a few
1745 auto_aliases for win32 which were causing problems. Users can
1750 auto_aliases for win32 which were causing problems. Users can
1746 define the ones they personally like.
1751 define the ones they personally like.
1747
1752
1748 2005-02-21 Fernando Perez <fperez@colorado.edu>
1753 2005-02-21 Fernando Perez <fperez@colorado.edu>
1749
1754
1750 * IPython/Magic.py (magic_time): new magic to time execution of
1755 * IPython/Magic.py (magic_time): new magic to time execution of
1751 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
1756 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
1752
1757
1753 2005-02-19 Fernando Perez <fperez@colorado.edu>
1758 2005-02-19 Fernando Perez <fperez@colorado.edu>
1754
1759
1755 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
1760 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
1756 into keys (for prompts, for example).
1761 into keys (for prompts, for example).
1757
1762
1758 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
1763 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
1759 prompts in case users want them. This introduces a small behavior
1764 prompts in case users want them. This introduces a small behavior
1760 change: ipython does not automatically add a space to all prompts
1765 change: ipython does not automatically add a space to all prompts
1761 anymore. To get the old prompts with a space, users should add it
1766 anymore. To get the old prompts with a space, users should add it
1762 manually to their ipythonrc file, so for example prompt_in1 should
1767 manually to their ipythonrc file, so for example prompt_in1 should
1763 now read 'In [\#]: ' instead of 'In [\#]:'.
1768 now read 'In [\#]: ' instead of 'In [\#]:'.
1764 (BasePrompt.__init__): New option prompts_pad_left (only in rc
1769 (BasePrompt.__init__): New option prompts_pad_left (only in rc
1765 file) to control left-padding of secondary prompts.
1770 file) to control left-padding of secondary prompts.
1766
1771
1767 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
1772 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
1768 the profiler can't be imported. Fix for Debian, which removed
1773 the profiler can't be imported. Fix for Debian, which removed
1769 profile.py because of License issues. I applied a slightly
1774 profile.py because of License issues. I applied a slightly
1770 modified version of the original Debian patch at
1775 modified version of the original Debian patch at
1771 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
1776 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
1772
1777
1773 2005-02-17 Fernando Perez <fperez@colorado.edu>
1778 2005-02-17 Fernando Perez <fperez@colorado.edu>
1774
1779
1775 * IPython/genutils.py (native_line_ends): Fix bug which would
1780 * IPython/genutils.py (native_line_ends): Fix bug which would
1776 cause improper line-ends under win32 b/c I was not opening files
1781 cause improper line-ends under win32 b/c I was not opening files
1777 in binary mode. Bug report and fix thanks to Ville.
1782 in binary mode. Bug report and fix thanks to Ville.
1778
1783
1779 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
1784 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
1780 trying to catch spurious foo[1] autocalls. My fix actually broke
1785 trying to catch spurious foo[1] autocalls. My fix actually broke
1781 ',/' autoquote/call with explicit escape (bad regexp).
1786 ',/' autoquote/call with explicit escape (bad regexp).
1782
1787
1783 2005-02-15 *** Released version 0.6.11
1788 2005-02-15 *** Released version 0.6.11
1784
1789
1785 2005-02-14 Fernando Perez <fperez@colorado.edu>
1790 2005-02-14 Fernando Perez <fperez@colorado.edu>
1786
1791
1787 * IPython/background_jobs.py: New background job management
1792 * IPython/background_jobs.py: New background job management
1788 subsystem. This is implemented via a new set of classes, and
1793 subsystem. This is implemented via a new set of classes, and
1789 IPython now provides a builtin 'jobs' object for background job
1794 IPython now provides a builtin 'jobs' object for background job
1790 execution. A convenience %bg magic serves as a lightweight
1795 execution. A convenience %bg magic serves as a lightweight
1791 frontend for starting the more common type of calls. This was
1796 frontend for starting the more common type of calls. This was
1792 inspired by discussions with B. Granger and the BackgroundCommand
1797 inspired by discussions with B. Granger and the BackgroundCommand
1793 class described in the book Python Scripting for Computational
1798 class described in the book Python Scripting for Computational
1794 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
1799 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
1795 (although ultimately no code from this text was used, as IPython's
1800 (although ultimately no code from this text was used, as IPython's
1796 system is a separate implementation).
1801 system is a separate implementation).
1797
1802
1798 * IPython/iplib.py (MagicCompleter.python_matches): add new option
1803 * IPython/iplib.py (MagicCompleter.python_matches): add new option
1799 to control the completion of single/double underscore names
1804 to control the completion of single/double underscore names
1800 separately. As documented in the example ipytonrc file, the
1805 separately. As documented in the example ipytonrc file, the
1801 readline_omit__names variable can now be set to 2, to omit even
1806 readline_omit__names variable can now be set to 2, to omit even
1802 single underscore names. Thanks to a patch by Brian Wong
1807 single underscore names. Thanks to a patch by Brian Wong
1803 <BrianWong-AT-AirgoNetworks.Com>.
1808 <BrianWong-AT-AirgoNetworks.Com>.
1804 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
1809 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
1805 be autocalled as foo([1]) if foo were callable. A problem for
1810 be autocalled as foo([1]) if foo were callable. A problem for
1806 things which are both callable and implement __getitem__.
1811 things which are both callable and implement __getitem__.
1807 (init_readline): Fix autoindentation for win32. Thanks to a patch
1812 (init_readline): Fix autoindentation for win32. Thanks to a patch
1808 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
1813 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
1809
1814
1810 2005-02-12 Fernando Perez <fperez@colorado.edu>
1815 2005-02-12 Fernando Perez <fperez@colorado.edu>
1811
1816
1812 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
1817 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
1813 which I had written long ago to sort out user error messages which
1818 which I had written long ago to sort out user error messages which
1814 may occur during startup. This seemed like a good idea initially,
1819 may occur during startup. This seemed like a good idea initially,
1815 but it has proven a disaster in retrospect. I don't want to
1820 but it has proven a disaster in retrospect. I don't want to
1816 change much code for now, so my fix is to set the internal 'debug'
1821 change much code for now, so my fix is to set the internal 'debug'
1817 flag to true everywhere, whose only job was precisely to control
1822 flag to true everywhere, whose only job was precisely to control
1818 this subsystem. This closes issue 28 (as well as avoiding all
1823 this subsystem. This closes issue 28 (as well as avoiding all
1819 sorts of strange hangups which occur from time to time).
1824 sorts of strange hangups which occur from time to time).
1820
1825
1821 2005-02-07 Fernando Perez <fperez@colorado.edu>
1826 2005-02-07 Fernando Perez <fperez@colorado.edu>
1822
1827
1823 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
1828 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
1824 previous call produced a syntax error.
1829 previous call produced a syntax error.
1825
1830
1826 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
1831 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
1827 classes without constructor.
1832 classes without constructor.
1828
1833
1829 2005-02-06 Fernando Perez <fperez@colorado.edu>
1834 2005-02-06 Fernando Perez <fperez@colorado.edu>
1830
1835
1831 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
1836 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
1832 completions with the results of each matcher, so we return results
1837 completions with the results of each matcher, so we return results
1833 to the user from all namespaces. This breaks with ipython
1838 to the user from all namespaces. This breaks with ipython
1834 tradition, but I think it's a nicer behavior. Now you get all
1839 tradition, but I think it's a nicer behavior. Now you get all
1835 possible completions listed, from all possible namespaces (python,
1840 possible completions listed, from all possible namespaces (python,
1836 filesystem, magics...) After a request by John Hunter
1841 filesystem, magics...) After a request by John Hunter
1837 <jdhunter-AT-nitace.bsd.uchicago.edu>.
1842 <jdhunter-AT-nitace.bsd.uchicago.edu>.
1838
1843
1839 2005-02-05 Fernando Perez <fperez@colorado.edu>
1844 2005-02-05 Fernando Perez <fperez@colorado.edu>
1840
1845
1841 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
1846 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
1842 the call had quote characters in it (the quotes were stripped).
1847 the call had quote characters in it (the quotes were stripped).
1843
1848
1844 2005-01-31 Fernando Perez <fperez@colorado.edu>
1849 2005-01-31 Fernando Perez <fperez@colorado.edu>
1845
1850
1846 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
1851 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
1847 Itpl.itpl() to make the code more robust against psyco
1852 Itpl.itpl() to make the code more robust against psyco
1848 optimizations.
1853 optimizations.
1849
1854
1850 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
1855 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
1851 of causing an exception. Quicker, cleaner.
1856 of causing an exception. Quicker, cleaner.
1852
1857
1853 2005-01-28 Fernando Perez <fperez@colorado.edu>
1858 2005-01-28 Fernando Perez <fperez@colorado.edu>
1854
1859
1855 * scripts/ipython_win_post_install.py (install): hardcode
1860 * scripts/ipython_win_post_install.py (install): hardcode
1856 sys.prefix+'python.exe' as the executable path. It turns out that
1861 sys.prefix+'python.exe' as the executable path. It turns out that
1857 during the post-installation run, sys.executable resolves to the
1862 during the post-installation run, sys.executable resolves to the
1858 name of the binary installer! I should report this as a distutils
1863 name of the binary installer! I should report this as a distutils
1859 bug, I think. I updated the .10 release with this tiny fix, to
1864 bug, I think. I updated the .10 release with this tiny fix, to
1860 avoid annoying the lists further.
1865 avoid annoying the lists further.
1861
1866
1862 2005-01-27 *** Released version 0.6.10
1867 2005-01-27 *** Released version 0.6.10
1863
1868
1864 2005-01-27 Fernando Perez <fperez@colorado.edu>
1869 2005-01-27 Fernando Perez <fperez@colorado.edu>
1865
1870
1866 * IPython/numutils.py (norm): Added 'inf' as optional name for
1871 * IPython/numutils.py (norm): Added 'inf' as optional name for
1867 L-infinity norm, included references to mathworld.com for vector
1872 L-infinity norm, included references to mathworld.com for vector
1868 norm definitions.
1873 norm definitions.
1869 (amin/amax): added amin/amax for array min/max. Similar to what
1874 (amin/amax): added amin/amax for array min/max. Similar to what
1870 pylab ships with after the recent reorganization of names.
1875 pylab ships with after the recent reorganization of names.
1871 (spike/spike_odd): removed deprecated spike/spike_odd functions.
1876 (spike/spike_odd): removed deprecated spike/spike_odd functions.
1872
1877
1873 * ipython.el: committed Alex's recent fixes and improvements.
1878 * ipython.el: committed Alex's recent fixes and improvements.
1874 Tested with python-mode from CVS, and it looks excellent. Since
1879 Tested with python-mode from CVS, and it looks excellent. Since
1875 python-mode hasn't released anything in a while, I'm temporarily
1880 python-mode hasn't released anything in a while, I'm temporarily
1876 putting a copy of today's CVS (v 4.70) of python-mode in:
1881 putting a copy of today's CVS (v 4.70) of python-mode in:
1877 http://ipython.scipy.org/tmp/python-mode.el
1882 http://ipython.scipy.org/tmp/python-mode.el
1878
1883
1879 * scripts/ipython_win_post_install.py (install): Win32 fix to use
1884 * scripts/ipython_win_post_install.py (install): Win32 fix to use
1880 sys.executable for the executable name, instead of assuming it's
1885 sys.executable for the executable name, instead of assuming it's
1881 called 'python.exe' (the post-installer would have produced broken
1886 called 'python.exe' (the post-installer would have produced broken
1882 setups on systems with a differently named python binary).
1887 setups on systems with a differently named python binary).
1883
1888
1884 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
1889 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
1885 references to os.linesep, to make the code more
1890 references to os.linesep, to make the code more
1886 platform-independent. This is also part of the win32 coloring
1891 platform-independent. This is also part of the win32 coloring
1887 fixes.
1892 fixes.
1888
1893
1889 * IPython/genutils.py (page_dumb): Remove attempts to chop long
1894 * IPython/genutils.py (page_dumb): Remove attempts to chop long
1890 lines, which actually cause coloring bugs because the length of
1895 lines, which actually cause coloring bugs because the length of
1891 the line is very difficult to correctly compute with embedded
1896 the line is very difficult to correctly compute with embedded
1892 escapes. This was the source of all the coloring problems under
1897 escapes. This was the source of all the coloring problems under
1893 Win32. I think that _finally_, Win32 users have a properly
1898 Win32. I think that _finally_, Win32 users have a properly
1894 working ipython in all respects. This would never have happened
1899 working ipython in all respects. This would never have happened
1895 if not for Gary Bishop and Viktor Ransmayr's great help and work.
1900 if not for Gary Bishop and Viktor Ransmayr's great help and work.
1896
1901
1897 2005-01-26 *** Released version 0.6.9
1902 2005-01-26 *** Released version 0.6.9
1898
1903
1899 2005-01-25 Fernando Perez <fperez@colorado.edu>
1904 2005-01-25 Fernando Perez <fperez@colorado.edu>
1900
1905
1901 * setup.py: finally, we have a true Windows installer, thanks to
1906 * setup.py: finally, we have a true Windows installer, thanks to
1902 the excellent work of Viktor Ransmayr
1907 the excellent work of Viktor Ransmayr
1903 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
1908 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
1904 Windows users. The setup routine is quite a bit cleaner thanks to
1909 Windows users. The setup routine is quite a bit cleaner thanks to
1905 this, and the post-install script uses the proper functions to
1910 this, and the post-install script uses the proper functions to
1906 allow a clean de-installation using the standard Windows Control
1911 allow a clean de-installation using the standard Windows Control
1907 Panel.
1912 Panel.
1908
1913
1909 * IPython/genutils.py (get_home_dir): changed to use the $HOME
1914 * IPython/genutils.py (get_home_dir): changed to use the $HOME
1910 environment variable under all OSes (including win32) if
1915 environment variable under all OSes (including win32) if
1911 available. This will give consistency to win32 users who have set
1916 available. This will give consistency to win32 users who have set
1912 this variable for any reason. If os.environ['HOME'] fails, the
1917 this variable for any reason. If os.environ['HOME'] fails, the
1913 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
1918 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
1914
1919
1915 2005-01-24 Fernando Perez <fperez@colorado.edu>
1920 2005-01-24 Fernando Perez <fperez@colorado.edu>
1916
1921
1917 * IPython/numutils.py (empty_like): add empty_like(), similar to
1922 * IPython/numutils.py (empty_like): add empty_like(), similar to
1918 zeros_like() but taking advantage of the new empty() Numeric routine.
1923 zeros_like() but taking advantage of the new empty() Numeric routine.
1919
1924
1920 2005-01-23 *** Released version 0.6.8
1925 2005-01-23 *** Released version 0.6.8
1921
1926
1922 2005-01-22 Fernando Perez <fperez@colorado.edu>
1927 2005-01-22 Fernando Perez <fperez@colorado.edu>
1923
1928
1924 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
1929 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
1925 automatic show() calls. After discussing things with JDH, it
1930 automatic show() calls. After discussing things with JDH, it
1926 turns out there are too many corner cases where this can go wrong.
1931 turns out there are too many corner cases where this can go wrong.
1927 It's best not to try to be 'too smart', and simply have ipython
1932 It's best not to try to be 'too smart', and simply have ipython
1928 reproduce as much as possible the default behavior of a normal
1933 reproduce as much as possible the default behavior of a normal
1929 python shell.
1934 python shell.
1930
1935
1931 * IPython/iplib.py (InteractiveShell.__init__): Modified the
1936 * IPython/iplib.py (InteractiveShell.__init__): Modified the
1932 line-splitting regexp and _prefilter() to avoid calling getattr()
1937 line-splitting regexp and _prefilter() to avoid calling getattr()
1933 on assignments. This closes
1938 on assignments. This closes
1934 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
1939 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
1935 readline uses getattr(), so a simple <TAB> keypress is still
1940 readline uses getattr(), so a simple <TAB> keypress is still
1936 enough to trigger getattr() calls on an object.
1941 enough to trigger getattr() calls on an object.
1937
1942
1938 2005-01-21 Fernando Perez <fperez@colorado.edu>
1943 2005-01-21 Fernando Perez <fperez@colorado.edu>
1939
1944
1940 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
1945 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
1941 docstring under pylab so it doesn't mask the original.
1946 docstring under pylab so it doesn't mask the original.
1942
1947
1943 2005-01-21 *** Released version 0.6.7
1948 2005-01-21 *** Released version 0.6.7
1944
1949
1945 2005-01-21 Fernando Perez <fperez@colorado.edu>
1950 2005-01-21 Fernando Perez <fperez@colorado.edu>
1946
1951
1947 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
1952 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
1948 signal handling for win32 users in multithreaded mode.
1953 signal handling for win32 users in multithreaded mode.
1949
1954
1950 2005-01-17 Fernando Perez <fperez@colorado.edu>
1955 2005-01-17 Fernando Perez <fperez@colorado.edu>
1951
1956
1952 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
1957 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
1953 instances with no __init__. After a crash report by Norbert Nemec
1958 instances with no __init__. After a crash report by Norbert Nemec
1954 <Norbert-AT-nemec-online.de>.
1959 <Norbert-AT-nemec-online.de>.
1955
1960
1956 2005-01-14 Fernando Perez <fperez@colorado.edu>
1961 2005-01-14 Fernando Perez <fperez@colorado.edu>
1957
1962
1958 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
1963 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
1959 names for verbose exceptions, when multiple dotted names and the
1964 names for verbose exceptions, when multiple dotted names and the
1960 'parent' object were present on the same line.
1965 'parent' object were present on the same line.
1961
1966
1962 2005-01-11 Fernando Perez <fperez@colorado.edu>
1967 2005-01-11 Fernando Perez <fperez@colorado.edu>
1963
1968
1964 * IPython/genutils.py (flag_calls): new utility to trap and flag
1969 * IPython/genutils.py (flag_calls): new utility to trap and flag
1965 calls in functions. I need it to clean up matplotlib support.
1970 calls in functions. I need it to clean up matplotlib support.
1966 Also removed some deprecated code in genutils.
1971 Also removed some deprecated code in genutils.
1967
1972
1968 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
1973 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
1969 that matplotlib scripts called with %run, which don't call show()
1974 that matplotlib scripts called with %run, which don't call show()
1970 themselves, still have their plotting windows open.
1975 themselves, still have their plotting windows open.
1971
1976
1972 2005-01-05 Fernando Perez <fperez@colorado.edu>
1977 2005-01-05 Fernando Perez <fperez@colorado.edu>
1973
1978
1974 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
1979 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
1975 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
1980 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
1976
1981
1977 2004-12-19 Fernando Perez <fperez@colorado.edu>
1982 2004-12-19 Fernando Perez <fperez@colorado.edu>
1978
1983
1979 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
1984 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
1980 parent_runcode, which was an eyesore. The same result can be
1985 parent_runcode, which was an eyesore. The same result can be
1981 obtained with Python's regular superclass mechanisms.
1986 obtained with Python's regular superclass mechanisms.
1982
1987
1983 2004-12-17 Fernando Perez <fperez@colorado.edu>
1988 2004-12-17 Fernando Perez <fperez@colorado.edu>
1984
1989
1985 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
1990 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
1986 reported by Prabhu.
1991 reported by Prabhu.
1987 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
1992 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
1988 sys.stderr) instead of explicitly calling sys.stderr. This helps
1993 sys.stderr) instead of explicitly calling sys.stderr. This helps
1989 maintain our I/O abstractions clean, for future GUI embeddings.
1994 maintain our I/O abstractions clean, for future GUI embeddings.
1990
1995
1991 * IPython/genutils.py (info): added new utility for sys.stderr
1996 * IPython/genutils.py (info): added new utility for sys.stderr
1992 unified info message handling (thin wrapper around warn()).
1997 unified info message handling (thin wrapper around warn()).
1993
1998
1994 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
1999 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
1995 composite (dotted) names on verbose exceptions.
2000 composite (dotted) names on verbose exceptions.
1996 (VerboseTB.nullrepr): harden against another kind of errors which
2001 (VerboseTB.nullrepr): harden against another kind of errors which
1997 Python's inspect module can trigger, and which were crashing
2002 Python's inspect module can trigger, and which were crashing
1998 IPython. Thanks to a report by Marco Lombardi
2003 IPython. Thanks to a report by Marco Lombardi
1999 <mlombard-AT-ma010192.hq.eso.org>.
2004 <mlombard-AT-ma010192.hq.eso.org>.
2000
2005
2001 2004-12-13 *** Released version 0.6.6
2006 2004-12-13 *** Released version 0.6.6
2002
2007
2003 2004-12-12 Fernando Perez <fperez@colorado.edu>
2008 2004-12-12 Fernando Perez <fperez@colorado.edu>
2004
2009
2005 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
2010 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
2006 generated by pygtk upon initialization if it was built without
2011 generated by pygtk upon initialization if it was built without
2007 threads (for matplotlib users). After a crash reported by
2012 threads (for matplotlib users). After a crash reported by
2008 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
2013 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
2009
2014
2010 * IPython/ipmaker.py (make_IPython): fix small bug in the
2015 * IPython/ipmaker.py (make_IPython): fix small bug in the
2011 import_some parameter for multiple imports.
2016 import_some parameter for multiple imports.
2012
2017
2013 * IPython/iplib.py (ipmagic): simplified the interface of
2018 * IPython/iplib.py (ipmagic): simplified the interface of
2014 ipmagic() to take a single string argument, just as it would be
2019 ipmagic() to take a single string argument, just as it would be
2015 typed at the IPython cmd line.
2020 typed at the IPython cmd line.
2016 (ipalias): Added new ipalias() with an interface identical to
2021 (ipalias): Added new ipalias() with an interface identical to
2017 ipmagic(). This completes exposing a pure python interface to the
2022 ipmagic(). This completes exposing a pure python interface to the
2018 alias and magic system, which can be used in loops or more complex
2023 alias and magic system, which can be used in loops or more complex
2019 code where IPython's automatic line mangling is not active.
2024 code where IPython's automatic line mangling is not active.
2020
2025
2021 * IPython/genutils.py (timing): changed interface of timing to
2026 * IPython/genutils.py (timing): changed interface of timing to
2022 simply run code once, which is the most common case. timings()
2027 simply run code once, which is the most common case. timings()
2023 remains unchanged, for the cases where you want multiple runs.
2028 remains unchanged, for the cases where you want multiple runs.
2024
2029
2025 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
2030 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
2026 bug where Python2.2 crashes with exec'ing code which does not end
2031 bug where Python2.2 crashes with exec'ing code which does not end
2027 in a single newline. Python 2.3 is OK, so I hadn't noticed this
2032 in a single newline. Python 2.3 is OK, so I hadn't noticed this
2028 before.
2033 before.
2029
2034
2030 2004-12-10 Fernando Perez <fperez@colorado.edu>
2035 2004-12-10 Fernando Perez <fperez@colorado.edu>
2031
2036
2032 * IPython/Magic.py (Magic.magic_prun): changed name of option from
2037 * IPython/Magic.py (Magic.magic_prun): changed name of option from
2033 -t to -T, to accomodate the new -t flag in %run (the %run and
2038 -t to -T, to accomodate the new -t flag in %run (the %run and
2034 %prun options are kind of intermixed, and it's not easy to change
2039 %prun options are kind of intermixed, and it's not easy to change
2035 this with the limitations of python's getopt).
2040 this with the limitations of python's getopt).
2036
2041
2037 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
2042 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
2038 the execution of scripts. It's not as fine-tuned as timeit.py,
2043 the execution of scripts. It's not as fine-tuned as timeit.py,
2039 but it works from inside ipython (and under 2.2, which lacks
2044 but it works from inside ipython (and under 2.2, which lacks
2040 timeit.py). Optionally a number of runs > 1 can be given for
2045 timeit.py). Optionally a number of runs > 1 can be given for
2041 timing very short-running code.
2046 timing very short-running code.
2042
2047
2043 * IPython/genutils.py (uniq_stable): new routine which returns a
2048 * IPython/genutils.py (uniq_stable): new routine which returns a
2044 list of unique elements in any iterable, but in stable order of
2049 list of unique elements in any iterable, but in stable order of
2045 appearance. I needed this for the ultraTB fixes, and it's a handy
2050 appearance. I needed this for the ultraTB fixes, and it's a handy
2046 utility.
2051 utility.
2047
2052
2048 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
2053 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
2049 dotted names in Verbose exceptions. This had been broken since
2054 dotted names in Verbose exceptions. This had been broken since
2050 the very start, now x.y will properly be printed in a Verbose
2055 the very start, now x.y will properly be printed in a Verbose
2051 traceback, instead of x being shown and y appearing always as an
2056 traceback, instead of x being shown and y appearing always as an
2052 'undefined global'. Getting this to work was a bit tricky,
2057 'undefined global'. Getting this to work was a bit tricky,
2053 because by default python tokenizers are stateless. Saved by
2058 because by default python tokenizers are stateless. Saved by
2054 python's ability to easily add a bit of state to an arbitrary
2059 python's ability to easily add a bit of state to an arbitrary
2055 function (without needing to build a full-blown callable object).
2060 function (without needing to build a full-blown callable object).
2056
2061
2057 Also big cleanup of this code, which had horrendous runtime
2062 Also big cleanup of this code, which had horrendous runtime
2058 lookups of zillions of attributes for colorization. Moved all
2063 lookups of zillions of attributes for colorization. Moved all
2059 this code into a few templates, which make it cleaner and quicker.
2064 this code into a few templates, which make it cleaner and quicker.
2060
2065
2061 Printout quality was also improved for Verbose exceptions: one
2066 Printout quality was also improved for Verbose exceptions: one
2062 variable per line, and memory addresses are printed (this can be
2067 variable per line, and memory addresses are printed (this can be
2063 quite handy in nasty debugging situations, which is what Verbose
2068 quite handy in nasty debugging situations, which is what Verbose
2064 is for).
2069 is for).
2065
2070
2066 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
2071 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
2067 the command line as scripts to be loaded by embedded instances.
2072 the command line as scripts to be loaded by embedded instances.
2068 Doing so has the potential for an infinite recursion if there are
2073 Doing so has the potential for an infinite recursion if there are
2069 exceptions thrown in the process. This fixes a strange crash
2074 exceptions thrown in the process. This fixes a strange crash
2070 reported by Philippe MULLER <muller-AT-irit.fr>.
2075 reported by Philippe MULLER <muller-AT-irit.fr>.
2071
2076
2072 2004-12-09 Fernando Perez <fperez@colorado.edu>
2077 2004-12-09 Fernando Perez <fperez@colorado.edu>
2073
2078
2074 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
2079 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
2075 to reflect new names in matplotlib, which now expose the
2080 to reflect new names in matplotlib, which now expose the
2076 matlab-compatible interface via a pylab module instead of the
2081 matlab-compatible interface via a pylab module instead of the
2077 'matlab' name. The new code is backwards compatible, so users of
2082 'matlab' name. The new code is backwards compatible, so users of
2078 all matplotlib versions are OK. Patch by J. Hunter.
2083 all matplotlib versions are OK. Patch by J. Hunter.
2079
2084
2080 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
2085 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
2081 of __init__ docstrings for instances (class docstrings are already
2086 of __init__ docstrings for instances (class docstrings are already
2082 automatically printed). Instances with customized docstrings
2087 automatically printed). Instances with customized docstrings
2083 (indep. of the class) are also recognized and all 3 separate
2088 (indep. of the class) are also recognized and all 3 separate
2084 docstrings are printed (instance, class, constructor). After some
2089 docstrings are printed (instance, class, constructor). After some
2085 comments/suggestions by J. Hunter.
2090 comments/suggestions by J. Hunter.
2086
2091
2087 2004-12-05 Fernando Perez <fperez@colorado.edu>
2092 2004-12-05 Fernando Perez <fperez@colorado.edu>
2088
2093
2089 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
2094 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
2090 warnings when tab-completion fails and triggers an exception.
2095 warnings when tab-completion fails and triggers an exception.
2091
2096
2092 2004-12-03 Fernando Perez <fperez@colorado.edu>
2097 2004-12-03 Fernando Perez <fperez@colorado.edu>
2093
2098
2094 * IPython/Magic.py (magic_prun): Fix bug where an exception would
2099 * IPython/Magic.py (magic_prun): Fix bug where an exception would
2095 be triggered when using 'run -p'. An incorrect option flag was
2100 be triggered when using 'run -p'. An incorrect option flag was
2096 being set ('d' instead of 'D').
2101 being set ('d' instead of 'D').
2097 (manpage): fix missing escaped \- sign.
2102 (manpage): fix missing escaped \- sign.
2098
2103
2099 2004-11-30 *** Released version 0.6.5
2104 2004-11-30 *** Released version 0.6.5
2100
2105
2101 2004-11-30 Fernando Perez <fperez@colorado.edu>
2106 2004-11-30 Fernando Perez <fperez@colorado.edu>
2102
2107
2103 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
2108 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
2104 setting with -d option.
2109 setting with -d option.
2105
2110
2106 * setup.py (docfiles): Fix problem where the doc glob I was using
2111 * setup.py (docfiles): Fix problem where the doc glob I was using
2107 was COMPLETELY BROKEN. It was giving the right files by pure
2112 was COMPLETELY BROKEN. It was giving the right files by pure
2108 accident, but failed once I tried to include ipython.el. Note:
2113 accident, but failed once I tried to include ipython.el. Note:
2109 glob() does NOT allow you to do exclusion on multiple endings!
2114 glob() does NOT allow you to do exclusion on multiple endings!
2110
2115
2111 2004-11-29 Fernando Perez <fperez@colorado.edu>
2116 2004-11-29 Fernando Perez <fperez@colorado.edu>
2112
2117
2113 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
2118 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
2114 the manpage as the source. Better formatting & consistency.
2119 the manpage as the source. Better formatting & consistency.
2115
2120
2116 * IPython/Magic.py (magic_run): Added new -d option, to run
2121 * IPython/Magic.py (magic_run): Added new -d option, to run
2117 scripts under the control of the python pdb debugger. Note that
2122 scripts under the control of the python pdb debugger. Note that
2118 this required changing the %prun option -d to -D, to avoid a clash
2123 this required changing the %prun option -d to -D, to avoid a clash
2119 (since %run must pass options to %prun, and getopt is too dumb to
2124 (since %run must pass options to %prun, and getopt is too dumb to
2120 handle options with string values with embedded spaces). Thanks
2125 handle options with string values with embedded spaces). Thanks
2121 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
2126 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
2122 (magic_who_ls): added type matching to %who and %whos, so that one
2127 (magic_who_ls): added type matching to %who and %whos, so that one
2123 can filter their output to only include variables of certain
2128 can filter their output to only include variables of certain
2124 types. Another suggestion by Matthew.
2129 types. Another suggestion by Matthew.
2125 (magic_whos): Added memory summaries in kb and Mb for arrays.
2130 (magic_whos): Added memory summaries in kb and Mb for arrays.
2126 (magic_who): Improve formatting (break lines every 9 vars).
2131 (magic_who): Improve formatting (break lines every 9 vars).
2127
2132
2128 2004-11-28 Fernando Perez <fperez@colorado.edu>
2133 2004-11-28 Fernando Perez <fperez@colorado.edu>
2129
2134
2130 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
2135 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
2131 cache when empty lines were present.
2136 cache when empty lines were present.
2132
2137
2133 2004-11-24 Fernando Perez <fperez@colorado.edu>
2138 2004-11-24 Fernando Perez <fperez@colorado.edu>
2134
2139
2135 * IPython/usage.py (__doc__): document the re-activated threading
2140 * IPython/usage.py (__doc__): document the re-activated threading
2136 options for WX and GTK.
2141 options for WX and GTK.
2137
2142
2138 2004-11-23 Fernando Perez <fperez@colorado.edu>
2143 2004-11-23 Fernando Perez <fperez@colorado.edu>
2139
2144
2140 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
2145 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
2141 the -wthread and -gthread options, along with a new -tk one to try
2146 the -wthread and -gthread options, along with a new -tk one to try
2142 and coordinate Tk threading with wx/gtk. The tk support is very
2147 and coordinate Tk threading with wx/gtk. The tk support is very
2143 platform dependent, since it seems to require Tcl and Tk to be
2148 platform dependent, since it seems to require Tcl and Tk to be
2144 built with threads (Fedora1/2 appears NOT to have it, but in
2149 built with threads (Fedora1/2 appears NOT to have it, but in
2145 Prabhu's Debian boxes it works OK). But even with some Tk
2150 Prabhu's Debian boxes it works OK). But even with some Tk
2146 limitations, this is a great improvement.
2151 limitations, this is a great improvement.
2147
2152
2148 * IPython/Prompts.py (prompt_specials_color): Added \t for time
2153 * IPython/Prompts.py (prompt_specials_color): Added \t for time
2149 info in user prompts. Patch by Prabhu.
2154 info in user prompts. Patch by Prabhu.
2150
2155
2151 2004-11-18 Fernando Perez <fperez@colorado.edu>
2156 2004-11-18 Fernando Perez <fperez@colorado.edu>
2152
2157
2153 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
2158 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
2154 EOFErrors and bail, to avoid infinite loops if a non-terminating
2159 EOFErrors and bail, to avoid infinite loops if a non-terminating
2155 file is fed into ipython. Patch submitted in issue 19 by user,
2160 file is fed into ipython. Patch submitted in issue 19 by user,
2156 many thanks.
2161 many thanks.
2157
2162
2158 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
2163 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
2159 autoquote/parens in continuation prompts, which can cause lots of
2164 autoquote/parens in continuation prompts, which can cause lots of
2160 problems. Closes roundup issue 20.
2165 problems. Closes roundup issue 20.
2161
2166
2162 2004-11-17 Fernando Perez <fperez@colorado.edu>
2167 2004-11-17 Fernando Perez <fperez@colorado.edu>
2163
2168
2164 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
2169 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
2165 reported as debian bug #280505. I'm not sure my local changelog
2170 reported as debian bug #280505. I'm not sure my local changelog
2166 entry has the proper debian format (Jack?).
2171 entry has the proper debian format (Jack?).
2167
2172
2168 2004-11-08 *** Released version 0.6.4
2173 2004-11-08 *** Released version 0.6.4
2169
2174
2170 2004-11-08 Fernando Perez <fperez@colorado.edu>
2175 2004-11-08 Fernando Perez <fperez@colorado.edu>
2171
2176
2172 * IPython/iplib.py (init_readline): Fix exit message for Windows
2177 * IPython/iplib.py (init_readline): Fix exit message for Windows
2173 when readline is active. Thanks to a report by Eric Jones
2178 when readline is active. Thanks to a report by Eric Jones
2174 <eric-AT-enthought.com>.
2179 <eric-AT-enthought.com>.
2175
2180
2176 2004-11-07 Fernando Perez <fperez@colorado.edu>
2181 2004-11-07 Fernando Perez <fperez@colorado.edu>
2177
2182
2178 * IPython/genutils.py (page): Add a trap for OSError exceptions,
2183 * IPython/genutils.py (page): Add a trap for OSError exceptions,
2179 sometimes seen by win2k/cygwin users.
2184 sometimes seen by win2k/cygwin users.
2180
2185
2181 2004-11-06 Fernando Perez <fperez@colorado.edu>
2186 2004-11-06 Fernando Perez <fperez@colorado.edu>
2182
2187
2183 * IPython/iplib.py (interact): Change the handling of %Exit from
2188 * IPython/iplib.py (interact): Change the handling of %Exit from
2184 trying to propagate a SystemExit to an internal ipython flag.
2189 trying to propagate a SystemExit to an internal ipython flag.
2185 This is less elegant than using Python's exception mechanism, but
2190 This is less elegant than using Python's exception mechanism, but
2186 I can't get that to work reliably with threads, so under -pylab
2191 I can't get that to work reliably with threads, so under -pylab
2187 %Exit was hanging IPython. Cross-thread exception handling is
2192 %Exit was hanging IPython. Cross-thread exception handling is
2188 really a bitch. Thaks to a bug report by Stephen Walton
2193 really a bitch. Thaks to a bug report by Stephen Walton
2189 <stephen.walton-AT-csun.edu>.
2194 <stephen.walton-AT-csun.edu>.
2190
2195
2191 2004-11-04 Fernando Perez <fperez@colorado.edu>
2196 2004-11-04 Fernando Perez <fperez@colorado.edu>
2192
2197
2193 * IPython/iplib.py (raw_input_original): store a pointer to the
2198 * IPython/iplib.py (raw_input_original): store a pointer to the
2194 true raw_input to harden against code which can modify it
2199 true raw_input to harden against code which can modify it
2195 (wx.py.PyShell does this and would otherwise crash ipython).
2200 (wx.py.PyShell does this and would otherwise crash ipython).
2196 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
2201 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
2197
2202
2198 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
2203 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
2199 Ctrl-C problem, which does not mess up the input line.
2204 Ctrl-C problem, which does not mess up the input line.
2200
2205
2201 2004-11-03 Fernando Perez <fperez@colorado.edu>
2206 2004-11-03 Fernando Perez <fperez@colorado.edu>
2202
2207
2203 * IPython/Release.py: Changed licensing to BSD, in all files.
2208 * IPython/Release.py: Changed licensing to BSD, in all files.
2204 (name): lowercase name for tarball/RPM release.
2209 (name): lowercase name for tarball/RPM release.
2205
2210
2206 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
2211 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
2207 use throughout ipython.
2212 use throughout ipython.
2208
2213
2209 * IPython/Magic.py (Magic._ofind): Switch to using the new
2214 * IPython/Magic.py (Magic._ofind): Switch to using the new
2210 OInspect.getdoc() function.
2215 OInspect.getdoc() function.
2211
2216
2212 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
2217 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
2213 of the line currently being canceled via Ctrl-C. It's extremely
2218 of the line currently being canceled via Ctrl-C. It's extremely
2214 ugly, but I don't know how to do it better (the problem is one of
2219 ugly, but I don't know how to do it better (the problem is one of
2215 handling cross-thread exceptions).
2220 handling cross-thread exceptions).
2216
2221
2217 2004-10-28 Fernando Perez <fperez@colorado.edu>
2222 2004-10-28 Fernando Perez <fperez@colorado.edu>
2218
2223
2219 * IPython/Shell.py (signal_handler): add signal handlers to trap
2224 * IPython/Shell.py (signal_handler): add signal handlers to trap
2220 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
2225 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
2221 report by Francesc Alted.
2226 report by Francesc Alted.
2222
2227
2223 2004-10-21 Fernando Perez <fperez@colorado.edu>
2228 2004-10-21 Fernando Perez <fperez@colorado.edu>
2224
2229
2225 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
2230 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
2226 to % for pysh syntax extensions.
2231 to % for pysh syntax extensions.
2227
2232
2228 2004-10-09 Fernando Perez <fperez@colorado.edu>
2233 2004-10-09 Fernando Perez <fperez@colorado.edu>
2229
2234
2230 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
2235 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
2231 arrays to print a more useful summary, without calling str(arr).
2236 arrays to print a more useful summary, without calling str(arr).
2232 This avoids the problem of extremely lengthy computations which
2237 This avoids the problem of extremely lengthy computations which
2233 occur if arr is large, and appear to the user as a system lockup
2238 occur if arr is large, and appear to the user as a system lockup
2234 with 100% cpu activity. After a suggestion by Kristian Sandberg
2239 with 100% cpu activity. After a suggestion by Kristian Sandberg
2235 <Kristian.Sandberg@colorado.edu>.
2240 <Kristian.Sandberg@colorado.edu>.
2236 (Magic.__init__): fix bug in global magic escapes not being
2241 (Magic.__init__): fix bug in global magic escapes not being
2237 correctly set.
2242 correctly set.
2238
2243
2239 2004-10-08 Fernando Perez <fperez@colorado.edu>
2244 2004-10-08 Fernando Perez <fperez@colorado.edu>
2240
2245
2241 * IPython/Magic.py (__license__): change to absolute imports of
2246 * IPython/Magic.py (__license__): change to absolute imports of
2242 ipython's own internal packages, to start adapting to the absolute
2247 ipython's own internal packages, to start adapting to the absolute
2243 import requirement of PEP-328.
2248 import requirement of PEP-328.
2244
2249
2245 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
2250 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
2246 files, and standardize author/license marks through the Release
2251 files, and standardize author/license marks through the Release
2247 module instead of having per/file stuff (except for files with
2252 module instead of having per/file stuff (except for files with
2248 particular licenses, like the MIT/PSF-licensed codes).
2253 particular licenses, like the MIT/PSF-licensed codes).
2249
2254
2250 * IPython/Debugger.py: remove dead code for python 2.1
2255 * IPython/Debugger.py: remove dead code for python 2.1
2251
2256
2252 2004-10-04 Fernando Perez <fperez@colorado.edu>
2257 2004-10-04 Fernando Perez <fperez@colorado.edu>
2253
2258
2254 * IPython/iplib.py (ipmagic): New function for accessing magics
2259 * IPython/iplib.py (ipmagic): New function for accessing magics
2255 via a normal python function call.
2260 via a normal python function call.
2256
2261
2257 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
2262 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
2258 from '@' to '%', to accomodate the new @decorator syntax of python
2263 from '@' to '%', to accomodate the new @decorator syntax of python
2259 2.4.
2264 2.4.
2260
2265
2261 2004-09-29 Fernando Perez <fperez@colorado.edu>
2266 2004-09-29 Fernando Perez <fperez@colorado.edu>
2262
2267
2263 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
2268 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
2264 matplotlib.use to prevent running scripts which try to switch
2269 matplotlib.use to prevent running scripts which try to switch
2265 interactive backends from within ipython. This will just crash
2270 interactive backends from within ipython. This will just crash
2266 the python interpreter, so we can't allow it (but a detailed error
2271 the python interpreter, so we can't allow it (but a detailed error
2267 is given to the user).
2272 is given to the user).
2268
2273
2269 2004-09-28 Fernando Perez <fperez@colorado.edu>
2274 2004-09-28 Fernando Perez <fperez@colorado.edu>
2270
2275
2271 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
2276 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
2272 matplotlib-related fixes so that using @run with non-matplotlib
2277 matplotlib-related fixes so that using @run with non-matplotlib
2273 scripts doesn't pop up spurious plot windows. This requires
2278 scripts doesn't pop up spurious plot windows. This requires
2274 matplotlib >= 0.63, where I had to make some changes as well.
2279 matplotlib >= 0.63, where I had to make some changes as well.
2275
2280
2276 * IPython/ipmaker.py (make_IPython): update version requirement to
2281 * IPython/ipmaker.py (make_IPython): update version requirement to
2277 python 2.2.
2282 python 2.2.
2278
2283
2279 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
2284 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
2280 banner arg for embedded customization.
2285 banner arg for embedded customization.
2281
2286
2282 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
2287 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
2283 explicit uses of __IP as the IPython's instance name. Now things
2288 explicit uses of __IP as the IPython's instance name. Now things
2284 are properly handled via the shell.name value. The actual code
2289 are properly handled via the shell.name value. The actual code
2285 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
2290 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
2286 is much better than before. I'll clean things completely when the
2291 is much better than before. I'll clean things completely when the
2287 magic stuff gets a real overhaul.
2292 magic stuff gets a real overhaul.
2288
2293
2289 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
2294 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
2290 minor changes to debian dir.
2295 minor changes to debian dir.
2291
2296
2292 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
2297 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
2293 pointer to the shell itself in the interactive namespace even when
2298 pointer to the shell itself in the interactive namespace even when
2294 a user-supplied dict is provided. This is needed for embedding
2299 a user-supplied dict is provided. This is needed for embedding
2295 purposes (found by tests with Michel Sanner).
2300 purposes (found by tests with Michel Sanner).
2296
2301
2297 2004-09-27 Fernando Perez <fperez@colorado.edu>
2302 2004-09-27 Fernando Perez <fperez@colorado.edu>
2298
2303
2299 * IPython/UserConfig/ipythonrc: remove []{} from
2304 * IPython/UserConfig/ipythonrc: remove []{} from
2300 readline_remove_delims, so that things like [modname.<TAB> do
2305 readline_remove_delims, so that things like [modname.<TAB> do
2301 proper completion. This disables [].TAB, but that's a less common
2306 proper completion. This disables [].TAB, but that's a less common
2302 case than module names in list comprehensions, for example.
2307 case than module names in list comprehensions, for example.
2303 Thanks to a report by Andrea Riciputi.
2308 Thanks to a report by Andrea Riciputi.
2304
2309
2305 2004-09-09 Fernando Perez <fperez@colorado.edu>
2310 2004-09-09 Fernando Perez <fperez@colorado.edu>
2306
2311
2307 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
2312 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
2308 blocking problems in win32 and osx. Fix by John.
2313 blocking problems in win32 and osx. Fix by John.
2309
2314
2310 2004-09-08 Fernando Perez <fperez@colorado.edu>
2315 2004-09-08 Fernando Perez <fperez@colorado.edu>
2311
2316
2312 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
2317 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
2313 for Win32 and OSX. Fix by John Hunter.
2318 for Win32 and OSX. Fix by John Hunter.
2314
2319
2315 2004-08-30 *** Released version 0.6.3
2320 2004-08-30 *** Released version 0.6.3
2316
2321
2317 2004-08-30 Fernando Perez <fperez@colorado.edu>
2322 2004-08-30 Fernando Perez <fperez@colorado.edu>
2318
2323
2319 * setup.py (isfile): Add manpages to list of dependent files to be
2324 * setup.py (isfile): Add manpages to list of dependent files to be
2320 updated.
2325 updated.
2321
2326
2322 2004-08-27 Fernando Perez <fperez@colorado.edu>
2327 2004-08-27 Fernando Perez <fperez@colorado.edu>
2323
2328
2324 * IPython/Shell.py (start): I've disabled -wthread and -gthread
2329 * IPython/Shell.py (start): I've disabled -wthread and -gthread
2325 for now. They don't really work with standalone WX/GTK code
2330 for now. They don't really work with standalone WX/GTK code
2326 (though matplotlib IS working fine with both of those backends).
2331 (though matplotlib IS working fine with both of those backends).
2327 This will neeed much more testing. I disabled most things with
2332 This will neeed much more testing. I disabled most things with
2328 comments, so turning it back on later should be pretty easy.
2333 comments, so turning it back on later should be pretty easy.
2329
2334
2330 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
2335 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
2331 autocalling of expressions like r'foo', by modifying the line
2336 autocalling of expressions like r'foo', by modifying the line
2332 split regexp. Closes
2337 split regexp. Closes
2333 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
2338 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
2334 Riley <ipythonbugs-AT-sabi.net>.
2339 Riley <ipythonbugs-AT-sabi.net>.
2335 (InteractiveShell.mainloop): honor --nobanner with banner
2340 (InteractiveShell.mainloop): honor --nobanner with banner
2336 extensions.
2341 extensions.
2337
2342
2338 * IPython/Shell.py: Significant refactoring of all classes, so
2343 * IPython/Shell.py: Significant refactoring of all classes, so
2339 that we can really support ALL matplotlib backends and threading
2344 that we can really support ALL matplotlib backends and threading
2340 models (John spotted a bug with Tk which required this). Now we
2345 models (John spotted a bug with Tk which required this). Now we
2341 should support single-threaded, WX-threads and GTK-threads, both
2346 should support single-threaded, WX-threads and GTK-threads, both
2342 for generic code and for matplotlib.
2347 for generic code and for matplotlib.
2343
2348
2344 * IPython/ipmaker.py (__call__): Changed -mpthread option to
2349 * IPython/ipmaker.py (__call__): Changed -mpthread option to
2345 -pylab, to simplify things for users. Will also remove the pylab
2350 -pylab, to simplify things for users. Will also remove the pylab
2346 profile, since now all of matplotlib configuration is directly
2351 profile, since now all of matplotlib configuration is directly
2347 handled here. This also reduces startup time.
2352 handled here. This also reduces startup time.
2348
2353
2349 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
2354 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
2350 shell wasn't being correctly called. Also in IPShellWX.
2355 shell wasn't being correctly called. Also in IPShellWX.
2351
2356
2352 * IPython/iplib.py (InteractiveShell.__init__): Added option to
2357 * IPython/iplib.py (InteractiveShell.__init__): Added option to
2353 fine-tune banner.
2358 fine-tune banner.
2354
2359
2355 * IPython/numutils.py (spike): Deprecate these spike functions,
2360 * IPython/numutils.py (spike): Deprecate these spike functions,
2356 delete (long deprecated) gnuplot_exec handler.
2361 delete (long deprecated) gnuplot_exec handler.
2357
2362
2358 2004-08-26 Fernando Perez <fperez@colorado.edu>
2363 2004-08-26 Fernando Perez <fperez@colorado.edu>
2359
2364
2360 * ipython.1: Update for threading options, plus some others which
2365 * ipython.1: Update for threading options, plus some others which
2361 were missing.
2366 were missing.
2362
2367
2363 * IPython/ipmaker.py (__call__): Added -wthread option for
2368 * IPython/ipmaker.py (__call__): Added -wthread option for
2364 wxpython thread handling. Make sure threading options are only
2369 wxpython thread handling. Make sure threading options are only
2365 valid at the command line.
2370 valid at the command line.
2366
2371
2367 * scripts/ipython: moved shell selection into a factory function
2372 * scripts/ipython: moved shell selection into a factory function
2368 in Shell.py, to keep the starter script to a minimum.
2373 in Shell.py, to keep the starter script to a minimum.
2369
2374
2370 2004-08-25 Fernando Perez <fperez@colorado.edu>
2375 2004-08-25 Fernando Perez <fperez@colorado.edu>
2371
2376
2372 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
2377 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
2373 John. Along with some recent changes he made to matplotlib, the
2378 John. Along with some recent changes he made to matplotlib, the
2374 next versions of both systems should work very well together.
2379 next versions of both systems should work very well together.
2375
2380
2376 2004-08-24 Fernando Perez <fperez@colorado.edu>
2381 2004-08-24 Fernando Perez <fperez@colorado.edu>
2377
2382
2378 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
2383 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
2379 tried to switch the profiling to using hotshot, but I'm getting
2384 tried to switch the profiling to using hotshot, but I'm getting
2380 strange errors from prof.runctx() there. I may be misreading the
2385 strange errors from prof.runctx() there. I may be misreading the
2381 docs, but it looks weird. For now the profiling code will
2386 docs, but it looks weird. For now the profiling code will
2382 continue to use the standard profiler.
2387 continue to use the standard profiler.
2383
2388
2384 2004-08-23 Fernando Perez <fperez@colorado.edu>
2389 2004-08-23 Fernando Perez <fperez@colorado.edu>
2385
2390
2386 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
2391 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
2387 threaded shell, by John Hunter. It's not quite ready yet, but
2392 threaded shell, by John Hunter. It's not quite ready yet, but
2388 close.
2393 close.
2389
2394
2390 2004-08-22 Fernando Perez <fperez@colorado.edu>
2395 2004-08-22 Fernando Perez <fperez@colorado.edu>
2391
2396
2392 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
2397 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
2393 in Magic and ultraTB.
2398 in Magic and ultraTB.
2394
2399
2395 * ipython.1: document threading options in manpage.
2400 * ipython.1: document threading options in manpage.
2396
2401
2397 * scripts/ipython: Changed name of -thread option to -gthread,
2402 * scripts/ipython: Changed name of -thread option to -gthread,
2398 since this is GTK specific. I want to leave the door open for a
2403 since this is GTK specific. I want to leave the door open for a
2399 -wthread option for WX, which will most likely be necessary. This
2404 -wthread option for WX, which will most likely be necessary. This
2400 change affects usage and ipmaker as well.
2405 change affects usage and ipmaker as well.
2401
2406
2402 * IPython/Shell.py (matplotlib_shell): Add a factory function to
2407 * IPython/Shell.py (matplotlib_shell): Add a factory function to
2403 handle the matplotlib shell issues. Code by John Hunter
2408 handle the matplotlib shell issues. Code by John Hunter
2404 <jdhunter-AT-nitace.bsd.uchicago.edu>.
2409 <jdhunter-AT-nitace.bsd.uchicago.edu>.
2405 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
2410 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
2406 broken (and disabled for end users) for now, but it puts the
2411 broken (and disabled for end users) for now, but it puts the
2407 infrastructure in place.
2412 infrastructure in place.
2408
2413
2409 2004-08-21 Fernando Perez <fperez@colorado.edu>
2414 2004-08-21 Fernando Perez <fperez@colorado.edu>
2410
2415
2411 * ipythonrc-pylab: Add matplotlib support.
2416 * ipythonrc-pylab: Add matplotlib support.
2412
2417
2413 * matplotlib_config.py: new files for matplotlib support, part of
2418 * matplotlib_config.py: new files for matplotlib support, part of
2414 the pylab profile.
2419 the pylab profile.
2415
2420
2416 * IPython/usage.py (__doc__): documented the threading options.
2421 * IPython/usage.py (__doc__): documented the threading options.
2417
2422
2418 2004-08-20 Fernando Perez <fperez@colorado.edu>
2423 2004-08-20 Fernando Perez <fperez@colorado.edu>
2419
2424
2420 * ipython: Modified the main calling routine to handle the -thread
2425 * ipython: Modified the main calling routine to handle the -thread
2421 and -mpthread options. This needs to be done as a top-level hack,
2426 and -mpthread options. This needs to be done as a top-level hack,
2422 because it determines which class to instantiate for IPython
2427 because it determines which class to instantiate for IPython
2423 itself.
2428 itself.
2424
2429
2425 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
2430 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
2426 classes to support multithreaded GTK operation without blocking,
2431 classes to support multithreaded GTK operation without blocking,
2427 and matplotlib with all backends. This is a lot of still very
2432 and matplotlib with all backends. This is a lot of still very
2428 experimental code, and threads are tricky. So it may still have a
2433 experimental code, and threads are tricky. So it may still have a
2429 few rough edges... This code owes a lot to
2434 few rough edges... This code owes a lot to
2430 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
2435 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
2431 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
2436 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
2432 to John Hunter for all the matplotlib work.
2437 to John Hunter for all the matplotlib work.
2433
2438
2434 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
2439 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
2435 options for gtk thread and matplotlib support.
2440 options for gtk thread and matplotlib support.
2436
2441
2437 2004-08-16 Fernando Perez <fperez@colorado.edu>
2442 2004-08-16 Fernando Perez <fperez@colorado.edu>
2438
2443
2439 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
2444 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
2440 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
2445 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
2441 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
2446 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
2442
2447
2443 2004-08-11 Fernando Perez <fperez@colorado.edu>
2448 2004-08-11 Fernando Perez <fperez@colorado.edu>
2444
2449
2445 * setup.py (isfile): Fix build so documentation gets updated for
2450 * setup.py (isfile): Fix build so documentation gets updated for
2446 rpms (it was only done for .tgz builds).
2451 rpms (it was only done for .tgz builds).
2447
2452
2448 2004-08-10 Fernando Perez <fperez@colorado.edu>
2453 2004-08-10 Fernando Perez <fperez@colorado.edu>
2449
2454
2450 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
2455 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
2451
2456
2452 * iplib.py : Silence syntax error exceptions in tab-completion.
2457 * iplib.py : Silence syntax error exceptions in tab-completion.
2453
2458
2454 2004-08-05 Fernando Perez <fperez@colorado.edu>
2459 2004-08-05 Fernando Perez <fperez@colorado.edu>
2455
2460
2456 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
2461 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
2457 'color off' mark for continuation prompts. This was causing long
2462 'color off' mark for continuation prompts. This was causing long
2458 continuation lines to mis-wrap.
2463 continuation lines to mis-wrap.
2459
2464
2460 2004-08-01 Fernando Perez <fperez@colorado.edu>
2465 2004-08-01 Fernando Perez <fperez@colorado.edu>
2461
2466
2462 * IPython/ipmaker.py (make_IPython): Allow the shell class used
2467 * IPython/ipmaker.py (make_IPython): Allow the shell class used
2463 for building ipython to be a parameter. All this is necessary
2468 for building ipython to be a parameter. All this is necessary
2464 right now to have a multithreaded version, but this insane
2469 right now to have a multithreaded version, but this insane
2465 non-design will be cleaned up soon. For now, it's a hack that
2470 non-design will be cleaned up soon. For now, it's a hack that
2466 works.
2471 works.
2467
2472
2468 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
2473 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
2469 args in various places. No bugs so far, but it's a dangerous
2474 args in various places. No bugs so far, but it's a dangerous
2470 practice.
2475 practice.
2471
2476
2472 2004-07-31 Fernando Perez <fperez@colorado.edu>
2477 2004-07-31 Fernando Perez <fperez@colorado.edu>
2473
2478
2474 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
2479 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
2475 fix completion of files with dots in their names under most
2480 fix completion of files with dots in their names under most
2476 profiles (pysh was OK because the completion order is different).
2481 profiles (pysh was OK because the completion order is different).
2477
2482
2478 2004-07-27 Fernando Perez <fperez@colorado.edu>
2483 2004-07-27 Fernando Perez <fperez@colorado.edu>
2479
2484
2480 * IPython/iplib.py (InteractiveShell.__init__): build dict of
2485 * IPython/iplib.py (InteractiveShell.__init__): build dict of
2481 keywords manually, b/c the one in keyword.py was removed in python
2486 keywords manually, b/c the one in keyword.py was removed in python
2482 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
2487 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
2483 This is NOT a bug under python 2.3 and earlier.
2488 This is NOT a bug under python 2.3 and earlier.
2484
2489
2485 2004-07-26 Fernando Perez <fperez@colorado.edu>
2490 2004-07-26 Fernando Perez <fperez@colorado.edu>
2486
2491
2487 * IPython/ultraTB.py (VerboseTB.text): Add another
2492 * IPython/ultraTB.py (VerboseTB.text): Add another
2488 linecache.checkcache() call to try to prevent inspect.py from
2493 linecache.checkcache() call to try to prevent inspect.py from
2489 crashing under python 2.3. I think this fixes
2494 crashing under python 2.3. I think this fixes
2490 http://www.scipy.net/roundup/ipython/issue17.
2495 http://www.scipy.net/roundup/ipython/issue17.
2491
2496
2492 2004-07-26 *** Released version 0.6.2
2497 2004-07-26 *** Released version 0.6.2
2493
2498
2494 2004-07-26 Fernando Perez <fperez@colorado.edu>
2499 2004-07-26 Fernando Perez <fperez@colorado.edu>
2495
2500
2496 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
2501 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
2497 fail for any number.
2502 fail for any number.
2498 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
2503 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
2499 empty bookmarks.
2504 empty bookmarks.
2500
2505
2501 2004-07-26 *** Released version 0.6.1
2506 2004-07-26 *** Released version 0.6.1
2502
2507
2503 2004-07-26 Fernando Perez <fperez@colorado.edu>
2508 2004-07-26 Fernando Perez <fperez@colorado.edu>
2504
2509
2505 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
2510 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
2506
2511
2507 * IPython/iplib.py (protect_filename): Applied Ville's patch for
2512 * IPython/iplib.py (protect_filename): Applied Ville's patch for
2508 escaping '()[]{}' in filenames.
2513 escaping '()[]{}' in filenames.
2509
2514
2510 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
2515 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
2511 Python 2.2 users who lack a proper shlex.split.
2516 Python 2.2 users who lack a proper shlex.split.
2512
2517
2513 2004-07-19 Fernando Perez <fperez@colorado.edu>
2518 2004-07-19 Fernando Perez <fperez@colorado.edu>
2514
2519
2515 * IPython/iplib.py (InteractiveShell.init_readline): Add support
2520 * IPython/iplib.py (InteractiveShell.init_readline): Add support
2516 for reading readline's init file. I follow the normal chain:
2521 for reading readline's init file. I follow the normal chain:
2517 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
2522 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
2518 report by Mike Heeter. This closes
2523 report by Mike Heeter. This closes
2519 http://www.scipy.net/roundup/ipython/issue16.
2524 http://www.scipy.net/roundup/ipython/issue16.
2520
2525
2521 2004-07-18 Fernando Perez <fperez@colorado.edu>
2526 2004-07-18 Fernando Perez <fperez@colorado.edu>
2522
2527
2523 * IPython/iplib.py (__init__): Add better handling of '\' under
2528 * IPython/iplib.py (__init__): Add better handling of '\' under
2524 Win32 for filenames. After a patch by Ville.
2529 Win32 for filenames. After a patch by Ville.
2525
2530
2526 2004-07-17 Fernando Perez <fperez@colorado.edu>
2531 2004-07-17 Fernando Perez <fperez@colorado.edu>
2527
2532
2528 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
2533 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
2529 autocalling would be triggered for 'foo is bar' if foo is
2534 autocalling would be triggered for 'foo is bar' if foo is
2530 callable. I also cleaned up the autocall detection code to use a
2535 callable. I also cleaned up the autocall detection code to use a
2531 regexp, which is faster. Bug reported by Alexander Schmolck.
2536 regexp, which is faster. Bug reported by Alexander Schmolck.
2532
2537
2533 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
2538 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
2534 '?' in them would confuse the help system. Reported by Alex
2539 '?' in them would confuse the help system. Reported by Alex
2535 Schmolck.
2540 Schmolck.
2536
2541
2537 2004-07-16 Fernando Perez <fperez@colorado.edu>
2542 2004-07-16 Fernando Perez <fperez@colorado.edu>
2538
2543
2539 * IPython/GnuplotInteractive.py (__all__): added plot2.
2544 * IPython/GnuplotInteractive.py (__all__): added plot2.
2540
2545
2541 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
2546 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
2542 plotting dictionaries, lists or tuples of 1d arrays.
2547 plotting dictionaries, lists or tuples of 1d arrays.
2543
2548
2544 * IPython/Magic.py (Magic.magic_hist): small clenaups and
2549 * IPython/Magic.py (Magic.magic_hist): small clenaups and
2545 optimizations.
2550 optimizations.
2546
2551
2547 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
2552 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
2548 the information which was there from Janko's original IPP code:
2553 the information which was there from Janko's original IPP code:
2549
2554
2550 03.05.99 20:53 porto.ifm.uni-kiel.de
2555 03.05.99 20:53 porto.ifm.uni-kiel.de
2551 --Started changelog.
2556 --Started changelog.
2552 --make clear do what it say it does
2557 --make clear do what it say it does
2553 --added pretty output of lines from inputcache
2558 --added pretty output of lines from inputcache
2554 --Made Logger a mixin class, simplifies handling of switches
2559 --Made Logger a mixin class, simplifies handling of switches
2555 --Added own completer class. .string<TAB> expands to last history
2560 --Added own completer class. .string<TAB> expands to last history
2556 line which starts with string. The new expansion is also present
2561 line which starts with string. The new expansion is also present
2557 with Ctrl-r from the readline library. But this shows, who this
2562 with Ctrl-r from the readline library. But this shows, who this
2558 can be done for other cases.
2563 can be done for other cases.
2559 --Added convention that all shell functions should accept a
2564 --Added convention that all shell functions should accept a
2560 parameter_string This opens the door for different behaviour for
2565 parameter_string This opens the door for different behaviour for
2561 each function. @cd is a good example of this.
2566 each function. @cd is a good example of this.
2562
2567
2563 04.05.99 12:12 porto.ifm.uni-kiel.de
2568 04.05.99 12:12 porto.ifm.uni-kiel.de
2564 --added logfile rotation
2569 --added logfile rotation
2565 --added new mainloop method which freezes first the namespace
2570 --added new mainloop method which freezes first the namespace
2566
2571
2567 07.05.99 21:24 porto.ifm.uni-kiel.de
2572 07.05.99 21:24 porto.ifm.uni-kiel.de
2568 --added the docreader classes. Now there is a help system.
2573 --added the docreader classes. Now there is a help system.
2569 -This is only a first try. Currently it's not easy to put new
2574 -This is only a first try. Currently it's not easy to put new
2570 stuff in the indices. But this is the way to go. Info would be
2575 stuff in the indices. But this is the way to go. Info would be
2571 better, but HTML is every where and not everybody has an info
2576 better, but HTML is every where and not everybody has an info
2572 system installed and it's not so easy to change html-docs to info.
2577 system installed and it's not so easy to change html-docs to info.
2573 --added global logfile option
2578 --added global logfile option
2574 --there is now a hook for object inspection method pinfo needs to
2579 --there is now a hook for object inspection method pinfo needs to
2575 be provided for this. Can be reached by two '??'.
2580 be provided for this. Can be reached by two '??'.
2576
2581
2577 08.05.99 20:51 porto.ifm.uni-kiel.de
2582 08.05.99 20:51 porto.ifm.uni-kiel.de
2578 --added a README
2583 --added a README
2579 --bug in rc file. Something has changed so functions in the rc
2584 --bug in rc file. Something has changed so functions in the rc
2580 file need to reference the shell and not self. Not clear if it's a
2585 file need to reference the shell and not self. Not clear if it's a
2581 bug or feature.
2586 bug or feature.
2582 --changed rc file for new behavior
2587 --changed rc file for new behavior
2583
2588
2584 2004-07-15 Fernando Perez <fperez@colorado.edu>
2589 2004-07-15 Fernando Perez <fperez@colorado.edu>
2585
2590
2586 * IPython/Logger.py (Logger.log): fixed recent bug where the input
2591 * IPython/Logger.py (Logger.log): fixed recent bug where the input
2587 cache was falling out of sync in bizarre manners when multi-line
2592 cache was falling out of sync in bizarre manners when multi-line
2588 input was present. Minor optimizations and cleanup.
2593 input was present. Minor optimizations and cleanup.
2589
2594
2590 (Logger): Remove old Changelog info for cleanup. This is the
2595 (Logger): Remove old Changelog info for cleanup. This is the
2591 information which was there from Janko's original code:
2596 information which was there from Janko's original code:
2592
2597
2593 Changes to Logger: - made the default log filename a parameter
2598 Changes to Logger: - made the default log filename a parameter
2594
2599
2595 - put a check for lines beginning with !@? in log(). Needed
2600 - put a check for lines beginning with !@? in log(). Needed
2596 (even if the handlers properly log their lines) for mid-session
2601 (even if the handlers properly log their lines) for mid-session
2597 logging activation to work properly. Without this, lines logged
2602 logging activation to work properly. Without this, lines logged
2598 in mid session, which get read from the cache, would end up
2603 in mid session, which get read from the cache, would end up
2599 'bare' (with !@? in the open) in the log. Now they are caught
2604 'bare' (with !@? in the open) in the log. Now they are caught
2600 and prepended with a #.
2605 and prepended with a #.
2601
2606
2602 * IPython/iplib.py (InteractiveShell.init_readline): added check
2607 * IPython/iplib.py (InteractiveShell.init_readline): added check
2603 in case MagicCompleter fails to be defined, so we don't crash.
2608 in case MagicCompleter fails to be defined, so we don't crash.
2604
2609
2605 2004-07-13 Fernando Perez <fperez@colorado.edu>
2610 2004-07-13 Fernando Perez <fperez@colorado.edu>
2606
2611
2607 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
2612 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
2608 of EPS if the requested filename ends in '.eps'.
2613 of EPS if the requested filename ends in '.eps'.
2609
2614
2610 2004-07-04 Fernando Perez <fperez@colorado.edu>
2615 2004-07-04 Fernando Perez <fperez@colorado.edu>
2611
2616
2612 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
2617 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
2613 escaping of quotes when calling the shell.
2618 escaping of quotes when calling the shell.
2614
2619
2615 2004-07-02 Fernando Perez <fperez@colorado.edu>
2620 2004-07-02 Fernando Perez <fperez@colorado.edu>
2616
2621
2617 * IPython/Prompts.py (CachedOutput.update): Fix problem with
2622 * IPython/Prompts.py (CachedOutput.update): Fix problem with
2618 gettext not working because we were clobbering '_'. Fixes
2623 gettext not working because we were clobbering '_'. Fixes
2619 http://www.scipy.net/roundup/ipython/issue6.
2624 http://www.scipy.net/roundup/ipython/issue6.
2620
2625
2621 2004-07-01 Fernando Perez <fperez@colorado.edu>
2626 2004-07-01 Fernando Perez <fperez@colorado.edu>
2622
2627
2623 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
2628 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
2624 into @cd. Patch by Ville.
2629 into @cd. Patch by Ville.
2625
2630
2626 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2631 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2627 new function to store things after ipmaker runs. Patch by Ville.
2632 new function to store things after ipmaker runs. Patch by Ville.
2628 Eventually this will go away once ipmaker is removed and the class
2633 Eventually this will go away once ipmaker is removed and the class
2629 gets cleaned up, but for now it's ok. Key functionality here is
2634 gets cleaned up, but for now it's ok. Key functionality here is
2630 the addition of the persistent storage mechanism, a dict for
2635 the addition of the persistent storage mechanism, a dict for
2631 keeping data across sessions (for now just bookmarks, but more can
2636 keeping data across sessions (for now just bookmarks, but more can
2632 be implemented later).
2637 be implemented later).
2633
2638
2634 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
2639 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
2635 persistent across sections. Patch by Ville, I modified it
2640 persistent across sections. Patch by Ville, I modified it
2636 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
2641 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
2637 added a '-l' option to list all bookmarks.
2642 added a '-l' option to list all bookmarks.
2638
2643
2639 * IPython/iplib.py (InteractiveShell.atexit_operations): new
2644 * IPython/iplib.py (InteractiveShell.atexit_operations): new
2640 center for cleanup. Registered with atexit.register(). I moved
2645 center for cleanup. Registered with atexit.register(). I moved
2641 here the old exit_cleanup(). After a patch by Ville.
2646 here the old exit_cleanup(). After a patch by Ville.
2642
2647
2643 * IPython/Magic.py (get_py_filename): added '~' to the accepted
2648 * IPython/Magic.py (get_py_filename): added '~' to the accepted
2644 characters in the hacked shlex_split for python 2.2.
2649 characters in the hacked shlex_split for python 2.2.
2645
2650
2646 * IPython/iplib.py (file_matches): more fixes to filenames with
2651 * IPython/iplib.py (file_matches): more fixes to filenames with
2647 whitespace in them. It's not perfect, but limitations in python's
2652 whitespace in them. It's not perfect, but limitations in python's
2648 readline make it impossible to go further.
2653 readline make it impossible to go further.
2649
2654
2650 2004-06-29 Fernando Perez <fperez@colorado.edu>
2655 2004-06-29 Fernando Perez <fperez@colorado.edu>
2651
2656
2652 * IPython/iplib.py (file_matches): escape whitespace correctly in
2657 * IPython/iplib.py (file_matches): escape whitespace correctly in
2653 filename completions. Bug reported by Ville.
2658 filename completions. Bug reported by Ville.
2654
2659
2655 2004-06-28 Fernando Perez <fperez@colorado.edu>
2660 2004-06-28 Fernando Perez <fperez@colorado.edu>
2656
2661
2657 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
2662 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
2658 the history file will be called 'history-PROFNAME' (or just
2663 the history file will be called 'history-PROFNAME' (or just
2659 'history' if no profile is loaded). I was getting annoyed at
2664 'history' if no profile is loaded). I was getting annoyed at
2660 getting my Numerical work history clobbered by pysh sessions.
2665 getting my Numerical work history clobbered by pysh sessions.
2661
2666
2662 * IPython/iplib.py (InteractiveShell.__init__): Internal
2667 * IPython/iplib.py (InteractiveShell.__init__): Internal
2663 getoutputerror() function so that we can honor the system_verbose
2668 getoutputerror() function so that we can honor the system_verbose
2664 flag for _all_ system calls. I also added escaping of #
2669 flag for _all_ system calls. I also added escaping of #
2665 characters here to avoid confusing Itpl.
2670 characters here to avoid confusing Itpl.
2666
2671
2667 * IPython/Magic.py (shlex_split): removed call to shell in
2672 * IPython/Magic.py (shlex_split): removed call to shell in
2668 parse_options and replaced it with shlex.split(). The annoying
2673 parse_options and replaced it with shlex.split(). The annoying
2669 part was that in Python 2.2, shlex.split() doesn't exist, so I had
2674 part was that in Python 2.2, shlex.split() doesn't exist, so I had
2670 to backport it from 2.3, with several frail hacks (the shlex
2675 to backport it from 2.3, with several frail hacks (the shlex
2671 module is rather limited in 2.2). Thanks to a suggestion by Ville
2676 module is rather limited in 2.2). Thanks to a suggestion by Ville
2672 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
2677 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
2673 problem.
2678 problem.
2674
2679
2675 (Magic.magic_system_verbose): new toggle to print the actual
2680 (Magic.magic_system_verbose): new toggle to print the actual
2676 system calls made by ipython. Mainly for debugging purposes.
2681 system calls made by ipython. Mainly for debugging purposes.
2677
2682
2678 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
2683 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
2679 doesn't support persistence. Reported (and fix suggested) by
2684 doesn't support persistence. Reported (and fix suggested) by
2680 Travis Caldwell <travis_caldwell2000@yahoo.com>.
2685 Travis Caldwell <travis_caldwell2000@yahoo.com>.
2681
2686
2682 2004-06-26 Fernando Perez <fperez@colorado.edu>
2687 2004-06-26 Fernando Perez <fperez@colorado.edu>
2683
2688
2684 * IPython/Logger.py (Logger.log): fix to handle correctly empty
2689 * IPython/Logger.py (Logger.log): fix to handle correctly empty
2685 continue prompts.
2690 continue prompts.
2686
2691
2687 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
2692 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
2688 function (basically a big docstring) and a few more things here to
2693 function (basically a big docstring) and a few more things here to
2689 speedup startup. pysh.py is now very lightweight. We want because
2694 speedup startup. pysh.py is now very lightweight. We want because
2690 it gets execfile'd, while InterpreterExec gets imported, so
2695 it gets execfile'd, while InterpreterExec gets imported, so
2691 byte-compilation saves time.
2696 byte-compilation saves time.
2692
2697
2693 2004-06-25 Fernando Perez <fperez@colorado.edu>
2698 2004-06-25 Fernando Perez <fperez@colorado.edu>
2694
2699
2695 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
2700 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
2696 -NUM', which was recently broken.
2701 -NUM', which was recently broken.
2697
2702
2698 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
2703 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
2699 in multi-line input (but not !!, which doesn't make sense there).
2704 in multi-line input (but not !!, which doesn't make sense there).
2700
2705
2701 * IPython/UserConfig/ipythonrc: made autoindent on by default.
2706 * IPython/UserConfig/ipythonrc: made autoindent on by default.
2702 It's just too useful, and people can turn it off in the less
2707 It's just too useful, and people can turn it off in the less
2703 common cases where it's a problem.
2708 common cases where it's a problem.
2704
2709
2705 2004-06-24 Fernando Perez <fperez@colorado.edu>
2710 2004-06-24 Fernando Perez <fperez@colorado.edu>
2706
2711
2707 * IPython/iplib.py (InteractiveShell._prefilter): big change -
2712 * IPython/iplib.py (InteractiveShell._prefilter): big change -
2708 special syntaxes (like alias calling) is now allied in multi-line
2713 special syntaxes (like alias calling) is now allied in multi-line
2709 input. This is still _very_ experimental, but it's necessary for
2714 input. This is still _very_ experimental, but it's necessary for
2710 efficient shell usage combining python looping syntax with system
2715 efficient shell usage combining python looping syntax with system
2711 calls. For now it's restricted to aliases, I don't think it
2716 calls. For now it's restricted to aliases, I don't think it
2712 really even makes sense to have this for magics.
2717 really even makes sense to have this for magics.
2713
2718
2714 2004-06-23 Fernando Perez <fperez@colorado.edu>
2719 2004-06-23 Fernando Perez <fperez@colorado.edu>
2715
2720
2716 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
2721 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
2717 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
2722 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
2718
2723
2719 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
2724 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
2720 extensions under Windows (after code sent by Gary Bishop). The
2725 extensions under Windows (after code sent by Gary Bishop). The
2721 extensions considered 'executable' are stored in IPython's rc
2726 extensions considered 'executable' are stored in IPython's rc
2722 structure as win_exec_ext.
2727 structure as win_exec_ext.
2723
2728
2724 * IPython/genutils.py (shell): new function, like system() but
2729 * IPython/genutils.py (shell): new function, like system() but
2725 without return value. Very useful for interactive shell work.
2730 without return value. Very useful for interactive shell work.
2726
2731
2727 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
2732 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
2728 delete aliases.
2733 delete aliases.
2729
2734
2730 * IPython/iplib.py (InteractiveShell.alias_table_update): make
2735 * IPython/iplib.py (InteractiveShell.alias_table_update): make
2731 sure that the alias table doesn't contain python keywords.
2736 sure that the alias table doesn't contain python keywords.
2732
2737
2733 2004-06-21 Fernando Perez <fperez@colorado.edu>
2738 2004-06-21 Fernando Perez <fperez@colorado.edu>
2734
2739
2735 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
2740 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
2736 non-existent items are found in $PATH. Reported by Thorsten.
2741 non-existent items are found in $PATH. Reported by Thorsten.
2737
2742
2738 2004-06-20 Fernando Perez <fperez@colorado.edu>
2743 2004-06-20 Fernando Perez <fperez@colorado.edu>
2739
2744
2740 * IPython/iplib.py (complete): modified the completer so that the
2745 * IPython/iplib.py (complete): modified the completer so that the
2741 order of priorities can be easily changed at runtime.
2746 order of priorities can be easily changed at runtime.
2742
2747
2743 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
2748 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
2744 Modified to auto-execute all lines beginning with '~', '/' or '.'.
2749 Modified to auto-execute all lines beginning with '~', '/' or '.'.
2745
2750
2746 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
2751 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
2747 expand Python variables prepended with $ in all system calls. The
2752 expand Python variables prepended with $ in all system calls. The
2748 same was done to InteractiveShell.handle_shell_escape. Now all
2753 same was done to InteractiveShell.handle_shell_escape. Now all
2749 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
2754 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
2750 expansion of python variables and expressions according to the
2755 expansion of python variables and expressions according to the
2751 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
2756 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
2752
2757
2753 Though PEP-215 has been rejected, a similar (but simpler) one
2758 Though PEP-215 has been rejected, a similar (but simpler) one
2754 seems like it will go into Python 2.4, PEP-292 -
2759 seems like it will go into Python 2.4, PEP-292 -
2755 http://www.python.org/peps/pep-0292.html.
2760 http://www.python.org/peps/pep-0292.html.
2756
2761
2757 I'll keep the full syntax of PEP-215, since IPython has since the
2762 I'll keep the full syntax of PEP-215, since IPython has since the
2758 start used Ka-Ping Yee's reference implementation discussed there
2763 start used Ka-Ping Yee's reference implementation discussed there
2759 (Itpl), and I actually like the powerful semantics it offers.
2764 (Itpl), and I actually like the powerful semantics it offers.
2760
2765
2761 In order to access normal shell variables, the $ has to be escaped
2766 In order to access normal shell variables, the $ has to be escaped
2762 via an extra $. For example:
2767 via an extra $. For example:
2763
2768
2764 In [7]: PATH='a python variable'
2769 In [7]: PATH='a python variable'
2765
2770
2766 In [8]: !echo $PATH
2771 In [8]: !echo $PATH
2767 a python variable
2772 a python variable
2768
2773
2769 In [9]: !echo $$PATH
2774 In [9]: !echo $$PATH
2770 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
2775 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
2771
2776
2772 (Magic.parse_options): escape $ so the shell doesn't evaluate
2777 (Magic.parse_options): escape $ so the shell doesn't evaluate
2773 things prematurely.
2778 things prematurely.
2774
2779
2775 * IPython/iplib.py (InteractiveShell.call_alias): added the
2780 * IPython/iplib.py (InteractiveShell.call_alias): added the
2776 ability for aliases to expand python variables via $.
2781 ability for aliases to expand python variables via $.
2777
2782
2778 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
2783 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
2779 system, now there's a @rehash/@rehashx pair of magics. These work
2784 system, now there's a @rehash/@rehashx pair of magics. These work
2780 like the csh rehash command, and can be invoked at any time. They
2785 like the csh rehash command, and can be invoked at any time. They
2781 build a table of aliases to everything in the user's $PATH
2786 build a table of aliases to everything in the user's $PATH
2782 (@rehash uses everything, @rehashx is slower but only adds
2787 (@rehash uses everything, @rehashx is slower but only adds
2783 executable files). With this, the pysh.py-based shell profile can
2788 executable files). With this, the pysh.py-based shell profile can
2784 now simply call rehash upon startup, and full access to all
2789 now simply call rehash upon startup, and full access to all
2785 programs in the user's path is obtained.
2790 programs in the user's path is obtained.
2786
2791
2787 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
2792 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
2788 functionality is now fully in place. I removed the old dynamic
2793 functionality is now fully in place. I removed the old dynamic
2789 code generation based approach, in favor of a much lighter one
2794 code generation based approach, in favor of a much lighter one
2790 based on a simple dict. The advantage is that this allows me to
2795 based on a simple dict. The advantage is that this allows me to
2791 now have thousands of aliases with negligible cost (unthinkable
2796 now have thousands of aliases with negligible cost (unthinkable
2792 with the old system).
2797 with the old system).
2793
2798
2794 2004-06-19 Fernando Perez <fperez@colorado.edu>
2799 2004-06-19 Fernando Perez <fperez@colorado.edu>
2795
2800
2796 * IPython/iplib.py (__init__): extended MagicCompleter class to
2801 * IPython/iplib.py (__init__): extended MagicCompleter class to
2797 also complete (last in priority) on user aliases.
2802 also complete (last in priority) on user aliases.
2798
2803
2799 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
2804 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
2800 call to eval.
2805 call to eval.
2801 (ItplNS.__init__): Added a new class which functions like Itpl,
2806 (ItplNS.__init__): Added a new class which functions like Itpl,
2802 but allows configuring the namespace for the evaluation to occur
2807 but allows configuring the namespace for the evaluation to occur
2803 in.
2808 in.
2804
2809
2805 2004-06-18 Fernando Perez <fperez@colorado.edu>
2810 2004-06-18 Fernando Perez <fperez@colorado.edu>
2806
2811
2807 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
2812 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
2808 better message when 'exit' or 'quit' are typed (a common newbie
2813 better message when 'exit' or 'quit' are typed (a common newbie
2809 confusion).
2814 confusion).
2810
2815
2811 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
2816 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
2812 check for Windows users.
2817 check for Windows users.
2813
2818
2814 * IPython/iplib.py (InteractiveShell.user_setup): removed
2819 * IPython/iplib.py (InteractiveShell.user_setup): removed
2815 disabling of colors for Windows. I'll test at runtime and issue a
2820 disabling of colors for Windows. I'll test at runtime and issue a
2816 warning if Gary's readline isn't found, as to nudge users to
2821 warning if Gary's readline isn't found, as to nudge users to
2817 download it.
2822 download it.
2818
2823
2819 2004-06-16 Fernando Perez <fperez@colorado.edu>
2824 2004-06-16 Fernando Perez <fperez@colorado.edu>
2820
2825
2821 * IPython/genutils.py (Stream.__init__): changed to print errors
2826 * IPython/genutils.py (Stream.__init__): changed to print errors
2822 to sys.stderr. I had a circular dependency here. Now it's
2827 to sys.stderr. I had a circular dependency here. Now it's
2823 possible to run ipython as IDLE's shell (consider this pre-alpha,
2828 possible to run ipython as IDLE's shell (consider this pre-alpha,
2824 since true stdout things end up in the starting terminal instead
2829 since true stdout things end up in the starting terminal instead
2825 of IDLE's out).
2830 of IDLE's out).
2826
2831
2827 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
2832 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
2828 users who haven't # updated their prompt_in2 definitions. Remove
2833 users who haven't # updated their prompt_in2 definitions. Remove
2829 eventually.
2834 eventually.
2830 (multiple_replace): added credit to original ASPN recipe.
2835 (multiple_replace): added credit to original ASPN recipe.
2831
2836
2832 2004-06-15 Fernando Perez <fperez@colorado.edu>
2837 2004-06-15 Fernando Perez <fperez@colorado.edu>
2833
2838
2834 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
2839 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
2835 list of auto-defined aliases.
2840 list of auto-defined aliases.
2836
2841
2837 2004-06-13 Fernando Perez <fperez@colorado.edu>
2842 2004-06-13 Fernando Perez <fperez@colorado.edu>
2838
2843
2839 * setup.py (scriptfiles): Don't trigger win_post_install unless an
2844 * setup.py (scriptfiles): Don't trigger win_post_install unless an
2840 install was really requested (so setup.py can be used for other
2845 install was really requested (so setup.py can be used for other
2841 things under Windows).
2846 things under Windows).
2842
2847
2843 2004-06-10 Fernando Perez <fperez@colorado.edu>
2848 2004-06-10 Fernando Perez <fperez@colorado.edu>
2844
2849
2845 * IPython/Logger.py (Logger.create_log): Manually remove any old
2850 * IPython/Logger.py (Logger.create_log): Manually remove any old
2846 backup, since os.remove may fail under Windows. Fixes bug
2851 backup, since os.remove may fail under Windows. Fixes bug
2847 reported by Thorsten.
2852 reported by Thorsten.
2848
2853
2849 2004-06-09 Fernando Perez <fperez@colorado.edu>
2854 2004-06-09 Fernando Perez <fperez@colorado.edu>
2850
2855
2851 * examples/example-embed.py: fixed all references to %n (replaced
2856 * examples/example-embed.py: fixed all references to %n (replaced
2852 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
2857 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
2853 for all examples and the manual as well.
2858 for all examples and the manual as well.
2854
2859
2855 2004-06-08 Fernando Perez <fperez@colorado.edu>
2860 2004-06-08 Fernando Perez <fperez@colorado.edu>
2856
2861
2857 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
2862 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
2858 alignment and color management. All 3 prompt subsystems now
2863 alignment and color management. All 3 prompt subsystems now
2859 inherit from BasePrompt.
2864 inherit from BasePrompt.
2860
2865
2861 * tools/release: updates for windows installer build and tag rpms
2866 * tools/release: updates for windows installer build and tag rpms
2862 with python version (since paths are fixed).
2867 with python version (since paths are fixed).
2863
2868
2864 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
2869 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
2865 which will become eventually obsolete. Also fixed the default
2870 which will become eventually obsolete. Also fixed the default
2866 prompt_in2 to use \D, so at least new users start with the correct
2871 prompt_in2 to use \D, so at least new users start with the correct
2867 defaults.
2872 defaults.
2868 WARNING: Users with existing ipythonrc files will need to apply
2873 WARNING: Users with existing ipythonrc files will need to apply
2869 this fix manually!
2874 this fix manually!
2870
2875
2871 * setup.py: make windows installer (.exe). This is finally the
2876 * setup.py: make windows installer (.exe). This is finally the
2872 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
2877 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
2873 which I hadn't included because it required Python 2.3 (or recent
2878 which I hadn't included because it required Python 2.3 (or recent
2874 distutils).
2879 distutils).
2875
2880
2876 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
2881 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
2877 usage of new '\D' escape.
2882 usage of new '\D' escape.
2878
2883
2879 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
2884 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
2880 lacks os.getuid())
2885 lacks os.getuid())
2881 (CachedOutput.set_colors): Added the ability to turn coloring
2886 (CachedOutput.set_colors): Added the ability to turn coloring
2882 on/off with @colors even for manually defined prompt colors. It
2887 on/off with @colors even for manually defined prompt colors. It
2883 uses a nasty global, but it works safely and via the generic color
2888 uses a nasty global, but it works safely and via the generic color
2884 handling mechanism.
2889 handling mechanism.
2885 (Prompt2.__init__): Introduced new escape '\D' for continuation
2890 (Prompt2.__init__): Introduced new escape '\D' for continuation
2886 prompts. It represents the counter ('\#') as dots.
2891 prompts. It represents the counter ('\#') as dots.
2887 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
2892 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
2888 need to update their ipythonrc files and replace '%n' with '\D' in
2893 need to update their ipythonrc files and replace '%n' with '\D' in
2889 their prompt_in2 settings everywhere. Sorry, but there's
2894 their prompt_in2 settings everywhere. Sorry, but there's
2890 otherwise no clean way to get all prompts to properly align. The
2895 otherwise no clean way to get all prompts to properly align. The
2891 ipythonrc shipped with IPython has been updated.
2896 ipythonrc shipped with IPython has been updated.
2892
2897
2893 2004-06-07 Fernando Perez <fperez@colorado.edu>
2898 2004-06-07 Fernando Perez <fperez@colorado.edu>
2894
2899
2895 * setup.py (isfile): Pass local_icons option to latex2html, so the
2900 * setup.py (isfile): Pass local_icons option to latex2html, so the
2896 resulting HTML file is self-contained. Thanks to
2901 resulting HTML file is self-contained. Thanks to
2897 dryice-AT-liu.com.cn for the tip.
2902 dryice-AT-liu.com.cn for the tip.
2898
2903
2899 * pysh.py: I created a new profile 'shell', which implements a
2904 * pysh.py: I created a new profile 'shell', which implements a
2900 _rudimentary_ IPython-based shell. This is in NO WAY a realy
2905 _rudimentary_ IPython-based shell. This is in NO WAY a realy
2901 system shell, nor will it become one anytime soon. It's mainly
2906 system shell, nor will it become one anytime soon. It's mainly
2902 meant to illustrate the use of the new flexible bash-like prompts.
2907 meant to illustrate the use of the new flexible bash-like prompts.
2903 I guess it could be used by hardy souls for true shell management,
2908 I guess it could be used by hardy souls for true shell management,
2904 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
2909 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
2905 profile. This uses the InterpreterExec extension provided by
2910 profile. This uses the InterpreterExec extension provided by
2906 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
2911 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
2907
2912
2908 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
2913 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
2909 auto-align itself with the length of the previous input prompt
2914 auto-align itself with the length of the previous input prompt
2910 (taking into account the invisible color escapes).
2915 (taking into account the invisible color escapes).
2911 (CachedOutput.__init__): Large restructuring of this class. Now
2916 (CachedOutput.__init__): Large restructuring of this class. Now
2912 all three prompts (primary1, primary2, output) are proper objects,
2917 all three prompts (primary1, primary2, output) are proper objects,
2913 managed by the 'parent' CachedOutput class. The code is still a
2918 managed by the 'parent' CachedOutput class. The code is still a
2914 bit hackish (all prompts share state via a pointer to the cache),
2919 bit hackish (all prompts share state via a pointer to the cache),
2915 but it's overall far cleaner than before.
2920 but it's overall far cleaner than before.
2916
2921
2917 * IPython/genutils.py (getoutputerror): modified to add verbose,
2922 * IPython/genutils.py (getoutputerror): modified to add verbose,
2918 debug and header options. This makes the interface of all getout*
2923 debug and header options. This makes the interface of all getout*
2919 functions uniform.
2924 functions uniform.
2920 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
2925 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
2921
2926
2922 * IPython/Magic.py (Magic.default_option): added a function to
2927 * IPython/Magic.py (Magic.default_option): added a function to
2923 allow registering default options for any magic command. This
2928 allow registering default options for any magic command. This
2924 makes it easy to have profiles which customize the magics globally
2929 makes it easy to have profiles which customize the magics globally
2925 for a certain use. The values set through this function are
2930 for a certain use. The values set through this function are
2926 picked up by the parse_options() method, which all magics should
2931 picked up by the parse_options() method, which all magics should
2927 use to parse their options.
2932 use to parse their options.
2928
2933
2929 * IPython/genutils.py (warn): modified the warnings framework to
2934 * IPython/genutils.py (warn): modified the warnings framework to
2930 use the Term I/O class. I'm trying to slowly unify all of
2935 use the Term I/O class. I'm trying to slowly unify all of
2931 IPython's I/O operations to pass through Term.
2936 IPython's I/O operations to pass through Term.
2932
2937
2933 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
2938 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
2934 the secondary prompt to correctly match the length of the primary
2939 the secondary prompt to correctly match the length of the primary
2935 one for any prompt. Now multi-line code will properly line up
2940 one for any prompt. Now multi-line code will properly line up
2936 even for path dependent prompts, such as the new ones available
2941 even for path dependent prompts, such as the new ones available
2937 via the prompt_specials.
2942 via the prompt_specials.
2938
2943
2939 2004-06-06 Fernando Perez <fperez@colorado.edu>
2944 2004-06-06 Fernando Perez <fperez@colorado.edu>
2940
2945
2941 * IPython/Prompts.py (prompt_specials): Added the ability to have
2946 * IPython/Prompts.py (prompt_specials): Added the ability to have
2942 bash-like special sequences in the prompts, which get
2947 bash-like special sequences in the prompts, which get
2943 automatically expanded. Things like hostname, current working
2948 automatically expanded. Things like hostname, current working
2944 directory and username are implemented already, but it's easy to
2949 directory and username are implemented already, but it's easy to
2945 add more in the future. Thanks to a patch by W.J. van der Laan
2950 add more in the future. Thanks to a patch by W.J. van der Laan
2946 <gnufnork-AT-hetdigitalegat.nl>
2951 <gnufnork-AT-hetdigitalegat.nl>
2947 (prompt_specials): Added color support for prompt strings, so
2952 (prompt_specials): Added color support for prompt strings, so
2948 users can define arbitrary color setups for their prompts.
2953 users can define arbitrary color setups for their prompts.
2949
2954
2950 2004-06-05 Fernando Perez <fperez@colorado.edu>
2955 2004-06-05 Fernando Perez <fperez@colorado.edu>
2951
2956
2952 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
2957 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
2953 code to load Gary Bishop's readline and configure it
2958 code to load Gary Bishop's readline and configure it
2954 automatically. Thanks to Gary for help on this.
2959 automatically. Thanks to Gary for help on this.
2955
2960
2956 2004-06-01 Fernando Perez <fperez@colorado.edu>
2961 2004-06-01 Fernando Perez <fperez@colorado.edu>
2957
2962
2958 * IPython/Logger.py (Logger.create_log): fix bug for logging
2963 * IPython/Logger.py (Logger.create_log): fix bug for logging
2959 with no filename (previous fix was incomplete).
2964 with no filename (previous fix was incomplete).
2960
2965
2961 2004-05-25 Fernando Perez <fperez@colorado.edu>
2966 2004-05-25 Fernando Perez <fperez@colorado.edu>
2962
2967
2963 * IPython/Magic.py (Magic.parse_options): fix bug where naked
2968 * IPython/Magic.py (Magic.parse_options): fix bug where naked
2964 parens would get passed to the shell.
2969 parens would get passed to the shell.
2965
2970
2966 2004-05-20 Fernando Perez <fperez@colorado.edu>
2971 2004-05-20 Fernando Perez <fperez@colorado.edu>
2967
2972
2968 * IPython/Magic.py (Magic.magic_prun): changed default profile
2973 * IPython/Magic.py (Magic.magic_prun): changed default profile
2969 sort order to 'time' (the more common profiling need).
2974 sort order to 'time' (the more common profiling need).
2970
2975
2971 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
2976 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
2972 so that source code shown is guaranteed in sync with the file on
2977 so that source code shown is guaranteed in sync with the file on
2973 disk (also changed in psource). Similar fix to the one for
2978 disk (also changed in psource). Similar fix to the one for
2974 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
2979 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
2975 <yann.ledu-AT-noos.fr>.
2980 <yann.ledu-AT-noos.fr>.
2976
2981
2977 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
2982 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
2978 with a single option would not be correctly parsed. Closes
2983 with a single option would not be correctly parsed. Closes
2979 http://www.scipy.net/roundup/ipython/issue14. This bug had been
2984 http://www.scipy.net/roundup/ipython/issue14. This bug had been
2980 introduced in 0.6.0 (on 2004-05-06).
2985 introduced in 0.6.0 (on 2004-05-06).
2981
2986
2982 2004-05-13 *** Released version 0.6.0
2987 2004-05-13 *** Released version 0.6.0
2983
2988
2984 2004-05-13 Fernando Perez <fperez@colorado.edu>
2989 2004-05-13 Fernando Perez <fperez@colorado.edu>
2985
2990
2986 * debian/: Added debian/ directory to CVS, so that debian support
2991 * debian/: Added debian/ directory to CVS, so that debian support
2987 is publicly accessible. The debian package is maintained by Jack
2992 is publicly accessible. The debian package is maintained by Jack
2988 Moffit <jack-AT-xiph.org>.
2993 Moffit <jack-AT-xiph.org>.
2989
2994
2990 * Documentation: included the notes about an ipython-based system
2995 * Documentation: included the notes about an ipython-based system
2991 shell (the hypothetical 'pysh') into the new_design.pdf document,
2996 shell (the hypothetical 'pysh') into the new_design.pdf document,
2992 so that these ideas get distributed to users along with the
2997 so that these ideas get distributed to users along with the
2993 official documentation.
2998 official documentation.
2994
2999
2995 2004-05-10 Fernando Perez <fperez@colorado.edu>
3000 2004-05-10 Fernando Perez <fperez@colorado.edu>
2996
3001
2997 * IPython/Logger.py (Logger.create_log): fix recently introduced
3002 * IPython/Logger.py (Logger.create_log): fix recently introduced
2998 bug (misindented line) where logstart would fail when not given an
3003 bug (misindented line) where logstart would fail when not given an
2999 explicit filename.
3004 explicit filename.
3000
3005
3001 2004-05-09 Fernando Perez <fperez@colorado.edu>
3006 2004-05-09 Fernando Perez <fperez@colorado.edu>
3002
3007
3003 * IPython/Magic.py (Magic.parse_options): skip system call when
3008 * IPython/Magic.py (Magic.parse_options): skip system call when
3004 there are no options to look for. Faster, cleaner for the common
3009 there are no options to look for. Faster, cleaner for the common
3005 case.
3010 case.
3006
3011
3007 * Documentation: many updates to the manual: describing Windows
3012 * Documentation: many updates to the manual: describing Windows
3008 support better, Gnuplot updates, credits, misc small stuff. Also
3013 support better, Gnuplot updates, credits, misc small stuff. Also
3009 updated the new_design doc a bit.
3014 updated the new_design doc a bit.
3010
3015
3011 2004-05-06 *** Released version 0.6.0.rc1
3016 2004-05-06 *** Released version 0.6.0.rc1
3012
3017
3013 2004-05-06 Fernando Perez <fperez@colorado.edu>
3018 2004-05-06 Fernando Perez <fperez@colorado.edu>
3014
3019
3015 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
3020 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
3016 operations to use the vastly more efficient list/''.join() method.
3021 operations to use the vastly more efficient list/''.join() method.
3017 (FormattedTB.text): Fix
3022 (FormattedTB.text): Fix
3018 http://www.scipy.net/roundup/ipython/issue12 - exception source
3023 http://www.scipy.net/roundup/ipython/issue12 - exception source
3019 extract not updated after reload. Thanks to Mike Salib
3024 extract not updated after reload. Thanks to Mike Salib
3020 <msalib-AT-mit.edu> for pinning the source of the problem.
3025 <msalib-AT-mit.edu> for pinning the source of the problem.
3021 Fortunately, the solution works inside ipython and doesn't require
3026 Fortunately, the solution works inside ipython and doesn't require
3022 any changes to python proper.
3027 any changes to python proper.
3023
3028
3024 * IPython/Magic.py (Magic.parse_options): Improved to process the
3029 * IPython/Magic.py (Magic.parse_options): Improved to process the
3025 argument list as a true shell would (by actually using the
3030 argument list as a true shell would (by actually using the
3026 underlying system shell). This way, all @magics automatically get
3031 underlying system shell). This way, all @magics automatically get
3027 shell expansion for variables. Thanks to a comment by Alex
3032 shell expansion for variables. Thanks to a comment by Alex
3028 Schmolck.
3033 Schmolck.
3029
3034
3030 2004-04-04 Fernando Perez <fperez@colorado.edu>
3035 2004-04-04 Fernando Perez <fperez@colorado.edu>
3031
3036
3032 * IPython/iplib.py (InteractiveShell.interact): Added a special
3037 * IPython/iplib.py (InteractiveShell.interact): Added a special
3033 trap for a debugger quit exception, which is basically impossible
3038 trap for a debugger quit exception, which is basically impossible
3034 to handle by normal mechanisms, given what pdb does to the stack.
3039 to handle by normal mechanisms, given what pdb does to the stack.
3035 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
3040 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
3036
3041
3037 2004-04-03 Fernando Perez <fperez@colorado.edu>
3042 2004-04-03 Fernando Perez <fperez@colorado.edu>
3038
3043
3039 * IPython/genutils.py (Term): Standardized the names of the Term
3044 * IPython/genutils.py (Term): Standardized the names of the Term
3040 class streams to cin/cout/cerr, following C++ naming conventions
3045 class streams to cin/cout/cerr, following C++ naming conventions
3041 (I can't use in/out/err because 'in' is not a valid attribute
3046 (I can't use in/out/err because 'in' is not a valid attribute
3042 name).
3047 name).
3043
3048
3044 * IPython/iplib.py (InteractiveShell.interact): don't increment
3049 * IPython/iplib.py (InteractiveShell.interact): don't increment
3045 the prompt if there's no user input. By Daniel 'Dang' Griffith
3050 the prompt if there's no user input. By Daniel 'Dang' Griffith
3046 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
3051 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
3047 Francois Pinard.
3052 Francois Pinard.
3048
3053
3049 2004-04-02 Fernando Perez <fperez@colorado.edu>
3054 2004-04-02 Fernando Perez <fperez@colorado.edu>
3050
3055
3051 * IPython/genutils.py (Stream.__init__): Modified to survive at
3056 * IPython/genutils.py (Stream.__init__): Modified to survive at
3052 least importing in contexts where stdin/out/err aren't true file
3057 least importing in contexts where stdin/out/err aren't true file
3053 objects, such as PyCrust (they lack fileno() and mode). However,
3058 objects, such as PyCrust (they lack fileno() and mode). However,
3054 the recovery facilities which rely on these things existing will
3059 the recovery facilities which rely on these things existing will
3055 not work.
3060 not work.
3056
3061
3057 2004-04-01 Fernando Perez <fperez@colorado.edu>
3062 2004-04-01 Fernando Perez <fperez@colorado.edu>
3058
3063
3059 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
3064 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
3060 use the new getoutputerror() function, so it properly
3065 use the new getoutputerror() function, so it properly
3061 distinguishes stdout/err.
3066 distinguishes stdout/err.
3062
3067
3063 * IPython/genutils.py (getoutputerror): added a function to
3068 * IPython/genutils.py (getoutputerror): added a function to
3064 capture separately the standard output and error of a command.
3069 capture separately the standard output and error of a command.
3065 After a comment from dang on the mailing lists. This code is
3070 After a comment from dang on the mailing lists. This code is
3066 basically a modified version of commands.getstatusoutput(), from
3071 basically a modified version of commands.getstatusoutput(), from
3067 the standard library.
3072 the standard library.
3068
3073
3069 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
3074 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
3070 '!!' as a special syntax (shorthand) to access @sx.
3075 '!!' as a special syntax (shorthand) to access @sx.
3071
3076
3072 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
3077 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
3073 command and return its output as a list split on '\n'.
3078 command and return its output as a list split on '\n'.
3074
3079
3075 2004-03-31 Fernando Perez <fperez@colorado.edu>
3080 2004-03-31 Fernando Perez <fperez@colorado.edu>
3076
3081
3077 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
3082 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
3078 method to dictionaries used as FakeModule instances if they lack
3083 method to dictionaries used as FakeModule instances if they lack
3079 it. At least pydoc in python2.3 breaks for runtime-defined
3084 it. At least pydoc in python2.3 breaks for runtime-defined
3080 functions without this hack. At some point I need to _really_
3085 functions without this hack. At some point I need to _really_
3081 understand what FakeModule is doing, because it's a gross hack.
3086 understand what FakeModule is doing, because it's a gross hack.
3082 But it solves Arnd's problem for now...
3087 But it solves Arnd's problem for now...
3083
3088
3084 2004-02-27 Fernando Perez <fperez@colorado.edu>
3089 2004-02-27 Fernando Perez <fperez@colorado.edu>
3085
3090
3086 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
3091 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
3087 mode would behave erratically. Also increased the number of
3092 mode would behave erratically. Also increased the number of
3088 possible logs in rotate mod to 999. Thanks to Rod Holland
3093 possible logs in rotate mod to 999. Thanks to Rod Holland
3089 <rhh@StructureLABS.com> for the report and fixes.
3094 <rhh@StructureLABS.com> for the report and fixes.
3090
3095
3091 2004-02-26 Fernando Perez <fperez@colorado.edu>
3096 2004-02-26 Fernando Perez <fperez@colorado.edu>
3092
3097
3093 * IPython/genutils.py (page): Check that the curses module really
3098 * IPython/genutils.py (page): Check that the curses module really
3094 has the initscr attribute before trying to use it. For some
3099 has the initscr attribute before trying to use it. For some
3095 reason, the Solaris curses module is missing this. I think this
3100 reason, the Solaris curses module is missing this. I think this
3096 should be considered a Solaris python bug, but I'm not sure.
3101 should be considered a Solaris python bug, but I'm not sure.
3097
3102
3098 2004-01-17 Fernando Perez <fperez@colorado.edu>
3103 2004-01-17 Fernando Perez <fperez@colorado.edu>
3099
3104
3100 * IPython/genutils.py (Stream.__init__): Changes to try to make
3105 * IPython/genutils.py (Stream.__init__): Changes to try to make
3101 ipython robust against stdin/out/err being closed by the user.
3106 ipython robust against stdin/out/err being closed by the user.
3102 This is 'user error' (and blocks a normal python session, at least
3107 This is 'user error' (and blocks a normal python session, at least
3103 the stdout case). However, Ipython should be able to survive such
3108 the stdout case). However, Ipython should be able to survive such
3104 instances of abuse as gracefully as possible. To simplify the
3109 instances of abuse as gracefully as possible. To simplify the
3105 coding and maintain compatibility with Gary Bishop's Term
3110 coding and maintain compatibility with Gary Bishop's Term
3106 contributions, I've made use of classmethods for this. I think
3111 contributions, I've made use of classmethods for this. I think
3107 this introduces a dependency on python 2.2.
3112 this introduces a dependency on python 2.2.
3108
3113
3109 2004-01-13 Fernando Perez <fperez@colorado.edu>
3114 2004-01-13 Fernando Perez <fperez@colorado.edu>
3110
3115
3111 * IPython/numutils.py (exp_safe): simplified the code a bit and
3116 * IPython/numutils.py (exp_safe): simplified the code a bit and
3112 removed the need for importing the kinds module altogether.
3117 removed the need for importing the kinds module altogether.
3113
3118
3114 2004-01-06 Fernando Perez <fperez@colorado.edu>
3119 2004-01-06 Fernando Perez <fperez@colorado.edu>
3115
3120
3116 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
3121 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
3117 a magic function instead, after some community feedback. No
3122 a magic function instead, after some community feedback. No
3118 special syntax will exist for it, but its name is deliberately
3123 special syntax will exist for it, but its name is deliberately
3119 very short.
3124 very short.
3120
3125
3121 2003-12-20 Fernando Perez <fperez@colorado.edu>
3126 2003-12-20 Fernando Perez <fperez@colorado.edu>
3122
3127
3123 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
3128 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
3124 new functionality, to automagically assign the result of a shell
3129 new functionality, to automagically assign the result of a shell
3125 command to a variable. I'll solicit some community feedback on
3130 command to a variable. I'll solicit some community feedback on
3126 this before making it permanent.
3131 this before making it permanent.
3127
3132
3128 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
3133 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
3129 requested about callables for which inspect couldn't obtain a
3134 requested about callables for which inspect couldn't obtain a
3130 proper argspec. Thanks to a crash report sent by Etienne
3135 proper argspec. Thanks to a crash report sent by Etienne
3131 Posthumus <etienne-AT-apple01.cs.vu.nl>.
3136 Posthumus <etienne-AT-apple01.cs.vu.nl>.
3132
3137
3133 2003-12-09 Fernando Perez <fperez@colorado.edu>
3138 2003-12-09 Fernando Perez <fperez@colorado.edu>
3134
3139
3135 * IPython/genutils.py (page): patch for the pager to work across
3140 * IPython/genutils.py (page): patch for the pager to work across
3136 various versions of Windows. By Gary Bishop.
3141 various versions of Windows. By Gary Bishop.
3137
3142
3138 2003-12-04 Fernando Perez <fperez@colorado.edu>
3143 2003-12-04 Fernando Perez <fperez@colorado.edu>
3139
3144
3140 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
3145 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
3141 Gnuplot.py version 1.7, whose internal names changed quite a bit.
3146 Gnuplot.py version 1.7, whose internal names changed quite a bit.
3142 While I tested this and it looks ok, there may still be corner
3147 While I tested this and it looks ok, there may still be corner
3143 cases I've missed.
3148 cases I've missed.
3144
3149
3145 2003-12-01 Fernando Perez <fperez@colorado.edu>
3150 2003-12-01 Fernando Perez <fperez@colorado.edu>
3146
3151
3147 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
3152 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
3148 where a line like 'p,q=1,2' would fail because the automagic
3153 where a line like 'p,q=1,2' would fail because the automagic
3149 system would be triggered for @p.
3154 system would be triggered for @p.
3150
3155
3151 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
3156 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
3152 cleanups, code unmodified.
3157 cleanups, code unmodified.
3153
3158
3154 * IPython/genutils.py (Term): added a class for IPython to handle
3159 * IPython/genutils.py (Term): added a class for IPython to handle
3155 output. In most cases it will just be a proxy for stdout/err, but
3160 output. In most cases it will just be a proxy for stdout/err, but
3156 having this allows modifications to be made for some platforms,
3161 having this allows modifications to be made for some platforms,
3157 such as handling color escapes under Windows. All of this code
3162 such as handling color escapes under Windows. All of this code
3158 was contributed by Gary Bishop, with minor modifications by me.
3163 was contributed by Gary Bishop, with minor modifications by me.
3159 The actual changes affect many files.
3164 The actual changes affect many files.
3160
3165
3161 2003-11-30 Fernando Perez <fperez@colorado.edu>
3166 2003-11-30 Fernando Perez <fperez@colorado.edu>
3162
3167
3163 * IPython/iplib.py (file_matches): new completion code, courtesy
3168 * IPython/iplib.py (file_matches): new completion code, courtesy
3164 of Jeff Collins. This enables filename completion again under
3169 of Jeff Collins. This enables filename completion again under
3165 python 2.3, which disabled it at the C level.
3170 python 2.3, which disabled it at the C level.
3166
3171
3167 2003-11-11 Fernando Perez <fperez@colorado.edu>
3172 2003-11-11 Fernando Perez <fperez@colorado.edu>
3168
3173
3169 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
3174 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
3170 for Numeric.array(map(...)), but often convenient.
3175 for Numeric.array(map(...)), but often convenient.
3171
3176
3172 2003-11-05 Fernando Perez <fperez@colorado.edu>
3177 2003-11-05 Fernando Perez <fperez@colorado.edu>
3173
3178
3174 * IPython/numutils.py (frange): Changed a call from int() to
3179 * IPython/numutils.py (frange): Changed a call from int() to
3175 int(round()) to prevent a problem reported with arange() in the
3180 int(round()) to prevent a problem reported with arange() in the
3176 numpy list.
3181 numpy list.
3177
3182
3178 2003-10-06 Fernando Perez <fperez@colorado.edu>
3183 2003-10-06 Fernando Perez <fperez@colorado.edu>
3179
3184
3180 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
3185 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
3181 prevent crashes if sys lacks an argv attribute (it happens with
3186 prevent crashes if sys lacks an argv attribute (it happens with
3182 embedded interpreters which build a bare-bones sys module).
3187 embedded interpreters which build a bare-bones sys module).
3183 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
3188 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
3184
3189
3185 2003-09-24 Fernando Perez <fperez@colorado.edu>
3190 2003-09-24 Fernando Perez <fperez@colorado.edu>
3186
3191
3187 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
3192 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
3188 to protect against poorly written user objects where __getattr__
3193 to protect against poorly written user objects where __getattr__
3189 raises exceptions other than AttributeError. Thanks to a bug
3194 raises exceptions other than AttributeError. Thanks to a bug
3190 report by Oliver Sander <osander-AT-gmx.de>.
3195 report by Oliver Sander <osander-AT-gmx.de>.
3191
3196
3192 * IPython/FakeModule.py (FakeModule.__repr__): this method was
3197 * IPython/FakeModule.py (FakeModule.__repr__): this method was
3193 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
3198 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
3194
3199
3195 2003-09-09 Fernando Perez <fperez@colorado.edu>
3200 2003-09-09 Fernando Perez <fperez@colorado.edu>
3196
3201
3197 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3202 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3198 unpacking a list whith a callable as first element would
3203 unpacking a list whith a callable as first element would
3199 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
3204 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
3200 Collins.
3205 Collins.
3201
3206
3202 2003-08-25 *** Released version 0.5.0
3207 2003-08-25 *** Released version 0.5.0
3203
3208
3204 2003-08-22 Fernando Perez <fperez@colorado.edu>
3209 2003-08-22 Fernando Perez <fperez@colorado.edu>
3205
3210
3206 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
3211 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
3207 improperly defined user exceptions. Thanks to feedback from Mark
3212 improperly defined user exceptions. Thanks to feedback from Mark
3208 Russell <mrussell-AT-verio.net>.
3213 Russell <mrussell-AT-verio.net>.
3209
3214
3210 2003-08-20 Fernando Perez <fperez@colorado.edu>
3215 2003-08-20 Fernando Perez <fperez@colorado.edu>
3211
3216
3212 * IPython/OInspect.py (Inspector.pinfo): changed String Form
3217 * IPython/OInspect.py (Inspector.pinfo): changed String Form
3213 printing so that it would print multi-line string forms starting
3218 printing so that it would print multi-line string forms starting
3214 with a new line. This way the formatting is better respected for
3219 with a new line. This way the formatting is better respected for
3215 objects which work hard to make nice string forms.
3220 objects which work hard to make nice string forms.
3216
3221
3217 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
3222 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
3218 autocall would overtake data access for objects with both
3223 autocall would overtake data access for objects with both
3219 __getitem__ and __call__.
3224 __getitem__ and __call__.
3220
3225
3221 2003-08-19 *** Released version 0.5.0-rc1
3226 2003-08-19 *** Released version 0.5.0-rc1
3222
3227
3223 2003-08-19 Fernando Perez <fperez@colorado.edu>
3228 2003-08-19 Fernando Perez <fperez@colorado.edu>
3224
3229
3225 * IPython/deep_reload.py (load_tail): single tiny change here
3230 * IPython/deep_reload.py (load_tail): single tiny change here
3226 seems to fix the long-standing bug of dreload() failing to work
3231 seems to fix the long-standing bug of dreload() failing to work
3227 for dotted names. But this module is pretty tricky, so I may have
3232 for dotted names. But this module is pretty tricky, so I may have
3228 missed some subtlety. Needs more testing!.
3233 missed some subtlety. Needs more testing!.
3229
3234
3230 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
3235 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
3231 exceptions which have badly implemented __str__ methods.
3236 exceptions which have badly implemented __str__ methods.
3232 (VerboseTB.text): harden against inspect.getinnerframes crashing,
3237 (VerboseTB.text): harden against inspect.getinnerframes crashing,
3233 which I've been getting reports about from Python 2.3 users. I
3238 which I've been getting reports about from Python 2.3 users. I
3234 wish I had a simple test case to reproduce the problem, so I could
3239 wish I had a simple test case to reproduce the problem, so I could
3235 either write a cleaner workaround or file a bug report if
3240 either write a cleaner workaround or file a bug report if
3236 necessary.
3241 necessary.
3237
3242
3238 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
3243 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
3239 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
3244 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
3240 a bug report by Tjabo Kloppenburg.
3245 a bug report by Tjabo Kloppenburg.
3241
3246
3242 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
3247 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
3243 crashes. Wrapped the pdb call in a blanket try/except, since pdb
3248 crashes. Wrapped the pdb call in a blanket try/except, since pdb
3244 seems rather unstable. Thanks to a bug report by Tjabo
3249 seems rather unstable. Thanks to a bug report by Tjabo
3245 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
3250 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
3246
3251
3247 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
3252 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
3248 this out soon because of the critical fixes in the inner loop for
3253 this out soon because of the critical fixes in the inner loop for
3249 generators.
3254 generators.
3250
3255
3251 * IPython/Magic.py (Magic.getargspec): removed. This (and
3256 * IPython/Magic.py (Magic.getargspec): removed. This (and
3252 _get_def) have been obsoleted by OInspect for a long time, I
3257 _get_def) have been obsoleted by OInspect for a long time, I
3253 hadn't noticed that they were dead code.
3258 hadn't noticed that they were dead code.
3254 (Magic._ofind): restored _ofind functionality for a few literals
3259 (Magic._ofind): restored _ofind functionality for a few literals
3255 (those in ["''",'""','[]','{}','()']). But it won't work anymore
3260 (those in ["''",'""','[]','{}','()']). But it won't work anymore
3256 for things like "hello".capitalize?, since that would require a
3261 for things like "hello".capitalize?, since that would require a
3257 potentially dangerous eval() again.
3262 potentially dangerous eval() again.
3258
3263
3259 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
3264 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
3260 logic a bit more to clean up the escapes handling and minimize the
3265 logic a bit more to clean up the escapes handling and minimize the
3261 use of _ofind to only necessary cases. The interactive 'feel' of
3266 use of _ofind to only necessary cases. The interactive 'feel' of
3262 IPython should have improved quite a bit with the changes in
3267 IPython should have improved quite a bit with the changes in
3263 _prefilter and _ofind (besides being far safer than before).
3268 _prefilter and _ofind (besides being far safer than before).
3264
3269
3265 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
3270 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
3266 obscure, never reported). Edit would fail to find the object to
3271 obscure, never reported). Edit would fail to find the object to
3267 edit under some circumstances.
3272 edit under some circumstances.
3268 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
3273 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
3269 which were causing double-calling of generators. Those eval calls
3274 which were causing double-calling of generators. Those eval calls
3270 were _very_ dangerous, since code with side effects could be
3275 were _very_ dangerous, since code with side effects could be
3271 triggered. As they say, 'eval is evil'... These were the
3276 triggered. As they say, 'eval is evil'... These were the
3272 nastiest evals in IPython. Besides, _ofind is now far simpler,
3277 nastiest evals in IPython. Besides, _ofind is now far simpler,
3273 and it should also be quite a bit faster. Its use of inspect is
3278 and it should also be quite a bit faster. Its use of inspect is
3274 also safer, so perhaps some of the inspect-related crashes I've
3279 also safer, so perhaps some of the inspect-related crashes I've
3275 seen lately with Python 2.3 might be taken care of. That will
3280 seen lately with Python 2.3 might be taken care of. That will
3276 need more testing.
3281 need more testing.
3277
3282
3278 2003-08-17 Fernando Perez <fperez@colorado.edu>
3283 2003-08-17 Fernando Perez <fperez@colorado.edu>
3279
3284
3280 * IPython/iplib.py (InteractiveShell._prefilter): significant
3285 * IPython/iplib.py (InteractiveShell._prefilter): significant
3281 simplifications to the logic for handling user escapes. Faster
3286 simplifications to the logic for handling user escapes. Faster
3282 and simpler code.
3287 and simpler code.
3283
3288
3284 2003-08-14 Fernando Perez <fperez@colorado.edu>
3289 2003-08-14 Fernando Perez <fperez@colorado.edu>
3285
3290
3286 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
3291 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
3287 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
3292 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
3288 but it should be quite a bit faster. And the recursive version
3293 but it should be quite a bit faster. And the recursive version
3289 generated O(log N) intermediate storage for all rank>1 arrays,
3294 generated O(log N) intermediate storage for all rank>1 arrays,
3290 even if they were contiguous.
3295 even if they were contiguous.
3291 (l1norm): Added this function.
3296 (l1norm): Added this function.
3292 (norm): Added this function for arbitrary norms (including
3297 (norm): Added this function for arbitrary norms (including
3293 l-infinity). l1 and l2 are still special cases for convenience
3298 l-infinity). l1 and l2 are still special cases for convenience
3294 and speed.
3299 and speed.
3295
3300
3296 2003-08-03 Fernando Perez <fperez@colorado.edu>
3301 2003-08-03 Fernando Perez <fperez@colorado.edu>
3297
3302
3298 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
3303 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
3299 exceptions, which now raise PendingDeprecationWarnings in Python
3304 exceptions, which now raise PendingDeprecationWarnings in Python
3300 2.3. There were some in Magic and some in Gnuplot2.
3305 2.3. There were some in Magic and some in Gnuplot2.
3301
3306
3302 2003-06-30 Fernando Perez <fperez@colorado.edu>
3307 2003-06-30 Fernando Perez <fperez@colorado.edu>
3303
3308
3304 * IPython/genutils.py (page): modified to call curses only for
3309 * IPython/genutils.py (page): modified to call curses only for
3305 terminals where TERM=='xterm'. After problems under many other
3310 terminals where TERM=='xterm'. After problems under many other
3306 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
3311 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
3307
3312
3308 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
3313 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
3309 would be triggered when readline was absent. This was just an old
3314 would be triggered when readline was absent. This was just an old
3310 debugging statement I'd forgotten to take out.
3315 debugging statement I'd forgotten to take out.
3311
3316
3312 2003-06-20 Fernando Perez <fperez@colorado.edu>
3317 2003-06-20 Fernando Perez <fperez@colorado.edu>
3313
3318
3314 * IPython/genutils.py (clock): modified to return only user time
3319 * IPython/genutils.py (clock): modified to return only user time
3315 (not counting system time), after a discussion on scipy. While
3320 (not counting system time), after a discussion on scipy. While
3316 system time may be a useful quantity occasionally, it may much
3321 system time may be a useful quantity occasionally, it may much
3317 more easily be skewed by occasional swapping or other similar
3322 more easily be skewed by occasional swapping or other similar
3318 activity.
3323 activity.
3319
3324
3320 2003-06-05 Fernando Perez <fperez@colorado.edu>
3325 2003-06-05 Fernando Perez <fperez@colorado.edu>
3321
3326
3322 * IPython/numutils.py (identity): new function, for building
3327 * IPython/numutils.py (identity): new function, for building
3323 arbitrary rank Kronecker deltas (mostly backwards compatible with
3328 arbitrary rank Kronecker deltas (mostly backwards compatible with
3324 Numeric.identity)
3329 Numeric.identity)
3325
3330
3326 2003-06-03 Fernando Perez <fperez@colorado.edu>
3331 2003-06-03 Fernando Perez <fperez@colorado.edu>
3327
3332
3328 * IPython/iplib.py (InteractiveShell.handle_magic): protect
3333 * IPython/iplib.py (InteractiveShell.handle_magic): protect
3329 arguments passed to magics with spaces, to allow trailing '\' to
3334 arguments passed to magics with spaces, to allow trailing '\' to
3330 work normally (mainly for Windows users).
3335 work normally (mainly for Windows users).
3331
3336
3332 2003-05-29 Fernando Perez <fperez@colorado.edu>
3337 2003-05-29 Fernando Perez <fperez@colorado.edu>
3333
3338
3334 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
3339 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
3335 instead of pydoc.help. This fixes a bizarre behavior where
3340 instead of pydoc.help. This fixes a bizarre behavior where
3336 printing '%s' % locals() would trigger the help system. Now
3341 printing '%s' % locals() would trigger the help system. Now
3337 ipython behaves like normal python does.
3342 ipython behaves like normal python does.
3338
3343
3339 Note that if one does 'from pydoc import help', the bizarre
3344 Note that if one does 'from pydoc import help', the bizarre
3340 behavior returns, but this will also happen in normal python, so
3345 behavior returns, but this will also happen in normal python, so
3341 it's not an ipython bug anymore (it has to do with how pydoc.help
3346 it's not an ipython bug anymore (it has to do with how pydoc.help
3342 is implemented).
3347 is implemented).
3343
3348
3344 2003-05-22 Fernando Perez <fperez@colorado.edu>
3349 2003-05-22 Fernando Perez <fperez@colorado.edu>
3345
3350
3346 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
3351 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
3347 return [] instead of None when nothing matches, also match to end
3352 return [] instead of None when nothing matches, also match to end
3348 of line. Patch by Gary Bishop.
3353 of line. Patch by Gary Bishop.
3349
3354
3350 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
3355 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
3351 protection as before, for files passed on the command line. This
3356 protection as before, for files passed on the command line. This
3352 prevents the CrashHandler from kicking in if user files call into
3357 prevents the CrashHandler from kicking in if user files call into
3353 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
3358 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
3354 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
3359 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
3355
3360
3356 2003-05-20 *** Released version 0.4.0
3361 2003-05-20 *** Released version 0.4.0
3357
3362
3358 2003-05-20 Fernando Perez <fperez@colorado.edu>
3363 2003-05-20 Fernando Perez <fperez@colorado.edu>
3359
3364
3360 * setup.py: added support for manpages. It's a bit hackish b/c of
3365 * setup.py: added support for manpages. It's a bit hackish b/c of
3361 a bug in the way the bdist_rpm distutils target handles gzipped
3366 a bug in the way the bdist_rpm distutils target handles gzipped
3362 manpages, but it works. After a patch by Jack.
3367 manpages, but it works. After a patch by Jack.
3363
3368
3364 2003-05-19 Fernando Perez <fperez@colorado.edu>
3369 2003-05-19 Fernando Perez <fperez@colorado.edu>
3365
3370
3366 * IPython/numutils.py: added a mockup of the kinds module, since
3371 * IPython/numutils.py: added a mockup of the kinds module, since
3367 it was recently removed from Numeric. This way, numutils will
3372 it was recently removed from Numeric. This way, numutils will
3368 work for all users even if they are missing kinds.
3373 work for all users even if they are missing kinds.
3369
3374
3370 * IPython/Magic.py (Magic._ofind): Harden against an inspect
3375 * IPython/Magic.py (Magic._ofind): Harden against an inspect
3371 failure, which can occur with SWIG-wrapped extensions. After a
3376 failure, which can occur with SWIG-wrapped extensions. After a
3372 crash report from Prabhu.
3377 crash report from Prabhu.
3373
3378
3374 2003-05-16 Fernando Perez <fperez@colorado.edu>
3379 2003-05-16 Fernando Perez <fperez@colorado.edu>
3375
3380
3376 * IPython/iplib.py (InteractiveShell.excepthook): New method to
3381 * IPython/iplib.py (InteractiveShell.excepthook): New method to
3377 protect ipython from user code which may call directly
3382 protect ipython from user code which may call directly
3378 sys.excepthook (this looks like an ipython crash to the user, even
3383 sys.excepthook (this looks like an ipython crash to the user, even
3379 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
3384 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
3380 This is especially important to help users of WxWindows, but may
3385 This is especially important to help users of WxWindows, but may
3381 also be useful in other cases.
3386 also be useful in other cases.
3382
3387
3383 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
3388 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
3384 an optional tb_offset to be specified, and to preserve exception
3389 an optional tb_offset to be specified, and to preserve exception
3385 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
3390 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
3386
3391
3387 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
3392 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
3388
3393
3389 2003-05-15 Fernando Perez <fperez@colorado.edu>
3394 2003-05-15 Fernando Perez <fperez@colorado.edu>
3390
3395
3391 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
3396 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
3392 installing for a new user under Windows.
3397 installing for a new user under Windows.
3393
3398
3394 2003-05-12 Fernando Perez <fperez@colorado.edu>
3399 2003-05-12 Fernando Perez <fperez@colorado.edu>
3395
3400
3396 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
3401 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
3397 handler for Emacs comint-based lines. Currently it doesn't do
3402 handler for Emacs comint-based lines. Currently it doesn't do
3398 much (but importantly, it doesn't update the history cache). In
3403 much (but importantly, it doesn't update the history cache). In
3399 the future it may be expanded if Alex needs more functionality
3404 the future it may be expanded if Alex needs more functionality
3400 there.
3405 there.
3401
3406
3402 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
3407 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
3403 info to crash reports.
3408 info to crash reports.
3404
3409
3405 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
3410 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
3406 just like Python's -c. Also fixed crash with invalid -color
3411 just like Python's -c. Also fixed crash with invalid -color
3407 option value at startup. Thanks to Will French
3412 option value at startup. Thanks to Will French
3408 <wfrench-AT-bestweb.net> for the bug report.
3413 <wfrench-AT-bestweb.net> for the bug report.
3409
3414
3410 2003-05-09 Fernando Perez <fperez@colorado.edu>
3415 2003-05-09 Fernando Perez <fperez@colorado.edu>
3411
3416
3412 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
3417 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
3413 to EvalDict (it's a mapping, after all) and simplified its code
3418 to EvalDict (it's a mapping, after all) and simplified its code
3414 quite a bit, after a nice discussion on c.l.py where Gustavo
3419 quite a bit, after a nice discussion on c.l.py where Gustavo
3415 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
3420 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
3416
3421
3417 2003-04-30 Fernando Perez <fperez@colorado.edu>
3422 2003-04-30 Fernando Perez <fperez@colorado.edu>
3418
3423
3419 * IPython/genutils.py (timings_out): modified it to reduce its
3424 * IPython/genutils.py (timings_out): modified it to reduce its
3420 overhead in the common reps==1 case.
3425 overhead in the common reps==1 case.
3421
3426
3422 2003-04-29 Fernando Perez <fperez@colorado.edu>
3427 2003-04-29 Fernando Perez <fperez@colorado.edu>
3423
3428
3424 * IPython/genutils.py (timings_out): Modified to use the resource
3429 * IPython/genutils.py (timings_out): Modified to use the resource
3425 module, which avoids the wraparound problems of time.clock().
3430 module, which avoids the wraparound problems of time.clock().
3426
3431
3427 2003-04-17 *** Released version 0.2.15pre4
3432 2003-04-17 *** Released version 0.2.15pre4
3428
3433
3429 2003-04-17 Fernando Perez <fperez@colorado.edu>
3434 2003-04-17 Fernando Perez <fperez@colorado.edu>
3430
3435
3431 * setup.py (scriptfiles): Split windows-specific stuff over to a
3436 * setup.py (scriptfiles): Split windows-specific stuff over to a
3432 separate file, in an attempt to have a Windows GUI installer.
3437 separate file, in an attempt to have a Windows GUI installer.
3433 That didn't work, but part of the groundwork is done.
3438 That didn't work, but part of the groundwork is done.
3434
3439
3435 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
3440 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
3436 indent/unindent with 4 spaces. Particularly useful in combination
3441 indent/unindent with 4 spaces. Particularly useful in combination
3437 with the new auto-indent option.
3442 with the new auto-indent option.
3438
3443
3439 2003-04-16 Fernando Perez <fperez@colorado.edu>
3444 2003-04-16 Fernando Perez <fperez@colorado.edu>
3440
3445
3441 * IPython/Magic.py: various replacements of self.rc for
3446 * IPython/Magic.py: various replacements of self.rc for
3442 self.shell.rc. A lot more remains to be done to fully disentangle
3447 self.shell.rc. A lot more remains to be done to fully disentangle
3443 this class from the main Shell class.
3448 this class from the main Shell class.
3444
3449
3445 * IPython/GnuplotRuntime.py: added checks for mouse support so
3450 * IPython/GnuplotRuntime.py: added checks for mouse support so
3446 that we don't try to enable it if the current gnuplot doesn't
3451 that we don't try to enable it if the current gnuplot doesn't
3447 really support it. Also added checks so that we don't try to
3452 really support it. Also added checks so that we don't try to
3448 enable persist under Windows (where Gnuplot doesn't recognize the
3453 enable persist under Windows (where Gnuplot doesn't recognize the
3449 option).
3454 option).
3450
3455
3451 * IPython/iplib.py (InteractiveShell.interact): Added optional
3456 * IPython/iplib.py (InteractiveShell.interact): Added optional
3452 auto-indenting code, after a patch by King C. Shu
3457 auto-indenting code, after a patch by King C. Shu
3453 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
3458 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
3454 get along well with pasting indented code. If I ever figure out
3459 get along well with pasting indented code. If I ever figure out
3455 how to make that part go well, it will become on by default.
3460 how to make that part go well, it will become on by default.
3456
3461
3457 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
3462 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
3458 crash ipython if there was an unmatched '%' in the user's prompt
3463 crash ipython if there was an unmatched '%' in the user's prompt
3459 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
3464 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
3460
3465
3461 * IPython/iplib.py (InteractiveShell.interact): removed the
3466 * IPython/iplib.py (InteractiveShell.interact): removed the
3462 ability to ask the user whether he wants to crash or not at the
3467 ability to ask the user whether he wants to crash or not at the
3463 'last line' exception handler. Calling functions at that point
3468 'last line' exception handler. Calling functions at that point
3464 changes the stack, and the error reports would have incorrect
3469 changes the stack, and the error reports would have incorrect
3465 tracebacks.
3470 tracebacks.
3466
3471
3467 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
3472 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
3468 pass through a peger a pretty-printed form of any object. After a
3473 pass through a peger a pretty-printed form of any object. After a
3469 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
3474 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
3470
3475
3471 2003-04-14 Fernando Perez <fperez@colorado.edu>
3476 2003-04-14 Fernando Perez <fperez@colorado.edu>
3472
3477
3473 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
3478 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
3474 all files in ~ would be modified at first install (instead of
3479 all files in ~ would be modified at first install (instead of
3475 ~/.ipython). This could be potentially disastrous, as the
3480 ~/.ipython). This could be potentially disastrous, as the
3476 modification (make line-endings native) could damage binary files.
3481 modification (make line-endings native) could damage binary files.
3477
3482
3478 2003-04-10 Fernando Perez <fperez@colorado.edu>
3483 2003-04-10 Fernando Perez <fperez@colorado.edu>
3479
3484
3480 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
3485 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
3481 handle only lines which are invalid python. This now means that
3486 handle only lines which are invalid python. This now means that
3482 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
3487 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
3483 for the bug report.
3488 for the bug report.
3484
3489
3485 2003-04-01 Fernando Perez <fperez@colorado.edu>
3490 2003-04-01 Fernando Perez <fperez@colorado.edu>
3486
3491
3487 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
3492 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
3488 where failing to set sys.last_traceback would crash pdb.pm().
3493 where failing to set sys.last_traceback would crash pdb.pm().
3489 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
3494 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
3490 report.
3495 report.
3491
3496
3492 2003-03-25 Fernando Perez <fperez@colorado.edu>
3497 2003-03-25 Fernando Perez <fperez@colorado.edu>
3493
3498
3494 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
3499 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
3495 before printing it (it had a lot of spurious blank lines at the
3500 before printing it (it had a lot of spurious blank lines at the
3496 end).
3501 end).
3497
3502
3498 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
3503 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
3499 output would be sent 21 times! Obviously people don't use this
3504 output would be sent 21 times! Obviously people don't use this
3500 too often, or I would have heard about it.
3505 too often, or I would have heard about it.
3501
3506
3502 2003-03-24 Fernando Perez <fperez@colorado.edu>
3507 2003-03-24 Fernando Perez <fperez@colorado.edu>
3503
3508
3504 * setup.py (scriptfiles): renamed the data_files parameter from
3509 * setup.py (scriptfiles): renamed the data_files parameter from
3505 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
3510 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
3506 for the patch.
3511 for the patch.
3507
3512
3508 2003-03-20 Fernando Perez <fperez@colorado.edu>
3513 2003-03-20 Fernando Perez <fperez@colorado.edu>
3509
3514
3510 * IPython/genutils.py (error): added error() and fatal()
3515 * IPython/genutils.py (error): added error() and fatal()
3511 functions.
3516 functions.
3512
3517
3513 2003-03-18 *** Released version 0.2.15pre3
3518 2003-03-18 *** Released version 0.2.15pre3
3514
3519
3515 2003-03-18 Fernando Perez <fperez@colorado.edu>
3520 2003-03-18 Fernando Perez <fperez@colorado.edu>
3516
3521
3517 * setupext/install_data_ext.py
3522 * setupext/install_data_ext.py
3518 (install_data_ext.initialize_options): Class contributed by Jack
3523 (install_data_ext.initialize_options): Class contributed by Jack
3519 Moffit for fixing the old distutils hack. He is sending this to
3524 Moffit for fixing the old distutils hack. He is sending this to
3520 the distutils folks so in the future we may not need it as a
3525 the distutils folks so in the future we may not need it as a
3521 private fix.
3526 private fix.
3522
3527
3523 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
3528 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
3524 changes for Debian packaging. See his patch for full details.
3529 changes for Debian packaging. See his patch for full details.
3525 The old distutils hack of making the ipythonrc* files carry a
3530 The old distutils hack of making the ipythonrc* files carry a
3526 bogus .py extension is gone, at last. Examples were moved to a
3531 bogus .py extension is gone, at last. Examples were moved to a
3527 separate subdir under doc/, and the separate executable scripts
3532 separate subdir under doc/, and the separate executable scripts
3528 now live in their own directory. Overall a great cleanup. The
3533 now live in their own directory. Overall a great cleanup. The
3529 manual was updated to use the new files, and setup.py has been
3534 manual was updated to use the new files, and setup.py has been
3530 fixed for this setup.
3535 fixed for this setup.
3531
3536
3532 * IPython/PyColorize.py (Parser.usage): made non-executable and
3537 * IPython/PyColorize.py (Parser.usage): made non-executable and
3533 created a pycolor wrapper around it to be included as a script.
3538 created a pycolor wrapper around it to be included as a script.
3534
3539
3535 2003-03-12 *** Released version 0.2.15pre2
3540 2003-03-12 *** Released version 0.2.15pre2
3536
3541
3537 2003-03-12 Fernando Perez <fperez@colorado.edu>
3542 2003-03-12 Fernando Perez <fperez@colorado.edu>
3538
3543
3539 * IPython/ColorANSI.py (make_color_table): Finally fixed the
3544 * IPython/ColorANSI.py (make_color_table): Finally fixed the
3540 long-standing problem with garbage characters in some terminals.
3545 long-standing problem with garbage characters in some terminals.
3541 The issue was really that the \001 and \002 escapes must _only_ be
3546 The issue was really that the \001 and \002 escapes must _only_ be
3542 passed to input prompts (which call readline), but _never_ to
3547 passed to input prompts (which call readline), but _never_ to
3543 normal text to be printed on screen. I changed ColorANSI to have
3548 normal text to be printed on screen. I changed ColorANSI to have
3544 two classes: TermColors and InputTermColors, each with the
3549 two classes: TermColors and InputTermColors, each with the
3545 appropriate escapes for input prompts or normal text. The code in
3550 appropriate escapes for input prompts or normal text. The code in
3546 Prompts.py got slightly more complicated, but this very old and
3551 Prompts.py got slightly more complicated, but this very old and
3547 annoying bug is finally fixed.
3552 annoying bug is finally fixed.
3548
3553
3549 All the credit for nailing down the real origin of this problem
3554 All the credit for nailing down the real origin of this problem
3550 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
3555 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
3551 *Many* thanks to him for spending quite a bit of effort on this.
3556 *Many* thanks to him for spending quite a bit of effort on this.
3552
3557
3553 2003-03-05 *** Released version 0.2.15pre1
3558 2003-03-05 *** Released version 0.2.15pre1
3554
3559
3555 2003-03-03 Fernando Perez <fperez@colorado.edu>
3560 2003-03-03 Fernando Perez <fperez@colorado.edu>
3556
3561
3557 * IPython/FakeModule.py: Moved the former _FakeModule to a
3562 * IPython/FakeModule.py: Moved the former _FakeModule to a
3558 separate file, because it's also needed by Magic (to fix a similar
3563 separate file, because it's also needed by Magic (to fix a similar
3559 pickle-related issue in @run).
3564 pickle-related issue in @run).
3560
3565
3561 2003-03-02 Fernando Perez <fperez@colorado.edu>
3566 2003-03-02 Fernando Perez <fperez@colorado.edu>
3562
3567
3563 * IPython/Magic.py (Magic.magic_autocall): new magic to control
3568 * IPython/Magic.py (Magic.magic_autocall): new magic to control
3564 the autocall option at runtime.
3569 the autocall option at runtime.
3565 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
3570 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
3566 across Magic.py to start separating Magic from InteractiveShell.
3571 across Magic.py to start separating Magic from InteractiveShell.
3567 (Magic._ofind): Fixed to return proper namespace for dotted
3572 (Magic._ofind): Fixed to return proper namespace for dotted
3568 names. Before, a dotted name would always return 'not currently
3573 names. Before, a dotted name would always return 'not currently
3569 defined', because it would find the 'parent'. s.x would be found,
3574 defined', because it would find the 'parent'. s.x would be found,
3570 but since 'x' isn't defined by itself, it would get confused.
3575 but since 'x' isn't defined by itself, it would get confused.
3571 (Magic.magic_run): Fixed pickling problems reported by Ralf
3576 (Magic.magic_run): Fixed pickling problems reported by Ralf
3572 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
3577 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
3573 that I'd used when Mike Heeter reported similar issues at the
3578 that I'd used when Mike Heeter reported similar issues at the
3574 top-level, but now for @run. It boils down to injecting the
3579 top-level, but now for @run. It boils down to injecting the
3575 namespace where code is being executed with something that looks
3580 namespace where code is being executed with something that looks
3576 enough like a module to fool pickle.dump(). Since a pickle stores
3581 enough like a module to fool pickle.dump(). Since a pickle stores
3577 a named reference to the importing module, we need this for
3582 a named reference to the importing module, we need this for
3578 pickles to save something sensible.
3583 pickles to save something sensible.
3579
3584
3580 * IPython/ipmaker.py (make_IPython): added an autocall option.
3585 * IPython/ipmaker.py (make_IPython): added an autocall option.
3581
3586
3582 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
3587 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
3583 the auto-eval code. Now autocalling is an option, and the code is
3588 the auto-eval code. Now autocalling is an option, and the code is
3584 also vastly safer. There is no more eval() involved at all.
3589 also vastly safer. There is no more eval() involved at all.
3585
3590
3586 2003-03-01 Fernando Perez <fperez@colorado.edu>
3591 2003-03-01 Fernando Perez <fperez@colorado.edu>
3587
3592
3588 * IPython/Magic.py (Magic._ofind): Changed interface to return a
3593 * IPython/Magic.py (Magic._ofind): Changed interface to return a
3589 dict with named keys instead of a tuple.
3594 dict with named keys instead of a tuple.
3590
3595
3591 * IPython: Started using CVS for IPython as of 0.2.15pre1.
3596 * IPython: Started using CVS for IPython as of 0.2.15pre1.
3592
3597
3593 * setup.py (make_shortcut): Fixed message about directories
3598 * setup.py (make_shortcut): Fixed message about directories
3594 created during Windows installation (the directories were ok, just
3599 created during Windows installation (the directories were ok, just
3595 the printed message was misleading). Thanks to Chris Liechti
3600 the printed message was misleading). Thanks to Chris Liechti
3596 <cliechti-AT-gmx.net> for the heads up.
3601 <cliechti-AT-gmx.net> for the heads up.
3597
3602
3598 2003-02-21 Fernando Perez <fperez@colorado.edu>
3603 2003-02-21 Fernando Perez <fperez@colorado.edu>
3599
3604
3600 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
3605 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
3601 of ValueError exception when checking for auto-execution. This
3606 of ValueError exception when checking for auto-execution. This
3602 one is raised by things like Numeric arrays arr.flat when the
3607 one is raised by things like Numeric arrays arr.flat when the
3603 array is non-contiguous.
3608 array is non-contiguous.
3604
3609
3605 2003-01-31 Fernando Perez <fperez@colorado.edu>
3610 2003-01-31 Fernando Perez <fperez@colorado.edu>
3606
3611
3607 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
3612 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
3608 not return any value at all (even though the command would get
3613 not return any value at all (even though the command would get
3609 executed).
3614 executed).
3610 (xsys): Flush stdout right after printing the command to ensure
3615 (xsys): Flush stdout right after printing the command to ensure
3611 proper ordering of commands and command output in the total
3616 proper ordering of commands and command output in the total
3612 output.
3617 output.
3613 (SystemExec/xsys/bq): Switched the names of xsys/bq and
3618 (SystemExec/xsys/bq): Switched the names of xsys/bq and
3614 system/getoutput as defaults. The old ones are kept for
3619 system/getoutput as defaults. The old ones are kept for
3615 compatibility reasons, so no code which uses this library needs
3620 compatibility reasons, so no code which uses this library needs
3616 changing.
3621 changing.
3617
3622
3618 2003-01-27 *** Released version 0.2.14
3623 2003-01-27 *** Released version 0.2.14
3619
3624
3620 2003-01-25 Fernando Perez <fperez@colorado.edu>
3625 2003-01-25 Fernando Perez <fperez@colorado.edu>
3621
3626
3622 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
3627 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
3623 functions defined in previous edit sessions could not be re-edited
3628 functions defined in previous edit sessions could not be re-edited
3624 (because the temp files were immediately removed). Now temp files
3629 (because the temp files were immediately removed). Now temp files
3625 are removed only at IPython's exit.
3630 are removed only at IPython's exit.
3626 (Magic.magic_run): Improved @run to perform shell-like expansions
3631 (Magic.magic_run): Improved @run to perform shell-like expansions
3627 on its arguments (~users and $VARS). With this, @run becomes more
3632 on its arguments (~users and $VARS). With this, @run becomes more
3628 like a normal command-line.
3633 like a normal command-line.
3629
3634
3630 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
3635 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
3631 bugs related to embedding and cleaned up that code. A fairly
3636 bugs related to embedding and cleaned up that code. A fairly
3632 important one was the impossibility to access the global namespace
3637 important one was the impossibility to access the global namespace
3633 through the embedded IPython (only local variables were visible).
3638 through the embedded IPython (only local variables were visible).
3634
3639
3635 2003-01-14 Fernando Perez <fperez@colorado.edu>
3640 2003-01-14 Fernando Perez <fperez@colorado.edu>
3636
3641
3637 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
3642 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
3638 auto-calling to be a bit more conservative. Now it doesn't get
3643 auto-calling to be a bit more conservative. Now it doesn't get
3639 triggered if any of '!=()<>' are in the rest of the input line, to
3644 triggered if any of '!=()<>' are in the rest of the input line, to
3640 allow comparing callables. Thanks to Alex for the heads up.
3645 allow comparing callables. Thanks to Alex for the heads up.
3641
3646
3642 2003-01-07 Fernando Perez <fperez@colorado.edu>
3647 2003-01-07 Fernando Perez <fperez@colorado.edu>
3643
3648
3644 * IPython/genutils.py (page): fixed estimation of the number of
3649 * IPython/genutils.py (page): fixed estimation of the number of
3645 lines in a string to be paged to simply count newlines. This
3650 lines in a string to be paged to simply count newlines. This
3646 prevents over-guessing due to embedded escape sequences. A better
3651 prevents over-guessing due to embedded escape sequences. A better
3647 long-term solution would involve stripping out the control chars
3652 long-term solution would involve stripping out the control chars
3648 for the count, but it's potentially so expensive I just don't
3653 for the count, but it's potentially so expensive I just don't
3649 think it's worth doing.
3654 think it's worth doing.
3650
3655
3651 2002-12-19 *** Released version 0.2.14pre50
3656 2002-12-19 *** Released version 0.2.14pre50
3652
3657
3653 2002-12-19 Fernando Perez <fperez@colorado.edu>
3658 2002-12-19 Fernando Perez <fperez@colorado.edu>
3654
3659
3655 * tools/release (version): Changed release scripts to inform
3660 * tools/release (version): Changed release scripts to inform
3656 Andrea and build a NEWS file with a list of recent changes.
3661 Andrea and build a NEWS file with a list of recent changes.
3657
3662
3658 * IPython/ColorANSI.py (__all__): changed terminal detection
3663 * IPython/ColorANSI.py (__all__): changed terminal detection
3659 code. Seems to work better for xterms without breaking
3664 code. Seems to work better for xterms without breaking
3660 konsole. Will need more testing to determine if WinXP and Mac OSX
3665 konsole. Will need more testing to determine if WinXP and Mac OSX
3661 also work ok.
3666 also work ok.
3662
3667
3663 2002-12-18 *** Released version 0.2.14pre49
3668 2002-12-18 *** Released version 0.2.14pre49
3664
3669
3665 2002-12-18 Fernando Perez <fperez@colorado.edu>
3670 2002-12-18 Fernando Perez <fperez@colorado.edu>
3666
3671
3667 * Docs: added new info about Mac OSX, from Andrea.
3672 * Docs: added new info about Mac OSX, from Andrea.
3668
3673
3669 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
3674 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
3670 allow direct plotting of python strings whose format is the same
3675 allow direct plotting of python strings whose format is the same
3671 of gnuplot data files.
3676 of gnuplot data files.
3672
3677
3673 2002-12-16 Fernando Perez <fperez@colorado.edu>
3678 2002-12-16 Fernando Perez <fperez@colorado.edu>
3674
3679
3675 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
3680 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
3676 value of exit question to be acknowledged.
3681 value of exit question to be acknowledged.
3677
3682
3678 2002-12-03 Fernando Perez <fperez@colorado.edu>
3683 2002-12-03 Fernando Perez <fperez@colorado.edu>
3679
3684
3680 * IPython/ipmaker.py: removed generators, which had been added
3685 * IPython/ipmaker.py: removed generators, which had been added
3681 by mistake in an earlier debugging run. This was causing trouble
3686 by mistake in an earlier debugging run. This was causing trouble
3682 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
3687 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
3683 for pointing this out.
3688 for pointing this out.
3684
3689
3685 2002-11-17 Fernando Perez <fperez@colorado.edu>
3690 2002-11-17 Fernando Perez <fperez@colorado.edu>
3686
3691
3687 * Manual: updated the Gnuplot section.
3692 * Manual: updated the Gnuplot section.
3688
3693
3689 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
3694 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
3690 a much better split of what goes in Runtime and what goes in
3695 a much better split of what goes in Runtime and what goes in
3691 Interactive.
3696 Interactive.
3692
3697
3693 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
3698 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
3694 being imported from iplib.
3699 being imported from iplib.
3695
3700
3696 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
3701 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
3697 for command-passing. Now the global Gnuplot instance is called
3702 for command-passing. Now the global Gnuplot instance is called
3698 'gp' instead of 'g', which was really a far too fragile and
3703 'gp' instead of 'g', which was really a far too fragile and
3699 common name.
3704 common name.
3700
3705
3701 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
3706 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
3702 bounding boxes generated by Gnuplot for square plots.
3707 bounding boxes generated by Gnuplot for square plots.
3703
3708
3704 * IPython/genutils.py (popkey): new function added. I should
3709 * IPython/genutils.py (popkey): new function added. I should
3705 suggest this on c.l.py as a dict method, it seems useful.
3710 suggest this on c.l.py as a dict method, it seems useful.
3706
3711
3707 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
3712 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
3708 to transparently handle PostScript generation. MUCH better than
3713 to transparently handle PostScript generation. MUCH better than
3709 the previous plot_eps/replot_eps (which I removed now). The code
3714 the previous plot_eps/replot_eps (which I removed now). The code
3710 is also fairly clean and well documented now (including
3715 is also fairly clean and well documented now (including
3711 docstrings).
3716 docstrings).
3712
3717
3713 2002-11-13 Fernando Perez <fperez@colorado.edu>
3718 2002-11-13 Fernando Perez <fperez@colorado.edu>
3714
3719
3715 * IPython/Magic.py (Magic.magic_edit): fixed docstring
3720 * IPython/Magic.py (Magic.magic_edit): fixed docstring
3716 (inconsistent with options).
3721 (inconsistent with options).
3717
3722
3718 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
3723 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
3719 manually disabled, I don't know why. Fixed it.
3724 manually disabled, I don't know why. Fixed it.
3720 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
3725 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
3721 eps output.
3726 eps output.
3722
3727
3723 2002-11-12 Fernando Perez <fperez@colorado.edu>
3728 2002-11-12 Fernando Perez <fperez@colorado.edu>
3724
3729
3725 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
3730 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
3726 don't propagate up to caller. Fixes crash reported by François
3731 don't propagate up to caller. Fixes crash reported by François
3727 Pinard.
3732 Pinard.
3728
3733
3729 2002-11-09 Fernando Perez <fperez@colorado.edu>
3734 2002-11-09 Fernando Perez <fperez@colorado.edu>
3730
3735
3731 * IPython/ipmaker.py (make_IPython): fixed problem with writing
3736 * IPython/ipmaker.py (make_IPython): fixed problem with writing
3732 history file for new users.
3737 history file for new users.
3733 (make_IPython): fixed bug where initial install would leave the
3738 (make_IPython): fixed bug where initial install would leave the
3734 user running in the .ipython dir.
3739 user running in the .ipython dir.
3735 (make_IPython): fixed bug where config dir .ipython would be
3740 (make_IPython): fixed bug where config dir .ipython would be
3736 created regardless of the given -ipythondir option. Thanks to Cory
3741 created regardless of the given -ipythondir option. Thanks to Cory
3737 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
3742 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
3738
3743
3739 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
3744 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
3740 type confirmations. Will need to use it in all of IPython's code
3745 type confirmations. Will need to use it in all of IPython's code
3741 consistently.
3746 consistently.
3742
3747
3743 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
3748 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
3744 context to print 31 lines instead of the default 5. This will make
3749 context to print 31 lines instead of the default 5. This will make
3745 the crash reports extremely detailed in case the problem is in
3750 the crash reports extremely detailed in case the problem is in
3746 libraries I don't have access to.
3751 libraries I don't have access to.
3747
3752
3748 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
3753 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
3749 line of defense' code to still crash, but giving users fair
3754 line of defense' code to still crash, but giving users fair
3750 warning. I don't want internal errors to go unreported: if there's
3755 warning. I don't want internal errors to go unreported: if there's
3751 an internal problem, IPython should crash and generate a full
3756 an internal problem, IPython should crash and generate a full
3752 report.
3757 report.
3753
3758
3754 2002-11-08 Fernando Perez <fperez@colorado.edu>
3759 2002-11-08 Fernando Perez <fperez@colorado.edu>
3755
3760
3756 * IPython/iplib.py (InteractiveShell.interact): added code to trap
3761 * IPython/iplib.py (InteractiveShell.interact): added code to trap
3757 otherwise uncaught exceptions which can appear if people set
3762 otherwise uncaught exceptions which can appear if people set
3758 sys.stdout to something badly broken. Thanks to a crash report
3763 sys.stdout to something badly broken. Thanks to a crash report
3759 from henni-AT-mail.brainbot.com.
3764 from henni-AT-mail.brainbot.com.
3760
3765
3761 2002-11-04 Fernando Perez <fperez@colorado.edu>
3766 2002-11-04 Fernando Perez <fperez@colorado.edu>
3762
3767
3763 * IPython/iplib.py (InteractiveShell.interact): added
3768 * IPython/iplib.py (InteractiveShell.interact): added
3764 __IPYTHON__active to the builtins. It's a flag which goes on when
3769 __IPYTHON__active to the builtins. It's a flag which goes on when
3765 the interaction starts and goes off again when it stops. This
3770 the interaction starts and goes off again when it stops. This
3766 allows embedding code to detect being inside IPython. Before this
3771 allows embedding code to detect being inside IPython. Before this
3767 was done via __IPYTHON__, but that only shows that an IPython
3772 was done via __IPYTHON__, but that only shows that an IPython
3768 instance has been created.
3773 instance has been created.
3769
3774
3770 * IPython/Magic.py (Magic.magic_env): I realized that in a
3775 * IPython/Magic.py (Magic.magic_env): I realized that in a
3771 UserDict, instance.data holds the data as a normal dict. So I
3776 UserDict, instance.data holds the data as a normal dict. So I
3772 modified @env to return os.environ.data instead of rebuilding a
3777 modified @env to return os.environ.data instead of rebuilding a
3773 dict by hand.
3778 dict by hand.
3774
3779
3775 2002-11-02 Fernando Perez <fperez@colorado.edu>
3780 2002-11-02 Fernando Perez <fperez@colorado.edu>
3776
3781
3777 * IPython/genutils.py (warn): changed so that level 1 prints no
3782 * IPython/genutils.py (warn): changed so that level 1 prints no
3778 header. Level 2 is now the default (with 'WARNING' header, as
3783 header. Level 2 is now the default (with 'WARNING' header, as
3779 before). I think I tracked all places where changes were needed in
3784 before). I think I tracked all places where changes were needed in
3780 IPython, but outside code using the old level numbering may have
3785 IPython, but outside code using the old level numbering may have
3781 broken.
3786 broken.
3782
3787
3783 * IPython/iplib.py (InteractiveShell.runcode): added this to
3788 * IPython/iplib.py (InteractiveShell.runcode): added this to
3784 handle the tracebacks in SystemExit traps correctly. The previous
3789 handle the tracebacks in SystemExit traps correctly. The previous
3785 code (through interact) was printing more of the stack than
3790 code (through interact) was printing more of the stack than
3786 necessary, showing IPython internal code to the user.
3791 necessary, showing IPython internal code to the user.
3787
3792
3788 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
3793 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
3789 default. Now that the default at the confirmation prompt is yes,
3794 default. Now that the default at the confirmation prompt is yes,
3790 it's not so intrusive. François' argument that ipython sessions
3795 it's not so intrusive. François' argument that ipython sessions
3791 tend to be complex enough not to lose them from an accidental C-d,
3796 tend to be complex enough not to lose them from an accidental C-d,
3792 is a valid one.
3797 is a valid one.
3793
3798
3794 * IPython/iplib.py (InteractiveShell.interact): added a
3799 * IPython/iplib.py (InteractiveShell.interact): added a
3795 showtraceback() call to the SystemExit trap, and modified the exit
3800 showtraceback() call to the SystemExit trap, and modified the exit
3796 confirmation to have yes as the default.
3801 confirmation to have yes as the default.
3797
3802
3798 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
3803 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
3799 this file. It's been gone from the code for a long time, this was
3804 this file. It's been gone from the code for a long time, this was
3800 simply leftover junk.
3805 simply leftover junk.
3801
3806
3802 2002-11-01 Fernando Perez <fperez@colorado.edu>
3807 2002-11-01 Fernando Perez <fperez@colorado.edu>
3803
3808
3804 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
3809 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
3805 added. If set, IPython now traps EOF and asks for
3810 added. If set, IPython now traps EOF and asks for
3806 confirmation. After a request by François Pinard.
3811 confirmation. After a request by François Pinard.
3807
3812
3808 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
3813 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
3809 of @abort, and with a new (better) mechanism for handling the
3814 of @abort, and with a new (better) mechanism for handling the
3810 exceptions.
3815 exceptions.
3811
3816
3812 2002-10-27 Fernando Perez <fperez@colorado.edu>
3817 2002-10-27 Fernando Perez <fperez@colorado.edu>
3813
3818
3814 * IPython/usage.py (__doc__): updated the --help information and
3819 * IPython/usage.py (__doc__): updated the --help information and
3815 the ipythonrc file to indicate that -log generates
3820 the ipythonrc file to indicate that -log generates
3816 ./ipython.log. Also fixed the corresponding info in @logstart.
3821 ./ipython.log. Also fixed the corresponding info in @logstart.
3817 This and several other fixes in the manuals thanks to reports by
3822 This and several other fixes in the manuals thanks to reports by
3818 François Pinard <pinard-AT-iro.umontreal.ca>.
3823 François Pinard <pinard-AT-iro.umontreal.ca>.
3819
3824
3820 * IPython/Logger.py (Logger.switch_log): Fixed error message to
3825 * IPython/Logger.py (Logger.switch_log): Fixed error message to
3821 refer to @logstart (instead of @log, which doesn't exist).
3826 refer to @logstart (instead of @log, which doesn't exist).
3822
3827
3823 * IPython/iplib.py (InteractiveShell._prefilter): fixed
3828 * IPython/iplib.py (InteractiveShell._prefilter): fixed
3824 AttributeError crash. Thanks to Christopher Armstrong
3829 AttributeError crash. Thanks to Christopher Armstrong
3825 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
3830 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
3826 introduced recently (in 0.2.14pre37) with the fix to the eval
3831 introduced recently (in 0.2.14pre37) with the fix to the eval
3827 problem mentioned below.
3832 problem mentioned below.
3828
3833
3829 2002-10-17 Fernando Perez <fperez@colorado.edu>
3834 2002-10-17 Fernando Perez <fperez@colorado.edu>
3830
3835
3831 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
3836 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
3832 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
3837 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
3833
3838
3834 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
3839 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
3835 this function to fix a problem reported by Alex Schmolck. He saw
3840 this function to fix a problem reported by Alex Schmolck. He saw
3836 it with list comprehensions and generators, which were getting
3841 it with list comprehensions and generators, which were getting
3837 called twice. The real problem was an 'eval' call in testing for
3842 called twice. The real problem was an 'eval' call in testing for
3838 automagic which was evaluating the input line silently.
3843 automagic which was evaluating the input line silently.
3839
3844
3840 This is a potentially very nasty bug, if the input has side
3845 This is a potentially very nasty bug, if the input has side
3841 effects which must not be repeated. The code is much cleaner now,
3846 effects which must not be repeated. The code is much cleaner now,
3842 without any blanket 'except' left and with a regexp test for
3847 without any blanket 'except' left and with a regexp test for
3843 actual function names.
3848 actual function names.
3844
3849
3845 But an eval remains, which I'm not fully comfortable with. I just
3850 But an eval remains, which I'm not fully comfortable with. I just
3846 don't know how to find out if an expression could be a callable in
3851 don't know how to find out if an expression could be a callable in
3847 the user's namespace without doing an eval on the string. However
3852 the user's namespace without doing an eval on the string. However
3848 that string is now much more strictly checked so that no code
3853 that string is now much more strictly checked so that no code
3849 slips by, so the eval should only happen for things that can
3854 slips by, so the eval should only happen for things that can
3850 really be only function/method names.
3855 really be only function/method names.
3851
3856
3852 2002-10-15 Fernando Perez <fperez@colorado.edu>
3857 2002-10-15 Fernando Perez <fperez@colorado.edu>
3853
3858
3854 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
3859 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
3855 OSX information to main manual, removed README_Mac_OSX file from
3860 OSX information to main manual, removed README_Mac_OSX file from
3856 distribution. Also updated credits for recent additions.
3861 distribution. Also updated credits for recent additions.
3857
3862
3858 2002-10-10 Fernando Perez <fperez@colorado.edu>
3863 2002-10-10 Fernando Perez <fperez@colorado.edu>
3859
3864
3860 * README_Mac_OSX: Added a README for Mac OSX users for fixing
3865 * README_Mac_OSX: Added a README for Mac OSX users for fixing
3861 terminal-related issues. Many thanks to Andrea Riciputi
3866 terminal-related issues. Many thanks to Andrea Riciputi
3862 <andrea.riciputi-AT-libero.it> for writing it.
3867 <andrea.riciputi-AT-libero.it> for writing it.
3863
3868
3864 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
3869 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
3865 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
3870 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
3866
3871
3867 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
3872 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
3868 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
3873 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
3869 <syver-en-AT-online.no> who both submitted patches for this problem.
3874 <syver-en-AT-online.no> who both submitted patches for this problem.
3870
3875
3871 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
3876 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
3872 global embedding to make sure that things don't overwrite user
3877 global embedding to make sure that things don't overwrite user
3873 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
3878 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
3874
3879
3875 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
3880 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
3876 compatibility. Thanks to Hayden Callow
3881 compatibility. Thanks to Hayden Callow
3877 <h.callow-AT-elec.canterbury.ac.nz>
3882 <h.callow-AT-elec.canterbury.ac.nz>
3878
3883
3879 2002-10-04 Fernando Perez <fperez@colorado.edu>
3884 2002-10-04 Fernando Perez <fperez@colorado.edu>
3880
3885
3881 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
3886 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
3882 Gnuplot.File objects.
3887 Gnuplot.File objects.
3883
3888
3884 2002-07-23 Fernando Perez <fperez@colorado.edu>
3889 2002-07-23 Fernando Perez <fperez@colorado.edu>
3885
3890
3886 * IPython/genutils.py (timing): Added timings() and timing() for
3891 * IPython/genutils.py (timing): Added timings() and timing() for
3887 quick access to the most commonly needed data, the execution
3892 quick access to the most commonly needed data, the execution
3888 times. Old timing() renamed to timings_out().
3893 times. Old timing() renamed to timings_out().
3889
3894
3890 2002-07-18 Fernando Perez <fperez@colorado.edu>
3895 2002-07-18 Fernando Perez <fperez@colorado.edu>
3891
3896
3892 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
3897 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
3893 bug with nested instances disrupting the parent's tab completion.
3898 bug with nested instances disrupting the parent's tab completion.
3894
3899
3895 * IPython/iplib.py (all_completions): Added Alex Schmolck's
3900 * IPython/iplib.py (all_completions): Added Alex Schmolck's
3896 all_completions code to begin the emacs integration.
3901 all_completions code to begin the emacs integration.
3897
3902
3898 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
3903 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
3899 argument to allow titling individual arrays when plotting.
3904 argument to allow titling individual arrays when plotting.
3900
3905
3901 2002-07-15 Fernando Perez <fperez@colorado.edu>
3906 2002-07-15 Fernando Perez <fperez@colorado.edu>
3902
3907
3903 * setup.py (make_shortcut): changed to retrieve the value of
3908 * setup.py (make_shortcut): changed to retrieve the value of
3904 'Program Files' directory from the registry (this value changes in
3909 'Program Files' directory from the registry (this value changes in
3905 non-english versions of Windows). Thanks to Thomas Fanslau
3910 non-english versions of Windows). Thanks to Thomas Fanslau
3906 <tfanslau-AT-gmx.de> for the report.
3911 <tfanslau-AT-gmx.de> for the report.
3907
3912
3908 2002-07-10 Fernando Perez <fperez@colorado.edu>
3913 2002-07-10 Fernando Perez <fperez@colorado.edu>
3909
3914
3910 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
3915 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
3911 a bug in pdb, which crashes if a line with only whitespace is
3916 a bug in pdb, which crashes if a line with only whitespace is
3912 entered. Bug report submitted to sourceforge.
3917 entered. Bug report submitted to sourceforge.
3913
3918
3914 2002-07-09 Fernando Perez <fperez@colorado.edu>
3919 2002-07-09 Fernando Perez <fperez@colorado.edu>
3915
3920
3916 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
3921 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
3917 reporting exceptions (it's a bug in inspect.py, I just set a
3922 reporting exceptions (it's a bug in inspect.py, I just set a
3918 workaround).
3923 workaround).
3919
3924
3920 2002-07-08 Fernando Perez <fperez@colorado.edu>
3925 2002-07-08 Fernando Perez <fperez@colorado.edu>
3921
3926
3922 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
3927 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
3923 __IPYTHON__ in __builtins__ to show up in user_ns.
3928 __IPYTHON__ in __builtins__ to show up in user_ns.
3924
3929
3925 2002-07-03 Fernando Perez <fperez@colorado.edu>
3930 2002-07-03 Fernando Perez <fperez@colorado.edu>
3926
3931
3927 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
3932 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
3928 name from @gp_set_instance to @gp_set_default.
3933 name from @gp_set_instance to @gp_set_default.
3929
3934
3930 * IPython/ipmaker.py (make_IPython): default editor value set to
3935 * IPython/ipmaker.py (make_IPython): default editor value set to
3931 '0' (a string), to match the rc file. Otherwise will crash when
3936 '0' (a string), to match the rc file. Otherwise will crash when
3932 .strip() is called on it.
3937 .strip() is called on it.
3933
3938
3934
3939
3935 2002-06-28 Fernando Perez <fperez@colorado.edu>
3940 2002-06-28 Fernando Perez <fperez@colorado.edu>
3936
3941
3937 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
3942 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
3938 of files in current directory when a file is executed via
3943 of files in current directory when a file is executed via
3939 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
3944 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
3940
3945
3941 * setup.py (manfiles): fix for rpm builds, submitted by RA
3946 * setup.py (manfiles): fix for rpm builds, submitted by RA
3942 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
3947 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
3943
3948
3944 * IPython/ipmaker.py (make_IPython): fixed lookup of default
3949 * IPython/ipmaker.py (make_IPython): fixed lookup of default
3945 editor when set to '0'. Problem was, '0' evaluates to True (it's a
3950 editor when set to '0'. Problem was, '0' evaluates to True (it's a
3946 string!). A. Schmolck caught this one.
3951 string!). A. Schmolck caught this one.
3947
3952
3948 2002-06-27 Fernando Perez <fperez@colorado.edu>
3953 2002-06-27 Fernando Perez <fperez@colorado.edu>
3949
3954
3950 * IPython/ipmaker.py (make_IPython): fixed bug when running user
3955 * IPython/ipmaker.py (make_IPython): fixed bug when running user
3951 defined files at the cmd line. __name__ wasn't being set to
3956 defined files at the cmd line. __name__ wasn't being set to
3952 __main__.
3957 __main__.
3953
3958
3954 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
3959 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
3955 regular lists and tuples besides Numeric arrays.
3960 regular lists and tuples besides Numeric arrays.
3956
3961
3957 * IPython/Prompts.py (CachedOutput.__call__): Added output
3962 * IPython/Prompts.py (CachedOutput.__call__): Added output
3958 supression for input ending with ';'. Similar to Mathematica and
3963 supression for input ending with ';'. Similar to Mathematica and
3959 Matlab. The _* vars and Out[] list are still updated, just like
3964 Matlab. The _* vars and Out[] list are still updated, just like
3960 Mathematica behaves.
3965 Mathematica behaves.
3961
3966
3962 2002-06-25 Fernando Perez <fperez@colorado.edu>
3967 2002-06-25 Fernando Perez <fperez@colorado.edu>
3963
3968
3964 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
3969 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
3965 .ini extensions for profiels under Windows.
3970 .ini extensions for profiels under Windows.
3966
3971
3967 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
3972 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
3968 string form. Fix contributed by Alexander Schmolck
3973 string form. Fix contributed by Alexander Schmolck
3969 <a.schmolck-AT-gmx.net>
3974 <a.schmolck-AT-gmx.net>
3970
3975
3971 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
3976 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
3972 pre-configured Gnuplot instance.
3977 pre-configured Gnuplot instance.
3973
3978
3974 2002-06-21 Fernando Perez <fperez@colorado.edu>
3979 2002-06-21 Fernando Perez <fperez@colorado.edu>
3975
3980
3976 * IPython/numutils.py (exp_safe): new function, works around the
3981 * IPython/numutils.py (exp_safe): new function, works around the
3977 underflow problems in Numeric.
3982 underflow problems in Numeric.
3978 (log2): New fn. Safe log in base 2: returns exact integer answer
3983 (log2): New fn. Safe log in base 2: returns exact integer answer
3979 for exact integer powers of 2.
3984 for exact integer powers of 2.
3980
3985
3981 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
3986 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
3982 properly.
3987 properly.
3983
3988
3984 2002-06-20 Fernando Perez <fperez@colorado.edu>
3989 2002-06-20 Fernando Perez <fperez@colorado.edu>
3985
3990
3986 * IPython/genutils.py (timing): new function like
3991 * IPython/genutils.py (timing): new function like
3987 Mathematica's. Similar to time_test, but returns more info.
3992 Mathematica's. Similar to time_test, but returns more info.
3988
3993
3989 2002-06-18 Fernando Perez <fperez@colorado.edu>
3994 2002-06-18 Fernando Perez <fperez@colorado.edu>
3990
3995
3991 * IPython/Magic.py (Magic.magic_save): modified @save and @r
3996 * IPython/Magic.py (Magic.magic_save): modified @save and @r
3992 according to Mike Heeter's suggestions.
3997 according to Mike Heeter's suggestions.
3993
3998
3994 2002-06-16 Fernando Perez <fperez@colorado.edu>
3999 2002-06-16 Fernando Perez <fperez@colorado.edu>
3995
4000
3996 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
4001 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
3997 system. GnuplotMagic is gone as a user-directory option. New files
4002 system. GnuplotMagic is gone as a user-directory option. New files
3998 make it easier to use all the gnuplot stuff both from external
4003 make it easier to use all the gnuplot stuff both from external
3999 programs as well as from IPython. Had to rewrite part of
4004 programs as well as from IPython. Had to rewrite part of
4000 hardcopy() b/c of a strange bug: often the ps files simply don't
4005 hardcopy() b/c of a strange bug: often the ps files simply don't
4001 get created, and require a repeat of the command (often several
4006 get created, and require a repeat of the command (often several
4002 times).
4007 times).
4003
4008
4004 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
4009 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
4005 resolve output channel at call time, so that if sys.stderr has
4010 resolve output channel at call time, so that if sys.stderr has
4006 been redirected by user this gets honored.
4011 been redirected by user this gets honored.
4007
4012
4008 2002-06-13 Fernando Perez <fperez@colorado.edu>
4013 2002-06-13 Fernando Perez <fperez@colorado.edu>
4009
4014
4010 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
4015 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
4011 IPShell. Kept a copy with the old names to avoid breaking people's
4016 IPShell. Kept a copy with the old names to avoid breaking people's
4012 embedded code.
4017 embedded code.
4013
4018
4014 * IPython/ipython: simplified it to the bare minimum after
4019 * IPython/ipython: simplified it to the bare minimum after
4015 Holger's suggestions. Added info about how to use it in
4020 Holger's suggestions. Added info about how to use it in
4016 PYTHONSTARTUP.
4021 PYTHONSTARTUP.
4017
4022
4018 * IPython/Shell.py (IPythonShell): changed the options passing
4023 * IPython/Shell.py (IPythonShell): changed the options passing
4019 from a string with funky %s replacements to a straight list. Maybe
4024 from a string with funky %s replacements to a straight list. Maybe
4020 a bit more typing, but it follows sys.argv conventions, so there's
4025 a bit more typing, but it follows sys.argv conventions, so there's
4021 less special-casing to remember.
4026 less special-casing to remember.
4022
4027
4023 2002-06-12 Fernando Perez <fperez@colorado.edu>
4028 2002-06-12 Fernando Perez <fperez@colorado.edu>
4024
4029
4025 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
4030 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
4026 command. Thanks to a suggestion by Mike Heeter.
4031 command. Thanks to a suggestion by Mike Heeter.
4027 (Magic.magic_pfile): added behavior to look at filenames if given
4032 (Magic.magic_pfile): added behavior to look at filenames if given
4028 arg is not a defined object.
4033 arg is not a defined object.
4029 (Magic.magic_save): New @save function to save code snippets. Also
4034 (Magic.magic_save): New @save function to save code snippets. Also
4030 a Mike Heeter idea.
4035 a Mike Heeter idea.
4031
4036
4032 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
4037 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
4033 plot() and replot(). Much more convenient now, especially for
4038 plot() and replot(). Much more convenient now, especially for
4034 interactive use.
4039 interactive use.
4035
4040
4036 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
4041 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
4037 filenames.
4042 filenames.
4038
4043
4039 2002-06-02 Fernando Perez <fperez@colorado.edu>
4044 2002-06-02 Fernando Perez <fperez@colorado.edu>
4040
4045
4041 * IPython/Struct.py (Struct.__init__): modified to admit
4046 * IPython/Struct.py (Struct.__init__): modified to admit
4042 initialization via another struct.
4047 initialization via another struct.
4043
4048
4044 * IPython/genutils.py (SystemExec.__init__): New stateful
4049 * IPython/genutils.py (SystemExec.__init__): New stateful
4045 interface to xsys and bq. Useful for writing system scripts.
4050 interface to xsys and bq. Useful for writing system scripts.
4046
4051
4047 2002-05-30 Fernando Perez <fperez@colorado.edu>
4052 2002-05-30 Fernando Perez <fperez@colorado.edu>
4048
4053
4049 * MANIFEST.in: Changed docfile selection to exclude all the lyx
4054 * MANIFEST.in: Changed docfile selection to exclude all the lyx
4050 documents. This will make the user download smaller (it's getting
4055 documents. This will make the user download smaller (it's getting
4051 too big).
4056 too big).
4052
4057
4053 2002-05-29 Fernando Perez <fperez@colorado.edu>
4058 2002-05-29 Fernando Perez <fperez@colorado.edu>
4054
4059
4055 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
4060 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
4056 fix problems with shelve and pickle. Seems to work, but I don't
4061 fix problems with shelve and pickle. Seems to work, but I don't
4057 know if corner cases break it. Thanks to Mike Heeter
4062 know if corner cases break it. Thanks to Mike Heeter
4058 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
4063 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
4059
4064
4060 2002-05-24 Fernando Perez <fperez@colorado.edu>
4065 2002-05-24 Fernando Perez <fperez@colorado.edu>
4061
4066
4062 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
4067 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
4063 macros having broken.
4068 macros having broken.
4064
4069
4065 2002-05-21 Fernando Perez <fperez@colorado.edu>
4070 2002-05-21 Fernando Perez <fperez@colorado.edu>
4066
4071
4067 * IPython/Magic.py (Magic.magic_logstart): fixed recently
4072 * IPython/Magic.py (Magic.magic_logstart): fixed recently
4068 introduced logging bug: all history before logging started was
4073 introduced logging bug: all history before logging started was
4069 being written one character per line! This came from the redesign
4074 being written one character per line! This came from the redesign
4070 of the input history as a special list which slices to strings,
4075 of the input history as a special list which slices to strings,
4071 not to lists.
4076 not to lists.
4072
4077
4073 2002-05-20 Fernando Perez <fperez@colorado.edu>
4078 2002-05-20 Fernando Perez <fperez@colorado.edu>
4074
4079
4075 * IPython/Prompts.py (CachedOutput.__init__): made the color table
4080 * IPython/Prompts.py (CachedOutput.__init__): made the color table
4076 be an attribute of all classes in this module. The design of these
4081 be an attribute of all classes in this module. The design of these
4077 classes needs some serious overhauling.
4082 classes needs some serious overhauling.
4078
4083
4079 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
4084 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
4080 which was ignoring '_' in option names.
4085 which was ignoring '_' in option names.
4081
4086
4082 * IPython/ultraTB.py (FormattedTB.__init__): Changed
4087 * IPython/ultraTB.py (FormattedTB.__init__): Changed
4083 'Verbose_novars' to 'Context' and made it the new default. It's a
4088 'Verbose_novars' to 'Context' and made it the new default. It's a
4084 bit more readable and also safer than verbose.
4089 bit more readable and also safer than verbose.
4085
4090
4086 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
4091 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
4087 triple-quoted strings.
4092 triple-quoted strings.
4088
4093
4089 * IPython/OInspect.py (__all__): new module exposing the object
4094 * IPython/OInspect.py (__all__): new module exposing the object
4090 introspection facilities. Now the corresponding magics are dummy
4095 introspection facilities. Now the corresponding magics are dummy
4091 wrappers around this. Having this module will make it much easier
4096 wrappers around this. Having this module will make it much easier
4092 to put these functions into our modified pdb.
4097 to put these functions into our modified pdb.
4093 This new object inspector system uses the new colorizing module,
4098 This new object inspector system uses the new colorizing module,
4094 so source code and other things are nicely syntax highlighted.
4099 so source code and other things are nicely syntax highlighted.
4095
4100
4096 2002-05-18 Fernando Perez <fperez@colorado.edu>
4101 2002-05-18 Fernando Perez <fperez@colorado.edu>
4097
4102
4098 * IPython/ColorANSI.py: Split the coloring tools into a separate
4103 * IPython/ColorANSI.py: Split the coloring tools into a separate
4099 module so I can use them in other code easier (they were part of
4104 module so I can use them in other code easier (they were part of
4100 ultraTB).
4105 ultraTB).
4101
4106
4102 2002-05-17 Fernando Perez <fperez@colorado.edu>
4107 2002-05-17 Fernando Perez <fperez@colorado.edu>
4103
4108
4104 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
4109 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
4105 fixed it to set the global 'g' also to the called instance, as
4110 fixed it to set the global 'g' also to the called instance, as
4106 long as 'g' was still a gnuplot instance (so it doesn't overwrite
4111 long as 'g' was still a gnuplot instance (so it doesn't overwrite
4107 user's 'g' variables).
4112 user's 'g' variables).
4108
4113
4109 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
4114 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
4110 global variables (aliases to _ih,_oh) so that users which expect
4115 global variables (aliases to _ih,_oh) so that users which expect
4111 In[5] or Out[7] to work aren't unpleasantly surprised.
4116 In[5] or Out[7] to work aren't unpleasantly surprised.
4112 (InputList.__getslice__): new class to allow executing slices of
4117 (InputList.__getslice__): new class to allow executing slices of
4113 input history directly. Very simple class, complements the use of
4118 input history directly. Very simple class, complements the use of
4114 macros.
4119 macros.
4115
4120
4116 2002-05-16 Fernando Perez <fperez@colorado.edu>
4121 2002-05-16 Fernando Perez <fperez@colorado.edu>
4117
4122
4118 * setup.py (docdirbase): make doc directory be just doc/IPython
4123 * setup.py (docdirbase): make doc directory be just doc/IPython
4119 without version numbers, it will reduce clutter for users.
4124 without version numbers, it will reduce clutter for users.
4120
4125
4121 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
4126 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
4122 execfile call to prevent possible memory leak. See for details:
4127 execfile call to prevent possible memory leak. See for details:
4123 http://mail.python.org/pipermail/python-list/2002-February/088476.html
4128 http://mail.python.org/pipermail/python-list/2002-February/088476.html
4124
4129
4125 2002-05-15 Fernando Perez <fperez@colorado.edu>
4130 2002-05-15 Fernando Perez <fperez@colorado.edu>
4126
4131
4127 * IPython/Magic.py (Magic.magic_psource): made the object
4132 * IPython/Magic.py (Magic.magic_psource): made the object
4128 introspection names be more standard: pdoc, pdef, pfile and
4133 introspection names be more standard: pdoc, pdef, pfile and
4129 psource. They all print/page their output, and it makes
4134 psource. They all print/page their output, and it makes
4130 remembering them easier. Kept old names for compatibility as
4135 remembering them easier. Kept old names for compatibility as
4131 aliases.
4136 aliases.
4132
4137
4133 2002-05-14 Fernando Perez <fperez@colorado.edu>
4138 2002-05-14 Fernando Perez <fperez@colorado.edu>
4134
4139
4135 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
4140 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
4136 what the mouse problem was. The trick is to use gnuplot with temp
4141 what the mouse problem was. The trick is to use gnuplot with temp
4137 files and NOT with pipes (for data communication), because having
4142 files and NOT with pipes (for data communication), because having
4138 both pipes and the mouse on is bad news.
4143 both pipes and the mouse on is bad news.
4139
4144
4140 2002-05-13 Fernando Perez <fperez@colorado.edu>
4145 2002-05-13 Fernando Perez <fperez@colorado.edu>
4141
4146
4142 * IPython/Magic.py (Magic._ofind): fixed namespace order search
4147 * IPython/Magic.py (Magic._ofind): fixed namespace order search
4143 bug. Information would be reported about builtins even when
4148 bug. Information would be reported about builtins even when
4144 user-defined functions overrode them.
4149 user-defined functions overrode them.
4145
4150
4146 2002-05-11 Fernando Perez <fperez@colorado.edu>
4151 2002-05-11 Fernando Perez <fperez@colorado.edu>
4147
4152
4148 * IPython/__init__.py (__all__): removed FlexCompleter from
4153 * IPython/__init__.py (__all__): removed FlexCompleter from
4149 __all__ so that things don't fail in platforms without readline.
4154 __all__ so that things don't fail in platforms without readline.
4150
4155
4151 2002-05-10 Fernando Perez <fperez@colorado.edu>
4156 2002-05-10 Fernando Perez <fperez@colorado.edu>
4152
4157
4153 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
4158 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
4154 it requires Numeric, effectively making Numeric a dependency for
4159 it requires Numeric, effectively making Numeric a dependency for
4155 IPython.
4160 IPython.
4156
4161
4157 * Released 0.2.13
4162 * Released 0.2.13
4158
4163
4159 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
4164 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
4160 profiler interface. Now all the major options from the profiler
4165 profiler interface. Now all the major options from the profiler
4161 module are directly supported in IPython, both for single
4166 module are directly supported in IPython, both for single
4162 expressions (@prun) and for full programs (@run -p).
4167 expressions (@prun) and for full programs (@run -p).
4163
4168
4164 2002-05-09 Fernando Perez <fperez@colorado.edu>
4169 2002-05-09 Fernando Perez <fperez@colorado.edu>
4165
4170
4166 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
4171 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
4167 magic properly formatted for screen.
4172 magic properly formatted for screen.
4168
4173
4169 * setup.py (make_shortcut): Changed things to put pdf version in
4174 * setup.py (make_shortcut): Changed things to put pdf version in
4170 doc/ instead of doc/manual (had to change lyxport a bit).
4175 doc/ instead of doc/manual (had to change lyxport a bit).
4171
4176
4172 * IPython/Magic.py (Profile.string_stats): made profile runs go
4177 * IPython/Magic.py (Profile.string_stats): made profile runs go
4173 through pager (they are long and a pager allows searching, saving,
4178 through pager (they are long and a pager allows searching, saving,
4174 etc.)
4179 etc.)
4175
4180
4176 2002-05-08 Fernando Perez <fperez@colorado.edu>
4181 2002-05-08 Fernando Perez <fperez@colorado.edu>
4177
4182
4178 * Released 0.2.12
4183 * Released 0.2.12
4179
4184
4180 2002-05-06 Fernando Perez <fperez@colorado.edu>
4185 2002-05-06 Fernando Perez <fperez@colorado.edu>
4181
4186
4182 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
4187 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
4183 introduced); 'hist n1 n2' was broken.
4188 introduced); 'hist n1 n2' was broken.
4184 (Magic.magic_pdb): added optional on/off arguments to @pdb
4189 (Magic.magic_pdb): added optional on/off arguments to @pdb
4185 (Magic.magic_run): added option -i to @run, which executes code in
4190 (Magic.magic_run): added option -i to @run, which executes code in
4186 the IPython namespace instead of a clean one. Also added @irun as
4191 the IPython namespace instead of a clean one. Also added @irun as
4187 an alias to @run -i.
4192 an alias to @run -i.
4188
4193
4189 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
4194 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
4190 fixed (it didn't really do anything, the namespaces were wrong).
4195 fixed (it didn't really do anything, the namespaces were wrong).
4191
4196
4192 * IPython/Debugger.py (__init__): Added workaround for python 2.1
4197 * IPython/Debugger.py (__init__): Added workaround for python 2.1
4193
4198
4194 * IPython/__init__.py (__all__): Fixed package namespace, now
4199 * IPython/__init__.py (__all__): Fixed package namespace, now
4195 'import IPython' does give access to IPython.<all> as
4200 'import IPython' does give access to IPython.<all> as
4196 expected. Also renamed __release__ to Release.
4201 expected. Also renamed __release__ to Release.
4197
4202
4198 * IPython/Debugger.py (__license__): created new Pdb class which
4203 * IPython/Debugger.py (__license__): created new Pdb class which
4199 functions like a drop-in for the normal pdb.Pdb but does NOT
4204 functions like a drop-in for the normal pdb.Pdb but does NOT
4200 import readline by default. This way it doesn't muck up IPython's
4205 import readline by default. This way it doesn't muck up IPython's
4201 readline handling, and now tab-completion finally works in the
4206 readline handling, and now tab-completion finally works in the
4202 debugger -- sort of. It completes things globally visible, but the
4207 debugger -- sort of. It completes things globally visible, but the
4203 completer doesn't track the stack as pdb walks it. That's a bit
4208 completer doesn't track the stack as pdb walks it. That's a bit
4204 tricky, and I'll have to implement it later.
4209 tricky, and I'll have to implement it later.
4205
4210
4206 2002-05-05 Fernando Perez <fperez@colorado.edu>
4211 2002-05-05 Fernando Perez <fperez@colorado.edu>
4207
4212
4208 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
4213 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
4209 magic docstrings when printed via ? (explicit \'s were being
4214 magic docstrings when printed via ? (explicit \'s were being
4210 printed).
4215 printed).
4211
4216
4212 * IPython/ipmaker.py (make_IPython): fixed namespace
4217 * IPython/ipmaker.py (make_IPython): fixed namespace
4213 identification bug. Now variables loaded via logs or command-line
4218 identification bug. Now variables loaded via logs or command-line
4214 files are recognized in the interactive namespace by @who.
4219 files are recognized in the interactive namespace by @who.
4215
4220
4216 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
4221 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
4217 log replay system stemming from the string form of Structs.
4222 log replay system stemming from the string form of Structs.
4218
4223
4219 * IPython/Magic.py (Macro.__init__): improved macros to properly
4224 * IPython/Magic.py (Macro.__init__): improved macros to properly
4220 handle magic commands in them.
4225 handle magic commands in them.
4221 (Magic.magic_logstart): usernames are now expanded so 'logstart
4226 (Magic.magic_logstart): usernames are now expanded so 'logstart
4222 ~/mylog' now works.
4227 ~/mylog' now works.
4223
4228
4224 * IPython/iplib.py (complete): fixed bug where paths starting with
4229 * IPython/iplib.py (complete): fixed bug where paths starting with
4225 '/' would be completed as magic names.
4230 '/' would be completed as magic names.
4226
4231
4227 2002-05-04 Fernando Perez <fperez@colorado.edu>
4232 2002-05-04 Fernando Perez <fperez@colorado.edu>
4228
4233
4229 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
4234 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
4230 allow running full programs under the profiler's control.
4235 allow running full programs under the profiler's control.
4231
4236
4232 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
4237 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
4233 mode to report exceptions verbosely but without formatting
4238 mode to report exceptions verbosely but without formatting
4234 variables. This addresses the issue of ipython 'freezing' (it's
4239 variables. This addresses the issue of ipython 'freezing' (it's
4235 not frozen, but caught in an expensive formatting loop) when huge
4240 not frozen, but caught in an expensive formatting loop) when huge
4236 variables are in the context of an exception.
4241 variables are in the context of an exception.
4237 (VerboseTB.text): Added '--->' markers at line where exception was
4242 (VerboseTB.text): Added '--->' markers at line where exception was
4238 triggered. Much clearer to read, especially in NoColor modes.
4243 triggered. Much clearer to read, especially in NoColor modes.
4239
4244
4240 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
4245 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
4241 implemented in reverse when changing to the new parse_options().
4246 implemented in reverse when changing to the new parse_options().
4242
4247
4243 2002-05-03 Fernando Perez <fperez@colorado.edu>
4248 2002-05-03 Fernando Perez <fperez@colorado.edu>
4244
4249
4245 * IPython/Magic.py (Magic.parse_options): new function so that
4250 * IPython/Magic.py (Magic.parse_options): new function so that
4246 magics can parse options easier.
4251 magics can parse options easier.
4247 (Magic.magic_prun): new function similar to profile.run(),
4252 (Magic.magic_prun): new function similar to profile.run(),
4248 suggested by Chris Hart.
4253 suggested by Chris Hart.
4249 (Magic.magic_cd): fixed behavior so that it only changes if
4254 (Magic.magic_cd): fixed behavior so that it only changes if
4250 directory actually is in history.
4255 directory actually is in history.
4251
4256
4252 * IPython/usage.py (__doc__): added information about potential
4257 * IPython/usage.py (__doc__): added information about potential
4253 slowness of Verbose exception mode when there are huge data
4258 slowness of Verbose exception mode when there are huge data
4254 structures to be formatted (thanks to Archie Paulson).
4259 structures to be formatted (thanks to Archie Paulson).
4255
4260
4256 * IPython/ipmaker.py (make_IPython): Changed default logging
4261 * IPython/ipmaker.py (make_IPython): Changed default logging
4257 (when simply called with -log) to use curr_dir/ipython.log in
4262 (when simply called with -log) to use curr_dir/ipython.log in
4258 rotate mode. Fixed crash which was occuring with -log before
4263 rotate mode. Fixed crash which was occuring with -log before
4259 (thanks to Jim Boyle).
4264 (thanks to Jim Boyle).
4260
4265
4261 2002-05-01 Fernando Perez <fperez@colorado.edu>
4266 2002-05-01 Fernando Perez <fperez@colorado.edu>
4262
4267
4263 * Released 0.2.11 for these fixes (mainly the ultraTB one which
4268 * Released 0.2.11 for these fixes (mainly the ultraTB one which
4264 was nasty -- though somewhat of a corner case).
4269 was nasty -- though somewhat of a corner case).
4265
4270
4266 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
4271 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
4267 text (was a bug).
4272 text (was a bug).
4268
4273
4269 2002-04-30 Fernando Perez <fperez@colorado.edu>
4274 2002-04-30 Fernando Perez <fperez@colorado.edu>
4270
4275
4271 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
4276 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
4272 a print after ^D or ^C from the user so that the In[] prompt
4277 a print after ^D or ^C from the user so that the In[] prompt
4273 doesn't over-run the gnuplot one.
4278 doesn't over-run the gnuplot one.
4274
4279
4275 2002-04-29 Fernando Perez <fperez@colorado.edu>
4280 2002-04-29 Fernando Perez <fperez@colorado.edu>
4276
4281
4277 * Released 0.2.10
4282 * Released 0.2.10
4278
4283
4279 * IPython/__release__.py (version): get date dynamically.
4284 * IPython/__release__.py (version): get date dynamically.
4280
4285
4281 * Misc. documentation updates thanks to Arnd's comments. Also ran
4286 * Misc. documentation updates thanks to Arnd's comments. Also ran
4282 a full spellcheck on the manual (hadn't been done in a while).
4287 a full spellcheck on the manual (hadn't been done in a while).
4283
4288
4284 2002-04-27 Fernando Perez <fperez@colorado.edu>
4289 2002-04-27 Fernando Perez <fperez@colorado.edu>
4285
4290
4286 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
4291 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
4287 starting a log in mid-session would reset the input history list.
4292 starting a log in mid-session would reset the input history list.
4288
4293
4289 2002-04-26 Fernando Perez <fperez@colorado.edu>
4294 2002-04-26 Fernando Perez <fperez@colorado.edu>
4290
4295
4291 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
4296 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
4292 all files were being included in an update. Now anything in
4297 all files were being included in an update. Now anything in
4293 UserConfig that matches [A-Za-z]*.py will go (this excludes
4298 UserConfig that matches [A-Za-z]*.py will go (this excludes
4294 __init__.py)
4299 __init__.py)
4295
4300
4296 2002-04-25 Fernando Perez <fperez@colorado.edu>
4301 2002-04-25 Fernando Perez <fperez@colorado.edu>
4297
4302
4298 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
4303 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
4299 to __builtins__ so that any form of embedded or imported code can
4304 to __builtins__ so that any form of embedded or imported code can
4300 test for being inside IPython.
4305 test for being inside IPython.
4301
4306
4302 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
4307 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
4303 changed to GnuplotMagic because it's now an importable module,
4308 changed to GnuplotMagic because it's now an importable module,
4304 this makes the name follow that of the standard Gnuplot module.
4309 this makes the name follow that of the standard Gnuplot module.
4305 GnuplotMagic can now be loaded at any time in mid-session.
4310 GnuplotMagic can now be loaded at any time in mid-session.
4306
4311
4307 2002-04-24 Fernando Perez <fperez@colorado.edu>
4312 2002-04-24 Fernando Perez <fperez@colorado.edu>
4308
4313
4309 * IPython/numutils.py: removed SIUnits. It doesn't properly set
4314 * IPython/numutils.py: removed SIUnits. It doesn't properly set
4310 the globals (IPython has its own namespace) and the
4315 the globals (IPython has its own namespace) and the
4311 PhysicalQuantity stuff is much better anyway.
4316 PhysicalQuantity stuff is much better anyway.
4312
4317
4313 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
4318 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
4314 embedding example to standard user directory for
4319 embedding example to standard user directory for
4315 distribution. Also put it in the manual.
4320 distribution. Also put it in the manual.
4316
4321
4317 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
4322 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
4318 instance as first argument (so it doesn't rely on some obscure
4323 instance as first argument (so it doesn't rely on some obscure
4319 hidden global).
4324 hidden global).
4320
4325
4321 * IPython/UserConfig/ipythonrc.py: put () back in accepted
4326 * IPython/UserConfig/ipythonrc.py: put () back in accepted
4322 delimiters. While it prevents ().TAB from working, it allows
4327 delimiters. While it prevents ().TAB from working, it allows
4323 completions in open (... expressions. This is by far a more common
4328 completions in open (... expressions. This is by far a more common
4324 case.
4329 case.
4325
4330
4326 2002-04-23 Fernando Perez <fperez@colorado.edu>
4331 2002-04-23 Fernando Perez <fperez@colorado.edu>
4327
4332
4328 * IPython/Extensions/InterpreterPasteInput.py: new
4333 * IPython/Extensions/InterpreterPasteInput.py: new
4329 syntax-processing module for pasting lines with >>> or ... at the
4334 syntax-processing module for pasting lines with >>> or ... at the
4330 start.
4335 start.
4331
4336
4332 * IPython/Extensions/PhysicalQ_Interactive.py
4337 * IPython/Extensions/PhysicalQ_Interactive.py
4333 (PhysicalQuantityInteractive.__int__): fixed to work with either
4338 (PhysicalQuantityInteractive.__int__): fixed to work with either
4334 Numeric or math.
4339 Numeric or math.
4335
4340
4336 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
4341 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
4337 provided profiles. Now we have:
4342 provided profiles. Now we have:
4338 -math -> math module as * and cmath with its own namespace.
4343 -math -> math module as * and cmath with its own namespace.
4339 -numeric -> Numeric as *, plus gnuplot & grace
4344 -numeric -> Numeric as *, plus gnuplot & grace
4340 -physics -> same as before
4345 -physics -> same as before
4341
4346
4342 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
4347 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
4343 user-defined magics wouldn't be found by @magic if they were
4348 user-defined magics wouldn't be found by @magic if they were
4344 defined as class methods. Also cleaned up the namespace search
4349 defined as class methods. Also cleaned up the namespace search
4345 logic and the string building (to use %s instead of many repeated
4350 logic and the string building (to use %s instead of many repeated
4346 string adds).
4351 string adds).
4347
4352
4348 * IPython/UserConfig/example-magic.py (magic_foo): updated example
4353 * IPython/UserConfig/example-magic.py (magic_foo): updated example
4349 of user-defined magics to operate with class methods (cleaner, in
4354 of user-defined magics to operate with class methods (cleaner, in
4350 line with the gnuplot code).
4355 line with the gnuplot code).
4351
4356
4352 2002-04-22 Fernando Perez <fperez@colorado.edu>
4357 2002-04-22 Fernando Perez <fperez@colorado.edu>
4353
4358
4354 * setup.py: updated dependency list so that manual is updated when
4359 * setup.py: updated dependency list so that manual is updated when
4355 all included files change.
4360 all included files change.
4356
4361
4357 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
4362 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
4358 the delimiter removal option (the fix is ugly right now).
4363 the delimiter removal option (the fix is ugly right now).
4359
4364
4360 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
4365 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
4361 all of the math profile (quicker loading, no conflict between
4366 all of the math profile (quicker loading, no conflict between
4362 g-9.8 and g-gnuplot).
4367 g-9.8 and g-gnuplot).
4363
4368
4364 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
4369 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
4365 name of post-mortem files to IPython_crash_report.txt.
4370 name of post-mortem files to IPython_crash_report.txt.
4366
4371
4367 * Cleanup/update of the docs. Added all the new readline info and
4372 * Cleanup/update of the docs. Added all the new readline info and
4368 formatted all lists as 'real lists'.
4373 formatted all lists as 'real lists'.
4369
4374
4370 * IPython/ipmaker.py (make_IPython): removed now-obsolete
4375 * IPython/ipmaker.py (make_IPython): removed now-obsolete
4371 tab-completion options, since the full readline parse_and_bind is
4376 tab-completion options, since the full readline parse_and_bind is
4372 now accessible.
4377 now accessible.
4373
4378
4374 * IPython/iplib.py (InteractiveShell.init_readline): Changed
4379 * IPython/iplib.py (InteractiveShell.init_readline): Changed
4375 handling of readline options. Now users can specify any string to
4380 handling of readline options. Now users can specify any string to
4376 be passed to parse_and_bind(), as well as the delimiters to be
4381 be passed to parse_and_bind(), as well as the delimiters to be
4377 removed.
4382 removed.
4378 (InteractiveShell.__init__): Added __name__ to the global
4383 (InteractiveShell.__init__): Added __name__ to the global
4379 namespace so that things like Itpl which rely on its existence
4384 namespace so that things like Itpl which rely on its existence
4380 don't crash.
4385 don't crash.
4381 (InteractiveShell._prefilter): Defined the default with a _ so
4386 (InteractiveShell._prefilter): Defined the default with a _ so
4382 that prefilter() is easier to override, while the default one
4387 that prefilter() is easier to override, while the default one
4383 remains available.
4388 remains available.
4384
4389
4385 2002-04-18 Fernando Perez <fperez@colorado.edu>
4390 2002-04-18 Fernando Perez <fperez@colorado.edu>
4386
4391
4387 * Added information about pdb in the docs.
4392 * Added information about pdb in the docs.
4388
4393
4389 2002-04-17 Fernando Perez <fperez@colorado.edu>
4394 2002-04-17 Fernando Perez <fperez@colorado.edu>
4390
4395
4391 * IPython/ipmaker.py (make_IPython): added rc_override option to
4396 * IPython/ipmaker.py (make_IPython): added rc_override option to
4392 allow passing config options at creation time which may override
4397 allow passing config options at creation time which may override
4393 anything set in the config files or command line. This is
4398 anything set in the config files or command line. This is
4394 particularly useful for configuring embedded instances.
4399 particularly useful for configuring embedded instances.
4395
4400
4396 2002-04-15 Fernando Perez <fperez@colorado.edu>
4401 2002-04-15 Fernando Perez <fperez@colorado.edu>
4397
4402
4398 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
4403 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
4399 crash embedded instances because of the input cache falling out of
4404 crash embedded instances because of the input cache falling out of
4400 sync with the output counter.
4405 sync with the output counter.
4401
4406
4402 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
4407 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
4403 mode which calls pdb after an uncaught exception in IPython itself.
4408 mode which calls pdb after an uncaught exception in IPython itself.
4404
4409
4405 2002-04-14 Fernando Perez <fperez@colorado.edu>
4410 2002-04-14 Fernando Perez <fperez@colorado.edu>
4406
4411
4407 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
4412 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
4408 readline, fix it back after each call.
4413 readline, fix it back after each call.
4409
4414
4410 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
4415 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
4411 method to force all access via __call__(), which guarantees that
4416 method to force all access via __call__(), which guarantees that
4412 traceback references are properly deleted.
4417 traceback references are properly deleted.
4413
4418
4414 * IPython/Prompts.py (CachedOutput._display): minor fixes to
4419 * IPython/Prompts.py (CachedOutput._display): minor fixes to
4415 improve printing when pprint is in use.
4420 improve printing when pprint is in use.
4416
4421
4417 2002-04-13 Fernando Perez <fperez@colorado.edu>
4422 2002-04-13 Fernando Perez <fperez@colorado.edu>
4418
4423
4419 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
4424 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
4420 exceptions aren't caught anymore. If the user triggers one, he
4425 exceptions aren't caught anymore. If the user triggers one, he
4421 should know why he's doing it and it should go all the way up,
4426 should know why he's doing it and it should go all the way up,
4422 just like any other exception. So now @abort will fully kill the
4427 just like any other exception. So now @abort will fully kill the
4423 embedded interpreter and the embedding code (unless that happens
4428 embedded interpreter and the embedding code (unless that happens
4424 to catch SystemExit).
4429 to catch SystemExit).
4425
4430
4426 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
4431 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
4427 and a debugger() method to invoke the interactive pdb debugger
4432 and a debugger() method to invoke the interactive pdb debugger
4428 after printing exception information. Also added the corresponding
4433 after printing exception information. Also added the corresponding
4429 -pdb option and @pdb magic to control this feature, and updated
4434 -pdb option and @pdb magic to control this feature, and updated
4430 the docs. After a suggestion from Christopher Hart
4435 the docs. After a suggestion from Christopher Hart
4431 (hart-AT-caltech.edu).
4436 (hart-AT-caltech.edu).
4432
4437
4433 2002-04-12 Fernando Perez <fperez@colorado.edu>
4438 2002-04-12 Fernando Perez <fperez@colorado.edu>
4434
4439
4435 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
4440 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
4436 the exception handlers defined by the user (not the CrashHandler)
4441 the exception handlers defined by the user (not the CrashHandler)
4437 so that user exceptions don't trigger an ipython bug report.
4442 so that user exceptions don't trigger an ipython bug report.
4438
4443
4439 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
4444 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
4440 configurable (it should have always been so).
4445 configurable (it should have always been so).
4441
4446
4442 2002-03-26 Fernando Perez <fperez@colorado.edu>
4447 2002-03-26 Fernando Perez <fperez@colorado.edu>
4443
4448
4444 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
4449 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
4445 and there to fix embedding namespace issues. This should all be
4450 and there to fix embedding namespace issues. This should all be
4446 done in a more elegant way.
4451 done in a more elegant way.
4447
4452
4448 2002-03-25 Fernando Perez <fperez@colorado.edu>
4453 2002-03-25 Fernando Perez <fperez@colorado.edu>
4449
4454
4450 * IPython/genutils.py (get_home_dir): Try to make it work under
4455 * IPython/genutils.py (get_home_dir): Try to make it work under
4451 win9x also.
4456 win9x also.
4452
4457
4453 2002-03-20 Fernando Perez <fperez@colorado.edu>
4458 2002-03-20 Fernando Perez <fperez@colorado.edu>
4454
4459
4455 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
4460 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
4456 sys.displayhook untouched upon __init__.
4461 sys.displayhook untouched upon __init__.
4457
4462
4458 2002-03-19 Fernando Perez <fperez@colorado.edu>
4463 2002-03-19 Fernando Perez <fperez@colorado.edu>
4459
4464
4460 * Released 0.2.9 (for embedding bug, basically).
4465 * Released 0.2.9 (for embedding bug, basically).
4461
4466
4462 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
4467 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
4463 exceptions so that enclosing shell's state can be restored.
4468 exceptions so that enclosing shell's state can be restored.
4464
4469
4465 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
4470 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
4466 naming conventions in the .ipython/ dir.
4471 naming conventions in the .ipython/ dir.
4467
4472
4468 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
4473 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
4469 from delimiters list so filenames with - in them get expanded.
4474 from delimiters list so filenames with - in them get expanded.
4470
4475
4471 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
4476 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
4472 sys.displayhook not being properly restored after an embedded call.
4477 sys.displayhook not being properly restored after an embedded call.
4473
4478
4474 2002-03-18 Fernando Perez <fperez@colorado.edu>
4479 2002-03-18 Fernando Perez <fperez@colorado.edu>
4475
4480
4476 * Released 0.2.8
4481 * Released 0.2.8
4477
4482
4478 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
4483 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
4479 some files weren't being included in a -upgrade.
4484 some files weren't being included in a -upgrade.
4480 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
4485 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
4481 on' so that the first tab completes.
4486 on' so that the first tab completes.
4482 (InteractiveShell.handle_magic): fixed bug with spaces around
4487 (InteractiveShell.handle_magic): fixed bug with spaces around
4483 quotes breaking many magic commands.
4488 quotes breaking many magic commands.
4484
4489
4485 * setup.py: added note about ignoring the syntax error messages at
4490 * setup.py: added note about ignoring the syntax error messages at
4486 installation.
4491 installation.
4487
4492
4488 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
4493 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
4489 streamlining the gnuplot interface, now there's only one magic @gp.
4494 streamlining the gnuplot interface, now there's only one magic @gp.
4490
4495
4491 2002-03-17 Fernando Perez <fperez@colorado.edu>
4496 2002-03-17 Fernando Perez <fperez@colorado.edu>
4492
4497
4493 * IPython/UserConfig/magic_gnuplot.py: new name for the
4498 * IPython/UserConfig/magic_gnuplot.py: new name for the
4494 example-magic_pm.py file. Much enhanced system, now with a shell
4499 example-magic_pm.py file. Much enhanced system, now with a shell
4495 for communicating directly with gnuplot, one command at a time.
4500 for communicating directly with gnuplot, one command at a time.
4496
4501
4497 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
4502 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
4498 setting __name__=='__main__'.
4503 setting __name__=='__main__'.
4499
4504
4500 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
4505 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
4501 mini-shell for accessing gnuplot from inside ipython. Should
4506 mini-shell for accessing gnuplot from inside ipython. Should
4502 extend it later for grace access too. Inspired by Arnd's
4507 extend it later for grace access too. Inspired by Arnd's
4503 suggestion.
4508 suggestion.
4504
4509
4505 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
4510 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
4506 calling magic functions with () in their arguments. Thanks to Arnd
4511 calling magic functions with () in their arguments. Thanks to Arnd
4507 Baecker for pointing this to me.
4512 Baecker for pointing this to me.
4508
4513
4509 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
4514 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
4510 infinitely for integer or complex arrays (only worked with floats).
4515 infinitely for integer or complex arrays (only worked with floats).
4511
4516
4512 2002-03-16 Fernando Perez <fperez@colorado.edu>
4517 2002-03-16 Fernando Perez <fperez@colorado.edu>
4513
4518
4514 * setup.py: Merged setup and setup_windows into a single script
4519 * setup.py: Merged setup and setup_windows into a single script
4515 which properly handles things for windows users.
4520 which properly handles things for windows users.
4516
4521
4517 2002-03-15 Fernando Perez <fperez@colorado.edu>
4522 2002-03-15 Fernando Perez <fperez@colorado.edu>
4518
4523
4519 * Big change to the manual: now the magics are all automatically
4524 * Big change to the manual: now the magics are all automatically
4520 documented. This information is generated from their docstrings
4525 documented. This information is generated from their docstrings
4521 and put in a latex file included by the manual lyx file. This way
4526 and put in a latex file included by the manual lyx file. This way
4522 we get always up to date information for the magics. The manual
4527 we get always up to date information for the magics. The manual
4523 now also has proper version information, also auto-synced.
4528 now also has proper version information, also auto-synced.
4524
4529
4525 For this to work, an undocumented --magic_docstrings option was added.
4530 For this to work, an undocumented --magic_docstrings option was added.
4526
4531
4527 2002-03-13 Fernando Perez <fperez@colorado.edu>
4532 2002-03-13 Fernando Perez <fperez@colorado.edu>
4528
4533
4529 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
4534 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
4530 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
4535 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
4531
4536
4532 2002-03-12 Fernando Perez <fperez@colorado.edu>
4537 2002-03-12 Fernando Perez <fperez@colorado.edu>
4533
4538
4534 * IPython/ultraTB.py (TermColors): changed color escapes again to
4539 * IPython/ultraTB.py (TermColors): changed color escapes again to
4535 fix the (old, reintroduced) line-wrapping bug. Basically, if
4540 fix the (old, reintroduced) line-wrapping bug. Basically, if
4536 \001..\002 aren't given in the color escapes, lines get wrapped
4541 \001..\002 aren't given in the color escapes, lines get wrapped
4537 weirdly. But giving those screws up old xterms and emacs terms. So
4542 weirdly. But giving those screws up old xterms and emacs terms. So
4538 I added some logic for emacs terms to be ok, but I can't identify old
4543 I added some logic for emacs terms to be ok, but I can't identify old
4539 xterms separately ($TERM=='xterm' for many terminals, like konsole).
4544 xterms separately ($TERM=='xterm' for many terminals, like konsole).
4540
4545
4541 2002-03-10 Fernando Perez <fperez@colorado.edu>
4546 2002-03-10 Fernando Perez <fperez@colorado.edu>
4542
4547
4543 * IPython/usage.py (__doc__): Various documentation cleanups and
4548 * IPython/usage.py (__doc__): Various documentation cleanups and
4544 updates, both in usage docstrings and in the manual.
4549 updates, both in usage docstrings and in the manual.
4545
4550
4546 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
4551 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
4547 handling of caching. Set minimum acceptabe value for having a
4552 handling of caching. Set minimum acceptabe value for having a
4548 cache at 20 values.
4553 cache at 20 values.
4549
4554
4550 * IPython/iplib.py (InteractiveShell.user_setup): moved the
4555 * IPython/iplib.py (InteractiveShell.user_setup): moved the
4551 install_first_time function to a method, renamed it and added an
4556 install_first_time function to a method, renamed it and added an
4552 'upgrade' mode. Now people can update their config directory with
4557 'upgrade' mode. Now people can update their config directory with
4553 a simple command line switch (-upgrade, also new).
4558 a simple command line switch (-upgrade, also new).
4554
4559
4555 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
4560 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
4556 @file (convenient for automagic users under Python >= 2.2).
4561 @file (convenient for automagic users under Python >= 2.2).
4557 Removed @files (it seemed more like a plural than an abbrev. of
4562 Removed @files (it seemed more like a plural than an abbrev. of
4558 'file show').
4563 'file show').
4559
4564
4560 * IPython/iplib.py (install_first_time): Fixed crash if there were
4565 * IPython/iplib.py (install_first_time): Fixed crash if there were
4561 backup files ('~') in .ipython/ install directory.
4566 backup files ('~') in .ipython/ install directory.
4562
4567
4563 * IPython/ipmaker.py (make_IPython): fixes for new prompt
4568 * IPython/ipmaker.py (make_IPython): fixes for new prompt
4564 system. Things look fine, but these changes are fairly
4569 system. Things look fine, but these changes are fairly
4565 intrusive. Test them for a few days.
4570 intrusive. Test them for a few days.
4566
4571
4567 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
4572 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
4568 the prompts system. Now all in/out prompt strings are user
4573 the prompts system. Now all in/out prompt strings are user
4569 controllable. This is particularly useful for embedding, as one
4574 controllable. This is particularly useful for embedding, as one
4570 can tag embedded instances with particular prompts.
4575 can tag embedded instances with particular prompts.
4571
4576
4572 Also removed global use of sys.ps1/2, which now allows nested
4577 Also removed global use of sys.ps1/2, which now allows nested
4573 embeddings without any problems. Added command-line options for
4578 embeddings without any problems. Added command-line options for
4574 the prompt strings.
4579 the prompt strings.
4575
4580
4576 2002-03-08 Fernando Perez <fperez@colorado.edu>
4581 2002-03-08 Fernando Perez <fperez@colorado.edu>
4577
4582
4578 * IPython/UserConfig/example-embed-short.py (ipshell): added
4583 * IPython/UserConfig/example-embed-short.py (ipshell): added
4579 example file with the bare minimum code for embedding.
4584 example file with the bare minimum code for embedding.
4580
4585
4581 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
4586 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
4582 functionality for the embeddable shell to be activated/deactivated
4587 functionality for the embeddable shell to be activated/deactivated
4583 either globally or at each call.
4588 either globally or at each call.
4584
4589
4585 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
4590 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
4586 rewriting the prompt with '--->' for auto-inputs with proper
4591 rewriting the prompt with '--->' for auto-inputs with proper
4587 coloring. Now the previous UGLY hack in handle_auto() is gone, and
4592 coloring. Now the previous UGLY hack in handle_auto() is gone, and
4588 this is handled by the prompts class itself, as it should.
4593 this is handled by the prompts class itself, as it should.
4589
4594
4590 2002-03-05 Fernando Perez <fperez@colorado.edu>
4595 2002-03-05 Fernando Perez <fperez@colorado.edu>
4591
4596
4592 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
4597 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
4593 @logstart to avoid name clashes with the math log function.
4598 @logstart to avoid name clashes with the math log function.
4594
4599
4595 * Big updates to X/Emacs section of the manual.
4600 * Big updates to X/Emacs section of the manual.
4596
4601
4597 * Removed ipython_emacs. Milan explained to me how to pass
4602 * Removed ipython_emacs. Milan explained to me how to pass
4598 arguments to ipython through Emacs. Some day I'm going to end up
4603 arguments to ipython through Emacs. Some day I'm going to end up
4599 learning some lisp...
4604 learning some lisp...
4600
4605
4601 2002-03-04 Fernando Perez <fperez@colorado.edu>
4606 2002-03-04 Fernando Perez <fperez@colorado.edu>
4602
4607
4603 * IPython/ipython_emacs: Created script to be used as the
4608 * IPython/ipython_emacs: Created script to be used as the
4604 py-python-command Emacs variable so we can pass IPython
4609 py-python-command Emacs variable so we can pass IPython
4605 parameters. I can't figure out how to tell Emacs directly to pass
4610 parameters. I can't figure out how to tell Emacs directly to pass
4606 parameters to IPython, so a dummy shell script will do it.
4611 parameters to IPython, so a dummy shell script will do it.
4607
4612
4608 Other enhancements made for things to work better under Emacs'
4613 Other enhancements made for things to work better under Emacs'
4609 various types of terminals. Many thanks to Milan Zamazal
4614 various types of terminals. Many thanks to Milan Zamazal
4610 <pdm-AT-zamazal.org> for all the suggestions and pointers.
4615 <pdm-AT-zamazal.org> for all the suggestions and pointers.
4611
4616
4612 2002-03-01 Fernando Perez <fperez@colorado.edu>
4617 2002-03-01 Fernando Perez <fperez@colorado.edu>
4613
4618
4614 * IPython/ipmaker.py (make_IPython): added a --readline! option so
4619 * IPython/ipmaker.py (make_IPython): added a --readline! option so
4615 that loading of readline is now optional. This gives better
4620 that loading of readline is now optional. This gives better
4616 control to emacs users.
4621 control to emacs users.
4617
4622
4618 * IPython/ultraTB.py (__date__): Modified color escape sequences
4623 * IPython/ultraTB.py (__date__): Modified color escape sequences
4619 and now things work fine under xterm and in Emacs' term buffers
4624 and now things work fine under xterm and in Emacs' term buffers
4620 (though not shell ones). Well, in emacs you get colors, but all
4625 (though not shell ones). Well, in emacs you get colors, but all
4621 seem to be 'light' colors (no difference between dark and light
4626 seem to be 'light' colors (no difference between dark and light
4622 ones). But the garbage chars are gone, and also in xterms. It
4627 ones). But the garbage chars are gone, and also in xterms. It
4623 seems that now I'm using 'cleaner' ansi sequences.
4628 seems that now I'm using 'cleaner' ansi sequences.
4624
4629
4625 2002-02-21 Fernando Perez <fperez@colorado.edu>
4630 2002-02-21 Fernando Perez <fperez@colorado.edu>
4626
4631
4627 * Released 0.2.7 (mainly to publish the scoping fix).
4632 * Released 0.2.7 (mainly to publish the scoping fix).
4628
4633
4629 * IPython/Logger.py (Logger.logstate): added. A corresponding
4634 * IPython/Logger.py (Logger.logstate): added. A corresponding
4630 @logstate magic was created.
4635 @logstate magic was created.
4631
4636
4632 * IPython/Magic.py: fixed nested scoping problem under Python
4637 * IPython/Magic.py: fixed nested scoping problem under Python
4633 2.1.x (automagic wasn't working).
4638 2.1.x (automagic wasn't working).
4634
4639
4635 2002-02-20 Fernando Perez <fperez@colorado.edu>
4640 2002-02-20 Fernando Perez <fperez@colorado.edu>
4636
4641
4637 * Released 0.2.6.
4642 * Released 0.2.6.
4638
4643
4639 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
4644 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
4640 option so that logs can come out without any headers at all.
4645 option so that logs can come out without any headers at all.
4641
4646
4642 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
4647 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
4643 SciPy.
4648 SciPy.
4644
4649
4645 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
4650 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
4646 that embedded IPython calls don't require vars() to be explicitly
4651 that embedded IPython calls don't require vars() to be explicitly
4647 passed. Now they are extracted from the caller's frame (code
4652 passed. Now they are extracted from the caller's frame (code
4648 snatched from Eric Jones' weave). Added better documentation to
4653 snatched from Eric Jones' weave). Added better documentation to
4649 the section on embedding and the example file.
4654 the section on embedding and the example file.
4650
4655
4651 * IPython/genutils.py (page): Changed so that under emacs, it just
4656 * IPython/genutils.py (page): Changed so that under emacs, it just
4652 prints the string. You can then page up and down in the emacs
4657 prints the string. You can then page up and down in the emacs
4653 buffer itself. This is how the builtin help() works.
4658 buffer itself. This is how the builtin help() works.
4654
4659
4655 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
4660 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
4656 macro scoping: macros need to be executed in the user's namespace
4661 macro scoping: macros need to be executed in the user's namespace
4657 to work as if they had been typed by the user.
4662 to work as if they had been typed by the user.
4658
4663
4659 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
4664 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
4660 execute automatically (no need to type 'exec...'). They then
4665 execute automatically (no need to type 'exec...'). They then
4661 behave like 'true macros'. The printing system was also modified
4666 behave like 'true macros'. The printing system was also modified
4662 for this to work.
4667 for this to work.
4663
4668
4664 2002-02-19 Fernando Perez <fperez@colorado.edu>
4669 2002-02-19 Fernando Perez <fperez@colorado.edu>
4665
4670
4666 * IPython/genutils.py (page_file): new function for paging files
4671 * IPython/genutils.py (page_file): new function for paging files
4667 in an OS-independent way. Also necessary for file viewing to work
4672 in an OS-independent way. Also necessary for file viewing to work
4668 well inside Emacs buffers.
4673 well inside Emacs buffers.
4669 (page): Added checks for being in an emacs buffer.
4674 (page): Added checks for being in an emacs buffer.
4670 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
4675 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
4671 same bug in iplib.
4676 same bug in iplib.
4672
4677
4673 2002-02-18 Fernando Perez <fperez@colorado.edu>
4678 2002-02-18 Fernando Perez <fperez@colorado.edu>
4674
4679
4675 * IPython/iplib.py (InteractiveShell.init_readline): modified use
4680 * IPython/iplib.py (InteractiveShell.init_readline): modified use
4676 of readline so that IPython can work inside an Emacs buffer.
4681 of readline so that IPython can work inside an Emacs buffer.
4677
4682
4678 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
4683 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
4679 method signatures (they weren't really bugs, but it looks cleaner
4684 method signatures (they weren't really bugs, but it looks cleaner
4680 and keeps PyChecker happy).
4685 and keeps PyChecker happy).
4681
4686
4682 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
4687 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
4683 for implementing various user-defined hooks. Currently only
4688 for implementing various user-defined hooks. Currently only
4684 display is done.
4689 display is done.
4685
4690
4686 * IPython/Prompts.py (CachedOutput._display): changed display
4691 * IPython/Prompts.py (CachedOutput._display): changed display
4687 functions so that they can be dynamically changed by users easily.
4692 functions so that they can be dynamically changed by users easily.
4688
4693
4689 * IPython/Extensions/numeric_formats.py (num_display): added an
4694 * IPython/Extensions/numeric_formats.py (num_display): added an
4690 extension for printing NumPy arrays in flexible manners. It
4695 extension for printing NumPy arrays in flexible manners. It
4691 doesn't do anything yet, but all the structure is in
4696 doesn't do anything yet, but all the structure is in
4692 place. Ultimately the plan is to implement output format control
4697 place. Ultimately the plan is to implement output format control
4693 like in Octave.
4698 like in Octave.
4694
4699
4695 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
4700 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
4696 methods are found at run-time by all the automatic machinery.
4701 methods are found at run-time by all the automatic machinery.
4697
4702
4698 2002-02-17 Fernando Perez <fperez@colorado.edu>
4703 2002-02-17 Fernando Perez <fperez@colorado.edu>
4699
4704
4700 * setup_Windows.py (make_shortcut): documented. Cleaned up the
4705 * setup_Windows.py (make_shortcut): documented. Cleaned up the
4701 whole file a little.
4706 whole file a little.
4702
4707
4703 * ToDo: closed this document. Now there's a new_design.lyx
4708 * ToDo: closed this document. Now there's a new_design.lyx
4704 document for all new ideas. Added making a pdf of it for the
4709 document for all new ideas. Added making a pdf of it for the
4705 end-user distro.
4710 end-user distro.
4706
4711
4707 * IPython/Logger.py (Logger.switch_log): Created this to replace
4712 * IPython/Logger.py (Logger.switch_log): Created this to replace
4708 logon() and logoff(). It also fixes a nasty crash reported by
4713 logon() and logoff(). It also fixes a nasty crash reported by
4709 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
4714 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
4710
4715
4711 * IPython/iplib.py (complete): got auto-completion to work with
4716 * IPython/iplib.py (complete): got auto-completion to work with
4712 automagic (I had wanted this for a long time).
4717 automagic (I had wanted this for a long time).
4713
4718
4714 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
4719 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
4715 to @file, since file() is now a builtin and clashes with automagic
4720 to @file, since file() is now a builtin and clashes with automagic
4716 for @file.
4721 for @file.
4717
4722
4718 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
4723 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
4719 of this was previously in iplib, which had grown to more than 2000
4724 of this was previously in iplib, which had grown to more than 2000
4720 lines, way too long. No new functionality, but it makes managing
4725 lines, way too long. No new functionality, but it makes managing
4721 the code a bit easier.
4726 the code a bit easier.
4722
4727
4723 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
4728 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
4724 information to crash reports.
4729 information to crash reports.
4725
4730
4726 2002-02-12 Fernando Perez <fperez@colorado.edu>
4731 2002-02-12 Fernando Perez <fperez@colorado.edu>
4727
4732
4728 * Released 0.2.5.
4733 * Released 0.2.5.
4729
4734
4730 2002-02-11 Fernando Perez <fperez@colorado.edu>
4735 2002-02-11 Fernando Perez <fperez@colorado.edu>
4731
4736
4732 * Wrote a relatively complete Windows installer. It puts
4737 * Wrote a relatively complete Windows installer. It puts
4733 everything in place, creates Start Menu entries and fixes the
4738 everything in place, creates Start Menu entries and fixes the
4734 color issues. Nothing fancy, but it works.
4739 color issues. Nothing fancy, but it works.
4735
4740
4736 2002-02-10 Fernando Perez <fperez@colorado.edu>
4741 2002-02-10 Fernando Perez <fperez@colorado.edu>
4737
4742
4738 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
4743 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
4739 os.path.expanduser() call so that we can type @run ~/myfile.py and
4744 os.path.expanduser() call so that we can type @run ~/myfile.py and
4740 have thigs work as expected.
4745 have thigs work as expected.
4741
4746
4742 * IPython/genutils.py (page): fixed exception handling so things
4747 * IPython/genutils.py (page): fixed exception handling so things
4743 work both in Unix and Windows correctly. Quitting a pager triggers
4748 work both in Unix and Windows correctly. Quitting a pager triggers
4744 an IOError/broken pipe in Unix, and in windows not finding a pager
4749 an IOError/broken pipe in Unix, and in windows not finding a pager
4745 is also an IOError, so I had to actually look at the return value
4750 is also an IOError, so I had to actually look at the return value
4746 of the exception, not just the exception itself. Should be ok now.
4751 of the exception, not just the exception itself. Should be ok now.
4747
4752
4748 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
4753 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
4749 modified to allow case-insensitive color scheme changes.
4754 modified to allow case-insensitive color scheme changes.
4750
4755
4751 2002-02-09 Fernando Perez <fperez@colorado.edu>
4756 2002-02-09 Fernando Perez <fperez@colorado.edu>
4752
4757
4753 * IPython/genutils.py (native_line_ends): new function to leave
4758 * IPython/genutils.py (native_line_ends): new function to leave
4754 user config files with os-native line-endings.
4759 user config files with os-native line-endings.
4755
4760
4756 * README and manual updates.
4761 * README and manual updates.
4757
4762
4758 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
4763 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
4759 instead of StringType to catch Unicode strings.
4764 instead of StringType to catch Unicode strings.
4760
4765
4761 * IPython/genutils.py (filefind): fixed bug for paths with
4766 * IPython/genutils.py (filefind): fixed bug for paths with
4762 embedded spaces (very common in Windows).
4767 embedded spaces (very common in Windows).
4763
4768
4764 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
4769 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
4765 files under Windows, so that they get automatically associated
4770 files under Windows, so that they get automatically associated
4766 with a text editor. Windows makes it a pain to handle
4771 with a text editor. Windows makes it a pain to handle
4767 extension-less files.
4772 extension-less files.
4768
4773
4769 * IPython/iplib.py (InteractiveShell.init_readline): Made the
4774 * IPython/iplib.py (InteractiveShell.init_readline): Made the
4770 warning about readline only occur for Posix. In Windows there's no
4775 warning about readline only occur for Posix. In Windows there's no
4771 way to get readline, so why bother with the warning.
4776 way to get readline, so why bother with the warning.
4772
4777
4773 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
4778 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
4774 for __str__ instead of dir(self), since dir() changed in 2.2.
4779 for __str__ instead of dir(self), since dir() changed in 2.2.
4775
4780
4776 * Ported to Windows! Tested on XP, I suspect it should work fine
4781 * Ported to Windows! Tested on XP, I suspect it should work fine
4777 on NT/2000, but I don't think it will work on 98 et al. That
4782 on NT/2000, but I don't think it will work on 98 et al. That
4778 series of Windows is such a piece of junk anyway that I won't try
4783 series of Windows is such a piece of junk anyway that I won't try
4779 porting it there. The XP port was straightforward, showed a few
4784 porting it there. The XP port was straightforward, showed a few
4780 bugs here and there (fixed all), in particular some string
4785 bugs here and there (fixed all), in particular some string
4781 handling stuff which required considering Unicode strings (which
4786 handling stuff which required considering Unicode strings (which
4782 Windows uses). This is good, but hasn't been too tested :) No
4787 Windows uses). This is good, but hasn't been too tested :) No
4783 fancy installer yet, I'll put a note in the manual so people at
4788 fancy installer yet, I'll put a note in the manual so people at
4784 least make manually a shortcut.
4789 least make manually a shortcut.
4785
4790
4786 * IPython/iplib.py (Magic.magic_colors): Unified the color options
4791 * IPython/iplib.py (Magic.magic_colors): Unified the color options
4787 into a single one, "colors". This now controls both prompt and
4792 into a single one, "colors". This now controls both prompt and
4788 exception color schemes, and can be changed both at startup
4793 exception color schemes, and can be changed both at startup
4789 (either via command-line switches or via ipythonrc files) and at
4794 (either via command-line switches or via ipythonrc files) and at
4790 runtime, with @colors.
4795 runtime, with @colors.
4791 (Magic.magic_run): renamed @prun to @run and removed the old
4796 (Magic.magic_run): renamed @prun to @run and removed the old
4792 @run. The two were too similar to warrant keeping both.
4797 @run. The two were too similar to warrant keeping both.
4793
4798
4794 2002-02-03 Fernando Perez <fperez@colorado.edu>
4799 2002-02-03 Fernando Perez <fperez@colorado.edu>
4795
4800
4796 * IPython/iplib.py (install_first_time): Added comment on how to
4801 * IPython/iplib.py (install_first_time): Added comment on how to
4797 configure the color options for first-time users. Put a <return>
4802 configure the color options for first-time users. Put a <return>
4798 request at the end so that small-terminal users get a chance to
4803 request at the end so that small-terminal users get a chance to
4799 read the startup info.
4804 read the startup info.
4800
4805
4801 2002-01-23 Fernando Perez <fperez@colorado.edu>
4806 2002-01-23 Fernando Perez <fperez@colorado.edu>
4802
4807
4803 * IPython/iplib.py (CachedOutput.update): Changed output memory
4808 * IPython/iplib.py (CachedOutput.update): Changed output memory
4804 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
4809 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
4805 input history we still use _i. Did this b/c these variable are
4810 input history we still use _i. Did this b/c these variable are
4806 very commonly used in interactive work, so the less we need to
4811 very commonly used in interactive work, so the less we need to
4807 type the better off we are.
4812 type the better off we are.
4808 (Magic.magic_prun): updated @prun to better handle the namespaces
4813 (Magic.magic_prun): updated @prun to better handle the namespaces
4809 the file will run in, including a fix for __name__ not being set
4814 the file will run in, including a fix for __name__ not being set
4810 before.
4815 before.
4811
4816
4812 2002-01-20 Fernando Perez <fperez@colorado.edu>
4817 2002-01-20 Fernando Perez <fperez@colorado.edu>
4813
4818
4814 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
4819 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
4815 extra garbage for Python 2.2. Need to look more carefully into
4820 extra garbage for Python 2.2. Need to look more carefully into
4816 this later.
4821 this later.
4817
4822
4818 2002-01-19 Fernando Perez <fperez@colorado.edu>
4823 2002-01-19 Fernando Perez <fperez@colorado.edu>
4819
4824
4820 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
4825 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
4821 display SyntaxError exceptions properly formatted when they occur
4826 display SyntaxError exceptions properly formatted when they occur
4822 (they can be triggered by imported code).
4827 (they can be triggered by imported code).
4823
4828
4824 2002-01-18 Fernando Perez <fperez@colorado.edu>
4829 2002-01-18 Fernando Perez <fperez@colorado.edu>
4825
4830
4826 * IPython/iplib.py (InteractiveShell.safe_execfile): now
4831 * IPython/iplib.py (InteractiveShell.safe_execfile): now
4827 SyntaxError exceptions are reported nicely formatted, instead of
4832 SyntaxError exceptions are reported nicely formatted, instead of
4828 spitting out only offset information as before.
4833 spitting out only offset information as before.
4829 (Magic.magic_prun): Added the @prun function for executing
4834 (Magic.magic_prun): Added the @prun function for executing
4830 programs with command line args inside IPython.
4835 programs with command line args inside IPython.
4831
4836
4832 2002-01-16 Fernando Perez <fperez@colorado.edu>
4837 2002-01-16 Fernando Perez <fperez@colorado.edu>
4833
4838
4834 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
4839 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
4835 to *not* include the last item given in a range. This brings their
4840 to *not* include the last item given in a range. This brings their
4836 behavior in line with Python's slicing:
4841 behavior in line with Python's slicing:
4837 a[n1:n2] -> a[n1]...a[n2-1]
4842 a[n1:n2] -> a[n1]...a[n2-1]
4838 It may be a bit less convenient, but I prefer to stick to Python's
4843 It may be a bit less convenient, but I prefer to stick to Python's
4839 conventions *everywhere*, so users never have to wonder.
4844 conventions *everywhere*, so users never have to wonder.
4840 (Magic.magic_macro): Added @macro function to ease the creation of
4845 (Magic.magic_macro): Added @macro function to ease the creation of
4841 macros.
4846 macros.
4842
4847
4843 2002-01-05 Fernando Perez <fperez@colorado.edu>
4848 2002-01-05 Fernando Perez <fperez@colorado.edu>
4844
4849
4845 * Released 0.2.4.
4850 * Released 0.2.4.
4846
4851
4847 * IPython/iplib.py (Magic.magic_pdef):
4852 * IPython/iplib.py (Magic.magic_pdef):
4848 (InteractiveShell.safe_execfile): report magic lines and error
4853 (InteractiveShell.safe_execfile): report magic lines and error
4849 lines without line numbers so one can easily copy/paste them for
4854 lines without line numbers so one can easily copy/paste them for
4850 re-execution.
4855 re-execution.
4851
4856
4852 * Updated manual with recent changes.
4857 * Updated manual with recent changes.
4853
4858
4854 * IPython/iplib.py (Magic.magic_oinfo): added constructor
4859 * IPython/iplib.py (Magic.magic_oinfo): added constructor
4855 docstring printing when class? is called. Very handy for knowing
4860 docstring printing when class? is called. Very handy for knowing
4856 how to create class instances (as long as __init__ is well
4861 how to create class instances (as long as __init__ is well
4857 documented, of course :)
4862 documented, of course :)
4858 (Magic.magic_doc): print both class and constructor docstrings.
4863 (Magic.magic_doc): print both class and constructor docstrings.
4859 (Magic.magic_pdef): give constructor info if passed a class and
4864 (Magic.magic_pdef): give constructor info if passed a class and
4860 __call__ info for callable object instances.
4865 __call__ info for callable object instances.
4861
4866
4862 2002-01-04 Fernando Perez <fperez@colorado.edu>
4867 2002-01-04 Fernando Perez <fperez@colorado.edu>
4863
4868
4864 * Made deep_reload() off by default. It doesn't always work
4869 * Made deep_reload() off by default. It doesn't always work
4865 exactly as intended, so it's probably safer to have it off. It's
4870 exactly as intended, so it's probably safer to have it off. It's
4866 still available as dreload() anyway, so nothing is lost.
4871 still available as dreload() anyway, so nothing is lost.
4867
4872
4868 2002-01-02 Fernando Perez <fperez@colorado.edu>
4873 2002-01-02 Fernando Perez <fperez@colorado.edu>
4869
4874
4870 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
4875 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
4871 so I wanted an updated release).
4876 so I wanted an updated release).
4872
4877
4873 2001-12-27 Fernando Perez <fperez@colorado.edu>
4878 2001-12-27 Fernando Perez <fperez@colorado.edu>
4874
4879
4875 * IPython/iplib.py (InteractiveShell.interact): Added the original
4880 * IPython/iplib.py (InteractiveShell.interact): Added the original
4876 code from 'code.py' for this module in order to change the
4881 code from 'code.py' for this module in order to change the
4877 handling of a KeyboardInterrupt. This was necessary b/c otherwise
4882 handling of a KeyboardInterrupt. This was necessary b/c otherwise
4878 the history cache would break when the user hit Ctrl-C, and
4883 the history cache would break when the user hit Ctrl-C, and
4879 interact() offers no way to add any hooks to it.
4884 interact() offers no way to add any hooks to it.
4880
4885
4881 2001-12-23 Fernando Perez <fperez@colorado.edu>
4886 2001-12-23 Fernando Perez <fperez@colorado.edu>
4882
4887
4883 * setup.py: added check for 'MANIFEST' before trying to remove
4888 * setup.py: added check for 'MANIFEST' before trying to remove
4884 it. Thanks to Sean Reifschneider.
4889 it. Thanks to Sean Reifschneider.
4885
4890
4886 2001-12-22 Fernando Perez <fperez@colorado.edu>
4891 2001-12-22 Fernando Perez <fperez@colorado.edu>
4887
4892
4888 * Released 0.2.2.
4893 * Released 0.2.2.
4889
4894
4890 * Finished (reasonably) writing the manual. Later will add the
4895 * Finished (reasonably) writing the manual. Later will add the
4891 python-standard navigation stylesheets, but for the time being
4896 python-standard navigation stylesheets, but for the time being
4892 it's fairly complete. Distribution will include html and pdf
4897 it's fairly complete. Distribution will include html and pdf
4893 versions.
4898 versions.
4894
4899
4895 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
4900 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
4896 (MayaVi author).
4901 (MayaVi author).
4897
4902
4898 2001-12-21 Fernando Perez <fperez@colorado.edu>
4903 2001-12-21 Fernando Perez <fperez@colorado.edu>
4899
4904
4900 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
4905 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
4901 good public release, I think (with the manual and the distutils
4906 good public release, I think (with the manual and the distutils
4902 installer). The manual can use some work, but that can go
4907 installer). The manual can use some work, but that can go
4903 slowly. Otherwise I think it's quite nice for end users. Next
4908 slowly. Otherwise I think it's quite nice for end users. Next
4904 summer, rewrite the guts of it...
4909 summer, rewrite the guts of it...
4905
4910
4906 * Changed format of ipythonrc files to use whitespace as the
4911 * Changed format of ipythonrc files to use whitespace as the
4907 separator instead of an explicit '='. Cleaner.
4912 separator instead of an explicit '='. Cleaner.
4908
4913
4909 2001-12-20 Fernando Perez <fperez@colorado.edu>
4914 2001-12-20 Fernando Perez <fperez@colorado.edu>
4910
4915
4911 * Started a manual in LyX. For now it's just a quick merge of the
4916 * Started a manual in LyX. For now it's just a quick merge of the
4912 various internal docstrings and READMEs. Later it may grow into a
4917 various internal docstrings and READMEs. Later it may grow into a
4913 nice, full-blown manual.
4918 nice, full-blown manual.
4914
4919
4915 * Set up a distutils based installer. Installation should now be
4920 * Set up a distutils based installer. Installation should now be
4916 trivially simple for end-users.
4921 trivially simple for end-users.
4917
4922
4918 2001-12-11 Fernando Perez <fperez@colorado.edu>
4923 2001-12-11 Fernando Perez <fperez@colorado.edu>
4919
4924
4920 * Released 0.2.0. First public release, announced it at
4925 * Released 0.2.0. First public release, announced it at
4921 comp.lang.python. From now on, just bugfixes...
4926 comp.lang.python. From now on, just bugfixes...
4922
4927
4923 * Went through all the files, set copyright/license notices and
4928 * Went through all the files, set copyright/license notices and
4924 cleaned up things. Ready for release.
4929 cleaned up things. Ready for release.
4925
4930
4926 2001-12-10 Fernando Perez <fperez@colorado.edu>
4931 2001-12-10 Fernando Perez <fperez@colorado.edu>
4927
4932
4928 * Changed the first-time installer not to use tarfiles. It's more
4933 * Changed the first-time installer not to use tarfiles. It's more
4929 robust now and less unix-dependent. Also makes it easier for
4934 robust now and less unix-dependent. Also makes it easier for
4930 people to later upgrade versions.
4935 people to later upgrade versions.
4931
4936
4932 * Changed @exit to @abort to reflect the fact that it's pretty
4937 * Changed @exit to @abort to reflect the fact that it's pretty
4933 brutal (a sys.exit()). The difference between @abort and Ctrl-D
4938 brutal (a sys.exit()). The difference between @abort and Ctrl-D
4934 becomes significant only when IPyhton is embedded: in that case,
4939 becomes significant only when IPyhton is embedded: in that case,
4935 C-D closes IPython only, but @abort kills the enclosing program
4940 C-D closes IPython only, but @abort kills the enclosing program
4936 too (unless it had called IPython inside a try catching
4941 too (unless it had called IPython inside a try catching
4937 SystemExit).
4942 SystemExit).
4938
4943
4939 * Created Shell module which exposes the actuall IPython Shell
4944 * Created Shell module which exposes the actuall IPython Shell
4940 classes, currently the normal and the embeddable one. This at
4945 classes, currently the normal and the embeddable one. This at
4941 least offers a stable interface we won't need to change when
4946 least offers a stable interface we won't need to change when
4942 (later) the internals are rewritten. That rewrite will be confined
4947 (later) the internals are rewritten. That rewrite will be confined
4943 to iplib and ipmaker, but the Shell interface should remain as is.
4948 to iplib and ipmaker, but the Shell interface should remain as is.
4944
4949
4945 * Added embed module which offers an embeddable IPShell object,
4950 * Added embed module which offers an embeddable IPShell object,
4946 useful to fire up IPython *inside* a running program. Great for
4951 useful to fire up IPython *inside* a running program. Great for
4947 debugging or dynamical data analysis.
4952 debugging or dynamical data analysis.
4948
4953
4949 2001-12-08 Fernando Perez <fperez@colorado.edu>
4954 2001-12-08 Fernando Perez <fperez@colorado.edu>
4950
4955
4951 * Fixed small bug preventing seeing info from methods of defined
4956 * Fixed small bug preventing seeing info from methods of defined
4952 objects (incorrect namespace in _ofind()).
4957 objects (incorrect namespace in _ofind()).
4953
4958
4954 * Documentation cleanup. Moved the main usage docstrings to a
4959 * Documentation cleanup. Moved the main usage docstrings to a
4955 separate file, usage.py (cleaner to maintain, and hopefully in the
4960 separate file, usage.py (cleaner to maintain, and hopefully in the
4956 future some perlpod-like way of producing interactive, man and
4961 future some perlpod-like way of producing interactive, man and
4957 html docs out of it will be found).
4962 html docs out of it will be found).
4958
4963
4959 * Added @profile to see your profile at any time.
4964 * Added @profile to see your profile at any time.
4960
4965
4961 * Added @p as an alias for 'print'. It's especially convenient if
4966 * Added @p as an alias for 'print'. It's especially convenient if
4962 using automagic ('p x' prints x).
4967 using automagic ('p x' prints x).
4963
4968
4964 * Small cleanups and fixes after a pychecker run.
4969 * Small cleanups and fixes after a pychecker run.
4965
4970
4966 * Changed the @cd command to handle @cd - and @cd -<n> for
4971 * Changed the @cd command to handle @cd - and @cd -<n> for
4967 visiting any directory in _dh.
4972 visiting any directory in _dh.
4968
4973
4969 * Introduced _dh, a history of visited directories. @dhist prints
4974 * Introduced _dh, a history of visited directories. @dhist prints
4970 it out with numbers.
4975 it out with numbers.
4971
4976
4972 2001-12-07 Fernando Perez <fperez@colorado.edu>
4977 2001-12-07 Fernando Perez <fperez@colorado.edu>
4973
4978
4974 * Released 0.1.22
4979 * Released 0.1.22
4975
4980
4976 * Made initialization a bit more robust against invalid color
4981 * Made initialization a bit more robust against invalid color
4977 options in user input (exit, not traceback-crash).
4982 options in user input (exit, not traceback-crash).
4978
4983
4979 * Changed the bug crash reporter to write the report only in the
4984 * Changed the bug crash reporter to write the report only in the
4980 user's .ipython directory. That way IPython won't litter people's
4985 user's .ipython directory. That way IPython won't litter people's
4981 hard disks with crash files all over the place. Also print on
4986 hard disks with crash files all over the place. Also print on
4982 screen the necessary mail command.
4987 screen the necessary mail command.
4983
4988
4984 * With the new ultraTB, implemented LightBG color scheme for light
4989 * With the new ultraTB, implemented LightBG color scheme for light
4985 background terminals. A lot of people like white backgrounds, so I
4990 background terminals. A lot of people like white backgrounds, so I
4986 guess we should at least give them something readable.
4991 guess we should at least give them something readable.
4987
4992
4988 2001-12-06 Fernando Perez <fperez@colorado.edu>
4993 2001-12-06 Fernando Perez <fperez@colorado.edu>
4989
4994
4990 * Modified the structure of ultraTB. Now there's a proper class
4995 * Modified the structure of ultraTB. Now there's a proper class
4991 for tables of color schemes which allow adding schemes easily and
4996 for tables of color schemes which allow adding schemes easily and
4992 switching the active scheme without creating a new instance every
4997 switching the active scheme without creating a new instance every
4993 time (which was ridiculous). The syntax for creating new schemes
4998 time (which was ridiculous). The syntax for creating new schemes
4994 is also cleaner. I think ultraTB is finally done, with a clean
4999 is also cleaner. I think ultraTB is finally done, with a clean
4995 class structure. Names are also much cleaner (now there's proper
5000 class structure. Names are also much cleaner (now there's proper
4996 color tables, no need for every variable to also have 'color' in
5001 color tables, no need for every variable to also have 'color' in
4997 its name).
5002 its name).
4998
5003
4999 * Broke down genutils into separate files. Now genutils only
5004 * Broke down genutils into separate files. Now genutils only
5000 contains utility functions, and classes have been moved to their
5005 contains utility functions, and classes have been moved to their
5001 own files (they had enough independent functionality to warrant
5006 own files (they had enough independent functionality to warrant
5002 it): ConfigLoader, OutputTrap, Struct.
5007 it): ConfigLoader, OutputTrap, Struct.
5003
5008
5004 2001-12-05 Fernando Perez <fperez@colorado.edu>
5009 2001-12-05 Fernando Perez <fperez@colorado.edu>
5005
5010
5006 * IPython turns 21! Released version 0.1.21, as a candidate for
5011 * IPython turns 21! Released version 0.1.21, as a candidate for
5007 public consumption. If all goes well, release in a few days.
5012 public consumption. If all goes well, release in a few days.
5008
5013
5009 * Fixed path bug (files in Extensions/ directory wouldn't be found
5014 * Fixed path bug (files in Extensions/ directory wouldn't be found
5010 unless IPython/ was explicitly in sys.path).
5015 unless IPython/ was explicitly in sys.path).
5011
5016
5012 * Extended the FlexCompleter class as MagicCompleter to allow
5017 * Extended the FlexCompleter class as MagicCompleter to allow
5013 completion of @-starting lines.
5018 completion of @-starting lines.
5014
5019
5015 * Created __release__.py file as a central repository for release
5020 * Created __release__.py file as a central repository for release
5016 info that other files can read from.
5021 info that other files can read from.
5017
5022
5018 * Fixed small bug in logging: when logging was turned on in
5023 * Fixed small bug in logging: when logging was turned on in
5019 mid-session, old lines with special meanings (!@?) were being
5024 mid-session, old lines with special meanings (!@?) were being
5020 logged without the prepended comment, which is necessary since
5025 logged without the prepended comment, which is necessary since
5021 they are not truly valid python syntax. This should make session
5026 they are not truly valid python syntax. This should make session
5022 restores produce less errors.
5027 restores produce less errors.
5023
5028
5024 * The namespace cleanup forced me to make a FlexCompleter class
5029 * The namespace cleanup forced me to make a FlexCompleter class
5025 which is nothing but a ripoff of rlcompleter, but with selectable
5030 which is nothing but a ripoff of rlcompleter, but with selectable
5026 namespace (rlcompleter only works in __main__.__dict__). I'll try
5031 namespace (rlcompleter only works in __main__.__dict__). I'll try
5027 to submit a note to the authors to see if this change can be
5032 to submit a note to the authors to see if this change can be
5028 incorporated in future rlcompleter releases (Dec.6: done)
5033 incorporated in future rlcompleter releases (Dec.6: done)
5029
5034
5030 * More fixes to namespace handling. It was a mess! Now all
5035 * More fixes to namespace handling. It was a mess! Now all
5031 explicit references to __main__.__dict__ are gone (except when
5036 explicit references to __main__.__dict__ are gone (except when
5032 really needed) and everything is handled through the namespace
5037 really needed) and everything is handled through the namespace
5033 dicts in the IPython instance. We seem to be getting somewhere
5038 dicts in the IPython instance. We seem to be getting somewhere
5034 with this, finally...
5039 with this, finally...
5035
5040
5036 * Small documentation updates.
5041 * Small documentation updates.
5037
5042
5038 * Created the Extensions directory under IPython (with an
5043 * Created the Extensions directory under IPython (with an
5039 __init__.py). Put the PhysicalQ stuff there. This directory should
5044 __init__.py). Put the PhysicalQ stuff there. This directory should
5040 be used for all special-purpose extensions.
5045 be used for all special-purpose extensions.
5041
5046
5042 * File renaming:
5047 * File renaming:
5043 ipythonlib --> ipmaker
5048 ipythonlib --> ipmaker
5044 ipplib --> iplib
5049 ipplib --> iplib
5045 This makes a bit more sense in terms of what these files actually do.
5050 This makes a bit more sense in terms of what these files actually do.
5046
5051
5047 * Moved all the classes and functions in ipythonlib to ipplib, so
5052 * Moved all the classes and functions in ipythonlib to ipplib, so
5048 now ipythonlib only has make_IPython(). This will ease up its
5053 now ipythonlib only has make_IPython(). This will ease up its
5049 splitting in smaller functional chunks later.
5054 splitting in smaller functional chunks later.
5050
5055
5051 * Cleaned up (done, I think) output of @whos. Better column
5056 * Cleaned up (done, I think) output of @whos. Better column
5052 formatting, and now shows str(var) for as much as it can, which is
5057 formatting, and now shows str(var) for as much as it can, which is
5053 typically what one gets with a 'print var'.
5058 typically what one gets with a 'print var'.
5054
5059
5055 2001-12-04 Fernando Perez <fperez@colorado.edu>
5060 2001-12-04 Fernando Perez <fperez@colorado.edu>
5056
5061
5057 * Fixed namespace problems. Now builtin/IPyhton/user names get
5062 * Fixed namespace problems. Now builtin/IPyhton/user names get
5058 properly reported in their namespace. Internal namespace handling
5063 properly reported in their namespace. Internal namespace handling
5059 is finally getting decent (not perfect yet, but much better than
5064 is finally getting decent (not perfect yet, but much better than
5060 the ad-hoc mess we had).
5065 the ad-hoc mess we had).
5061
5066
5062 * Removed -exit option. If people just want to run a python
5067 * Removed -exit option. If people just want to run a python
5063 script, that's what the normal interpreter is for. Less
5068 script, that's what the normal interpreter is for. Less
5064 unnecessary options, less chances for bugs.
5069 unnecessary options, less chances for bugs.
5065
5070
5066 * Added a crash handler which generates a complete post-mortem if
5071 * Added a crash handler which generates a complete post-mortem if
5067 IPython crashes. This will help a lot in tracking bugs down the
5072 IPython crashes. This will help a lot in tracking bugs down the
5068 road.
5073 road.
5069
5074
5070 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
5075 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
5071 which were boud to functions being reassigned would bypass the
5076 which were boud to functions being reassigned would bypass the
5072 logger, breaking the sync of _il with the prompt counter. This
5077 logger, breaking the sync of _il with the prompt counter. This
5073 would then crash IPython later when a new line was logged.
5078 would then crash IPython later when a new line was logged.
5074
5079
5075 2001-12-02 Fernando Perez <fperez@colorado.edu>
5080 2001-12-02 Fernando Perez <fperez@colorado.edu>
5076
5081
5077 * Made IPython a package. This means people don't have to clutter
5082 * Made IPython a package. This means people don't have to clutter
5078 their sys.path with yet another directory. Changed the INSTALL
5083 their sys.path with yet another directory. Changed the INSTALL
5079 file accordingly.
5084 file accordingly.
5080
5085
5081 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
5086 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
5082 sorts its output (so @who shows it sorted) and @whos formats the
5087 sorts its output (so @who shows it sorted) and @whos formats the
5083 table according to the width of the first column. Nicer, easier to
5088 table according to the width of the first column. Nicer, easier to
5084 read. Todo: write a generic table_format() which takes a list of
5089 read. Todo: write a generic table_format() which takes a list of
5085 lists and prints it nicely formatted, with optional row/column
5090 lists and prints it nicely formatted, with optional row/column
5086 separators and proper padding and justification.
5091 separators and proper padding and justification.
5087
5092
5088 * Released 0.1.20
5093 * Released 0.1.20
5089
5094
5090 * Fixed bug in @log which would reverse the inputcache list (a
5095 * Fixed bug in @log which would reverse the inputcache list (a
5091 copy operation was missing).
5096 copy operation was missing).
5092
5097
5093 * Code cleanup. @config was changed to use page(). Better, since
5098 * Code cleanup. @config was changed to use page(). Better, since
5094 its output is always quite long.
5099 its output is always quite long.
5095
5100
5096 * Itpl is back as a dependency. I was having too many problems
5101 * Itpl is back as a dependency. I was having too many problems
5097 getting the parametric aliases to work reliably, and it's just
5102 getting the parametric aliases to work reliably, and it's just
5098 easier to code weird string operations with it than playing %()s
5103 easier to code weird string operations with it than playing %()s
5099 games. It's only ~6k, so I don't think it's too big a deal.
5104 games. It's only ~6k, so I don't think it's too big a deal.
5100
5105
5101 * Found (and fixed) a very nasty bug with history. !lines weren't
5106 * Found (and fixed) a very nasty bug with history. !lines weren't
5102 getting cached, and the out of sync caches would crash
5107 getting cached, and the out of sync caches would crash
5103 IPython. Fixed it by reorganizing the prefilter/handlers/logger
5108 IPython. Fixed it by reorganizing the prefilter/handlers/logger
5104 division of labor a bit better. Bug fixed, cleaner structure.
5109 division of labor a bit better. Bug fixed, cleaner structure.
5105
5110
5106 2001-12-01 Fernando Perez <fperez@colorado.edu>
5111 2001-12-01 Fernando Perez <fperez@colorado.edu>
5107
5112
5108 * Released 0.1.19
5113 * Released 0.1.19
5109
5114
5110 * Added option -n to @hist to prevent line number printing. Much
5115 * Added option -n to @hist to prevent line number printing. Much
5111 easier to copy/paste code this way.
5116 easier to copy/paste code this way.
5112
5117
5113 * Created global _il to hold the input list. Allows easy
5118 * Created global _il to hold the input list. Allows easy
5114 re-execution of blocks of code by slicing it (inspired by Janko's
5119 re-execution of blocks of code by slicing it (inspired by Janko's
5115 comment on 'macros').
5120 comment on 'macros').
5116
5121
5117 * Small fixes and doc updates.
5122 * Small fixes and doc updates.
5118
5123
5119 * Rewrote @history function (was @h). Renamed it to @hist, @h is
5124 * Rewrote @history function (was @h). Renamed it to @hist, @h is
5120 much too fragile with automagic. Handles properly multi-line
5125 much too fragile with automagic. Handles properly multi-line
5121 statements and takes parameters.
5126 statements and takes parameters.
5122
5127
5123 2001-11-30 Fernando Perez <fperez@colorado.edu>
5128 2001-11-30 Fernando Perez <fperez@colorado.edu>
5124
5129
5125 * Version 0.1.18 released.
5130 * Version 0.1.18 released.
5126
5131
5127 * Fixed nasty namespace bug in initial module imports.
5132 * Fixed nasty namespace bug in initial module imports.
5128
5133
5129 * Added copyright/license notes to all code files (except
5134 * Added copyright/license notes to all code files (except
5130 DPyGetOpt). For the time being, LGPL. That could change.
5135 DPyGetOpt). For the time being, LGPL. That could change.
5131
5136
5132 * Rewrote a much nicer README, updated INSTALL, cleaned up
5137 * Rewrote a much nicer README, updated INSTALL, cleaned up
5133 ipythonrc-* samples.
5138 ipythonrc-* samples.
5134
5139
5135 * Overall code/documentation cleanup. Basically ready for
5140 * Overall code/documentation cleanup. Basically ready for
5136 release. Only remaining thing: licence decision (LGPL?).
5141 release. Only remaining thing: licence decision (LGPL?).
5137
5142
5138 * Converted load_config to a class, ConfigLoader. Now recursion
5143 * Converted load_config to a class, ConfigLoader. Now recursion
5139 control is better organized. Doesn't include the same file twice.
5144 control is better organized. Doesn't include the same file twice.
5140
5145
5141 2001-11-29 Fernando Perez <fperez@colorado.edu>
5146 2001-11-29 Fernando Perez <fperez@colorado.edu>
5142
5147
5143 * Got input history working. Changed output history variables from
5148 * Got input history working. Changed output history variables from
5144 _p to _o so that _i is for input and _o for output. Just cleaner
5149 _p to _o so that _i is for input and _o for output. Just cleaner
5145 convention.
5150 convention.
5146
5151
5147 * Implemented parametric aliases. This pretty much allows the
5152 * Implemented parametric aliases. This pretty much allows the
5148 alias system to offer full-blown shell convenience, I think.
5153 alias system to offer full-blown shell convenience, I think.
5149
5154
5150 * Version 0.1.17 released, 0.1.18 opened.
5155 * Version 0.1.17 released, 0.1.18 opened.
5151
5156
5152 * dot_ipython/ipythonrc (alias): added documentation.
5157 * dot_ipython/ipythonrc (alias): added documentation.
5153 (xcolor): Fixed small bug (xcolors -> xcolor)
5158 (xcolor): Fixed small bug (xcolors -> xcolor)
5154
5159
5155 * Changed the alias system. Now alias is a magic command to define
5160 * Changed the alias system. Now alias is a magic command to define
5156 aliases just like the shell. Rationale: the builtin magics should
5161 aliases just like the shell. Rationale: the builtin magics should
5157 be there for things deeply connected to IPython's
5162 be there for things deeply connected to IPython's
5158 architecture. And this is a much lighter system for what I think
5163 architecture. And this is a much lighter system for what I think
5159 is the really important feature: allowing users to define quickly
5164 is the really important feature: allowing users to define quickly
5160 magics that will do shell things for them, so they can customize
5165 magics that will do shell things for them, so they can customize
5161 IPython easily to match their work habits. If someone is really
5166 IPython easily to match their work habits. If someone is really
5162 desperate to have another name for a builtin alias, they can
5167 desperate to have another name for a builtin alias, they can
5163 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
5168 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
5164 works.
5169 works.
5165
5170
5166 2001-11-28 Fernando Perez <fperez@colorado.edu>
5171 2001-11-28 Fernando Perez <fperez@colorado.edu>
5167
5172
5168 * Changed @file so that it opens the source file at the proper
5173 * Changed @file so that it opens the source file at the proper
5169 line. Since it uses less, if your EDITOR environment is
5174 line. Since it uses less, if your EDITOR environment is
5170 configured, typing v will immediately open your editor of choice
5175 configured, typing v will immediately open your editor of choice
5171 right at the line where the object is defined. Not as quick as
5176 right at the line where the object is defined. Not as quick as
5172 having a direct @edit command, but for all intents and purposes it
5177 having a direct @edit command, but for all intents and purposes it
5173 works. And I don't have to worry about writing @edit to deal with
5178 works. And I don't have to worry about writing @edit to deal with
5174 all the editors, less does that.
5179 all the editors, less does that.
5175
5180
5176 * Version 0.1.16 released, 0.1.17 opened.
5181 * Version 0.1.16 released, 0.1.17 opened.
5177
5182
5178 * Fixed some nasty bugs in the page/page_dumb combo that could
5183 * Fixed some nasty bugs in the page/page_dumb combo that could
5179 crash IPython.
5184 crash IPython.
5180
5185
5181 2001-11-27 Fernando Perez <fperez@colorado.edu>
5186 2001-11-27 Fernando Perez <fperez@colorado.edu>
5182
5187
5183 * Version 0.1.15 released, 0.1.16 opened.
5188 * Version 0.1.15 released, 0.1.16 opened.
5184
5189
5185 * Finally got ? and ?? to work for undefined things: now it's
5190 * Finally got ? and ?? to work for undefined things: now it's
5186 possible to type {}.get? and get information about the get method
5191 possible to type {}.get? and get information about the get method
5187 of dicts, or os.path? even if only os is defined (so technically
5192 of dicts, or os.path? even if only os is defined (so technically
5188 os.path isn't). Works at any level. For example, after import os,
5193 os.path isn't). Works at any level. For example, after import os,
5189 os?, os.path?, os.path.abspath? all work. This is great, took some
5194 os?, os.path?, os.path.abspath? all work. This is great, took some
5190 work in _ofind.
5195 work in _ofind.
5191
5196
5192 * Fixed more bugs with logging. The sanest way to do it was to add
5197 * Fixed more bugs with logging. The sanest way to do it was to add
5193 to @log a 'mode' parameter. Killed two in one shot (this mode
5198 to @log a 'mode' parameter. Killed two in one shot (this mode
5194 option was a request of Janko's). I think it's finally clean
5199 option was a request of Janko's). I think it's finally clean
5195 (famous last words).
5200 (famous last words).
5196
5201
5197 * Added a page_dumb() pager which does a decent job of paging on
5202 * Added a page_dumb() pager which does a decent job of paging on
5198 screen, if better things (like less) aren't available. One less
5203 screen, if better things (like less) aren't available. One less
5199 unix dependency (someday maybe somebody will port this to
5204 unix dependency (someday maybe somebody will port this to
5200 windows).
5205 windows).
5201
5206
5202 * Fixed problem in magic_log: would lock of logging out if log
5207 * Fixed problem in magic_log: would lock of logging out if log
5203 creation failed (because it would still think it had succeeded).
5208 creation failed (because it would still think it had succeeded).
5204
5209
5205 * Improved the page() function using curses to auto-detect screen
5210 * Improved the page() function using curses to auto-detect screen
5206 size. Now it can make a much better decision on whether to print
5211 size. Now it can make a much better decision on whether to print
5207 or page a string. Option screen_length was modified: a value 0
5212 or page a string. Option screen_length was modified: a value 0
5208 means auto-detect, and that's the default now.
5213 means auto-detect, and that's the default now.
5209
5214
5210 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
5215 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
5211 go out. I'll test it for a few days, then talk to Janko about
5216 go out. I'll test it for a few days, then talk to Janko about
5212 licences and announce it.
5217 licences and announce it.
5213
5218
5214 * Fixed the length of the auto-generated ---> prompt which appears
5219 * Fixed the length of the auto-generated ---> prompt which appears
5215 for auto-parens and auto-quotes. Getting this right isn't trivial,
5220 for auto-parens and auto-quotes. Getting this right isn't trivial,
5216 with all the color escapes, different prompt types and optional
5221 with all the color escapes, different prompt types and optional
5217 separators. But it seems to be working in all the combinations.
5222 separators. But it seems to be working in all the combinations.
5218
5223
5219 2001-11-26 Fernando Perez <fperez@colorado.edu>
5224 2001-11-26 Fernando Perez <fperez@colorado.edu>
5220
5225
5221 * Wrote a regexp filter to get option types from the option names
5226 * Wrote a regexp filter to get option types from the option names
5222 string. This eliminates the need to manually keep two duplicate
5227 string. This eliminates the need to manually keep two duplicate
5223 lists.
5228 lists.
5224
5229
5225 * Removed the unneeded check_option_names. Now options are handled
5230 * Removed the unneeded check_option_names. Now options are handled
5226 in a much saner manner and it's easy to visually check that things
5231 in a much saner manner and it's easy to visually check that things
5227 are ok.
5232 are ok.
5228
5233
5229 * Updated version numbers on all files I modified to carry a
5234 * Updated version numbers on all files I modified to carry a
5230 notice so Janko and Nathan have clear version markers.
5235 notice so Janko and Nathan have clear version markers.
5231
5236
5232 * Updated docstring for ultraTB with my changes. I should send
5237 * Updated docstring for ultraTB with my changes. I should send
5233 this to Nathan.
5238 this to Nathan.
5234
5239
5235 * Lots of small fixes. Ran everything through pychecker again.
5240 * Lots of small fixes. Ran everything through pychecker again.
5236
5241
5237 * Made loading of deep_reload an cmd line option. If it's not too
5242 * Made loading of deep_reload an cmd line option. If it's not too
5238 kosher, now people can just disable it. With -nodeep_reload it's
5243 kosher, now people can just disable it. With -nodeep_reload it's
5239 still available as dreload(), it just won't overwrite reload().
5244 still available as dreload(), it just won't overwrite reload().
5240
5245
5241 * Moved many options to the no| form (-opt and -noopt
5246 * Moved many options to the no| form (-opt and -noopt
5242 accepted). Cleaner.
5247 accepted). Cleaner.
5243
5248
5244 * Changed magic_log so that if called with no parameters, it uses
5249 * Changed magic_log so that if called with no parameters, it uses
5245 'rotate' mode. That way auto-generated logs aren't automatically
5250 'rotate' mode. That way auto-generated logs aren't automatically
5246 over-written. For normal logs, now a backup is made if it exists
5251 over-written. For normal logs, now a backup is made if it exists
5247 (only 1 level of backups). A new 'backup' mode was added to the
5252 (only 1 level of backups). A new 'backup' mode was added to the
5248 Logger class to support this. This was a request by Janko.
5253 Logger class to support this. This was a request by Janko.
5249
5254
5250 * Added @logoff/@logon to stop/restart an active log.
5255 * Added @logoff/@logon to stop/restart an active log.
5251
5256
5252 * Fixed a lot of bugs in log saving/replay. It was pretty
5257 * Fixed a lot of bugs in log saving/replay. It was pretty
5253 broken. Now special lines (!@,/) appear properly in the command
5258 broken. Now special lines (!@,/) appear properly in the command
5254 history after a log replay.
5259 history after a log replay.
5255
5260
5256 * Tried and failed to implement full session saving via pickle. My
5261 * Tried and failed to implement full session saving via pickle. My
5257 idea was to pickle __main__.__dict__, but modules can't be
5262 idea was to pickle __main__.__dict__, but modules can't be
5258 pickled. This would be a better alternative to replaying logs, but
5263 pickled. This would be a better alternative to replaying logs, but
5259 seems quite tricky to get to work. Changed -session to be called
5264 seems quite tricky to get to work. Changed -session to be called
5260 -logplay, which more accurately reflects what it does. And if we
5265 -logplay, which more accurately reflects what it does. And if we
5261 ever get real session saving working, -session is now available.
5266 ever get real session saving working, -session is now available.
5262
5267
5263 * Implemented color schemes for prompts also. As for tracebacks,
5268 * Implemented color schemes for prompts also. As for tracebacks,
5264 currently only NoColor and Linux are supported. But now the
5269 currently only NoColor and Linux are supported. But now the
5265 infrastructure is in place, based on a generic ColorScheme
5270 infrastructure is in place, based on a generic ColorScheme
5266 class. So writing and activating new schemes both for the prompts
5271 class. So writing and activating new schemes both for the prompts
5267 and the tracebacks should be straightforward.
5272 and the tracebacks should be straightforward.
5268
5273
5269 * Version 0.1.13 released, 0.1.14 opened.
5274 * Version 0.1.13 released, 0.1.14 opened.
5270
5275
5271 * Changed handling of options for output cache. Now counter is
5276 * Changed handling of options for output cache. Now counter is
5272 hardwired starting at 1 and one specifies the maximum number of
5277 hardwired starting at 1 and one specifies the maximum number of
5273 entries *in the outcache* (not the max prompt counter). This is
5278 entries *in the outcache* (not the max prompt counter). This is
5274 much better, since many statements won't increase the cache
5279 much better, since many statements won't increase the cache
5275 count. It also eliminated some confusing options, now there's only
5280 count. It also eliminated some confusing options, now there's only
5276 one: cache_size.
5281 one: cache_size.
5277
5282
5278 * Added 'alias' magic function and magic_alias option in the
5283 * Added 'alias' magic function and magic_alias option in the
5279 ipythonrc file. Now the user can easily define whatever names he
5284 ipythonrc file. Now the user can easily define whatever names he
5280 wants for the magic functions without having to play weird
5285 wants for the magic functions without having to play weird
5281 namespace games. This gives IPython a real shell-like feel.
5286 namespace games. This gives IPython a real shell-like feel.
5282
5287
5283 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
5288 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
5284 @ or not).
5289 @ or not).
5285
5290
5286 This was one of the last remaining 'visible' bugs (that I know
5291 This was one of the last remaining 'visible' bugs (that I know
5287 of). I think if I can clean up the session loading so it works
5292 of). I think if I can clean up the session loading so it works
5288 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
5293 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
5289 about licensing).
5294 about licensing).
5290
5295
5291 2001-11-25 Fernando Perez <fperez@colorado.edu>
5296 2001-11-25 Fernando Perez <fperez@colorado.edu>
5292
5297
5293 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
5298 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
5294 there's a cleaner distinction between what ? and ?? show.
5299 there's a cleaner distinction between what ? and ?? show.
5295
5300
5296 * Added screen_length option. Now the user can define his own
5301 * Added screen_length option. Now the user can define his own
5297 screen size for page() operations.
5302 screen size for page() operations.
5298
5303
5299 * Implemented magic shell-like functions with automatic code
5304 * Implemented magic shell-like functions with automatic code
5300 generation. Now adding another function is just a matter of adding
5305 generation. Now adding another function is just a matter of adding
5301 an entry to a dict, and the function is dynamically generated at
5306 an entry to a dict, and the function is dynamically generated at
5302 run-time. Python has some really cool features!
5307 run-time. Python has some really cool features!
5303
5308
5304 * Renamed many options to cleanup conventions a little. Now all
5309 * Renamed many options to cleanup conventions a little. Now all
5305 are lowercase, and only underscores where needed. Also in the code
5310 are lowercase, and only underscores where needed. Also in the code
5306 option name tables are clearer.
5311 option name tables are clearer.
5307
5312
5308 * Changed prompts a little. Now input is 'In [n]:' instead of
5313 * Changed prompts a little. Now input is 'In [n]:' instead of
5309 'In[n]:='. This allows it the numbers to be aligned with the
5314 'In[n]:='. This allows it the numbers to be aligned with the
5310 Out[n] numbers, and removes usage of ':=' which doesn't exist in
5315 Out[n] numbers, and removes usage of ':=' which doesn't exist in
5311 Python (it was a Mathematica thing). The '...' continuation prompt
5316 Python (it was a Mathematica thing). The '...' continuation prompt
5312 was also changed a little to align better.
5317 was also changed a little to align better.
5313
5318
5314 * Fixed bug when flushing output cache. Not all _p<n> variables
5319 * Fixed bug when flushing output cache. Not all _p<n> variables
5315 exist, so their deletion needs to be wrapped in a try:
5320 exist, so their deletion needs to be wrapped in a try:
5316
5321
5317 * Figured out how to properly use inspect.formatargspec() (it
5322 * Figured out how to properly use inspect.formatargspec() (it
5318 requires the args preceded by *). So I removed all the code from
5323 requires the args preceded by *). So I removed all the code from
5319 _get_pdef in Magic, which was just replicating that.
5324 _get_pdef in Magic, which was just replicating that.
5320
5325
5321 * Added test to prefilter to allow redefining magic function names
5326 * Added test to prefilter to allow redefining magic function names
5322 as variables. This is ok, since the @ form is always available,
5327 as variables. This is ok, since the @ form is always available,
5323 but whe should allow the user to define a variable called 'ls' if
5328 but whe should allow the user to define a variable called 'ls' if
5324 he needs it.
5329 he needs it.
5325
5330
5326 * Moved the ToDo information from README into a separate ToDo.
5331 * Moved the ToDo information from README into a separate ToDo.
5327
5332
5328 * General code cleanup and small bugfixes. I think it's close to a
5333 * General code cleanup and small bugfixes. I think it's close to a
5329 state where it can be released, obviously with a big 'beta'
5334 state where it can be released, obviously with a big 'beta'
5330 warning on it.
5335 warning on it.
5331
5336
5332 * Got the magic function split to work. Now all magics are defined
5337 * Got the magic function split to work. Now all magics are defined
5333 in a separate class. It just organizes things a bit, and now
5338 in a separate class. It just organizes things a bit, and now
5334 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
5339 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
5335 was too long).
5340 was too long).
5336
5341
5337 * Changed @clear to @reset to avoid potential confusions with
5342 * Changed @clear to @reset to avoid potential confusions with
5338 the shell command clear. Also renamed @cl to @clear, which does
5343 the shell command clear. Also renamed @cl to @clear, which does
5339 exactly what people expect it to from their shell experience.
5344 exactly what people expect it to from their shell experience.
5340
5345
5341 Added a check to the @reset command (since it's so
5346 Added a check to the @reset command (since it's so
5342 destructive, it's probably a good idea to ask for confirmation).
5347 destructive, it's probably a good idea to ask for confirmation).
5343 But now reset only works for full namespace resetting. Since the
5348 But now reset only works for full namespace resetting. Since the
5344 del keyword is already there for deleting a few specific
5349 del keyword is already there for deleting a few specific
5345 variables, I don't see the point of having a redundant magic
5350 variables, I don't see the point of having a redundant magic
5346 function for the same task.
5351 function for the same task.
5347
5352
5348 2001-11-24 Fernando Perez <fperez@colorado.edu>
5353 2001-11-24 Fernando Perez <fperez@colorado.edu>
5349
5354
5350 * Updated the builtin docs (esp. the ? ones).
5355 * Updated the builtin docs (esp. the ? ones).
5351
5356
5352 * Ran all the code through pychecker. Not terribly impressed with
5357 * Ran all the code through pychecker. Not terribly impressed with
5353 it: lots of spurious warnings and didn't really find anything of
5358 it: lots of spurious warnings and didn't really find anything of
5354 substance (just a few modules being imported and not used).
5359 substance (just a few modules being imported and not used).
5355
5360
5356 * Implemented the new ultraTB functionality into IPython. New
5361 * Implemented the new ultraTB functionality into IPython. New
5357 option: xcolors. This chooses color scheme. xmode now only selects
5362 option: xcolors. This chooses color scheme. xmode now only selects
5358 between Plain and Verbose. Better orthogonality.
5363 between Plain and Verbose. Better orthogonality.
5359
5364
5360 * Large rewrite of ultraTB. Much cleaner now, with a separation of
5365 * Large rewrite of ultraTB. Much cleaner now, with a separation of
5361 mode and color scheme for the exception handlers. Now it's
5366 mode and color scheme for the exception handlers. Now it's
5362 possible to have the verbose traceback with no coloring.
5367 possible to have the verbose traceback with no coloring.
5363
5368
5364 2001-11-23 Fernando Perez <fperez@colorado.edu>
5369 2001-11-23 Fernando Perez <fperez@colorado.edu>
5365
5370
5366 * Version 0.1.12 released, 0.1.13 opened.
5371 * Version 0.1.12 released, 0.1.13 opened.
5367
5372
5368 * Removed option to set auto-quote and auto-paren escapes by
5373 * Removed option to set auto-quote and auto-paren escapes by
5369 user. The chances of breaking valid syntax are just too high. If
5374 user. The chances of breaking valid syntax are just too high. If
5370 someone *really* wants, they can always dig into the code.
5375 someone *really* wants, they can always dig into the code.
5371
5376
5372 * Made prompt separators configurable.
5377 * Made prompt separators configurable.
5373
5378
5374 2001-11-22 Fernando Perez <fperez@colorado.edu>
5379 2001-11-22 Fernando Perez <fperez@colorado.edu>
5375
5380
5376 * Small bugfixes in many places.
5381 * Small bugfixes in many places.
5377
5382
5378 * Removed the MyCompleter class from ipplib. It seemed redundant
5383 * Removed the MyCompleter class from ipplib. It seemed redundant
5379 with the C-p,C-n history search functionality. Less code to
5384 with the C-p,C-n history search functionality. Less code to
5380 maintain.
5385 maintain.
5381
5386
5382 * Moved all the original ipython.py code into ipythonlib.py. Right
5387 * Moved all the original ipython.py code into ipythonlib.py. Right
5383 now it's just one big dump into a function called make_IPython, so
5388 now it's just one big dump into a function called make_IPython, so
5384 no real modularity has been gained. But at least it makes the
5389 no real modularity has been gained. But at least it makes the
5385 wrapper script tiny, and since ipythonlib is a module, it gets
5390 wrapper script tiny, and since ipythonlib is a module, it gets
5386 compiled and startup is much faster.
5391 compiled and startup is much faster.
5387
5392
5388 This is a reasobably 'deep' change, so we should test it for a
5393 This is a reasobably 'deep' change, so we should test it for a
5389 while without messing too much more with the code.
5394 while without messing too much more with the code.
5390
5395
5391 2001-11-21 Fernando Perez <fperez@colorado.edu>
5396 2001-11-21 Fernando Perez <fperez@colorado.edu>
5392
5397
5393 * Version 0.1.11 released, 0.1.12 opened for further work.
5398 * Version 0.1.11 released, 0.1.12 opened for further work.
5394
5399
5395 * Removed dependency on Itpl. It was only needed in one place. It
5400 * Removed dependency on Itpl. It was only needed in one place. It
5396 would be nice if this became part of python, though. It makes life
5401 would be nice if this became part of python, though. It makes life
5397 *a lot* easier in some cases.
5402 *a lot* easier in some cases.
5398
5403
5399 * Simplified the prefilter code a bit. Now all handlers are
5404 * Simplified the prefilter code a bit. Now all handlers are
5400 expected to explicitly return a value (at least a blank string).
5405 expected to explicitly return a value (at least a blank string).
5401
5406
5402 * Heavy edits in ipplib. Removed the help system altogether. Now
5407 * Heavy edits in ipplib. Removed the help system altogether. Now
5403 obj?/?? is used for inspecting objects, a magic @doc prints
5408 obj?/?? is used for inspecting objects, a magic @doc prints
5404 docstrings, and full-blown Python help is accessed via the 'help'
5409 docstrings, and full-blown Python help is accessed via the 'help'
5405 keyword. This cleans up a lot of code (less to maintain) and does
5410 keyword. This cleans up a lot of code (less to maintain) and does
5406 the job. Since 'help' is now a standard Python component, might as
5411 the job. Since 'help' is now a standard Python component, might as
5407 well use it and remove duplicate functionality.
5412 well use it and remove duplicate functionality.
5408
5413
5409 Also removed the option to use ipplib as a standalone program. By
5414 Also removed the option to use ipplib as a standalone program. By
5410 now it's too dependent on other parts of IPython to function alone.
5415 now it's too dependent on other parts of IPython to function alone.
5411
5416
5412 * Fixed bug in genutils.pager. It would crash if the pager was
5417 * Fixed bug in genutils.pager. It would crash if the pager was
5413 exited immediately after opening (broken pipe).
5418 exited immediately after opening (broken pipe).
5414
5419
5415 * Trimmed down the VerboseTB reporting a little. The header is
5420 * Trimmed down the VerboseTB reporting a little. The header is
5416 much shorter now and the repeated exception arguments at the end
5421 much shorter now and the repeated exception arguments at the end
5417 have been removed. For interactive use the old header seemed a bit
5422 have been removed. For interactive use the old header seemed a bit
5418 excessive.
5423 excessive.
5419
5424
5420 * Fixed small bug in output of @whos for variables with multi-word
5425 * Fixed small bug in output of @whos for variables with multi-word
5421 types (only first word was displayed).
5426 types (only first word was displayed).
5422
5427
5423 2001-11-17 Fernando Perez <fperez@colorado.edu>
5428 2001-11-17 Fernando Perez <fperez@colorado.edu>
5424
5429
5425 * Version 0.1.10 released, 0.1.11 opened for further work.
5430 * Version 0.1.10 released, 0.1.11 opened for further work.
5426
5431
5427 * Modified dirs and friends. dirs now *returns* the stack (not
5432 * Modified dirs and friends. dirs now *returns* the stack (not
5428 prints), so one can manipulate it as a variable. Convenient to
5433 prints), so one can manipulate it as a variable. Convenient to
5429 travel along many directories.
5434 travel along many directories.
5430
5435
5431 * Fixed bug in magic_pdef: would only work with functions with
5436 * Fixed bug in magic_pdef: would only work with functions with
5432 arguments with default values.
5437 arguments with default values.
5433
5438
5434 2001-11-14 Fernando Perez <fperez@colorado.edu>
5439 2001-11-14 Fernando Perez <fperez@colorado.edu>
5435
5440
5436 * Added the PhysicsInput stuff to dot_ipython so it ships as an
5441 * Added the PhysicsInput stuff to dot_ipython so it ships as an
5437 example with IPython. Various other minor fixes and cleanups.
5442 example with IPython. Various other minor fixes and cleanups.
5438
5443
5439 * Version 0.1.9 released, 0.1.10 opened for further work.
5444 * Version 0.1.9 released, 0.1.10 opened for further work.
5440
5445
5441 * Added sys.path to the list of directories searched in the
5446 * Added sys.path to the list of directories searched in the
5442 execfile= option. It used to be the current directory and the
5447 execfile= option. It used to be the current directory and the
5443 user's IPYTHONDIR only.
5448 user's IPYTHONDIR only.
5444
5449
5445 2001-11-13 Fernando Perez <fperez@colorado.edu>
5450 2001-11-13 Fernando Perez <fperez@colorado.edu>
5446
5451
5447 * Reinstated the raw_input/prefilter separation that Janko had
5452 * Reinstated the raw_input/prefilter separation that Janko had
5448 initially. This gives a more convenient setup for extending the
5453 initially. This gives a more convenient setup for extending the
5449 pre-processor from the outside: raw_input always gets a string,
5454 pre-processor from the outside: raw_input always gets a string,
5450 and prefilter has to process it. We can then redefine prefilter
5455 and prefilter has to process it. We can then redefine prefilter
5451 from the outside and implement extensions for special
5456 from the outside and implement extensions for special
5452 purposes.
5457 purposes.
5453
5458
5454 Today I got one for inputting PhysicalQuantity objects
5459 Today I got one for inputting PhysicalQuantity objects
5455 (from Scientific) without needing any function calls at
5460 (from Scientific) without needing any function calls at
5456 all. Extremely convenient, and it's all done as a user-level
5461 all. Extremely convenient, and it's all done as a user-level
5457 extension (no IPython code was touched). Now instead of:
5462 extension (no IPython code was touched). Now instead of:
5458 a = PhysicalQuantity(4.2,'m/s**2')
5463 a = PhysicalQuantity(4.2,'m/s**2')
5459 one can simply say
5464 one can simply say
5460 a = 4.2 m/s**2
5465 a = 4.2 m/s**2
5461 or even
5466 or even
5462 a = 4.2 m/s^2
5467 a = 4.2 m/s^2
5463
5468
5464 I use this, but it's also a proof of concept: IPython really is
5469 I use this, but it's also a proof of concept: IPython really is
5465 fully user-extensible, even at the level of the parsing of the
5470 fully user-extensible, even at the level of the parsing of the
5466 command line. It's not trivial, but it's perfectly doable.
5471 command line. It's not trivial, but it's perfectly doable.
5467
5472
5468 * Added 'add_flip' method to inclusion conflict resolver. Fixes
5473 * Added 'add_flip' method to inclusion conflict resolver. Fixes
5469 the problem of modules being loaded in the inverse order in which
5474 the problem of modules being loaded in the inverse order in which
5470 they were defined in
5475 they were defined in
5471
5476
5472 * Version 0.1.8 released, 0.1.9 opened for further work.
5477 * Version 0.1.8 released, 0.1.9 opened for further work.
5473
5478
5474 * Added magics pdef, source and file. They respectively show the
5479 * Added magics pdef, source and file. They respectively show the
5475 definition line ('prototype' in C), source code and full python
5480 definition line ('prototype' in C), source code and full python
5476 file for any callable object. The object inspector oinfo uses
5481 file for any callable object. The object inspector oinfo uses
5477 these to show the same information.
5482 these to show the same information.
5478
5483
5479 * Version 0.1.7 released, 0.1.8 opened for further work.
5484 * Version 0.1.7 released, 0.1.8 opened for further work.
5480
5485
5481 * Separated all the magic functions into a class called Magic. The
5486 * Separated all the magic functions into a class called Magic. The
5482 InteractiveShell class was becoming too big for Xemacs to handle
5487 InteractiveShell class was becoming too big for Xemacs to handle
5483 (de-indenting a line would lock it up for 10 seconds while it
5488 (de-indenting a line would lock it up for 10 seconds while it
5484 backtracked on the whole class!)
5489 backtracked on the whole class!)
5485
5490
5486 FIXME: didn't work. It can be done, but right now namespaces are
5491 FIXME: didn't work. It can be done, but right now namespaces are
5487 all messed up. Do it later (reverted it for now, so at least
5492 all messed up. Do it later (reverted it for now, so at least
5488 everything works as before).
5493 everything works as before).
5489
5494
5490 * Got the object introspection system (magic_oinfo) working! I
5495 * Got the object introspection system (magic_oinfo) working! I
5491 think this is pretty much ready for release to Janko, so he can
5496 think this is pretty much ready for release to Janko, so he can
5492 test it for a while and then announce it. Pretty much 100% of what
5497 test it for a while and then announce it. Pretty much 100% of what
5493 I wanted for the 'phase 1' release is ready. Happy, tired.
5498 I wanted for the 'phase 1' release is ready. Happy, tired.
5494
5499
5495 2001-11-12 Fernando Perez <fperez@colorado.edu>
5500 2001-11-12 Fernando Perez <fperez@colorado.edu>
5496
5501
5497 * Version 0.1.6 released, 0.1.7 opened for further work.
5502 * Version 0.1.6 released, 0.1.7 opened for further work.
5498
5503
5499 * Fixed bug in printing: it used to test for truth before
5504 * Fixed bug in printing: it used to test for truth before
5500 printing, so 0 wouldn't print. Now checks for None.
5505 printing, so 0 wouldn't print. Now checks for None.
5501
5506
5502 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
5507 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
5503 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
5508 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
5504 reaches by hand into the outputcache. Think of a better way to do
5509 reaches by hand into the outputcache. Think of a better way to do
5505 this later.
5510 this later.
5506
5511
5507 * Various small fixes thanks to Nathan's comments.
5512 * Various small fixes thanks to Nathan's comments.
5508
5513
5509 * Changed magic_pprint to magic_Pprint. This way it doesn't
5514 * Changed magic_pprint to magic_Pprint. This way it doesn't
5510 collide with pprint() and the name is consistent with the command
5515 collide with pprint() and the name is consistent with the command
5511 line option.
5516 line option.
5512
5517
5513 * Changed prompt counter behavior to be fully like
5518 * Changed prompt counter behavior to be fully like
5514 Mathematica's. That is, even input that doesn't return a result
5519 Mathematica's. That is, even input that doesn't return a result
5515 raises the prompt counter. The old behavior was kind of confusing
5520 raises the prompt counter. The old behavior was kind of confusing
5516 (getting the same prompt number several times if the operation
5521 (getting the same prompt number several times if the operation
5517 didn't return a result).
5522 didn't return a result).
5518
5523
5519 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
5524 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
5520
5525
5521 * Fixed -Classic mode (wasn't working anymore).
5526 * Fixed -Classic mode (wasn't working anymore).
5522
5527
5523 * Added colored prompts using Nathan's new code. Colors are
5528 * Added colored prompts using Nathan's new code. Colors are
5524 currently hardwired, they can be user-configurable. For
5529 currently hardwired, they can be user-configurable. For
5525 developers, they can be chosen in file ipythonlib.py, at the
5530 developers, they can be chosen in file ipythonlib.py, at the
5526 beginning of the CachedOutput class def.
5531 beginning of the CachedOutput class def.
5527
5532
5528 2001-11-11 Fernando Perez <fperez@colorado.edu>
5533 2001-11-11 Fernando Perez <fperez@colorado.edu>
5529
5534
5530 * Version 0.1.5 released, 0.1.6 opened for further work.
5535 * Version 0.1.5 released, 0.1.6 opened for further work.
5531
5536
5532 * Changed magic_env to *return* the environment as a dict (not to
5537 * Changed magic_env to *return* the environment as a dict (not to
5533 print it). This way it prints, but it can also be processed.
5538 print it). This way it prints, but it can also be processed.
5534
5539
5535 * Added Verbose exception reporting to interactive
5540 * Added Verbose exception reporting to interactive
5536 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
5541 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
5537 traceback. Had to make some changes to the ultraTB file. This is
5542 traceback. Had to make some changes to the ultraTB file. This is
5538 probably the last 'big' thing in my mental todo list. This ties
5543 probably the last 'big' thing in my mental todo list. This ties
5539 in with the next entry:
5544 in with the next entry:
5540
5545
5541 * Changed -Xi and -Xf to a single -xmode option. Now all the user
5546 * Changed -Xi and -Xf to a single -xmode option. Now all the user
5542 has to specify is Plain, Color or Verbose for all exception
5547 has to specify is Plain, Color or Verbose for all exception
5543 handling.
5548 handling.
5544
5549
5545 * Removed ShellServices option. All this can really be done via
5550 * Removed ShellServices option. All this can really be done via
5546 the magic system. It's easier to extend, cleaner and has automatic
5551 the magic system. It's easier to extend, cleaner and has automatic
5547 namespace protection and documentation.
5552 namespace protection and documentation.
5548
5553
5549 2001-11-09 Fernando Perez <fperez@colorado.edu>
5554 2001-11-09 Fernando Perez <fperez@colorado.edu>
5550
5555
5551 * Fixed bug in output cache flushing (missing parameter to
5556 * Fixed bug in output cache flushing (missing parameter to
5552 __init__). Other small bugs fixed (found using pychecker).
5557 __init__). Other small bugs fixed (found using pychecker).
5553
5558
5554 * Version 0.1.4 opened for bugfixing.
5559 * Version 0.1.4 opened for bugfixing.
5555
5560
5556 2001-11-07 Fernando Perez <fperez@colorado.edu>
5561 2001-11-07 Fernando Perez <fperez@colorado.edu>
5557
5562
5558 * Version 0.1.3 released, mainly because of the raw_input bug.
5563 * Version 0.1.3 released, mainly because of the raw_input bug.
5559
5564
5560 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
5565 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
5561 and when testing for whether things were callable, a call could
5566 and when testing for whether things were callable, a call could
5562 actually be made to certain functions. They would get called again
5567 actually be made to certain functions. They would get called again
5563 once 'really' executed, with a resulting double call. A disaster
5568 once 'really' executed, with a resulting double call. A disaster
5564 in many cases (list.reverse() would never work!).
5569 in many cases (list.reverse() would never work!).
5565
5570
5566 * Removed prefilter() function, moved its code to raw_input (which
5571 * Removed prefilter() function, moved its code to raw_input (which
5567 after all was just a near-empty caller for prefilter). This saves
5572 after all was just a near-empty caller for prefilter). This saves
5568 a function call on every prompt, and simplifies the class a tiny bit.
5573 a function call on every prompt, and simplifies the class a tiny bit.
5569
5574
5570 * Fix _ip to __ip name in magic example file.
5575 * Fix _ip to __ip name in magic example file.
5571
5576
5572 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
5577 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
5573 work with non-gnu versions of tar.
5578 work with non-gnu versions of tar.
5574
5579
5575 2001-11-06 Fernando Perez <fperez@colorado.edu>
5580 2001-11-06 Fernando Perez <fperez@colorado.edu>
5576
5581
5577 * Version 0.1.2. Just to keep track of the recent changes.
5582 * Version 0.1.2. Just to keep track of the recent changes.
5578
5583
5579 * Fixed nasty bug in output prompt routine. It used to check 'if
5584 * Fixed nasty bug in output prompt routine. It used to check 'if
5580 arg != None...'. Problem is, this fails if arg implements a
5585 arg != None...'. Problem is, this fails if arg implements a
5581 special comparison (__cmp__) which disallows comparing to
5586 special comparison (__cmp__) which disallows comparing to
5582 None. Found it when trying to use the PhysicalQuantity module from
5587 None. Found it when trying to use the PhysicalQuantity module from
5583 ScientificPython.
5588 ScientificPython.
5584
5589
5585 2001-11-05 Fernando Perez <fperez@colorado.edu>
5590 2001-11-05 Fernando Perez <fperez@colorado.edu>
5586
5591
5587 * Also added dirs. Now the pushd/popd/dirs family functions
5592 * Also added dirs. Now the pushd/popd/dirs family functions
5588 basically like the shell, with the added convenience of going home
5593 basically like the shell, with the added convenience of going home
5589 when called with no args.
5594 when called with no args.
5590
5595
5591 * pushd/popd slightly modified to mimic shell behavior more
5596 * pushd/popd slightly modified to mimic shell behavior more
5592 closely.
5597 closely.
5593
5598
5594 * Added env,pushd,popd from ShellServices as magic functions. I
5599 * Added env,pushd,popd from ShellServices as magic functions. I
5595 think the cleanest will be to port all desired functions from
5600 think the cleanest will be to port all desired functions from
5596 ShellServices as magics and remove ShellServices altogether. This
5601 ShellServices as magics and remove ShellServices altogether. This
5597 will provide a single, clean way of adding functionality
5602 will provide a single, clean way of adding functionality
5598 (shell-type or otherwise) to IP.
5603 (shell-type or otherwise) to IP.
5599
5604
5600 2001-11-04 Fernando Perez <fperez@colorado.edu>
5605 2001-11-04 Fernando Perez <fperez@colorado.edu>
5601
5606
5602 * Added .ipython/ directory to sys.path. This way users can keep
5607 * Added .ipython/ directory to sys.path. This way users can keep
5603 customizations there and access them via import.
5608 customizations there and access them via import.
5604
5609
5605 2001-11-03 Fernando Perez <fperez@colorado.edu>
5610 2001-11-03 Fernando Perez <fperez@colorado.edu>
5606
5611
5607 * Opened version 0.1.1 for new changes.
5612 * Opened version 0.1.1 for new changes.
5608
5613
5609 * Changed version number to 0.1.0: first 'public' release, sent to
5614 * Changed version number to 0.1.0: first 'public' release, sent to
5610 Nathan and Janko.
5615 Nathan and Janko.
5611
5616
5612 * Lots of small fixes and tweaks.
5617 * Lots of small fixes and tweaks.
5613
5618
5614 * Minor changes to whos format. Now strings are shown, snipped if
5619 * Minor changes to whos format. Now strings are shown, snipped if
5615 too long.
5620 too long.
5616
5621
5617 * Changed ShellServices to work on __main__ so they show up in @who
5622 * Changed ShellServices to work on __main__ so they show up in @who
5618
5623
5619 * Help also works with ? at the end of a line:
5624 * Help also works with ? at the end of a line:
5620 ?sin and sin?
5625 ?sin and sin?
5621 both produce the same effect. This is nice, as often I use the
5626 both produce the same effect. This is nice, as often I use the
5622 tab-complete to find the name of a method, but I used to then have
5627 tab-complete to find the name of a method, but I used to then have
5623 to go to the beginning of the line to put a ? if I wanted more
5628 to go to the beginning of the line to put a ? if I wanted more
5624 info. Now I can just add the ? and hit return. Convenient.
5629 info. Now I can just add the ? and hit return. Convenient.
5625
5630
5626 2001-11-02 Fernando Perez <fperez@colorado.edu>
5631 2001-11-02 Fernando Perez <fperez@colorado.edu>
5627
5632
5628 * Python version check (>=2.1) added.
5633 * Python version check (>=2.1) added.
5629
5634
5630 * Added LazyPython documentation. At this point the docs are quite
5635 * Added LazyPython documentation. At this point the docs are quite
5631 a mess. A cleanup is in order.
5636 a mess. A cleanup is in order.
5632
5637
5633 * Auto-installer created. For some bizarre reason, the zipfiles
5638 * Auto-installer created. For some bizarre reason, the zipfiles
5634 module isn't working on my system. So I made a tar version
5639 module isn't working on my system. So I made a tar version
5635 (hopefully the command line options in various systems won't kill
5640 (hopefully the command line options in various systems won't kill
5636 me).
5641 me).
5637
5642
5638 * Fixes to Struct in genutils. Now all dictionary-like methods are
5643 * Fixes to Struct in genutils. Now all dictionary-like methods are
5639 protected (reasonably).
5644 protected (reasonably).
5640
5645
5641 * Added pager function to genutils and changed ? to print usage
5646 * Added pager function to genutils and changed ? to print usage
5642 note through it (it was too long).
5647 note through it (it was too long).
5643
5648
5644 * Added the LazyPython functionality. Works great! I changed the
5649 * Added the LazyPython functionality. Works great! I changed the
5645 auto-quote escape to ';', it's on home row and next to '. But
5650 auto-quote escape to ';', it's on home row and next to '. But
5646 both auto-quote and auto-paren (still /) escapes are command-line
5651 both auto-quote and auto-paren (still /) escapes are command-line
5647 parameters.
5652 parameters.
5648
5653
5649
5654
5650 2001-11-01 Fernando Perez <fperez@colorado.edu>
5655 2001-11-01 Fernando Perez <fperez@colorado.edu>
5651
5656
5652 * Version changed to 0.0.7. Fairly large change: configuration now
5657 * Version changed to 0.0.7. Fairly large change: configuration now
5653 is all stored in a directory, by default .ipython. There, all
5658 is all stored in a directory, by default .ipython. There, all
5654 config files have normal looking names (not .names)
5659 config files have normal looking names (not .names)
5655
5660
5656 * Version 0.0.6 Released first to Lucas and Archie as a test
5661 * Version 0.0.6 Released first to Lucas and Archie as a test
5657 run. Since it's the first 'semi-public' release, change version to
5662 run. Since it's the first 'semi-public' release, change version to
5658 > 0.0.6 for any changes now.
5663 > 0.0.6 for any changes now.
5659
5664
5660 * Stuff I had put in the ipplib.py changelog:
5665 * Stuff I had put in the ipplib.py changelog:
5661
5666
5662 Changes to InteractiveShell:
5667 Changes to InteractiveShell:
5663
5668
5664 - Made the usage message a parameter.
5669 - Made the usage message a parameter.
5665
5670
5666 - Require the name of the shell variable to be given. It's a bit
5671 - Require the name of the shell variable to be given. It's a bit
5667 of a hack, but allows the name 'shell' not to be hardwired in the
5672 of a hack, but allows the name 'shell' not to be hardwired in the
5668 magic (@) handler, which is problematic b/c it requires
5673 magic (@) handler, which is problematic b/c it requires
5669 polluting the global namespace with 'shell'. This in turn is
5674 polluting the global namespace with 'shell'. This in turn is
5670 fragile: if a user redefines a variable called shell, things
5675 fragile: if a user redefines a variable called shell, things
5671 break.
5676 break.
5672
5677
5673 - magic @: all functions available through @ need to be defined
5678 - magic @: all functions available through @ need to be defined
5674 as magic_<name>, even though they can be called simply as
5679 as magic_<name>, even though they can be called simply as
5675 @<name>. This allows the special command @magic to gather
5680 @<name>. This allows the special command @magic to gather
5676 information automatically about all existing magic functions,
5681 information automatically about all existing magic functions,
5677 even if they are run-time user extensions, by parsing the shell
5682 even if they are run-time user extensions, by parsing the shell
5678 instance __dict__ looking for special magic_ names.
5683 instance __dict__ looking for special magic_ names.
5679
5684
5680 - mainloop: added *two* local namespace parameters. This allows
5685 - mainloop: added *two* local namespace parameters. This allows
5681 the class to differentiate between parameters which were there
5686 the class to differentiate between parameters which were there
5682 before and after command line initialization was processed. This
5687 before and after command line initialization was processed. This
5683 way, later @who can show things loaded at startup by the
5688 way, later @who can show things loaded at startup by the
5684 user. This trick was necessary to make session saving/reloading
5689 user. This trick was necessary to make session saving/reloading
5685 really work: ideally after saving/exiting/reloading a session,
5690 really work: ideally after saving/exiting/reloading a session,
5686 *everything* should look the same, including the output of @who. I
5691 *everything* should look the same, including the output of @who. I
5687 was only able to make this work with this double namespace
5692 was only able to make this work with this double namespace
5688 trick.
5693 trick.
5689
5694
5690 - added a header to the logfile which allows (almost) full
5695 - added a header to the logfile which allows (almost) full
5691 session restoring.
5696 session restoring.
5692
5697
5693 - prepend lines beginning with @ or !, with a and log
5698 - prepend lines beginning with @ or !, with a and log
5694 them. Why? !lines: may be useful to know what you did @lines:
5699 them. Why? !lines: may be useful to know what you did @lines:
5695 they may affect session state. So when restoring a session, at
5700 they may affect session state. So when restoring a session, at
5696 least inform the user of their presence. I couldn't quite get
5701 least inform the user of their presence. I couldn't quite get
5697 them to properly re-execute, but at least the user is warned.
5702 them to properly re-execute, but at least the user is warned.
5698
5703
5699 * Started ChangeLog.
5704 * Started ChangeLog.
General Comments 0
You need to be logged in to leave comments. Login now