##// END OF EJS Templates
Make cursor visible over non existing attributes.
walter.doerwald -
Show More
@@ -1,1663 +1,1665 b''
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 __xiter__(self, mode):
100 def __xiter__(self, mode):
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, description=astyle.Text((self.style_header, name)))
128 yield ipipe.Fields(fields, 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 # Attribute names to display (in this order)
186 # Attribute names to display (in this order)
187 self.displayattrs = []
187 self.displayattrs = []
188
188
189 # index and name of attribute under the cursor
189 # index and name of attribute under the cursor
190 self.displayattr = (None, ipipe.noitem)
190 self.displayattr = (None, ipipe.noitem)
191
191
192 # Maps attribute names to column widths
192 # Maps attribute names 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 else:
210 else:
211 have += 1
211 have += 1
212 self.items.append(_BrowserCachedItem(item))
212 self.items.append(_BrowserCachedItem(item))
213
213
214 def calcdisplayattrs(self):
214 def calcdisplayattrs(self):
215 # Calculate which attributes are available from the objects that are
215 # Calculate which attributes are available from the objects that are
216 # currently visible on screen (and store it in ``self.displayattrs``)
216 # currently visible on screen (and store it in ``self.displayattrs``)
217
217
218 attrnames = set()
218 attrnames = set()
219 self.displayattrs = []
219 self.displayattrs = []
220 if self.attrs:
220 if self.attrs:
221 # If the browser object specifies a fixed list of attributes,
221 # If the browser object specifies a fixed list of attributes,
222 # simply use it (removing hidden attributes).
222 # simply use it (removing hidden attributes).
223 for attrname in self.attrs:
223 for attrname in self.attrs:
224 if attrname not in attrnames and attrname not in self.hiddenattrs:
224 if attrname not in attrnames and attrname not in self.hiddenattrs:
225 self.displayattrs.append(attrname)
225 self.displayattrs.append(attrname)
226 attrnames.add(attrname)
226 attrnames.add(attrname)
227 else:
227 else:
228 endy = min(self.datastarty+self.mainsizey, len(self.items))
228 endy = min(self.datastarty+self.mainsizey, len(self.items))
229 for i in xrange(self.datastarty, endy):
229 for i in xrange(self.datastarty, endy):
230 for attrname in ipipe.xattrs(self.items[i].item, "default"):
230 for attrname in ipipe.xattrs(self.items[i].item, "default"):
231 if attrname not in attrnames and attrname not in self.hiddenattrs:
231 if attrname not in attrnames and attrname not in self.hiddenattrs:
232 self.displayattrs.append(attrname)
232 self.displayattrs.append(attrname)
233 attrnames.add(attrname)
233 attrnames.add(attrname)
234
234
235 def getrow(self, i):
235 def getrow(self, i):
236 # Return a dictinary with the attributes for the object
236 # Return a dictinary with the attributes for the object
237 # ``self.items[i]``. Attribute names are taken from
237 # ``self.items[i]``. Attribute names are taken from
238 # ``self.displayattrs`` so ``calcdisplayattrs()`` must have been
238 # ``self.displayattrs`` so ``calcdisplayattrs()`` must have been
239 # called before.
239 # called before.
240 row = {}
240 row = {}
241 item = self.items[i].item
241 item = self.items[i].item
242 for attrname in self.displayattrs:
242 for attrname in self.displayattrs:
243 try:
243 try:
244 value = ipipe._getattr(item, attrname, ipipe.noitem)
244 value = ipipe._getattr(item, attrname, ipipe.noitem)
245 except (KeyboardInterrupt, SystemExit):
245 except (KeyboardInterrupt, SystemExit):
246 raise
246 raise
247 except Exception, exc:
247 except Exception, exc:
248 value = exc
248 value = exc
249 # only store attribute if it exists (or we got an exception)
249 # only store attribute if it exists (or we got an exception)
250 if value is not ipipe.noitem:
250 if value is not ipipe.noitem:
251 # remember alignment, length and colored text
251 # remember alignment, length and colored text
252 row[attrname] = ipipe.xformat(value, "cell", self.browser.maxattrlength)
252 row[attrname] = ipipe.xformat(value, "cell", self.browser.maxattrlength)
253 return row
253 return row
254
254
255 def calcwidths(self):
255 def calcwidths(self):
256 # Recalculate the displayed fields and their widths.
256 # Recalculate the displayed fields and their widths.
257 # ``calcdisplayattrs()'' must have been called and the cache
257 # ``calcdisplayattrs()'' must have been called and the cache
258 # for attributes of the objects on screen (``self.displayrows``)
258 # for attributes of the objects on screen (``self.displayrows``)
259 # must have been filled. This returns a dictionary mapping
259 # must have been filled. This returns a dictionary mapping
260 # column names to widths.
260 # column names to widths.
261 self.colwidths = {}
261 self.colwidths = {}
262 for row in self.displayrows:
262 for row in self.displayrows:
263 for attrname in self.displayattrs:
263 for attrname in self.displayattrs:
264 try:
264 try:
265 length = row[attrname][1]
265 length = row[attrname][1]
266 except KeyError:
266 except KeyError:
267 length = 0
267 length = 0
268 # always add attribute to colwidths, even if it doesn't exist
268 # always add attribute to colwidths, even if it doesn't exist
269 if attrname not in self.colwidths:
269 if attrname not in self.colwidths:
270 self.colwidths[attrname] = len(ipipe._attrname(attrname))
270 self.colwidths[attrname] = len(ipipe._attrname(attrname))
271 newwidth = max(self.colwidths[attrname], length)
271 newwidth = max(self.colwidths[attrname], length)
272 self.colwidths[attrname] = newwidth
272 self.colwidths[attrname] = newwidth
273
273
274 # How many characters do we need to paint the largest item number?
274 # How many characters do we need to paint the largest item number?
275 self.numbersizex = len(str(self.datastarty+self.mainsizey-1))
275 self.numbersizex = len(str(self.datastarty+self.mainsizey-1))
276 # How must space have we got to display data?
276 # How must space have we got to display data?
277 self.mainsizex = self.browser.scrsizex-self.numbersizex-3
277 self.mainsizex = self.browser.scrsizex-self.numbersizex-3
278 # width of all columns
278 # width of all columns
279 self.datasizex = sum(self.colwidths.itervalues()) + len(self.colwidths)
279 self.datasizex = sum(self.colwidths.itervalues()) + len(self.colwidths)
280
280
281 def calcdisplayattr(self):
281 def calcdisplayattr(self):
282 # Find out which attribute the cursor is on and store this
282 # Find out which attribute the cursor is on and store this
283 # information in ``self.displayattr``.
283 # information in ``self.displayattr``.
284 pos = 0
284 pos = 0
285 for (i, attrname) in enumerate(self.displayattrs):
285 for (i, attrname) in enumerate(self.displayattrs):
286 if pos+self.colwidths[attrname] >= self.curx:
286 if pos+self.colwidths[attrname] >= self.curx:
287 self.displayattr = (i, attrname)
287 self.displayattr = (i, attrname)
288 break
288 break
289 pos += self.colwidths[attrname]+1
289 pos += self.colwidths[attrname]+1
290 else:
290 else:
291 self.displayattr = (None, ipipe.noitem)
291 self.displayattr = (None, ipipe.noitem)
292
292
293 def moveto(self, x, y, refresh=False):
293 def moveto(self, x, y, refresh=False):
294 # Move the cursor to the position ``(x,y)`` (in data coordinates,
294 # Move the cursor to the position ``(x,y)`` (in data coordinates,
295 # not in screen coordinates). If ``refresh`` is true, all cached
295 # not in screen coordinates). If ``refresh`` is true, all cached
296 # values will be recalculated (e.g. because the list has been
296 # values will be recalculated (e.g. because the list has been
297 # resorted, so screen positions etc. are no longer valid).
297 # resorted, so screen positions etc. are no longer valid).
298 olddatastarty = self.datastarty
298 olddatastarty = self.datastarty
299 oldx = self.curx
299 oldx = self.curx
300 oldy = self.cury
300 oldy = self.cury
301 x = int(x+0.5)
301 x = int(x+0.5)
302 y = int(y+0.5)
302 y = int(y+0.5)
303 newx = x # remember where we wanted to move
303 newx = x # remember where we wanted to move
304 newy = y # remember where we wanted to move
304 newy = y # remember where we wanted to move
305
305
306 scrollbordery = min(self.browser.scrollbordery, self.mainsizey//2)
306 scrollbordery = min(self.browser.scrollbordery, self.mainsizey//2)
307 scrollborderx = min(self.browser.scrollborderx, self.mainsizex//2)
307 scrollborderx = min(self.browser.scrollborderx, self.mainsizex//2)
308
308
309 # Make sure that the cursor didn't leave the main area vertically
309 # Make sure that the cursor didn't leave the main area vertically
310 if y < 0:
310 if y < 0:
311 y = 0
311 y = 0
312 # try to get enough items to fill the screen
312 # try to get enough items to fill the screen
313 self.fetch(max(y+scrollbordery+1, self.mainsizey))
313 self.fetch(max(y+scrollbordery+1, self.mainsizey))
314 if y >= len(self.items):
314 if y >= len(self.items):
315 y = max(0, len(self.items)-1)
315 y = max(0, len(self.items)-1)
316
316
317 # Make sure that the cursor stays on screen vertically
317 # Make sure that the cursor stays on screen vertically
318 if y < self.datastarty+scrollbordery:
318 if y < self.datastarty+scrollbordery:
319 self.datastarty = max(0, y-scrollbordery)
319 self.datastarty = max(0, y-scrollbordery)
320 elif y >= self.datastarty+self.mainsizey-scrollbordery:
320 elif y >= self.datastarty+self.mainsizey-scrollbordery:
321 self.datastarty = max(0, min(y-self.mainsizey+scrollbordery+1,
321 self.datastarty = max(0, min(y-self.mainsizey+scrollbordery+1,
322 len(self.items)-self.mainsizey))
322 len(self.items)-self.mainsizey))
323
323
324 if refresh: # Do we need to refresh the complete display?
324 if refresh: # Do we need to refresh the complete display?
325 self.calcdisplayattrs()
325 self.calcdisplayattrs()
326 endy = min(self.datastarty+self.mainsizey, len(self.items))
326 endy = min(self.datastarty+self.mainsizey, len(self.items))
327 self.displayrows = map(self.getrow, xrange(self.datastarty, endy))
327 self.displayrows = map(self.getrow, xrange(self.datastarty, endy))
328 self.calcwidths()
328 self.calcwidths()
329 # Did we scroll vertically => update displayrows
329 # Did we scroll vertically => update displayrows
330 # and various other attributes
330 # and various other attributes
331 elif self.datastarty != olddatastarty:
331 elif self.datastarty != olddatastarty:
332 # Recalculate which attributes we have to display
332 # Recalculate which attributes we have to display
333 olddisplayattrs = self.displayattrs
333 olddisplayattrs = self.displayattrs
334 self.calcdisplayattrs()
334 self.calcdisplayattrs()
335 # If there are new attributes, recreate the cache
335 # If there are new attributes, recreate the cache
336 if self.displayattrs != olddisplayattrs:
336 if self.displayattrs != olddisplayattrs:
337 endy = min(self.datastarty+self.mainsizey, len(self.items))
337 endy = min(self.datastarty+self.mainsizey, len(self.items))
338 self.displayrows = map(self.getrow, xrange(self.datastarty, endy))
338 self.displayrows = map(self.getrow, xrange(self.datastarty, endy))
339 elif self.datastarty<olddatastarty: # we did scroll up
339 elif self.datastarty<olddatastarty: # we did scroll up
340 # drop rows from the end
340 # drop rows from the end
341 del self.displayrows[self.datastarty-olddatastarty:]
341 del self.displayrows[self.datastarty-olddatastarty:]
342 # fetch new items
342 # fetch new items
343 for i in xrange(min(olddatastarty, self.datastarty+self.mainsizey)-1,
343 for i in xrange(min(olddatastarty, self.datastarty+self.mainsizey)-1,
344 self.datastarty-1, -1):
344 self.datastarty-1, -1):
345 try:
345 try:
346 row = self.getrow(i)
346 row = self.getrow(i)
347 except IndexError:
347 except IndexError:
348 # we didn't have enough objects to fill the screen
348 # we didn't have enough objects to fill the screen
349 break
349 break
350 self.displayrows.insert(0, row)
350 self.displayrows.insert(0, row)
351 else: # we did scroll down
351 else: # we did scroll down
352 # drop rows from the start
352 # drop rows from the start
353 del self.displayrows[:self.datastarty-olddatastarty]
353 del self.displayrows[:self.datastarty-olddatastarty]
354 # fetch new items
354 # fetch new items
355 for i in xrange(max(olddatastarty+self.mainsizey, self.datastarty),
355 for i in xrange(max(olddatastarty+self.mainsizey, self.datastarty),
356 self.datastarty+self.mainsizey):
356 self.datastarty+self.mainsizey):
357 try:
357 try:
358 row = self.getrow(i)
358 row = self.getrow(i)
359 except IndexError:
359 except IndexError:
360 # we didn't have enough objects to fill the screen
360 # we didn't have enough objects to fill the screen
361 break
361 break
362 self.displayrows.append(row)
362 self.displayrows.append(row)
363 self.calcwidths()
363 self.calcwidths()
364
364
365 # Make sure that the cursor didn't leave the data area horizontally
365 # Make sure that the cursor didn't leave the data area horizontally
366 if x < 0:
366 if x < 0:
367 x = 0
367 x = 0
368 elif x >= self.datasizex:
368 elif x >= self.datasizex:
369 x = max(0, self.datasizex-1)
369 x = max(0, self.datasizex-1)
370
370
371 # Make sure that the cursor stays on screen horizontally
371 # Make sure that the cursor stays on screen horizontally
372 if x < self.datastartx+scrollborderx:
372 if x < self.datastartx+scrollborderx:
373 self.datastartx = max(0, x-scrollborderx)
373 self.datastartx = max(0, x-scrollborderx)
374 elif x >= self.datastartx+self.mainsizex-scrollborderx:
374 elif x >= self.datastartx+self.mainsizex-scrollborderx:
375 self.datastartx = max(0, min(x-self.mainsizex+scrollborderx+1,
375 self.datastartx = max(0, min(x-self.mainsizex+scrollborderx+1,
376 self.datasizex-self.mainsizex))
376 self.datasizex-self.mainsizex))
377
377
378 if x == oldx and y == oldy and (x != newx or y != newy): # couldn't move
378 if x == oldx and y == oldy and (x != newx or y != newy): # couldn't move
379 self.browser.beep()
379 self.browser.beep()
380 else:
380 else:
381 self.curx = x
381 self.curx = x
382 self.cury = y
382 self.cury = y
383 self.calcdisplayattr()
383 self.calcdisplayattr()
384
384
385 def sort(self, key, reverse=False):
385 def sort(self, key, reverse=False):
386 """
386 """
387 Sort the currently list of items using the key function ``key``. If
387 Sort the currently list of items using the key function ``key``. If
388 ``reverse`` is true the sort order is reversed.
388 ``reverse`` is true the sort order is reversed.
389 """
389 """
390 curitem = self.items[self.cury] # Remember where the cursor is now
390 curitem = self.items[self.cury] # Remember where the cursor is now
391
391
392 # Sort items
392 # Sort items
393 def realkey(item):
393 def realkey(item):
394 return key(item.item)
394 return key(item.item)
395 self.items = ipipe.deque(sorted(self.items, key=realkey, reverse=reverse))
395 self.items = ipipe.deque(sorted(self.items, key=realkey, reverse=reverse))
396
396
397 # Find out where the object under the cursor went
397 # Find out where the object under the cursor went
398 cury = self.cury
398 cury = self.cury
399 for (i, item) in enumerate(self.items):
399 for (i, item) in enumerate(self.items):
400 if item is curitem:
400 if item is curitem:
401 cury = i
401 cury = i
402 break
402 break
403
403
404 self.moveto(self.curx, cury, refresh=True)
404 self.moveto(self.curx, cury, refresh=True)
405
405
406
406
407 class _CommandInput(object):
407 class _CommandInput(object):
408 keymap = Keymap()
408 keymap = Keymap()
409 keymap.register("left", curses.KEY_LEFT)
409 keymap.register("left", curses.KEY_LEFT)
410 keymap.register("right", curses.KEY_RIGHT)
410 keymap.register("right", curses.KEY_RIGHT)
411 keymap.register("home", curses.KEY_HOME, "\x01") # Ctrl-A
411 keymap.register("home", curses.KEY_HOME, "\x01") # Ctrl-A
412 keymap.register("end", curses.KEY_END, "\x05") # Ctrl-E
412 keymap.register("end", curses.KEY_END, "\x05") # Ctrl-E
413 # FIXME: What's happening here?
413 # FIXME: What's happening here?
414 keymap.register("backspace", curses.KEY_BACKSPACE, "\x08\x7f")
414 keymap.register("backspace", curses.KEY_BACKSPACE, "\x08\x7f")
415 keymap.register("delete", curses.KEY_DC)
415 keymap.register("delete", curses.KEY_DC)
416 keymap.register("delend", 0x0b) # Ctrl-K
416 keymap.register("delend", 0x0b) # Ctrl-K
417 keymap.register("execute", "\r\n")
417 keymap.register("execute", "\r\n")
418 keymap.register("up", curses.KEY_UP)
418 keymap.register("up", curses.KEY_UP)
419 keymap.register("down", curses.KEY_DOWN)
419 keymap.register("down", curses.KEY_DOWN)
420 keymap.register("incsearchup", curses.KEY_PPAGE)
420 keymap.register("incsearchup", curses.KEY_PPAGE)
421 keymap.register("incsearchdown", curses.KEY_NPAGE)
421 keymap.register("incsearchdown", curses.KEY_NPAGE)
422 keymap.register("exit", "\x18"), # Ctrl-X
422 keymap.register("exit", "\x18"), # Ctrl-X
423
423
424 def __init__(self, prompt):
424 def __init__(self, prompt):
425 self.prompt = prompt
425 self.prompt = prompt
426 self.history = []
426 self.history = []
427 self.maxhistory = 100
427 self.maxhistory = 100
428 self.input = ""
428 self.input = ""
429 self.curx = 0
429 self.curx = 0
430 self.cury = -1 # blank line
430 self.cury = -1 # blank line
431
431
432 def start(self):
432 def start(self):
433 self.input = ""
433 self.input = ""
434 self.curx = 0
434 self.curx = 0
435 self.cury = -1 # blank line
435 self.cury = -1 # blank line
436
436
437 def handlekey(self, browser, key):
437 def handlekey(self, browser, key):
438 cmdname = self.keymap.get(key, None)
438 cmdname = self.keymap.get(key, None)
439 if cmdname is not None:
439 if cmdname is not None:
440 cmdfunc = getattr(self, "cmd_%s" % cmdname, None)
440 cmdfunc = getattr(self, "cmd_%s" % cmdname, None)
441 if cmdfunc is not None:
441 if cmdfunc is not None:
442 return cmdfunc(browser)
442 return cmdfunc(browser)
443 curses.beep()
443 curses.beep()
444 elif key != -1:
444 elif key != -1:
445 try:
445 try:
446 char = chr(key)
446 char = chr(key)
447 except ValueError:
447 except ValueError:
448 curses.beep()
448 curses.beep()
449 else:
449 else:
450 return self.handlechar(browser, char)
450 return self.handlechar(browser, char)
451
451
452 def handlechar(self, browser, char):
452 def handlechar(self, browser, char):
453 self.input = self.input[:self.curx] + char + self.input[self.curx:]
453 self.input = self.input[:self.curx] + char + self.input[self.curx:]
454 self.curx += 1
454 self.curx += 1
455 return True
455 return True
456
456
457 def dohistory(self):
457 def dohistory(self):
458 self.history.insert(0, self.input)
458 self.history.insert(0, self.input)
459 del self.history[:-self.maxhistory]
459 del self.history[:-self.maxhistory]
460
460
461 def cmd_backspace(self, browser):
461 def cmd_backspace(self, browser):
462 if self.curx:
462 if self.curx:
463 self.input = self.input[:self.curx-1] + self.input[self.curx:]
463 self.input = self.input[:self.curx-1] + self.input[self.curx:]
464 self.curx -= 1
464 self.curx -= 1
465 return True
465 return True
466 else:
466 else:
467 curses.beep()
467 curses.beep()
468
468
469 def cmd_delete(self, browser):
469 def cmd_delete(self, browser):
470 if self.curx<len(self.input):
470 if self.curx<len(self.input):
471 self.input = self.input[:self.curx] + self.input[self.curx+1:]
471 self.input = self.input[:self.curx] + self.input[self.curx+1:]
472 return True
472 return True
473 else:
473 else:
474 curses.beep()
474 curses.beep()
475
475
476 def cmd_delend(self, browser):
476 def cmd_delend(self, browser):
477 if self.curx<len(self.input):
477 if self.curx<len(self.input):
478 self.input = self.input[:self.curx]
478 self.input = self.input[:self.curx]
479 return True
479 return True
480
480
481 def cmd_left(self, browser):
481 def cmd_left(self, browser):
482 if self.curx:
482 if self.curx:
483 self.curx -= 1
483 self.curx -= 1
484 return True
484 return True
485 else:
485 else:
486 curses.beep()
486 curses.beep()
487
487
488 def cmd_right(self, browser):
488 def cmd_right(self, browser):
489 if self.curx < len(self.input):
489 if self.curx < len(self.input):
490 self.curx += 1
490 self.curx += 1
491 return True
491 return True
492 else:
492 else:
493 curses.beep()
493 curses.beep()
494
494
495 def cmd_home(self, browser):
495 def cmd_home(self, browser):
496 if self.curx:
496 if self.curx:
497 self.curx = 0
497 self.curx = 0
498 return True
498 return True
499 else:
499 else:
500 curses.beep()
500 curses.beep()
501
501
502 def cmd_end(self, browser):
502 def cmd_end(self, browser):
503 if self.curx < len(self.input):
503 if self.curx < len(self.input):
504 self.curx = len(self.input)
504 self.curx = len(self.input)
505 return True
505 return True
506 else:
506 else:
507 curses.beep()
507 curses.beep()
508
508
509 def cmd_up(self, browser):
509 def cmd_up(self, browser):
510 if self.cury < len(self.history)-1:
510 if self.cury < len(self.history)-1:
511 self.cury += 1
511 self.cury += 1
512 self.input = self.history[self.cury]
512 self.input = self.history[self.cury]
513 self.curx = len(self.input)
513 self.curx = len(self.input)
514 return True
514 return True
515 else:
515 else:
516 curses.beep()
516 curses.beep()
517
517
518 def cmd_down(self, browser):
518 def cmd_down(self, browser):
519 if self.cury >= 0:
519 if self.cury >= 0:
520 self.cury -= 1
520 self.cury -= 1
521 if self.cury>=0:
521 if self.cury>=0:
522 self.input = self.history[self.cury]
522 self.input = self.history[self.cury]
523 else:
523 else:
524 self.input = ""
524 self.input = ""
525 self.curx = len(self.input)
525 self.curx = len(self.input)
526 return True
526 return True
527 else:
527 else:
528 curses.beep()
528 curses.beep()
529
529
530 def cmd_incsearchup(self, browser):
530 def cmd_incsearchup(self, browser):
531 prefix = self.input[:self.curx]
531 prefix = self.input[:self.curx]
532 cury = self.cury
532 cury = self.cury
533 while True:
533 while True:
534 cury += 1
534 cury += 1
535 if cury >= len(self.history):
535 if cury >= len(self.history):
536 break
536 break
537 if self.history[cury].startswith(prefix):
537 if self.history[cury].startswith(prefix):
538 self.input = self.history[cury]
538 self.input = self.history[cury]
539 self.cury = cury
539 self.cury = cury
540 return True
540 return True
541 curses.beep()
541 curses.beep()
542
542
543 def cmd_incsearchdown(self, browser):
543 def cmd_incsearchdown(self, browser):
544 prefix = self.input[:self.curx]
544 prefix = self.input[:self.curx]
545 cury = self.cury
545 cury = self.cury
546 while True:
546 while True:
547 cury -= 1
547 cury -= 1
548 if cury <= 0:
548 if cury <= 0:
549 break
549 break
550 if self.history[cury].startswith(prefix):
550 if self.history[cury].startswith(prefix):
551 self.input = self.history[self.cury]
551 self.input = self.history[self.cury]
552 self.cury = cury
552 self.cury = cury
553 return True
553 return True
554 curses.beep()
554 curses.beep()
555
555
556 def cmd_exit(self, browser):
556 def cmd_exit(self, browser):
557 browser.mode = "default"
557 browser.mode = "default"
558 return True
558 return True
559
559
560 def cmd_execute(self, browser):
560 def cmd_execute(self, browser):
561 raise NotImplementedError
561 raise NotImplementedError
562
562
563
563
564 class _CommandGoto(_CommandInput):
564 class _CommandGoto(_CommandInput):
565 def __init__(self):
565 def __init__(self):
566 _CommandInput.__init__(self, "goto object #")
566 _CommandInput.__init__(self, "goto object #")
567
567
568 def handlechar(self, browser, char):
568 def handlechar(self, browser, char):
569 # Only accept digits
569 # Only accept digits
570 if not "0" <= char <= "9":
570 if not "0" <= char <= "9":
571 curses.beep()
571 curses.beep()
572 else:
572 else:
573 return _CommandInput.handlechar(self, browser, char)
573 return _CommandInput.handlechar(self, browser, char)
574
574
575 def cmd_execute(self, browser):
575 def cmd_execute(self, browser):
576 level = browser.levels[-1]
576 level = browser.levels[-1]
577 if self.input:
577 if self.input:
578 self.dohistory()
578 self.dohistory()
579 level.moveto(level.curx, int(self.input))
579 level.moveto(level.curx, int(self.input))
580 browser.mode = "default"
580 browser.mode = "default"
581 return True
581 return True
582
582
583
583
584 class _CommandFind(_CommandInput):
584 class _CommandFind(_CommandInput):
585 def __init__(self):
585 def __init__(self):
586 _CommandInput.__init__(self, "find expression")
586 _CommandInput.__init__(self, "find expression")
587
587
588 def cmd_execute(self, browser):
588 def cmd_execute(self, browser):
589 level = browser.levels[-1]
589 level = browser.levels[-1]
590 if self.input:
590 if self.input:
591 self.dohistory()
591 self.dohistory()
592 while True:
592 while True:
593 cury = level.cury
593 cury = level.cury
594 level.moveto(level.curx, cury+1)
594 level.moveto(level.curx, cury+1)
595 if cury == level.cury:
595 if cury == level.cury:
596 curses.beep()
596 curses.beep()
597 break # hit end
597 break # hit end
598 item = level.items[level.cury].item
598 item = level.items[level.cury].item
599 try:
599 try:
600 globals = ipipe.getglobals(None)
600 globals = ipipe.getglobals(None)
601 if eval(self.input, globals, ipipe.AttrNamespace(item)):
601 if eval(self.input, globals, ipipe.AttrNamespace(item)):
602 break # found something
602 break # found something
603 except (KeyboardInterrupt, SystemExit):
603 except (KeyboardInterrupt, SystemExit):
604 raise
604 raise
605 except Exception, exc:
605 except Exception, exc:
606 browser.report(exc)
606 browser.report(exc)
607 curses.beep()
607 curses.beep()
608 break # break on error
608 break # break on error
609 browser.mode = "default"
609 browser.mode = "default"
610 return True
610 return True
611
611
612
612
613 class _CommandFindBackwards(_CommandInput):
613 class _CommandFindBackwards(_CommandInput):
614 def __init__(self):
614 def __init__(self):
615 _CommandInput.__init__(self, "find backwards expression")
615 _CommandInput.__init__(self, "find backwards expression")
616
616
617 def cmd_execute(self, browser):
617 def cmd_execute(self, browser):
618 level = browser.levels[-1]
618 level = browser.levels[-1]
619 if self.input:
619 if self.input:
620 self.dohistory()
620 self.dohistory()
621 while level.cury:
621 while level.cury:
622 level.moveto(level.curx, level.cury-1)
622 level.moveto(level.curx, level.cury-1)
623 item = level.items[level.cury].item
623 item = level.items[level.cury].item
624 try:
624 try:
625 globals = ipipe.getglobals(None)
625 globals = ipipe.getglobals(None)
626 if eval(self.input, globals, ipipe.AttrNamespace(item)):
626 if eval(self.input, globals, ipipe.AttrNamespace(item)):
627 break # found something
627 break # found something
628 except (KeyboardInterrupt, SystemExit):
628 except (KeyboardInterrupt, SystemExit):
629 raise
629 raise
630 except Exception, exc:
630 except Exception, exc:
631 browser.report(exc)
631 browser.report(exc)
632 curses.beep()
632 curses.beep()
633 break # break on error
633 break # break on error
634 else:
634 else:
635 curses.beep()
635 curses.beep()
636 browser.mode = "default"
636 browser.mode = "default"
637 return True
637 return True
638
638
639
639
640 class ibrowse(ipipe.Display):
640 class ibrowse(ipipe.Display):
641 # Show this many lines from the previous screen when paging horizontally
641 # Show this many lines from the previous screen when paging horizontally
642 pageoverlapx = 1
642 pageoverlapx = 1
643
643
644 # Show this many lines from the previous screen when paging vertically
644 # Show this many lines from the previous screen when paging vertically
645 pageoverlapy = 1
645 pageoverlapy = 1
646
646
647 # Start scrolling when the cursor is less than this number of columns
647 # Start scrolling when the cursor is less than this number of columns
648 # away from the left or right screen edge
648 # away from the left or right screen edge
649 scrollborderx = 10
649 scrollborderx = 10
650
650
651 # Start scrolling when the cursor is less than this number of lines
651 # Start scrolling when the cursor is less than this number of lines
652 # away from the top or bottom screen edge
652 # away from the top or bottom screen edge
653 scrollbordery = 5
653 scrollbordery = 5
654
654
655 # Accelerate by this factor when scrolling horizontally
655 # Accelerate by this factor when scrolling horizontally
656 acceleratex = 1.05
656 acceleratex = 1.05
657
657
658 # Accelerate by this factor when scrolling vertically
658 # Accelerate by this factor when scrolling vertically
659 acceleratey = 1.05
659 acceleratey = 1.05
660
660
661 # The maximum horizontal scroll speed
661 # The maximum horizontal scroll speed
662 # (as a factor of the screen width (i.e. 0.5 == half a screen width)
662 # (as a factor of the screen width (i.e. 0.5 == half a screen width)
663 maxspeedx = 0.5
663 maxspeedx = 0.5
664
664
665 # The maximum vertical scroll speed
665 # The maximum vertical scroll speed
666 # (as a factor of the screen height (i.e. 0.5 == half a screen height)
666 # (as a factor of the screen height (i.e. 0.5 == half a screen height)
667 maxspeedy = 0.5
667 maxspeedy = 0.5
668
668
669 # The maximum number of header lines for browser level
669 # The maximum number of header lines for browser level
670 # if the nesting is deeper, only the innermost levels are displayed
670 # if the nesting is deeper, only the innermost levels are displayed
671 maxheaders = 5
671 maxheaders = 5
672
672
673 # The approximate maximum length of a column entry
673 # The approximate maximum length of a column entry
674 maxattrlength = 200
674 maxattrlength = 200
675
675
676 # Styles for various parts of the GUI
676 # Styles for various parts of the GUI
677 style_objheadertext = astyle.Style.fromstr("white:black:bold|reverse")
677 style_objheadertext = astyle.Style.fromstr("white:black:bold|reverse")
678 style_objheadernumber = astyle.Style.fromstr("white:blue:bold|reverse")
678 style_objheadernumber = astyle.Style.fromstr("white:blue:bold|reverse")
679 style_objheaderobject = astyle.Style.fromstr("white:black:reverse")
679 style_objheaderobject = astyle.Style.fromstr("white:black:reverse")
680 style_colheader = astyle.Style.fromstr("blue:white:reverse")
680 style_colheader = astyle.Style.fromstr("blue:white:reverse")
681 style_colheaderhere = astyle.Style.fromstr("green:black:bold|reverse")
681 style_colheaderhere = astyle.Style.fromstr("green:black:bold|reverse")
682 style_colheadersep = astyle.Style.fromstr("blue:black:reverse")
682 style_colheadersep = astyle.Style.fromstr("blue:black:reverse")
683 style_number = astyle.Style.fromstr("blue:white:reverse")
683 style_number = astyle.Style.fromstr("blue:white:reverse")
684 style_numberhere = astyle.Style.fromstr("green:black:bold|reverse")
684 style_numberhere = astyle.Style.fromstr("green:black:bold|reverse")
685 style_sep = astyle.Style.fromstr("blue:black")
685 style_sep = astyle.Style.fromstr("blue:black")
686 style_data = astyle.Style.fromstr("white:black")
686 style_data = astyle.Style.fromstr("white:black")
687 style_datapad = astyle.Style.fromstr("blue:black:bold")
687 style_datapad = astyle.Style.fromstr("blue:black:bold")
688 style_footer = astyle.Style.fromstr("black:white")
688 style_footer = astyle.Style.fromstr("black:white")
689 style_report = astyle.Style.fromstr("white:black")
689 style_report = astyle.Style.fromstr("white:black")
690
690
691 # Column separator in header
691 # Column separator in header
692 headersepchar = "|"
692 headersepchar = "|"
693
693
694 # Character for padding data cell entries
694 # Character for padding data cell entries
695 datapadchar = "."
695 datapadchar = "."
696
696
697 # Column separator in data area
697 # Column separator in data area
698 datasepchar = "|"
698 datasepchar = "|"
699
699
700 # Character to use for "empty" cell (i.e. for non-existing attributes)
700 # Character to use for "empty" cell (i.e. for non-existing attributes)
701 nodatachar = "-"
701 nodatachar = "-"
702
702
703 # Prompts for modes that require keyboard input
703 # Prompts for modes that require keyboard input
704 prompts = {
704 prompts = {
705 "goto": _CommandGoto(),
705 "goto": _CommandGoto(),
706 "find": _CommandFind(),
706 "find": _CommandFind(),
707 "findbackwards": _CommandFindBackwards()
707 "findbackwards": _CommandFindBackwards()
708 }
708 }
709
709
710 # Maps curses key codes to "function" names
710 # Maps curses key codes to "function" names
711 keymap = Keymap()
711 keymap = Keymap()
712 keymap.register("quit", "q")
712 keymap.register("quit", "q")
713 keymap.register("up", curses.KEY_UP)
713 keymap.register("up", curses.KEY_UP)
714 keymap.register("down", curses.KEY_DOWN)
714 keymap.register("down", curses.KEY_DOWN)
715 keymap.register("pageup", curses.KEY_PPAGE)
715 keymap.register("pageup", curses.KEY_PPAGE)
716 keymap.register("pagedown", curses.KEY_NPAGE)
716 keymap.register("pagedown", curses.KEY_NPAGE)
717 keymap.register("left", curses.KEY_LEFT)
717 keymap.register("left", curses.KEY_LEFT)
718 keymap.register("right", curses.KEY_RIGHT)
718 keymap.register("right", curses.KEY_RIGHT)
719 keymap.register("home", curses.KEY_HOME, "\x01")
719 keymap.register("home", curses.KEY_HOME, "\x01")
720 keymap.register("end", curses.KEY_END, "\x05")
720 keymap.register("end", curses.KEY_END, "\x05")
721 keymap.register("prevattr", "<\x1b")
721 keymap.register("prevattr", "<\x1b")
722 keymap.register("nextattr", ">\t")
722 keymap.register("nextattr", ">\t")
723 keymap.register("pick", "p")
723 keymap.register("pick", "p")
724 keymap.register("pickattr", "P")
724 keymap.register("pickattr", "P")
725 keymap.register("pickallattrs", "C")
725 keymap.register("pickallattrs", "C")
726 keymap.register("pickmarked", "m")
726 keymap.register("pickmarked", "m")
727 keymap.register("pickmarkedattr", "M")
727 keymap.register("pickmarkedattr", "M")
728 keymap.register("enterdefault", "\r\n")
728 keymap.register("enterdefault", "\r\n")
729 # FIXME: What's happening here?
729 # FIXME: What's happening here?
730 keymap.register("leave", curses.KEY_BACKSPACE, "x\x08\x7f")
730 keymap.register("leave", curses.KEY_BACKSPACE, "x\x08\x7f")
731 keymap.register("hideattr", "h")
731 keymap.register("hideattr", "h")
732 keymap.register("unhideattrs", "H")
732 keymap.register("unhideattrs", "H")
733 keymap.register("help", "?")
733 keymap.register("help", "?")
734 keymap.register("enter", "e")
734 keymap.register("enter", "e")
735 keymap.register("enterattr", "E")
735 keymap.register("enterattr", "E")
736 keymap.register("detail", "d")
736 keymap.register("detail", "d")
737 keymap.register("detailattr", "D")
737 keymap.register("detailattr", "D")
738 keymap.register("tooglemark", " ")
738 keymap.register("tooglemark", " ")
739 keymap.register("markrange", "r")
739 keymap.register("markrange", "r")
740 keymap.register("sortattrasc", "v")
740 keymap.register("sortattrasc", "v")
741 keymap.register("sortattrdesc", "V")
741 keymap.register("sortattrdesc", "V")
742 keymap.register("goto", "g")
742 keymap.register("goto", "g")
743 keymap.register("find", "f")
743 keymap.register("find", "f")
744 keymap.register("findbackwards", "b")
744 keymap.register("findbackwards", "b")
745
745
746 def __init__(self, *attrs):
746 def __init__(self, *attrs):
747 """
747 """
748 Create a new browser. If ``attrs`` is not empty, it is the list
748 Create a new browser. If ``attrs`` is not empty, it is the list
749 of attributes that will be displayed in the browser, otherwise
749 of attributes that will be displayed in the browser, otherwise
750 these will be determined by the objects on screen.
750 these will be determined by the objects on screen.
751 """
751 """
752 self.attrs = attrs
752 self.attrs = attrs
753
753
754 # Stack of browser levels
754 # Stack of browser levels
755 self.levels = []
755 self.levels = []
756 # how many colums to scroll (Changes when accelerating)
756 # how many colums to scroll (Changes when accelerating)
757 self.stepx = 1.
757 self.stepx = 1.
758
758
759 # how many rows to scroll (Changes when accelerating)
759 # how many rows to scroll (Changes when accelerating)
760 self.stepy = 1.
760 self.stepy = 1.
761
761
762 # Beep on the edges of the data area? (Will be set to ``False``
762 # Beep on the edges of the data area? (Will be set to ``False``
763 # once the cursor hits the edge of the screen, so we don't get
763 # once the cursor hits the edge of the screen, so we don't get
764 # multiple beeps).
764 # multiple beeps).
765 self._dobeep = True
765 self._dobeep = True
766
766
767 # Cache for registered ``curses`` colors and styles.
767 # Cache for registered ``curses`` colors and styles.
768 self._styles = {}
768 self._styles = {}
769 self._colors = {}
769 self._colors = {}
770 self._maxcolor = 1
770 self._maxcolor = 1
771
771
772 # How many header lines do we want to paint (the numbers of levels
772 # How many header lines do we want to paint (the numbers of levels
773 # we have, but with an upper bound)
773 # we have, but with an upper bound)
774 self._headerlines = 1
774 self._headerlines = 1
775
775
776 # Index of first header line
776 # Index of first header line
777 self._firstheaderline = 0
777 self._firstheaderline = 0
778
778
779 # curses window
779 # curses window
780 self.scr = None
780 self.scr = None
781 # report in the footer line (error, executed command etc.)
781 # report in the footer line (error, executed command etc.)
782 self._report = None
782 self._report = None
783
783
784 # value to be returned to the caller (set by commands)
784 # value to be returned to the caller (set by commands)
785 self.returnvalue = None
785 self.returnvalue = None
786
786
787 # The mode the browser is in
787 # The mode the browser is in
788 # e.g. normal browsing or entering an argument for a command
788 # e.g. normal browsing or entering an argument for a command
789 self.mode = "default"
789 self.mode = "default"
790
790
791 # set by the SIGWINCH signal handler
791 # set by the SIGWINCH signal handler
792 self.resized = False
792 self.resized = False
793
793
794 def nextstepx(self, step):
794 def nextstepx(self, step):
795 """
795 """
796 Accelerate horizontally.
796 Accelerate horizontally.
797 """
797 """
798 return max(1., min(step*self.acceleratex,
798 return max(1., min(step*self.acceleratex,
799 self.maxspeedx*self.levels[-1].mainsizex))
799 self.maxspeedx*self.levels[-1].mainsizex))
800
800
801 def nextstepy(self, step):
801 def nextstepy(self, step):
802 """
802 """
803 Accelerate vertically.
803 Accelerate vertically.
804 """
804 """
805 return max(1., min(step*self.acceleratey,
805 return max(1., min(step*self.acceleratey,
806 self.maxspeedy*self.levels[-1].mainsizey))
806 self.maxspeedy*self.levels[-1].mainsizey))
807
807
808 def getstyle(self, style):
808 def getstyle(self, style):
809 """
809 """
810 Register the ``style`` with ``curses`` or get it from the cache,
810 Register the ``style`` with ``curses`` or get it from the cache,
811 if it has been registered before.
811 if it has been registered before.
812 """
812 """
813 try:
813 try:
814 return self._styles[style.fg, style.bg, style.attrs]
814 return self._styles[style.fg, style.bg, style.attrs]
815 except KeyError:
815 except KeyError:
816 attrs = 0
816 attrs = 0
817 for b in astyle.A2CURSES:
817 for b in astyle.A2CURSES:
818 if style.attrs & b:
818 if style.attrs & b:
819 attrs |= astyle.A2CURSES[b]
819 attrs |= astyle.A2CURSES[b]
820 try:
820 try:
821 color = self._colors[style.fg, style.bg]
821 color = self._colors[style.fg, style.bg]
822 except KeyError:
822 except KeyError:
823 curses.init_pair(
823 curses.init_pair(
824 self._maxcolor,
824 self._maxcolor,
825 astyle.COLOR2CURSES[style.fg],
825 astyle.COLOR2CURSES[style.fg],
826 astyle.COLOR2CURSES[style.bg]
826 astyle.COLOR2CURSES[style.bg]
827 )
827 )
828 color = curses.color_pair(self._maxcolor)
828 color = curses.color_pair(self._maxcolor)
829 self._colors[style.fg, style.bg] = color
829 self._colors[style.fg, style.bg] = color
830 self._maxcolor += 1
830 self._maxcolor += 1
831 c = color | attrs
831 c = color | attrs
832 self._styles[style.fg, style.bg, style.attrs] = c
832 self._styles[style.fg, style.bg, style.attrs] = c
833 return c
833 return c
834
834
835 def addstr(self, y, x, begx, endx, text, style):
835 def addstr(self, y, x, begx, endx, text, style):
836 """
836 """
837 A version of ``curses.addstr()`` that can handle ``x`` coordinates
837 A version of ``curses.addstr()`` that can handle ``x`` coordinates
838 that are outside the screen.
838 that are outside the screen.
839 """
839 """
840 text2 = text[max(0, begx-x):max(0, endx-x)]
840 text2 = text[max(0, begx-x):max(0, endx-x)]
841 if text2:
841 if text2:
842 self.scr.addstr(y, max(x, begx), text2, self.getstyle(style))
842 self.scr.addstr(y, max(x, begx), text2, self.getstyle(style))
843 return len(text)
843 return len(text)
844
844
845 def addchr(self, y, x, begx, endx, c, l, style):
845 def addchr(self, y, x, begx, endx, c, l, style):
846 x0 = max(x, begx)
846 x0 = max(x, begx)
847 x1 = min(x+l, endx)
847 x1 = min(x+l, endx)
848 if x1>x0:
848 if x1>x0:
849 self.scr.addstr(y, x0, c*(x1-x0), self.getstyle(style))
849 self.scr.addstr(y, x0, c*(x1-x0), self.getstyle(style))
850 return l
850 return l
851
851
852 def _calcheaderlines(self, levels):
852 def _calcheaderlines(self, levels):
853 # Calculate how many headerlines do we have to display, if we have
853 # Calculate how many headerlines do we have to display, if we have
854 # ``levels`` browser levels
854 # ``levels`` browser levels
855 if levels is None:
855 if levels is None:
856 levels = len(self.levels)
856 levels = len(self.levels)
857 self._headerlines = min(self.maxheaders, levels)
857 self._headerlines = min(self.maxheaders, levels)
858 self._firstheaderline = levels-self._headerlines
858 self._firstheaderline = levels-self._headerlines
859
859
860 def getstylehere(self, style):
860 def getstylehere(self, style):
861 """
861 """
862 Return a style for displaying the original style ``style``
862 Return a style for displaying the original style ``style``
863 in the row the cursor is on.
863 in the row the cursor is on.
864 """
864 """
865 return astyle.Style(style.fg, astyle.COLOR_BLUE, style.attrs | astyle.A_BOLD)
865 return astyle.Style(style.fg, astyle.COLOR_BLUE, style.attrs | astyle.A_BOLD)
866
866
867 def report(self, msg):
867 def report(self, msg):
868 """
868 """
869 Store the message ``msg`` for display below the footer line. This
869 Store the message ``msg`` for display below the footer line. This
870 will be displayed as soon as the screen is redrawn.
870 will be displayed as soon as the screen is redrawn.
871 """
871 """
872 self._report = msg
872 self._report = msg
873
873
874 def enter(self, item, mode, *attrs):
874 def enter(self, item, mode, *attrs):
875 """
875 """
876 Enter the object ``item`` in the mode ``mode``. If ``attrs`` is
876 Enter the object ``item`` in the mode ``mode``. If ``attrs`` is
877 specified, it will be used as a fixed list of attributes to display.
877 specified, it will be used as a fixed list of attributes to display.
878 """
878 """
879 try:
879 try:
880 iterator = ipipe.xiter(item, mode)
880 iterator = ipipe.xiter(item, mode)
881 except (KeyboardInterrupt, SystemExit):
881 except (KeyboardInterrupt, SystemExit):
882 raise
882 raise
883 except Exception, exc:
883 except Exception, exc:
884 curses.beep()
884 curses.beep()
885 self.report(exc)
885 self.report(exc)
886 else:
886 else:
887 self._calcheaderlines(len(self.levels)+1)
887 self._calcheaderlines(len(self.levels)+1)
888 level = _BrowserLevel(
888 level = _BrowserLevel(
889 self,
889 self,
890 item,
890 item,
891 iterator,
891 iterator,
892 self.scrsizey-1-self._headerlines-2,
892 self.scrsizey-1-self._headerlines-2,
893 *attrs
893 *attrs
894 )
894 )
895 self.levels.append(level)
895 self.levels.append(level)
896
896
897 def startkeyboardinput(self, mode):
897 def startkeyboardinput(self, mode):
898 """
898 """
899 Enter mode ``mode``, which requires keyboard input.
899 Enter mode ``mode``, which requires keyboard input.
900 """
900 """
901 self.mode = mode
901 self.mode = mode
902 self.prompts[mode].start()
902 self.prompts[mode].start()
903
903
904 def keylabel(self, keycode):
904 def keylabel(self, keycode):
905 """
905 """
906 Return a pretty name for the ``curses`` key ``keycode`` (used in the
906 Return a pretty name for the ``curses`` key ``keycode`` (used in the
907 help screen and in reports about unassigned keys).
907 help screen and in reports about unassigned keys).
908 """
908 """
909 if keycode <= 0xff:
909 if keycode <= 0xff:
910 specialsnames = {
910 specialsnames = {
911 ord("\n"): "RETURN",
911 ord("\n"): "RETURN",
912 ord(" "): "SPACE",
912 ord(" "): "SPACE",
913 ord("\t"): "TAB",
913 ord("\t"): "TAB",
914 ord("\x7f"): "DELETE",
914 ord("\x7f"): "DELETE",
915 ord("\x08"): "BACKSPACE",
915 ord("\x08"): "BACKSPACE",
916 }
916 }
917 if keycode in specialsnames:
917 if keycode in specialsnames:
918 return specialsnames[keycode]
918 return specialsnames[keycode]
919 elif 0x00 < keycode < 0x20:
919 elif 0x00 < keycode < 0x20:
920 return "CTRL-%s" % chr(keycode + 64)
920 return "CTRL-%s" % chr(keycode + 64)
921 return repr(chr(keycode))
921 return repr(chr(keycode))
922 for name in dir(curses):
922 for name in dir(curses):
923 if name.startswith("KEY_") and getattr(curses, name) == keycode:
923 if name.startswith("KEY_") and getattr(curses, name) == keycode:
924 return name
924 return name
925 return str(keycode)
925 return str(keycode)
926
926
927 def beep(self, force=False):
927 def beep(self, force=False):
928 if force or self._dobeep:
928 if force or self._dobeep:
929 curses.beep()
929 curses.beep()
930 # don't beep again (as long as the same key is pressed)
930 # don't beep again (as long as the same key is pressed)
931 self._dobeep = False
931 self._dobeep = False
932
932
933 def cmd_up(self):
933 def cmd_up(self):
934 """
934 """
935 Move the cursor to the previous row.
935 Move the cursor to the previous row.
936 """
936 """
937 level = self.levels[-1]
937 level = self.levels[-1]
938 self.report("up")
938 self.report("up")
939 level.moveto(level.curx, level.cury-self.stepy)
939 level.moveto(level.curx, level.cury-self.stepy)
940
940
941 def cmd_down(self):
941 def cmd_down(self):
942 """
942 """
943 Move the cursor to the next row.
943 Move the cursor to the next row.
944 """
944 """
945 level = self.levels[-1]
945 level = self.levels[-1]
946 self.report("down")
946 self.report("down")
947 level.moveto(level.curx, level.cury+self.stepy)
947 level.moveto(level.curx, level.cury+self.stepy)
948
948
949 def cmd_pageup(self):
949 def cmd_pageup(self):
950 """
950 """
951 Move the cursor up one page.
951 Move the cursor up one page.
952 """
952 """
953 level = self.levels[-1]
953 level = self.levels[-1]
954 self.report("page up")
954 self.report("page up")
955 level.moveto(level.curx, level.cury-level.mainsizey+self.pageoverlapy)
955 level.moveto(level.curx, level.cury-level.mainsizey+self.pageoverlapy)
956
956
957 def cmd_pagedown(self):
957 def cmd_pagedown(self):
958 """
958 """
959 Move the cursor down one page.
959 Move the cursor down one page.
960 """
960 """
961 level = self.levels[-1]
961 level = self.levels[-1]
962 self.report("page down")
962 self.report("page down")
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_left(self):
965 def cmd_left(self):
966 """
966 """
967 Move the cursor left.
967 Move the cursor left.
968 """
968 """
969 level = self.levels[-1]
969 level = self.levels[-1]
970 self.report("left")
970 self.report("left")
971 level.moveto(level.curx-self.stepx, level.cury)
971 level.moveto(level.curx-self.stepx, level.cury)
972
972
973 def cmd_right(self):
973 def cmd_right(self):
974 """
974 """
975 Move the cursor right.
975 Move the cursor right.
976 """
976 """
977 level = self.levels[-1]
977 level = self.levels[-1]
978 self.report("right")
978 self.report("right")
979 level.moveto(level.curx+self.stepx, level.cury)
979 level.moveto(level.curx+self.stepx, level.cury)
980
980
981 def cmd_home(self):
981 def cmd_home(self):
982 """
982 """
983 Move the cursor to the first column.
983 Move the cursor to the first column.
984 """
984 """
985 level = self.levels[-1]
985 level = self.levels[-1]
986 self.report("home")
986 self.report("home")
987 level.moveto(0, level.cury)
987 level.moveto(0, level.cury)
988
988
989 def cmd_end(self):
989 def cmd_end(self):
990 """
990 """
991 Move the cursor to the last column.
991 Move the cursor to the last column.
992 """
992 """
993 level = self.levels[-1]
993 level = self.levels[-1]
994 self.report("end")
994 self.report("end")
995 level.moveto(level.datasizex+level.mainsizey-self.pageoverlapx, level.cury)
995 level.moveto(level.datasizex+level.mainsizey-self.pageoverlapx, level.cury)
996
996
997 def cmd_prevattr(self):
997 def cmd_prevattr(self):
998 """
998 """
999 Move the cursor one attribute column to the left.
999 Move the cursor one attribute column to the left.
1000 """
1000 """
1001 level = self.levels[-1]
1001 level = self.levels[-1]
1002 if level.displayattr[0] is None or level.displayattr[0] == 0:
1002 if level.displayattr[0] is None or level.displayattr[0] == 0:
1003 self.beep()
1003 self.beep()
1004 else:
1004 else:
1005 self.report("prevattr")
1005 self.report("prevattr")
1006 pos = 0
1006 pos = 0
1007 for (i, attrname) in enumerate(level.displayattrs):
1007 for (i, attrname) in enumerate(level.displayattrs):
1008 if i == level.displayattr[0]-1:
1008 if i == level.displayattr[0]-1:
1009 break
1009 break
1010 pos += level.colwidths[attrname] + 1
1010 pos += level.colwidths[attrname] + 1
1011 level.moveto(pos, level.cury)
1011 level.moveto(pos, level.cury)
1012
1012
1013 def cmd_nextattr(self):
1013 def cmd_nextattr(self):
1014 """
1014 """
1015 Move the cursor one attribute column to the right.
1015 Move the cursor one attribute column to the right.
1016 """
1016 """
1017 level = self.levels[-1]
1017 level = self.levels[-1]
1018 if level.displayattr[0] is None or level.displayattr[0] == len(level.displayattrs)-1:
1018 if level.displayattr[0] is None or level.displayattr[0] == len(level.displayattrs)-1:
1019 self.beep()
1019 self.beep()
1020 else:
1020 else:
1021 self.report("nextattr")
1021 self.report("nextattr")
1022 pos = 0
1022 pos = 0
1023 for (i, attrname) in enumerate(level.displayattrs):
1023 for (i, attrname) in enumerate(level.displayattrs):
1024 if i == level.displayattr[0]+1:
1024 if i == level.displayattr[0]+1:
1025 break
1025 break
1026 pos += level.colwidths[attrname] + 1
1026 pos += level.colwidths[attrname] + 1
1027 level.moveto(pos, level.cury)
1027 level.moveto(pos, level.cury)
1028
1028
1029 def cmd_pick(self):
1029 def cmd_pick(self):
1030 """
1030 """
1031 'Pick' the object under the cursor (i.e. the row the cursor is on).
1031 'Pick' the object under the cursor (i.e. the row the cursor is on).
1032 This leaves the browser and returns the picked object to the caller.
1032 This leaves the browser and returns the picked object to the caller.
1033 (In IPython this object will be available as the '_' variable.)
1033 (In IPython this object will be available as the '_' variable.)
1034 """
1034 """
1035 level = self.levels[-1]
1035 level = self.levels[-1]
1036 self.returnvalue = level.items[level.cury].item
1036 self.returnvalue = level.items[level.cury].item
1037 return True
1037 return True
1038
1038
1039 def cmd_pickattr(self):
1039 def cmd_pickattr(self):
1040 """
1040 """
1041 'Pick' the attribute under the cursor (i.e. the row/column the
1041 'Pick' the attribute under the cursor (i.e. the row/column the
1042 cursor is on).
1042 cursor is on).
1043 """
1043 """
1044 level = self.levels[-1]
1044 level = self.levels[-1]
1045 attrname = level.displayattr[1]
1045 attrname = level.displayattr[1]
1046 if attrname is ipipe.noitem:
1046 if attrname is ipipe.noitem:
1047 curses.beep()
1047 curses.beep()
1048 self.report(AttributeError(ipipe._attrname(attrname)))
1048 self.report(AttributeError(ipipe._attrname(attrname)))
1049 return
1049 return
1050 attr = ipipe._getattr(level.items[level.cury].item, attrname)
1050 attr = ipipe._getattr(level.items[level.cury].item, attrname)
1051 if attr is ipipe.noitem:
1051 if attr is ipipe.noitem:
1052 curses.beep()
1052 curses.beep()
1053 self.report(AttributeError(ipipe._attrname(attrname)))
1053 self.report(AttributeError(ipipe._attrname(attrname)))
1054 else:
1054 else:
1055 self.returnvalue = attr
1055 self.returnvalue = attr
1056 return True
1056 return True
1057
1057
1058 def cmd_pickallattrs(self):
1058 def cmd_pickallattrs(self):
1059 """
1059 """
1060 Pick' the complete column under the cursor (i.e. the attribute under
1060 Pick' the complete column under the cursor (i.e. the attribute under
1061 the cursor) from all currently fetched objects. These attributes
1061 the cursor) from all currently fetched objects. These attributes
1062 will be returned as a list.
1062 will be returned as a list.
1063 """
1063 """
1064 level = self.levels[-1]
1064 level = self.levels[-1]
1065 attrname = level.displayattr[1]
1065 attrname = level.displayattr[1]
1066 if attrname is ipipe.noitem:
1066 if attrname is ipipe.noitem:
1067 curses.beep()
1067 curses.beep()
1068 self.report(AttributeError(ipipe._attrname(attrname)))
1068 self.report(AttributeError(ipipe._attrname(attrname)))
1069 return
1069 return
1070 result = []
1070 result = []
1071 for cache in level.items:
1071 for cache in level.items:
1072 attr = ipipe._getattr(cache.item, attrname)
1072 attr = ipipe._getattr(cache.item, attrname)
1073 if attr is not ipipe.noitem:
1073 if attr is not ipipe.noitem:
1074 result.append(attr)
1074 result.append(attr)
1075 self.returnvalue = result
1075 self.returnvalue = result
1076 return True
1076 return True
1077
1077
1078 def cmd_pickmarked(self):
1078 def cmd_pickmarked(self):
1079 """
1079 """
1080 'Pick' marked objects. Marked objects will be returned as a list.
1080 'Pick' marked objects. Marked objects will be returned as a list.
1081 """
1081 """
1082 level = self.levels[-1]
1082 level = self.levels[-1]
1083 self.returnvalue = [cache.item for cache in level.items if cache.marked]
1083 self.returnvalue = [cache.item for cache in level.items if cache.marked]
1084 return True
1084 return True
1085
1085
1086 def cmd_pickmarkedattr(self):
1086 def cmd_pickmarkedattr(self):
1087 """
1087 """
1088 'Pick' the attribute under the cursor from all marked objects
1088 'Pick' the attribute under the cursor from all marked objects
1089 (This returns a list).
1089 (This returns a list).
1090 """
1090 """
1091
1091
1092 level = self.levels[-1]
1092 level = self.levels[-1]
1093 attrname = level.displayattr[1]
1093 attrname = level.displayattr[1]
1094 if attrname is ipipe.noitem:
1094 if attrname is ipipe.noitem:
1095 curses.beep()
1095 curses.beep()
1096 self.report(AttributeError(ipipe._attrname(attrname)))
1096 self.report(AttributeError(ipipe._attrname(attrname)))
1097 return
1097 return
1098 result = []
1098 result = []
1099 for cache in level.items:
1099 for cache in level.items:
1100 if cache.marked:
1100 if cache.marked:
1101 attr = ipipe._getattr(cache.item, attrname)
1101 attr = ipipe._getattr(cache.item, attrname)
1102 if attr is not ipipe.noitem:
1102 if attr is not ipipe.noitem:
1103 result.append(attr)
1103 result.append(attr)
1104 self.returnvalue = result
1104 self.returnvalue = result
1105 return True
1105 return True
1106
1106
1107 def cmd_markrange(self):
1107 def cmd_markrange(self):
1108 """
1108 """
1109 Mark all objects from the last marked object before the current cursor
1109 Mark all objects from the last marked object before the current cursor
1110 position to the cursor position.
1110 position to the cursor position.
1111 """
1111 """
1112 level = self.levels[-1]
1112 level = self.levels[-1]
1113 self.report("markrange")
1113 self.report("markrange")
1114 start = None
1114 start = None
1115 if level.items:
1115 if level.items:
1116 for i in xrange(level.cury, -1, -1):
1116 for i in xrange(level.cury, -1, -1):
1117 if level.items[i].marked:
1117 if level.items[i].marked:
1118 start = i
1118 start = i
1119 break
1119 break
1120 if start is None:
1120 if start is None:
1121 self.report(CommandError("no mark before cursor"))
1121 self.report(CommandError("no mark before cursor"))
1122 curses.beep()
1122 curses.beep()
1123 else:
1123 else:
1124 for i in xrange(start, level.cury+1):
1124 for i in xrange(start, level.cury+1):
1125 cache = level.items[i]
1125 cache = level.items[i]
1126 if not cache.marked:
1126 if not cache.marked:
1127 cache.marked = True
1127 cache.marked = True
1128 level.marked += 1
1128 level.marked += 1
1129
1129
1130 def cmd_enterdefault(self):
1130 def cmd_enterdefault(self):
1131 """
1131 """
1132 Enter the object under the cursor. (what this mean depends on the object
1132 Enter the object under the cursor. (what this mean depends on the object
1133 itself (i.e. how it implements the '__xiter__' method). This opens a new
1133 itself (i.e. how it implements the '__xiter__' method). This opens a new
1134 browser 'level'.
1134 browser 'level'.
1135 """
1135 """
1136 level = self.levels[-1]
1136 level = self.levels[-1]
1137 try:
1137 try:
1138 item = level.items[level.cury].item
1138 item = level.items[level.cury].item
1139 except IndexError:
1139 except IndexError:
1140 self.report(CommandError("No object"))
1140 self.report(CommandError("No object"))
1141 curses.beep()
1141 curses.beep()
1142 else:
1142 else:
1143 self.report("entering object (default mode)...")
1143 self.report("entering object (default mode)...")
1144 self.enter(item, "default")
1144 self.enter(item, "default")
1145
1145
1146 def cmd_leave(self):
1146 def cmd_leave(self):
1147 """
1147 """
1148 Leave the current browser level and go back to the previous one.
1148 Leave the current browser level and go back to the previous one.
1149 """
1149 """
1150 self.report("leave")
1150 self.report("leave")
1151 if len(self.levels) > 1:
1151 if len(self.levels) > 1:
1152 self._calcheaderlines(len(self.levels)-1)
1152 self._calcheaderlines(len(self.levels)-1)
1153 self.levels.pop(-1)
1153 self.levels.pop(-1)
1154 else:
1154 else:
1155 self.report(CommandError("This is the last level"))
1155 self.report(CommandError("This is the last level"))
1156 curses.beep()
1156 curses.beep()
1157
1157
1158 def cmd_enter(self):
1158 def cmd_enter(self):
1159 """
1159 """
1160 Enter the object under the cursor. If the object provides different
1160 Enter the object under the cursor. If the object provides different
1161 enter modes a menu of all modes will be presented; choose one and enter
1161 enter modes a menu of all modes will be presented; choose one and enter
1162 it (via the 'enter' or 'enterdefault' command).
1162 it (via the 'enter' or 'enterdefault' command).
1163 """
1163 """
1164 level = self.levels[-1]
1164 level = self.levels[-1]
1165 try:
1165 try:
1166 item = level.items[level.cury].item
1166 item = level.items[level.cury].item
1167 except IndexError:
1167 except IndexError:
1168 self.report(CommandError("No object"))
1168 self.report(CommandError("No object"))
1169 curses.beep()
1169 curses.beep()
1170 else:
1170 else:
1171 self.report("entering object...")
1171 self.report("entering object...")
1172 self.enter(item, None)
1172 self.enter(item, None)
1173
1173
1174 def cmd_enterattr(self):
1174 def cmd_enterattr(self):
1175 """
1175 """
1176 Enter the attribute under the cursor.
1176 Enter the attribute under the cursor.
1177 """
1177 """
1178 level = self.levels[-1]
1178 level = self.levels[-1]
1179 attrname = level.displayattr[1]
1179 attrname = level.displayattr[1]
1180 if attrname is ipipe.noitem:
1180 if attrname is ipipe.noitem:
1181 curses.beep()
1181 curses.beep()
1182 self.report(AttributeError(ipipe._attrname(attrname)))
1182 self.report(AttributeError(ipipe._attrname(attrname)))
1183 return
1183 return
1184 try:
1184 try:
1185 item = level.items[level.cury].item
1185 item = level.items[level.cury].item
1186 except IndexError:
1186 except IndexError:
1187 self.report(CommandError("No object"))
1187 self.report(CommandError("No object"))
1188 curses.beep()
1188 curses.beep()
1189 else:
1189 else:
1190 attr = ipipe._getattr(item, attrname)
1190 attr = ipipe._getattr(item, attrname)
1191 if attr is ipipe.noitem:
1191 if attr is ipipe.noitem:
1192 self.report(AttributeError(ipipe._attrname(attrname)))
1192 self.report(AttributeError(ipipe._attrname(attrname)))
1193 else:
1193 else:
1194 self.report("entering object attribute %s..." % ipipe._attrname(attrname))
1194 self.report("entering object attribute %s..." % ipipe._attrname(attrname))
1195 self.enter(attr, None)
1195 self.enter(attr, None)
1196
1196
1197 def cmd_detail(self):
1197 def cmd_detail(self):
1198 """
1198 """
1199 Show a detail view of the object under the cursor. This shows the
1199 Show a detail view of the object under the cursor. This shows the
1200 name, type, doc string and value of the object attributes (and it
1200 name, type, doc string and value of the object attributes (and it
1201 might show more attributes than in the list view, depending on
1201 might show more attributes than in the list view, depending on
1202 the object).
1202 the object).
1203 """
1203 """
1204 level = self.levels[-1]
1204 level = self.levels[-1]
1205 try:
1205 try:
1206 item = level.items[level.cury].item
1206 item = level.items[level.cury].item
1207 except IndexError:
1207 except IndexError:
1208 self.report(CommandError("No object"))
1208 self.report(CommandError("No object"))
1209 curses.beep()
1209 curses.beep()
1210 else:
1210 else:
1211 self.report("entering detail view for object...")
1211 self.report("entering detail view for object...")
1212 self.enter(item, "detail")
1212 self.enter(item, "detail")
1213
1213
1214 def cmd_detailattr(self):
1214 def cmd_detailattr(self):
1215 """
1215 """
1216 Show a detail view of the attribute under the cursor.
1216 Show a detail view of the attribute under the cursor.
1217 """
1217 """
1218 level = self.levels[-1]
1218 level = self.levels[-1]
1219 attrname = level.displayattr[1]
1219 attrname = level.displayattr[1]
1220 if attrname is ipipe.noitem:
1220 if attrname is ipipe.noitem:
1221 curses.beep()
1221 curses.beep()
1222 self.report(AttributeError(ipipe._attrname(attrname)))
1222 self.report(AttributeError(ipipe._attrname(attrname)))
1223 return
1223 return
1224 try:
1224 try:
1225 item = level.items[level.cury].item
1225 item = level.items[level.cury].item
1226 except IndexError:
1226 except IndexError:
1227 self.report(CommandError("No object"))
1227 self.report(CommandError("No object"))
1228 curses.beep()
1228 curses.beep()
1229 else:
1229 else:
1230 attr = ipipe._getattr(item, attrname)
1230 attr = ipipe._getattr(item, attrname)
1231 if attr is ipipe.noitem:
1231 if attr is ipipe.noitem:
1232 self.report(AttributeError(ipipe._attrname(attrname)))
1232 self.report(AttributeError(ipipe._attrname(attrname)))
1233 else:
1233 else:
1234 self.report("entering detail view for attribute...")
1234 self.report("entering detail view for attribute...")
1235 self.enter(attr, "detail")
1235 self.enter(attr, "detail")
1236
1236
1237 def cmd_tooglemark(self):
1237 def cmd_tooglemark(self):
1238 """
1238 """
1239 Mark/unmark the object under the cursor. Marked objects have a '!'
1239 Mark/unmark the object under the cursor. Marked objects have a '!'
1240 after the row number).
1240 after the row number).
1241 """
1241 """
1242 level = self.levels[-1]
1242 level = self.levels[-1]
1243 self.report("toggle mark")
1243 self.report("toggle mark")
1244 try:
1244 try:
1245 item = level.items[level.cury]
1245 item = level.items[level.cury]
1246 except IndexError: # no items?
1246 except IndexError: # no items?
1247 pass
1247 pass
1248 else:
1248 else:
1249 if item.marked:
1249 if item.marked:
1250 item.marked = False
1250 item.marked = False
1251 level.marked -= 1
1251 level.marked -= 1
1252 else:
1252 else:
1253 item.marked = True
1253 item.marked = True
1254 level.marked += 1
1254 level.marked += 1
1255
1255
1256 def cmd_sortattrasc(self):
1256 def cmd_sortattrasc(self):
1257 """
1257 """
1258 Sort the objects (in ascending order) using the attribute under
1258 Sort the objects (in ascending order) using the attribute under
1259 the cursor as the sort key.
1259 the cursor as the sort key.
1260 """
1260 """
1261 level = self.levels[-1]
1261 level = self.levels[-1]
1262 attrname = level.displayattr[1]
1262 attrname = level.displayattr[1]
1263 if attrname is ipipe.noitem:
1263 if attrname is ipipe.noitem:
1264 curses.beep()
1264 curses.beep()
1265 self.report(AttributeError(ipipe._attrname(attrname)))
1265 self.report(AttributeError(ipipe._attrname(attrname)))
1266 return
1266 return
1267 self.report("sort by %s (ascending)" % ipipe._attrname(attrname))
1267 self.report("sort by %s (ascending)" % ipipe._attrname(attrname))
1268 def key(item):
1268 def key(item):
1269 try:
1269 try:
1270 return ipipe._getattr(item, attrname, None)
1270 return ipipe._getattr(item, attrname, None)
1271 except (KeyboardInterrupt, SystemExit):
1271 except (KeyboardInterrupt, SystemExit):
1272 raise
1272 raise
1273 except Exception:
1273 except Exception:
1274 return None
1274 return None
1275 level.sort(key)
1275 level.sort(key)
1276
1276
1277 def cmd_sortattrdesc(self):
1277 def cmd_sortattrdesc(self):
1278 """
1278 """
1279 Sort the objects (in descending order) using the attribute under
1279 Sort the objects (in descending order) using the attribute under
1280 the cursor as the sort key.
1280 the cursor as the sort key.
1281 """
1281 """
1282 level = self.levels[-1]
1282 level = self.levels[-1]
1283 attrname = level.displayattr[1]
1283 attrname = level.displayattr[1]
1284 if attrname is ipipe.noitem:
1284 if attrname is ipipe.noitem:
1285 curses.beep()
1285 curses.beep()
1286 self.report(AttributeError(ipipe._attrname(attrname)))
1286 self.report(AttributeError(ipipe._attrname(attrname)))
1287 return
1287 return
1288 self.report("sort by %s (descending)" % ipipe._attrname(attrname))
1288 self.report("sort by %s (descending)" % ipipe._attrname(attrname))
1289 def key(item):
1289 def key(item):
1290 try:
1290 try:
1291 return ipipe._getattr(item, attrname, None)
1291 return ipipe._getattr(item, attrname, None)
1292 except (KeyboardInterrupt, SystemExit):
1292 except (KeyboardInterrupt, SystemExit):
1293 raise
1293 raise
1294 except Exception:
1294 except Exception:
1295 return None
1295 return None
1296 level.sort(key, reverse=True)
1296 level.sort(key, reverse=True)
1297
1297
1298 def cmd_hideattr(self):
1298 def cmd_hideattr(self):
1299 """
1299 """
1300 Hide the attribute under the cursor.
1300 Hide the attribute under the cursor.
1301 """
1301 """
1302 level = self.levels[-1]
1302 level = self.levels[-1]
1303 if level.displayattr[0] is None:
1303 if level.displayattr[0] is None:
1304 self.beep()
1304 self.beep()
1305 else:
1305 else:
1306 self.report("hideattr")
1306 self.report("hideattr")
1307 level.hiddenattrs.add(level.displayattr[1])
1307 level.hiddenattrs.add(level.displayattr[1])
1308 level.moveto(level.curx, level.cury, refresh=True)
1308 level.moveto(level.curx, level.cury, refresh=True)
1309
1309
1310 def cmd_unhideattrs(self):
1310 def cmd_unhideattrs(self):
1311 """
1311 """
1312 Make all attributes visible again.
1312 Make all attributes visible again.
1313 """
1313 """
1314 level = self.levels[-1]
1314 level = self.levels[-1]
1315 self.report("unhideattrs")
1315 self.report("unhideattrs")
1316 level.hiddenattrs.clear()
1316 level.hiddenattrs.clear()
1317 level.moveto(level.curx, level.cury, refresh=True)
1317 level.moveto(level.curx, level.cury, refresh=True)
1318
1318
1319 def cmd_goto(self):
1319 def cmd_goto(self):
1320 """
1320 """
1321 Jump to a row. The row number can be entered at the
1321 Jump to a row. The row number can be entered at the
1322 bottom of the screen.
1322 bottom of the screen.
1323 """
1323 """
1324 self.startkeyboardinput("goto")
1324 self.startkeyboardinput("goto")
1325
1325
1326 def cmd_find(self):
1326 def cmd_find(self):
1327 """
1327 """
1328 Search forward for a row. The search condition can be entered at the
1328 Search forward for a row. The search condition can be entered at the
1329 bottom of the screen.
1329 bottom of the screen.
1330 """
1330 """
1331 self.startkeyboardinput("find")
1331 self.startkeyboardinput("find")
1332
1332
1333 def cmd_findbackwards(self):
1333 def cmd_findbackwards(self):
1334 """
1334 """
1335 Search backward for a row. The search condition can be entered at the
1335 Search backward for a row. The search condition can be entered at the
1336 bottom of the screen.
1336 bottom of the screen.
1337 """
1337 """
1338 self.startkeyboardinput("findbackwards")
1338 self.startkeyboardinput("findbackwards")
1339
1339
1340 def cmd_help(self):
1340 def cmd_help(self):
1341 """
1341 """
1342 Opens the help screen as a new browser level, describing keyboard
1342 Opens the help screen as a new browser level, describing keyboard
1343 shortcuts.
1343 shortcuts.
1344 """
1344 """
1345 for level in self.levels:
1345 for level in self.levels:
1346 if isinstance(level.input, _BrowserHelp):
1346 if isinstance(level.input, _BrowserHelp):
1347 curses.beep()
1347 curses.beep()
1348 self.report(CommandError("help already active"))
1348 self.report(CommandError("help already active"))
1349 return
1349 return
1350
1350
1351 self.enter(_BrowserHelp(self), "default")
1351 self.enter(_BrowserHelp(self), "default")
1352
1352
1353 def cmd_quit(self):
1353 def cmd_quit(self):
1354 """
1354 """
1355 Quit the browser and return to the IPython prompt.
1355 Quit the browser and return to the IPython prompt.
1356 """
1356 """
1357 self.returnvalue = None
1357 self.returnvalue = None
1358 return True
1358 return True
1359
1359
1360 def sigwinchhandler(self, signal, frame):
1360 def sigwinchhandler(self, signal, frame):
1361 self.resized = True
1361 self.resized = True
1362
1362
1363 def _dodisplay(self, scr):
1363 def _dodisplay(self, scr):
1364 """
1364 """
1365 This method is the workhorse of the browser. It handles screen
1365 This method is the workhorse of the browser. It handles screen
1366 drawing and the keyboard.
1366 drawing and the keyboard.
1367 """
1367 """
1368 self.scr = scr
1368 self.scr = scr
1369 curses.halfdelay(1)
1369 curses.halfdelay(1)
1370 footery = 2
1370 footery = 2
1371
1371
1372 keys = []
1372 keys = []
1373 for key in ("quit", "help"):
1373 for key in ("quit", "help"):
1374 key = self.keymap.findkey(key, None)
1374 key = self.keymap.findkey(key, None)
1375 if key is not None:
1375 if key is not None:
1376 keys.append("%s=quit" % self.keylabel(key))
1376 keys.append("%s=quit" % self.keylabel(key))
1377 helpmsg = " | %s" % " ".join(keys)
1377 helpmsg = " | %s" % " ".join(keys)
1378
1378
1379 scr.clear()
1379 scr.clear()
1380 msg = "Fetching first batch of objects..."
1380 msg = "Fetching first batch of objects..."
1381 (self.scrsizey, self.scrsizex) = scr.getmaxyx()
1381 (self.scrsizey, self.scrsizex) = scr.getmaxyx()
1382 scr.addstr(self.scrsizey//2, (self.scrsizex-len(msg))//2, msg)
1382 scr.addstr(self.scrsizey//2, (self.scrsizex-len(msg))//2, msg)
1383 scr.refresh()
1383 scr.refresh()
1384
1384
1385 lastc = -1
1385 lastc = -1
1386
1386
1387 self.levels = []
1387 self.levels = []
1388 # enter the first level
1388 # enter the first level
1389 self.enter(self.input, ipipe.xiter(self.input, "default"), *self.attrs)
1389 self.enter(self.input, ipipe.xiter(self.input, "default"), *self.attrs)
1390
1390
1391 self._calcheaderlines(None)
1391 self._calcheaderlines(None)
1392
1392
1393 while True:
1393 while True:
1394 level = self.levels[-1]
1394 level = self.levels[-1]
1395 (self.scrsizey, self.scrsizex) = scr.getmaxyx()
1395 (self.scrsizey, self.scrsizex) = scr.getmaxyx()
1396 level.mainsizey = self.scrsizey-1-self._headerlines-footery
1396 level.mainsizey = self.scrsizey-1-self._headerlines-footery
1397
1397
1398 # Paint object header
1398 # Paint object header
1399 for i in xrange(self._firstheaderline, self._firstheaderline+self._headerlines):
1399 for i in xrange(self._firstheaderline, self._firstheaderline+self._headerlines):
1400 lv = self.levels[i]
1400 lv = self.levels[i]
1401 posx = 0
1401 posx = 0
1402 posy = i-self._firstheaderline
1402 posy = i-self._firstheaderline
1403 endx = self.scrsizex
1403 endx = self.scrsizex
1404 if i: # not the first level
1404 if i: # not the first level
1405 msg = " (%d/%d" % (self.levels[i-1].cury, len(self.levels[i-1].items))
1405 msg = " (%d/%d" % (self.levels[i-1].cury, len(self.levels[i-1].items))
1406 if not self.levels[i-1].exhausted:
1406 if not self.levels[i-1].exhausted:
1407 msg += "+"
1407 msg += "+"
1408 msg += ") "
1408 msg += ") "
1409 endx -= len(msg)+1
1409 endx -= len(msg)+1
1410 posx += self.addstr(posy, posx, 0, endx, " ibrowse #%d: " % i, self.style_objheadertext)
1410 posx += self.addstr(posy, posx, 0, endx, " ibrowse #%d: " % i, self.style_objheadertext)
1411 for (style, text) in lv.header:
1411 for (style, text) in lv.header:
1412 posx += self.addstr(posy, posx, 0, endx, text, self.style_objheaderobject)
1412 posx += self.addstr(posy, posx, 0, endx, text, self.style_objheaderobject)
1413 if posx >= endx:
1413 if posx >= endx:
1414 break
1414 break
1415 if i:
1415 if i:
1416 posx += self.addstr(posy, posx, 0, self.scrsizex, msg, self.style_objheadernumber)
1416 posx += self.addstr(posy, posx, 0, self.scrsizex, msg, self.style_objheadernumber)
1417 posx += self.addchr(posy, posx, 0, self.scrsizex, " ", self.scrsizex-posx, self.style_objheadernumber)
1417 posx += self.addchr(posy, posx, 0, self.scrsizex, " ", self.scrsizex-posx, self.style_objheadernumber)
1418
1418
1419 if not level.items:
1419 if not level.items:
1420 self.addchr(self._headerlines, 0, 0, self.scrsizex, " ", self.scrsizex, self.style_colheader)
1420 self.addchr(self._headerlines, 0, 0, self.scrsizex, " ", self.scrsizex, self.style_colheader)
1421 self.addstr(self._headerlines+1, 0, 0, self.scrsizex, " <empty>", astyle.style_error)
1421 self.addstr(self._headerlines+1, 0, 0, self.scrsizex, " <empty>", astyle.style_error)
1422 scr.clrtobot()
1422 scr.clrtobot()
1423 else:
1423 else:
1424 # Paint column headers
1424 # Paint column headers
1425 scr.move(self._headerlines, 0)
1425 scr.move(self._headerlines, 0)
1426 scr.addstr(" %*s " % (level.numbersizex, "#"), self.getstyle(self.style_colheader))
1426 scr.addstr(" %*s " % (level.numbersizex, "#"), self.getstyle(self.style_colheader))
1427 scr.addstr(self.headersepchar, self.getstyle(self.style_colheadersep))
1427 scr.addstr(self.headersepchar, self.getstyle(self.style_colheadersep))
1428 begx = level.numbersizex+3
1428 begx = level.numbersizex+3
1429 posx = begx-level.datastartx
1429 posx = begx-level.datastartx
1430 for attrname in level.displayattrs:
1430 for attrname in level.displayattrs:
1431 strattrname = ipipe._attrname(attrname)
1431 strattrname = ipipe._attrname(attrname)
1432 cwidth = level.colwidths[attrname]
1432 cwidth = level.colwidths[attrname]
1433 header = strattrname.ljust(cwidth)
1433 header = strattrname.ljust(cwidth)
1434 if attrname == level.displayattr[1]:
1434 if attrname == level.displayattr[1]:
1435 style = self.style_colheaderhere
1435 style = self.style_colheaderhere
1436 else:
1436 else:
1437 style = self.style_colheader
1437 style = self.style_colheader
1438 posx += self.addstr(self._headerlines, posx, begx, self.scrsizex, header, style)
1438 posx += self.addstr(self._headerlines, posx, begx, self.scrsizex, header, style)
1439 posx += self.addstr(self._headerlines, posx, begx, self.scrsizex, self.headersepchar, self.style_colheadersep)
1439 posx += self.addstr(self._headerlines, posx, begx, self.scrsizex, self.headersepchar, self.style_colheadersep)
1440 if posx >= self.scrsizex:
1440 if posx >= self.scrsizex:
1441 break
1441 break
1442 else:
1442 else:
1443 scr.addstr(" "*(self.scrsizex-posx), self.getstyle(self.style_colheader))
1443 scr.addstr(" "*(self.scrsizex-posx), self.getstyle(self.style_colheader))
1444
1444
1445 # Paint rows
1445 # Paint rows
1446 posy = self._headerlines+1+level.datastarty
1446 posy = self._headerlines+1+level.datastarty
1447 for i in xrange(level.datastarty, min(level.datastarty+level.mainsizey, len(level.items))):
1447 for i in xrange(level.datastarty, min(level.datastarty+level.mainsizey, len(level.items))):
1448 cache = level.items[i]
1448 cache = level.items[i]
1449 if i == level.cury:
1449 if i == level.cury:
1450 style = self.style_numberhere
1450 style = self.style_numberhere
1451 else:
1451 else:
1452 style = self.style_number
1452 style = self.style_number
1453
1453
1454 posy = self._headerlines+1+i-level.datastarty
1454 posy = self._headerlines+1+i-level.datastarty
1455 posx = begx-level.datastartx
1455 posx = begx-level.datastartx
1456
1456
1457 scr.move(posy, 0)
1457 scr.move(posy, 0)
1458 scr.addstr(" %*d%s" % (level.numbersizex, i, " !"[cache.marked]), self.getstyle(style))
1458 scr.addstr(" %*d%s" % (level.numbersizex, i, " !"[cache.marked]), self.getstyle(style))
1459 scr.addstr(self.headersepchar, self.getstyle(self.style_sep))
1459 scr.addstr(self.headersepchar, self.getstyle(self.style_sep))
1460
1460
1461 for attrname in level.displayattrs:
1461 for attrname in level.displayattrs:
1462 cwidth = level.colwidths[attrname]
1462 cwidth = level.colwidths[attrname]
1463 try:
1463 try:
1464 (align, length, parts) = level.displayrows[i-level.datastarty][attrname]
1464 (align, length, parts) = level.displayrows[i-level.datastarty][attrname]
1465 except KeyError:
1465 except KeyError:
1466 align = 2
1466 align = 2
1467 style = astyle.style_nodata
1467 style = astyle.style_nodata
1468 if i == level.cury:
1469 style = self.getstylehere(style)
1468 padstyle = self.style_datapad
1470 padstyle = self.style_datapad
1469 sepstyle = self.style_sep
1471 sepstyle = self.style_sep
1470 if i == level.cury:
1472 if i == level.cury:
1471 padstyle = self.getstylehere(padstyle)
1473 padstyle = self.getstylehere(padstyle)
1472 sepstyle = self.getstylehere(sepstyle)
1474 sepstyle = self.getstylehere(sepstyle)
1473 if align == 2:
1475 if align == 2:
1474 posx += self.addchr(posy, posx, begx, self.scrsizex, self.nodatachar, cwidth, style)
1476 posx += self.addchr(posy, posx, begx, self.scrsizex, self.nodatachar, cwidth, style)
1475 else:
1477 else:
1476 if align == 1:
1478 if align == 1:
1477 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, cwidth-length, padstyle)
1479 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, cwidth-length, padstyle)
1478 elif align == 0:
1480 elif align == 0:
1479 pad1 = (cwidth-length)//2
1481 pad1 = (cwidth-length)//2
1480 pad2 = cwidth-length-len(pad1)
1482 pad2 = cwidth-length-len(pad1)
1481 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, pad1, padstyle)
1483 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, pad1, padstyle)
1482 for (style, text) in parts:
1484 for (style, text) in parts:
1483 if i == level.cury:
1485 if i == level.cury:
1484 style = self.getstylehere(style)
1486 style = self.getstylehere(style)
1485 posx += self.addstr(posy, posx, begx, self.scrsizex, text, style)
1487 posx += self.addstr(posy, posx, begx, self.scrsizex, text, style)
1486 if posx >= self.scrsizex:
1488 if posx >= self.scrsizex:
1487 break
1489 break
1488 if align == -1:
1490 if align == -1:
1489 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, cwidth-length, padstyle)
1491 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, cwidth-length, padstyle)
1490 elif align == 0:
1492 elif align == 0:
1491 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, pad2, padstyle)
1493 posx += self.addchr(posy, posx, begx, self.scrsizex, self.datapadchar, pad2, padstyle)
1492 posx += self.addstr(posy, posx, begx, self.scrsizex, self.datasepchar, sepstyle)
1494 posx += self.addstr(posy, posx, begx, self.scrsizex, self.datasepchar, sepstyle)
1493 else:
1495 else:
1494 scr.clrtoeol()
1496 scr.clrtoeol()
1495
1497
1496 # Add blank row headers for the rest of the screen
1498 # Add blank row headers for the rest of the screen
1497 for posy in xrange(posy+1, self.scrsizey-2):
1499 for posy in xrange(posy+1, self.scrsizey-2):
1498 scr.addstr(posy, 0, " " * (level.numbersizex+2), self.getstyle(self.style_colheader))
1500 scr.addstr(posy, 0, " " * (level.numbersizex+2), self.getstyle(self.style_colheader))
1499 scr.clrtoeol()
1501 scr.clrtoeol()
1500
1502
1501 posy = self.scrsizey-footery
1503 posy = self.scrsizey-footery
1502 # Display footer
1504 # Display footer
1503 scr.addstr(posy, 0, " "*self.scrsizex, self.getstyle(self.style_footer))
1505 scr.addstr(posy, 0, " "*self.scrsizex, self.getstyle(self.style_footer))
1504
1506
1505 if level.exhausted:
1507 if level.exhausted:
1506 flag = ""
1508 flag = ""
1507 else:
1509 else:
1508 flag = "+"
1510 flag = "+"
1509
1511
1510 endx = self.scrsizex-len(helpmsg)-1
1512 endx = self.scrsizex-len(helpmsg)-1
1511 scr.addstr(posy, endx, helpmsg, self.getstyle(self.style_footer))
1513 scr.addstr(posy, endx, helpmsg, self.getstyle(self.style_footer))
1512
1514
1513 posx = 0
1515 posx = 0
1514 msg = " %d%s objects (%d marked): " % (len(level.items), flag, level.marked)
1516 msg = " %d%s objects (%d marked): " % (len(level.items), flag, level.marked)
1515 posx += self.addstr(posy, posx, 0, endx, msg, self.style_footer)
1517 posx += self.addstr(posy, posx, 0, endx, msg, self.style_footer)
1516 try:
1518 try:
1517 item = level.items[level.cury].item
1519 item = level.items[level.cury].item
1518 except IndexError: # empty
1520 except IndexError: # empty
1519 pass
1521 pass
1520 else:
1522 else:
1521 for (nostyle, text) in ipipe.xrepr(item, "footer"):
1523 for (nostyle, text) in ipipe.xrepr(item, "footer"):
1522 if not isinstance(nostyle, int):
1524 if not isinstance(nostyle, int):
1523 posx += self.addstr(posy, posx, 0, endx, text, self.style_footer)
1525 posx += self.addstr(posy, posx, 0, endx, text, self.style_footer)
1524 if posx >= endx:
1526 if posx >= endx:
1525 break
1527 break
1526
1528
1527 attrstyle = [(astyle.style_default, "no attribute")]
1529 attrstyle = [(astyle.style_default, "no attribute")]
1528 attrname = level.displayattr[1]
1530 attrname = level.displayattr[1]
1529 if attrname is not ipipe.noitem and attrname is not None:
1531 if attrname is not ipipe.noitem and attrname is not None:
1530 posx += self.addstr(posy, posx, 0, endx, " | ", self.style_footer)
1532 posx += self.addstr(posy, posx, 0, endx, " | ", self.style_footer)
1531 posx += self.addstr(posy, posx, 0, endx, ipipe._attrname(attrname), self.style_footer)
1533 posx += self.addstr(posy, posx, 0, endx, ipipe._attrname(attrname), self.style_footer)
1532 posx += self.addstr(posy, posx, 0, endx, ": ", self.style_footer)
1534 posx += self.addstr(posy, posx, 0, endx, ": ", self.style_footer)
1533 try:
1535 try:
1534 attr = ipipe._getattr(item, attrname)
1536 attr = ipipe._getattr(item, attrname)
1535 except (SystemExit, KeyboardInterrupt):
1537 except (SystemExit, KeyboardInterrupt):
1536 raise
1538 raise
1537 except Exception, exc:
1539 except Exception, exc:
1538 attr = exc
1540 attr = exc
1539 if attr is not ipipe.noitem:
1541 if attr is not ipipe.noitem:
1540 attrstyle = ipipe.xrepr(attr, "footer")
1542 attrstyle = ipipe.xrepr(attr, "footer")
1541 for (nostyle, text) in attrstyle:
1543 for (nostyle, text) in attrstyle:
1542 if not isinstance(nostyle, int):
1544 if not isinstance(nostyle, int):
1543 posx += self.addstr(posy, posx, 0, endx, text, self.style_footer)
1545 posx += self.addstr(posy, posx, 0, endx, text, self.style_footer)
1544 if posx >= endx:
1546 if posx >= endx:
1545 break
1547 break
1546
1548
1547 try:
1549 try:
1548 # Display input prompt
1550 # Display input prompt
1549 if self.mode in self.prompts:
1551 if self.mode in self.prompts:
1550 history = self.prompts[self.mode]
1552 history = self.prompts[self.mode]
1551 posx = 0
1553 posx = 0
1552 posy = self.scrsizey-1
1554 posy = self.scrsizey-1
1553 posx += self.addstr(posy, posx, 0, endx, history.prompt, astyle.style_default)
1555 posx += self.addstr(posy, posx, 0, endx, history.prompt, astyle.style_default)
1554 posx += self.addstr(posy, posx, 0, endx, " [", astyle.style_default)
1556 posx += self.addstr(posy, posx, 0, endx, " [", astyle.style_default)
1555 if history.cury==-1:
1557 if history.cury==-1:
1556 text = "new"
1558 text = "new"
1557 else:
1559 else:
1558 text = str(history.cury+1)
1560 text = str(history.cury+1)
1559 posx += self.addstr(posy, posx, 0, endx, text, astyle.style_type_number)
1561 posx += self.addstr(posy, posx, 0, endx, text, astyle.style_type_number)
1560 if history.history:
1562 if history.history:
1561 posx += self.addstr(posy, posx, 0, endx, "/", astyle.style_default)
1563 posx += self.addstr(posy, posx, 0, endx, "/", astyle.style_default)
1562 posx += self.addstr(posy, posx, 0, endx, str(len(history.history)), astyle.style_type_number)
1564 posx += self.addstr(posy, posx, 0, endx, str(len(history.history)), astyle.style_type_number)
1563 posx += self.addstr(posy, posx, 0, endx, "]: ", astyle.style_default)
1565 posx += self.addstr(posy, posx, 0, endx, "]: ", astyle.style_default)
1564 inputstartx = posx
1566 inputstartx = posx
1565 posx += self.addstr(posy, posx, 0, endx, history.input, astyle.style_default)
1567 posx += self.addstr(posy, posx, 0, endx, history.input, astyle.style_default)
1566 # Display report
1568 # Display report
1567 else:
1569 else:
1568 if self._report is not None:
1570 if self._report is not None:
1569 if isinstance(self._report, Exception):
1571 if isinstance(self._report, Exception):
1570 style = self.getstyle(astyle.style_error)
1572 style = self.getstyle(astyle.style_error)
1571 if self._report.__class__.__module__ == "exceptions":
1573 if self._report.__class__.__module__ == "exceptions":
1572 msg = "%s: %s" % \
1574 msg = "%s: %s" % \
1573 (self._report.__class__.__name__, self._report)
1575 (self._report.__class__.__name__, self._report)
1574 else:
1576 else:
1575 msg = "%s.%s: %s" % \
1577 msg = "%s.%s: %s" % \
1576 (self._report.__class__.__module__,
1578 (self._report.__class__.__module__,
1577 self._report.__class__.__name__, self._report)
1579 self._report.__class__.__name__, self._report)
1578 else:
1580 else:
1579 style = self.getstyle(self.style_report)
1581 style = self.getstyle(self.style_report)
1580 msg = self._report
1582 msg = self._report
1581 scr.addstr(self.scrsizey-1, 0, msg[:self.scrsizex], style)
1583 scr.addstr(self.scrsizey-1, 0, msg[:self.scrsizex], style)
1582 self._report = None
1584 self._report = None
1583 else:
1585 else:
1584 scr.move(self.scrsizey-1, 0)
1586 scr.move(self.scrsizey-1, 0)
1585 except curses.error:
1587 except curses.error:
1586 # Protect against errors from writing to the last line
1588 # Protect against errors from writing to the last line
1587 pass
1589 pass
1588 scr.clrtoeol()
1590 scr.clrtoeol()
1589
1591
1590 # Position cursor
1592 # Position cursor
1591 if self.mode in self.prompts:
1593 if self.mode in self.prompts:
1592 history = self.prompts[self.mode]
1594 history = self.prompts[self.mode]
1593 scr.move(self.scrsizey-1, inputstartx+history.curx)
1595 scr.move(self.scrsizey-1, inputstartx+history.curx)
1594 else:
1596 else:
1595 scr.move(
1597 scr.move(
1596 1+self._headerlines+level.cury-level.datastarty,
1598 1+self._headerlines+level.cury-level.datastarty,
1597 level.numbersizex+3+level.curx-level.datastartx
1599 level.numbersizex+3+level.curx-level.datastartx
1598 )
1600 )
1599 scr.refresh()
1601 scr.refresh()
1600
1602
1601 # Check keyboard
1603 # Check keyboard
1602 while True:
1604 while True:
1603 c = scr.getch()
1605 c = scr.getch()
1604 if self.resized:
1606 if self.resized:
1605 size = fcntl.ioctl(0, tty.TIOCGWINSZ, "12345678")
1607 size = fcntl.ioctl(0, tty.TIOCGWINSZ, "12345678")
1606 size = struct.unpack("4H", size)
1608 size = struct.unpack("4H", size)
1607 oldsize = scr.getmaxyx()
1609 oldsize = scr.getmaxyx()
1608 scr.erase()
1610 scr.erase()
1609 curses.resize_term(size[0], size[1])
1611 curses.resize_term(size[0], size[1])
1610 newsize = scr.getmaxyx()
1612 newsize = scr.getmaxyx()
1611 scr.erase()
1613 scr.erase()
1612 for l in self.levels:
1614 for l in self.levels:
1613 l.mainsizey += newsize[0]-oldsize[0]
1615 l.mainsizey += newsize[0]-oldsize[0]
1614 l.moveto(l.curx, l.cury, refresh=True)
1616 l.moveto(l.curx, l.cury, refresh=True)
1615 scr.refresh()
1617 scr.refresh()
1616 self.resized = False
1618 self.resized = False
1617 break # Redisplay
1619 break # Redisplay
1618 if self.mode in self.prompts:
1620 if self.mode in self.prompts:
1619 if self.prompts[self.mode].handlekey(self, c):
1621 if self.prompts[self.mode].handlekey(self, c):
1620 break # Redisplay
1622 break # Redisplay
1621 else:
1623 else:
1622 # if no key is pressed slow down and beep again
1624 # if no key is pressed slow down and beep again
1623 if c == -1:
1625 if c == -1:
1624 self.stepx = 1.
1626 self.stepx = 1.
1625 self.stepy = 1.
1627 self.stepy = 1.
1626 self._dobeep = True
1628 self._dobeep = True
1627 else:
1629 else:
1628 # if a different key was pressed slow down and beep too
1630 # if a different key was pressed slow down and beep too
1629 if c != lastc:
1631 if c != lastc:
1630 lastc = c
1632 lastc = c
1631 self.stepx = 1.
1633 self.stepx = 1.
1632 self.stepy = 1.
1634 self.stepy = 1.
1633 self._dobeep = True
1635 self._dobeep = True
1634 cmdname = self.keymap.get(c, None)
1636 cmdname = self.keymap.get(c, None)
1635 if cmdname is None:
1637 if cmdname is None:
1636 self.report(
1638 self.report(
1637 UnassignedKeyError("Unassigned key %s" %
1639 UnassignedKeyError("Unassigned key %s" %
1638 self.keylabel(c)))
1640 self.keylabel(c)))
1639 else:
1641 else:
1640 cmdfunc = getattr(self, "cmd_%s" % cmdname, None)
1642 cmdfunc = getattr(self, "cmd_%s" % cmdname, None)
1641 if cmdfunc is None:
1643 if cmdfunc is None:
1642 self.report(
1644 self.report(
1643 UnknownCommandError("Unknown command %r" %
1645 UnknownCommandError("Unknown command %r" %
1644 (cmdname,)))
1646 (cmdname,)))
1645 elif cmdfunc():
1647 elif cmdfunc():
1646 returnvalue = self.returnvalue
1648 returnvalue = self.returnvalue
1647 self.returnvalue = None
1649 self.returnvalue = None
1648 return returnvalue
1650 return returnvalue
1649 self.stepx = self.nextstepx(self.stepx)
1651 self.stepx = self.nextstepx(self.stepx)
1650 self.stepy = self.nextstepy(self.stepy)
1652 self.stepy = self.nextstepy(self.stepy)
1651 curses.flushinp() # get rid of type ahead
1653 curses.flushinp() # get rid of type ahead
1652 break # Redisplay
1654 break # Redisplay
1653 self.scr = None
1655 self.scr = None
1654
1656
1655 def display(self):
1657 def display(self):
1656 if hasattr(curses, "resize_term"):
1658 if hasattr(curses, "resize_term"):
1657 oldhandler = signal.signal(signal.SIGWINCH, self.sigwinchhandler)
1659 oldhandler = signal.signal(signal.SIGWINCH, self.sigwinchhandler)
1658 try:
1660 try:
1659 return curses.wrapper(self._dodisplay)
1661 return curses.wrapper(self._dodisplay)
1660 finally:
1662 finally:
1661 signal.signal(signal.SIGWINCH, oldhandler)
1663 signal.signal(signal.SIGWINCH, oldhandler)
1662 else:
1664 else:
1663 return curses.wrapper(self._dodisplay)
1665 return curses.wrapper(self._dodisplay)
@@ -1,5658 +1,5663 b''
1 2006-07-18 Walter Doerwald <walter@livinglogic.de>
2
3 * IPython/Extensions/ibrowse.py (ix): Make cursor visible over
4 non existing attributes.
5
1 2006-07-14 Walter Doerwald <walter@livinglogic.de>
6 2006-07-14 Walter Doerwald <walter@livinglogic.de>
2
7
3 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
8 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
4 error output of the running command doesn't mess up the screen.
9 error output of the running command doesn't mess up the screen.
5
10
6 2006-07-13 Walter Doerwald <walter@livinglogic.de>
11 2006-07-13 Walter Doerwald <walter@livinglogic.de>
7
12
8 * IPython/Extensions/ipipe.py (isort): Make isort usable without
13 * IPython/Extensions/ipipe.py (isort): Make isort usable without
9 argument. This sorts the items themselves.
14 argument. This sorts the items themselves.
10
15
11 2006-07-12 Walter Doerwald <walter@livinglogic.de>
16 2006-07-12 Walter Doerwald <walter@livinglogic.de>
12
17
13 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
18 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
14 Compile expression strings into code objects. This should speed
19 Compile expression strings into code objects. This should speed
15 up ifilter and friends somewhat.
20 up ifilter and friends somewhat.
16
21
17 2006-07-08 Ville Vainio <vivainio@gmail.com>
22 2006-07-08 Ville Vainio <vivainio@gmail.com>
18
23
19 * Magic.py: %cpaste now strips > from the beginning of lines
24 * Magic.py: %cpaste now strips > from the beginning of lines
20 to ease pasting quoted code from emails. Contributed by
25 to ease pasting quoted code from emails. Contributed by
21 Stefan van der Walt.
26 Stefan van der Walt.
22
27
23 2006-06-29 Ville Vainio <vivainio@gmail.com>
28 2006-06-29 Ville Vainio <vivainio@gmail.com>
24
29
25 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
30 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
26 mode, patch contributed by Darren Dale. NEEDS TESTING!
31 mode, patch contributed by Darren Dale. NEEDS TESTING!
27
32
28 2006-06-28 Walter Doerwald <walter@livinglogic.de>
33 2006-06-28 Walter Doerwald <walter@livinglogic.de>
29
34
30 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
35 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
31 a blue background. Fix fetching new display rows when the browser
36 a blue background. Fix fetching new display rows when the browser
32 scrolls more than a screenful (e.g. by using the goto command).
37 scrolls more than a screenful (e.g. by using the goto command).
33
38
34 2006-06-27 Ville Vainio <vivainio@gmail.com>
39 2006-06-27 Ville Vainio <vivainio@gmail.com>
35
40
36 * Magic.py (_inspect, _ofind) Apply David Huard's
41 * Magic.py (_inspect, _ofind) Apply David Huard's
37 patch for displaying the correct docstring for 'property'
42 patch for displaying the correct docstring for 'property'
38 attributes.
43 attributes.
39
44
40 2006-06-23 Walter Doerwald <walter@livinglogic.de>
45 2006-06-23 Walter Doerwald <walter@livinglogic.de>
41
46
42 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
47 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
43 commands into the methods implementing them.
48 commands into the methods implementing them.
44
49
45 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
50 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
46
51
47 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
52 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
48 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
53 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
49 autoindent support was authored by Jin Liu.
54 autoindent support was authored by Jin Liu.
50
55
51 2006-06-22 Walter Doerwald <walter@livinglogic.de>
56 2006-06-22 Walter Doerwald <walter@livinglogic.de>
52
57
53 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
58 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
54 for keymaps with a custom class that simplifies handling.
59 for keymaps with a custom class that simplifies handling.
55
60
56 2006-06-19 Walter Doerwald <walter@livinglogic.de>
61 2006-06-19 Walter Doerwald <walter@livinglogic.de>
57
62
58 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
63 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
59 resizing. This requires Python 2.5 to work.
64 resizing. This requires Python 2.5 to work.
60
65
61 2006-06-16 Walter Doerwald <walter@livinglogic.de>
66 2006-06-16 Walter Doerwald <walter@livinglogic.de>
62
67
63 * IPython/Extensions/ibrowse.py: Add two new commands to
68 * IPython/Extensions/ibrowse.py: Add two new commands to
64 ibrowse: "hideattr" (mapped to "h") hides the attribute under
69 ibrowse: "hideattr" (mapped to "h") hides the attribute under
65 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
70 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
66 attributes again. Remapped the help command to "?". Display
71 attributes again. Remapped the help command to "?". Display
67 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
72 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
68 as keys for the "home" and "end" commands. Add three new commands
73 as keys for the "home" and "end" commands. Add three new commands
69 to the input mode for "find" and friends: "delend" (CTRL-K)
74 to the input mode for "find" and friends: "delend" (CTRL-K)
70 deletes to the end of line. "incsearchup" searches upwards in the
75 deletes to the end of line. "incsearchup" searches upwards in the
71 command history for an input that starts with the text before the cursor.
76 command history for an input that starts with the text before the cursor.
72 "incsearchdown" does the same downwards. Removed a bogus mapping of
77 "incsearchdown" does the same downwards. Removed a bogus mapping of
73 the x key to "delete".
78 the x key to "delete".
74
79
75 2006-06-15 Ville Vainio <vivainio@gmail.com>
80 2006-06-15 Ville Vainio <vivainio@gmail.com>
76
81
77 * iplib.py, hooks.py: Added new generate_prompt hook that can be
82 * iplib.py, hooks.py: Added new generate_prompt hook that can be
78 used to create prompts dynamically, instead of the "old" way of
83 used to create prompts dynamically, instead of the "old" way of
79 assigning "magic" strings to prompt_in1 and prompt_in2. The old
84 assigning "magic" strings to prompt_in1 and prompt_in2. The old
80 way still works (it's invoked by the default hook), of course.
85 way still works (it's invoked by the default hook), of course.
81
86
82 * Prompts.py: added generate_output_prompt hook for altering output
87 * Prompts.py: added generate_output_prompt hook for altering output
83 prompt
88 prompt
84
89
85 * Release.py: Changed version string to 0.7.3.svn.
90 * Release.py: Changed version string to 0.7.3.svn.
86
91
87 2006-06-15 Walter Doerwald <walter@livinglogic.de>
92 2006-06-15 Walter Doerwald <walter@livinglogic.de>
88
93
89 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
94 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
90 the call to fetch() always tries to fetch enough data for at least one
95 the call to fetch() always tries to fetch enough data for at least one
91 full screen. This makes it possible to simply call moveto(0,0,True) in
96 full screen. This makes it possible to simply call moveto(0,0,True) in
92 the constructor. Fix typos and removed the obsolete goto attribute.
97 the constructor. Fix typos and removed the obsolete goto attribute.
93
98
94 2006-06-12 Ville Vainio <vivainio@gmail.com>
99 2006-06-12 Ville Vainio <vivainio@gmail.com>
95
100
96 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
101 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
97 allowing $variable interpolation within multiline statements,
102 allowing $variable interpolation within multiline statements,
98 though so far only with "sh" profile for a testing period.
103 though so far only with "sh" profile for a testing period.
99 The patch also enables splitting long commands with \ but it
104 The patch also enables splitting long commands with \ but it
100 doesn't work properly yet.
105 doesn't work properly yet.
101
106
102 2006-06-12 Walter Doerwald <walter@livinglogic.de>
107 2006-06-12 Walter Doerwald <walter@livinglogic.de>
103
108
104 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
109 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
105 input history and the position of the cursor in the input history for
110 input history and the position of the cursor in the input history for
106 the find, findbackwards and goto command.
111 the find, findbackwards and goto command.
107
112
108 2006-06-10 Walter Doerwald <walter@livinglogic.de>
113 2006-06-10 Walter Doerwald <walter@livinglogic.de>
109
114
110 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
115 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
111 implements the basic functionality of browser commands that require
116 implements the basic functionality of browser commands that require
112 input. Reimplement the goto, find and findbackwards commands as
117 input. Reimplement the goto, find and findbackwards commands as
113 subclasses of _CommandInput. Add an input history and keymaps to those
118 subclasses of _CommandInput. Add an input history and keymaps to those
114 commands. Add "\r" as a keyboard shortcut for the enterdefault and
119 commands. Add "\r" as a keyboard shortcut for the enterdefault and
115 execute commands.
120 execute commands.
116
121
117 2006-06-07 Ville Vainio <vivainio@gmail.com>
122 2006-06-07 Ville Vainio <vivainio@gmail.com>
118
123
119 * iplib.py: ipython mybatch.ipy exits ipython immediately after
124 * iplib.py: ipython mybatch.ipy exits ipython immediately after
120 running the batch files instead of leaving the session open.
125 running the batch files instead of leaving the session open.
121
126
122 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
127 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
123
128
124 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
129 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
125 the original fix was incomplete. Patch submitted by W. Maier.
130 the original fix was incomplete. Patch submitted by W. Maier.
126
131
127 2006-06-07 Ville Vainio <vivainio@gmail.com>
132 2006-06-07 Ville Vainio <vivainio@gmail.com>
128
133
129 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
134 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
130 Confirmation prompts can be supressed by 'quiet' option.
135 Confirmation prompts can be supressed by 'quiet' option.
131 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
136 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
132
137
133 2006-06-06 *** Released version 0.7.2
138 2006-06-06 *** Released version 0.7.2
134
139
135 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
140 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
136
141
137 * IPython/Release.py (version): Made 0.7.2 final for release.
142 * IPython/Release.py (version): Made 0.7.2 final for release.
138 Repo tagged and release cut.
143 Repo tagged and release cut.
139
144
140 2006-06-05 Ville Vainio <vivainio@gmail.com>
145 2006-06-05 Ville Vainio <vivainio@gmail.com>
141
146
142 * Magic.py (magic_rehashx): Honor no_alias list earlier in
147 * Magic.py (magic_rehashx): Honor no_alias list earlier in
143 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
148 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
144
149
145 * upgrade_dir.py: try import 'path' module a bit harder
150 * upgrade_dir.py: try import 'path' module a bit harder
146 (for %upgrade)
151 (for %upgrade)
147
152
148 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
153 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
149
154
150 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
155 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
151 instead of looping 20 times.
156 instead of looping 20 times.
152
157
153 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
158 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
154 correctly at initialization time. Bug reported by Krishna Mohan
159 correctly at initialization time. Bug reported by Krishna Mohan
155 Gundu <gkmohan-AT-gmail.com> on the user list.
160 Gundu <gkmohan-AT-gmail.com> on the user list.
156
161
157 * IPython/Release.py (version): Mark 0.7.2 version to start
162 * IPython/Release.py (version): Mark 0.7.2 version to start
158 testing for release on 06/06.
163 testing for release on 06/06.
159
164
160 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
165 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
161
166
162 * scripts/irunner: thin script interface so users don't have to
167 * scripts/irunner: thin script interface so users don't have to
163 find the module and call it as an executable, since modules rarely
168 find the module and call it as an executable, since modules rarely
164 live in people's PATH.
169 live in people's PATH.
165
170
166 * IPython/irunner.py (InteractiveRunner.__init__): added
171 * IPython/irunner.py (InteractiveRunner.__init__): added
167 delaybeforesend attribute to control delays with newer versions of
172 delaybeforesend attribute to control delays with newer versions of
168 pexpect. Thanks to detailed help from pexpect's author, Noah
173 pexpect. Thanks to detailed help from pexpect's author, Noah
169 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
174 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
170 correctly (it works in NoColor mode).
175 correctly (it works in NoColor mode).
171
176
172 * IPython/iplib.py (handle_normal): fix nasty crash reported on
177 * IPython/iplib.py (handle_normal): fix nasty crash reported on
173 SAGE list, from improper log() calls.
178 SAGE list, from improper log() calls.
174
179
175 2006-05-31 Ville Vainio <vivainio@gmail.com>
180 2006-05-31 Ville Vainio <vivainio@gmail.com>
176
181
177 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
182 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
178 with args in parens to work correctly with dirs that have spaces.
183 with args in parens to work correctly with dirs that have spaces.
179
184
180 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
185 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
181
186
182 * IPython/Logger.py (Logger.logstart): add option to log raw input
187 * IPython/Logger.py (Logger.logstart): add option to log raw input
183 instead of the processed one. A -r flag was added to the
188 instead of the processed one. A -r flag was added to the
184 %logstart magic used for controlling logging.
189 %logstart magic used for controlling logging.
185
190
186 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
191 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
187
192
188 * IPython/iplib.py (InteractiveShell.__init__): add check for the
193 * IPython/iplib.py (InteractiveShell.__init__): add check for the
189 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
194 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
190 recognize the option. After a bug report by Will Maier. This
195 recognize the option. After a bug report by Will Maier. This
191 closes #64 (will do it after confirmation from W. Maier).
196 closes #64 (will do it after confirmation from W. Maier).
192
197
193 * IPython/irunner.py: New module to run scripts as if manually
198 * IPython/irunner.py: New module to run scripts as if manually
194 typed into an interactive environment, based on pexpect. After a
199 typed into an interactive environment, based on pexpect. After a
195 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
200 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
196 ipython-user list. Simple unittests in the tests/ directory.
201 ipython-user list. Simple unittests in the tests/ directory.
197
202
198 * tools/release: add Will Maier, OpenBSD port maintainer, to
203 * tools/release: add Will Maier, OpenBSD port maintainer, to
199 recepients list. We are now officially part of the OpenBSD ports:
204 recepients list. We are now officially part of the OpenBSD ports:
200 http://www.openbsd.org/ports.html ! Many thanks to Will for the
205 http://www.openbsd.org/ports.html ! Many thanks to Will for the
201 work.
206 work.
202
207
203 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
208 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
204
209
205 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
210 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
206 so that it doesn't break tkinter apps.
211 so that it doesn't break tkinter apps.
207
212
208 * IPython/iplib.py (_prefilter): fix bug where aliases would
213 * IPython/iplib.py (_prefilter): fix bug where aliases would
209 shadow variables when autocall was fully off. Reported by SAGE
214 shadow variables when autocall was fully off. Reported by SAGE
210 author William Stein.
215 author William Stein.
211
216
212 * IPython/OInspect.py (Inspector.__init__): add a flag to control
217 * IPython/OInspect.py (Inspector.__init__): add a flag to control
213 at what detail level strings are computed when foo? is requested.
218 at what detail level strings are computed when foo? is requested.
214 This allows users to ask for example that the string form of an
219 This allows users to ask for example that the string form of an
215 object is only computed when foo?? is called, or even never, by
220 object is only computed when foo?? is called, or even never, by
216 setting the object_info_string_level >= 2 in the configuration
221 setting the object_info_string_level >= 2 in the configuration
217 file. This new option has been added and documented. After a
222 file. This new option has been added and documented. After a
218 request by SAGE to be able to control the printing of very large
223 request by SAGE to be able to control the printing of very large
219 objects more easily.
224 objects more easily.
220
225
221 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
226 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
222
227
223 * IPython/ipmaker.py (make_IPython): remove the ipython call path
228 * IPython/ipmaker.py (make_IPython): remove the ipython call path
224 from sys.argv, to be 100% consistent with how Python itself works
229 from sys.argv, to be 100% consistent with how Python itself works
225 (as seen for example with python -i file.py). After a bug report
230 (as seen for example with python -i file.py). After a bug report
226 by Jeffrey Collins.
231 by Jeffrey Collins.
227
232
228 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
233 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
229 nasty bug which was preventing custom namespaces with -pylab,
234 nasty bug which was preventing custom namespaces with -pylab,
230 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
235 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
231 compatibility (long gone from mpl).
236 compatibility (long gone from mpl).
232
237
233 * IPython/ipapi.py (make_session): name change: create->make. We
238 * IPython/ipapi.py (make_session): name change: create->make. We
234 use make in other places (ipmaker,...), it's shorter and easier to
239 use make in other places (ipmaker,...), it's shorter and easier to
235 type and say, etc. I'm trying to clean things before 0.7.2 so
240 type and say, etc. I'm trying to clean things before 0.7.2 so
236 that I can keep things stable wrt to ipapi in the chainsaw branch.
241 that I can keep things stable wrt to ipapi in the chainsaw branch.
237
242
238 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
243 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
239 python-mode recognizes our debugger mode. Add support for
244 python-mode recognizes our debugger mode. Add support for
240 autoindent inside (X)emacs. After a patch sent in by Jin Liu
245 autoindent inside (X)emacs. After a patch sent in by Jin Liu
241 <m.liu.jin-AT-gmail.com> originally written by
246 <m.liu.jin-AT-gmail.com> originally written by
242 doxgen-AT-newsmth.net (with minor modifications for xemacs
247 doxgen-AT-newsmth.net (with minor modifications for xemacs
243 compatibility)
248 compatibility)
244
249
245 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
250 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
246 tracebacks when walking the stack so that the stack tracking system
251 tracebacks when walking the stack so that the stack tracking system
247 in emacs' python-mode can identify the frames correctly.
252 in emacs' python-mode can identify the frames correctly.
248
253
249 * IPython/ipmaker.py (make_IPython): make the internal (and
254 * IPython/ipmaker.py (make_IPython): make the internal (and
250 default config) autoedit_syntax value false by default. Too many
255 default config) autoedit_syntax value false by default. Too many
251 users have complained to me (both on and off-list) about problems
256 users have complained to me (both on and off-list) about problems
252 with this option being on by default, so I'm making it default to
257 with this option being on by default, so I'm making it default to
253 off. It can still be enabled by anyone via the usual mechanisms.
258 off. It can still be enabled by anyone via the usual mechanisms.
254
259
255 * IPython/completer.py (Completer.attr_matches): add support for
260 * IPython/completer.py (Completer.attr_matches): add support for
256 PyCrust-style _getAttributeNames magic method. Patch contributed
261 PyCrust-style _getAttributeNames magic method. Patch contributed
257 by <mscott-AT-goldenspud.com>. Closes #50.
262 by <mscott-AT-goldenspud.com>. Closes #50.
258
263
259 * IPython/iplib.py (InteractiveShell.__init__): remove the
264 * IPython/iplib.py (InteractiveShell.__init__): remove the
260 deletion of exit/quit from __builtin__, which can break
265 deletion of exit/quit from __builtin__, which can break
261 third-party tools like the Zope debugging console. The
266 third-party tools like the Zope debugging console. The
262 %exit/%quit magics remain. In general, it's probably a good idea
267 %exit/%quit magics remain. In general, it's probably a good idea
263 not to delete anything from __builtin__, since we never know what
268 not to delete anything from __builtin__, since we never know what
264 that will break. In any case, python now (for 2.5) will support
269 that will break. In any case, python now (for 2.5) will support
265 'real' exit/quit, so this issue is moot. Closes #55.
270 'real' exit/quit, so this issue is moot. Closes #55.
266
271
267 * IPython/genutils.py (with_obj): rename the 'with' function to
272 * IPython/genutils.py (with_obj): rename the 'with' function to
268 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
273 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
269 becomes a language keyword. Closes #53.
274 becomes a language keyword. Closes #53.
270
275
271 * IPython/FakeModule.py (FakeModule.__init__): add a proper
276 * IPython/FakeModule.py (FakeModule.__init__): add a proper
272 __file__ attribute to this so it fools more things into thinking
277 __file__ attribute to this so it fools more things into thinking
273 it is a real module. Closes #59.
278 it is a real module. Closes #59.
274
279
275 * IPython/Magic.py (magic_edit): add -n option to open the editor
280 * IPython/Magic.py (magic_edit): add -n option to open the editor
276 at a specific line number. After a patch by Stefan van der Walt.
281 at a specific line number. After a patch by Stefan van der Walt.
277
282
278 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
283 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
279
284
280 * IPython/iplib.py (edit_syntax_error): fix crash when for some
285 * IPython/iplib.py (edit_syntax_error): fix crash when for some
281 reason the file could not be opened. After automatic crash
286 reason the file could not be opened. After automatic crash
282 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
287 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
283 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
288 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
284 (_should_recompile): Don't fire editor if using %bg, since there
289 (_should_recompile): Don't fire editor if using %bg, since there
285 is no file in the first place. From the same report as above.
290 is no file in the first place. From the same report as above.
286 (raw_input): protect against faulty third-party prefilters. After
291 (raw_input): protect against faulty third-party prefilters. After
287 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
292 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
288 while running under SAGE.
293 while running under SAGE.
289
294
290 2006-05-23 Ville Vainio <vivainio@gmail.com>
295 2006-05-23 Ville Vainio <vivainio@gmail.com>
291
296
292 * ipapi.py: Stripped down ip.to_user_ns() to work only as
297 * ipapi.py: Stripped down ip.to_user_ns() to work only as
293 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
298 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
294 now returns None (again), unless dummy is specifically allowed by
299 now returns None (again), unless dummy is specifically allowed by
295 ipapi.get(allow_dummy=True).
300 ipapi.get(allow_dummy=True).
296
301
297 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
302 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
298
303
299 * IPython: remove all 2.2-compatibility objects and hacks from
304 * IPython: remove all 2.2-compatibility objects and hacks from
300 everywhere, since we only support 2.3 at this point. Docs
305 everywhere, since we only support 2.3 at this point. Docs
301 updated.
306 updated.
302
307
303 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
308 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
304 Anything requiring extra validation can be turned into a Python
309 Anything requiring extra validation can be turned into a Python
305 property in the future. I used a property for the db one b/c
310 property in the future. I used a property for the db one b/c
306 there was a nasty circularity problem with the initialization
311 there was a nasty circularity problem with the initialization
307 order, which right now I don't have time to clean up.
312 order, which right now I don't have time to clean up.
308
313
309 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
314 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
310 another locking bug reported by Jorgen. I'm not 100% sure though,
315 another locking bug reported by Jorgen. I'm not 100% sure though,
311 so more testing is needed...
316 so more testing is needed...
312
317
313 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
318 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
314
319
315 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
320 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
316 local variables from any routine in user code (typically executed
321 local variables from any routine in user code (typically executed
317 with %run) directly into the interactive namespace. Very useful
322 with %run) directly into the interactive namespace. Very useful
318 when doing complex debugging.
323 when doing complex debugging.
319 (IPythonNotRunning): Changed the default None object to a dummy
324 (IPythonNotRunning): Changed the default None object to a dummy
320 whose attributes can be queried as well as called without
325 whose attributes can be queried as well as called without
321 exploding, to ease writing code which works transparently both in
326 exploding, to ease writing code which works transparently both in
322 and out of ipython and uses some of this API.
327 and out of ipython and uses some of this API.
323
328
324 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
329 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
325
330
326 * IPython/hooks.py (result_display): Fix the fact that our display
331 * IPython/hooks.py (result_display): Fix the fact that our display
327 hook was using str() instead of repr(), as the default python
332 hook was using str() instead of repr(), as the default python
328 console does. This had gone unnoticed b/c it only happened if
333 console does. This had gone unnoticed b/c it only happened if
329 %Pprint was off, but the inconsistency was there.
334 %Pprint was off, but the inconsistency was there.
330
335
331 2006-05-15 Ville Vainio <vivainio@gmail.com>
336 2006-05-15 Ville Vainio <vivainio@gmail.com>
332
337
333 * Oinspect.py: Only show docstring for nonexisting/binary files
338 * Oinspect.py: Only show docstring for nonexisting/binary files
334 when doing object??, closing ticket #62
339 when doing object??, closing ticket #62
335
340
336 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
341 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
337
342
338 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
343 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
339 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
344 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
340 was being released in a routine which hadn't checked if it had
345 was being released in a routine which hadn't checked if it had
341 been the one to acquire it.
346 been the one to acquire it.
342
347
343 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
348 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
344
349
345 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
350 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
346
351
347 2006-04-11 Ville Vainio <vivainio@gmail.com>
352 2006-04-11 Ville Vainio <vivainio@gmail.com>
348
353
349 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
354 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
350 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
355 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
351 prefilters, allowing stuff like magics and aliases in the file.
356 prefilters, allowing stuff like magics and aliases in the file.
352
357
353 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
358 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
354 added. Supported now are "%clear in" and "%clear out" (clear input and
359 added. Supported now are "%clear in" and "%clear out" (clear input and
355 output history, respectively). Also fixed CachedOutput.flush to
360 output history, respectively). Also fixed CachedOutput.flush to
356 properly flush the output cache.
361 properly flush the output cache.
357
362
358 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
363 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
359 half-success (and fail explicitly).
364 half-success (and fail explicitly).
360
365
361 2006-03-28 Ville Vainio <vivainio@gmail.com>
366 2006-03-28 Ville Vainio <vivainio@gmail.com>
362
367
363 * iplib.py: Fix quoting of aliases so that only argless ones
368 * iplib.py: Fix quoting of aliases so that only argless ones
364 are quoted
369 are quoted
365
370
366 2006-03-28 Ville Vainio <vivainio@gmail.com>
371 2006-03-28 Ville Vainio <vivainio@gmail.com>
367
372
368 * iplib.py: Quote aliases with spaces in the name.
373 * iplib.py: Quote aliases with spaces in the name.
369 "c:\program files\blah\bin" is now legal alias target.
374 "c:\program files\blah\bin" is now legal alias target.
370
375
371 * ext_rehashdir.py: Space no longer allowed as arg
376 * ext_rehashdir.py: Space no longer allowed as arg
372 separator, since space is legal in path names.
377 separator, since space is legal in path names.
373
378
374 2006-03-16 Ville Vainio <vivainio@gmail.com>
379 2006-03-16 Ville Vainio <vivainio@gmail.com>
375
380
376 * upgrade_dir.py: Take path.py from Extensions, correcting
381 * upgrade_dir.py: Take path.py from Extensions, correcting
377 %upgrade magic
382 %upgrade magic
378
383
379 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
384 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
380
385
381 * hooks.py: Only enclose editor binary in quotes if legal and
386 * hooks.py: Only enclose editor binary in quotes if legal and
382 necessary (space in the name, and is an existing file). Fixes a bug
387 necessary (space in the name, and is an existing file). Fixes a bug
383 reported by Zachary Pincus.
388 reported by Zachary Pincus.
384
389
385 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
390 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
386
391
387 * Manual: thanks to a tip on proper color handling for Emacs, by
392 * Manual: thanks to a tip on proper color handling for Emacs, by
388 Eric J Haywiser <ejh1-AT-MIT.EDU>.
393 Eric J Haywiser <ejh1-AT-MIT.EDU>.
389
394
390 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
395 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
391 by applying the provided patch. Thanks to Liu Jin
396 by applying the provided patch. Thanks to Liu Jin
392 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
397 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
393 XEmacs/Linux, I'm trusting the submitter that it actually helps
398 XEmacs/Linux, I'm trusting the submitter that it actually helps
394 under win32/GNU Emacs. Will revisit if any problems are reported.
399 under win32/GNU Emacs. Will revisit if any problems are reported.
395
400
396 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
401 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
397
402
398 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
403 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
399 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
404 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
400
405
401 2006-03-12 Ville Vainio <vivainio@gmail.com>
406 2006-03-12 Ville Vainio <vivainio@gmail.com>
402
407
403 * Magic.py (magic_timeit): Added %timeit magic, contributed by
408 * Magic.py (magic_timeit): Added %timeit magic, contributed by
404 Torsten Marek.
409 Torsten Marek.
405
410
406 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
411 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
407
412
408 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
413 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
409 line ranges works again.
414 line ranges works again.
410
415
411 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
416 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
412
417
413 * IPython/iplib.py (showtraceback): add back sys.last_traceback
418 * IPython/iplib.py (showtraceback): add back sys.last_traceback
414 and friends, after a discussion with Zach Pincus on ipython-user.
419 and friends, after a discussion with Zach Pincus on ipython-user.
415 I'm not 100% sure, but after thinking about it quite a bit, it may
420 I'm not 100% sure, but after thinking about it quite a bit, it may
416 be OK. Testing with the multithreaded shells didn't reveal any
421 be OK. Testing with the multithreaded shells didn't reveal any
417 problems, but let's keep an eye out.
422 problems, but let's keep an eye out.
418
423
419 In the process, I fixed a few things which were calling
424 In the process, I fixed a few things which were calling
420 self.InteractiveTB() directly (like safe_execfile), which is a
425 self.InteractiveTB() directly (like safe_execfile), which is a
421 mistake: ALL exception reporting should be done by calling
426 mistake: ALL exception reporting should be done by calling
422 self.showtraceback(), which handles state and tab-completion and
427 self.showtraceback(), which handles state and tab-completion and
423 more.
428 more.
424
429
425 2006-03-01 Ville Vainio <vivainio@gmail.com>
430 2006-03-01 Ville Vainio <vivainio@gmail.com>
426
431
427 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
432 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
428 To use, do "from ipipe import *".
433 To use, do "from ipipe import *".
429
434
430 2006-02-24 Ville Vainio <vivainio@gmail.com>
435 2006-02-24 Ville Vainio <vivainio@gmail.com>
431
436
432 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
437 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
433 "cleanly" and safely than the older upgrade mechanism.
438 "cleanly" and safely than the older upgrade mechanism.
434
439
435 2006-02-21 Ville Vainio <vivainio@gmail.com>
440 2006-02-21 Ville Vainio <vivainio@gmail.com>
436
441
437 * Magic.py: %save works again.
442 * Magic.py: %save works again.
438
443
439 2006-02-15 Ville Vainio <vivainio@gmail.com>
444 2006-02-15 Ville Vainio <vivainio@gmail.com>
440
445
441 * Magic.py: %Pprint works again
446 * Magic.py: %Pprint works again
442
447
443 * Extensions/ipy_sane_defaults.py: Provide everything provided
448 * Extensions/ipy_sane_defaults.py: Provide everything provided
444 in default ipythonrc, to make it possible to have a completely empty
449 in default ipythonrc, to make it possible to have a completely empty
445 ipythonrc (and thus completely rc-file free configuration)
450 ipythonrc (and thus completely rc-file free configuration)
446
451
447 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
452 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
448
453
449 * IPython/hooks.py (editor): quote the call to the editor command,
454 * IPython/hooks.py (editor): quote the call to the editor command,
450 to allow commands with spaces in them. Problem noted by watching
455 to allow commands with spaces in them. Problem noted by watching
451 Ian Oswald's video about textpad under win32 at
456 Ian Oswald's video about textpad under win32 at
452 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
457 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
453
458
454 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
459 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
455 describing magics (we haven't used @ for a loong time).
460 describing magics (we haven't used @ for a loong time).
456
461
457 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
462 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
458 contributed by marienz to close
463 contributed by marienz to close
459 http://www.scipy.net/roundup/ipython/issue53.
464 http://www.scipy.net/roundup/ipython/issue53.
460
465
461 2006-02-10 Ville Vainio <vivainio@gmail.com>
466 2006-02-10 Ville Vainio <vivainio@gmail.com>
462
467
463 * genutils.py: getoutput now works in win32 too
468 * genutils.py: getoutput now works in win32 too
464
469
465 * completer.py: alias and magic completion only invoked
470 * completer.py: alias and magic completion only invoked
466 at the first "item" in the line, to avoid "cd %store"
471 at the first "item" in the line, to avoid "cd %store"
467 nonsense.
472 nonsense.
468
473
469 2006-02-09 Ville Vainio <vivainio@gmail.com>
474 2006-02-09 Ville Vainio <vivainio@gmail.com>
470
475
471 * test/*: Added a unit testing framework (finally).
476 * test/*: Added a unit testing framework (finally).
472 '%run runtests.py' to run test_*.
477 '%run runtests.py' to run test_*.
473
478
474 * ipapi.py: Exposed runlines and set_custom_exc
479 * ipapi.py: Exposed runlines and set_custom_exc
475
480
476 2006-02-07 Ville Vainio <vivainio@gmail.com>
481 2006-02-07 Ville Vainio <vivainio@gmail.com>
477
482
478 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
483 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
479 instead use "f(1 2)" as before.
484 instead use "f(1 2)" as before.
480
485
481 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
486 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
482
487
483 * IPython/demo.py (IPythonDemo): Add new classes to the demo
488 * IPython/demo.py (IPythonDemo): Add new classes to the demo
484 facilities, for demos processed by the IPython input filter
489 facilities, for demos processed by the IPython input filter
485 (IPythonDemo), and for running a script one-line-at-a-time as a
490 (IPythonDemo), and for running a script one-line-at-a-time as a
486 demo, both for pure Python (LineDemo) and for IPython-processed
491 demo, both for pure Python (LineDemo) and for IPython-processed
487 input (IPythonLineDemo). After a request by Dave Kohel, from the
492 input (IPythonLineDemo). After a request by Dave Kohel, from the
488 SAGE team.
493 SAGE team.
489 (Demo.edit): added an edit() method to the demo objects, to edit
494 (Demo.edit): added an edit() method to the demo objects, to edit
490 the in-memory copy of the last executed block.
495 the in-memory copy of the last executed block.
491
496
492 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
497 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
493 processing to %edit, %macro and %save. These commands can now be
498 processing to %edit, %macro and %save. These commands can now be
494 invoked on the unprocessed input as it was typed by the user
499 invoked on the unprocessed input as it was typed by the user
495 (without any prefilters applied). After requests by the SAGE team
500 (without any prefilters applied). After requests by the SAGE team
496 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
501 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
497
502
498 2006-02-01 Ville Vainio <vivainio@gmail.com>
503 2006-02-01 Ville Vainio <vivainio@gmail.com>
499
504
500 * setup.py, eggsetup.py: easy_install ipython==dev works
505 * setup.py, eggsetup.py: easy_install ipython==dev works
501 correctly now (on Linux)
506 correctly now (on Linux)
502
507
503 * ipy_user_conf,ipmaker: user config changes, removed spurious
508 * ipy_user_conf,ipmaker: user config changes, removed spurious
504 warnings
509 warnings
505
510
506 * iplib: if rc.banner is string, use it as is.
511 * iplib: if rc.banner is string, use it as is.
507
512
508 * Magic: %pycat accepts a string argument and pages it's contents.
513 * Magic: %pycat accepts a string argument and pages it's contents.
509
514
510
515
511 2006-01-30 Ville Vainio <vivainio@gmail.com>
516 2006-01-30 Ville Vainio <vivainio@gmail.com>
512
517
513 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
518 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
514 Now %store and bookmarks work through PickleShare, meaning that
519 Now %store and bookmarks work through PickleShare, meaning that
515 concurrent access is possible and all ipython sessions see the
520 concurrent access is possible and all ipython sessions see the
516 same database situation all the time, instead of snapshot of
521 same database situation all the time, instead of snapshot of
517 the situation when the session was started. Hence, %bookmark
522 the situation when the session was started. Hence, %bookmark
518 results are immediately accessible from othes sessions. The database
523 results are immediately accessible from othes sessions. The database
519 is also available for use by user extensions. See:
524 is also available for use by user extensions. See:
520 http://www.python.org/pypi/pickleshare
525 http://www.python.org/pypi/pickleshare
521
526
522 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
527 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
523
528
524 * aliases can now be %store'd
529 * aliases can now be %store'd
525
530
526 * path.py moved to Extensions so that pickleshare does not need
531 * path.py moved to Extensions so that pickleshare does not need
527 IPython-specific import. Extensions added to pythonpath right
532 IPython-specific import. Extensions added to pythonpath right
528 at __init__.
533 at __init__.
529
534
530 * iplib.py: ipalias deprecated/redundant; aliases are converted and
535 * iplib.py: ipalias deprecated/redundant; aliases are converted and
531 called with _ip.system and the pre-transformed command string.
536 called with _ip.system and the pre-transformed command string.
532
537
533 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
538 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
534
539
535 * IPython/iplib.py (interact): Fix that we were not catching
540 * IPython/iplib.py (interact): Fix that we were not catching
536 KeyboardInterrupt exceptions properly. I'm not quite sure why the
541 KeyboardInterrupt exceptions properly. I'm not quite sure why the
537 logic here had to change, but it's fixed now.
542 logic here had to change, but it's fixed now.
538
543
539 2006-01-29 Ville Vainio <vivainio@gmail.com>
544 2006-01-29 Ville Vainio <vivainio@gmail.com>
540
545
541 * iplib.py: Try to import pyreadline on Windows.
546 * iplib.py: Try to import pyreadline on Windows.
542
547
543 2006-01-27 Ville Vainio <vivainio@gmail.com>
548 2006-01-27 Ville Vainio <vivainio@gmail.com>
544
549
545 * iplib.py: Expose ipapi as _ip in builtin namespace.
550 * iplib.py: Expose ipapi as _ip in builtin namespace.
546 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
551 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
547 and ip_set_hook (-> _ip.set_hook) redundant. % and !
552 and ip_set_hook (-> _ip.set_hook) redundant. % and !
548 syntax now produce _ip.* variant of the commands.
553 syntax now produce _ip.* variant of the commands.
549
554
550 * "_ip.options().autoedit_syntax = 2" automatically throws
555 * "_ip.options().autoedit_syntax = 2" automatically throws
551 user to editor for syntax error correction without prompting.
556 user to editor for syntax error correction without prompting.
552
557
553 2006-01-27 Ville Vainio <vivainio@gmail.com>
558 2006-01-27 Ville Vainio <vivainio@gmail.com>
554
559
555 * ipmaker.py: Give "realistic" sys.argv for scripts (without
560 * ipmaker.py: Give "realistic" sys.argv for scripts (without
556 'ipython' at argv[0]) executed through command line.
561 'ipython' at argv[0]) executed through command line.
557 NOTE: this DEPRECATES calling ipython with multiple scripts
562 NOTE: this DEPRECATES calling ipython with multiple scripts
558 ("ipython a.py b.py c.py")
563 ("ipython a.py b.py c.py")
559
564
560 * iplib.py, hooks.py: Added configurable input prefilter,
565 * iplib.py, hooks.py: Added configurable input prefilter,
561 named 'input_prefilter'. See ext_rescapture.py for example
566 named 'input_prefilter'. See ext_rescapture.py for example
562 usage.
567 usage.
563
568
564 * ext_rescapture.py, Magic.py: Better system command output capture
569 * ext_rescapture.py, Magic.py: Better system command output capture
565 through 'var = !ls' (deprecates user-visible %sc). Same notation
570 through 'var = !ls' (deprecates user-visible %sc). Same notation
566 applies for magics, 'var = %alias' assigns alias list to var.
571 applies for magics, 'var = %alias' assigns alias list to var.
567
572
568 * ipapi.py: added meta() for accessing extension-usable data store.
573 * ipapi.py: added meta() for accessing extension-usable data store.
569
574
570 * iplib.py: added InteractiveShell.getapi(). New magics should be
575 * iplib.py: added InteractiveShell.getapi(). New magics should be
571 written doing self.getapi() instead of using the shell directly.
576 written doing self.getapi() instead of using the shell directly.
572
577
573 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
578 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
574 %store foo >> ~/myfoo.txt to store variables to files (in clean
579 %store foo >> ~/myfoo.txt to store variables to files (in clean
575 textual form, not a restorable pickle).
580 textual form, not a restorable pickle).
576
581
577 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
582 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
578
583
579 * usage.py, Magic.py: added %quickref
584 * usage.py, Magic.py: added %quickref
580
585
581 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
586 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
582
587
583 * GetoptErrors when invoking magics etc. with wrong args
588 * GetoptErrors when invoking magics etc. with wrong args
584 are now more helpful:
589 are now more helpful:
585 GetoptError: option -l not recognized (allowed: "qb" )
590 GetoptError: option -l not recognized (allowed: "qb" )
586
591
587 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
592 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
588
593
589 * IPython/demo.py (Demo.show): Flush stdout after each block, so
594 * IPython/demo.py (Demo.show): Flush stdout after each block, so
590 computationally intensive blocks don't appear to stall the demo.
595 computationally intensive blocks don't appear to stall the demo.
591
596
592 2006-01-24 Ville Vainio <vivainio@gmail.com>
597 2006-01-24 Ville Vainio <vivainio@gmail.com>
593
598
594 * iplib.py, hooks.py: 'result_display' hook can return a non-None
599 * iplib.py, hooks.py: 'result_display' hook can return a non-None
595 value to manipulate resulting history entry.
600 value to manipulate resulting history entry.
596
601
597 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
602 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
598 to instance methods of IPApi class, to make extending an embedded
603 to instance methods of IPApi class, to make extending an embedded
599 IPython feasible. See ext_rehashdir.py for example usage.
604 IPython feasible. See ext_rehashdir.py for example usage.
600
605
601 * Merged 1071-1076 from branches/0.7.1
606 * Merged 1071-1076 from branches/0.7.1
602
607
603
608
604 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
609 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
605
610
606 * tools/release (daystamp): Fix build tools to use the new
611 * tools/release (daystamp): Fix build tools to use the new
607 eggsetup.py script to build lightweight eggs.
612 eggsetup.py script to build lightweight eggs.
608
613
609 * Applied changesets 1062 and 1064 before 0.7.1 release.
614 * Applied changesets 1062 and 1064 before 0.7.1 release.
610
615
611 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
616 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
612 see the raw input history (without conversions like %ls ->
617 see the raw input history (without conversions like %ls ->
613 ipmagic("ls")). After a request from W. Stein, SAGE
618 ipmagic("ls")). After a request from W. Stein, SAGE
614 (http://modular.ucsd.edu/sage) developer. This information is
619 (http://modular.ucsd.edu/sage) developer. This information is
615 stored in the input_hist_raw attribute of the IPython instance, so
620 stored in the input_hist_raw attribute of the IPython instance, so
616 developers can access it if needed (it's an InputList instance).
621 developers can access it if needed (it's an InputList instance).
617
622
618 * Versionstring = 0.7.2.svn
623 * Versionstring = 0.7.2.svn
619
624
620 * eggsetup.py: A separate script for constructing eggs, creates
625 * eggsetup.py: A separate script for constructing eggs, creates
621 proper launch scripts even on Windows (an .exe file in
626 proper launch scripts even on Windows (an .exe file in
622 \python24\scripts).
627 \python24\scripts).
623
628
624 * ipapi.py: launch_new_instance, launch entry point needed for the
629 * ipapi.py: launch_new_instance, launch entry point needed for the
625 egg.
630 egg.
626
631
627 2006-01-23 Ville Vainio <vivainio@gmail.com>
632 2006-01-23 Ville Vainio <vivainio@gmail.com>
628
633
629 * Added %cpaste magic for pasting python code
634 * Added %cpaste magic for pasting python code
630
635
631 2006-01-22 Ville Vainio <vivainio@gmail.com>
636 2006-01-22 Ville Vainio <vivainio@gmail.com>
632
637
633 * Merge from branches/0.7.1 into trunk, revs 1052-1057
638 * Merge from branches/0.7.1 into trunk, revs 1052-1057
634
639
635 * Versionstring = 0.7.2.svn
640 * Versionstring = 0.7.2.svn
636
641
637 * eggsetup.py: A separate script for constructing eggs, creates
642 * eggsetup.py: A separate script for constructing eggs, creates
638 proper launch scripts even on Windows (an .exe file in
643 proper launch scripts even on Windows (an .exe file in
639 \python24\scripts).
644 \python24\scripts).
640
645
641 * ipapi.py: launch_new_instance, launch entry point needed for the
646 * ipapi.py: launch_new_instance, launch entry point needed for the
642 egg.
647 egg.
643
648
644 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
649 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
645
650
646 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
651 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
647 %pfile foo would print the file for foo even if it was a binary.
652 %pfile foo would print the file for foo even if it was a binary.
648 Now, extensions '.so' and '.dll' are skipped.
653 Now, extensions '.so' and '.dll' are skipped.
649
654
650 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
655 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
651 bug, where macros would fail in all threaded modes. I'm not 100%
656 bug, where macros would fail in all threaded modes. I'm not 100%
652 sure, so I'm going to put out an rc instead of making a release
657 sure, so I'm going to put out an rc instead of making a release
653 today, and wait for feedback for at least a few days.
658 today, and wait for feedback for at least a few days.
654
659
655 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
660 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
656 it...) the handling of pasting external code with autoindent on.
661 it...) the handling of pasting external code with autoindent on.
657 To get out of a multiline input, the rule will appear for most
662 To get out of a multiline input, the rule will appear for most
658 users unchanged: two blank lines or change the indent level
663 users unchanged: two blank lines or change the indent level
659 proposed by IPython. But there is a twist now: you can
664 proposed by IPython. But there is a twist now: you can
660 add/subtract only *one or two spaces*. If you add/subtract three
665 add/subtract only *one or two spaces*. If you add/subtract three
661 or more (unless you completely delete the line), IPython will
666 or more (unless you completely delete the line), IPython will
662 accept that line, and you'll need to enter a second one of pure
667 accept that line, and you'll need to enter a second one of pure
663 whitespace. I know it sounds complicated, but I can't find a
668 whitespace. I know it sounds complicated, but I can't find a
664 different solution that covers all the cases, with the right
669 different solution that covers all the cases, with the right
665 heuristics. Hopefully in actual use, nobody will really notice
670 heuristics. Hopefully in actual use, nobody will really notice
666 all these strange rules and things will 'just work'.
671 all these strange rules and things will 'just work'.
667
672
668 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
673 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
669
674
670 * IPython/iplib.py (interact): catch exceptions which can be
675 * IPython/iplib.py (interact): catch exceptions which can be
671 triggered asynchronously by signal handlers. Thanks to an
676 triggered asynchronously by signal handlers. Thanks to an
672 automatic crash report, submitted by Colin Kingsley
677 automatic crash report, submitted by Colin Kingsley
673 <tercel-AT-gentoo.org>.
678 <tercel-AT-gentoo.org>.
674
679
675 2006-01-20 Ville Vainio <vivainio@gmail.com>
680 2006-01-20 Ville Vainio <vivainio@gmail.com>
676
681
677 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
682 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
678 (%rehashdir, very useful, try it out) of how to extend ipython
683 (%rehashdir, very useful, try it out) of how to extend ipython
679 with new magics. Also added Extensions dir to pythonpath to make
684 with new magics. Also added Extensions dir to pythonpath to make
680 importing extensions easy.
685 importing extensions easy.
681
686
682 * %store now complains when trying to store interactively declared
687 * %store now complains when trying to store interactively declared
683 classes / instances of those classes.
688 classes / instances of those classes.
684
689
685 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
690 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
686 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
691 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
687 if they exist, and ipy_user_conf.py with some defaults is created for
692 if they exist, and ipy_user_conf.py with some defaults is created for
688 the user.
693 the user.
689
694
690 * Startup rehashing done by the config file, not InterpreterExec.
695 * Startup rehashing done by the config file, not InterpreterExec.
691 This means system commands are available even without selecting the
696 This means system commands are available even without selecting the
692 pysh profile. It's the sensible default after all.
697 pysh profile. It's the sensible default after all.
693
698
694 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
699 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
695
700
696 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
701 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
697 multiline code with autoindent on working. But I am really not
702 multiline code with autoindent on working. But I am really not
698 sure, so this needs more testing. Will commit a debug-enabled
703 sure, so this needs more testing. Will commit a debug-enabled
699 version for now, while I test it some more, so that Ville and
704 version for now, while I test it some more, so that Ville and
700 others may also catch any problems. Also made
705 others may also catch any problems. Also made
701 self.indent_current_str() a method, to ensure that there's no
706 self.indent_current_str() a method, to ensure that there's no
702 chance of the indent space count and the corresponding string
707 chance of the indent space count and the corresponding string
703 falling out of sync. All code needing the string should just call
708 falling out of sync. All code needing the string should just call
704 the method.
709 the method.
705
710
706 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
711 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
707
712
708 * IPython/Magic.py (magic_edit): fix check for when users don't
713 * IPython/Magic.py (magic_edit): fix check for when users don't
709 save their output files, the try/except was in the wrong section.
714 save their output files, the try/except was in the wrong section.
710
715
711 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
716 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
712
717
713 * IPython/Magic.py (magic_run): fix __file__ global missing from
718 * IPython/Magic.py (magic_run): fix __file__ global missing from
714 script's namespace when executed via %run. After a report by
719 script's namespace when executed via %run. After a report by
715 Vivian.
720 Vivian.
716
721
717 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
722 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
718 when using python 2.4. The parent constructor changed in 2.4, and
723 when using python 2.4. The parent constructor changed in 2.4, and
719 we need to track it directly (we can't call it, as it messes up
724 we need to track it directly (we can't call it, as it messes up
720 readline and tab-completion inside our pdb would stop working).
725 readline and tab-completion inside our pdb would stop working).
721 After a bug report by R. Bernstein <rocky-AT-panix.com>.
726 After a bug report by R. Bernstein <rocky-AT-panix.com>.
722
727
723 2006-01-16 Ville Vainio <vivainio@gmail.com>
728 2006-01-16 Ville Vainio <vivainio@gmail.com>
724
729
725 * Ipython/magic.py: Reverted back to old %edit functionality
730 * Ipython/magic.py: Reverted back to old %edit functionality
726 that returns file contents on exit.
731 that returns file contents on exit.
727
732
728 * IPython/path.py: Added Jason Orendorff's "path" module to
733 * IPython/path.py: Added Jason Orendorff's "path" module to
729 IPython tree, http://www.jorendorff.com/articles/python/path/.
734 IPython tree, http://www.jorendorff.com/articles/python/path/.
730 You can get path objects conveniently through %sc, and !!, e.g.:
735 You can get path objects conveniently through %sc, and !!, e.g.:
731 sc files=ls
736 sc files=ls
732 for p in files.paths: # or files.p
737 for p in files.paths: # or files.p
733 print p,p.mtime
738 print p,p.mtime
734
739
735 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
740 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
736 now work again without considering the exclusion regexp -
741 now work again without considering the exclusion regexp -
737 hence, things like ',foo my/path' turn to 'foo("my/path")'
742 hence, things like ',foo my/path' turn to 'foo("my/path")'
738 instead of syntax error.
743 instead of syntax error.
739
744
740
745
741 2006-01-14 Ville Vainio <vivainio@gmail.com>
746 2006-01-14 Ville Vainio <vivainio@gmail.com>
742
747
743 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
748 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
744 ipapi decorators for python 2.4 users, options() provides access to rc
749 ipapi decorators for python 2.4 users, options() provides access to rc
745 data.
750 data.
746
751
747 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
752 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
748 as path separators (even on Linux ;-). Space character after
753 as path separators (even on Linux ;-). Space character after
749 backslash (as yielded by tab completer) is still space;
754 backslash (as yielded by tab completer) is still space;
750 "%cd long\ name" works as expected.
755 "%cd long\ name" works as expected.
751
756
752 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
757 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
753 as "chain of command", with priority. API stays the same,
758 as "chain of command", with priority. API stays the same,
754 TryNext exception raised by a hook function signals that
759 TryNext exception raised by a hook function signals that
755 current hook failed and next hook should try handling it, as
760 current hook failed and next hook should try handling it, as
756 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
761 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
757 requested configurable display hook, which is now implemented.
762 requested configurable display hook, which is now implemented.
758
763
759 2006-01-13 Ville Vainio <vivainio@gmail.com>
764 2006-01-13 Ville Vainio <vivainio@gmail.com>
760
765
761 * IPython/platutils*.py: platform specific utility functions,
766 * IPython/platutils*.py: platform specific utility functions,
762 so far only set_term_title is implemented (change terminal
767 so far only set_term_title is implemented (change terminal
763 label in windowing systems). %cd now changes the title to
768 label in windowing systems). %cd now changes the title to
764 current dir.
769 current dir.
765
770
766 * IPython/Release.py: Added myself to "authors" list,
771 * IPython/Release.py: Added myself to "authors" list,
767 had to create new files.
772 had to create new files.
768
773
769 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
774 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
770 shell escape; not a known bug but had potential to be one in the
775 shell escape; not a known bug but had potential to be one in the
771 future.
776 future.
772
777
773 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
778 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
774 extension API for IPython! See the module for usage example. Fix
779 extension API for IPython! See the module for usage example. Fix
775 OInspect for docstring-less magic functions.
780 OInspect for docstring-less magic functions.
776
781
777
782
778 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
783 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
779
784
780 * IPython/iplib.py (raw_input): temporarily deactivate all
785 * IPython/iplib.py (raw_input): temporarily deactivate all
781 attempts at allowing pasting of code with autoindent on. It
786 attempts at allowing pasting of code with autoindent on. It
782 introduced bugs (reported by Prabhu) and I can't seem to find a
787 introduced bugs (reported by Prabhu) and I can't seem to find a
783 robust combination which works in all cases. Will have to revisit
788 robust combination which works in all cases. Will have to revisit
784 later.
789 later.
785
790
786 * IPython/genutils.py: remove isspace() function. We've dropped
791 * IPython/genutils.py: remove isspace() function. We've dropped
787 2.2 compatibility, so it's OK to use the string method.
792 2.2 compatibility, so it's OK to use the string method.
788
793
789 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
794 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
790
795
791 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
796 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
792 matching what NOT to autocall on, to include all python binary
797 matching what NOT to autocall on, to include all python binary
793 operators (including things like 'and', 'or', 'is' and 'in').
798 operators (including things like 'and', 'or', 'is' and 'in').
794 Prompted by a bug report on 'foo & bar', but I realized we had
799 Prompted by a bug report on 'foo & bar', but I realized we had
795 many more potential bug cases with other operators. The regexp is
800 many more potential bug cases with other operators. The regexp is
796 self.re_exclude_auto, it's fairly commented.
801 self.re_exclude_auto, it's fairly commented.
797
802
798 2006-01-12 Ville Vainio <vivainio@gmail.com>
803 2006-01-12 Ville Vainio <vivainio@gmail.com>
799
804
800 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
805 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
801 Prettified and hardened string/backslash quoting with ipsystem(),
806 Prettified and hardened string/backslash quoting with ipsystem(),
802 ipalias() and ipmagic(). Now even \ characters are passed to
807 ipalias() and ipmagic(). Now even \ characters are passed to
803 %magics, !shell escapes and aliases exactly as they are in the
808 %magics, !shell escapes and aliases exactly as they are in the
804 ipython command line. Should improve backslash experience,
809 ipython command line. Should improve backslash experience,
805 particularly in Windows (path delimiter for some commands that
810 particularly in Windows (path delimiter for some commands that
806 won't understand '/'), but Unix benefits as well (regexps). %cd
811 won't understand '/'), but Unix benefits as well (regexps). %cd
807 magic still doesn't support backslash path delimiters, though. Also
812 magic still doesn't support backslash path delimiters, though. Also
808 deleted all pretense of supporting multiline command strings in
813 deleted all pretense of supporting multiline command strings in
809 !system or %magic commands. Thanks to Jerry McRae for suggestions.
814 !system or %magic commands. Thanks to Jerry McRae for suggestions.
810
815
811 * doc/build_doc_instructions.txt added. Documentation on how to
816 * doc/build_doc_instructions.txt added. Documentation on how to
812 use doc/update_manual.py, added yesterday. Both files contributed
817 use doc/update_manual.py, added yesterday. Both files contributed
813 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
818 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
814 doc/*.sh for deprecation at a later date.
819 doc/*.sh for deprecation at a later date.
815
820
816 * /ipython.py Added ipython.py to root directory for
821 * /ipython.py Added ipython.py to root directory for
817 zero-installation (tar xzvf ipython.tgz; cd ipython; python
822 zero-installation (tar xzvf ipython.tgz; cd ipython; python
818 ipython.py) and development convenience (no need to keep doing
823 ipython.py) and development convenience (no need to keep doing
819 "setup.py install" between changes).
824 "setup.py install" between changes).
820
825
821 * Made ! and !! shell escapes work (again) in multiline expressions:
826 * Made ! and !! shell escapes work (again) in multiline expressions:
822 if 1:
827 if 1:
823 !ls
828 !ls
824 !!ls
829 !!ls
825
830
826 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
831 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
827
832
828 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
833 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
829 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
834 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
830 module in case-insensitive installation. Was causing crashes
835 module in case-insensitive installation. Was causing crashes
831 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
836 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
832
837
833 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
838 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
834 <marienz-AT-gentoo.org>, closes
839 <marienz-AT-gentoo.org>, closes
835 http://www.scipy.net/roundup/ipython/issue51.
840 http://www.scipy.net/roundup/ipython/issue51.
836
841
837 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
842 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
838
843
839 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
844 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
840 problem of excessive CPU usage under *nix and keyboard lag under
845 problem of excessive CPU usage under *nix and keyboard lag under
841 win32.
846 win32.
842
847
843 2006-01-10 *** Released version 0.7.0
848 2006-01-10 *** Released version 0.7.0
844
849
845 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
850 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
846
851
847 * IPython/Release.py (revision): tag version number to 0.7.0,
852 * IPython/Release.py (revision): tag version number to 0.7.0,
848 ready for release.
853 ready for release.
849
854
850 * IPython/Magic.py (magic_edit): Add print statement to %edit so
855 * IPython/Magic.py (magic_edit): Add print statement to %edit so
851 it informs the user of the name of the temp. file used. This can
856 it informs the user of the name of the temp. file used. This can
852 help if you decide later to reuse that same file, so you know
857 help if you decide later to reuse that same file, so you know
853 where to copy the info from.
858 where to copy the info from.
854
859
855 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
860 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
856
861
857 * setup_bdist_egg.py: little script to build an egg. Added
862 * setup_bdist_egg.py: little script to build an egg. Added
858 support in the release tools as well.
863 support in the release tools as well.
859
864
860 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
865 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
861
866
862 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
867 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
863 version selection (new -wxversion command line and ipythonrc
868 version selection (new -wxversion command line and ipythonrc
864 parameter). Patch contributed by Arnd Baecker
869 parameter). Patch contributed by Arnd Baecker
865 <arnd.baecker-AT-web.de>.
870 <arnd.baecker-AT-web.de>.
866
871
867 * IPython/iplib.py (embed_mainloop): fix tab-completion in
872 * IPython/iplib.py (embed_mainloop): fix tab-completion in
868 embedded instances, for variables defined at the interactive
873 embedded instances, for variables defined at the interactive
869 prompt of the embedded ipython. Reported by Arnd.
874 prompt of the embedded ipython. Reported by Arnd.
870
875
871 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
876 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
872 it can be used as a (stateful) toggle, or with a direct parameter.
877 it can be used as a (stateful) toggle, or with a direct parameter.
873
878
874 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
879 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
875 could be triggered in certain cases and cause the traceback
880 could be triggered in certain cases and cause the traceback
876 printer not to work.
881 printer not to work.
877
882
878 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
883 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
879
884
880 * IPython/iplib.py (_should_recompile): Small fix, closes
885 * IPython/iplib.py (_should_recompile): Small fix, closes
881 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
886 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
882
887
883 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
888 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
884
889
885 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
890 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
886 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
891 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
887 Moad for help with tracking it down.
892 Moad for help with tracking it down.
888
893
889 * IPython/iplib.py (handle_auto): fix autocall handling for
894 * IPython/iplib.py (handle_auto): fix autocall handling for
890 objects which support BOTH __getitem__ and __call__ (so that f [x]
895 objects which support BOTH __getitem__ and __call__ (so that f [x]
891 is left alone, instead of becoming f([x]) automatically).
896 is left alone, instead of becoming f([x]) automatically).
892
897
893 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
898 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
894 Ville's patch.
899 Ville's patch.
895
900
896 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
901 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
897
902
898 * IPython/iplib.py (handle_auto): changed autocall semantics to
903 * IPython/iplib.py (handle_auto): changed autocall semantics to
899 include 'smart' mode, where the autocall transformation is NOT
904 include 'smart' mode, where the autocall transformation is NOT
900 applied if there are no arguments on the line. This allows you to
905 applied if there are no arguments on the line. This allows you to
901 just type 'foo' if foo is a callable to see its internal form,
906 just type 'foo' if foo is a callable to see its internal form,
902 instead of having it called with no arguments (typically a
907 instead of having it called with no arguments (typically a
903 mistake). The old 'full' autocall still exists: for that, you
908 mistake). The old 'full' autocall still exists: for that, you
904 need to set the 'autocall' parameter to 2 in your ipythonrc file.
909 need to set the 'autocall' parameter to 2 in your ipythonrc file.
905
910
906 * IPython/completer.py (Completer.attr_matches): add
911 * IPython/completer.py (Completer.attr_matches): add
907 tab-completion support for Enthoughts' traits. After a report by
912 tab-completion support for Enthoughts' traits. After a report by
908 Arnd and a patch by Prabhu.
913 Arnd and a patch by Prabhu.
909
914
910 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
915 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
911
916
912 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
917 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
913 Schmolck's patch to fix inspect.getinnerframes().
918 Schmolck's patch to fix inspect.getinnerframes().
914
919
915 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
920 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
916 for embedded instances, regarding handling of namespaces and items
921 for embedded instances, regarding handling of namespaces and items
917 added to the __builtin__ one. Multiple embedded instances and
922 added to the __builtin__ one. Multiple embedded instances and
918 recursive embeddings should work better now (though I'm not sure
923 recursive embeddings should work better now (though I'm not sure
919 I've got all the corner cases fixed, that code is a bit of a brain
924 I've got all the corner cases fixed, that code is a bit of a brain
920 twister).
925 twister).
921
926
922 * IPython/Magic.py (magic_edit): added support to edit in-memory
927 * IPython/Magic.py (magic_edit): added support to edit in-memory
923 macros (automatically creates the necessary temp files). %edit
928 macros (automatically creates the necessary temp files). %edit
924 also doesn't return the file contents anymore, it's just noise.
929 also doesn't return the file contents anymore, it's just noise.
925
930
926 * IPython/completer.py (Completer.attr_matches): revert change to
931 * IPython/completer.py (Completer.attr_matches): revert change to
927 complete only on attributes listed in __all__. I realized it
932 complete only on attributes listed in __all__. I realized it
928 cripples the tab-completion system as a tool for exploring the
933 cripples the tab-completion system as a tool for exploring the
929 internals of unknown libraries (it renders any non-__all__
934 internals of unknown libraries (it renders any non-__all__
930 attribute off-limits). I got bit by this when trying to see
935 attribute off-limits). I got bit by this when trying to see
931 something inside the dis module.
936 something inside the dis module.
932
937
933 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
938 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
934
939
935 * IPython/iplib.py (InteractiveShell.__init__): add .meta
940 * IPython/iplib.py (InteractiveShell.__init__): add .meta
936 namespace for users and extension writers to hold data in. This
941 namespace for users and extension writers to hold data in. This
937 follows the discussion in
942 follows the discussion in
938 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
943 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
939
944
940 * IPython/completer.py (IPCompleter.complete): small patch to help
945 * IPython/completer.py (IPCompleter.complete): small patch to help
941 tab-completion under Emacs, after a suggestion by John Barnard
946 tab-completion under Emacs, after a suggestion by John Barnard
942 <barnarj-AT-ccf.org>.
947 <barnarj-AT-ccf.org>.
943
948
944 * IPython/Magic.py (Magic.extract_input_slices): added support for
949 * IPython/Magic.py (Magic.extract_input_slices): added support for
945 the slice notation in magics to use N-M to represent numbers N...M
950 the slice notation in magics to use N-M to represent numbers N...M
946 (closed endpoints). This is used by %macro and %save.
951 (closed endpoints). This is used by %macro and %save.
947
952
948 * IPython/completer.py (Completer.attr_matches): for modules which
953 * IPython/completer.py (Completer.attr_matches): for modules which
949 define __all__, complete only on those. After a patch by Jeffrey
954 define __all__, complete only on those. After a patch by Jeffrey
950 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
955 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
951 speed up this routine.
956 speed up this routine.
952
957
953 * IPython/Logger.py (Logger.log): fix a history handling bug. I
958 * IPython/Logger.py (Logger.log): fix a history handling bug. I
954 don't know if this is the end of it, but the behavior now is
959 don't know if this is the end of it, but the behavior now is
955 certainly much more correct. Note that coupled with macros,
960 certainly much more correct. Note that coupled with macros,
956 slightly surprising (at first) behavior may occur: a macro will in
961 slightly surprising (at first) behavior may occur: a macro will in
957 general expand to multiple lines of input, so upon exiting, the
962 general expand to multiple lines of input, so upon exiting, the
958 in/out counters will both be bumped by the corresponding amount
963 in/out counters will both be bumped by the corresponding amount
959 (as if the macro's contents had been typed interactively). Typing
964 (as if the macro's contents had been typed interactively). Typing
960 %hist will reveal the intermediate (silently processed) lines.
965 %hist will reveal the intermediate (silently processed) lines.
961
966
962 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
967 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
963 pickle to fail (%run was overwriting __main__ and not restoring
968 pickle to fail (%run was overwriting __main__ and not restoring
964 it, but pickle relies on __main__ to operate).
969 it, but pickle relies on __main__ to operate).
965
970
966 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
971 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
967 using properties, but forgot to make the main InteractiveShell
972 using properties, but forgot to make the main InteractiveShell
968 class a new-style class. Properties fail silently, and
973 class a new-style class. Properties fail silently, and
969 mysteriously, with old-style class (getters work, but
974 mysteriously, with old-style class (getters work, but
970 setters don't do anything).
975 setters don't do anything).
971
976
972 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
977 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
973
978
974 * IPython/Magic.py (magic_history): fix history reporting bug (I
979 * IPython/Magic.py (magic_history): fix history reporting bug (I
975 know some nasties are still there, I just can't seem to find a
980 know some nasties are still there, I just can't seem to find a
976 reproducible test case to track them down; the input history is
981 reproducible test case to track them down; the input history is
977 falling out of sync...)
982 falling out of sync...)
978
983
979 * IPython/iplib.py (handle_shell_escape): fix bug where both
984 * IPython/iplib.py (handle_shell_escape): fix bug where both
980 aliases and system accesses where broken for indented code (such
985 aliases and system accesses where broken for indented code (such
981 as loops).
986 as loops).
982
987
983 * IPython/genutils.py (shell): fix small but critical bug for
988 * IPython/genutils.py (shell): fix small but critical bug for
984 win32 system access.
989 win32 system access.
985
990
986 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
991 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
987
992
988 * IPython/iplib.py (showtraceback): remove use of the
993 * IPython/iplib.py (showtraceback): remove use of the
989 sys.last_{type/value/traceback} structures, which are non
994 sys.last_{type/value/traceback} structures, which are non
990 thread-safe.
995 thread-safe.
991 (_prefilter): change control flow to ensure that we NEVER
996 (_prefilter): change control flow to ensure that we NEVER
992 introspect objects when autocall is off. This will guarantee that
997 introspect objects when autocall is off. This will guarantee that
993 having an input line of the form 'x.y', where access to attribute
998 having an input line of the form 'x.y', where access to attribute
994 'y' has side effects, doesn't trigger the side effect TWICE. It
999 'y' has side effects, doesn't trigger the side effect TWICE. It
995 is important to note that, with autocall on, these side effects
1000 is important to note that, with autocall on, these side effects
996 can still happen.
1001 can still happen.
997 (ipsystem): new builtin, to complete the ip{magic/alias/system}
1002 (ipsystem): new builtin, to complete the ip{magic/alias/system}
998 trio. IPython offers these three kinds of special calls which are
1003 trio. IPython offers these three kinds of special calls which are
999 not python code, and it's a good thing to have their call method
1004 not python code, and it's a good thing to have their call method
1000 be accessible as pure python functions (not just special syntax at
1005 be accessible as pure python functions (not just special syntax at
1001 the command line). It gives us a better internal implementation
1006 the command line). It gives us a better internal implementation
1002 structure, as well as exposing these for user scripting more
1007 structure, as well as exposing these for user scripting more
1003 cleanly.
1008 cleanly.
1004
1009
1005 * IPython/macro.py (Macro.__init__): moved macros to a standalone
1010 * IPython/macro.py (Macro.__init__): moved macros to a standalone
1006 file. Now that they'll be more likely to be used with the
1011 file. Now that they'll be more likely to be used with the
1007 persistance system (%store), I want to make sure their module path
1012 persistance system (%store), I want to make sure their module path
1008 doesn't change in the future, so that we don't break things for
1013 doesn't change in the future, so that we don't break things for
1009 users' persisted data.
1014 users' persisted data.
1010
1015
1011 * IPython/iplib.py (autoindent_update): move indentation
1016 * IPython/iplib.py (autoindent_update): move indentation
1012 management into the _text_ processing loop, not the keyboard
1017 management into the _text_ processing loop, not the keyboard
1013 interactive one. This is necessary to correctly process non-typed
1018 interactive one. This is necessary to correctly process non-typed
1014 multiline input (such as macros).
1019 multiline input (such as macros).
1015
1020
1016 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
1021 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
1017 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
1022 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
1018 which was producing problems in the resulting manual.
1023 which was producing problems in the resulting manual.
1019 (magic_whos): improve reporting of instances (show their class,
1024 (magic_whos): improve reporting of instances (show their class,
1020 instead of simply printing 'instance' which isn't terribly
1025 instead of simply printing 'instance' which isn't terribly
1021 informative).
1026 informative).
1022
1027
1023 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
1028 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
1024 (minor mods) to support network shares under win32.
1029 (minor mods) to support network shares under win32.
1025
1030
1026 * IPython/winconsole.py (get_console_size): add new winconsole
1031 * IPython/winconsole.py (get_console_size): add new winconsole
1027 module and fixes to page_dumb() to improve its behavior under
1032 module and fixes to page_dumb() to improve its behavior under
1028 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
1033 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
1029
1034
1030 * IPython/Magic.py (Macro): simplified Macro class to just
1035 * IPython/Magic.py (Macro): simplified Macro class to just
1031 subclass list. We've had only 2.2 compatibility for a very long
1036 subclass list. We've had only 2.2 compatibility for a very long
1032 time, yet I was still avoiding subclassing the builtin types. No
1037 time, yet I was still avoiding subclassing the builtin types. No
1033 more (I'm also starting to use properties, though I won't shift to
1038 more (I'm also starting to use properties, though I won't shift to
1034 2.3-specific features quite yet).
1039 2.3-specific features quite yet).
1035 (magic_store): added Ville's patch for lightweight variable
1040 (magic_store): added Ville's patch for lightweight variable
1036 persistence, after a request on the user list by Matt Wilkie
1041 persistence, after a request on the user list by Matt Wilkie
1037 <maphew-AT-gmail.com>. The new %store magic's docstring has full
1042 <maphew-AT-gmail.com>. The new %store magic's docstring has full
1038 details.
1043 details.
1039
1044
1040 * IPython/iplib.py (InteractiveShell.post_config_initialization):
1045 * IPython/iplib.py (InteractiveShell.post_config_initialization):
1041 changed the default logfile name from 'ipython.log' to
1046 changed the default logfile name from 'ipython.log' to
1042 'ipython_log.py'. These logs are real python files, and now that
1047 'ipython_log.py'. These logs are real python files, and now that
1043 we have much better multiline support, people are more likely to
1048 we have much better multiline support, people are more likely to
1044 want to use them as such. Might as well name them correctly.
1049 want to use them as such. Might as well name them correctly.
1045
1050
1046 * IPython/Magic.py: substantial cleanup. While we can't stop
1051 * IPython/Magic.py: substantial cleanup. While we can't stop
1047 using magics as mixins, due to the existing customizations 'out
1052 using magics as mixins, due to the existing customizations 'out
1048 there' which rely on the mixin naming conventions, at least I
1053 there' which rely on the mixin naming conventions, at least I
1049 cleaned out all cross-class name usage. So once we are OK with
1054 cleaned out all cross-class name usage. So once we are OK with
1050 breaking compatibility, the two systems can be separated.
1055 breaking compatibility, the two systems can be separated.
1051
1056
1052 * IPython/Logger.py: major cleanup. This one is NOT a mixin
1057 * IPython/Logger.py: major cleanup. This one is NOT a mixin
1053 anymore, and the class is a fair bit less hideous as well. New
1058 anymore, and the class is a fair bit less hideous as well. New
1054 features were also introduced: timestamping of input, and logging
1059 features were also introduced: timestamping of input, and logging
1055 of output results. These are user-visible with the -t and -o
1060 of output results. These are user-visible with the -t and -o
1056 options to %logstart. Closes
1061 options to %logstart. Closes
1057 http://www.scipy.net/roundup/ipython/issue11 and a request by
1062 http://www.scipy.net/roundup/ipython/issue11 and a request by
1058 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
1063 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
1059
1064
1060 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
1065 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
1061
1066
1062 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
1067 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
1063 better handle backslashes in paths. See the thread 'More Windows
1068 better handle backslashes in paths. See the thread 'More Windows
1064 questions part 2 - \/ characters revisited' on the iypthon user
1069 questions part 2 - \/ characters revisited' on the iypthon user
1065 list:
1070 list:
1066 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
1071 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
1067
1072
1068 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
1073 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
1069
1074
1070 (InteractiveShell.__init__): change threaded shells to not use the
1075 (InteractiveShell.__init__): change threaded shells to not use the
1071 ipython crash handler. This was causing more problems than not,
1076 ipython crash handler. This was causing more problems than not,
1072 as exceptions in the main thread (GUI code, typically) would
1077 as exceptions in the main thread (GUI code, typically) would
1073 always show up as a 'crash', when they really weren't.
1078 always show up as a 'crash', when they really weren't.
1074
1079
1075 The colors and exception mode commands (%colors/%xmode) have been
1080 The colors and exception mode commands (%colors/%xmode) have been
1076 synchronized to also take this into account, so users can get
1081 synchronized to also take this into account, so users can get
1077 verbose exceptions for their threaded code as well. I also added
1082 verbose exceptions for their threaded code as well. I also added
1078 support for activating pdb inside this exception handler as well,
1083 support for activating pdb inside this exception handler as well,
1079 so now GUI authors can use IPython's enhanced pdb at runtime.
1084 so now GUI authors can use IPython's enhanced pdb at runtime.
1080
1085
1081 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
1086 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
1082 true by default, and add it to the shipped ipythonrc file. Since
1087 true by default, and add it to the shipped ipythonrc file. Since
1083 this asks the user before proceeding, I think it's OK to make it
1088 this asks the user before proceeding, I think it's OK to make it
1084 true by default.
1089 true by default.
1085
1090
1086 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
1091 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
1087 of the previous special-casing of input in the eval loop. I think
1092 of the previous special-casing of input in the eval loop. I think
1088 this is cleaner, as they really are commands and shouldn't have
1093 this is cleaner, as they really are commands and shouldn't have
1089 a special role in the middle of the core code.
1094 a special role in the middle of the core code.
1090
1095
1091 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
1096 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
1092
1097
1093 * IPython/iplib.py (edit_syntax_error): added support for
1098 * IPython/iplib.py (edit_syntax_error): added support for
1094 automatically reopening the editor if the file had a syntax error
1099 automatically reopening the editor if the file had a syntax error
1095 in it. Thanks to scottt who provided the patch at:
1100 in it. Thanks to scottt who provided the patch at:
1096 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
1101 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
1097 version committed).
1102 version committed).
1098
1103
1099 * IPython/iplib.py (handle_normal): add suport for multi-line
1104 * IPython/iplib.py (handle_normal): add suport for multi-line
1100 input with emtpy lines. This fixes
1105 input with emtpy lines. This fixes
1101 http://www.scipy.net/roundup/ipython/issue43 and a similar
1106 http://www.scipy.net/roundup/ipython/issue43 and a similar
1102 discussion on the user list.
1107 discussion on the user list.
1103
1108
1104 WARNING: a behavior change is necessarily introduced to support
1109 WARNING: a behavior change is necessarily introduced to support
1105 blank lines: now a single blank line with whitespace does NOT
1110 blank lines: now a single blank line with whitespace does NOT
1106 break the input loop, which means that when autoindent is on, by
1111 break the input loop, which means that when autoindent is on, by
1107 default hitting return on the next (indented) line does NOT exit.
1112 default hitting return on the next (indented) line does NOT exit.
1108
1113
1109 Instead, to exit a multiline input you can either have:
1114 Instead, to exit a multiline input you can either have:
1110
1115
1111 - TWO whitespace lines (just hit return again), or
1116 - TWO whitespace lines (just hit return again), or
1112 - a single whitespace line of a different length than provided
1117 - a single whitespace line of a different length than provided
1113 by the autoindent (add or remove a space).
1118 by the autoindent (add or remove a space).
1114
1119
1115 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
1120 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
1116 module to better organize all readline-related functionality.
1121 module to better organize all readline-related functionality.
1117 I've deleted FlexCompleter and put all completion clases here.
1122 I've deleted FlexCompleter and put all completion clases here.
1118
1123
1119 * IPython/iplib.py (raw_input): improve indentation management.
1124 * IPython/iplib.py (raw_input): improve indentation management.
1120 It is now possible to paste indented code with autoindent on, and
1125 It is now possible to paste indented code with autoindent on, and
1121 the code is interpreted correctly (though it still looks bad on
1126 the code is interpreted correctly (though it still looks bad on
1122 screen, due to the line-oriented nature of ipython).
1127 screen, due to the line-oriented nature of ipython).
1123 (MagicCompleter.complete): change behavior so that a TAB key on an
1128 (MagicCompleter.complete): change behavior so that a TAB key on an
1124 otherwise empty line actually inserts a tab, instead of completing
1129 otherwise empty line actually inserts a tab, instead of completing
1125 on the entire global namespace. This makes it easier to use the
1130 on the entire global namespace. This makes it easier to use the
1126 TAB key for indentation. After a request by Hans Meine
1131 TAB key for indentation. After a request by Hans Meine
1127 <hans_meine-AT-gmx.net>
1132 <hans_meine-AT-gmx.net>
1128 (_prefilter): add support so that typing plain 'exit' or 'quit'
1133 (_prefilter): add support so that typing plain 'exit' or 'quit'
1129 does a sensible thing. Originally I tried to deviate as little as
1134 does a sensible thing. Originally I tried to deviate as little as
1130 possible from the default python behavior, but even that one may
1135 possible from the default python behavior, but even that one may
1131 change in this direction (thread on python-dev to that effect).
1136 change in this direction (thread on python-dev to that effect).
1132 Regardless, ipython should do the right thing even if CPython's
1137 Regardless, ipython should do the right thing even if CPython's
1133 '>>>' prompt doesn't.
1138 '>>>' prompt doesn't.
1134 (InteractiveShell): removed subclassing code.InteractiveConsole
1139 (InteractiveShell): removed subclassing code.InteractiveConsole
1135 class. By now we'd overridden just about all of its methods: I've
1140 class. By now we'd overridden just about all of its methods: I've
1136 copied the remaining two over, and now ipython is a standalone
1141 copied the remaining two over, and now ipython is a standalone
1137 class. This will provide a clearer picture for the chainsaw
1142 class. This will provide a clearer picture for the chainsaw
1138 branch refactoring.
1143 branch refactoring.
1139
1144
1140 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
1145 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
1141
1146
1142 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
1147 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
1143 failures for objects which break when dir() is called on them.
1148 failures for objects which break when dir() is called on them.
1144
1149
1145 * IPython/FlexCompleter.py (Completer.__init__): Added support for
1150 * IPython/FlexCompleter.py (Completer.__init__): Added support for
1146 distinct local and global namespaces in the completer API. This
1151 distinct local and global namespaces in the completer API. This
1147 change allows us to properly handle completion with distinct
1152 change allows us to properly handle completion with distinct
1148 scopes, including in embedded instances (this had never really
1153 scopes, including in embedded instances (this had never really
1149 worked correctly).
1154 worked correctly).
1150
1155
1151 Note: this introduces a change in the constructor for
1156 Note: this introduces a change in the constructor for
1152 MagicCompleter, as a new global_namespace parameter is now the
1157 MagicCompleter, as a new global_namespace parameter is now the
1153 second argument (the others were bumped one position).
1158 second argument (the others were bumped one position).
1154
1159
1155 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
1160 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
1156
1161
1157 * IPython/iplib.py (embed_mainloop): fix tab-completion in
1162 * IPython/iplib.py (embed_mainloop): fix tab-completion in
1158 embedded instances (which can be done now thanks to Vivian's
1163 embedded instances (which can be done now thanks to Vivian's
1159 frame-handling fixes for pdb).
1164 frame-handling fixes for pdb).
1160 (InteractiveShell.__init__): Fix namespace handling problem in
1165 (InteractiveShell.__init__): Fix namespace handling problem in
1161 embedded instances. We were overwriting __main__ unconditionally,
1166 embedded instances. We were overwriting __main__ unconditionally,
1162 and this should only be done for 'full' (non-embedded) IPython;
1167 and this should only be done for 'full' (non-embedded) IPython;
1163 embedded instances must respect the caller's __main__. Thanks to
1168 embedded instances must respect the caller's __main__. Thanks to
1164 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
1169 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
1165
1170
1166 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
1171 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
1167
1172
1168 * setup.py: added download_url to setup(). This registers the
1173 * setup.py: added download_url to setup(). This registers the
1169 download address at PyPI, which is not only useful to humans
1174 download address at PyPI, which is not only useful to humans
1170 browsing the site, but is also picked up by setuptools (the Eggs
1175 browsing the site, but is also picked up by setuptools (the Eggs
1171 machinery). Thanks to Ville and R. Kern for the info/discussion
1176 machinery). Thanks to Ville and R. Kern for the info/discussion
1172 on this.
1177 on this.
1173
1178
1174 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
1179 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
1175
1180
1176 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
1181 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
1177 This brings a lot of nice functionality to the pdb mode, which now
1182 This brings a lot of nice functionality to the pdb mode, which now
1178 has tab-completion, syntax highlighting, and better stack handling
1183 has tab-completion, syntax highlighting, and better stack handling
1179 than before. Many thanks to Vivian De Smedt
1184 than before. Many thanks to Vivian De Smedt
1180 <vivian-AT-vdesmedt.com> for the original patches.
1185 <vivian-AT-vdesmedt.com> for the original patches.
1181
1186
1182 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
1187 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
1183
1188
1184 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
1189 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
1185 sequence to consistently accept the banner argument. The
1190 sequence to consistently accept the banner argument. The
1186 inconsistency was tripping SAGE, thanks to Gary Zablackis
1191 inconsistency was tripping SAGE, thanks to Gary Zablackis
1187 <gzabl-AT-yahoo.com> for the report.
1192 <gzabl-AT-yahoo.com> for the report.
1188
1193
1189 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
1194 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
1190
1195
1191 * IPython/iplib.py (InteractiveShell.post_config_initialization):
1196 * IPython/iplib.py (InteractiveShell.post_config_initialization):
1192 Fix bug where a naked 'alias' call in the ipythonrc file would
1197 Fix bug where a naked 'alias' call in the ipythonrc file would
1193 cause a crash. Bug reported by Jorgen Stenarson.
1198 cause a crash. Bug reported by Jorgen Stenarson.
1194
1199
1195 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
1200 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
1196
1201
1197 * IPython/ipmaker.py (make_IPython): cleanups which should improve
1202 * IPython/ipmaker.py (make_IPython): cleanups which should improve
1198 startup time.
1203 startup time.
1199
1204
1200 * IPython/iplib.py (runcode): my globals 'fix' for embedded
1205 * IPython/iplib.py (runcode): my globals 'fix' for embedded
1201 instances had introduced a bug with globals in normal code. Now
1206 instances had introduced a bug with globals in normal code. Now
1202 it's working in all cases.
1207 it's working in all cases.
1203
1208
1204 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
1209 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
1205 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
1210 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
1206 has been introduced to set the default case sensitivity of the
1211 has been introduced to set the default case sensitivity of the
1207 searches. Users can still select either mode at runtime on a
1212 searches. Users can still select either mode at runtime on a
1208 per-search basis.
1213 per-search basis.
1209
1214
1210 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
1215 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
1211
1216
1212 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
1217 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
1213 attributes in wildcard searches for subclasses. Modified version
1218 attributes in wildcard searches for subclasses. Modified version
1214 of a patch by Jorgen.
1219 of a patch by Jorgen.
1215
1220
1216 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
1221 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
1217
1222
1218 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
1223 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
1219 embedded instances. I added a user_global_ns attribute to the
1224 embedded instances. I added a user_global_ns attribute to the
1220 InteractiveShell class to handle this.
1225 InteractiveShell class to handle this.
1221
1226
1222 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
1227 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
1223
1228
1224 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
1229 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
1225 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
1230 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
1226 (reported under win32, but may happen also in other platforms).
1231 (reported under win32, but may happen also in other platforms).
1227 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
1232 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
1228
1233
1229 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
1234 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
1230
1235
1231 * IPython/Magic.py (magic_psearch): new support for wildcard
1236 * IPython/Magic.py (magic_psearch): new support for wildcard
1232 patterns. Now, typing ?a*b will list all names which begin with a
1237 patterns. Now, typing ?a*b will list all names which begin with a
1233 and end in b, for example. The %psearch magic has full
1238 and end in b, for example. The %psearch magic has full
1234 docstrings. Many thanks to JΓΆrgen Stenarson
1239 docstrings. Many thanks to JΓΆrgen Stenarson
1235 <jorgen.stenarson-AT-bostream.nu>, author of the patches
1240 <jorgen.stenarson-AT-bostream.nu>, author of the patches
1236 implementing this functionality.
1241 implementing this functionality.
1237
1242
1238 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1243 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1239
1244
1240 * Manual: fixed long-standing annoyance of double-dashes (as in
1245 * Manual: fixed long-standing annoyance of double-dashes (as in
1241 --prefix=~, for example) being stripped in the HTML version. This
1246 --prefix=~, for example) being stripped in the HTML version. This
1242 is a latex2html bug, but a workaround was provided. Many thanks
1247 is a latex2html bug, but a workaround was provided. Many thanks
1243 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
1248 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
1244 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
1249 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
1245 rolling. This seemingly small issue had tripped a number of users
1250 rolling. This seemingly small issue had tripped a number of users
1246 when first installing, so I'm glad to see it gone.
1251 when first installing, so I'm glad to see it gone.
1247
1252
1248 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1253 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1249
1254
1250 * IPython/Extensions/numeric_formats.py: fix missing import,
1255 * IPython/Extensions/numeric_formats.py: fix missing import,
1251 reported by Stephen Walton.
1256 reported by Stephen Walton.
1252
1257
1253 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
1258 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
1254
1259
1255 * IPython/demo.py: finish demo module, fully documented now.
1260 * IPython/demo.py: finish demo module, fully documented now.
1256
1261
1257 * IPython/genutils.py (file_read): simple little utility to read a
1262 * IPython/genutils.py (file_read): simple little utility to read a
1258 file and ensure it's closed afterwards.
1263 file and ensure it's closed afterwards.
1259
1264
1260 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
1265 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
1261
1266
1262 * IPython/demo.py (Demo.__init__): added support for individually
1267 * IPython/demo.py (Demo.__init__): added support for individually
1263 tagging blocks for automatic execution.
1268 tagging blocks for automatic execution.
1264
1269
1265 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
1270 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
1266 syntax-highlighted python sources, requested by John.
1271 syntax-highlighted python sources, requested by John.
1267
1272
1268 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
1273 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
1269
1274
1270 * IPython/demo.py (Demo.again): fix bug where again() blocks after
1275 * IPython/demo.py (Demo.again): fix bug where again() blocks after
1271 finishing.
1276 finishing.
1272
1277
1273 * IPython/genutils.py (shlex_split): moved from Magic to here,
1278 * IPython/genutils.py (shlex_split): moved from Magic to here,
1274 where all 2.2 compatibility stuff lives. I needed it for demo.py.
1279 where all 2.2 compatibility stuff lives. I needed it for demo.py.
1275
1280
1276 * IPython/demo.py (Demo.__init__): added support for silent
1281 * IPython/demo.py (Demo.__init__): added support for silent
1277 blocks, improved marks as regexps, docstrings written.
1282 blocks, improved marks as regexps, docstrings written.
1278 (Demo.__init__): better docstring, added support for sys.argv.
1283 (Demo.__init__): better docstring, added support for sys.argv.
1279
1284
1280 * IPython/genutils.py (marquee): little utility used by the demo
1285 * IPython/genutils.py (marquee): little utility used by the demo
1281 code, handy in general.
1286 code, handy in general.
1282
1287
1283 * IPython/demo.py (Demo.__init__): new class for interactive
1288 * IPython/demo.py (Demo.__init__): new class for interactive
1284 demos. Not documented yet, I just wrote it in a hurry for
1289 demos. Not documented yet, I just wrote it in a hurry for
1285 scipy'05. Will docstring later.
1290 scipy'05. Will docstring later.
1286
1291
1287 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
1292 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
1288
1293
1289 * IPython/Shell.py (sigint_handler): Drastic simplification which
1294 * IPython/Shell.py (sigint_handler): Drastic simplification which
1290 also seems to make Ctrl-C work correctly across threads! This is
1295 also seems to make Ctrl-C work correctly across threads! This is
1291 so simple, that I can't beleive I'd missed it before. Needs more
1296 so simple, that I can't beleive I'd missed it before. Needs more
1292 testing, though.
1297 testing, though.
1293 (KBINT): Never mind, revert changes. I'm sure I'd tried something
1298 (KBINT): Never mind, revert changes. I'm sure I'd tried something
1294 like this before...
1299 like this before...
1295
1300
1296 * IPython/genutils.py (get_home_dir): add protection against
1301 * IPython/genutils.py (get_home_dir): add protection against
1297 non-dirs in win32 registry.
1302 non-dirs in win32 registry.
1298
1303
1299 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
1304 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
1300 bug where dict was mutated while iterating (pysh crash).
1305 bug where dict was mutated while iterating (pysh crash).
1301
1306
1302 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
1307 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
1303
1308
1304 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
1309 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
1305 spurious newlines added by this routine. After a report by
1310 spurious newlines added by this routine. After a report by
1306 F. Mantegazza.
1311 F. Mantegazza.
1307
1312
1308 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
1313 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
1309
1314
1310 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
1315 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
1311 calls. These were a leftover from the GTK 1.x days, and can cause
1316 calls. These were a leftover from the GTK 1.x days, and can cause
1312 problems in certain cases (after a report by John Hunter).
1317 problems in certain cases (after a report by John Hunter).
1313
1318
1314 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
1319 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
1315 os.getcwd() fails at init time. Thanks to patch from David Remahl
1320 os.getcwd() fails at init time. Thanks to patch from David Remahl
1316 <chmod007-AT-mac.com>.
1321 <chmod007-AT-mac.com>.
1317 (InteractiveShell.__init__): prevent certain special magics from
1322 (InteractiveShell.__init__): prevent certain special magics from
1318 being shadowed by aliases. Closes
1323 being shadowed by aliases. Closes
1319 http://www.scipy.net/roundup/ipython/issue41.
1324 http://www.scipy.net/roundup/ipython/issue41.
1320
1325
1321 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
1326 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
1322
1327
1323 * IPython/iplib.py (InteractiveShell.complete): Added new
1328 * IPython/iplib.py (InteractiveShell.complete): Added new
1324 top-level completion method to expose the completion mechanism
1329 top-level completion method to expose the completion mechanism
1325 beyond readline-based environments.
1330 beyond readline-based environments.
1326
1331
1327 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
1332 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
1328
1333
1329 * tools/ipsvnc (svnversion): fix svnversion capture.
1334 * tools/ipsvnc (svnversion): fix svnversion capture.
1330
1335
1331 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
1336 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
1332 attribute to self, which was missing. Before, it was set by a
1337 attribute to self, which was missing. Before, it was set by a
1333 routine which in certain cases wasn't being called, so the
1338 routine which in certain cases wasn't being called, so the
1334 instance could end up missing the attribute. This caused a crash.
1339 instance could end up missing the attribute. This caused a crash.
1335 Closes http://www.scipy.net/roundup/ipython/issue40.
1340 Closes http://www.scipy.net/roundup/ipython/issue40.
1336
1341
1337 2005-08-16 Fernando Perez <fperez@colorado.edu>
1342 2005-08-16 Fernando Perez <fperez@colorado.edu>
1338
1343
1339 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
1344 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
1340 contains non-string attribute. Closes
1345 contains non-string attribute. Closes
1341 http://www.scipy.net/roundup/ipython/issue38.
1346 http://www.scipy.net/roundup/ipython/issue38.
1342
1347
1343 2005-08-14 Fernando Perez <fperez@colorado.edu>
1348 2005-08-14 Fernando Perez <fperez@colorado.edu>
1344
1349
1345 * tools/ipsvnc: Minor improvements, to add changeset info.
1350 * tools/ipsvnc: Minor improvements, to add changeset info.
1346
1351
1347 2005-08-12 Fernando Perez <fperez@colorado.edu>
1352 2005-08-12 Fernando Perez <fperez@colorado.edu>
1348
1353
1349 * IPython/iplib.py (runsource): remove self.code_to_run_src
1354 * IPython/iplib.py (runsource): remove self.code_to_run_src
1350 attribute. I realized this is nothing more than
1355 attribute. I realized this is nothing more than
1351 '\n'.join(self.buffer), and having the same data in two different
1356 '\n'.join(self.buffer), and having the same data in two different
1352 places is just asking for synchronization bugs. This may impact
1357 places is just asking for synchronization bugs. This may impact
1353 people who have custom exception handlers, so I need to warn
1358 people who have custom exception handlers, so I need to warn
1354 ipython-dev about it (F. Mantegazza may use them).
1359 ipython-dev about it (F. Mantegazza may use them).
1355
1360
1356 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
1361 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
1357
1362
1358 * IPython/genutils.py: fix 2.2 compatibility (generators)
1363 * IPython/genutils.py: fix 2.2 compatibility (generators)
1359
1364
1360 2005-07-18 Fernando Perez <fperez@colorado.edu>
1365 2005-07-18 Fernando Perez <fperez@colorado.edu>
1361
1366
1362 * IPython/genutils.py (get_home_dir): fix to help users with
1367 * IPython/genutils.py (get_home_dir): fix to help users with
1363 invalid $HOME under win32.
1368 invalid $HOME under win32.
1364
1369
1365 2005-07-17 Fernando Perez <fperez@colorado.edu>
1370 2005-07-17 Fernando Perez <fperez@colorado.edu>
1366
1371
1367 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
1372 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
1368 some old hacks and clean up a bit other routines; code should be
1373 some old hacks and clean up a bit other routines; code should be
1369 simpler and a bit faster.
1374 simpler and a bit faster.
1370
1375
1371 * IPython/iplib.py (interact): removed some last-resort attempts
1376 * IPython/iplib.py (interact): removed some last-resort attempts
1372 to survive broken stdout/stderr. That code was only making it
1377 to survive broken stdout/stderr. That code was only making it
1373 harder to abstract out the i/o (necessary for gui integration),
1378 harder to abstract out the i/o (necessary for gui integration),
1374 and the crashes it could prevent were extremely rare in practice
1379 and the crashes it could prevent were extremely rare in practice
1375 (besides being fully user-induced in a pretty violent manner).
1380 (besides being fully user-induced in a pretty violent manner).
1376
1381
1377 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
1382 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
1378 Nothing major yet, but the code is simpler to read; this should
1383 Nothing major yet, but the code is simpler to read; this should
1379 make it easier to do more serious modifications in the future.
1384 make it easier to do more serious modifications in the future.
1380
1385
1381 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
1386 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
1382 which broke in .15 (thanks to a report by Ville).
1387 which broke in .15 (thanks to a report by Ville).
1383
1388
1384 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
1389 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
1385 be quite correct, I know next to nothing about unicode). This
1390 be quite correct, I know next to nothing about unicode). This
1386 will allow unicode strings to be used in prompts, amongst other
1391 will allow unicode strings to be used in prompts, amongst other
1387 cases. It also will prevent ipython from crashing when unicode
1392 cases. It also will prevent ipython from crashing when unicode
1388 shows up unexpectedly in many places. If ascii encoding fails, we
1393 shows up unexpectedly in many places. If ascii encoding fails, we
1389 assume utf_8. Currently the encoding is not a user-visible
1394 assume utf_8. Currently the encoding is not a user-visible
1390 setting, though it could be made so if there is demand for it.
1395 setting, though it could be made so if there is demand for it.
1391
1396
1392 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
1397 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
1393
1398
1394 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
1399 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
1395
1400
1396 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
1401 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
1397
1402
1398 * IPython/genutils.py: Add 2.2 compatibility here, so all other
1403 * IPython/genutils.py: Add 2.2 compatibility here, so all other
1399 code can work transparently for 2.2/2.3.
1404 code can work transparently for 2.2/2.3.
1400
1405
1401 2005-07-16 Fernando Perez <fperez@colorado.edu>
1406 2005-07-16 Fernando Perez <fperez@colorado.edu>
1402
1407
1403 * IPython/ultraTB.py (ExceptionColors): Make a global variable
1408 * IPython/ultraTB.py (ExceptionColors): Make a global variable
1404 out of the color scheme table used for coloring exception
1409 out of the color scheme table used for coloring exception
1405 tracebacks. This allows user code to add new schemes at runtime.
1410 tracebacks. This allows user code to add new schemes at runtime.
1406 This is a minimally modified version of the patch at
1411 This is a minimally modified version of the patch at
1407 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
1412 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
1408 for the contribution.
1413 for the contribution.
1409
1414
1410 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
1415 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
1411 slightly modified version of the patch in
1416 slightly modified version of the patch in
1412 http://www.scipy.net/roundup/ipython/issue34, which also allows me
1417 http://www.scipy.net/roundup/ipython/issue34, which also allows me
1413 to remove the previous try/except solution (which was costlier).
1418 to remove the previous try/except solution (which was costlier).
1414 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
1419 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
1415
1420
1416 2005-06-08 Fernando Perez <fperez@colorado.edu>
1421 2005-06-08 Fernando Perez <fperez@colorado.edu>
1417
1422
1418 * IPython/iplib.py (write/write_err): Add methods to abstract all
1423 * IPython/iplib.py (write/write_err): Add methods to abstract all
1419 I/O a bit more.
1424 I/O a bit more.
1420
1425
1421 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
1426 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
1422 warning, reported by Aric Hagberg, fix by JD Hunter.
1427 warning, reported by Aric Hagberg, fix by JD Hunter.
1423
1428
1424 2005-06-02 *** Released version 0.6.15
1429 2005-06-02 *** Released version 0.6.15
1425
1430
1426 2005-06-01 Fernando Perez <fperez@colorado.edu>
1431 2005-06-01 Fernando Perez <fperez@colorado.edu>
1427
1432
1428 * IPython/iplib.py (MagicCompleter.file_matches): Fix
1433 * IPython/iplib.py (MagicCompleter.file_matches): Fix
1429 tab-completion of filenames within open-quoted strings. Note that
1434 tab-completion of filenames within open-quoted strings. Note that
1430 this requires that in ~/.ipython/ipythonrc, users change the
1435 this requires that in ~/.ipython/ipythonrc, users change the
1431 readline delimiters configuration to read:
1436 readline delimiters configuration to read:
1432
1437
1433 readline_remove_delims -/~
1438 readline_remove_delims -/~
1434
1439
1435
1440
1436 2005-05-31 *** Released version 0.6.14
1441 2005-05-31 *** Released version 0.6.14
1437
1442
1438 2005-05-29 Fernando Perez <fperez@colorado.edu>
1443 2005-05-29 Fernando Perez <fperez@colorado.edu>
1439
1444
1440 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
1445 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
1441 with files not on the filesystem. Reported by Eliyahu Sandler
1446 with files not on the filesystem. Reported by Eliyahu Sandler
1442 <eli@gondolin.net>
1447 <eli@gondolin.net>
1443
1448
1444 2005-05-22 Fernando Perez <fperez@colorado.edu>
1449 2005-05-22 Fernando Perez <fperez@colorado.edu>
1445
1450
1446 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
1451 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
1447 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
1452 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
1448
1453
1449 2005-05-19 Fernando Perez <fperez@colorado.edu>
1454 2005-05-19 Fernando Perez <fperez@colorado.edu>
1450
1455
1451 * IPython/iplib.py (safe_execfile): close a file which could be
1456 * IPython/iplib.py (safe_execfile): close a file which could be
1452 left open (causing problems in win32, which locks open files).
1457 left open (causing problems in win32, which locks open files).
1453 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
1458 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
1454
1459
1455 2005-05-18 Fernando Perez <fperez@colorado.edu>
1460 2005-05-18 Fernando Perez <fperez@colorado.edu>
1456
1461
1457 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
1462 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
1458 keyword arguments correctly to safe_execfile().
1463 keyword arguments correctly to safe_execfile().
1459
1464
1460 2005-05-13 Fernando Perez <fperez@colorado.edu>
1465 2005-05-13 Fernando Perez <fperez@colorado.edu>
1461
1466
1462 * ipython.1: Added info about Qt to manpage, and threads warning
1467 * ipython.1: Added info about Qt to manpage, and threads warning
1463 to usage page (invoked with --help).
1468 to usage page (invoked with --help).
1464
1469
1465 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
1470 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
1466 new matcher (it goes at the end of the priority list) to do
1471 new matcher (it goes at the end of the priority list) to do
1467 tab-completion on named function arguments. Submitted by George
1472 tab-completion on named function arguments. Submitted by George
1468 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
1473 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
1469 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
1474 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
1470 for more details.
1475 for more details.
1471
1476
1472 * IPython/Magic.py (magic_run): Added new -e flag to ignore
1477 * IPython/Magic.py (magic_run): Added new -e flag to ignore
1473 SystemExit exceptions in the script being run. Thanks to a report
1478 SystemExit exceptions in the script being run. Thanks to a report
1474 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
1479 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
1475 producing very annoying behavior when running unit tests.
1480 producing very annoying behavior when running unit tests.
1476
1481
1477 2005-05-12 Fernando Perez <fperez@colorado.edu>
1482 2005-05-12 Fernando Perez <fperez@colorado.edu>
1478
1483
1479 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
1484 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
1480 which I'd broken (again) due to a changed regexp. In the process,
1485 which I'd broken (again) due to a changed regexp. In the process,
1481 added ';' as an escape to auto-quote the whole line without
1486 added ';' as an escape to auto-quote the whole line without
1482 splitting its arguments. Thanks to a report by Jerry McRae
1487 splitting its arguments. Thanks to a report by Jerry McRae
1483 <qrs0xyc02-AT-sneakemail.com>.
1488 <qrs0xyc02-AT-sneakemail.com>.
1484
1489
1485 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
1490 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
1486 possible crashes caused by a TokenError. Reported by Ed Schofield
1491 possible crashes caused by a TokenError. Reported by Ed Schofield
1487 <schofield-AT-ftw.at>.
1492 <schofield-AT-ftw.at>.
1488
1493
1489 2005-05-06 Fernando Perez <fperez@colorado.edu>
1494 2005-05-06 Fernando Perez <fperez@colorado.edu>
1490
1495
1491 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
1496 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
1492
1497
1493 2005-04-29 Fernando Perez <fperez@colorado.edu>
1498 2005-04-29 Fernando Perez <fperez@colorado.edu>
1494
1499
1495 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
1500 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
1496 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
1501 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
1497 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
1502 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
1498 which provides support for Qt interactive usage (similar to the
1503 which provides support for Qt interactive usage (similar to the
1499 existing one for WX and GTK). This had been often requested.
1504 existing one for WX and GTK). This had been often requested.
1500
1505
1501 2005-04-14 *** Released version 0.6.13
1506 2005-04-14 *** Released version 0.6.13
1502
1507
1503 2005-04-08 Fernando Perez <fperez@colorado.edu>
1508 2005-04-08 Fernando Perez <fperez@colorado.edu>
1504
1509
1505 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
1510 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
1506 from _ofind, which gets called on almost every input line. Now,
1511 from _ofind, which gets called on almost every input line. Now,
1507 we only try to get docstrings if they are actually going to be
1512 we only try to get docstrings if they are actually going to be
1508 used (the overhead of fetching unnecessary docstrings can be
1513 used (the overhead of fetching unnecessary docstrings can be
1509 noticeable for certain objects, such as Pyro proxies).
1514 noticeable for certain objects, such as Pyro proxies).
1510
1515
1511 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
1516 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
1512 for completers. For some reason I had been passing them the state
1517 for completers. For some reason I had been passing them the state
1513 variable, which completers never actually need, and was in
1518 variable, which completers never actually need, and was in
1514 conflict with the rlcompleter API. Custom completers ONLY need to
1519 conflict with the rlcompleter API. Custom completers ONLY need to
1515 take the text parameter.
1520 take the text parameter.
1516
1521
1517 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
1522 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
1518 work correctly in pysh. I've also moved all the logic which used
1523 work correctly in pysh. I've also moved all the logic which used
1519 to be in pysh.py here, which will prevent problems with future
1524 to be in pysh.py here, which will prevent problems with future
1520 upgrades. However, this time I must warn users to update their
1525 upgrades. However, this time I must warn users to update their
1521 pysh profile to include the line
1526 pysh profile to include the line
1522
1527
1523 import_all IPython.Extensions.InterpreterExec
1528 import_all IPython.Extensions.InterpreterExec
1524
1529
1525 because otherwise things won't work for them. They MUST also
1530 because otherwise things won't work for them. They MUST also
1526 delete pysh.py and the line
1531 delete pysh.py and the line
1527
1532
1528 execfile pysh.py
1533 execfile pysh.py
1529
1534
1530 from their ipythonrc-pysh.
1535 from their ipythonrc-pysh.
1531
1536
1532 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
1537 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
1533 robust in the face of objects whose dir() returns non-strings
1538 robust in the face of objects whose dir() returns non-strings
1534 (which it shouldn't, but some broken libs like ITK do). Thanks to
1539 (which it shouldn't, but some broken libs like ITK do). Thanks to
1535 a patch by John Hunter (implemented differently, though). Also
1540 a patch by John Hunter (implemented differently, though). Also
1536 minor improvements by using .extend instead of + on lists.
1541 minor improvements by using .extend instead of + on lists.
1537
1542
1538 * pysh.py:
1543 * pysh.py:
1539
1544
1540 2005-04-06 Fernando Perez <fperez@colorado.edu>
1545 2005-04-06 Fernando Perez <fperez@colorado.edu>
1541
1546
1542 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
1547 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
1543 by default, so that all users benefit from it. Those who don't
1548 by default, so that all users benefit from it. Those who don't
1544 want it can still turn it off.
1549 want it can still turn it off.
1545
1550
1546 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
1551 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
1547 config file, I'd forgotten about this, so users were getting it
1552 config file, I'd forgotten about this, so users were getting it
1548 off by default.
1553 off by default.
1549
1554
1550 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
1555 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
1551 consistency. Now magics can be called in multiline statements,
1556 consistency. Now magics can be called in multiline statements,
1552 and python variables can be expanded in magic calls via $var.
1557 and python variables can be expanded in magic calls via $var.
1553 This makes the magic system behave just like aliases or !system
1558 This makes the magic system behave just like aliases or !system
1554 calls.
1559 calls.
1555
1560
1556 2005-03-28 Fernando Perez <fperez@colorado.edu>
1561 2005-03-28 Fernando Perez <fperez@colorado.edu>
1557
1562
1558 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
1563 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
1559 expensive string additions for building command. Add support for
1564 expensive string additions for building command. Add support for
1560 trailing ';' when autocall is used.
1565 trailing ';' when autocall is used.
1561
1566
1562 2005-03-26 Fernando Perez <fperez@colorado.edu>
1567 2005-03-26 Fernando Perez <fperez@colorado.edu>
1563
1568
1564 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
1569 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
1565 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
1570 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
1566 ipython.el robust against prompts with any number of spaces
1571 ipython.el robust against prompts with any number of spaces
1567 (including 0) after the ':' character.
1572 (including 0) after the ':' character.
1568
1573
1569 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
1574 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
1570 continuation prompt, which misled users to think the line was
1575 continuation prompt, which misled users to think the line was
1571 already indented. Closes debian Bug#300847, reported to me by
1576 already indented. Closes debian Bug#300847, reported to me by
1572 Norbert Tretkowski <tretkowski-AT-inittab.de>.
1577 Norbert Tretkowski <tretkowski-AT-inittab.de>.
1573
1578
1574 2005-03-23 Fernando Perez <fperez@colorado.edu>
1579 2005-03-23 Fernando Perez <fperez@colorado.edu>
1575
1580
1576 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
1581 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
1577 properly aligned if they have embedded newlines.
1582 properly aligned if they have embedded newlines.
1578
1583
1579 * IPython/iplib.py (runlines): Add a public method to expose
1584 * IPython/iplib.py (runlines): Add a public method to expose
1580 IPython's code execution machinery, so that users can run strings
1585 IPython's code execution machinery, so that users can run strings
1581 as if they had been typed at the prompt interactively.
1586 as if they had been typed at the prompt interactively.
1582 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
1587 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
1583 methods which can call the system shell, but with python variable
1588 methods which can call the system shell, but with python variable
1584 expansion. The three such methods are: __IPYTHON__.system,
1589 expansion. The three such methods are: __IPYTHON__.system,
1585 .getoutput and .getoutputerror. These need to be documented in a
1590 .getoutput and .getoutputerror. These need to be documented in a
1586 'public API' section (to be written) of the manual.
1591 'public API' section (to be written) of the manual.
1587
1592
1588 2005-03-20 Fernando Perez <fperez@colorado.edu>
1593 2005-03-20 Fernando Perez <fperez@colorado.edu>
1589
1594
1590 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
1595 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
1591 for custom exception handling. This is quite powerful, and it
1596 for custom exception handling. This is quite powerful, and it
1592 allows for user-installable exception handlers which can trap
1597 allows for user-installable exception handlers which can trap
1593 custom exceptions at runtime and treat them separately from
1598 custom exceptions at runtime and treat them separately from
1594 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
1599 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
1595 Mantegazza <mantegazza-AT-ill.fr>.
1600 Mantegazza <mantegazza-AT-ill.fr>.
1596 (InteractiveShell.set_custom_completer): public API function to
1601 (InteractiveShell.set_custom_completer): public API function to
1597 add new completers at runtime.
1602 add new completers at runtime.
1598
1603
1599 2005-03-19 Fernando Perez <fperez@colorado.edu>
1604 2005-03-19 Fernando Perez <fperez@colorado.edu>
1600
1605
1601 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
1606 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
1602 allow objects which provide their docstrings via non-standard
1607 allow objects which provide their docstrings via non-standard
1603 mechanisms (like Pyro proxies) to still be inspected by ipython's
1608 mechanisms (like Pyro proxies) to still be inspected by ipython's
1604 ? system.
1609 ? system.
1605
1610
1606 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
1611 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
1607 automatic capture system. I tried quite hard to make it work
1612 automatic capture system. I tried quite hard to make it work
1608 reliably, and simply failed. I tried many combinations with the
1613 reliably, and simply failed. I tried many combinations with the
1609 subprocess module, but eventually nothing worked in all needed
1614 subprocess module, but eventually nothing worked in all needed
1610 cases (not blocking stdin for the child, duplicating stdout
1615 cases (not blocking stdin for the child, duplicating stdout
1611 without blocking, etc). The new %sc/%sx still do capture to these
1616 without blocking, etc). The new %sc/%sx still do capture to these
1612 magical list/string objects which make shell use much more
1617 magical list/string objects which make shell use much more
1613 conveninent, so not all is lost.
1618 conveninent, so not all is lost.
1614
1619
1615 XXX - FIX MANUAL for the change above!
1620 XXX - FIX MANUAL for the change above!
1616
1621
1617 (runsource): I copied code.py's runsource() into ipython to modify
1622 (runsource): I copied code.py's runsource() into ipython to modify
1618 it a bit. Now the code object and source to be executed are
1623 it a bit. Now the code object and source to be executed are
1619 stored in ipython. This makes this info accessible to third-party
1624 stored in ipython. This makes this info accessible to third-party
1620 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
1625 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
1621 Mantegazza <mantegazza-AT-ill.fr>.
1626 Mantegazza <mantegazza-AT-ill.fr>.
1622
1627
1623 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
1628 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
1624 history-search via readline (like C-p/C-n). I'd wanted this for a
1629 history-search via readline (like C-p/C-n). I'd wanted this for a
1625 long time, but only recently found out how to do it. For users
1630 long time, but only recently found out how to do it. For users
1626 who already have their ipythonrc files made and want this, just
1631 who already have their ipythonrc files made and want this, just
1627 add:
1632 add:
1628
1633
1629 readline_parse_and_bind "\e[A": history-search-backward
1634 readline_parse_and_bind "\e[A": history-search-backward
1630 readline_parse_and_bind "\e[B": history-search-forward
1635 readline_parse_and_bind "\e[B": history-search-forward
1631
1636
1632 2005-03-18 Fernando Perez <fperez@colorado.edu>
1637 2005-03-18 Fernando Perez <fperez@colorado.edu>
1633
1638
1634 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
1639 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
1635 LSString and SList classes which allow transparent conversions
1640 LSString and SList classes which allow transparent conversions
1636 between list mode and whitespace-separated string.
1641 between list mode and whitespace-separated string.
1637 (magic_r): Fix recursion problem in %r.
1642 (magic_r): Fix recursion problem in %r.
1638
1643
1639 * IPython/genutils.py (LSString): New class to be used for
1644 * IPython/genutils.py (LSString): New class to be used for
1640 automatic storage of the results of all alias/system calls in _o
1645 automatic storage of the results of all alias/system calls in _o
1641 and _e (stdout/err). These provide a .l/.list attribute which
1646 and _e (stdout/err). These provide a .l/.list attribute which
1642 does automatic splitting on newlines. This means that for most
1647 does automatic splitting on newlines. This means that for most
1643 uses, you'll never need to do capturing of output with %sc/%sx
1648 uses, you'll never need to do capturing of output with %sc/%sx
1644 anymore, since ipython keeps this always done for you. Note that
1649 anymore, since ipython keeps this always done for you. Note that
1645 only the LAST results are stored, the _o/e variables are
1650 only the LAST results are stored, the _o/e variables are
1646 overwritten on each call. If you need to save their contents
1651 overwritten on each call. If you need to save their contents
1647 further, simply bind them to any other name.
1652 further, simply bind them to any other name.
1648
1653
1649 2005-03-17 Fernando Perez <fperez@colorado.edu>
1654 2005-03-17 Fernando Perez <fperez@colorado.edu>
1650
1655
1651 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
1656 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
1652 prompt namespace handling.
1657 prompt namespace handling.
1653
1658
1654 2005-03-16 Fernando Perez <fperez@colorado.edu>
1659 2005-03-16 Fernando Perez <fperez@colorado.edu>
1655
1660
1656 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
1661 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
1657 classic prompts to be '>>> ' (final space was missing, and it
1662 classic prompts to be '>>> ' (final space was missing, and it
1658 trips the emacs python mode).
1663 trips the emacs python mode).
1659 (BasePrompt.__str__): Added safe support for dynamic prompt
1664 (BasePrompt.__str__): Added safe support for dynamic prompt
1660 strings. Now you can set your prompt string to be '$x', and the
1665 strings. Now you can set your prompt string to be '$x', and the
1661 value of x will be printed from your interactive namespace. The
1666 value of x will be printed from your interactive namespace. The
1662 interpolation syntax includes the full Itpl support, so
1667 interpolation syntax includes the full Itpl support, so
1663 ${foo()+x+bar()} is a valid prompt string now, and the function
1668 ${foo()+x+bar()} is a valid prompt string now, and the function
1664 calls will be made at runtime.
1669 calls will be made at runtime.
1665
1670
1666 2005-03-15 Fernando Perez <fperez@colorado.edu>
1671 2005-03-15 Fernando Perez <fperez@colorado.edu>
1667
1672
1668 * IPython/Magic.py (magic_history): renamed %hist to %history, to
1673 * IPython/Magic.py (magic_history): renamed %hist to %history, to
1669 avoid name clashes in pylab. %hist still works, it just forwards
1674 avoid name clashes in pylab. %hist still works, it just forwards
1670 the call to %history.
1675 the call to %history.
1671
1676
1672 2005-03-02 *** Released version 0.6.12
1677 2005-03-02 *** Released version 0.6.12
1673
1678
1674 2005-03-02 Fernando Perez <fperez@colorado.edu>
1679 2005-03-02 Fernando Perez <fperez@colorado.edu>
1675
1680
1676 * IPython/iplib.py (handle_magic): log magic calls properly as
1681 * IPython/iplib.py (handle_magic): log magic calls properly as
1677 ipmagic() function calls.
1682 ipmagic() function calls.
1678
1683
1679 * IPython/Magic.py (magic_time): Improved %time to support
1684 * IPython/Magic.py (magic_time): Improved %time to support
1680 statements and provide wall-clock as well as CPU time.
1685 statements and provide wall-clock as well as CPU time.
1681
1686
1682 2005-02-27 Fernando Perez <fperez@colorado.edu>
1687 2005-02-27 Fernando Perez <fperez@colorado.edu>
1683
1688
1684 * IPython/hooks.py: New hooks module, to expose user-modifiable
1689 * IPython/hooks.py: New hooks module, to expose user-modifiable
1685 IPython functionality in a clean manner. For now only the editor
1690 IPython functionality in a clean manner. For now only the editor
1686 hook is actually written, and other thigns which I intend to turn
1691 hook is actually written, and other thigns which I intend to turn
1687 into proper hooks aren't yet there. The display and prefilter
1692 into proper hooks aren't yet there. The display and prefilter
1688 stuff, for example, should be hooks. But at least now the
1693 stuff, for example, should be hooks. But at least now the
1689 framework is in place, and the rest can be moved here with more
1694 framework is in place, and the rest can be moved here with more
1690 time later. IPython had had a .hooks variable for a long time for
1695 time later. IPython had had a .hooks variable for a long time for
1691 this purpose, but I'd never actually used it for anything.
1696 this purpose, but I'd never actually used it for anything.
1692
1697
1693 2005-02-26 Fernando Perez <fperez@colorado.edu>
1698 2005-02-26 Fernando Perez <fperez@colorado.edu>
1694
1699
1695 * IPython/ipmaker.py (make_IPython): make the default ipython
1700 * IPython/ipmaker.py (make_IPython): make the default ipython
1696 directory be called _ipython under win32, to follow more the
1701 directory be called _ipython under win32, to follow more the
1697 naming peculiarities of that platform (where buggy software like
1702 naming peculiarities of that platform (where buggy software like
1698 Visual Sourcesafe breaks with .named directories). Reported by
1703 Visual Sourcesafe breaks with .named directories). Reported by
1699 Ville Vainio.
1704 Ville Vainio.
1700
1705
1701 2005-02-23 Fernando Perez <fperez@colorado.edu>
1706 2005-02-23 Fernando Perez <fperez@colorado.edu>
1702
1707
1703 * IPython/iplib.py (InteractiveShell.__init__): removed a few
1708 * IPython/iplib.py (InteractiveShell.__init__): removed a few
1704 auto_aliases for win32 which were causing problems. Users can
1709 auto_aliases for win32 which were causing problems. Users can
1705 define the ones they personally like.
1710 define the ones they personally like.
1706
1711
1707 2005-02-21 Fernando Perez <fperez@colorado.edu>
1712 2005-02-21 Fernando Perez <fperez@colorado.edu>
1708
1713
1709 * IPython/Magic.py (magic_time): new magic to time execution of
1714 * IPython/Magic.py (magic_time): new magic to time execution of
1710 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
1715 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
1711
1716
1712 2005-02-19 Fernando Perez <fperez@colorado.edu>
1717 2005-02-19 Fernando Perez <fperez@colorado.edu>
1713
1718
1714 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
1719 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
1715 into keys (for prompts, for example).
1720 into keys (for prompts, for example).
1716
1721
1717 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
1722 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
1718 prompts in case users want them. This introduces a small behavior
1723 prompts in case users want them. This introduces a small behavior
1719 change: ipython does not automatically add a space to all prompts
1724 change: ipython does not automatically add a space to all prompts
1720 anymore. To get the old prompts with a space, users should add it
1725 anymore. To get the old prompts with a space, users should add it
1721 manually to their ipythonrc file, so for example prompt_in1 should
1726 manually to their ipythonrc file, so for example prompt_in1 should
1722 now read 'In [\#]: ' instead of 'In [\#]:'.
1727 now read 'In [\#]: ' instead of 'In [\#]:'.
1723 (BasePrompt.__init__): New option prompts_pad_left (only in rc
1728 (BasePrompt.__init__): New option prompts_pad_left (only in rc
1724 file) to control left-padding of secondary prompts.
1729 file) to control left-padding of secondary prompts.
1725
1730
1726 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
1731 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
1727 the profiler can't be imported. Fix for Debian, which removed
1732 the profiler can't be imported. Fix for Debian, which removed
1728 profile.py because of License issues. I applied a slightly
1733 profile.py because of License issues. I applied a slightly
1729 modified version of the original Debian patch at
1734 modified version of the original Debian patch at
1730 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
1735 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
1731
1736
1732 2005-02-17 Fernando Perez <fperez@colorado.edu>
1737 2005-02-17 Fernando Perez <fperez@colorado.edu>
1733
1738
1734 * IPython/genutils.py (native_line_ends): Fix bug which would
1739 * IPython/genutils.py (native_line_ends): Fix bug which would
1735 cause improper line-ends under win32 b/c I was not opening files
1740 cause improper line-ends under win32 b/c I was not opening files
1736 in binary mode. Bug report and fix thanks to Ville.
1741 in binary mode. Bug report and fix thanks to Ville.
1737
1742
1738 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
1743 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
1739 trying to catch spurious foo[1] autocalls. My fix actually broke
1744 trying to catch spurious foo[1] autocalls. My fix actually broke
1740 ',/' autoquote/call with explicit escape (bad regexp).
1745 ',/' autoquote/call with explicit escape (bad regexp).
1741
1746
1742 2005-02-15 *** Released version 0.6.11
1747 2005-02-15 *** Released version 0.6.11
1743
1748
1744 2005-02-14 Fernando Perez <fperez@colorado.edu>
1749 2005-02-14 Fernando Perez <fperez@colorado.edu>
1745
1750
1746 * IPython/background_jobs.py: New background job management
1751 * IPython/background_jobs.py: New background job management
1747 subsystem. This is implemented via a new set of classes, and
1752 subsystem. This is implemented via a new set of classes, and
1748 IPython now provides a builtin 'jobs' object for background job
1753 IPython now provides a builtin 'jobs' object for background job
1749 execution. A convenience %bg magic serves as a lightweight
1754 execution. A convenience %bg magic serves as a lightweight
1750 frontend for starting the more common type of calls. This was
1755 frontend for starting the more common type of calls. This was
1751 inspired by discussions with B. Granger and the BackgroundCommand
1756 inspired by discussions with B. Granger and the BackgroundCommand
1752 class described in the book Python Scripting for Computational
1757 class described in the book Python Scripting for Computational
1753 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
1758 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
1754 (although ultimately no code from this text was used, as IPython's
1759 (although ultimately no code from this text was used, as IPython's
1755 system is a separate implementation).
1760 system is a separate implementation).
1756
1761
1757 * IPython/iplib.py (MagicCompleter.python_matches): add new option
1762 * IPython/iplib.py (MagicCompleter.python_matches): add new option
1758 to control the completion of single/double underscore names
1763 to control the completion of single/double underscore names
1759 separately. As documented in the example ipytonrc file, the
1764 separately. As documented in the example ipytonrc file, the
1760 readline_omit__names variable can now be set to 2, to omit even
1765 readline_omit__names variable can now be set to 2, to omit even
1761 single underscore names. Thanks to a patch by Brian Wong
1766 single underscore names. Thanks to a patch by Brian Wong
1762 <BrianWong-AT-AirgoNetworks.Com>.
1767 <BrianWong-AT-AirgoNetworks.Com>.
1763 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
1768 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
1764 be autocalled as foo([1]) if foo were callable. A problem for
1769 be autocalled as foo([1]) if foo were callable. A problem for
1765 things which are both callable and implement __getitem__.
1770 things which are both callable and implement __getitem__.
1766 (init_readline): Fix autoindentation for win32. Thanks to a patch
1771 (init_readline): Fix autoindentation for win32. Thanks to a patch
1767 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
1772 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
1768
1773
1769 2005-02-12 Fernando Perez <fperez@colorado.edu>
1774 2005-02-12 Fernando Perez <fperez@colorado.edu>
1770
1775
1771 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
1776 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
1772 which I had written long ago to sort out user error messages which
1777 which I had written long ago to sort out user error messages which
1773 may occur during startup. This seemed like a good idea initially,
1778 may occur during startup. This seemed like a good idea initially,
1774 but it has proven a disaster in retrospect. I don't want to
1779 but it has proven a disaster in retrospect. I don't want to
1775 change much code for now, so my fix is to set the internal 'debug'
1780 change much code for now, so my fix is to set the internal 'debug'
1776 flag to true everywhere, whose only job was precisely to control
1781 flag to true everywhere, whose only job was precisely to control
1777 this subsystem. This closes issue 28 (as well as avoiding all
1782 this subsystem. This closes issue 28 (as well as avoiding all
1778 sorts of strange hangups which occur from time to time).
1783 sorts of strange hangups which occur from time to time).
1779
1784
1780 2005-02-07 Fernando Perez <fperez@colorado.edu>
1785 2005-02-07 Fernando Perez <fperez@colorado.edu>
1781
1786
1782 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
1787 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
1783 previous call produced a syntax error.
1788 previous call produced a syntax error.
1784
1789
1785 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
1790 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
1786 classes without constructor.
1791 classes without constructor.
1787
1792
1788 2005-02-06 Fernando Perez <fperez@colorado.edu>
1793 2005-02-06 Fernando Perez <fperez@colorado.edu>
1789
1794
1790 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
1795 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
1791 completions with the results of each matcher, so we return results
1796 completions with the results of each matcher, so we return results
1792 to the user from all namespaces. This breaks with ipython
1797 to the user from all namespaces. This breaks with ipython
1793 tradition, but I think it's a nicer behavior. Now you get all
1798 tradition, but I think it's a nicer behavior. Now you get all
1794 possible completions listed, from all possible namespaces (python,
1799 possible completions listed, from all possible namespaces (python,
1795 filesystem, magics...) After a request by John Hunter
1800 filesystem, magics...) After a request by John Hunter
1796 <jdhunter-AT-nitace.bsd.uchicago.edu>.
1801 <jdhunter-AT-nitace.bsd.uchicago.edu>.
1797
1802
1798 2005-02-05 Fernando Perez <fperez@colorado.edu>
1803 2005-02-05 Fernando Perez <fperez@colorado.edu>
1799
1804
1800 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
1805 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
1801 the call had quote characters in it (the quotes were stripped).
1806 the call had quote characters in it (the quotes were stripped).
1802
1807
1803 2005-01-31 Fernando Perez <fperez@colorado.edu>
1808 2005-01-31 Fernando Perez <fperez@colorado.edu>
1804
1809
1805 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
1810 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
1806 Itpl.itpl() to make the code more robust against psyco
1811 Itpl.itpl() to make the code more robust against psyco
1807 optimizations.
1812 optimizations.
1808
1813
1809 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
1814 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
1810 of causing an exception. Quicker, cleaner.
1815 of causing an exception. Quicker, cleaner.
1811
1816
1812 2005-01-28 Fernando Perez <fperez@colorado.edu>
1817 2005-01-28 Fernando Perez <fperez@colorado.edu>
1813
1818
1814 * scripts/ipython_win_post_install.py (install): hardcode
1819 * scripts/ipython_win_post_install.py (install): hardcode
1815 sys.prefix+'python.exe' as the executable path. It turns out that
1820 sys.prefix+'python.exe' as the executable path. It turns out that
1816 during the post-installation run, sys.executable resolves to the
1821 during the post-installation run, sys.executable resolves to the
1817 name of the binary installer! I should report this as a distutils
1822 name of the binary installer! I should report this as a distutils
1818 bug, I think. I updated the .10 release with this tiny fix, to
1823 bug, I think. I updated the .10 release with this tiny fix, to
1819 avoid annoying the lists further.
1824 avoid annoying the lists further.
1820
1825
1821 2005-01-27 *** Released version 0.6.10
1826 2005-01-27 *** Released version 0.6.10
1822
1827
1823 2005-01-27 Fernando Perez <fperez@colorado.edu>
1828 2005-01-27 Fernando Perez <fperez@colorado.edu>
1824
1829
1825 * IPython/numutils.py (norm): Added 'inf' as optional name for
1830 * IPython/numutils.py (norm): Added 'inf' as optional name for
1826 L-infinity norm, included references to mathworld.com for vector
1831 L-infinity norm, included references to mathworld.com for vector
1827 norm definitions.
1832 norm definitions.
1828 (amin/amax): added amin/amax for array min/max. Similar to what
1833 (amin/amax): added amin/amax for array min/max. Similar to what
1829 pylab ships with after the recent reorganization of names.
1834 pylab ships with after the recent reorganization of names.
1830 (spike/spike_odd): removed deprecated spike/spike_odd functions.
1835 (spike/spike_odd): removed deprecated spike/spike_odd functions.
1831
1836
1832 * ipython.el: committed Alex's recent fixes and improvements.
1837 * ipython.el: committed Alex's recent fixes and improvements.
1833 Tested with python-mode from CVS, and it looks excellent. Since
1838 Tested with python-mode from CVS, and it looks excellent. Since
1834 python-mode hasn't released anything in a while, I'm temporarily
1839 python-mode hasn't released anything in a while, I'm temporarily
1835 putting a copy of today's CVS (v 4.70) of python-mode in:
1840 putting a copy of today's CVS (v 4.70) of python-mode in:
1836 http://ipython.scipy.org/tmp/python-mode.el
1841 http://ipython.scipy.org/tmp/python-mode.el
1837
1842
1838 * scripts/ipython_win_post_install.py (install): Win32 fix to use
1843 * scripts/ipython_win_post_install.py (install): Win32 fix to use
1839 sys.executable for the executable name, instead of assuming it's
1844 sys.executable for the executable name, instead of assuming it's
1840 called 'python.exe' (the post-installer would have produced broken
1845 called 'python.exe' (the post-installer would have produced broken
1841 setups on systems with a differently named python binary).
1846 setups on systems with a differently named python binary).
1842
1847
1843 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
1848 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
1844 references to os.linesep, to make the code more
1849 references to os.linesep, to make the code more
1845 platform-independent. This is also part of the win32 coloring
1850 platform-independent. This is also part of the win32 coloring
1846 fixes.
1851 fixes.
1847
1852
1848 * IPython/genutils.py (page_dumb): Remove attempts to chop long
1853 * IPython/genutils.py (page_dumb): Remove attempts to chop long
1849 lines, which actually cause coloring bugs because the length of
1854 lines, which actually cause coloring bugs because the length of
1850 the line is very difficult to correctly compute with embedded
1855 the line is very difficult to correctly compute with embedded
1851 escapes. This was the source of all the coloring problems under
1856 escapes. This was the source of all the coloring problems under
1852 Win32. I think that _finally_, Win32 users have a properly
1857 Win32. I think that _finally_, Win32 users have a properly
1853 working ipython in all respects. This would never have happened
1858 working ipython in all respects. This would never have happened
1854 if not for Gary Bishop and Viktor Ransmayr's great help and work.
1859 if not for Gary Bishop and Viktor Ransmayr's great help and work.
1855
1860
1856 2005-01-26 *** Released version 0.6.9
1861 2005-01-26 *** Released version 0.6.9
1857
1862
1858 2005-01-25 Fernando Perez <fperez@colorado.edu>
1863 2005-01-25 Fernando Perez <fperez@colorado.edu>
1859
1864
1860 * setup.py: finally, we have a true Windows installer, thanks to
1865 * setup.py: finally, we have a true Windows installer, thanks to
1861 the excellent work of Viktor Ransmayr
1866 the excellent work of Viktor Ransmayr
1862 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
1867 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
1863 Windows users. The setup routine is quite a bit cleaner thanks to
1868 Windows users. The setup routine is quite a bit cleaner thanks to
1864 this, and the post-install script uses the proper functions to
1869 this, and the post-install script uses the proper functions to
1865 allow a clean de-installation using the standard Windows Control
1870 allow a clean de-installation using the standard Windows Control
1866 Panel.
1871 Panel.
1867
1872
1868 * IPython/genutils.py (get_home_dir): changed to use the $HOME
1873 * IPython/genutils.py (get_home_dir): changed to use the $HOME
1869 environment variable under all OSes (including win32) if
1874 environment variable under all OSes (including win32) if
1870 available. This will give consistency to win32 users who have set
1875 available. This will give consistency to win32 users who have set
1871 this variable for any reason. If os.environ['HOME'] fails, the
1876 this variable for any reason. If os.environ['HOME'] fails, the
1872 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
1877 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
1873
1878
1874 2005-01-24 Fernando Perez <fperez@colorado.edu>
1879 2005-01-24 Fernando Perez <fperez@colorado.edu>
1875
1880
1876 * IPython/numutils.py (empty_like): add empty_like(), similar to
1881 * IPython/numutils.py (empty_like): add empty_like(), similar to
1877 zeros_like() but taking advantage of the new empty() Numeric routine.
1882 zeros_like() but taking advantage of the new empty() Numeric routine.
1878
1883
1879 2005-01-23 *** Released version 0.6.8
1884 2005-01-23 *** Released version 0.6.8
1880
1885
1881 2005-01-22 Fernando Perez <fperez@colorado.edu>
1886 2005-01-22 Fernando Perez <fperez@colorado.edu>
1882
1887
1883 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
1888 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
1884 automatic show() calls. After discussing things with JDH, it
1889 automatic show() calls. After discussing things with JDH, it
1885 turns out there are too many corner cases where this can go wrong.
1890 turns out there are too many corner cases where this can go wrong.
1886 It's best not to try to be 'too smart', and simply have ipython
1891 It's best not to try to be 'too smart', and simply have ipython
1887 reproduce as much as possible the default behavior of a normal
1892 reproduce as much as possible the default behavior of a normal
1888 python shell.
1893 python shell.
1889
1894
1890 * IPython/iplib.py (InteractiveShell.__init__): Modified the
1895 * IPython/iplib.py (InteractiveShell.__init__): Modified the
1891 line-splitting regexp and _prefilter() to avoid calling getattr()
1896 line-splitting regexp and _prefilter() to avoid calling getattr()
1892 on assignments. This closes
1897 on assignments. This closes
1893 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
1898 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
1894 readline uses getattr(), so a simple <TAB> keypress is still
1899 readline uses getattr(), so a simple <TAB> keypress is still
1895 enough to trigger getattr() calls on an object.
1900 enough to trigger getattr() calls on an object.
1896
1901
1897 2005-01-21 Fernando Perez <fperez@colorado.edu>
1902 2005-01-21 Fernando Perez <fperez@colorado.edu>
1898
1903
1899 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
1904 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
1900 docstring under pylab so it doesn't mask the original.
1905 docstring under pylab so it doesn't mask the original.
1901
1906
1902 2005-01-21 *** Released version 0.6.7
1907 2005-01-21 *** Released version 0.6.7
1903
1908
1904 2005-01-21 Fernando Perez <fperez@colorado.edu>
1909 2005-01-21 Fernando Perez <fperez@colorado.edu>
1905
1910
1906 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
1911 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
1907 signal handling for win32 users in multithreaded mode.
1912 signal handling for win32 users in multithreaded mode.
1908
1913
1909 2005-01-17 Fernando Perez <fperez@colorado.edu>
1914 2005-01-17 Fernando Perez <fperez@colorado.edu>
1910
1915
1911 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
1916 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
1912 instances with no __init__. After a crash report by Norbert Nemec
1917 instances with no __init__. After a crash report by Norbert Nemec
1913 <Norbert-AT-nemec-online.de>.
1918 <Norbert-AT-nemec-online.de>.
1914
1919
1915 2005-01-14 Fernando Perez <fperez@colorado.edu>
1920 2005-01-14 Fernando Perez <fperez@colorado.edu>
1916
1921
1917 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
1922 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
1918 names for verbose exceptions, when multiple dotted names and the
1923 names for verbose exceptions, when multiple dotted names and the
1919 'parent' object were present on the same line.
1924 'parent' object were present on the same line.
1920
1925
1921 2005-01-11 Fernando Perez <fperez@colorado.edu>
1926 2005-01-11 Fernando Perez <fperez@colorado.edu>
1922
1927
1923 * IPython/genutils.py (flag_calls): new utility to trap and flag
1928 * IPython/genutils.py (flag_calls): new utility to trap and flag
1924 calls in functions. I need it to clean up matplotlib support.
1929 calls in functions. I need it to clean up matplotlib support.
1925 Also removed some deprecated code in genutils.
1930 Also removed some deprecated code in genutils.
1926
1931
1927 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
1932 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
1928 that matplotlib scripts called with %run, which don't call show()
1933 that matplotlib scripts called with %run, which don't call show()
1929 themselves, still have their plotting windows open.
1934 themselves, still have their plotting windows open.
1930
1935
1931 2005-01-05 Fernando Perez <fperez@colorado.edu>
1936 2005-01-05 Fernando Perez <fperez@colorado.edu>
1932
1937
1933 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
1938 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
1934 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
1939 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
1935
1940
1936 2004-12-19 Fernando Perez <fperez@colorado.edu>
1941 2004-12-19 Fernando Perez <fperez@colorado.edu>
1937
1942
1938 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
1943 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
1939 parent_runcode, which was an eyesore. The same result can be
1944 parent_runcode, which was an eyesore. The same result can be
1940 obtained with Python's regular superclass mechanisms.
1945 obtained with Python's regular superclass mechanisms.
1941
1946
1942 2004-12-17 Fernando Perez <fperez@colorado.edu>
1947 2004-12-17 Fernando Perez <fperez@colorado.edu>
1943
1948
1944 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
1949 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
1945 reported by Prabhu.
1950 reported by Prabhu.
1946 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
1951 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
1947 sys.stderr) instead of explicitly calling sys.stderr. This helps
1952 sys.stderr) instead of explicitly calling sys.stderr. This helps
1948 maintain our I/O abstractions clean, for future GUI embeddings.
1953 maintain our I/O abstractions clean, for future GUI embeddings.
1949
1954
1950 * IPython/genutils.py (info): added new utility for sys.stderr
1955 * IPython/genutils.py (info): added new utility for sys.stderr
1951 unified info message handling (thin wrapper around warn()).
1956 unified info message handling (thin wrapper around warn()).
1952
1957
1953 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
1958 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
1954 composite (dotted) names on verbose exceptions.
1959 composite (dotted) names on verbose exceptions.
1955 (VerboseTB.nullrepr): harden against another kind of errors which
1960 (VerboseTB.nullrepr): harden against another kind of errors which
1956 Python's inspect module can trigger, and which were crashing
1961 Python's inspect module can trigger, and which were crashing
1957 IPython. Thanks to a report by Marco Lombardi
1962 IPython. Thanks to a report by Marco Lombardi
1958 <mlombard-AT-ma010192.hq.eso.org>.
1963 <mlombard-AT-ma010192.hq.eso.org>.
1959
1964
1960 2004-12-13 *** Released version 0.6.6
1965 2004-12-13 *** Released version 0.6.6
1961
1966
1962 2004-12-12 Fernando Perez <fperez@colorado.edu>
1967 2004-12-12 Fernando Perez <fperez@colorado.edu>
1963
1968
1964 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
1969 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
1965 generated by pygtk upon initialization if it was built without
1970 generated by pygtk upon initialization if it was built without
1966 threads (for matplotlib users). After a crash reported by
1971 threads (for matplotlib users). After a crash reported by
1967 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
1972 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
1968
1973
1969 * IPython/ipmaker.py (make_IPython): fix small bug in the
1974 * IPython/ipmaker.py (make_IPython): fix small bug in the
1970 import_some parameter for multiple imports.
1975 import_some parameter for multiple imports.
1971
1976
1972 * IPython/iplib.py (ipmagic): simplified the interface of
1977 * IPython/iplib.py (ipmagic): simplified the interface of
1973 ipmagic() to take a single string argument, just as it would be
1978 ipmagic() to take a single string argument, just as it would be
1974 typed at the IPython cmd line.
1979 typed at the IPython cmd line.
1975 (ipalias): Added new ipalias() with an interface identical to
1980 (ipalias): Added new ipalias() with an interface identical to
1976 ipmagic(). This completes exposing a pure python interface to the
1981 ipmagic(). This completes exposing a pure python interface to the
1977 alias and magic system, which can be used in loops or more complex
1982 alias and magic system, which can be used in loops or more complex
1978 code where IPython's automatic line mangling is not active.
1983 code where IPython's automatic line mangling is not active.
1979
1984
1980 * IPython/genutils.py (timing): changed interface of timing to
1985 * IPython/genutils.py (timing): changed interface of timing to
1981 simply run code once, which is the most common case. timings()
1986 simply run code once, which is the most common case. timings()
1982 remains unchanged, for the cases where you want multiple runs.
1987 remains unchanged, for the cases where you want multiple runs.
1983
1988
1984 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
1989 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
1985 bug where Python2.2 crashes with exec'ing code which does not end
1990 bug where Python2.2 crashes with exec'ing code which does not end
1986 in a single newline. Python 2.3 is OK, so I hadn't noticed this
1991 in a single newline. Python 2.3 is OK, so I hadn't noticed this
1987 before.
1992 before.
1988
1993
1989 2004-12-10 Fernando Perez <fperez@colorado.edu>
1994 2004-12-10 Fernando Perez <fperez@colorado.edu>
1990
1995
1991 * IPython/Magic.py (Magic.magic_prun): changed name of option from
1996 * IPython/Magic.py (Magic.magic_prun): changed name of option from
1992 -t to -T, to accomodate the new -t flag in %run (the %run and
1997 -t to -T, to accomodate the new -t flag in %run (the %run and
1993 %prun options are kind of intermixed, and it's not easy to change
1998 %prun options are kind of intermixed, and it's not easy to change
1994 this with the limitations of python's getopt).
1999 this with the limitations of python's getopt).
1995
2000
1996 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
2001 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
1997 the execution of scripts. It's not as fine-tuned as timeit.py,
2002 the execution of scripts. It's not as fine-tuned as timeit.py,
1998 but it works from inside ipython (and under 2.2, which lacks
2003 but it works from inside ipython (and under 2.2, which lacks
1999 timeit.py). Optionally a number of runs > 1 can be given for
2004 timeit.py). Optionally a number of runs > 1 can be given for
2000 timing very short-running code.
2005 timing very short-running code.
2001
2006
2002 * IPython/genutils.py (uniq_stable): new routine which returns a
2007 * IPython/genutils.py (uniq_stable): new routine which returns a
2003 list of unique elements in any iterable, but in stable order of
2008 list of unique elements in any iterable, but in stable order of
2004 appearance. I needed this for the ultraTB fixes, and it's a handy
2009 appearance. I needed this for the ultraTB fixes, and it's a handy
2005 utility.
2010 utility.
2006
2011
2007 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
2012 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
2008 dotted names in Verbose exceptions. This had been broken since
2013 dotted names in Verbose exceptions. This had been broken since
2009 the very start, now x.y will properly be printed in a Verbose
2014 the very start, now x.y will properly be printed in a Verbose
2010 traceback, instead of x being shown and y appearing always as an
2015 traceback, instead of x being shown and y appearing always as an
2011 'undefined global'. Getting this to work was a bit tricky,
2016 'undefined global'. Getting this to work was a bit tricky,
2012 because by default python tokenizers are stateless. Saved by
2017 because by default python tokenizers are stateless. Saved by
2013 python's ability to easily add a bit of state to an arbitrary
2018 python's ability to easily add a bit of state to an arbitrary
2014 function (without needing to build a full-blown callable object).
2019 function (without needing to build a full-blown callable object).
2015
2020
2016 Also big cleanup of this code, which had horrendous runtime
2021 Also big cleanup of this code, which had horrendous runtime
2017 lookups of zillions of attributes for colorization. Moved all
2022 lookups of zillions of attributes for colorization. Moved all
2018 this code into a few templates, which make it cleaner and quicker.
2023 this code into a few templates, which make it cleaner and quicker.
2019
2024
2020 Printout quality was also improved for Verbose exceptions: one
2025 Printout quality was also improved for Verbose exceptions: one
2021 variable per line, and memory addresses are printed (this can be
2026 variable per line, and memory addresses are printed (this can be
2022 quite handy in nasty debugging situations, which is what Verbose
2027 quite handy in nasty debugging situations, which is what Verbose
2023 is for).
2028 is for).
2024
2029
2025 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
2030 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
2026 the command line as scripts to be loaded by embedded instances.
2031 the command line as scripts to be loaded by embedded instances.
2027 Doing so has the potential for an infinite recursion if there are
2032 Doing so has the potential for an infinite recursion if there are
2028 exceptions thrown in the process. This fixes a strange crash
2033 exceptions thrown in the process. This fixes a strange crash
2029 reported by Philippe MULLER <muller-AT-irit.fr>.
2034 reported by Philippe MULLER <muller-AT-irit.fr>.
2030
2035
2031 2004-12-09 Fernando Perez <fperez@colorado.edu>
2036 2004-12-09 Fernando Perez <fperez@colorado.edu>
2032
2037
2033 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
2038 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
2034 to reflect new names in matplotlib, which now expose the
2039 to reflect new names in matplotlib, which now expose the
2035 matlab-compatible interface via a pylab module instead of the
2040 matlab-compatible interface via a pylab module instead of the
2036 'matlab' name. The new code is backwards compatible, so users of
2041 'matlab' name. The new code is backwards compatible, so users of
2037 all matplotlib versions are OK. Patch by J. Hunter.
2042 all matplotlib versions are OK. Patch by J. Hunter.
2038
2043
2039 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
2044 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
2040 of __init__ docstrings for instances (class docstrings are already
2045 of __init__ docstrings for instances (class docstrings are already
2041 automatically printed). Instances with customized docstrings
2046 automatically printed). Instances with customized docstrings
2042 (indep. of the class) are also recognized and all 3 separate
2047 (indep. of the class) are also recognized and all 3 separate
2043 docstrings are printed (instance, class, constructor). After some
2048 docstrings are printed (instance, class, constructor). After some
2044 comments/suggestions by J. Hunter.
2049 comments/suggestions by J. Hunter.
2045
2050
2046 2004-12-05 Fernando Perez <fperez@colorado.edu>
2051 2004-12-05 Fernando Perez <fperez@colorado.edu>
2047
2052
2048 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
2053 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
2049 warnings when tab-completion fails and triggers an exception.
2054 warnings when tab-completion fails and triggers an exception.
2050
2055
2051 2004-12-03 Fernando Perez <fperez@colorado.edu>
2056 2004-12-03 Fernando Perez <fperez@colorado.edu>
2052
2057
2053 * IPython/Magic.py (magic_prun): Fix bug where an exception would
2058 * IPython/Magic.py (magic_prun): Fix bug where an exception would
2054 be triggered when using 'run -p'. An incorrect option flag was
2059 be triggered when using 'run -p'. An incorrect option flag was
2055 being set ('d' instead of 'D').
2060 being set ('d' instead of 'D').
2056 (manpage): fix missing escaped \- sign.
2061 (manpage): fix missing escaped \- sign.
2057
2062
2058 2004-11-30 *** Released version 0.6.5
2063 2004-11-30 *** Released version 0.6.5
2059
2064
2060 2004-11-30 Fernando Perez <fperez@colorado.edu>
2065 2004-11-30 Fernando Perez <fperez@colorado.edu>
2061
2066
2062 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
2067 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
2063 setting with -d option.
2068 setting with -d option.
2064
2069
2065 * setup.py (docfiles): Fix problem where the doc glob I was using
2070 * setup.py (docfiles): Fix problem where the doc glob I was using
2066 was COMPLETELY BROKEN. It was giving the right files by pure
2071 was COMPLETELY BROKEN. It was giving the right files by pure
2067 accident, but failed once I tried to include ipython.el. Note:
2072 accident, but failed once I tried to include ipython.el. Note:
2068 glob() does NOT allow you to do exclusion on multiple endings!
2073 glob() does NOT allow you to do exclusion on multiple endings!
2069
2074
2070 2004-11-29 Fernando Perez <fperez@colorado.edu>
2075 2004-11-29 Fernando Perez <fperez@colorado.edu>
2071
2076
2072 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
2077 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
2073 the manpage as the source. Better formatting & consistency.
2078 the manpage as the source. Better formatting & consistency.
2074
2079
2075 * IPython/Magic.py (magic_run): Added new -d option, to run
2080 * IPython/Magic.py (magic_run): Added new -d option, to run
2076 scripts under the control of the python pdb debugger. Note that
2081 scripts under the control of the python pdb debugger. Note that
2077 this required changing the %prun option -d to -D, to avoid a clash
2082 this required changing the %prun option -d to -D, to avoid a clash
2078 (since %run must pass options to %prun, and getopt is too dumb to
2083 (since %run must pass options to %prun, and getopt is too dumb to
2079 handle options with string values with embedded spaces). Thanks
2084 handle options with string values with embedded spaces). Thanks
2080 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
2085 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
2081 (magic_who_ls): added type matching to %who and %whos, so that one
2086 (magic_who_ls): added type matching to %who and %whos, so that one
2082 can filter their output to only include variables of certain
2087 can filter their output to only include variables of certain
2083 types. Another suggestion by Matthew.
2088 types. Another suggestion by Matthew.
2084 (magic_whos): Added memory summaries in kb and Mb for arrays.
2089 (magic_whos): Added memory summaries in kb and Mb for arrays.
2085 (magic_who): Improve formatting (break lines every 9 vars).
2090 (magic_who): Improve formatting (break lines every 9 vars).
2086
2091
2087 2004-11-28 Fernando Perez <fperez@colorado.edu>
2092 2004-11-28 Fernando Perez <fperez@colorado.edu>
2088
2093
2089 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
2094 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
2090 cache when empty lines were present.
2095 cache when empty lines were present.
2091
2096
2092 2004-11-24 Fernando Perez <fperez@colorado.edu>
2097 2004-11-24 Fernando Perez <fperez@colorado.edu>
2093
2098
2094 * IPython/usage.py (__doc__): document the re-activated threading
2099 * IPython/usage.py (__doc__): document the re-activated threading
2095 options for WX and GTK.
2100 options for WX and GTK.
2096
2101
2097 2004-11-23 Fernando Perez <fperez@colorado.edu>
2102 2004-11-23 Fernando Perez <fperez@colorado.edu>
2098
2103
2099 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
2104 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
2100 the -wthread and -gthread options, along with a new -tk one to try
2105 the -wthread and -gthread options, along with a new -tk one to try
2101 and coordinate Tk threading with wx/gtk. The tk support is very
2106 and coordinate Tk threading with wx/gtk. The tk support is very
2102 platform dependent, since it seems to require Tcl and Tk to be
2107 platform dependent, since it seems to require Tcl and Tk to be
2103 built with threads (Fedora1/2 appears NOT to have it, but in
2108 built with threads (Fedora1/2 appears NOT to have it, but in
2104 Prabhu's Debian boxes it works OK). But even with some Tk
2109 Prabhu's Debian boxes it works OK). But even with some Tk
2105 limitations, this is a great improvement.
2110 limitations, this is a great improvement.
2106
2111
2107 * IPython/Prompts.py (prompt_specials_color): Added \t for time
2112 * IPython/Prompts.py (prompt_specials_color): Added \t for time
2108 info in user prompts. Patch by Prabhu.
2113 info in user prompts. Patch by Prabhu.
2109
2114
2110 2004-11-18 Fernando Perez <fperez@colorado.edu>
2115 2004-11-18 Fernando Perez <fperez@colorado.edu>
2111
2116
2112 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
2117 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
2113 EOFErrors and bail, to avoid infinite loops if a non-terminating
2118 EOFErrors and bail, to avoid infinite loops if a non-terminating
2114 file is fed into ipython. Patch submitted in issue 19 by user,
2119 file is fed into ipython. Patch submitted in issue 19 by user,
2115 many thanks.
2120 many thanks.
2116
2121
2117 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
2122 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
2118 autoquote/parens in continuation prompts, which can cause lots of
2123 autoquote/parens in continuation prompts, which can cause lots of
2119 problems. Closes roundup issue 20.
2124 problems. Closes roundup issue 20.
2120
2125
2121 2004-11-17 Fernando Perez <fperez@colorado.edu>
2126 2004-11-17 Fernando Perez <fperez@colorado.edu>
2122
2127
2123 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
2128 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
2124 reported as debian bug #280505. I'm not sure my local changelog
2129 reported as debian bug #280505. I'm not sure my local changelog
2125 entry has the proper debian format (Jack?).
2130 entry has the proper debian format (Jack?).
2126
2131
2127 2004-11-08 *** Released version 0.6.4
2132 2004-11-08 *** Released version 0.6.4
2128
2133
2129 2004-11-08 Fernando Perez <fperez@colorado.edu>
2134 2004-11-08 Fernando Perez <fperez@colorado.edu>
2130
2135
2131 * IPython/iplib.py (init_readline): Fix exit message for Windows
2136 * IPython/iplib.py (init_readline): Fix exit message for Windows
2132 when readline is active. Thanks to a report by Eric Jones
2137 when readline is active. Thanks to a report by Eric Jones
2133 <eric-AT-enthought.com>.
2138 <eric-AT-enthought.com>.
2134
2139
2135 2004-11-07 Fernando Perez <fperez@colorado.edu>
2140 2004-11-07 Fernando Perez <fperez@colorado.edu>
2136
2141
2137 * IPython/genutils.py (page): Add a trap for OSError exceptions,
2142 * IPython/genutils.py (page): Add a trap for OSError exceptions,
2138 sometimes seen by win2k/cygwin users.
2143 sometimes seen by win2k/cygwin users.
2139
2144
2140 2004-11-06 Fernando Perez <fperez@colorado.edu>
2145 2004-11-06 Fernando Perez <fperez@colorado.edu>
2141
2146
2142 * IPython/iplib.py (interact): Change the handling of %Exit from
2147 * IPython/iplib.py (interact): Change the handling of %Exit from
2143 trying to propagate a SystemExit to an internal ipython flag.
2148 trying to propagate a SystemExit to an internal ipython flag.
2144 This is less elegant than using Python's exception mechanism, but
2149 This is less elegant than using Python's exception mechanism, but
2145 I can't get that to work reliably with threads, so under -pylab
2150 I can't get that to work reliably with threads, so under -pylab
2146 %Exit was hanging IPython. Cross-thread exception handling is
2151 %Exit was hanging IPython. Cross-thread exception handling is
2147 really a bitch. Thaks to a bug report by Stephen Walton
2152 really a bitch. Thaks to a bug report by Stephen Walton
2148 <stephen.walton-AT-csun.edu>.
2153 <stephen.walton-AT-csun.edu>.
2149
2154
2150 2004-11-04 Fernando Perez <fperez@colorado.edu>
2155 2004-11-04 Fernando Perez <fperez@colorado.edu>
2151
2156
2152 * IPython/iplib.py (raw_input_original): store a pointer to the
2157 * IPython/iplib.py (raw_input_original): store a pointer to the
2153 true raw_input to harden against code which can modify it
2158 true raw_input to harden against code which can modify it
2154 (wx.py.PyShell does this and would otherwise crash ipython).
2159 (wx.py.PyShell does this and would otherwise crash ipython).
2155 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
2160 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
2156
2161
2157 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
2162 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
2158 Ctrl-C problem, which does not mess up the input line.
2163 Ctrl-C problem, which does not mess up the input line.
2159
2164
2160 2004-11-03 Fernando Perez <fperez@colorado.edu>
2165 2004-11-03 Fernando Perez <fperez@colorado.edu>
2161
2166
2162 * IPython/Release.py: Changed licensing to BSD, in all files.
2167 * IPython/Release.py: Changed licensing to BSD, in all files.
2163 (name): lowercase name for tarball/RPM release.
2168 (name): lowercase name for tarball/RPM release.
2164
2169
2165 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
2170 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
2166 use throughout ipython.
2171 use throughout ipython.
2167
2172
2168 * IPython/Magic.py (Magic._ofind): Switch to using the new
2173 * IPython/Magic.py (Magic._ofind): Switch to using the new
2169 OInspect.getdoc() function.
2174 OInspect.getdoc() function.
2170
2175
2171 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
2176 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
2172 of the line currently being canceled via Ctrl-C. It's extremely
2177 of the line currently being canceled via Ctrl-C. It's extremely
2173 ugly, but I don't know how to do it better (the problem is one of
2178 ugly, but I don't know how to do it better (the problem is one of
2174 handling cross-thread exceptions).
2179 handling cross-thread exceptions).
2175
2180
2176 2004-10-28 Fernando Perez <fperez@colorado.edu>
2181 2004-10-28 Fernando Perez <fperez@colorado.edu>
2177
2182
2178 * IPython/Shell.py (signal_handler): add signal handlers to trap
2183 * IPython/Shell.py (signal_handler): add signal handlers to trap
2179 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
2184 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
2180 report by Francesc Alted.
2185 report by Francesc Alted.
2181
2186
2182 2004-10-21 Fernando Perez <fperez@colorado.edu>
2187 2004-10-21 Fernando Perez <fperez@colorado.edu>
2183
2188
2184 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
2189 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
2185 to % for pysh syntax extensions.
2190 to % for pysh syntax extensions.
2186
2191
2187 2004-10-09 Fernando Perez <fperez@colorado.edu>
2192 2004-10-09 Fernando Perez <fperez@colorado.edu>
2188
2193
2189 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
2194 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
2190 arrays to print a more useful summary, without calling str(arr).
2195 arrays to print a more useful summary, without calling str(arr).
2191 This avoids the problem of extremely lengthy computations which
2196 This avoids the problem of extremely lengthy computations which
2192 occur if arr is large, and appear to the user as a system lockup
2197 occur if arr is large, and appear to the user as a system lockup
2193 with 100% cpu activity. After a suggestion by Kristian Sandberg
2198 with 100% cpu activity. After a suggestion by Kristian Sandberg
2194 <Kristian.Sandberg@colorado.edu>.
2199 <Kristian.Sandberg@colorado.edu>.
2195 (Magic.__init__): fix bug in global magic escapes not being
2200 (Magic.__init__): fix bug in global magic escapes not being
2196 correctly set.
2201 correctly set.
2197
2202
2198 2004-10-08 Fernando Perez <fperez@colorado.edu>
2203 2004-10-08 Fernando Perez <fperez@colorado.edu>
2199
2204
2200 * IPython/Magic.py (__license__): change to absolute imports of
2205 * IPython/Magic.py (__license__): change to absolute imports of
2201 ipython's own internal packages, to start adapting to the absolute
2206 ipython's own internal packages, to start adapting to the absolute
2202 import requirement of PEP-328.
2207 import requirement of PEP-328.
2203
2208
2204 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
2209 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
2205 files, and standardize author/license marks through the Release
2210 files, and standardize author/license marks through the Release
2206 module instead of having per/file stuff (except for files with
2211 module instead of having per/file stuff (except for files with
2207 particular licenses, like the MIT/PSF-licensed codes).
2212 particular licenses, like the MIT/PSF-licensed codes).
2208
2213
2209 * IPython/Debugger.py: remove dead code for python 2.1
2214 * IPython/Debugger.py: remove dead code for python 2.1
2210
2215
2211 2004-10-04 Fernando Perez <fperez@colorado.edu>
2216 2004-10-04 Fernando Perez <fperez@colorado.edu>
2212
2217
2213 * IPython/iplib.py (ipmagic): New function for accessing magics
2218 * IPython/iplib.py (ipmagic): New function for accessing magics
2214 via a normal python function call.
2219 via a normal python function call.
2215
2220
2216 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
2221 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
2217 from '@' to '%', to accomodate the new @decorator syntax of python
2222 from '@' to '%', to accomodate the new @decorator syntax of python
2218 2.4.
2223 2.4.
2219
2224
2220 2004-09-29 Fernando Perez <fperez@colorado.edu>
2225 2004-09-29 Fernando Perez <fperez@colorado.edu>
2221
2226
2222 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
2227 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
2223 matplotlib.use to prevent running scripts which try to switch
2228 matplotlib.use to prevent running scripts which try to switch
2224 interactive backends from within ipython. This will just crash
2229 interactive backends from within ipython. This will just crash
2225 the python interpreter, so we can't allow it (but a detailed error
2230 the python interpreter, so we can't allow it (but a detailed error
2226 is given to the user).
2231 is given to the user).
2227
2232
2228 2004-09-28 Fernando Perez <fperez@colorado.edu>
2233 2004-09-28 Fernando Perez <fperez@colorado.edu>
2229
2234
2230 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
2235 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
2231 matplotlib-related fixes so that using @run with non-matplotlib
2236 matplotlib-related fixes so that using @run with non-matplotlib
2232 scripts doesn't pop up spurious plot windows. This requires
2237 scripts doesn't pop up spurious plot windows. This requires
2233 matplotlib >= 0.63, where I had to make some changes as well.
2238 matplotlib >= 0.63, where I had to make some changes as well.
2234
2239
2235 * IPython/ipmaker.py (make_IPython): update version requirement to
2240 * IPython/ipmaker.py (make_IPython): update version requirement to
2236 python 2.2.
2241 python 2.2.
2237
2242
2238 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
2243 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
2239 banner arg for embedded customization.
2244 banner arg for embedded customization.
2240
2245
2241 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
2246 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
2242 explicit uses of __IP as the IPython's instance name. Now things
2247 explicit uses of __IP as the IPython's instance name. Now things
2243 are properly handled via the shell.name value. The actual code
2248 are properly handled via the shell.name value. The actual code
2244 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
2249 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
2245 is much better than before. I'll clean things completely when the
2250 is much better than before. I'll clean things completely when the
2246 magic stuff gets a real overhaul.
2251 magic stuff gets a real overhaul.
2247
2252
2248 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
2253 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
2249 minor changes to debian dir.
2254 minor changes to debian dir.
2250
2255
2251 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
2256 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
2252 pointer to the shell itself in the interactive namespace even when
2257 pointer to the shell itself in the interactive namespace even when
2253 a user-supplied dict is provided. This is needed for embedding
2258 a user-supplied dict is provided. This is needed for embedding
2254 purposes (found by tests with Michel Sanner).
2259 purposes (found by tests with Michel Sanner).
2255
2260
2256 2004-09-27 Fernando Perez <fperez@colorado.edu>
2261 2004-09-27 Fernando Perez <fperez@colorado.edu>
2257
2262
2258 * IPython/UserConfig/ipythonrc: remove []{} from
2263 * IPython/UserConfig/ipythonrc: remove []{} from
2259 readline_remove_delims, so that things like [modname.<TAB> do
2264 readline_remove_delims, so that things like [modname.<TAB> do
2260 proper completion. This disables [].TAB, but that's a less common
2265 proper completion. This disables [].TAB, but that's a less common
2261 case than module names in list comprehensions, for example.
2266 case than module names in list comprehensions, for example.
2262 Thanks to a report by Andrea Riciputi.
2267 Thanks to a report by Andrea Riciputi.
2263
2268
2264 2004-09-09 Fernando Perez <fperez@colorado.edu>
2269 2004-09-09 Fernando Perez <fperez@colorado.edu>
2265
2270
2266 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
2271 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
2267 blocking problems in win32 and osx. Fix by John.
2272 blocking problems in win32 and osx. Fix by John.
2268
2273
2269 2004-09-08 Fernando Perez <fperez@colorado.edu>
2274 2004-09-08 Fernando Perez <fperez@colorado.edu>
2270
2275
2271 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
2276 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
2272 for Win32 and OSX. Fix by John Hunter.
2277 for Win32 and OSX. Fix by John Hunter.
2273
2278
2274 2004-08-30 *** Released version 0.6.3
2279 2004-08-30 *** Released version 0.6.3
2275
2280
2276 2004-08-30 Fernando Perez <fperez@colorado.edu>
2281 2004-08-30 Fernando Perez <fperez@colorado.edu>
2277
2282
2278 * setup.py (isfile): Add manpages to list of dependent files to be
2283 * setup.py (isfile): Add manpages to list of dependent files to be
2279 updated.
2284 updated.
2280
2285
2281 2004-08-27 Fernando Perez <fperez@colorado.edu>
2286 2004-08-27 Fernando Perez <fperez@colorado.edu>
2282
2287
2283 * IPython/Shell.py (start): I've disabled -wthread and -gthread
2288 * IPython/Shell.py (start): I've disabled -wthread and -gthread
2284 for now. They don't really work with standalone WX/GTK code
2289 for now. They don't really work with standalone WX/GTK code
2285 (though matplotlib IS working fine with both of those backends).
2290 (though matplotlib IS working fine with both of those backends).
2286 This will neeed much more testing. I disabled most things with
2291 This will neeed much more testing. I disabled most things with
2287 comments, so turning it back on later should be pretty easy.
2292 comments, so turning it back on later should be pretty easy.
2288
2293
2289 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
2294 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
2290 autocalling of expressions like r'foo', by modifying the line
2295 autocalling of expressions like r'foo', by modifying the line
2291 split regexp. Closes
2296 split regexp. Closes
2292 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
2297 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
2293 Riley <ipythonbugs-AT-sabi.net>.
2298 Riley <ipythonbugs-AT-sabi.net>.
2294 (InteractiveShell.mainloop): honor --nobanner with banner
2299 (InteractiveShell.mainloop): honor --nobanner with banner
2295 extensions.
2300 extensions.
2296
2301
2297 * IPython/Shell.py: Significant refactoring of all classes, so
2302 * IPython/Shell.py: Significant refactoring of all classes, so
2298 that we can really support ALL matplotlib backends and threading
2303 that we can really support ALL matplotlib backends and threading
2299 models (John spotted a bug with Tk which required this). Now we
2304 models (John spotted a bug with Tk which required this). Now we
2300 should support single-threaded, WX-threads and GTK-threads, both
2305 should support single-threaded, WX-threads and GTK-threads, both
2301 for generic code and for matplotlib.
2306 for generic code and for matplotlib.
2302
2307
2303 * IPython/ipmaker.py (__call__): Changed -mpthread option to
2308 * IPython/ipmaker.py (__call__): Changed -mpthread option to
2304 -pylab, to simplify things for users. Will also remove the pylab
2309 -pylab, to simplify things for users. Will also remove the pylab
2305 profile, since now all of matplotlib configuration is directly
2310 profile, since now all of matplotlib configuration is directly
2306 handled here. This also reduces startup time.
2311 handled here. This also reduces startup time.
2307
2312
2308 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
2313 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
2309 shell wasn't being correctly called. Also in IPShellWX.
2314 shell wasn't being correctly called. Also in IPShellWX.
2310
2315
2311 * IPython/iplib.py (InteractiveShell.__init__): Added option to
2316 * IPython/iplib.py (InteractiveShell.__init__): Added option to
2312 fine-tune banner.
2317 fine-tune banner.
2313
2318
2314 * IPython/numutils.py (spike): Deprecate these spike functions,
2319 * IPython/numutils.py (spike): Deprecate these spike functions,
2315 delete (long deprecated) gnuplot_exec handler.
2320 delete (long deprecated) gnuplot_exec handler.
2316
2321
2317 2004-08-26 Fernando Perez <fperez@colorado.edu>
2322 2004-08-26 Fernando Perez <fperez@colorado.edu>
2318
2323
2319 * ipython.1: Update for threading options, plus some others which
2324 * ipython.1: Update for threading options, plus some others which
2320 were missing.
2325 were missing.
2321
2326
2322 * IPython/ipmaker.py (__call__): Added -wthread option for
2327 * IPython/ipmaker.py (__call__): Added -wthread option for
2323 wxpython thread handling. Make sure threading options are only
2328 wxpython thread handling. Make sure threading options are only
2324 valid at the command line.
2329 valid at the command line.
2325
2330
2326 * scripts/ipython: moved shell selection into a factory function
2331 * scripts/ipython: moved shell selection into a factory function
2327 in Shell.py, to keep the starter script to a minimum.
2332 in Shell.py, to keep the starter script to a minimum.
2328
2333
2329 2004-08-25 Fernando Perez <fperez@colorado.edu>
2334 2004-08-25 Fernando Perez <fperez@colorado.edu>
2330
2335
2331 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
2336 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
2332 John. Along with some recent changes he made to matplotlib, the
2337 John. Along with some recent changes he made to matplotlib, the
2333 next versions of both systems should work very well together.
2338 next versions of both systems should work very well together.
2334
2339
2335 2004-08-24 Fernando Perez <fperez@colorado.edu>
2340 2004-08-24 Fernando Perez <fperez@colorado.edu>
2336
2341
2337 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
2342 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
2338 tried to switch the profiling to using hotshot, but I'm getting
2343 tried to switch the profiling to using hotshot, but I'm getting
2339 strange errors from prof.runctx() there. I may be misreading the
2344 strange errors from prof.runctx() there. I may be misreading the
2340 docs, but it looks weird. For now the profiling code will
2345 docs, but it looks weird. For now the profiling code will
2341 continue to use the standard profiler.
2346 continue to use the standard profiler.
2342
2347
2343 2004-08-23 Fernando Perez <fperez@colorado.edu>
2348 2004-08-23 Fernando Perez <fperez@colorado.edu>
2344
2349
2345 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
2350 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
2346 threaded shell, by John Hunter. It's not quite ready yet, but
2351 threaded shell, by John Hunter. It's not quite ready yet, but
2347 close.
2352 close.
2348
2353
2349 2004-08-22 Fernando Perez <fperez@colorado.edu>
2354 2004-08-22 Fernando Perez <fperez@colorado.edu>
2350
2355
2351 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
2356 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
2352 in Magic and ultraTB.
2357 in Magic and ultraTB.
2353
2358
2354 * ipython.1: document threading options in manpage.
2359 * ipython.1: document threading options in manpage.
2355
2360
2356 * scripts/ipython: Changed name of -thread option to -gthread,
2361 * scripts/ipython: Changed name of -thread option to -gthread,
2357 since this is GTK specific. I want to leave the door open for a
2362 since this is GTK specific. I want to leave the door open for a
2358 -wthread option for WX, which will most likely be necessary. This
2363 -wthread option for WX, which will most likely be necessary. This
2359 change affects usage and ipmaker as well.
2364 change affects usage and ipmaker as well.
2360
2365
2361 * IPython/Shell.py (matplotlib_shell): Add a factory function to
2366 * IPython/Shell.py (matplotlib_shell): Add a factory function to
2362 handle the matplotlib shell issues. Code by John Hunter
2367 handle the matplotlib shell issues. Code by John Hunter
2363 <jdhunter-AT-nitace.bsd.uchicago.edu>.
2368 <jdhunter-AT-nitace.bsd.uchicago.edu>.
2364 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
2369 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
2365 broken (and disabled for end users) for now, but it puts the
2370 broken (and disabled for end users) for now, but it puts the
2366 infrastructure in place.
2371 infrastructure in place.
2367
2372
2368 2004-08-21 Fernando Perez <fperez@colorado.edu>
2373 2004-08-21 Fernando Perez <fperez@colorado.edu>
2369
2374
2370 * ipythonrc-pylab: Add matplotlib support.
2375 * ipythonrc-pylab: Add matplotlib support.
2371
2376
2372 * matplotlib_config.py: new files for matplotlib support, part of
2377 * matplotlib_config.py: new files for matplotlib support, part of
2373 the pylab profile.
2378 the pylab profile.
2374
2379
2375 * IPython/usage.py (__doc__): documented the threading options.
2380 * IPython/usage.py (__doc__): documented the threading options.
2376
2381
2377 2004-08-20 Fernando Perez <fperez@colorado.edu>
2382 2004-08-20 Fernando Perez <fperez@colorado.edu>
2378
2383
2379 * ipython: Modified the main calling routine to handle the -thread
2384 * ipython: Modified the main calling routine to handle the -thread
2380 and -mpthread options. This needs to be done as a top-level hack,
2385 and -mpthread options. This needs to be done as a top-level hack,
2381 because it determines which class to instantiate for IPython
2386 because it determines which class to instantiate for IPython
2382 itself.
2387 itself.
2383
2388
2384 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
2389 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
2385 classes to support multithreaded GTK operation without blocking,
2390 classes to support multithreaded GTK operation without blocking,
2386 and matplotlib with all backends. This is a lot of still very
2391 and matplotlib with all backends. This is a lot of still very
2387 experimental code, and threads are tricky. So it may still have a
2392 experimental code, and threads are tricky. So it may still have a
2388 few rough edges... This code owes a lot to
2393 few rough edges... This code owes a lot to
2389 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
2394 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
2390 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
2395 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
2391 to John Hunter for all the matplotlib work.
2396 to John Hunter for all the matplotlib work.
2392
2397
2393 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
2398 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
2394 options for gtk thread and matplotlib support.
2399 options for gtk thread and matplotlib support.
2395
2400
2396 2004-08-16 Fernando Perez <fperez@colorado.edu>
2401 2004-08-16 Fernando Perez <fperez@colorado.edu>
2397
2402
2398 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
2403 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
2399 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
2404 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
2400 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
2405 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
2401
2406
2402 2004-08-11 Fernando Perez <fperez@colorado.edu>
2407 2004-08-11 Fernando Perez <fperez@colorado.edu>
2403
2408
2404 * setup.py (isfile): Fix build so documentation gets updated for
2409 * setup.py (isfile): Fix build so documentation gets updated for
2405 rpms (it was only done for .tgz builds).
2410 rpms (it was only done for .tgz builds).
2406
2411
2407 2004-08-10 Fernando Perez <fperez@colorado.edu>
2412 2004-08-10 Fernando Perez <fperez@colorado.edu>
2408
2413
2409 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
2414 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
2410
2415
2411 * iplib.py : Silence syntax error exceptions in tab-completion.
2416 * iplib.py : Silence syntax error exceptions in tab-completion.
2412
2417
2413 2004-08-05 Fernando Perez <fperez@colorado.edu>
2418 2004-08-05 Fernando Perez <fperez@colorado.edu>
2414
2419
2415 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
2420 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
2416 'color off' mark for continuation prompts. This was causing long
2421 'color off' mark for continuation prompts. This was causing long
2417 continuation lines to mis-wrap.
2422 continuation lines to mis-wrap.
2418
2423
2419 2004-08-01 Fernando Perez <fperez@colorado.edu>
2424 2004-08-01 Fernando Perez <fperez@colorado.edu>
2420
2425
2421 * IPython/ipmaker.py (make_IPython): Allow the shell class used
2426 * IPython/ipmaker.py (make_IPython): Allow the shell class used
2422 for building ipython to be a parameter. All this is necessary
2427 for building ipython to be a parameter. All this is necessary
2423 right now to have a multithreaded version, but this insane
2428 right now to have a multithreaded version, but this insane
2424 non-design will be cleaned up soon. For now, it's a hack that
2429 non-design will be cleaned up soon. For now, it's a hack that
2425 works.
2430 works.
2426
2431
2427 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
2432 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
2428 args in various places. No bugs so far, but it's a dangerous
2433 args in various places. No bugs so far, but it's a dangerous
2429 practice.
2434 practice.
2430
2435
2431 2004-07-31 Fernando Perez <fperez@colorado.edu>
2436 2004-07-31 Fernando Perez <fperez@colorado.edu>
2432
2437
2433 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
2438 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
2434 fix completion of files with dots in their names under most
2439 fix completion of files with dots in their names under most
2435 profiles (pysh was OK because the completion order is different).
2440 profiles (pysh was OK because the completion order is different).
2436
2441
2437 2004-07-27 Fernando Perez <fperez@colorado.edu>
2442 2004-07-27 Fernando Perez <fperez@colorado.edu>
2438
2443
2439 * IPython/iplib.py (InteractiveShell.__init__): build dict of
2444 * IPython/iplib.py (InteractiveShell.__init__): build dict of
2440 keywords manually, b/c the one in keyword.py was removed in python
2445 keywords manually, b/c the one in keyword.py was removed in python
2441 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
2446 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
2442 This is NOT a bug under python 2.3 and earlier.
2447 This is NOT a bug under python 2.3 and earlier.
2443
2448
2444 2004-07-26 Fernando Perez <fperez@colorado.edu>
2449 2004-07-26 Fernando Perez <fperez@colorado.edu>
2445
2450
2446 * IPython/ultraTB.py (VerboseTB.text): Add another
2451 * IPython/ultraTB.py (VerboseTB.text): Add another
2447 linecache.checkcache() call to try to prevent inspect.py from
2452 linecache.checkcache() call to try to prevent inspect.py from
2448 crashing under python 2.3. I think this fixes
2453 crashing under python 2.3. I think this fixes
2449 http://www.scipy.net/roundup/ipython/issue17.
2454 http://www.scipy.net/roundup/ipython/issue17.
2450
2455
2451 2004-07-26 *** Released version 0.6.2
2456 2004-07-26 *** Released version 0.6.2
2452
2457
2453 2004-07-26 Fernando Perez <fperez@colorado.edu>
2458 2004-07-26 Fernando Perez <fperez@colorado.edu>
2454
2459
2455 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
2460 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
2456 fail for any number.
2461 fail for any number.
2457 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
2462 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
2458 empty bookmarks.
2463 empty bookmarks.
2459
2464
2460 2004-07-26 *** Released version 0.6.1
2465 2004-07-26 *** Released version 0.6.1
2461
2466
2462 2004-07-26 Fernando Perez <fperez@colorado.edu>
2467 2004-07-26 Fernando Perez <fperez@colorado.edu>
2463
2468
2464 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
2469 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
2465
2470
2466 * IPython/iplib.py (protect_filename): Applied Ville's patch for
2471 * IPython/iplib.py (protect_filename): Applied Ville's patch for
2467 escaping '()[]{}' in filenames.
2472 escaping '()[]{}' in filenames.
2468
2473
2469 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
2474 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
2470 Python 2.2 users who lack a proper shlex.split.
2475 Python 2.2 users who lack a proper shlex.split.
2471
2476
2472 2004-07-19 Fernando Perez <fperez@colorado.edu>
2477 2004-07-19 Fernando Perez <fperez@colorado.edu>
2473
2478
2474 * IPython/iplib.py (InteractiveShell.init_readline): Add support
2479 * IPython/iplib.py (InteractiveShell.init_readline): Add support
2475 for reading readline's init file. I follow the normal chain:
2480 for reading readline's init file. I follow the normal chain:
2476 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
2481 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
2477 report by Mike Heeter. This closes
2482 report by Mike Heeter. This closes
2478 http://www.scipy.net/roundup/ipython/issue16.
2483 http://www.scipy.net/roundup/ipython/issue16.
2479
2484
2480 2004-07-18 Fernando Perez <fperez@colorado.edu>
2485 2004-07-18 Fernando Perez <fperez@colorado.edu>
2481
2486
2482 * IPython/iplib.py (__init__): Add better handling of '\' under
2487 * IPython/iplib.py (__init__): Add better handling of '\' under
2483 Win32 for filenames. After a patch by Ville.
2488 Win32 for filenames. After a patch by Ville.
2484
2489
2485 2004-07-17 Fernando Perez <fperez@colorado.edu>
2490 2004-07-17 Fernando Perez <fperez@colorado.edu>
2486
2491
2487 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
2492 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
2488 autocalling would be triggered for 'foo is bar' if foo is
2493 autocalling would be triggered for 'foo is bar' if foo is
2489 callable. I also cleaned up the autocall detection code to use a
2494 callable. I also cleaned up the autocall detection code to use a
2490 regexp, which is faster. Bug reported by Alexander Schmolck.
2495 regexp, which is faster. Bug reported by Alexander Schmolck.
2491
2496
2492 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
2497 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
2493 '?' in them would confuse the help system. Reported by Alex
2498 '?' in them would confuse the help system. Reported by Alex
2494 Schmolck.
2499 Schmolck.
2495
2500
2496 2004-07-16 Fernando Perez <fperez@colorado.edu>
2501 2004-07-16 Fernando Perez <fperez@colorado.edu>
2497
2502
2498 * IPython/GnuplotInteractive.py (__all__): added plot2.
2503 * IPython/GnuplotInteractive.py (__all__): added plot2.
2499
2504
2500 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
2505 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
2501 plotting dictionaries, lists or tuples of 1d arrays.
2506 plotting dictionaries, lists or tuples of 1d arrays.
2502
2507
2503 * IPython/Magic.py (Magic.magic_hist): small clenaups and
2508 * IPython/Magic.py (Magic.magic_hist): small clenaups and
2504 optimizations.
2509 optimizations.
2505
2510
2506 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
2511 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
2507 the information which was there from Janko's original IPP code:
2512 the information which was there from Janko's original IPP code:
2508
2513
2509 03.05.99 20:53 porto.ifm.uni-kiel.de
2514 03.05.99 20:53 porto.ifm.uni-kiel.de
2510 --Started changelog.
2515 --Started changelog.
2511 --make clear do what it say it does
2516 --make clear do what it say it does
2512 --added pretty output of lines from inputcache
2517 --added pretty output of lines from inputcache
2513 --Made Logger a mixin class, simplifies handling of switches
2518 --Made Logger a mixin class, simplifies handling of switches
2514 --Added own completer class. .string<TAB> expands to last history
2519 --Added own completer class. .string<TAB> expands to last history
2515 line which starts with string. The new expansion is also present
2520 line which starts with string. The new expansion is also present
2516 with Ctrl-r from the readline library. But this shows, who this
2521 with Ctrl-r from the readline library. But this shows, who this
2517 can be done for other cases.
2522 can be done for other cases.
2518 --Added convention that all shell functions should accept a
2523 --Added convention that all shell functions should accept a
2519 parameter_string This opens the door for different behaviour for
2524 parameter_string This opens the door for different behaviour for
2520 each function. @cd is a good example of this.
2525 each function. @cd is a good example of this.
2521
2526
2522 04.05.99 12:12 porto.ifm.uni-kiel.de
2527 04.05.99 12:12 porto.ifm.uni-kiel.de
2523 --added logfile rotation
2528 --added logfile rotation
2524 --added new mainloop method which freezes first the namespace
2529 --added new mainloop method which freezes first the namespace
2525
2530
2526 07.05.99 21:24 porto.ifm.uni-kiel.de
2531 07.05.99 21:24 porto.ifm.uni-kiel.de
2527 --added the docreader classes. Now there is a help system.
2532 --added the docreader classes. Now there is a help system.
2528 -This is only a first try. Currently it's not easy to put new
2533 -This is only a first try. Currently it's not easy to put new
2529 stuff in the indices. But this is the way to go. Info would be
2534 stuff in the indices. But this is the way to go. Info would be
2530 better, but HTML is every where and not everybody has an info
2535 better, but HTML is every where and not everybody has an info
2531 system installed and it's not so easy to change html-docs to info.
2536 system installed and it's not so easy to change html-docs to info.
2532 --added global logfile option
2537 --added global logfile option
2533 --there is now a hook for object inspection method pinfo needs to
2538 --there is now a hook for object inspection method pinfo needs to
2534 be provided for this. Can be reached by two '??'.
2539 be provided for this. Can be reached by two '??'.
2535
2540
2536 08.05.99 20:51 porto.ifm.uni-kiel.de
2541 08.05.99 20:51 porto.ifm.uni-kiel.de
2537 --added a README
2542 --added a README
2538 --bug in rc file. Something has changed so functions in the rc
2543 --bug in rc file. Something has changed so functions in the rc
2539 file need to reference the shell and not self. Not clear if it's a
2544 file need to reference the shell and not self. Not clear if it's a
2540 bug or feature.
2545 bug or feature.
2541 --changed rc file for new behavior
2546 --changed rc file for new behavior
2542
2547
2543 2004-07-15 Fernando Perez <fperez@colorado.edu>
2548 2004-07-15 Fernando Perez <fperez@colorado.edu>
2544
2549
2545 * IPython/Logger.py (Logger.log): fixed recent bug where the input
2550 * IPython/Logger.py (Logger.log): fixed recent bug where the input
2546 cache was falling out of sync in bizarre manners when multi-line
2551 cache was falling out of sync in bizarre manners when multi-line
2547 input was present. Minor optimizations and cleanup.
2552 input was present. Minor optimizations and cleanup.
2548
2553
2549 (Logger): Remove old Changelog info for cleanup. This is the
2554 (Logger): Remove old Changelog info for cleanup. This is the
2550 information which was there from Janko's original code:
2555 information which was there from Janko's original code:
2551
2556
2552 Changes to Logger: - made the default log filename a parameter
2557 Changes to Logger: - made the default log filename a parameter
2553
2558
2554 - put a check for lines beginning with !@? in log(). Needed
2559 - put a check for lines beginning with !@? in log(). Needed
2555 (even if the handlers properly log their lines) for mid-session
2560 (even if the handlers properly log their lines) for mid-session
2556 logging activation to work properly. Without this, lines logged
2561 logging activation to work properly. Without this, lines logged
2557 in mid session, which get read from the cache, would end up
2562 in mid session, which get read from the cache, would end up
2558 'bare' (with !@? in the open) in the log. Now they are caught
2563 'bare' (with !@? in the open) in the log. Now they are caught
2559 and prepended with a #.
2564 and prepended with a #.
2560
2565
2561 * IPython/iplib.py (InteractiveShell.init_readline): added check
2566 * IPython/iplib.py (InteractiveShell.init_readline): added check
2562 in case MagicCompleter fails to be defined, so we don't crash.
2567 in case MagicCompleter fails to be defined, so we don't crash.
2563
2568
2564 2004-07-13 Fernando Perez <fperez@colorado.edu>
2569 2004-07-13 Fernando Perez <fperez@colorado.edu>
2565
2570
2566 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
2571 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
2567 of EPS if the requested filename ends in '.eps'.
2572 of EPS if the requested filename ends in '.eps'.
2568
2573
2569 2004-07-04 Fernando Perez <fperez@colorado.edu>
2574 2004-07-04 Fernando Perez <fperez@colorado.edu>
2570
2575
2571 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
2576 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
2572 escaping of quotes when calling the shell.
2577 escaping of quotes when calling the shell.
2573
2578
2574 2004-07-02 Fernando Perez <fperez@colorado.edu>
2579 2004-07-02 Fernando Perez <fperez@colorado.edu>
2575
2580
2576 * IPython/Prompts.py (CachedOutput.update): Fix problem with
2581 * IPython/Prompts.py (CachedOutput.update): Fix problem with
2577 gettext not working because we were clobbering '_'. Fixes
2582 gettext not working because we were clobbering '_'. Fixes
2578 http://www.scipy.net/roundup/ipython/issue6.
2583 http://www.scipy.net/roundup/ipython/issue6.
2579
2584
2580 2004-07-01 Fernando Perez <fperez@colorado.edu>
2585 2004-07-01 Fernando Perez <fperez@colorado.edu>
2581
2586
2582 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
2587 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
2583 into @cd. Patch by Ville.
2588 into @cd. Patch by Ville.
2584
2589
2585 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2590 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2586 new function to store things after ipmaker runs. Patch by Ville.
2591 new function to store things after ipmaker runs. Patch by Ville.
2587 Eventually this will go away once ipmaker is removed and the class
2592 Eventually this will go away once ipmaker is removed and the class
2588 gets cleaned up, but for now it's ok. Key functionality here is
2593 gets cleaned up, but for now it's ok. Key functionality here is
2589 the addition of the persistent storage mechanism, a dict for
2594 the addition of the persistent storage mechanism, a dict for
2590 keeping data across sessions (for now just bookmarks, but more can
2595 keeping data across sessions (for now just bookmarks, but more can
2591 be implemented later).
2596 be implemented later).
2592
2597
2593 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
2598 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
2594 persistent across sections. Patch by Ville, I modified it
2599 persistent across sections. Patch by Ville, I modified it
2595 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
2600 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
2596 added a '-l' option to list all bookmarks.
2601 added a '-l' option to list all bookmarks.
2597
2602
2598 * IPython/iplib.py (InteractiveShell.atexit_operations): new
2603 * IPython/iplib.py (InteractiveShell.atexit_operations): new
2599 center for cleanup. Registered with atexit.register(). I moved
2604 center for cleanup. Registered with atexit.register(). I moved
2600 here the old exit_cleanup(). After a patch by Ville.
2605 here the old exit_cleanup(). After a patch by Ville.
2601
2606
2602 * IPython/Magic.py (get_py_filename): added '~' to the accepted
2607 * IPython/Magic.py (get_py_filename): added '~' to the accepted
2603 characters in the hacked shlex_split for python 2.2.
2608 characters in the hacked shlex_split for python 2.2.
2604
2609
2605 * IPython/iplib.py (file_matches): more fixes to filenames with
2610 * IPython/iplib.py (file_matches): more fixes to filenames with
2606 whitespace in them. It's not perfect, but limitations in python's
2611 whitespace in them. It's not perfect, but limitations in python's
2607 readline make it impossible to go further.
2612 readline make it impossible to go further.
2608
2613
2609 2004-06-29 Fernando Perez <fperez@colorado.edu>
2614 2004-06-29 Fernando Perez <fperez@colorado.edu>
2610
2615
2611 * IPython/iplib.py (file_matches): escape whitespace correctly in
2616 * IPython/iplib.py (file_matches): escape whitespace correctly in
2612 filename completions. Bug reported by Ville.
2617 filename completions. Bug reported by Ville.
2613
2618
2614 2004-06-28 Fernando Perez <fperez@colorado.edu>
2619 2004-06-28 Fernando Perez <fperez@colorado.edu>
2615
2620
2616 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
2621 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
2617 the history file will be called 'history-PROFNAME' (or just
2622 the history file will be called 'history-PROFNAME' (or just
2618 'history' if no profile is loaded). I was getting annoyed at
2623 'history' if no profile is loaded). I was getting annoyed at
2619 getting my Numerical work history clobbered by pysh sessions.
2624 getting my Numerical work history clobbered by pysh sessions.
2620
2625
2621 * IPython/iplib.py (InteractiveShell.__init__): Internal
2626 * IPython/iplib.py (InteractiveShell.__init__): Internal
2622 getoutputerror() function so that we can honor the system_verbose
2627 getoutputerror() function so that we can honor the system_verbose
2623 flag for _all_ system calls. I also added escaping of #
2628 flag for _all_ system calls. I also added escaping of #
2624 characters here to avoid confusing Itpl.
2629 characters here to avoid confusing Itpl.
2625
2630
2626 * IPython/Magic.py (shlex_split): removed call to shell in
2631 * IPython/Magic.py (shlex_split): removed call to shell in
2627 parse_options and replaced it with shlex.split(). The annoying
2632 parse_options and replaced it with shlex.split(). The annoying
2628 part was that in Python 2.2, shlex.split() doesn't exist, so I had
2633 part was that in Python 2.2, shlex.split() doesn't exist, so I had
2629 to backport it from 2.3, with several frail hacks (the shlex
2634 to backport it from 2.3, with several frail hacks (the shlex
2630 module is rather limited in 2.2). Thanks to a suggestion by Ville
2635 module is rather limited in 2.2). Thanks to a suggestion by Ville
2631 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
2636 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
2632 problem.
2637 problem.
2633
2638
2634 (Magic.magic_system_verbose): new toggle to print the actual
2639 (Magic.magic_system_verbose): new toggle to print the actual
2635 system calls made by ipython. Mainly for debugging purposes.
2640 system calls made by ipython. Mainly for debugging purposes.
2636
2641
2637 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
2642 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
2638 doesn't support persistence. Reported (and fix suggested) by
2643 doesn't support persistence. Reported (and fix suggested) by
2639 Travis Caldwell <travis_caldwell2000@yahoo.com>.
2644 Travis Caldwell <travis_caldwell2000@yahoo.com>.
2640
2645
2641 2004-06-26 Fernando Perez <fperez@colorado.edu>
2646 2004-06-26 Fernando Perez <fperez@colorado.edu>
2642
2647
2643 * IPython/Logger.py (Logger.log): fix to handle correctly empty
2648 * IPython/Logger.py (Logger.log): fix to handle correctly empty
2644 continue prompts.
2649 continue prompts.
2645
2650
2646 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
2651 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
2647 function (basically a big docstring) and a few more things here to
2652 function (basically a big docstring) and a few more things here to
2648 speedup startup. pysh.py is now very lightweight. We want because
2653 speedup startup. pysh.py is now very lightweight. We want because
2649 it gets execfile'd, while InterpreterExec gets imported, so
2654 it gets execfile'd, while InterpreterExec gets imported, so
2650 byte-compilation saves time.
2655 byte-compilation saves time.
2651
2656
2652 2004-06-25 Fernando Perez <fperez@colorado.edu>
2657 2004-06-25 Fernando Perez <fperez@colorado.edu>
2653
2658
2654 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
2659 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
2655 -NUM', which was recently broken.
2660 -NUM', which was recently broken.
2656
2661
2657 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
2662 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
2658 in multi-line input (but not !!, which doesn't make sense there).
2663 in multi-line input (but not !!, which doesn't make sense there).
2659
2664
2660 * IPython/UserConfig/ipythonrc: made autoindent on by default.
2665 * IPython/UserConfig/ipythonrc: made autoindent on by default.
2661 It's just too useful, and people can turn it off in the less
2666 It's just too useful, and people can turn it off in the less
2662 common cases where it's a problem.
2667 common cases where it's a problem.
2663
2668
2664 2004-06-24 Fernando Perez <fperez@colorado.edu>
2669 2004-06-24 Fernando Perez <fperez@colorado.edu>
2665
2670
2666 * IPython/iplib.py (InteractiveShell._prefilter): big change -
2671 * IPython/iplib.py (InteractiveShell._prefilter): big change -
2667 special syntaxes (like alias calling) is now allied in multi-line
2672 special syntaxes (like alias calling) is now allied in multi-line
2668 input. This is still _very_ experimental, but it's necessary for
2673 input. This is still _very_ experimental, but it's necessary for
2669 efficient shell usage combining python looping syntax with system
2674 efficient shell usage combining python looping syntax with system
2670 calls. For now it's restricted to aliases, I don't think it
2675 calls. For now it's restricted to aliases, I don't think it
2671 really even makes sense to have this for magics.
2676 really even makes sense to have this for magics.
2672
2677
2673 2004-06-23 Fernando Perez <fperez@colorado.edu>
2678 2004-06-23 Fernando Perez <fperez@colorado.edu>
2674
2679
2675 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
2680 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
2676 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
2681 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
2677
2682
2678 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
2683 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
2679 extensions under Windows (after code sent by Gary Bishop). The
2684 extensions under Windows (after code sent by Gary Bishop). The
2680 extensions considered 'executable' are stored in IPython's rc
2685 extensions considered 'executable' are stored in IPython's rc
2681 structure as win_exec_ext.
2686 structure as win_exec_ext.
2682
2687
2683 * IPython/genutils.py (shell): new function, like system() but
2688 * IPython/genutils.py (shell): new function, like system() but
2684 without return value. Very useful for interactive shell work.
2689 without return value. Very useful for interactive shell work.
2685
2690
2686 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
2691 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
2687 delete aliases.
2692 delete aliases.
2688
2693
2689 * IPython/iplib.py (InteractiveShell.alias_table_update): make
2694 * IPython/iplib.py (InteractiveShell.alias_table_update): make
2690 sure that the alias table doesn't contain python keywords.
2695 sure that the alias table doesn't contain python keywords.
2691
2696
2692 2004-06-21 Fernando Perez <fperez@colorado.edu>
2697 2004-06-21 Fernando Perez <fperez@colorado.edu>
2693
2698
2694 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
2699 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
2695 non-existent items are found in $PATH. Reported by Thorsten.
2700 non-existent items are found in $PATH. Reported by Thorsten.
2696
2701
2697 2004-06-20 Fernando Perez <fperez@colorado.edu>
2702 2004-06-20 Fernando Perez <fperez@colorado.edu>
2698
2703
2699 * IPython/iplib.py (complete): modified the completer so that the
2704 * IPython/iplib.py (complete): modified the completer so that the
2700 order of priorities can be easily changed at runtime.
2705 order of priorities can be easily changed at runtime.
2701
2706
2702 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
2707 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
2703 Modified to auto-execute all lines beginning with '~', '/' or '.'.
2708 Modified to auto-execute all lines beginning with '~', '/' or '.'.
2704
2709
2705 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
2710 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
2706 expand Python variables prepended with $ in all system calls. The
2711 expand Python variables prepended with $ in all system calls. The
2707 same was done to InteractiveShell.handle_shell_escape. Now all
2712 same was done to InteractiveShell.handle_shell_escape. Now all
2708 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
2713 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
2709 expansion of python variables and expressions according to the
2714 expansion of python variables and expressions according to the
2710 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
2715 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
2711
2716
2712 Though PEP-215 has been rejected, a similar (but simpler) one
2717 Though PEP-215 has been rejected, a similar (but simpler) one
2713 seems like it will go into Python 2.4, PEP-292 -
2718 seems like it will go into Python 2.4, PEP-292 -
2714 http://www.python.org/peps/pep-0292.html.
2719 http://www.python.org/peps/pep-0292.html.
2715
2720
2716 I'll keep the full syntax of PEP-215, since IPython has since the
2721 I'll keep the full syntax of PEP-215, since IPython has since the
2717 start used Ka-Ping Yee's reference implementation discussed there
2722 start used Ka-Ping Yee's reference implementation discussed there
2718 (Itpl), and I actually like the powerful semantics it offers.
2723 (Itpl), and I actually like the powerful semantics it offers.
2719
2724
2720 In order to access normal shell variables, the $ has to be escaped
2725 In order to access normal shell variables, the $ has to be escaped
2721 via an extra $. For example:
2726 via an extra $. For example:
2722
2727
2723 In [7]: PATH='a python variable'
2728 In [7]: PATH='a python variable'
2724
2729
2725 In [8]: !echo $PATH
2730 In [8]: !echo $PATH
2726 a python variable
2731 a python variable
2727
2732
2728 In [9]: !echo $$PATH
2733 In [9]: !echo $$PATH
2729 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
2734 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
2730
2735
2731 (Magic.parse_options): escape $ so the shell doesn't evaluate
2736 (Magic.parse_options): escape $ so the shell doesn't evaluate
2732 things prematurely.
2737 things prematurely.
2733
2738
2734 * IPython/iplib.py (InteractiveShell.call_alias): added the
2739 * IPython/iplib.py (InteractiveShell.call_alias): added the
2735 ability for aliases to expand python variables via $.
2740 ability for aliases to expand python variables via $.
2736
2741
2737 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
2742 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
2738 system, now there's a @rehash/@rehashx pair of magics. These work
2743 system, now there's a @rehash/@rehashx pair of magics. These work
2739 like the csh rehash command, and can be invoked at any time. They
2744 like the csh rehash command, and can be invoked at any time. They
2740 build a table of aliases to everything in the user's $PATH
2745 build a table of aliases to everything in the user's $PATH
2741 (@rehash uses everything, @rehashx is slower but only adds
2746 (@rehash uses everything, @rehashx is slower but only adds
2742 executable files). With this, the pysh.py-based shell profile can
2747 executable files). With this, the pysh.py-based shell profile can
2743 now simply call rehash upon startup, and full access to all
2748 now simply call rehash upon startup, and full access to all
2744 programs in the user's path is obtained.
2749 programs in the user's path is obtained.
2745
2750
2746 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
2751 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
2747 functionality is now fully in place. I removed the old dynamic
2752 functionality is now fully in place. I removed the old dynamic
2748 code generation based approach, in favor of a much lighter one
2753 code generation based approach, in favor of a much lighter one
2749 based on a simple dict. The advantage is that this allows me to
2754 based on a simple dict. The advantage is that this allows me to
2750 now have thousands of aliases with negligible cost (unthinkable
2755 now have thousands of aliases with negligible cost (unthinkable
2751 with the old system).
2756 with the old system).
2752
2757
2753 2004-06-19 Fernando Perez <fperez@colorado.edu>
2758 2004-06-19 Fernando Perez <fperez@colorado.edu>
2754
2759
2755 * IPython/iplib.py (__init__): extended MagicCompleter class to
2760 * IPython/iplib.py (__init__): extended MagicCompleter class to
2756 also complete (last in priority) on user aliases.
2761 also complete (last in priority) on user aliases.
2757
2762
2758 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
2763 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
2759 call to eval.
2764 call to eval.
2760 (ItplNS.__init__): Added a new class which functions like Itpl,
2765 (ItplNS.__init__): Added a new class which functions like Itpl,
2761 but allows configuring the namespace for the evaluation to occur
2766 but allows configuring the namespace for the evaluation to occur
2762 in.
2767 in.
2763
2768
2764 2004-06-18 Fernando Perez <fperez@colorado.edu>
2769 2004-06-18 Fernando Perez <fperez@colorado.edu>
2765
2770
2766 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
2771 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
2767 better message when 'exit' or 'quit' are typed (a common newbie
2772 better message when 'exit' or 'quit' are typed (a common newbie
2768 confusion).
2773 confusion).
2769
2774
2770 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
2775 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
2771 check for Windows users.
2776 check for Windows users.
2772
2777
2773 * IPython/iplib.py (InteractiveShell.user_setup): removed
2778 * IPython/iplib.py (InteractiveShell.user_setup): removed
2774 disabling of colors for Windows. I'll test at runtime and issue a
2779 disabling of colors for Windows. I'll test at runtime and issue a
2775 warning if Gary's readline isn't found, as to nudge users to
2780 warning if Gary's readline isn't found, as to nudge users to
2776 download it.
2781 download it.
2777
2782
2778 2004-06-16 Fernando Perez <fperez@colorado.edu>
2783 2004-06-16 Fernando Perez <fperez@colorado.edu>
2779
2784
2780 * IPython/genutils.py (Stream.__init__): changed to print errors
2785 * IPython/genutils.py (Stream.__init__): changed to print errors
2781 to sys.stderr. I had a circular dependency here. Now it's
2786 to sys.stderr. I had a circular dependency here. Now it's
2782 possible to run ipython as IDLE's shell (consider this pre-alpha,
2787 possible to run ipython as IDLE's shell (consider this pre-alpha,
2783 since true stdout things end up in the starting terminal instead
2788 since true stdout things end up in the starting terminal instead
2784 of IDLE's out).
2789 of IDLE's out).
2785
2790
2786 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
2791 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
2787 users who haven't # updated their prompt_in2 definitions. Remove
2792 users who haven't # updated their prompt_in2 definitions. Remove
2788 eventually.
2793 eventually.
2789 (multiple_replace): added credit to original ASPN recipe.
2794 (multiple_replace): added credit to original ASPN recipe.
2790
2795
2791 2004-06-15 Fernando Perez <fperez@colorado.edu>
2796 2004-06-15 Fernando Perez <fperez@colorado.edu>
2792
2797
2793 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
2798 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
2794 list of auto-defined aliases.
2799 list of auto-defined aliases.
2795
2800
2796 2004-06-13 Fernando Perez <fperez@colorado.edu>
2801 2004-06-13 Fernando Perez <fperez@colorado.edu>
2797
2802
2798 * setup.py (scriptfiles): Don't trigger win_post_install unless an
2803 * setup.py (scriptfiles): Don't trigger win_post_install unless an
2799 install was really requested (so setup.py can be used for other
2804 install was really requested (so setup.py can be used for other
2800 things under Windows).
2805 things under Windows).
2801
2806
2802 2004-06-10 Fernando Perez <fperez@colorado.edu>
2807 2004-06-10 Fernando Perez <fperez@colorado.edu>
2803
2808
2804 * IPython/Logger.py (Logger.create_log): Manually remove any old
2809 * IPython/Logger.py (Logger.create_log): Manually remove any old
2805 backup, since os.remove may fail under Windows. Fixes bug
2810 backup, since os.remove may fail under Windows. Fixes bug
2806 reported by Thorsten.
2811 reported by Thorsten.
2807
2812
2808 2004-06-09 Fernando Perez <fperez@colorado.edu>
2813 2004-06-09 Fernando Perez <fperez@colorado.edu>
2809
2814
2810 * examples/example-embed.py: fixed all references to %n (replaced
2815 * examples/example-embed.py: fixed all references to %n (replaced
2811 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
2816 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
2812 for all examples and the manual as well.
2817 for all examples and the manual as well.
2813
2818
2814 2004-06-08 Fernando Perez <fperez@colorado.edu>
2819 2004-06-08 Fernando Perez <fperez@colorado.edu>
2815
2820
2816 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
2821 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
2817 alignment and color management. All 3 prompt subsystems now
2822 alignment and color management. All 3 prompt subsystems now
2818 inherit from BasePrompt.
2823 inherit from BasePrompt.
2819
2824
2820 * tools/release: updates for windows installer build and tag rpms
2825 * tools/release: updates for windows installer build and tag rpms
2821 with python version (since paths are fixed).
2826 with python version (since paths are fixed).
2822
2827
2823 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
2828 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
2824 which will become eventually obsolete. Also fixed the default
2829 which will become eventually obsolete. Also fixed the default
2825 prompt_in2 to use \D, so at least new users start with the correct
2830 prompt_in2 to use \D, so at least new users start with the correct
2826 defaults.
2831 defaults.
2827 WARNING: Users with existing ipythonrc files will need to apply
2832 WARNING: Users with existing ipythonrc files will need to apply
2828 this fix manually!
2833 this fix manually!
2829
2834
2830 * setup.py: make windows installer (.exe). This is finally the
2835 * setup.py: make windows installer (.exe). This is finally the
2831 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
2836 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
2832 which I hadn't included because it required Python 2.3 (or recent
2837 which I hadn't included because it required Python 2.3 (or recent
2833 distutils).
2838 distutils).
2834
2839
2835 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
2840 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
2836 usage of new '\D' escape.
2841 usage of new '\D' escape.
2837
2842
2838 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
2843 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
2839 lacks os.getuid())
2844 lacks os.getuid())
2840 (CachedOutput.set_colors): Added the ability to turn coloring
2845 (CachedOutput.set_colors): Added the ability to turn coloring
2841 on/off with @colors even for manually defined prompt colors. It
2846 on/off with @colors even for manually defined prompt colors. It
2842 uses a nasty global, but it works safely and via the generic color
2847 uses a nasty global, but it works safely and via the generic color
2843 handling mechanism.
2848 handling mechanism.
2844 (Prompt2.__init__): Introduced new escape '\D' for continuation
2849 (Prompt2.__init__): Introduced new escape '\D' for continuation
2845 prompts. It represents the counter ('\#') as dots.
2850 prompts. It represents the counter ('\#') as dots.
2846 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
2851 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
2847 need to update their ipythonrc files and replace '%n' with '\D' in
2852 need to update their ipythonrc files and replace '%n' with '\D' in
2848 their prompt_in2 settings everywhere. Sorry, but there's
2853 their prompt_in2 settings everywhere. Sorry, but there's
2849 otherwise no clean way to get all prompts to properly align. The
2854 otherwise no clean way to get all prompts to properly align. The
2850 ipythonrc shipped with IPython has been updated.
2855 ipythonrc shipped with IPython has been updated.
2851
2856
2852 2004-06-07 Fernando Perez <fperez@colorado.edu>
2857 2004-06-07 Fernando Perez <fperez@colorado.edu>
2853
2858
2854 * setup.py (isfile): Pass local_icons option to latex2html, so the
2859 * setup.py (isfile): Pass local_icons option to latex2html, so the
2855 resulting HTML file is self-contained. Thanks to
2860 resulting HTML file is self-contained. Thanks to
2856 dryice-AT-liu.com.cn for the tip.
2861 dryice-AT-liu.com.cn for the tip.
2857
2862
2858 * pysh.py: I created a new profile 'shell', which implements a
2863 * pysh.py: I created a new profile 'shell', which implements a
2859 _rudimentary_ IPython-based shell. This is in NO WAY a realy
2864 _rudimentary_ IPython-based shell. This is in NO WAY a realy
2860 system shell, nor will it become one anytime soon. It's mainly
2865 system shell, nor will it become one anytime soon. It's mainly
2861 meant to illustrate the use of the new flexible bash-like prompts.
2866 meant to illustrate the use of the new flexible bash-like prompts.
2862 I guess it could be used by hardy souls for true shell management,
2867 I guess it could be used by hardy souls for true shell management,
2863 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
2868 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
2864 profile. This uses the InterpreterExec extension provided by
2869 profile. This uses the InterpreterExec extension provided by
2865 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
2870 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
2866
2871
2867 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
2872 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
2868 auto-align itself with the length of the previous input prompt
2873 auto-align itself with the length of the previous input prompt
2869 (taking into account the invisible color escapes).
2874 (taking into account the invisible color escapes).
2870 (CachedOutput.__init__): Large restructuring of this class. Now
2875 (CachedOutput.__init__): Large restructuring of this class. Now
2871 all three prompts (primary1, primary2, output) are proper objects,
2876 all three prompts (primary1, primary2, output) are proper objects,
2872 managed by the 'parent' CachedOutput class. The code is still a
2877 managed by the 'parent' CachedOutput class. The code is still a
2873 bit hackish (all prompts share state via a pointer to the cache),
2878 bit hackish (all prompts share state via a pointer to the cache),
2874 but it's overall far cleaner than before.
2879 but it's overall far cleaner than before.
2875
2880
2876 * IPython/genutils.py (getoutputerror): modified to add verbose,
2881 * IPython/genutils.py (getoutputerror): modified to add verbose,
2877 debug and header options. This makes the interface of all getout*
2882 debug and header options. This makes the interface of all getout*
2878 functions uniform.
2883 functions uniform.
2879 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
2884 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
2880
2885
2881 * IPython/Magic.py (Magic.default_option): added a function to
2886 * IPython/Magic.py (Magic.default_option): added a function to
2882 allow registering default options for any magic command. This
2887 allow registering default options for any magic command. This
2883 makes it easy to have profiles which customize the magics globally
2888 makes it easy to have profiles which customize the magics globally
2884 for a certain use. The values set through this function are
2889 for a certain use. The values set through this function are
2885 picked up by the parse_options() method, which all magics should
2890 picked up by the parse_options() method, which all magics should
2886 use to parse their options.
2891 use to parse their options.
2887
2892
2888 * IPython/genutils.py (warn): modified the warnings framework to
2893 * IPython/genutils.py (warn): modified the warnings framework to
2889 use the Term I/O class. I'm trying to slowly unify all of
2894 use the Term I/O class. I'm trying to slowly unify all of
2890 IPython's I/O operations to pass through Term.
2895 IPython's I/O operations to pass through Term.
2891
2896
2892 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
2897 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
2893 the secondary prompt to correctly match the length of the primary
2898 the secondary prompt to correctly match the length of the primary
2894 one for any prompt. Now multi-line code will properly line up
2899 one for any prompt. Now multi-line code will properly line up
2895 even for path dependent prompts, such as the new ones available
2900 even for path dependent prompts, such as the new ones available
2896 via the prompt_specials.
2901 via the prompt_specials.
2897
2902
2898 2004-06-06 Fernando Perez <fperez@colorado.edu>
2903 2004-06-06 Fernando Perez <fperez@colorado.edu>
2899
2904
2900 * IPython/Prompts.py (prompt_specials): Added the ability to have
2905 * IPython/Prompts.py (prompt_specials): Added the ability to have
2901 bash-like special sequences in the prompts, which get
2906 bash-like special sequences in the prompts, which get
2902 automatically expanded. Things like hostname, current working
2907 automatically expanded. Things like hostname, current working
2903 directory and username are implemented already, but it's easy to
2908 directory and username are implemented already, but it's easy to
2904 add more in the future. Thanks to a patch by W.J. van der Laan
2909 add more in the future. Thanks to a patch by W.J. van der Laan
2905 <gnufnork-AT-hetdigitalegat.nl>
2910 <gnufnork-AT-hetdigitalegat.nl>
2906 (prompt_specials): Added color support for prompt strings, so
2911 (prompt_specials): Added color support for prompt strings, so
2907 users can define arbitrary color setups for their prompts.
2912 users can define arbitrary color setups for their prompts.
2908
2913
2909 2004-06-05 Fernando Perez <fperez@colorado.edu>
2914 2004-06-05 Fernando Perez <fperez@colorado.edu>
2910
2915
2911 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
2916 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
2912 code to load Gary Bishop's readline and configure it
2917 code to load Gary Bishop's readline and configure it
2913 automatically. Thanks to Gary for help on this.
2918 automatically. Thanks to Gary for help on this.
2914
2919
2915 2004-06-01 Fernando Perez <fperez@colorado.edu>
2920 2004-06-01 Fernando Perez <fperez@colorado.edu>
2916
2921
2917 * IPython/Logger.py (Logger.create_log): fix bug for logging
2922 * IPython/Logger.py (Logger.create_log): fix bug for logging
2918 with no filename (previous fix was incomplete).
2923 with no filename (previous fix was incomplete).
2919
2924
2920 2004-05-25 Fernando Perez <fperez@colorado.edu>
2925 2004-05-25 Fernando Perez <fperez@colorado.edu>
2921
2926
2922 * IPython/Magic.py (Magic.parse_options): fix bug where naked
2927 * IPython/Magic.py (Magic.parse_options): fix bug where naked
2923 parens would get passed to the shell.
2928 parens would get passed to the shell.
2924
2929
2925 2004-05-20 Fernando Perez <fperez@colorado.edu>
2930 2004-05-20 Fernando Perez <fperez@colorado.edu>
2926
2931
2927 * IPython/Magic.py (Magic.magic_prun): changed default profile
2932 * IPython/Magic.py (Magic.magic_prun): changed default profile
2928 sort order to 'time' (the more common profiling need).
2933 sort order to 'time' (the more common profiling need).
2929
2934
2930 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
2935 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
2931 so that source code shown is guaranteed in sync with the file on
2936 so that source code shown is guaranteed in sync with the file on
2932 disk (also changed in psource). Similar fix to the one for
2937 disk (also changed in psource). Similar fix to the one for
2933 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
2938 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
2934 <yann.ledu-AT-noos.fr>.
2939 <yann.ledu-AT-noos.fr>.
2935
2940
2936 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
2941 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
2937 with a single option would not be correctly parsed. Closes
2942 with a single option would not be correctly parsed. Closes
2938 http://www.scipy.net/roundup/ipython/issue14. This bug had been
2943 http://www.scipy.net/roundup/ipython/issue14. This bug had been
2939 introduced in 0.6.0 (on 2004-05-06).
2944 introduced in 0.6.0 (on 2004-05-06).
2940
2945
2941 2004-05-13 *** Released version 0.6.0
2946 2004-05-13 *** Released version 0.6.0
2942
2947
2943 2004-05-13 Fernando Perez <fperez@colorado.edu>
2948 2004-05-13 Fernando Perez <fperez@colorado.edu>
2944
2949
2945 * debian/: Added debian/ directory to CVS, so that debian support
2950 * debian/: Added debian/ directory to CVS, so that debian support
2946 is publicly accessible. The debian package is maintained by Jack
2951 is publicly accessible. The debian package is maintained by Jack
2947 Moffit <jack-AT-xiph.org>.
2952 Moffit <jack-AT-xiph.org>.
2948
2953
2949 * Documentation: included the notes about an ipython-based system
2954 * Documentation: included the notes about an ipython-based system
2950 shell (the hypothetical 'pysh') into the new_design.pdf document,
2955 shell (the hypothetical 'pysh') into the new_design.pdf document,
2951 so that these ideas get distributed to users along with the
2956 so that these ideas get distributed to users along with the
2952 official documentation.
2957 official documentation.
2953
2958
2954 2004-05-10 Fernando Perez <fperez@colorado.edu>
2959 2004-05-10 Fernando Perez <fperez@colorado.edu>
2955
2960
2956 * IPython/Logger.py (Logger.create_log): fix recently introduced
2961 * IPython/Logger.py (Logger.create_log): fix recently introduced
2957 bug (misindented line) where logstart would fail when not given an
2962 bug (misindented line) where logstart would fail when not given an
2958 explicit filename.
2963 explicit filename.
2959
2964
2960 2004-05-09 Fernando Perez <fperez@colorado.edu>
2965 2004-05-09 Fernando Perez <fperez@colorado.edu>
2961
2966
2962 * IPython/Magic.py (Magic.parse_options): skip system call when
2967 * IPython/Magic.py (Magic.parse_options): skip system call when
2963 there are no options to look for. Faster, cleaner for the common
2968 there are no options to look for. Faster, cleaner for the common
2964 case.
2969 case.
2965
2970
2966 * Documentation: many updates to the manual: describing Windows
2971 * Documentation: many updates to the manual: describing Windows
2967 support better, Gnuplot updates, credits, misc small stuff. Also
2972 support better, Gnuplot updates, credits, misc small stuff. Also
2968 updated the new_design doc a bit.
2973 updated the new_design doc a bit.
2969
2974
2970 2004-05-06 *** Released version 0.6.0.rc1
2975 2004-05-06 *** Released version 0.6.0.rc1
2971
2976
2972 2004-05-06 Fernando Perez <fperez@colorado.edu>
2977 2004-05-06 Fernando Perez <fperez@colorado.edu>
2973
2978
2974 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
2979 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
2975 operations to use the vastly more efficient list/''.join() method.
2980 operations to use the vastly more efficient list/''.join() method.
2976 (FormattedTB.text): Fix
2981 (FormattedTB.text): Fix
2977 http://www.scipy.net/roundup/ipython/issue12 - exception source
2982 http://www.scipy.net/roundup/ipython/issue12 - exception source
2978 extract not updated after reload. Thanks to Mike Salib
2983 extract not updated after reload. Thanks to Mike Salib
2979 <msalib-AT-mit.edu> for pinning the source of the problem.
2984 <msalib-AT-mit.edu> for pinning the source of the problem.
2980 Fortunately, the solution works inside ipython and doesn't require
2985 Fortunately, the solution works inside ipython and doesn't require
2981 any changes to python proper.
2986 any changes to python proper.
2982
2987
2983 * IPython/Magic.py (Magic.parse_options): Improved to process the
2988 * IPython/Magic.py (Magic.parse_options): Improved to process the
2984 argument list as a true shell would (by actually using the
2989 argument list as a true shell would (by actually using the
2985 underlying system shell). This way, all @magics automatically get
2990 underlying system shell). This way, all @magics automatically get
2986 shell expansion for variables. Thanks to a comment by Alex
2991 shell expansion for variables. Thanks to a comment by Alex
2987 Schmolck.
2992 Schmolck.
2988
2993
2989 2004-04-04 Fernando Perez <fperez@colorado.edu>
2994 2004-04-04 Fernando Perez <fperez@colorado.edu>
2990
2995
2991 * IPython/iplib.py (InteractiveShell.interact): Added a special
2996 * IPython/iplib.py (InteractiveShell.interact): Added a special
2992 trap for a debugger quit exception, which is basically impossible
2997 trap for a debugger quit exception, which is basically impossible
2993 to handle by normal mechanisms, given what pdb does to the stack.
2998 to handle by normal mechanisms, given what pdb does to the stack.
2994 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
2999 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
2995
3000
2996 2004-04-03 Fernando Perez <fperez@colorado.edu>
3001 2004-04-03 Fernando Perez <fperez@colorado.edu>
2997
3002
2998 * IPython/genutils.py (Term): Standardized the names of the Term
3003 * IPython/genutils.py (Term): Standardized the names of the Term
2999 class streams to cin/cout/cerr, following C++ naming conventions
3004 class streams to cin/cout/cerr, following C++ naming conventions
3000 (I can't use in/out/err because 'in' is not a valid attribute
3005 (I can't use in/out/err because 'in' is not a valid attribute
3001 name).
3006 name).
3002
3007
3003 * IPython/iplib.py (InteractiveShell.interact): don't increment
3008 * IPython/iplib.py (InteractiveShell.interact): don't increment
3004 the prompt if there's no user input. By Daniel 'Dang' Griffith
3009 the prompt if there's no user input. By Daniel 'Dang' Griffith
3005 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
3010 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
3006 Francois Pinard.
3011 Francois Pinard.
3007
3012
3008 2004-04-02 Fernando Perez <fperez@colorado.edu>
3013 2004-04-02 Fernando Perez <fperez@colorado.edu>
3009
3014
3010 * IPython/genutils.py (Stream.__init__): Modified to survive at
3015 * IPython/genutils.py (Stream.__init__): Modified to survive at
3011 least importing in contexts where stdin/out/err aren't true file
3016 least importing in contexts where stdin/out/err aren't true file
3012 objects, such as PyCrust (they lack fileno() and mode). However,
3017 objects, such as PyCrust (they lack fileno() and mode). However,
3013 the recovery facilities which rely on these things existing will
3018 the recovery facilities which rely on these things existing will
3014 not work.
3019 not work.
3015
3020
3016 2004-04-01 Fernando Perez <fperez@colorado.edu>
3021 2004-04-01 Fernando Perez <fperez@colorado.edu>
3017
3022
3018 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
3023 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
3019 use the new getoutputerror() function, so it properly
3024 use the new getoutputerror() function, so it properly
3020 distinguishes stdout/err.
3025 distinguishes stdout/err.
3021
3026
3022 * IPython/genutils.py (getoutputerror): added a function to
3027 * IPython/genutils.py (getoutputerror): added a function to
3023 capture separately the standard output and error of a command.
3028 capture separately the standard output and error of a command.
3024 After a comment from dang on the mailing lists. This code is
3029 After a comment from dang on the mailing lists. This code is
3025 basically a modified version of commands.getstatusoutput(), from
3030 basically a modified version of commands.getstatusoutput(), from
3026 the standard library.
3031 the standard library.
3027
3032
3028 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
3033 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
3029 '!!' as a special syntax (shorthand) to access @sx.
3034 '!!' as a special syntax (shorthand) to access @sx.
3030
3035
3031 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
3036 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
3032 command and return its output as a list split on '\n'.
3037 command and return its output as a list split on '\n'.
3033
3038
3034 2004-03-31 Fernando Perez <fperez@colorado.edu>
3039 2004-03-31 Fernando Perez <fperez@colorado.edu>
3035
3040
3036 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
3041 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
3037 method to dictionaries used as FakeModule instances if they lack
3042 method to dictionaries used as FakeModule instances if they lack
3038 it. At least pydoc in python2.3 breaks for runtime-defined
3043 it. At least pydoc in python2.3 breaks for runtime-defined
3039 functions without this hack. At some point I need to _really_
3044 functions without this hack. At some point I need to _really_
3040 understand what FakeModule is doing, because it's a gross hack.
3045 understand what FakeModule is doing, because it's a gross hack.
3041 But it solves Arnd's problem for now...
3046 But it solves Arnd's problem for now...
3042
3047
3043 2004-02-27 Fernando Perez <fperez@colorado.edu>
3048 2004-02-27 Fernando Perez <fperez@colorado.edu>
3044
3049
3045 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
3050 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
3046 mode would behave erratically. Also increased the number of
3051 mode would behave erratically. Also increased the number of
3047 possible logs in rotate mod to 999. Thanks to Rod Holland
3052 possible logs in rotate mod to 999. Thanks to Rod Holland
3048 <rhh@StructureLABS.com> for the report and fixes.
3053 <rhh@StructureLABS.com> for the report and fixes.
3049
3054
3050 2004-02-26 Fernando Perez <fperez@colorado.edu>
3055 2004-02-26 Fernando Perez <fperez@colorado.edu>
3051
3056
3052 * IPython/genutils.py (page): Check that the curses module really
3057 * IPython/genutils.py (page): Check that the curses module really
3053 has the initscr attribute before trying to use it. For some
3058 has the initscr attribute before trying to use it. For some
3054 reason, the Solaris curses module is missing this. I think this
3059 reason, the Solaris curses module is missing this. I think this
3055 should be considered a Solaris python bug, but I'm not sure.
3060 should be considered a Solaris python bug, but I'm not sure.
3056
3061
3057 2004-01-17 Fernando Perez <fperez@colorado.edu>
3062 2004-01-17 Fernando Perez <fperez@colorado.edu>
3058
3063
3059 * IPython/genutils.py (Stream.__init__): Changes to try to make
3064 * IPython/genutils.py (Stream.__init__): Changes to try to make
3060 ipython robust against stdin/out/err being closed by the user.
3065 ipython robust against stdin/out/err being closed by the user.
3061 This is 'user error' (and blocks a normal python session, at least
3066 This is 'user error' (and blocks a normal python session, at least
3062 the stdout case). However, Ipython should be able to survive such
3067 the stdout case). However, Ipython should be able to survive such
3063 instances of abuse as gracefully as possible. To simplify the
3068 instances of abuse as gracefully as possible. To simplify the
3064 coding and maintain compatibility with Gary Bishop's Term
3069 coding and maintain compatibility with Gary Bishop's Term
3065 contributions, I've made use of classmethods for this. I think
3070 contributions, I've made use of classmethods for this. I think
3066 this introduces a dependency on python 2.2.
3071 this introduces a dependency on python 2.2.
3067
3072
3068 2004-01-13 Fernando Perez <fperez@colorado.edu>
3073 2004-01-13 Fernando Perez <fperez@colorado.edu>
3069
3074
3070 * IPython/numutils.py (exp_safe): simplified the code a bit and
3075 * IPython/numutils.py (exp_safe): simplified the code a bit and
3071 removed the need for importing the kinds module altogether.
3076 removed the need for importing the kinds module altogether.
3072
3077
3073 2004-01-06 Fernando Perez <fperez@colorado.edu>
3078 2004-01-06 Fernando Perez <fperez@colorado.edu>
3074
3079
3075 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
3080 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
3076 a magic function instead, after some community feedback. No
3081 a magic function instead, after some community feedback. No
3077 special syntax will exist for it, but its name is deliberately
3082 special syntax will exist for it, but its name is deliberately
3078 very short.
3083 very short.
3079
3084
3080 2003-12-20 Fernando Perez <fperez@colorado.edu>
3085 2003-12-20 Fernando Perez <fperez@colorado.edu>
3081
3086
3082 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
3087 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
3083 new functionality, to automagically assign the result of a shell
3088 new functionality, to automagically assign the result of a shell
3084 command to a variable. I'll solicit some community feedback on
3089 command to a variable. I'll solicit some community feedback on
3085 this before making it permanent.
3090 this before making it permanent.
3086
3091
3087 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
3092 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
3088 requested about callables for which inspect couldn't obtain a
3093 requested about callables for which inspect couldn't obtain a
3089 proper argspec. Thanks to a crash report sent by Etienne
3094 proper argspec. Thanks to a crash report sent by Etienne
3090 Posthumus <etienne-AT-apple01.cs.vu.nl>.
3095 Posthumus <etienne-AT-apple01.cs.vu.nl>.
3091
3096
3092 2003-12-09 Fernando Perez <fperez@colorado.edu>
3097 2003-12-09 Fernando Perez <fperez@colorado.edu>
3093
3098
3094 * IPython/genutils.py (page): patch for the pager to work across
3099 * IPython/genutils.py (page): patch for the pager to work across
3095 various versions of Windows. By Gary Bishop.
3100 various versions of Windows. By Gary Bishop.
3096
3101
3097 2003-12-04 Fernando Perez <fperez@colorado.edu>
3102 2003-12-04 Fernando Perez <fperez@colorado.edu>
3098
3103
3099 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
3104 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
3100 Gnuplot.py version 1.7, whose internal names changed quite a bit.
3105 Gnuplot.py version 1.7, whose internal names changed quite a bit.
3101 While I tested this and it looks ok, there may still be corner
3106 While I tested this and it looks ok, there may still be corner
3102 cases I've missed.
3107 cases I've missed.
3103
3108
3104 2003-12-01 Fernando Perez <fperez@colorado.edu>
3109 2003-12-01 Fernando Perez <fperez@colorado.edu>
3105
3110
3106 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
3111 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
3107 where a line like 'p,q=1,2' would fail because the automagic
3112 where a line like 'p,q=1,2' would fail because the automagic
3108 system would be triggered for @p.
3113 system would be triggered for @p.
3109
3114
3110 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
3115 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
3111 cleanups, code unmodified.
3116 cleanups, code unmodified.
3112
3117
3113 * IPython/genutils.py (Term): added a class for IPython to handle
3118 * IPython/genutils.py (Term): added a class for IPython to handle
3114 output. In most cases it will just be a proxy for stdout/err, but
3119 output. In most cases it will just be a proxy for stdout/err, but
3115 having this allows modifications to be made for some platforms,
3120 having this allows modifications to be made for some platforms,
3116 such as handling color escapes under Windows. All of this code
3121 such as handling color escapes under Windows. All of this code
3117 was contributed by Gary Bishop, with minor modifications by me.
3122 was contributed by Gary Bishop, with minor modifications by me.
3118 The actual changes affect many files.
3123 The actual changes affect many files.
3119
3124
3120 2003-11-30 Fernando Perez <fperez@colorado.edu>
3125 2003-11-30 Fernando Perez <fperez@colorado.edu>
3121
3126
3122 * IPython/iplib.py (file_matches): new completion code, courtesy
3127 * IPython/iplib.py (file_matches): new completion code, courtesy
3123 of Jeff Collins. This enables filename completion again under
3128 of Jeff Collins. This enables filename completion again under
3124 python 2.3, which disabled it at the C level.
3129 python 2.3, which disabled it at the C level.
3125
3130
3126 2003-11-11 Fernando Perez <fperez@colorado.edu>
3131 2003-11-11 Fernando Perez <fperez@colorado.edu>
3127
3132
3128 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
3133 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
3129 for Numeric.array(map(...)), but often convenient.
3134 for Numeric.array(map(...)), but often convenient.
3130
3135
3131 2003-11-05 Fernando Perez <fperez@colorado.edu>
3136 2003-11-05 Fernando Perez <fperez@colorado.edu>
3132
3137
3133 * IPython/numutils.py (frange): Changed a call from int() to
3138 * IPython/numutils.py (frange): Changed a call from int() to
3134 int(round()) to prevent a problem reported with arange() in the
3139 int(round()) to prevent a problem reported with arange() in the
3135 numpy list.
3140 numpy list.
3136
3141
3137 2003-10-06 Fernando Perez <fperez@colorado.edu>
3142 2003-10-06 Fernando Perez <fperez@colorado.edu>
3138
3143
3139 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
3144 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
3140 prevent crashes if sys lacks an argv attribute (it happens with
3145 prevent crashes if sys lacks an argv attribute (it happens with
3141 embedded interpreters which build a bare-bones sys module).
3146 embedded interpreters which build a bare-bones sys module).
3142 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
3147 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
3143
3148
3144 2003-09-24 Fernando Perez <fperez@colorado.edu>
3149 2003-09-24 Fernando Perez <fperez@colorado.edu>
3145
3150
3146 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
3151 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
3147 to protect against poorly written user objects where __getattr__
3152 to protect against poorly written user objects where __getattr__
3148 raises exceptions other than AttributeError. Thanks to a bug
3153 raises exceptions other than AttributeError. Thanks to a bug
3149 report by Oliver Sander <osander-AT-gmx.de>.
3154 report by Oliver Sander <osander-AT-gmx.de>.
3150
3155
3151 * IPython/FakeModule.py (FakeModule.__repr__): this method was
3156 * IPython/FakeModule.py (FakeModule.__repr__): this method was
3152 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
3157 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
3153
3158
3154 2003-09-09 Fernando Perez <fperez@colorado.edu>
3159 2003-09-09 Fernando Perez <fperez@colorado.edu>
3155
3160
3156 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3161 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3157 unpacking a list whith a callable as first element would
3162 unpacking a list whith a callable as first element would
3158 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
3163 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
3159 Collins.
3164 Collins.
3160
3165
3161 2003-08-25 *** Released version 0.5.0
3166 2003-08-25 *** Released version 0.5.0
3162
3167
3163 2003-08-22 Fernando Perez <fperez@colorado.edu>
3168 2003-08-22 Fernando Perez <fperez@colorado.edu>
3164
3169
3165 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
3170 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
3166 improperly defined user exceptions. Thanks to feedback from Mark
3171 improperly defined user exceptions. Thanks to feedback from Mark
3167 Russell <mrussell-AT-verio.net>.
3172 Russell <mrussell-AT-verio.net>.
3168
3173
3169 2003-08-20 Fernando Perez <fperez@colorado.edu>
3174 2003-08-20 Fernando Perez <fperez@colorado.edu>
3170
3175
3171 * IPython/OInspect.py (Inspector.pinfo): changed String Form
3176 * IPython/OInspect.py (Inspector.pinfo): changed String Form
3172 printing so that it would print multi-line string forms starting
3177 printing so that it would print multi-line string forms starting
3173 with a new line. This way the formatting is better respected for
3178 with a new line. This way the formatting is better respected for
3174 objects which work hard to make nice string forms.
3179 objects which work hard to make nice string forms.
3175
3180
3176 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
3181 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
3177 autocall would overtake data access for objects with both
3182 autocall would overtake data access for objects with both
3178 __getitem__ and __call__.
3183 __getitem__ and __call__.
3179
3184
3180 2003-08-19 *** Released version 0.5.0-rc1
3185 2003-08-19 *** Released version 0.5.0-rc1
3181
3186
3182 2003-08-19 Fernando Perez <fperez@colorado.edu>
3187 2003-08-19 Fernando Perez <fperez@colorado.edu>
3183
3188
3184 * IPython/deep_reload.py (load_tail): single tiny change here
3189 * IPython/deep_reload.py (load_tail): single tiny change here
3185 seems to fix the long-standing bug of dreload() failing to work
3190 seems to fix the long-standing bug of dreload() failing to work
3186 for dotted names. But this module is pretty tricky, so I may have
3191 for dotted names. But this module is pretty tricky, so I may have
3187 missed some subtlety. Needs more testing!.
3192 missed some subtlety. Needs more testing!.
3188
3193
3189 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
3194 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
3190 exceptions which have badly implemented __str__ methods.
3195 exceptions which have badly implemented __str__ methods.
3191 (VerboseTB.text): harden against inspect.getinnerframes crashing,
3196 (VerboseTB.text): harden against inspect.getinnerframes crashing,
3192 which I've been getting reports about from Python 2.3 users. I
3197 which I've been getting reports about from Python 2.3 users. I
3193 wish I had a simple test case to reproduce the problem, so I could
3198 wish I had a simple test case to reproduce the problem, so I could
3194 either write a cleaner workaround or file a bug report if
3199 either write a cleaner workaround or file a bug report if
3195 necessary.
3200 necessary.
3196
3201
3197 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
3202 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
3198 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
3203 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
3199 a bug report by Tjabo Kloppenburg.
3204 a bug report by Tjabo Kloppenburg.
3200
3205
3201 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
3206 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
3202 crashes. Wrapped the pdb call in a blanket try/except, since pdb
3207 crashes. Wrapped the pdb call in a blanket try/except, since pdb
3203 seems rather unstable. Thanks to a bug report by Tjabo
3208 seems rather unstable. Thanks to a bug report by Tjabo
3204 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
3209 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
3205
3210
3206 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
3211 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
3207 this out soon because of the critical fixes in the inner loop for
3212 this out soon because of the critical fixes in the inner loop for
3208 generators.
3213 generators.
3209
3214
3210 * IPython/Magic.py (Magic.getargspec): removed. This (and
3215 * IPython/Magic.py (Magic.getargspec): removed. This (and
3211 _get_def) have been obsoleted by OInspect for a long time, I
3216 _get_def) have been obsoleted by OInspect for a long time, I
3212 hadn't noticed that they were dead code.
3217 hadn't noticed that they were dead code.
3213 (Magic._ofind): restored _ofind functionality for a few literals
3218 (Magic._ofind): restored _ofind functionality for a few literals
3214 (those in ["''",'""','[]','{}','()']). But it won't work anymore
3219 (those in ["''",'""','[]','{}','()']). But it won't work anymore
3215 for things like "hello".capitalize?, since that would require a
3220 for things like "hello".capitalize?, since that would require a
3216 potentially dangerous eval() again.
3221 potentially dangerous eval() again.
3217
3222
3218 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
3223 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
3219 logic a bit more to clean up the escapes handling and minimize the
3224 logic a bit more to clean up the escapes handling and minimize the
3220 use of _ofind to only necessary cases. The interactive 'feel' of
3225 use of _ofind to only necessary cases. The interactive 'feel' of
3221 IPython should have improved quite a bit with the changes in
3226 IPython should have improved quite a bit with the changes in
3222 _prefilter and _ofind (besides being far safer than before).
3227 _prefilter and _ofind (besides being far safer than before).
3223
3228
3224 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
3229 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
3225 obscure, never reported). Edit would fail to find the object to
3230 obscure, never reported). Edit would fail to find the object to
3226 edit under some circumstances.
3231 edit under some circumstances.
3227 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
3232 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
3228 which were causing double-calling of generators. Those eval calls
3233 which were causing double-calling of generators. Those eval calls
3229 were _very_ dangerous, since code with side effects could be
3234 were _very_ dangerous, since code with side effects could be
3230 triggered. As they say, 'eval is evil'... These were the
3235 triggered. As they say, 'eval is evil'... These were the
3231 nastiest evals in IPython. Besides, _ofind is now far simpler,
3236 nastiest evals in IPython. Besides, _ofind is now far simpler,
3232 and it should also be quite a bit faster. Its use of inspect is
3237 and it should also be quite a bit faster. Its use of inspect is
3233 also safer, so perhaps some of the inspect-related crashes I've
3238 also safer, so perhaps some of the inspect-related crashes I've
3234 seen lately with Python 2.3 might be taken care of. That will
3239 seen lately with Python 2.3 might be taken care of. That will
3235 need more testing.
3240 need more testing.
3236
3241
3237 2003-08-17 Fernando Perez <fperez@colorado.edu>
3242 2003-08-17 Fernando Perez <fperez@colorado.edu>
3238
3243
3239 * IPython/iplib.py (InteractiveShell._prefilter): significant
3244 * IPython/iplib.py (InteractiveShell._prefilter): significant
3240 simplifications to the logic for handling user escapes. Faster
3245 simplifications to the logic for handling user escapes. Faster
3241 and simpler code.
3246 and simpler code.
3242
3247
3243 2003-08-14 Fernando Perez <fperez@colorado.edu>
3248 2003-08-14 Fernando Perez <fperez@colorado.edu>
3244
3249
3245 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
3250 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
3246 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
3251 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
3247 but it should be quite a bit faster. And the recursive version
3252 but it should be quite a bit faster. And the recursive version
3248 generated O(log N) intermediate storage for all rank>1 arrays,
3253 generated O(log N) intermediate storage for all rank>1 arrays,
3249 even if they were contiguous.
3254 even if they were contiguous.
3250 (l1norm): Added this function.
3255 (l1norm): Added this function.
3251 (norm): Added this function for arbitrary norms (including
3256 (norm): Added this function for arbitrary norms (including
3252 l-infinity). l1 and l2 are still special cases for convenience
3257 l-infinity). l1 and l2 are still special cases for convenience
3253 and speed.
3258 and speed.
3254
3259
3255 2003-08-03 Fernando Perez <fperez@colorado.edu>
3260 2003-08-03 Fernando Perez <fperez@colorado.edu>
3256
3261
3257 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
3262 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
3258 exceptions, which now raise PendingDeprecationWarnings in Python
3263 exceptions, which now raise PendingDeprecationWarnings in Python
3259 2.3. There were some in Magic and some in Gnuplot2.
3264 2.3. There were some in Magic and some in Gnuplot2.
3260
3265
3261 2003-06-30 Fernando Perez <fperez@colorado.edu>
3266 2003-06-30 Fernando Perez <fperez@colorado.edu>
3262
3267
3263 * IPython/genutils.py (page): modified to call curses only for
3268 * IPython/genutils.py (page): modified to call curses only for
3264 terminals where TERM=='xterm'. After problems under many other
3269 terminals where TERM=='xterm'. After problems under many other
3265 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
3270 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
3266
3271
3267 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
3272 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
3268 would be triggered when readline was absent. This was just an old
3273 would be triggered when readline was absent. This was just an old
3269 debugging statement I'd forgotten to take out.
3274 debugging statement I'd forgotten to take out.
3270
3275
3271 2003-06-20 Fernando Perez <fperez@colorado.edu>
3276 2003-06-20 Fernando Perez <fperez@colorado.edu>
3272
3277
3273 * IPython/genutils.py (clock): modified to return only user time
3278 * IPython/genutils.py (clock): modified to return only user time
3274 (not counting system time), after a discussion on scipy. While
3279 (not counting system time), after a discussion on scipy. While
3275 system time may be a useful quantity occasionally, it may much
3280 system time may be a useful quantity occasionally, it may much
3276 more easily be skewed by occasional swapping or other similar
3281 more easily be skewed by occasional swapping or other similar
3277 activity.
3282 activity.
3278
3283
3279 2003-06-05 Fernando Perez <fperez@colorado.edu>
3284 2003-06-05 Fernando Perez <fperez@colorado.edu>
3280
3285
3281 * IPython/numutils.py (identity): new function, for building
3286 * IPython/numutils.py (identity): new function, for building
3282 arbitrary rank Kronecker deltas (mostly backwards compatible with
3287 arbitrary rank Kronecker deltas (mostly backwards compatible with
3283 Numeric.identity)
3288 Numeric.identity)
3284
3289
3285 2003-06-03 Fernando Perez <fperez@colorado.edu>
3290 2003-06-03 Fernando Perez <fperez@colorado.edu>
3286
3291
3287 * IPython/iplib.py (InteractiveShell.handle_magic): protect
3292 * IPython/iplib.py (InteractiveShell.handle_magic): protect
3288 arguments passed to magics with spaces, to allow trailing '\' to
3293 arguments passed to magics with spaces, to allow trailing '\' to
3289 work normally (mainly for Windows users).
3294 work normally (mainly for Windows users).
3290
3295
3291 2003-05-29 Fernando Perez <fperez@colorado.edu>
3296 2003-05-29 Fernando Perez <fperez@colorado.edu>
3292
3297
3293 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
3298 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
3294 instead of pydoc.help. This fixes a bizarre behavior where
3299 instead of pydoc.help. This fixes a bizarre behavior where
3295 printing '%s' % locals() would trigger the help system. Now
3300 printing '%s' % locals() would trigger the help system. Now
3296 ipython behaves like normal python does.
3301 ipython behaves like normal python does.
3297
3302
3298 Note that if one does 'from pydoc import help', the bizarre
3303 Note that if one does 'from pydoc import help', the bizarre
3299 behavior returns, but this will also happen in normal python, so
3304 behavior returns, but this will also happen in normal python, so
3300 it's not an ipython bug anymore (it has to do with how pydoc.help
3305 it's not an ipython bug anymore (it has to do with how pydoc.help
3301 is implemented).
3306 is implemented).
3302
3307
3303 2003-05-22 Fernando Perez <fperez@colorado.edu>
3308 2003-05-22 Fernando Perez <fperez@colorado.edu>
3304
3309
3305 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
3310 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
3306 return [] instead of None when nothing matches, also match to end
3311 return [] instead of None when nothing matches, also match to end
3307 of line. Patch by Gary Bishop.
3312 of line. Patch by Gary Bishop.
3308
3313
3309 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
3314 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
3310 protection as before, for files passed on the command line. This
3315 protection as before, for files passed on the command line. This
3311 prevents the CrashHandler from kicking in if user files call into
3316 prevents the CrashHandler from kicking in if user files call into
3312 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
3317 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
3313 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
3318 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
3314
3319
3315 2003-05-20 *** Released version 0.4.0
3320 2003-05-20 *** Released version 0.4.0
3316
3321
3317 2003-05-20 Fernando Perez <fperez@colorado.edu>
3322 2003-05-20 Fernando Perez <fperez@colorado.edu>
3318
3323
3319 * setup.py: added support for manpages. It's a bit hackish b/c of
3324 * setup.py: added support for manpages. It's a bit hackish b/c of
3320 a bug in the way the bdist_rpm distutils target handles gzipped
3325 a bug in the way the bdist_rpm distutils target handles gzipped
3321 manpages, but it works. After a patch by Jack.
3326 manpages, but it works. After a patch by Jack.
3322
3327
3323 2003-05-19 Fernando Perez <fperez@colorado.edu>
3328 2003-05-19 Fernando Perez <fperez@colorado.edu>
3324
3329
3325 * IPython/numutils.py: added a mockup of the kinds module, since
3330 * IPython/numutils.py: added a mockup of the kinds module, since
3326 it was recently removed from Numeric. This way, numutils will
3331 it was recently removed from Numeric. This way, numutils will
3327 work for all users even if they are missing kinds.
3332 work for all users even if they are missing kinds.
3328
3333
3329 * IPython/Magic.py (Magic._ofind): Harden against an inspect
3334 * IPython/Magic.py (Magic._ofind): Harden against an inspect
3330 failure, which can occur with SWIG-wrapped extensions. After a
3335 failure, which can occur with SWIG-wrapped extensions. After a
3331 crash report from Prabhu.
3336 crash report from Prabhu.
3332
3337
3333 2003-05-16 Fernando Perez <fperez@colorado.edu>
3338 2003-05-16 Fernando Perez <fperez@colorado.edu>
3334
3339
3335 * IPython/iplib.py (InteractiveShell.excepthook): New method to
3340 * IPython/iplib.py (InteractiveShell.excepthook): New method to
3336 protect ipython from user code which may call directly
3341 protect ipython from user code which may call directly
3337 sys.excepthook (this looks like an ipython crash to the user, even
3342 sys.excepthook (this looks like an ipython crash to the user, even
3338 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
3343 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
3339 This is especially important to help users of WxWindows, but may
3344 This is especially important to help users of WxWindows, but may
3340 also be useful in other cases.
3345 also be useful in other cases.
3341
3346
3342 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
3347 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
3343 an optional tb_offset to be specified, and to preserve exception
3348 an optional tb_offset to be specified, and to preserve exception
3344 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
3349 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
3345
3350
3346 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
3351 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
3347
3352
3348 2003-05-15 Fernando Perez <fperez@colorado.edu>
3353 2003-05-15 Fernando Perez <fperez@colorado.edu>
3349
3354
3350 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
3355 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
3351 installing for a new user under Windows.
3356 installing for a new user under Windows.
3352
3357
3353 2003-05-12 Fernando Perez <fperez@colorado.edu>
3358 2003-05-12 Fernando Perez <fperez@colorado.edu>
3354
3359
3355 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
3360 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
3356 handler for Emacs comint-based lines. Currently it doesn't do
3361 handler for Emacs comint-based lines. Currently it doesn't do
3357 much (but importantly, it doesn't update the history cache). In
3362 much (but importantly, it doesn't update the history cache). In
3358 the future it may be expanded if Alex needs more functionality
3363 the future it may be expanded if Alex needs more functionality
3359 there.
3364 there.
3360
3365
3361 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
3366 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
3362 info to crash reports.
3367 info to crash reports.
3363
3368
3364 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
3369 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
3365 just like Python's -c. Also fixed crash with invalid -color
3370 just like Python's -c. Also fixed crash with invalid -color
3366 option value at startup. Thanks to Will French
3371 option value at startup. Thanks to Will French
3367 <wfrench-AT-bestweb.net> for the bug report.
3372 <wfrench-AT-bestweb.net> for the bug report.
3368
3373
3369 2003-05-09 Fernando Perez <fperez@colorado.edu>
3374 2003-05-09 Fernando Perez <fperez@colorado.edu>
3370
3375
3371 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
3376 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
3372 to EvalDict (it's a mapping, after all) and simplified its code
3377 to EvalDict (it's a mapping, after all) and simplified its code
3373 quite a bit, after a nice discussion on c.l.py where Gustavo
3378 quite a bit, after a nice discussion on c.l.py where Gustavo
3374 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
3379 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
3375
3380
3376 2003-04-30 Fernando Perez <fperez@colorado.edu>
3381 2003-04-30 Fernando Perez <fperez@colorado.edu>
3377
3382
3378 * IPython/genutils.py (timings_out): modified it to reduce its
3383 * IPython/genutils.py (timings_out): modified it to reduce its
3379 overhead in the common reps==1 case.
3384 overhead in the common reps==1 case.
3380
3385
3381 2003-04-29 Fernando Perez <fperez@colorado.edu>
3386 2003-04-29 Fernando Perez <fperez@colorado.edu>
3382
3387
3383 * IPython/genutils.py (timings_out): Modified to use the resource
3388 * IPython/genutils.py (timings_out): Modified to use the resource
3384 module, which avoids the wraparound problems of time.clock().
3389 module, which avoids the wraparound problems of time.clock().
3385
3390
3386 2003-04-17 *** Released version 0.2.15pre4
3391 2003-04-17 *** Released version 0.2.15pre4
3387
3392
3388 2003-04-17 Fernando Perez <fperez@colorado.edu>
3393 2003-04-17 Fernando Perez <fperez@colorado.edu>
3389
3394
3390 * setup.py (scriptfiles): Split windows-specific stuff over to a
3395 * setup.py (scriptfiles): Split windows-specific stuff over to a
3391 separate file, in an attempt to have a Windows GUI installer.
3396 separate file, in an attempt to have a Windows GUI installer.
3392 That didn't work, but part of the groundwork is done.
3397 That didn't work, but part of the groundwork is done.
3393
3398
3394 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
3399 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
3395 indent/unindent with 4 spaces. Particularly useful in combination
3400 indent/unindent with 4 spaces. Particularly useful in combination
3396 with the new auto-indent option.
3401 with the new auto-indent option.
3397
3402
3398 2003-04-16 Fernando Perez <fperez@colorado.edu>
3403 2003-04-16 Fernando Perez <fperez@colorado.edu>
3399
3404
3400 * IPython/Magic.py: various replacements of self.rc for
3405 * IPython/Magic.py: various replacements of self.rc for
3401 self.shell.rc. A lot more remains to be done to fully disentangle
3406 self.shell.rc. A lot more remains to be done to fully disentangle
3402 this class from the main Shell class.
3407 this class from the main Shell class.
3403
3408
3404 * IPython/GnuplotRuntime.py: added checks for mouse support so
3409 * IPython/GnuplotRuntime.py: added checks for mouse support so
3405 that we don't try to enable it if the current gnuplot doesn't
3410 that we don't try to enable it if the current gnuplot doesn't
3406 really support it. Also added checks so that we don't try to
3411 really support it. Also added checks so that we don't try to
3407 enable persist under Windows (where Gnuplot doesn't recognize the
3412 enable persist under Windows (where Gnuplot doesn't recognize the
3408 option).
3413 option).
3409
3414
3410 * IPython/iplib.py (InteractiveShell.interact): Added optional
3415 * IPython/iplib.py (InteractiveShell.interact): Added optional
3411 auto-indenting code, after a patch by King C. Shu
3416 auto-indenting code, after a patch by King C. Shu
3412 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
3417 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
3413 get along well with pasting indented code. If I ever figure out
3418 get along well with pasting indented code. If I ever figure out
3414 how to make that part go well, it will become on by default.
3419 how to make that part go well, it will become on by default.
3415
3420
3416 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
3421 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
3417 crash ipython if there was an unmatched '%' in the user's prompt
3422 crash ipython if there was an unmatched '%' in the user's prompt
3418 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
3423 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
3419
3424
3420 * IPython/iplib.py (InteractiveShell.interact): removed the
3425 * IPython/iplib.py (InteractiveShell.interact): removed the
3421 ability to ask the user whether he wants to crash or not at the
3426 ability to ask the user whether he wants to crash or not at the
3422 'last line' exception handler. Calling functions at that point
3427 'last line' exception handler. Calling functions at that point
3423 changes the stack, and the error reports would have incorrect
3428 changes the stack, and the error reports would have incorrect
3424 tracebacks.
3429 tracebacks.
3425
3430
3426 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
3431 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
3427 pass through a peger a pretty-printed form of any object. After a
3432 pass through a peger a pretty-printed form of any object. After a
3428 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
3433 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
3429
3434
3430 2003-04-14 Fernando Perez <fperez@colorado.edu>
3435 2003-04-14 Fernando Perez <fperez@colorado.edu>
3431
3436
3432 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
3437 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
3433 all files in ~ would be modified at first install (instead of
3438 all files in ~ would be modified at first install (instead of
3434 ~/.ipython). This could be potentially disastrous, as the
3439 ~/.ipython). This could be potentially disastrous, as the
3435 modification (make line-endings native) could damage binary files.
3440 modification (make line-endings native) could damage binary files.
3436
3441
3437 2003-04-10 Fernando Perez <fperez@colorado.edu>
3442 2003-04-10 Fernando Perez <fperez@colorado.edu>
3438
3443
3439 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
3444 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
3440 handle only lines which are invalid python. This now means that
3445 handle only lines which are invalid python. This now means that
3441 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
3446 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
3442 for the bug report.
3447 for the bug report.
3443
3448
3444 2003-04-01 Fernando Perez <fperez@colorado.edu>
3449 2003-04-01 Fernando Perez <fperez@colorado.edu>
3445
3450
3446 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
3451 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
3447 where failing to set sys.last_traceback would crash pdb.pm().
3452 where failing to set sys.last_traceback would crash pdb.pm().
3448 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
3453 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
3449 report.
3454 report.
3450
3455
3451 2003-03-25 Fernando Perez <fperez@colorado.edu>
3456 2003-03-25 Fernando Perez <fperez@colorado.edu>
3452
3457
3453 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
3458 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
3454 before printing it (it had a lot of spurious blank lines at the
3459 before printing it (it had a lot of spurious blank lines at the
3455 end).
3460 end).
3456
3461
3457 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
3462 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
3458 output would be sent 21 times! Obviously people don't use this
3463 output would be sent 21 times! Obviously people don't use this
3459 too often, or I would have heard about it.
3464 too often, or I would have heard about it.
3460
3465
3461 2003-03-24 Fernando Perez <fperez@colorado.edu>
3466 2003-03-24 Fernando Perez <fperez@colorado.edu>
3462
3467
3463 * setup.py (scriptfiles): renamed the data_files parameter from
3468 * setup.py (scriptfiles): renamed the data_files parameter from
3464 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
3469 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
3465 for the patch.
3470 for the patch.
3466
3471
3467 2003-03-20 Fernando Perez <fperez@colorado.edu>
3472 2003-03-20 Fernando Perez <fperez@colorado.edu>
3468
3473
3469 * IPython/genutils.py (error): added error() and fatal()
3474 * IPython/genutils.py (error): added error() and fatal()
3470 functions.
3475 functions.
3471
3476
3472 2003-03-18 *** Released version 0.2.15pre3
3477 2003-03-18 *** Released version 0.2.15pre3
3473
3478
3474 2003-03-18 Fernando Perez <fperez@colorado.edu>
3479 2003-03-18 Fernando Perez <fperez@colorado.edu>
3475
3480
3476 * setupext/install_data_ext.py
3481 * setupext/install_data_ext.py
3477 (install_data_ext.initialize_options): Class contributed by Jack
3482 (install_data_ext.initialize_options): Class contributed by Jack
3478 Moffit for fixing the old distutils hack. He is sending this to
3483 Moffit for fixing the old distutils hack. He is sending this to
3479 the distutils folks so in the future we may not need it as a
3484 the distutils folks so in the future we may not need it as a
3480 private fix.
3485 private fix.
3481
3486
3482 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
3487 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
3483 changes for Debian packaging. See his patch for full details.
3488 changes for Debian packaging. See his patch for full details.
3484 The old distutils hack of making the ipythonrc* files carry a
3489 The old distutils hack of making the ipythonrc* files carry a
3485 bogus .py extension is gone, at last. Examples were moved to a
3490 bogus .py extension is gone, at last. Examples were moved to a
3486 separate subdir under doc/, and the separate executable scripts
3491 separate subdir under doc/, and the separate executable scripts
3487 now live in their own directory. Overall a great cleanup. The
3492 now live in their own directory. Overall a great cleanup. The
3488 manual was updated to use the new files, and setup.py has been
3493 manual was updated to use the new files, and setup.py has been
3489 fixed for this setup.
3494 fixed for this setup.
3490
3495
3491 * IPython/PyColorize.py (Parser.usage): made non-executable and
3496 * IPython/PyColorize.py (Parser.usage): made non-executable and
3492 created a pycolor wrapper around it to be included as a script.
3497 created a pycolor wrapper around it to be included as a script.
3493
3498
3494 2003-03-12 *** Released version 0.2.15pre2
3499 2003-03-12 *** Released version 0.2.15pre2
3495
3500
3496 2003-03-12 Fernando Perez <fperez@colorado.edu>
3501 2003-03-12 Fernando Perez <fperez@colorado.edu>
3497
3502
3498 * IPython/ColorANSI.py (make_color_table): Finally fixed the
3503 * IPython/ColorANSI.py (make_color_table): Finally fixed the
3499 long-standing problem with garbage characters in some terminals.
3504 long-standing problem with garbage characters in some terminals.
3500 The issue was really that the \001 and \002 escapes must _only_ be
3505 The issue was really that the \001 and \002 escapes must _only_ be
3501 passed to input prompts (which call readline), but _never_ to
3506 passed to input prompts (which call readline), but _never_ to
3502 normal text to be printed on screen. I changed ColorANSI to have
3507 normal text to be printed on screen. I changed ColorANSI to have
3503 two classes: TermColors and InputTermColors, each with the
3508 two classes: TermColors and InputTermColors, each with the
3504 appropriate escapes for input prompts or normal text. The code in
3509 appropriate escapes for input prompts or normal text. The code in
3505 Prompts.py got slightly more complicated, but this very old and
3510 Prompts.py got slightly more complicated, but this very old and
3506 annoying bug is finally fixed.
3511 annoying bug is finally fixed.
3507
3512
3508 All the credit for nailing down the real origin of this problem
3513 All the credit for nailing down the real origin of this problem
3509 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
3514 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
3510 *Many* thanks to him for spending quite a bit of effort on this.
3515 *Many* thanks to him for spending quite a bit of effort on this.
3511
3516
3512 2003-03-05 *** Released version 0.2.15pre1
3517 2003-03-05 *** Released version 0.2.15pre1
3513
3518
3514 2003-03-03 Fernando Perez <fperez@colorado.edu>
3519 2003-03-03 Fernando Perez <fperez@colorado.edu>
3515
3520
3516 * IPython/FakeModule.py: Moved the former _FakeModule to a
3521 * IPython/FakeModule.py: Moved the former _FakeModule to a
3517 separate file, because it's also needed by Magic (to fix a similar
3522 separate file, because it's also needed by Magic (to fix a similar
3518 pickle-related issue in @run).
3523 pickle-related issue in @run).
3519
3524
3520 2003-03-02 Fernando Perez <fperez@colorado.edu>
3525 2003-03-02 Fernando Perez <fperez@colorado.edu>
3521
3526
3522 * IPython/Magic.py (Magic.magic_autocall): new magic to control
3527 * IPython/Magic.py (Magic.magic_autocall): new magic to control
3523 the autocall option at runtime.
3528 the autocall option at runtime.
3524 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
3529 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
3525 across Magic.py to start separating Magic from InteractiveShell.
3530 across Magic.py to start separating Magic from InteractiveShell.
3526 (Magic._ofind): Fixed to return proper namespace for dotted
3531 (Magic._ofind): Fixed to return proper namespace for dotted
3527 names. Before, a dotted name would always return 'not currently
3532 names. Before, a dotted name would always return 'not currently
3528 defined', because it would find the 'parent'. s.x would be found,
3533 defined', because it would find the 'parent'. s.x would be found,
3529 but since 'x' isn't defined by itself, it would get confused.
3534 but since 'x' isn't defined by itself, it would get confused.
3530 (Magic.magic_run): Fixed pickling problems reported by Ralf
3535 (Magic.magic_run): Fixed pickling problems reported by Ralf
3531 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
3536 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
3532 that I'd used when Mike Heeter reported similar issues at the
3537 that I'd used when Mike Heeter reported similar issues at the
3533 top-level, but now for @run. It boils down to injecting the
3538 top-level, but now for @run. It boils down to injecting the
3534 namespace where code is being executed with something that looks
3539 namespace where code is being executed with something that looks
3535 enough like a module to fool pickle.dump(). Since a pickle stores
3540 enough like a module to fool pickle.dump(). Since a pickle stores
3536 a named reference to the importing module, we need this for
3541 a named reference to the importing module, we need this for
3537 pickles to save something sensible.
3542 pickles to save something sensible.
3538
3543
3539 * IPython/ipmaker.py (make_IPython): added an autocall option.
3544 * IPython/ipmaker.py (make_IPython): added an autocall option.
3540
3545
3541 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
3546 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
3542 the auto-eval code. Now autocalling is an option, and the code is
3547 the auto-eval code. Now autocalling is an option, and the code is
3543 also vastly safer. There is no more eval() involved at all.
3548 also vastly safer. There is no more eval() involved at all.
3544
3549
3545 2003-03-01 Fernando Perez <fperez@colorado.edu>
3550 2003-03-01 Fernando Perez <fperez@colorado.edu>
3546
3551
3547 * IPython/Magic.py (Magic._ofind): Changed interface to return a
3552 * IPython/Magic.py (Magic._ofind): Changed interface to return a
3548 dict with named keys instead of a tuple.
3553 dict with named keys instead of a tuple.
3549
3554
3550 * IPython: Started using CVS for IPython as of 0.2.15pre1.
3555 * IPython: Started using CVS for IPython as of 0.2.15pre1.
3551
3556
3552 * setup.py (make_shortcut): Fixed message about directories
3557 * setup.py (make_shortcut): Fixed message about directories
3553 created during Windows installation (the directories were ok, just
3558 created during Windows installation (the directories were ok, just
3554 the printed message was misleading). Thanks to Chris Liechti
3559 the printed message was misleading). Thanks to Chris Liechti
3555 <cliechti-AT-gmx.net> for the heads up.
3560 <cliechti-AT-gmx.net> for the heads up.
3556
3561
3557 2003-02-21 Fernando Perez <fperez@colorado.edu>
3562 2003-02-21 Fernando Perez <fperez@colorado.edu>
3558
3563
3559 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
3564 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
3560 of ValueError exception when checking for auto-execution. This
3565 of ValueError exception when checking for auto-execution. This
3561 one is raised by things like Numeric arrays arr.flat when the
3566 one is raised by things like Numeric arrays arr.flat when the
3562 array is non-contiguous.
3567 array is non-contiguous.
3563
3568
3564 2003-01-31 Fernando Perez <fperez@colorado.edu>
3569 2003-01-31 Fernando Perez <fperez@colorado.edu>
3565
3570
3566 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
3571 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
3567 not return any value at all (even though the command would get
3572 not return any value at all (even though the command would get
3568 executed).
3573 executed).
3569 (xsys): Flush stdout right after printing the command to ensure
3574 (xsys): Flush stdout right after printing the command to ensure
3570 proper ordering of commands and command output in the total
3575 proper ordering of commands and command output in the total
3571 output.
3576 output.
3572 (SystemExec/xsys/bq): Switched the names of xsys/bq and
3577 (SystemExec/xsys/bq): Switched the names of xsys/bq and
3573 system/getoutput as defaults. The old ones are kept for
3578 system/getoutput as defaults. The old ones are kept for
3574 compatibility reasons, so no code which uses this library needs
3579 compatibility reasons, so no code which uses this library needs
3575 changing.
3580 changing.
3576
3581
3577 2003-01-27 *** Released version 0.2.14
3582 2003-01-27 *** Released version 0.2.14
3578
3583
3579 2003-01-25 Fernando Perez <fperez@colorado.edu>
3584 2003-01-25 Fernando Perez <fperez@colorado.edu>
3580
3585
3581 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
3586 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
3582 functions defined in previous edit sessions could not be re-edited
3587 functions defined in previous edit sessions could not be re-edited
3583 (because the temp files were immediately removed). Now temp files
3588 (because the temp files were immediately removed). Now temp files
3584 are removed only at IPython's exit.
3589 are removed only at IPython's exit.
3585 (Magic.magic_run): Improved @run to perform shell-like expansions
3590 (Magic.magic_run): Improved @run to perform shell-like expansions
3586 on its arguments (~users and $VARS). With this, @run becomes more
3591 on its arguments (~users and $VARS). With this, @run becomes more
3587 like a normal command-line.
3592 like a normal command-line.
3588
3593
3589 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
3594 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
3590 bugs related to embedding and cleaned up that code. A fairly
3595 bugs related to embedding and cleaned up that code. A fairly
3591 important one was the impossibility to access the global namespace
3596 important one was the impossibility to access the global namespace
3592 through the embedded IPython (only local variables were visible).
3597 through the embedded IPython (only local variables were visible).
3593
3598
3594 2003-01-14 Fernando Perez <fperez@colorado.edu>
3599 2003-01-14 Fernando Perez <fperez@colorado.edu>
3595
3600
3596 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
3601 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
3597 auto-calling to be a bit more conservative. Now it doesn't get
3602 auto-calling to be a bit more conservative. Now it doesn't get
3598 triggered if any of '!=()<>' are in the rest of the input line, to
3603 triggered if any of '!=()<>' are in the rest of the input line, to
3599 allow comparing callables. Thanks to Alex for the heads up.
3604 allow comparing callables. Thanks to Alex for the heads up.
3600
3605
3601 2003-01-07 Fernando Perez <fperez@colorado.edu>
3606 2003-01-07 Fernando Perez <fperez@colorado.edu>
3602
3607
3603 * IPython/genutils.py (page): fixed estimation of the number of
3608 * IPython/genutils.py (page): fixed estimation of the number of
3604 lines in a string to be paged to simply count newlines. This
3609 lines in a string to be paged to simply count newlines. This
3605 prevents over-guessing due to embedded escape sequences. A better
3610 prevents over-guessing due to embedded escape sequences. A better
3606 long-term solution would involve stripping out the control chars
3611 long-term solution would involve stripping out the control chars
3607 for the count, but it's potentially so expensive I just don't
3612 for the count, but it's potentially so expensive I just don't
3608 think it's worth doing.
3613 think it's worth doing.
3609
3614
3610 2002-12-19 *** Released version 0.2.14pre50
3615 2002-12-19 *** Released version 0.2.14pre50
3611
3616
3612 2002-12-19 Fernando Perez <fperez@colorado.edu>
3617 2002-12-19 Fernando Perez <fperez@colorado.edu>
3613
3618
3614 * tools/release (version): Changed release scripts to inform
3619 * tools/release (version): Changed release scripts to inform
3615 Andrea and build a NEWS file with a list of recent changes.
3620 Andrea and build a NEWS file with a list of recent changes.
3616
3621
3617 * IPython/ColorANSI.py (__all__): changed terminal detection
3622 * IPython/ColorANSI.py (__all__): changed terminal detection
3618 code. Seems to work better for xterms without breaking
3623 code. Seems to work better for xterms without breaking
3619 konsole. Will need more testing to determine if WinXP and Mac OSX
3624 konsole. Will need more testing to determine if WinXP and Mac OSX
3620 also work ok.
3625 also work ok.
3621
3626
3622 2002-12-18 *** Released version 0.2.14pre49
3627 2002-12-18 *** Released version 0.2.14pre49
3623
3628
3624 2002-12-18 Fernando Perez <fperez@colorado.edu>
3629 2002-12-18 Fernando Perez <fperez@colorado.edu>
3625
3630
3626 * Docs: added new info about Mac OSX, from Andrea.
3631 * Docs: added new info about Mac OSX, from Andrea.
3627
3632
3628 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
3633 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
3629 allow direct plotting of python strings whose format is the same
3634 allow direct plotting of python strings whose format is the same
3630 of gnuplot data files.
3635 of gnuplot data files.
3631
3636
3632 2002-12-16 Fernando Perez <fperez@colorado.edu>
3637 2002-12-16 Fernando Perez <fperez@colorado.edu>
3633
3638
3634 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
3639 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
3635 value of exit question to be acknowledged.
3640 value of exit question to be acknowledged.
3636
3641
3637 2002-12-03 Fernando Perez <fperez@colorado.edu>
3642 2002-12-03 Fernando Perez <fperez@colorado.edu>
3638
3643
3639 * IPython/ipmaker.py: removed generators, which had been added
3644 * IPython/ipmaker.py: removed generators, which had been added
3640 by mistake in an earlier debugging run. This was causing trouble
3645 by mistake in an earlier debugging run. This was causing trouble
3641 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
3646 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
3642 for pointing this out.
3647 for pointing this out.
3643
3648
3644 2002-11-17 Fernando Perez <fperez@colorado.edu>
3649 2002-11-17 Fernando Perez <fperez@colorado.edu>
3645
3650
3646 * Manual: updated the Gnuplot section.
3651 * Manual: updated the Gnuplot section.
3647
3652
3648 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
3653 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
3649 a much better split of what goes in Runtime and what goes in
3654 a much better split of what goes in Runtime and what goes in
3650 Interactive.
3655 Interactive.
3651
3656
3652 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
3657 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
3653 being imported from iplib.
3658 being imported from iplib.
3654
3659
3655 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
3660 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
3656 for command-passing. Now the global Gnuplot instance is called
3661 for command-passing. Now the global Gnuplot instance is called
3657 'gp' instead of 'g', which was really a far too fragile and
3662 'gp' instead of 'g', which was really a far too fragile and
3658 common name.
3663 common name.
3659
3664
3660 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
3665 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
3661 bounding boxes generated by Gnuplot for square plots.
3666 bounding boxes generated by Gnuplot for square plots.
3662
3667
3663 * IPython/genutils.py (popkey): new function added. I should
3668 * IPython/genutils.py (popkey): new function added. I should
3664 suggest this on c.l.py as a dict method, it seems useful.
3669 suggest this on c.l.py as a dict method, it seems useful.
3665
3670
3666 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
3671 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
3667 to transparently handle PostScript generation. MUCH better than
3672 to transparently handle PostScript generation. MUCH better than
3668 the previous plot_eps/replot_eps (which I removed now). The code
3673 the previous plot_eps/replot_eps (which I removed now). The code
3669 is also fairly clean and well documented now (including
3674 is also fairly clean and well documented now (including
3670 docstrings).
3675 docstrings).
3671
3676
3672 2002-11-13 Fernando Perez <fperez@colorado.edu>
3677 2002-11-13 Fernando Perez <fperez@colorado.edu>
3673
3678
3674 * IPython/Magic.py (Magic.magic_edit): fixed docstring
3679 * IPython/Magic.py (Magic.magic_edit): fixed docstring
3675 (inconsistent with options).
3680 (inconsistent with options).
3676
3681
3677 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
3682 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
3678 manually disabled, I don't know why. Fixed it.
3683 manually disabled, I don't know why. Fixed it.
3679 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
3684 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
3680 eps output.
3685 eps output.
3681
3686
3682 2002-11-12 Fernando Perez <fperez@colorado.edu>
3687 2002-11-12 Fernando Perez <fperez@colorado.edu>
3683
3688
3684 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
3689 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
3685 don't propagate up to caller. Fixes crash reported by François
3690 don't propagate up to caller. Fixes crash reported by François
3686 Pinard.
3691 Pinard.
3687
3692
3688 2002-11-09 Fernando Perez <fperez@colorado.edu>
3693 2002-11-09 Fernando Perez <fperez@colorado.edu>
3689
3694
3690 * IPython/ipmaker.py (make_IPython): fixed problem with writing
3695 * IPython/ipmaker.py (make_IPython): fixed problem with writing
3691 history file for new users.
3696 history file for new users.
3692 (make_IPython): fixed bug where initial install would leave the
3697 (make_IPython): fixed bug where initial install would leave the
3693 user running in the .ipython dir.
3698 user running in the .ipython dir.
3694 (make_IPython): fixed bug where config dir .ipython would be
3699 (make_IPython): fixed bug where config dir .ipython would be
3695 created regardless of the given -ipythondir option. Thanks to Cory
3700 created regardless of the given -ipythondir option. Thanks to Cory
3696 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
3701 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
3697
3702
3698 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
3703 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
3699 type confirmations. Will need to use it in all of IPython's code
3704 type confirmations. Will need to use it in all of IPython's code
3700 consistently.
3705 consistently.
3701
3706
3702 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
3707 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
3703 context to print 31 lines instead of the default 5. This will make
3708 context to print 31 lines instead of the default 5. This will make
3704 the crash reports extremely detailed in case the problem is in
3709 the crash reports extremely detailed in case the problem is in
3705 libraries I don't have access to.
3710 libraries I don't have access to.
3706
3711
3707 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
3712 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
3708 line of defense' code to still crash, but giving users fair
3713 line of defense' code to still crash, but giving users fair
3709 warning. I don't want internal errors to go unreported: if there's
3714 warning. I don't want internal errors to go unreported: if there's
3710 an internal problem, IPython should crash and generate a full
3715 an internal problem, IPython should crash and generate a full
3711 report.
3716 report.
3712
3717
3713 2002-11-08 Fernando Perez <fperez@colorado.edu>
3718 2002-11-08 Fernando Perez <fperez@colorado.edu>
3714
3719
3715 * IPython/iplib.py (InteractiveShell.interact): added code to trap
3720 * IPython/iplib.py (InteractiveShell.interact): added code to trap
3716 otherwise uncaught exceptions which can appear if people set
3721 otherwise uncaught exceptions which can appear if people set
3717 sys.stdout to something badly broken. Thanks to a crash report
3722 sys.stdout to something badly broken. Thanks to a crash report
3718 from henni-AT-mail.brainbot.com.
3723 from henni-AT-mail.brainbot.com.
3719
3724
3720 2002-11-04 Fernando Perez <fperez@colorado.edu>
3725 2002-11-04 Fernando Perez <fperez@colorado.edu>
3721
3726
3722 * IPython/iplib.py (InteractiveShell.interact): added
3727 * IPython/iplib.py (InteractiveShell.interact): added
3723 __IPYTHON__active to the builtins. It's a flag which goes on when
3728 __IPYTHON__active to the builtins. It's a flag which goes on when
3724 the interaction starts and goes off again when it stops. This
3729 the interaction starts and goes off again when it stops. This
3725 allows embedding code to detect being inside IPython. Before this
3730 allows embedding code to detect being inside IPython. Before this
3726 was done via __IPYTHON__, but that only shows that an IPython
3731 was done via __IPYTHON__, but that only shows that an IPython
3727 instance has been created.
3732 instance has been created.
3728
3733
3729 * IPython/Magic.py (Magic.magic_env): I realized that in a
3734 * IPython/Magic.py (Magic.magic_env): I realized that in a
3730 UserDict, instance.data holds the data as a normal dict. So I
3735 UserDict, instance.data holds the data as a normal dict. So I
3731 modified @env to return os.environ.data instead of rebuilding a
3736 modified @env to return os.environ.data instead of rebuilding a
3732 dict by hand.
3737 dict by hand.
3733
3738
3734 2002-11-02 Fernando Perez <fperez@colorado.edu>
3739 2002-11-02 Fernando Perez <fperez@colorado.edu>
3735
3740
3736 * IPython/genutils.py (warn): changed so that level 1 prints no
3741 * IPython/genutils.py (warn): changed so that level 1 prints no
3737 header. Level 2 is now the default (with 'WARNING' header, as
3742 header. Level 2 is now the default (with 'WARNING' header, as
3738 before). I think I tracked all places where changes were needed in
3743 before). I think I tracked all places where changes were needed in
3739 IPython, but outside code using the old level numbering may have
3744 IPython, but outside code using the old level numbering may have
3740 broken.
3745 broken.
3741
3746
3742 * IPython/iplib.py (InteractiveShell.runcode): added this to
3747 * IPython/iplib.py (InteractiveShell.runcode): added this to
3743 handle the tracebacks in SystemExit traps correctly. The previous
3748 handle the tracebacks in SystemExit traps correctly. The previous
3744 code (through interact) was printing more of the stack than
3749 code (through interact) was printing more of the stack than
3745 necessary, showing IPython internal code to the user.
3750 necessary, showing IPython internal code to the user.
3746
3751
3747 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
3752 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
3748 default. Now that the default at the confirmation prompt is yes,
3753 default. Now that the default at the confirmation prompt is yes,
3749 it's not so intrusive. François' argument that ipython sessions
3754 it's not so intrusive. François' argument that ipython sessions
3750 tend to be complex enough not to lose them from an accidental C-d,
3755 tend to be complex enough not to lose them from an accidental C-d,
3751 is a valid one.
3756 is a valid one.
3752
3757
3753 * IPython/iplib.py (InteractiveShell.interact): added a
3758 * IPython/iplib.py (InteractiveShell.interact): added a
3754 showtraceback() call to the SystemExit trap, and modified the exit
3759 showtraceback() call to the SystemExit trap, and modified the exit
3755 confirmation to have yes as the default.
3760 confirmation to have yes as the default.
3756
3761
3757 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
3762 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
3758 this file. It's been gone from the code for a long time, this was
3763 this file. It's been gone from the code for a long time, this was
3759 simply leftover junk.
3764 simply leftover junk.
3760
3765
3761 2002-11-01 Fernando Perez <fperez@colorado.edu>
3766 2002-11-01 Fernando Perez <fperez@colorado.edu>
3762
3767
3763 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
3768 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
3764 added. If set, IPython now traps EOF and asks for
3769 added. If set, IPython now traps EOF and asks for
3765 confirmation. After a request by François Pinard.
3770 confirmation. After a request by François Pinard.
3766
3771
3767 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
3772 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
3768 of @abort, and with a new (better) mechanism for handling the
3773 of @abort, and with a new (better) mechanism for handling the
3769 exceptions.
3774 exceptions.
3770
3775
3771 2002-10-27 Fernando Perez <fperez@colorado.edu>
3776 2002-10-27 Fernando Perez <fperez@colorado.edu>
3772
3777
3773 * IPython/usage.py (__doc__): updated the --help information and
3778 * IPython/usage.py (__doc__): updated the --help information and
3774 the ipythonrc file to indicate that -log generates
3779 the ipythonrc file to indicate that -log generates
3775 ./ipython.log. Also fixed the corresponding info in @logstart.
3780 ./ipython.log. Also fixed the corresponding info in @logstart.
3776 This and several other fixes in the manuals thanks to reports by
3781 This and several other fixes in the manuals thanks to reports by
3777 François Pinard <pinard-AT-iro.umontreal.ca>.
3782 François Pinard <pinard-AT-iro.umontreal.ca>.
3778
3783
3779 * IPython/Logger.py (Logger.switch_log): Fixed error message to
3784 * IPython/Logger.py (Logger.switch_log): Fixed error message to
3780 refer to @logstart (instead of @log, which doesn't exist).
3785 refer to @logstart (instead of @log, which doesn't exist).
3781
3786
3782 * IPython/iplib.py (InteractiveShell._prefilter): fixed
3787 * IPython/iplib.py (InteractiveShell._prefilter): fixed
3783 AttributeError crash. Thanks to Christopher Armstrong
3788 AttributeError crash. Thanks to Christopher Armstrong
3784 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
3789 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
3785 introduced recently (in 0.2.14pre37) with the fix to the eval
3790 introduced recently (in 0.2.14pre37) with the fix to the eval
3786 problem mentioned below.
3791 problem mentioned below.
3787
3792
3788 2002-10-17 Fernando Perez <fperez@colorado.edu>
3793 2002-10-17 Fernando Perez <fperez@colorado.edu>
3789
3794
3790 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
3795 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
3791 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
3796 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
3792
3797
3793 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
3798 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
3794 this function to fix a problem reported by Alex Schmolck. He saw
3799 this function to fix a problem reported by Alex Schmolck. He saw
3795 it with list comprehensions and generators, which were getting
3800 it with list comprehensions and generators, which were getting
3796 called twice. The real problem was an 'eval' call in testing for
3801 called twice. The real problem was an 'eval' call in testing for
3797 automagic which was evaluating the input line silently.
3802 automagic which was evaluating the input line silently.
3798
3803
3799 This is a potentially very nasty bug, if the input has side
3804 This is a potentially very nasty bug, if the input has side
3800 effects which must not be repeated. The code is much cleaner now,
3805 effects which must not be repeated. The code is much cleaner now,
3801 without any blanket 'except' left and with a regexp test for
3806 without any blanket 'except' left and with a regexp test for
3802 actual function names.
3807 actual function names.
3803
3808
3804 But an eval remains, which I'm not fully comfortable with. I just
3809 But an eval remains, which I'm not fully comfortable with. I just
3805 don't know how to find out if an expression could be a callable in
3810 don't know how to find out if an expression could be a callable in
3806 the user's namespace without doing an eval on the string. However
3811 the user's namespace without doing an eval on the string. However
3807 that string is now much more strictly checked so that no code
3812 that string is now much more strictly checked so that no code
3808 slips by, so the eval should only happen for things that can
3813 slips by, so the eval should only happen for things that can
3809 really be only function/method names.
3814 really be only function/method names.
3810
3815
3811 2002-10-15 Fernando Perez <fperez@colorado.edu>
3816 2002-10-15 Fernando Perez <fperez@colorado.edu>
3812
3817
3813 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
3818 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
3814 OSX information to main manual, removed README_Mac_OSX file from
3819 OSX information to main manual, removed README_Mac_OSX file from
3815 distribution. Also updated credits for recent additions.
3820 distribution. Also updated credits for recent additions.
3816
3821
3817 2002-10-10 Fernando Perez <fperez@colorado.edu>
3822 2002-10-10 Fernando Perez <fperez@colorado.edu>
3818
3823
3819 * README_Mac_OSX: Added a README for Mac OSX users for fixing
3824 * README_Mac_OSX: Added a README for Mac OSX users for fixing
3820 terminal-related issues. Many thanks to Andrea Riciputi
3825 terminal-related issues. Many thanks to Andrea Riciputi
3821 <andrea.riciputi-AT-libero.it> for writing it.
3826 <andrea.riciputi-AT-libero.it> for writing it.
3822
3827
3823 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
3828 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
3824 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
3829 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
3825
3830
3826 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
3831 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
3827 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
3832 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
3828 <syver-en-AT-online.no> who both submitted patches for this problem.
3833 <syver-en-AT-online.no> who both submitted patches for this problem.
3829
3834
3830 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
3835 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
3831 global embedding to make sure that things don't overwrite user
3836 global embedding to make sure that things don't overwrite user
3832 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
3837 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
3833
3838
3834 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
3839 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
3835 compatibility. Thanks to Hayden Callow
3840 compatibility. Thanks to Hayden Callow
3836 <h.callow-AT-elec.canterbury.ac.nz>
3841 <h.callow-AT-elec.canterbury.ac.nz>
3837
3842
3838 2002-10-04 Fernando Perez <fperez@colorado.edu>
3843 2002-10-04 Fernando Perez <fperez@colorado.edu>
3839
3844
3840 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
3845 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
3841 Gnuplot.File objects.
3846 Gnuplot.File objects.
3842
3847
3843 2002-07-23 Fernando Perez <fperez@colorado.edu>
3848 2002-07-23 Fernando Perez <fperez@colorado.edu>
3844
3849
3845 * IPython/genutils.py (timing): Added timings() and timing() for
3850 * IPython/genutils.py (timing): Added timings() and timing() for
3846 quick access to the most commonly needed data, the execution
3851 quick access to the most commonly needed data, the execution
3847 times. Old timing() renamed to timings_out().
3852 times. Old timing() renamed to timings_out().
3848
3853
3849 2002-07-18 Fernando Perez <fperez@colorado.edu>
3854 2002-07-18 Fernando Perez <fperez@colorado.edu>
3850
3855
3851 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
3856 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
3852 bug with nested instances disrupting the parent's tab completion.
3857 bug with nested instances disrupting the parent's tab completion.
3853
3858
3854 * IPython/iplib.py (all_completions): Added Alex Schmolck's
3859 * IPython/iplib.py (all_completions): Added Alex Schmolck's
3855 all_completions code to begin the emacs integration.
3860 all_completions code to begin the emacs integration.
3856
3861
3857 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
3862 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
3858 argument to allow titling individual arrays when plotting.
3863 argument to allow titling individual arrays when plotting.
3859
3864
3860 2002-07-15 Fernando Perez <fperez@colorado.edu>
3865 2002-07-15 Fernando Perez <fperez@colorado.edu>
3861
3866
3862 * setup.py (make_shortcut): changed to retrieve the value of
3867 * setup.py (make_shortcut): changed to retrieve the value of
3863 'Program Files' directory from the registry (this value changes in
3868 'Program Files' directory from the registry (this value changes in
3864 non-english versions of Windows). Thanks to Thomas Fanslau
3869 non-english versions of Windows). Thanks to Thomas Fanslau
3865 <tfanslau-AT-gmx.de> for the report.
3870 <tfanslau-AT-gmx.de> for the report.
3866
3871
3867 2002-07-10 Fernando Perez <fperez@colorado.edu>
3872 2002-07-10 Fernando Perez <fperez@colorado.edu>
3868
3873
3869 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
3874 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
3870 a bug in pdb, which crashes if a line with only whitespace is
3875 a bug in pdb, which crashes if a line with only whitespace is
3871 entered. Bug report submitted to sourceforge.
3876 entered. Bug report submitted to sourceforge.
3872
3877
3873 2002-07-09 Fernando Perez <fperez@colorado.edu>
3878 2002-07-09 Fernando Perez <fperez@colorado.edu>
3874
3879
3875 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
3880 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
3876 reporting exceptions (it's a bug in inspect.py, I just set a
3881 reporting exceptions (it's a bug in inspect.py, I just set a
3877 workaround).
3882 workaround).
3878
3883
3879 2002-07-08 Fernando Perez <fperez@colorado.edu>
3884 2002-07-08 Fernando Perez <fperez@colorado.edu>
3880
3885
3881 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
3886 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
3882 __IPYTHON__ in __builtins__ to show up in user_ns.
3887 __IPYTHON__ in __builtins__ to show up in user_ns.
3883
3888
3884 2002-07-03 Fernando Perez <fperez@colorado.edu>
3889 2002-07-03 Fernando Perez <fperez@colorado.edu>
3885
3890
3886 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
3891 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
3887 name from @gp_set_instance to @gp_set_default.
3892 name from @gp_set_instance to @gp_set_default.
3888
3893
3889 * IPython/ipmaker.py (make_IPython): default editor value set to
3894 * IPython/ipmaker.py (make_IPython): default editor value set to
3890 '0' (a string), to match the rc file. Otherwise will crash when
3895 '0' (a string), to match the rc file. Otherwise will crash when
3891 .strip() is called on it.
3896 .strip() is called on it.
3892
3897
3893
3898
3894 2002-06-28 Fernando Perez <fperez@colorado.edu>
3899 2002-06-28 Fernando Perez <fperez@colorado.edu>
3895
3900
3896 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
3901 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
3897 of files in current directory when a file is executed via
3902 of files in current directory when a file is executed via
3898 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
3903 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
3899
3904
3900 * setup.py (manfiles): fix for rpm builds, submitted by RA
3905 * setup.py (manfiles): fix for rpm builds, submitted by RA
3901 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
3906 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
3902
3907
3903 * IPython/ipmaker.py (make_IPython): fixed lookup of default
3908 * IPython/ipmaker.py (make_IPython): fixed lookup of default
3904 editor when set to '0'. Problem was, '0' evaluates to True (it's a
3909 editor when set to '0'. Problem was, '0' evaluates to True (it's a
3905 string!). A. Schmolck caught this one.
3910 string!). A. Schmolck caught this one.
3906
3911
3907 2002-06-27 Fernando Perez <fperez@colorado.edu>
3912 2002-06-27 Fernando Perez <fperez@colorado.edu>
3908
3913
3909 * IPython/ipmaker.py (make_IPython): fixed bug when running user
3914 * IPython/ipmaker.py (make_IPython): fixed bug when running user
3910 defined files at the cmd line. __name__ wasn't being set to
3915 defined files at the cmd line. __name__ wasn't being set to
3911 __main__.
3916 __main__.
3912
3917
3913 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
3918 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
3914 regular lists and tuples besides Numeric arrays.
3919 regular lists and tuples besides Numeric arrays.
3915
3920
3916 * IPython/Prompts.py (CachedOutput.__call__): Added output
3921 * IPython/Prompts.py (CachedOutput.__call__): Added output
3917 supression for input ending with ';'. Similar to Mathematica and
3922 supression for input ending with ';'. Similar to Mathematica and
3918 Matlab. The _* vars and Out[] list are still updated, just like
3923 Matlab. The _* vars and Out[] list are still updated, just like
3919 Mathematica behaves.
3924 Mathematica behaves.
3920
3925
3921 2002-06-25 Fernando Perez <fperez@colorado.edu>
3926 2002-06-25 Fernando Perez <fperez@colorado.edu>
3922
3927
3923 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
3928 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
3924 .ini extensions for profiels under Windows.
3929 .ini extensions for profiels under Windows.
3925
3930
3926 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
3931 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
3927 string form. Fix contributed by Alexander Schmolck
3932 string form. Fix contributed by Alexander Schmolck
3928 <a.schmolck-AT-gmx.net>
3933 <a.schmolck-AT-gmx.net>
3929
3934
3930 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
3935 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
3931 pre-configured Gnuplot instance.
3936 pre-configured Gnuplot instance.
3932
3937
3933 2002-06-21 Fernando Perez <fperez@colorado.edu>
3938 2002-06-21 Fernando Perez <fperez@colorado.edu>
3934
3939
3935 * IPython/numutils.py (exp_safe): new function, works around the
3940 * IPython/numutils.py (exp_safe): new function, works around the
3936 underflow problems in Numeric.
3941 underflow problems in Numeric.
3937 (log2): New fn. Safe log in base 2: returns exact integer answer
3942 (log2): New fn. Safe log in base 2: returns exact integer answer
3938 for exact integer powers of 2.
3943 for exact integer powers of 2.
3939
3944
3940 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
3945 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
3941 properly.
3946 properly.
3942
3947
3943 2002-06-20 Fernando Perez <fperez@colorado.edu>
3948 2002-06-20 Fernando Perez <fperez@colorado.edu>
3944
3949
3945 * IPython/genutils.py (timing): new function like
3950 * IPython/genutils.py (timing): new function like
3946 Mathematica's. Similar to time_test, but returns more info.
3951 Mathematica's. Similar to time_test, but returns more info.
3947
3952
3948 2002-06-18 Fernando Perez <fperez@colorado.edu>
3953 2002-06-18 Fernando Perez <fperez@colorado.edu>
3949
3954
3950 * IPython/Magic.py (Magic.magic_save): modified @save and @r
3955 * IPython/Magic.py (Magic.magic_save): modified @save and @r
3951 according to Mike Heeter's suggestions.
3956 according to Mike Heeter's suggestions.
3952
3957
3953 2002-06-16 Fernando Perez <fperez@colorado.edu>
3958 2002-06-16 Fernando Perez <fperez@colorado.edu>
3954
3959
3955 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
3960 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
3956 system. GnuplotMagic is gone as a user-directory option. New files
3961 system. GnuplotMagic is gone as a user-directory option. New files
3957 make it easier to use all the gnuplot stuff both from external
3962 make it easier to use all the gnuplot stuff both from external
3958 programs as well as from IPython. Had to rewrite part of
3963 programs as well as from IPython. Had to rewrite part of
3959 hardcopy() b/c of a strange bug: often the ps files simply don't
3964 hardcopy() b/c of a strange bug: often the ps files simply don't
3960 get created, and require a repeat of the command (often several
3965 get created, and require a repeat of the command (often several
3961 times).
3966 times).
3962
3967
3963 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
3968 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
3964 resolve output channel at call time, so that if sys.stderr has
3969 resolve output channel at call time, so that if sys.stderr has
3965 been redirected by user this gets honored.
3970 been redirected by user this gets honored.
3966
3971
3967 2002-06-13 Fernando Perez <fperez@colorado.edu>
3972 2002-06-13 Fernando Perez <fperez@colorado.edu>
3968
3973
3969 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
3974 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
3970 IPShell. Kept a copy with the old names to avoid breaking people's
3975 IPShell. Kept a copy with the old names to avoid breaking people's
3971 embedded code.
3976 embedded code.
3972
3977
3973 * IPython/ipython: simplified it to the bare minimum after
3978 * IPython/ipython: simplified it to the bare minimum after
3974 Holger's suggestions. Added info about how to use it in
3979 Holger's suggestions. Added info about how to use it in
3975 PYTHONSTARTUP.
3980 PYTHONSTARTUP.
3976
3981
3977 * IPython/Shell.py (IPythonShell): changed the options passing
3982 * IPython/Shell.py (IPythonShell): changed the options passing
3978 from a string with funky %s replacements to a straight list. Maybe
3983 from a string with funky %s replacements to a straight list. Maybe
3979 a bit more typing, but it follows sys.argv conventions, so there's
3984 a bit more typing, but it follows sys.argv conventions, so there's
3980 less special-casing to remember.
3985 less special-casing to remember.
3981
3986
3982 2002-06-12 Fernando Perez <fperez@colorado.edu>
3987 2002-06-12 Fernando Perez <fperez@colorado.edu>
3983
3988
3984 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
3989 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
3985 command. Thanks to a suggestion by Mike Heeter.
3990 command. Thanks to a suggestion by Mike Heeter.
3986 (Magic.magic_pfile): added behavior to look at filenames if given
3991 (Magic.magic_pfile): added behavior to look at filenames if given
3987 arg is not a defined object.
3992 arg is not a defined object.
3988 (Magic.magic_save): New @save function to save code snippets. Also
3993 (Magic.magic_save): New @save function to save code snippets. Also
3989 a Mike Heeter idea.
3994 a Mike Heeter idea.
3990
3995
3991 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
3996 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
3992 plot() and replot(). Much more convenient now, especially for
3997 plot() and replot(). Much more convenient now, especially for
3993 interactive use.
3998 interactive use.
3994
3999
3995 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
4000 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
3996 filenames.
4001 filenames.
3997
4002
3998 2002-06-02 Fernando Perez <fperez@colorado.edu>
4003 2002-06-02 Fernando Perez <fperez@colorado.edu>
3999
4004
4000 * IPython/Struct.py (Struct.__init__): modified to admit
4005 * IPython/Struct.py (Struct.__init__): modified to admit
4001 initialization via another struct.
4006 initialization via another struct.
4002
4007
4003 * IPython/genutils.py (SystemExec.__init__): New stateful
4008 * IPython/genutils.py (SystemExec.__init__): New stateful
4004 interface to xsys and bq. Useful for writing system scripts.
4009 interface to xsys and bq. Useful for writing system scripts.
4005
4010
4006 2002-05-30 Fernando Perez <fperez@colorado.edu>
4011 2002-05-30 Fernando Perez <fperez@colorado.edu>
4007
4012
4008 * MANIFEST.in: Changed docfile selection to exclude all the lyx
4013 * MANIFEST.in: Changed docfile selection to exclude all the lyx
4009 documents. This will make the user download smaller (it's getting
4014 documents. This will make the user download smaller (it's getting
4010 too big).
4015 too big).
4011
4016
4012 2002-05-29 Fernando Perez <fperez@colorado.edu>
4017 2002-05-29 Fernando Perez <fperez@colorado.edu>
4013
4018
4014 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
4019 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
4015 fix problems with shelve and pickle. Seems to work, but I don't
4020 fix problems with shelve and pickle. Seems to work, but I don't
4016 know if corner cases break it. Thanks to Mike Heeter
4021 know if corner cases break it. Thanks to Mike Heeter
4017 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
4022 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
4018
4023
4019 2002-05-24 Fernando Perez <fperez@colorado.edu>
4024 2002-05-24 Fernando Perez <fperez@colorado.edu>
4020
4025
4021 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
4026 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
4022 macros having broken.
4027 macros having broken.
4023
4028
4024 2002-05-21 Fernando Perez <fperez@colorado.edu>
4029 2002-05-21 Fernando Perez <fperez@colorado.edu>
4025
4030
4026 * IPython/Magic.py (Magic.magic_logstart): fixed recently
4031 * IPython/Magic.py (Magic.magic_logstart): fixed recently
4027 introduced logging bug: all history before logging started was
4032 introduced logging bug: all history before logging started was
4028 being written one character per line! This came from the redesign
4033 being written one character per line! This came from the redesign
4029 of the input history as a special list which slices to strings,
4034 of the input history as a special list which slices to strings,
4030 not to lists.
4035 not to lists.
4031
4036
4032 2002-05-20 Fernando Perez <fperez@colorado.edu>
4037 2002-05-20 Fernando Perez <fperez@colorado.edu>
4033
4038
4034 * IPython/Prompts.py (CachedOutput.__init__): made the color table
4039 * IPython/Prompts.py (CachedOutput.__init__): made the color table
4035 be an attribute of all classes in this module. The design of these
4040 be an attribute of all classes in this module. The design of these
4036 classes needs some serious overhauling.
4041 classes needs some serious overhauling.
4037
4042
4038 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
4043 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
4039 which was ignoring '_' in option names.
4044 which was ignoring '_' in option names.
4040
4045
4041 * IPython/ultraTB.py (FormattedTB.__init__): Changed
4046 * IPython/ultraTB.py (FormattedTB.__init__): Changed
4042 'Verbose_novars' to 'Context' and made it the new default. It's a
4047 'Verbose_novars' to 'Context' and made it the new default. It's a
4043 bit more readable and also safer than verbose.
4048 bit more readable and also safer than verbose.
4044
4049
4045 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
4050 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
4046 triple-quoted strings.
4051 triple-quoted strings.
4047
4052
4048 * IPython/OInspect.py (__all__): new module exposing the object
4053 * IPython/OInspect.py (__all__): new module exposing the object
4049 introspection facilities. Now the corresponding magics are dummy
4054 introspection facilities. Now the corresponding magics are dummy
4050 wrappers around this. Having this module will make it much easier
4055 wrappers around this. Having this module will make it much easier
4051 to put these functions into our modified pdb.
4056 to put these functions into our modified pdb.
4052 This new object inspector system uses the new colorizing module,
4057 This new object inspector system uses the new colorizing module,
4053 so source code and other things are nicely syntax highlighted.
4058 so source code and other things are nicely syntax highlighted.
4054
4059
4055 2002-05-18 Fernando Perez <fperez@colorado.edu>
4060 2002-05-18 Fernando Perez <fperez@colorado.edu>
4056
4061
4057 * IPython/ColorANSI.py: Split the coloring tools into a separate
4062 * IPython/ColorANSI.py: Split the coloring tools into a separate
4058 module so I can use them in other code easier (they were part of
4063 module so I can use them in other code easier (they were part of
4059 ultraTB).
4064 ultraTB).
4060
4065
4061 2002-05-17 Fernando Perez <fperez@colorado.edu>
4066 2002-05-17 Fernando Perez <fperez@colorado.edu>
4062
4067
4063 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
4068 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
4064 fixed it to set the global 'g' also to the called instance, as
4069 fixed it to set the global 'g' also to the called instance, as
4065 long as 'g' was still a gnuplot instance (so it doesn't overwrite
4070 long as 'g' was still a gnuplot instance (so it doesn't overwrite
4066 user's 'g' variables).
4071 user's 'g' variables).
4067
4072
4068 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
4073 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
4069 global variables (aliases to _ih,_oh) so that users which expect
4074 global variables (aliases to _ih,_oh) so that users which expect
4070 In[5] or Out[7] to work aren't unpleasantly surprised.
4075 In[5] or Out[7] to work aren't unpleasantly surprised.
4071 (InputList.__getslice__): new class to allow executing slices of
4076 (InputList.__getslice__): new class to allow executing slices of
4072 input history directly. Very simple class, complements the use of
4077 input history directly. Very simple class, complements the use of
4073 macros.
4078 macros.
4074
4079
4075 2002-05-16 Fernando Perez <fperez@colorado.edu>
4080 2002-05-16 Fernando Perez <fperez@colorado.edu>
4076
4081
4077 * setup.py (docdirbase): make doc directory be just doc/IPython
4082 * setup.py (docdirbase): make doc directory be just doc/IPython
4078 without version numbers, it will reduce clutter for users.
4083 without version numbers, it will reduce clutter for users.
4079
4084
4080 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
4085 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
4081 execfile call to prevent possible memory leak. See for details:
4086 execfile call to prevent possible memory leak. See for details:
4082 http://mail.python.org/pipermail/python-list/2002-February/088476.html
4087 http://mail.python.org/pipermail/python-list/2002-February/088476.html
4083
4088
4084 2002-05-15 Fernando Perez <fperez@colorado.edu>
4089 2002-05-15 Fernando Perez <fperez@colorado.edu>
4085
4090
4086 * IPython/Magic.py (Magic.magic_psource): made the object
4091 * IPython/Magic.py (Magic.magic_psource): made the object
4087 introspection names be more standard: pdoc, pdef, pfile and
4092 introspection names be more standard: pdoc, pdef, pfile and
4088 psource. They all print/page their output, and it makes
4093 psource. They all print/page their output, and it makes
4089 remembering them easier. Kept old names for compatibility as
4094 remembering them easier. Kept old names for compatibility as
4090 aliases.
4095 aliases.
4091
4096
4092 2002-05-14 Fernando Perez <fperez@colorado.edu>
4097 2002-05-14 Fernando Perez <fperez@colorado.edu>
4093
4098
4094 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
4099 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
4095 what the mouse problem was. The trick is to use gnuplot with temp
4100 what the mouse problem was. The trick is to use gnuplot with temp
4096 files and NOT with pipes (for data communication), because having
4101 files and NOT with pipes (for data communication), because having
4097 both pipes and the mouse on is bad news.
4102 both pipes and the mouse on is bad news.
4098
4103
4099 2002-05-13 Fernando Perez <fperez@colorado.edu>
4104 2002-05-13 Fernando Perez <fperez@colorado.edu>
4100
4105
4101 * IPython/Magic.py (Magic._ofind): fixed namespace order search
4106 * IPython/Magic.py (Magic._ofind): fixed namespace order search
4102 bug. Information would be reported about builtins even when
4107 bug. Information would be reported about builtins even when
4103 user-defined functions overrode them.
4108 user-defined functions overrode them.
4104
4109
4105 2002-05-11 Fernando Perez <fperez@colorado.edu>
4110 2002-05-11 Fernando Perez <fperez@colorado.edu>
4106
4111
4107 * IPython/__init__.py (__all__): removed FlexCompleter from
4112 * IPython/__init__.py (__all__): removed FlexCompleter from
4108 __all__ so that things don't fail in platforms without readline.
4113 __all__ so that things don't fail in platforms without readline.
4109
4114
4110 2002-05-10 Fernando Perez <fperez@colorado.edu>
4115 2002-05-10 Fernando Perez <fperez@colorado.edu>
4111
4116
4112 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
4117 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
4113 it requires Numeric, effectively making Numeric a dependency for
4118 it requires Numeric, effectively making Numeric a dependency for
4114 IPython.
4119 IPython.
4115
4120
4116 * Released 0.2.13
4121 * Released 0.2.13
4117
4122
4118 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
4123 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
4119 profiler interface. Now all the major options from the profiler
4124 profiler interface. Now all the major options from the profiler
4120 module are directly supported in IPython, both for single
4125 module are directly supported in IPython, both for single
4121 expressions (@prun) and for full programs (@run -p).
4126 expressions (@prun) and for full programs (@run -p).
4122
4127
4123 2002-05-09 Fernando Perez <fperez@colorado.edu>
4128 2002-05-09 Fernando Perez <fperez@colorado.edu>
4124
4129
4125 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
4130 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
4126 magic properly formatted for screen.
4131 magic properly formatted for screen.
4127
4132
4128 * setup.py (make_shortcut): Changed things to put pdf version in
4133 * setup.py (make_shortcut): Changed things to put pdf version in
4129 doc/ instead of doc/manual (had to change lyxport a bit).
4134 doc/ instead of doc/manual (had to change lyxport a bit).
4130
4135
4131 * IPython/Magic.py (Profile.string_stats): made profile runs go
4136 * IPython/Magic.py (Profile.string_stats): made profile runs go
4132 through pager (they are long and a pager allows searching, saving,
4137 through pager (they are long and a pager allows searching, saving,
4133 etc.)
4138 etc.)
4134
4139
4135 2002-05-08 Fernando Perez <fperez@colorado.edu>
4140 2002-05-08 Fernando Perez <fperez@colorado.edu>
4136
4141
4137 * Released 0.2.12
4142 * Released 0.2.12
4138
4143
4139 2002-05-06 Fernando Perez <fperez@colorado.edu>
4144 2002-05-06 Fernando Perez <fperez@colorado.edu>
4140
4145
4141 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
4146 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
4142 introduced); 'hist n1 n2' was broken.
4147 introduced); 'hist n1 n2' was broken.
4143 (Magic.magic_pdb): added optional on/off arguments to @pdb
4148 (Magic.magic_pdb): added optional on/off arguments to @pdb
4144 (Magic.magic_run): added option -i to @run, which executes code in
4149 (Magic.magic_run): added option -i to @run, which executes code in
4145 the IPython namespace instead of a clean one. Also added @irun as
4150 the IPython namespace instead of a clean one. Also added @irun as
4146 an alias to @run -i.
4151 an alias to @run -i.
4147
4152
4148 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
4153 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
4149 fixed (it didn't really do anything, the namespaces were wrong).
4154 fixed (it didn't really do anything, the namespaces were wrong).
4150
4155
4151 * IPython/Debugger.py (__init__): Added workaround for python 2.1
4156 * IPython/Debugger.py (__init__): Added workaround for python 2.1
4152
4157
4153 * IPython/__init__.py (__all__): Fixed package namespace, now
4158 * IPython/__init__.py (__all__): Fixed package namespace, now
4154 'import IPython' does give access to IPython.<all> as
4159 'import IPython' does give access to IPython.<all> as
4155 expected. Also renamed __release__ to Release.
4160 expected. Also renamed __release__ to Release.
4156
4161
4157 * IPython/Debugger.py (__license__): created new Pdb class which
4162 * IPython/Debugger.py (__license__): created new Pdb class which
4158 functions like a drop-in for the normal pdb.Pdb but does NOT
4163 functions like a drop-in for the normal pdb.Pdb but does NOT
4159 import readline by default. This way it doesn't muck up IPython's
4164 import readline by default. This way it doesn't muck up IPython's
4160 readline handling, and now tab-completion finally works in the
4165 readline handling, and now tab-completion finally works in the
4161 debugger -- sort of. It completes things globally visible, but the
4166 debugger -- sort of. It completes things globally visible, but the
4162 completer doesn't track the stack as pdb walks it. That's a bit
4167 completer doesn't track the stack as pdb walks it. That's a bit
4163 tricky, and I'll have to implement it later.
4168 tricky, and I'll have to implement it later.
4164
4169
4165 2002-05-05 Fernando Perez <fperez@colorado.edu>
4170 2002-05-05 Fernando Perez <fperez@colorado.edu>
4166
4171
4167 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
4172 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
4168 magic docstrings when printed via ? (explicit \'s were being
4173 magic docstrings when printed via ? (explicit \'s were being
4169 printed).
4174 printed).
4170
4175
4171 * IPython/ipmaker.py (make_IPython): fixed namespace
4176 * IPython/ipmaker.py (make_IPython): fixed namespace
4172 identification bug. Now variables loaded via logs or command-line
4177 identification bug. Now variables loaded via logs or command-line
4173 files are recognized in the interactive namespace by @who.
4178 files are recognized in the interactive namespace by @who.
4174
4179
4175 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
4180 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
4176 log replay system stemming from the string form of Structs.
4181 log replay system stemming from the string form of Structs.
4177
4182
4178 * IPython/Magic.py (Macro.__init__): improved macros to properly
4183 * IPython/Magic.py (Macro.__init__): improved macros to properly
4179 handle magic commands in them.
4184 handle magic commands in them.
4180 (Magic.magic_logstart): usernames are now expanded so 'logstart
4185 (Magic.magic_logstart): usernames are now expanded so 'logstart
4181 ~/mylog' now works.
4186 ~/mylog' now works.
4182
4187
4183 * IPython/iplib.py (complete): fixed bug where paths starting with
4188 * IPython/iplib.py (complete): fixed bug where paths starting with
4184 '/' would be completed as magic names.
4189 '/' would be completed as magic names.
4185
4190
4186 2002-05-04 Fernando Perez <fperez@colorado.edu>
4191 2002-05-04 Fernando Perez <fperez@colorado.edu>
4187
4192
4188 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
4193 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
4189 allow running full programs under the profiler's control.
4194 allow running full programs under the profiler's control.
4190
4195
4191 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
4196 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
4192 mode to report exceptions verbosely but without formatting
4197 mode to report exceptions verbosely but without formatting
4193 variables. This addresses the issue of ipython 'freezing' (it's
4198 variables. This addresses the issue of ipython 'freezing' (it's
4194 not frozen, but caught in an expensive formatting loop) when huge
4199 not frozen, but caught in an expensive formatting loop) when huge
4195 variables are in the context of an exception.
4200 variables are in the context of an exception.
4196 (VerboseTB.text): Added '--->' markers at line where exception was
4201 (VerboseTB.text): Added '--->' markers at line where exception was
4197 triggered. Much clearer to read, especially in NoColor modes.
4202 triggered. Much clearer to read, especially in NoColor modes.
4198
4203
4199 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
4204 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
4200 implemented in reverse when changing to the new parse_options().
4205 implemented in reverse when changing to the new parse_options().
4201
4206
4202 2002-05-03 Fernando Perez <fperez@colorado.edu>
4207 2002-05-03 Fernando Perez <fperez@colorado.edu>
4203
4208
4204 * IPython/Magic.py (Magic.parse_options): new function so that
4209 * IPython/Magic.py (Magic.parse_options): new function so that
4205 magics can parse options easier.
4210 magics can parse options easier.
4206 (Magic.magic_prun): new function similar to profile.run(),
4211 (Magic.magic_prun): new function similar to profile.run(),
4207 suggested by Chris Hart.
4212 suggested by Chris Hart.
4208 (Magic.magic_cd): fixed behavior so that it only changes if
4213 (Magic.magic_cd): fixed behavior so that it only changes if
4209 directory actually is in history.
4214 directory actually is in history.
4210
4215
4211 * IPython/usage.py (__doc__): added information about potential
4216 * IPython/usage.py (__doc__): added information about potential
4212 slowness of Verbose exception mode when there are huge data
4217 slowness of Verbose exception mode when there are huge data
4213 structures to be formatted (thanks to Archie Paulson).
4218 structures to be formatted (thanks to Archie Paulson).
4214
4219
4215 * IPython/ipmaker.py (make_IPython): Changed default logging
4220 * IPython/ipmaker.py (make_IPython): Changed default logging
4216 (when simply called with -log) to use curr_dir/ipython.log in
4221 (when simply called with -log) to use curr_dir/ipython.log in
4217 rotate mode. Fixed crash which was occuring with -log before
4222 rotate mode. Fixed crash which was occuring with -log before
4218 (thanks to Jim Boyle).
4223 (thanks to Jim Boyle).
4219
4224
4220 2002-05-01 Fernando Perez <fperez@colorado.edu>
4225 2002-05-01 Fernando Perez <fperez@colorado.edu>
4221
4226
4222 * Released 0.2.11 for these fixes (mainly the ultraTB one which
4227 * Released 0.2.11 for these fixes (mainly the ultraTB one which
4223 was nasty -- though somewhat of a corner case).
4228 was nasty -- though somewhat of a corner case).
4224
4229
4225 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
4230 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
4226 text (was a bug).
4231 text (was a bug).
4227
4232
4228 2002-04-30 Fernando Perez <fperez@colorado.edu>
4233 2002-04-30 Fernando Perez <fperez@colorado.edu>
4229
4234
4230 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
4235 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
4231 a print after ^D or ^C from the user so that the In[] prompt
4236 a print after ^D or ^C from the user so that the In[] prompt
4232 doesn't over-run the gnuplot one.
4237 doesn't over-run the gnuplot one.
4233
4238
4234 2002-04-29 Fernando Perez <fperez@colorado.edu>
4239 2002-04-29 Fernando Perez <fperez@colorado.edu>
4235
4240
4236 * Released 0.2.10
4241 * Released 0.2.10
4237
4242
4238 * IPython/__release__.py (version): get date dynamically.
4243 * IPython/__release__.py (version): get date dynamically.
4239
4244
4240 * Misc. documentation updates thanks to Arnd's comments. Also ran
4245 * Misc. documentation updates thanks to Arnd's comments. Also ran
4241 a full spellcheck on the manual (hadn't been done in a while).
4246 a full spellcheck on the manual (hadn't been done in a while).
4242
4247
4243 2002-04-27 Fernando Perez <fperez@colorado.edu>
4248 2002-04-27 Fernando Perez <fperez@colorado.edu>
4244
4249
4245 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
4250 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
4246 starting a log in mid-session would reset the input history list.
4251 starting a log in mid-session would reset the input history list.
4247
4252
4248 2002-04-26 Fernando Perez <fperez@colorado.edu>
4253 2002-04-26 Fernando Perez <fperez@colorado.edu>
4249
4254
4250 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
4255 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
4251 all files were being included in an update. Now anything in
4256 all files were being included in an update. Now anything in
4252 UserConfig that matches [A-Za-z]*.py will go (this excludes
4257 UserConfig that matches [A-Za-z]*.py will go (this excludes
4253 __init__.py)
4258 __init__.py)
4254
4259
4255 2002-04-25 Fernando Perez <fperez@colorado.edu>
4260 2002-04-25 Fernando Perez <fperez@colorado.edu>
4256
4261
4257 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
4262 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
4258 to __builtins__ so that any form of embedded or imported code can
4263 to __builtins__ so that any form of embedded or imported code can
4259 test for being inside IPython.
4264 test for being inside IPython.
4260
4265
4261 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
4266 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
4262 changed to GnuplotMagic because it's now an importable module,
4267 changed to GnuplotMagic because it's now an importable module,
4263 this makes the name follow that of the standard Gnuplot module.
4268 this makes the name follow that of the standard Gnuplot module.
4264 GnuplotMagic can now be loaded at any time in mid-session.
4269 GnuplotMagic can now be loaded at any time in mid-session.
4265
4270
4266 2002-04-24 Fernando Perez <fperez@colorado.edu>
4271 2002-04-24 Fernando Perez <fperez@colorado.edu>
4267
4272
4268 * IPython/numutils.py: removed SIUnits. It doesn't properly set
4273 * IPython/numutils.py: removed SIUnits. It doesn't properly set
4269 the globals (IPython has its own namespace) and the
4274 the globals (IPython has its own namespace) and the
4270 PhysicalQuantity stuff is much better anyway.
4275 PhysicalQuantity stuff is much better anyway.
4271
4276
4272 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
4277 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
4273 embedding example to standard user directory for
4278 embedding example to standard user directory for
4274 distribution. Also put it in the manual.
4279 distribution. Also put it in the manual.
4275
4280
4276 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
4281 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
4277 instance as first argument (so it doesn't rely on some obscure
4282 instance as first argument (so it doesn't rely on some obscure
4278 hidden global).
4283 hidden global).
4279
4284
4280 * IPython/UserConfig/ipythonrc.py: put () back in accepted
4285 * IPython/UserConfig/ipythonrc.py: put () back in accepted
4281 delimiters. While it prevents ().TAB from working, it allows
4286 delimiters. While it prevents ().TAB from working, it allows
4282 completions in open (... expressions. This is by far a more common
4287 completions in open (... expressions. This is by far a more common
4283 case.
4288 case.
4284
4289
4285 2002-04-23 Fernando Perez <fperez@colorado.edu>
4290 2002-04-23 Fernando Perez <fperez@colorado.edu>
4286
4291
4287 * IPython/Extensions/InterpreterPasteInput.py: new
4292 * IPython/Extensions/InterpreterPasteInput.py: new
4288 syntax-processing module for pasting lines with >>> or ... at the
4293 syntax-processing module for pasting lines with >>> or ... at the
4289 start.
4294 start.
4290
4295
4291 * IPython/Extensions/PhysicalQ_Interactive.py
4296 * IPython/Extensions/PhysicalQ_Interactive.py
4292 (PhysicalQuantityInteractive.__int__): fixed to work with either
4297 (PhysicalQuantityInteractive.__int__): fixed to work with either
4293 Numeric or math.
4298 Numeric or math.
4294
4299
4295 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
4300 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
4296 provided profiles. Now we have:
4301 provided profiles. Now we have:
4297 -math -> math module as * and cmath with its own namespace.
4302 -math -> math module as * and cmath with its own namespace.
4298 -numeric -> Numeric as *, plus gnuplot & grace
4303 -numeric -> Numeric as *, plus gnuplot & grace
4299 -physics -> same as before
4304 -physics -> same as before
4300
4305
4301 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
4306 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
4302 user-defined magics wouldn't be found by @magic if they were
4307 user-defined magics wouldn't be found by @magic if they were
4303 defined as class methods. Also cleaned up the namespace search
4308 defined as class methods. Also cleaned up the namespace search
4304 logic and the string building (to use %s instead of many repeated
4309 logic and the string building (to use %s instead of many repeated
4305 string adds).
4310 string adds).
4306
4311
4307 * IPython/UserConfig/example-magic.py (magic_foo): updated example
4312 * IPython/UserConfig/example-magic.py (magic_foo): updated example
4308 of user-defined magics to operate with class methods (cleaner, in
4313 of user-defined magics to operate with class methods (cleaner, in
4309 line with the gnuplot code).
4314 line with the gnuplot code).
4310
4315
4311 2002-04-22 Fernando Perez <fperez@colorado.edu>
4316 2002-04-22 Fernando Perez <fperez@colorado.edu>
4312
4317
4313 * setup.py: updated dependency list so that manual is updated when
4318 * setup.py: updated dependency list so that manual is updated when
4314 all included files change.
4319 all included files change.
4315
4320
4316 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
4321 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
4317 the delimiter removal option (the fix is ugly right now).
4322 the delimiter removal option (the fix is ugly right now).
4318
4323
4319 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
4324 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
4320 all of the math profile (quicker loading, no conflict between
4325 all of the math profile (quicker loading, no conflict between
4321 g-9.8 and g-gnuplot).
4326 g-9.8 and g-gnuplot).
4322
4327
4323 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
4328 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
4324 name of post-mortem files to IPython_crash_report.txt.
4329 name of post-mortem files to IPython_crash_report.txt.
4325
4330
4326 * Cleanup/update of the docs. Added all the new readline info and
4331 * Cleanup/update of the docs. Added all the new readline info and
4327 formatted all lists as 'real lists'.
4332 formatted all lists as 'real lists'.
4328
4333
4329 * IPython/ipmaker.py (make_IPython): removed now-obsolete
4334 * IPython/ipmaker.py (make_IPython): removed now-obsolete
4330 tab-completion options, since the full readline parse_and_bind is
4335 tab-completion options, since the full readline parse_and_bind is
4331 now accessible.
4336 now accessible.
4332
4337
4333 * IPython/iplib.py (InteractiveShell.init_readline): Changed
4338 * IPython/iplib.py (InteractiveShell.init_readline): Changed
4334 handling of readline options. Now users can specify any string to
4339 handling of readline options. Now users can specify any string to
4335 be passed to parse_and_bind(), as well as the delimiters to be
4340 be passed to parse_and_bind(), as well as the delimiters to be
4336 removed.
4341 removed.
4337 (InteractiveShell.__init__): Added __name__ to the global
4342 (InteractiveShell.__init__): Added __name__ to the global
4338 namespace so that things like Itpl which rely on its existence
4343 namespace so that things like Itpl which rely on its existence
4339 don't crash.
4344 don't crash.
4340 (InteractiveShell._prefilter): Defined the default with a _ so
4345 (InteractiveShell._prefilter): Defined the default with a _ so
4341 that prefilter() is easier to override, while the default one
4346 that prefilter() is easier to override, while the default one
4342 remains available.
4347 remains available.
4343
4348
4344 2002-04-18 Fernando Perez <fperez@colorado.edu>
4349 2002-04-18 Fernando Perez <fperez@colorado.edu>
4345
4350
4346 * Added information about pdb in the docs.
4351 * Added information about pdb in the docs.
4347
4352
4348 2002-04-17 Fernando Perez <fperez@colorado.edu>
4353 2002-04-17 Fernando Perez <fperez@colorado.edu>
4349
4354
4350 * IPython/ipmaker.py (make_IPython): added rc_override option to
4355 * IPython/ipmaker.py (make_IPython): added rc_override option to
4351 allow passing config options at creation time which may override
4356 allow passing config options at creation time which may override
4352 anything set in the config files or command line. This is
4357 anything set in the config files or command line. This is
4353 particularly useful for configuring embedded instances.
4358 particularly useful for configuring embedded instances.
4354
4359
4355 2002-04-15 Fernando Perez <fperez@colorado.edu>
4360 2002-04-15 Fernando Perez <fperez@colorado.edu>
4356
4361
4357 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
4362 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
4358 crash embedded instances because of the input cache falling out of
4363 crash embedded instances because of the input cache falling out of
4359 sync with the output counter.
4364 sync with the output counter.
4360
4365
4361 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
4366 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
4362 mode which calls pdb after an uncaught exception in IPython itself.
4367 mode which calls pdb after an uncaught exception in IPython itself.
4363
4368
4364 2002-04-14 Fernando Perez <fperez@colorado.edu>
4369 2002-04-14 Fernando Perez <fperez@colorado.edu>
4365
4370
4366 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
4371 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
4367 readline, fix it back after each call.
4372 readline, fix it back after each call.
4368
4373
4369 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
4374 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
4370 method to force all access via __call__(), which guarantees that
4375 method to force all access via __call__(), which guarantees that
4371 traceback references are properly deleted.
4376 traceback references are properly deleted.
4372
4377
4373 * IPython/Prompts.py (CachedOutput._display): minor fixes to
4378 * IPython/Prompts.py (CachedOutput._display): minor fixes to
4374 improve printing when pprint is in use.
4379 improve printing when pprint is in use.
4375
4380
4376 2002-04-13 Fernando Perez <fperez@colorado.edu>
4381 2002-04-13 Fernando Perez <fperez@colorado.edu>
4377
4382
4378 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
4383 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
4379 exceptions aren't caught anymore. If the user triggers one, he
4384 exceptions aren't caught anymore. If the user triggers one, he
4380 should know why he's doing it and it should go all the way up,
4385 should know why he's doing it and it should go all the way up,
4381 just like any other exception. So now @abort will fully kill the
4386 just like any other exception. So now @abort will fully kill the
4382 embedded interpreter and the embedding code (unless that happens
4387 embedded interpreter and the embedding code (unless that happens
4383 to catch SystemExit).
4388 to catch SystemExit).
4384
4389
4385 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
4390 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
4386 and a debugger() method to invoke the interactive pdb debugger
4391 and a debugger() method to invoke the interactive pdb debugger
4387 after printing exception information. Also added the corresponding
4392 after printing exception information. Also added the corresponding
4388 -pdb option and @pdb magic to control this feature, and updated
4393 -pdb option and @pdb magic to control this feature, and updated
4389 the docs. After a suggestion from Christopher Hart
4394 the docs. After a suggestion from Christopher Hart
4390 (hart-AT-caltech.edu).
4395 (hart-AT-caltech.edu).
4391
4396
4392 2002-04-12 Fernando Perez <fperez@colorado.edu>
4397 2002-04-12 Fernando Perez <fperez@colorado.edu>
4393
4398
4394 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
4399 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
4395 the exception handlers defined by the user (not the CrashHandler)
4400 the exception handlers defined by the user (not the CrashHandler)
4396 so that user exceptions don't trigger an ipython bug report.
4401 so that user exceptions don't trigger an ipython bug report.
4397
4402
4398 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
4403 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
4399 configurable (it should have always been so).
4404 configurable (it should have always been so).
4400
4405
4401 2002-03-26 Fernando Perez <fperez@colorado.edu>
4406 2002-03-26 Fernando Perez <fperez@colorado.edu>
4402
4407
4403 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
4408 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
4404 and there to fix embedding namespace issues. This should all be
4409 and there to fix embedding namespace issues. This should all be
4405 done in a more elegant way.
4410 done in a more elegant way.
4406
4411
4407 2002-03-25 Fernando Perez <fperez@colorado.edu>
4412 2002-03-25 Fernando Perez <fperez@colorado.edu>
4408
4413
4409 * IPython/genutils.py (get_home_dir): Try to make it work under
4414 * IPython/genutils.py (get_home_dir): Try to make it work under
4410 win9x also.
4415 win9x also.
4411
4416
4412 2002-03-20 Fernando Perez <fperez@colorado.edu>
4417 2002-03-20 Fernando Perez <fperez@colorado.edu>
4413
4418
4414 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
4419 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
4415 sys.displayhook untouched upon __init__.
4420 sys.displayhook untouched upon __init__.
4416
4421
4417 2002-03-19 Fernando Perez <fperez@colorado.edu>
4422 2002-03-19 Fernando Perez <fperez@colorado.edu>
4418
4423
4419 * Released 0.2.9 (for embedding bug, basically).
4424 * Released 0.2.9 (for embedding bug, basically).
4420
4425
4421 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
4426 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
4422 exceptions so that enclosing shell's state can be restored.
4427 exceptions so that enclosing shell's state can be restored.
4423
4428
4424 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
4429 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
4425 naming conventions in the .ipython/ dir.
4430 naming conventions in the .ipython/ dir.
4426
4431
4427 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
4432 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
4428 from delimiters list so filenames with - in them get expanded.
4433 from delimiters list so filenames with - in them get expanded.
4429
4434
4430 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
4435 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
4431 sys.displayhook not being properly restored after an embedded call.
4436 sys.displayhook not being properly restored after an embedded call.
4432
4437
4433 2002-03-18 Fernando Perez <fperez@colorado.edu>
4438 2002-03-18 Fernando Perez <fperez@colorado.edu>
4434
4439
4435 * Released 0.2.8
4440 * Released 0.2.8
4436
4441
4437 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
4442 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
4438 some files weren't being included in a -upgrade.
4443 some files weren't being included in a -upgrade.
4439 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
4444 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
4440 on' so that the first tab completes.
4445 on' so that the first tab completes.
4441 (InteractiveShell.handle_magic): fixed bug with spaces around
4446 (InteractiveShell.handle_magic): fixed bug with spaces around
4442 quotes breaking many magic commands.
4447 quotes breaking many magic commands.
4443
4448
4444 * setup.py: added note about ignoring the syntax error messages at
4449 * setup.py: added note about ignoring the syntax error messages at
4445 installation.
4450 installation.
4446
4451
4447 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
4452 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
4448 streamlining the gnuplot interface, now there's only one magic @gp.
4453 streamlining the gnuplot interface, now there's only one magic @gp.
4449
4454
4450 2002-03-17 Fernando Perez <fperez@colorado.edu>
4455 2002-03-17 Fernando Perez <fperez@colorado.edu>
4451
4456
4452 * IPython/UserConfig/magic_gnuplot.py: new name for the
4457 * IPython/UserConfig/magic_gnuplot.py: new name for the
4453 example-magic_pm.py file. Much enhanced system, now with a shell
4458 example-magic_pm.py file. Much enhanced system, now with a shell
4454 for communicating directly with gnuplot, one command at a time.
4459 for communicating directly with gnuplot, one command at a time.
4455
4460
4456 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
4461 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
4457 setting __name__=='__main__'.
4462 setting __name__=='__main__'.
4458
4463
4459 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
4464 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
4460 mini-shell for accessing gnuplot from inside ipython. Should
4465 mini-shell for accessing gnuplot from inside ipython. Should
4461 extend it later for grace access too. Inspired by Arnd's
4466 extend it later for grace access too. Inspired by Arnd's
4462 suggestion.
4467 suggestion.
4463
4468
4464 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
4469 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
4465 calling magic functions with () in their arguments. Thanks to Arnd
4470 calling magic functions with () in their arguments. Thanks to Arnd
4466 Baecker for pointing this to me.
4471 Baecker for pointing this to me.
4467
4472
4468 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
4473 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
4469 infinitely for integer or complex arrays (only worked with floats).
4474 infinitely for integer or complex arrays (only worked with floats).
4470
4475
4471 2002-03-16 Fernando Perez <fperez@colorado.edu>
4476 2002-03-16 Fernando Perez <fperez@colorado.edu>
4472
4477
4473 * setup.py: Merged setup and setup_windows into a single script
4478 * setup.py: Merged setup and setup_windows into a single script
4474 which properly handles things for windows users.
4479 which properly handles things for windows users.
4475
4480
4476 2002-03-15 Fernando Perez <fperez@colorado.edu>
4481 2002-03-15 Fernando Perez <fperez@colorado.edu>
4477
4482
4478 * Big change to the manual: now the magics are all automatically
4483 * Big change to the manual: now the magics are all automatically
4479 documented. This information is generated from their docstrings
4484 documented. This information is generated from their docstrings
4480 and put in a latex file included by the manual lyx file. This way
4485 and put in a latex file included by the manual lyx file. This way
4481 we get always up to date information for the magics. The manual
4486 we get always up to date information for the magics. The manual
4482 now also has proper version information, also auto-synced.
4487 now also has proper version information, also auto-synced.
4483
4488
4484 For this to work, an undocumented --magic_docstrings option was added.
4489 For this to work, an undocumented --magic_docstrings option was added.
4485
4490
4486 2002-03-13 Fernando Perez <fperez@colorado.edu>
4491 2002-03-13 Fernando Perez <fperez@colorado.edu>
4487
4492
4488 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
4493 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
4489 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
4494 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
4490
4495
4491 2002-03-12 Fernando Perez <fperez@colorado.edu>
4496 2002-03-12 Fernando Perez <fperez@colorado.edu>
4492
4497
4493 * IPython/ultraTB.py (TermColors): changed color escapes again to
4498 * IPython/ultraTB.py (TermColors): changed color escapes again to
4494 fix the (old, reintroduced) line-wrapping bug. Basically, if
4499 fix the (old, reintroduced) line-wrapping bug. Basically, if
4495 \001..\002 aren't given in the color escapes, lines get wrapped
4500 \001..\002 aren't given in the color escapes, lines get wrapped
4496 weirdly. But giving those screws up old xterms and emacs terms. So
4501 weirdly. But giving those screws up old xterms and emacs terms. So
4497 I added some logic for emacs terms to be ok, but I can't identify old
4502 I added some logic for emacs terms to be ok, but I can't identify old
4498 xterms separately ($TERM=='xterm' for many terminals, like konsole).
4503 xterms separately ($TERM=='xterm' for many terminals, like konsole).
4499
4504
4500 2002-03-10 Fernando Perez <fperez@colorado.edu>
4505 2002-03-10 Fernando Perez <fperez@colorado.edu>
4501
4506
4502 * IPython/usage.py (__doc__): Various documentation cleanups and
4507 * IPython/usage.py (__doc__): Various documentation cleanups and
4503 updates, both in usage docstrings and in the manual.
4508 updates, both in usage docstrings and in the manual.
4504
4509
4505 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
4510 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
4506 handling of caching. Set minimum acceptabe value for having a
4511 handling of caching. Set minimum acceptabe value for having a
4507 cache at 20 values.
4512 cache at 20 values.
4508
4513
4509 * IPython/iplib.py (InteractiveShell.user_setup): moved the
4514 * IPython/iplib.py (InteractiveShell.user_setup): moved the
4510 install_first_time function to a method, renamed it and added an
4515 install_first_time function to a method, renamed it and added an
4511 'upgrade' mode. Now people can update their config directory with
4516 'upgrade' mode. Now people can update their config directory with
4512 a simple command line switch (-upgrade, also new).
4517 a simple command line switch (-upgrade, also new).
4513
4518
4514 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
4519 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
4515 @file (convenient for automagic users under Python >= 2.2).
4520 @file (convenient for automagic users under Python >= 2.2).
4516 Removed @files (it seemed more like a plural than an abbrev. of
4521 Removed @files (it seemed more like a plural than an abbrev. of
4517 'file show').
4522 'file show').
4518
4523
4519 * IPython/iplib.py (install_first_time): Fixed crash if there were
4524 * IPython/iplib.py (install_first_time): Fixed crash if there were
4520 backup files ('~') in .ipython/ install directory.
4525 backup files ('~') in .ipython/ install directory.
4521
4526
4522 * IPython/ipmaker.py (make_IPython): fixes for new prompt
4527 * IPython/ipmaker.py (make_IPython): fixes for new prompt
4523 system. Things look fine, but these changes are fairly
4528 system. Things look fine, but these changes are fairly
4524 intrusive. Test them for a few days.
4529 intrusive. Test them for a few days.
4525
4530
4526 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
4531 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
4527 the prompts system. Now all in/out prompt strings are user
4532 the prompts system. Now all in/out prompt strings are user
4528 controllable. This is particularly useful for embedding, as one
4533 controllable. This is particularly useful for embedding, as one
4529 can tag embedded instances with particular prompts.
4534 can tag embedded instances with particular prompts.
4530
4535
4531 Also removed global use of sys.ps1/2, which now allows nested
4536 Also removed global use of sys.ps1/2, which now allows nested
4532 embeddings without any problems. Added command-line options for
4537 embeddings without any problems. Added command-line options for
4533 the prompt strings.
4538 the prompt strings.
4534
4539
4535 2002-03-08 Fernando Perez <fperez@colorado.edu>
4540 2002-03-08 Fernando Perez <fperez@colorado.edu>
4536
4541
4537 * IPython/UserConfig/example-embed-short.py (ipshell): added
4542 * IPython/UserConfig/example-embed-short.py (ipshell): added
4538 example file with the bare minimum code for embedding.
4543 example file with the bare minimum code for embedding.
4539
4544
4540 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
4545 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
4541 functionality for the embeddable shell to be activated/deactivated
4546 functionality for the embeddable shell to be activated/deactivated
4542 either globally or at each call.
4547 either globally or at each call.
4543
4548
4544 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
4549 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
4545 rewriting the prompt with '--->' for auto-inputs with proper
4550 rewriting the prompt with '--->' for auto-inputs with proper
4546 coloring. Now the previous UGLY hack in handle_auto() is gone, and
4551 coloring. Now the previous UGLY hack in handle_auto() is gone, and
4547 this is handled by the prompts class itself, as it should.
4552 this is handled by the prompts class itself, as it should.
4548
4553
4549 2002-03-05 Fernando Perez <fperez@colorado.edu>
4554 2002-03-05 Fernando Perez <fperez@colorado.edu>
4550
4555
4551 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
4556 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
4552 @logstart to avoid name clashes with the math log function.
4557 @logstart to avoid name clashes with the math log function.
4553
4558
4554 * Big updates to X/Emacs section of the manual.
4559 * Big updates to X/Emacs section of the manual.
4555
4560
4556 * Removed ipython_emacs. Milan explained to me how to pass
4561 * Removed ipython_emacs. Milan explained to me how to pass
4557 arguments to ipython through Emacs. Some day I'm going to end up
4562 arguments to ipython through Emacs. Some day I'm going to end up
4558 learning some lisp...
4563 learning some lisp...
4559
4564
4560 2002-03-04 Fernando Perez <fperez@colorado.edu>
4565 2002-03-04 Fernando Perez <fperez@colorado.edu>
4561
4566
4562 * IPython/ipython_emacs: Created script to be used as the
4567 * IPython/ipython_emacs: Created script to be used as the
4563 py-python-command Emacs variable so we can pass IPython
4568 py-python-command Emacs variable so we can pass IPython
4564 parameters. I can't figure out how to tell Emacs directly to pass
4569 parameters. I can't figure out how to tell Emacs directly to pass
4565 parameters to IPython, so a dummy shell script will do it.
4570 parameters to IPython, so a dummy shell script will do it.
4566
4571
4567 Other enhancements made for things to work better under Emacs'
4572 Other enhancements made for things to work better under Emacs'
4568 various types of terminals. Many thanks to Milan Zamazal
4573 various types of terminals. Many thanks to Milan Zamazal
4569 <pdm-AT-zamazal.org> for all the suggestions and pointers.
4574 <pdm-AT-zamazal.org> for all the suggestions and pointers.
4570
4575
4571 2002-03-01 Fernando Perez <fperez@colorado.edu>
4576 2002-03-01 Fernando Perez <fperez@colorado.edu>
4572
4577
4573 * IPython/ipmaker.py (make_IPython): added a --readline! option so
4578 * IPython/ipmaker.py (make_IPython): added a --readline! option so
4574 that loading of readline is now optional. This gives better
4579 that loading of readline is now optional. This gives better
4575 control to emacs users.
4580 control to emacs users.
4576
4581
4577 * IPython/ultraTB.py (__date__): Modified color escape sequences
4582 * IPython/ultraTB.py (__date__): Modified color escape sequences
4578 and now things work fine under xterm and in Emacs' term buffers
4583 and now things work fine under xterm and in Emacs' term buffers
4579 (though not shell ones). Well, in emacs you get colors, but all
4584 (though not shell ones). Well, in emacs you get colors, but all
4580 seem to be 'light' colors (no difference between dark and light
4585 seem to be 'light' colors (no difference between dark and light
4581 ones). But the garbage chars are gone, and also in xterms. It
4586 ones). But the garbage chars are gone, and also in xterms. It
4582 seems that now I'm using 'cleaner' ansi sequences.
4587 seems that now I'm using 'cleaner' ansi sequences.
4583
4588
4584 2002-02-21 Fernando Perez <fperez@colorado.edu>
4589 2002-02-21 Fernando Perez <fperez@colorado.edu>
4585
4590
4586 * Released 0.2.7 (mainly to publish the scoping fix).
4591 * Released 0.2.7 (mainly to publish the scoping fix).
4587
4592
4588 * IPython/Logger.py (Logger.logstate): added. A corresponding
4593 * IPython/Logger.py (Logger.logstate): added. A corresponding
4589 @logstate magic was created.
4594 @logstate magic was created.
4590
4595
4591 * IPython/Magic.py: fixed nested scoping problem under Python
4596 * IPython/Magic.py: fixed nested scoping problem under Python
4592 2.1.x (automagic wasn't working).
4597 2.1.x (automagic wasn't working).
4593
4598
4594 2002-02-20 Fernando Perez <fperez@colorado.edu>
4599 2002-02-20 Fernando Perez <fperez@colorado.edu>
4595
4600
4596 * Released 0.2.6.
4601 * Released 0.2.6.
4597
4602
4598 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
4603 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
4599 option so that logs can come out without any headers at all.
4604 option so that logs can come out without any headers at all.
4600
4605
4601 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
4606 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
4602 SciPy.
4607 SciPy.
4603
4608
4604 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
4609 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
4605 that embedded IPython calls don't require vars() to be explicitly
4610 that embedded IPython calls don't require vars() to be explicitly
4606 passed. Now they are extracted from the caller's frame (code
4611 passed. Now they are extracted from the caller's frame (code
4607 snatched from Eric Jones' weave). Added better documentation to
4612 snatched from Eric Jones' weave). Added better documentation to
4608 the section on embedding and the example file.
4613 the section on embedding and the example file.
4609
4614
4610 * IPython/genutils.py (page): Changed so that under emacs, it just
4615 * IPython/genutils.py (page): Changed so that under emacs, it just
4611 prints the string. You can then page up and down in the emacs
4616 prints the string. You can then page up and down in the emacs
4612 buffer itself. This is how the builtin help() works.
4617 buffer itself. This is how the builtin help() works.
4613
4618
4614 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
4619 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
4615 macro scoping: macros need to be executed in the user's namespace
4620 macro scoping: macros need to be executed in the user's namespace
4616 to work as if they had been typed by the user.
4621 to work as if they had been typed by the user.
4617
4622
4618 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
4623 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
4619 execute automatically (no need to type 'exec...'). They then
4624 execute automatically (no need to type 'exec...'). They then
4620 behave like 'true macros'. The printing system was also modified
4625 behave like 'true macros'. The printing system was also modified
4621 for this to work.
4626 for this to work.
4622
4627
4623 2002-02-19 Fernando Perez <fperez@colorado.edu>
4628 2002-02-19 Fernando Perez <fperez@colorado.edu>
4624
4629
4625 * IPython/genutils.py (page_file): new function for paging files
4630 * IPython/genutils.py (page_file): new function for paging files
4626 in an OS-independent way. Also necessary for file viewing to work
4631 in an OS-independent way. Also necessary for file viewing to work
4627 well inside Emacs buffers.
4632 well inside Emacs buffers.
4628 (page): Added checks for being in an emacs buffer.
4633 (page): Added checks for being in an emacs buffer.
4629 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
4634 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
4630 same bug in iplib.
4635 same bug in iplib.
4631
4636
4632 2002-02-18 Fernando Perez <fperez@colorado.edu>
4637 2002-02-18 Fernando Perez <fperez@colorado.edu>
4633
4638
4634 * IPython/iplib.py (InteractiveShell.init_readline): modified use
4639 * IPython/iplib.py (InteractiveShell.init_readline): modified use
4635 of readline so that IPython can work inside an Emacs buffer.
4640 of readline so that IPython can work inside an Emacs buffer.
4636
4641
4637 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
4642 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
4638 method signatures (they weren't really bugs, but it looks cleaner
4643 method signatures (they weren't really bugs, but it looks cleaner
4639 and keeps PyChecker happy).
4644 and keeps PyChecker happy).
4640
4645
4641 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
4646 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
4642 for implementing various user-defined hooks. Currently only
4647 for implementing various user-defined hooks. Currently only
4643 display is done.
4648 display is done.
4644
4649
4645 * IPython/Prompts.py (CachedOutput._display): changed display
4650 * IPython/Prompts.py (CachedOutput._display): changed display
4646 functions so that they can be dynamically changed by users easily.
4651 functions so that they can be dynamically changed by users easily.
4647
4652
4648 * IPython/Extensions/numeric_formats.py (num_display): added an
4653 * IPython/Extensions/numeric_formats.py (num_display): added an
4649 extension for printing NumPy arrays in flexible manners. It
4654 extension for printing NumPy arrays in flexible manners. It
4650 doesn't do anything yet, but all the structure is in
4655 doesn't do anything yet, but all the structure is in
4651 place. Ultimately the plan is to implement output format control
4656 place. Ultimately the plan is to implement output format control
4652 like in Octave.
4657 like in Octave.
4653
4658
4654 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
4659 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
4655 methods are found at run-time by all the automatic machinery.
4660 methods are found at run-time by all the automatic machinery.
4656
4661
4657 2002-02-17 Fernando Perez <fperez@colorado.edu>
4662 2002-02-17 Fernando Perez <fperez@colorado.edu>
4658
4663
4659 * setup_Windows.py (make_shortcut): documented. Cleaned up the
4664 * setup_Windows.py (make_shortcut): documented. Cleaned up the
4660 whole file a little.
4665 whole file a little.
4661
4666
4662 * ToDo: closed this document. Now there's a new_design.lyx
4667 * ToDo: closed this document. Now there's a new_design.lyx
4663 document for all new ideas. Added making a pdf of it for the
4668 document for all new ideas. Added making a pdf of it for the
4664 end-user distro.
4669 end-user distro.
4665
4670
4666 * IPython/Logger.py (Logger.switch_log): Created this to replace
4671 * IPython/Logger.py (Logger.switch_log): Created this to replace
4667 logon() and logoff(). It also fixes a nasty crash reported by
4672 logon() and logoff(). It also fixes a nasty crash reported by
4668 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
4673 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
4669
4674
4670 * IPython/iplib.py (complete): got auto-completion to work with
4675 * IPython/iplib.py (complete): got auto-completion to work with
4671 automagic (I had wanted this for a long time).
4676 automagic (I had wanted this for a long time).
4672
4677
4673 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
4678 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
4674 to @file, since file() is now a builtin and clashes with automagic
4679 to @file, since file() is now a builtin and clashes with automagic
4675 for @file.
4680 for @file.
4676
4681
4677 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
4682 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
4678 of this was previously in iplib, which had grown to more than 2000
4683 of this was previously in iplib, which had grown to more than 2000
4679 lines, way too long. No new functionality, but it makes managing
4684 lines, way too long. No new functionality, but it makes managing
4680 the code a bit easier.
4685 the code a bit easier.
4681
4686
4682 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
4687 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
4683 information to crash reports.
4688 information to crash reports.
4684
4689
4685 2002-02-12 Fernando Perez <fperez@colorado.edu>
4690 2002-02-12 Fernando Perez <fperez@colorado.edu>
4686
4691
4687 * Released 0.2.5.
4692 * Released 0.2.5.
4688
4693
4689 2002-02-11 Fernando Perez <fperez@colorado.edu>
4694 2002-02-11 Fernando Perez <fperez@colorado.edu>
4690
4695
4691 * Wrote a relatively complete Windows installer. It puts
4696 * Wrote a relatively complete Windows installer. It puts
4692 everything in place, creates Start Menu entries and fixes the
4697 everything in place, creates Start Menu entries and fixes the
4693 color issues. Nothing fancy, but it works.
4698 color issues. Nothing fancy, but it works.
4694
4699
4695 2002-02-10 Fernando Perez <fperez@colorado.edu>
4700 2002-02-10 Fernando Perez <fperez@colorado.edu>
4696
4701
4697 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
4702 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
4698 os.path.expanduser() call so that we can type @run ~/myfile.py and
4703 os.path.expanduser() call so that we can type @run ~/myfile.py and
4699 have thigs work as expected.
4704 have thigs work as expected.
4700
4705
4701 * IPython/genutils.py (page): fixed exception handling so things
4706 * IPython/genutils.py (page): fixed exception handling so things
4702 work both in Unix and Windows correctly. Quitting a pager triggers
4707 work both in Unix and Windows correctly. Quitting a pager triggers
4703 an IOError/broken pipe in Unix, and in windows not finding a pager
4708 an IOError/broken pipe in Unix, and in windows not finding a pager
4704 is also an IOError, so I had to actually look at the return value
4709 is also an IOError, so I had to actually look at the return value
4705 of the exception, not just the exception itself. Should be ok now.
4710 of the exception, not just the exception itself. Should be ok now.
4706
4711
4707 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
4712 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
4708 modified to allow case-insensitive color scheme changes.
4713 modified to allow case-insensitive color scheme changes.
4709
4714
4710 2002-02-09 Fernando Perez <fperez@colorado.edu>
4715 2002-02-09 Fernando Perez <fperez@colorado.edu>
4711
4716
4712 * IPython/genutils.py (native_line_ends): new function to leave
4717 * IPython/genutils.py (native_line_ends): new function to leave
4713 user config files with os-native line-endings.
4718 user config files with os-native line-endings.
4714
4719
4715 * README and manual updates.
4720 * README and manual updates.
4716
4721
4717 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
4722 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
4718 instead of StringType to catch Unicode strings.
4723 instead of StringType to catch Unicode strings.
4719
4724
4720 * IPython/genutils.py (filefind): fixed bug for paths with
4725 * IPython/genutils.py (filefind): fixed bug for paths with
4721 embedded spaces (very common in Windows).
4726 embedded spaces (very common in Windows).
4722
4727
4723 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
4728 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
4724 files under Windows, so that they get automatically associated
4729 files under Windows, so that they get automatically associated
4725 with a text editor. Windows makes it a pain to handle
4730 with a text editor. Windows makes it a pain to handle
4726 extension-less files.
4731 extension-less files.
4727
4732
4728 * IPython/iplib.py (InteractiveShell.init_readline): Made the
4733 * IPython/iplib.py (InteractiveShell.init_readline): Made the
4729 warning about readline only occur for Posix. In Windows there's no
4734 warning about readline only occur for Posix. In Windows there's no
4730 way to get readline, so why bother with the warning.
4735 way to get readline, so why bother with the warning.
4731
4736
4732 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
4737 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
4733 for __str__ instead of dir(self), since dir() changed in 2.2.
4738 for __str__ instead of dir(self), since dir() changed in 2.2.
4734
4739
4735 * Ported to Windows! Tested on XP, I suspect it should work fine
4740 * Ported to Windows! Tested on XP, I suspect it should work fine
4736 on NT/2000, but I don't think it will work on 98 et al. That
4741 on NT/2000, but I don't think it will work on 98 et al. That
4737 series of Windows is such a piece of junk anyway that I won't try
4742 series of Windows is such a piece of junk anyway that I won't try
4738 porting it there. The XP port was straightforward, showed a few
4743 porting it there. The XP port was straightforward, showed a few
4739 bugs here and there (fixed all), in particular some string
4744 bugs here and there (fixed all), in particular some string
4740 handling stuff which required considering Unicode strings (which
4745 handling stuff which required considering Unicode strings (which
4741 Windows uses). This is good, but hasn't been too tested :) No
4746 Windows uses). This is good, but hasn't been too tested :) No
4742 fancy installer yet, I'll put a note in the manual so people at
4747 fancy installer yet, I'll put a note in the manual so people at
4743 least make manually a shortcut.
4748 least make manually a shortcut.
4744
4749
4745 * IPython/iplib.py (Magic.magic_colors): Unified the color options
4750 * IPython/iplib.py (Magic.magic_colors): Unified the color options
4746 into a single one, "colors". This now controls both prompt and
4751 into a single one, "colors". This now controls both prompt and
4747 exception color schemes, and can be changed both at startup
4752 exception color schemes, and can be changed both at startup
4748 (either via command-line switches or via ipythonrc files) and at
4753 (either via command-line switches or via ipythonrc files) and at
4749 runtime, with @colors.
4754 runtime, with @colors.
4750 (Magic.magic_run): renamed @prun to @run and removed the old
4755 (Magic.magic_run): renamed @prun to @run and removed the old
4751 @run. The two were too similar to warrant keeping both.
4756 @run. The two were too similar to warrant keeping both.
4752
4757
4753 2002-02-03 Fernando Perez <fperez@colorado.edu>
4758 2002-02-03 Fernando Perez <fperez@colorado.edu>
4754
4759
4755 * IPython/iplib.py (install_first_time): Added comment on how to
4760 * IPython/iplib.py (install_first_time): Added comment on how to
4756 configure the color options for first-time users. Put a <return>
4761 configure the color options for first-time users. Put a <return>
4757 request at the end so that small-terminal users get a chance to
4762 request at the end so that small-terminal users get a chance to
4758 read the startup info.
4763 read the startup info.
4759
4764
4760 2002-01-23 Fernando Perez <fperez@colorado.edu>
4765 2002-01-23 Fernando Perez <fperez@colorado.edu>
4761
4766
4762 * IPython/iplib.py (CachedOutput.update): Changed output memory
4767 * IPython/iplib.py (CachedOutput.update): Changed output memory
4763 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
4768 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
4764 input history we still use _i. Did this b/c these variable are
4769 input history we still use _i. Did this b/c these variable are
4765 very commonly used in interactive work, so the less we need to
4770 very commonly used in interactive work, so the less we need to
4766 type the better off we are.
4771 type the better off we are.
4767 (Magic.magic_prun): updated @prun to better handle the namespaces
4772 (Magic.magic_prun): updated @prun to better handle the namespaces
4768 the file will run in, including a fix for __name__ not being set
4773 the file will run in, including a fix for __name__ not being set
4769 before.
4774 before.
4770
4775
4771 2002-01-20 Fernando Perez <fperez@colorado.edu>
4776 2002-01-20 Fernando Perez <fperez@colorado.edu>
4772
4777
4773 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
4778 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
4774 extra garbage for Python 2.2. Need to look more carefully into
4779 extra garbage for Python 2.2. Need to look more carefully into
4775 this later.
4780 this later.
4776
4781
4777 2002-01-19 Fernando Perez <fperez@colorado.edu>
4782 2002-01-19 Fernando Perez <fperez@colorado.edu>
4778
4783
4779 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
4784 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
4780 display SyntaxError exceptions properly formatted when they occur
4785 display SyntaxError exceptions properly formatted when they occur
4781 (they can be triggered by imported code).
4786 (they can be triggered by imported code).
4782
4787
4783 2002-01-18 Fernando Perez <fperez@colorado.edu>
4788 2002-01-18 Fernando Perez <fperez@colorado.edu>
4784
4789
4785 * IPython/iplib.py (InteractiveShell.safe_execfile): now
4790 * IPython/iplib.py (InteractiveShell.safe_execfile): now
4786 SyntaxError exceptions are reported nicely formatted, instead of
4791 SyntaxError exceptions are reported nicely formatted, instead of
4787 spitting out only offset information as before.
4792 spitting out only offset information as before.
4788 (Magic.magic_prun): Added the @prun function for executing
4793 (Magic.magic_prun): Added the @prun function for executing
4789 programs with command line args inside IPython.
4794 programs with command line args inside IPython.
4790
4795
4791 2002-01-16 Fernando Perez <fperez@colorado.edu>
4796 2002-01-16 Fernando Perez <fperez@colorado.edu>
4792
4797
4793 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
4798 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
4794 to *not* include the last item given in a range. This brings their
4799 to *not* include the last item given in a range. This brings their
4795 behavior in line with Python's slicing:
4800 behavior in line with Python's slicing:
4796 a[n1:n2] -> a[n1]...a[n2-1]
4801 a[n1:n2] -> a[n1]...a[n2-1]
4797 It may be a bit less convenient, but I prefer to stick to Python's
4802 It may be a bit less convenient, but I prefer to stick to Python's
4798 conventions *everywhere*, so users never have to wonder.
4803 conventions *everywhere*, so users never have to wonder.
4799 (Magic.magic_macro): Added @macro function to ease the creation of
4804 (Magic.magic_macro): Added @macro function to ease the creation of
4800 macros.
4805 macros.
4801
4806
4802 2002-01-05 Fernando Perez <fperez@colorado.edu>
4807 2002-01-05 Fernando Perez <fperez@colorado.edu>
4803
4808
4804 * Released 0.2.4.
4809 * Released 0.2.4.
4805
4810
4806 * IPython/iplib.py (Magic.magic_pdef):
4811 * IPython/iplib.py (Magic.magic_pdef):
4807 (InteractiveShell.safe_execfile): report magic lines and error
4812 (InteractiveShell.safe_execfile): report magic lines and error
4808 lines without line numbers so one can easily copy/paste them for
4813 lines without line numbers so one can easily copy/paste them for
4809 re-execution.
4814 re-execution.
4810
4815
4811 * Updated manual with recent changes.
4816 * Updated manual with recent changes.
4812
4817
4813 * IPython/iplib.py (Magic.magic_oinfo): added constructor
4818 * IPython/iplib.py (Magic.magic_oinfo): added constructor
4814 docstring printing when class? is called. Very handy for knowing
4819 docstring printing when class? is called. Very handy for knowing
4815 how to create class instances (as long as __init__ is well
4820 how to create class instances (as long as __init__ is well
4816 documented, of course :)
4821 documented, of course :)
4817 (Magic.magic_doc): print both class and constructor docstrings.
4822 (Magic.magic_doc): print both class and constructor docstrings.
4818 (Magic.magic_pdef): give constructor info if passed a class and
4823 (Magic.magic_pdef): give constructor info if passed a class and
4819 __call__ info for callable object instances.
4824 __call__ info for callable object instances.
4820
4825
4821 2002-01-04 Fernando Perez <fperez@colorado.edu>
4826 2002-01-04 Fernando Perez <fperez@colorado.edu>
4822
4827
4823 * Made deep_reload() off by default. It doesn't always work
4828 * Made deep_reload() off by default. It doesn't always work
4824 exactly as intended, so it's probably safer to have it off. It's
4829 exactly as intended, so it's probably safer to have it off. It's
4825 still available as dreload() anyway, so nothing is lost.
4830 still available as dreload() anyway, so nothing is lost.
4826
4831
4827 2002-01-02 Fernando Perez <fperez@colorado.edu>
4832 2002-01-02 Fernando Perez <fperez@colorado.edu>
4828
4833
4829 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
4834 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
4830 so I wanted an updated release).
4835 so I wanted an updated release).
4831
4836
4832 2001-12-27 Fernando Perez <fperez@colorado.edu>
4837 2001-12-27 Fernando Perez <fperez@colorado.edu>
4833
4838
4834 * IPython/iplib.py (InteractiveShell.interact): Added the original
4839 * IPython/iplib.py (InteractiveShell.interact): Added the original
4835 code from 'code.py' for this module in order to change the
4840 code from 'code.py' for this module in order to change the
4836 handling of a KeyboardInterrupt. This was necessary b/c otherwise
4841 handling of a KeyboardInterrupt. This was necessary b/c otherwise
4837 the history cache would break when the user hit Ctrl-C, and
4842 the history cache would break when the user hit Ctrl-C, and
4838 interact() offers no way to add any hooks to it.
4843 interact() offers no way to add any hooks to it.
4839
4844
4840 2001-12-23 Fernando Perez <fperez@colorado.edu>
4845 2001-12-23 Fernando Perez <fperez@colorado.edu>
4841
4846
4842 * setup.py: added check for 'MANIFEST' before trying to remove
4847 * setup.py: added check for 'MANIFEST' before trying to remove
4843 it. Thanks to Sean Reifschneider.
4848 it. Thanks to Sean Reifschneider.
4844
4849
4845 2001-12-22 Fernando Perez <fperez@colorado.edu>
4850 2001-12-22 Fernando Perez <fperez@colorado.edu>
4846
4851
4847 * Released 0.2.2.
4852 * Released 0.2.2.
4848
4853
4849 * Finished (reasonably) writing the manual. Later will add the
4854 * Finished (reasonably) writing the manual. Later will add the
4850 python-standard navigation stylesheets, but for the time being
4855 python-standard navigation stylesheets, but for the time being
4851 it's fairly complete. Distribution will include html and pdf
4856 it's fairly complete. Distribution will include html and pdf
4852 versions.
4857 versions.
4853
4858
4854 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
4859 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
4855 (MayaVi author).
4860 (MayaVi author).
4856
4861
4857 2001-12-21 Fernando Perez <fperez@colorado.edu>
4862 2001-12-21 Fernando Perez <fperez@colorado.edu>
4858
4863
4859 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
4864 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
4860 good public release, I think (with the manual and the distutils
4865 good public release, I think (with the manual and the distutils
4861 installer). The manual can use some work, but that can go
4866 installer). The manual can use some work, but that can go
4862 slowly. Otherwise I think it's quite nice for end users. Next
4867 slowly. Otherwise I think it's quite nice for end users. Next
4863 summer, rewrite the guts of it...
4868 summer, rewrite the guts of it...
4864
4869
4865 * Changed format of ipythonrc files to use whitespace as the
4870 * Changed format of ipythonrc files to use whitespace as the
4866 separator instead of an explicit '='. Cleaner.
4871 separator instead of an explicit '='. Cleaner.
4867
4872
4868 2001-12-20 Fernando Perez <fperez@colorado.edu>
4873 2001-12-20 Fernando Perez <fperez@colorado.edu>
4869
4874
4870 * Started a manual in LyX. For now it's just a quick merge of the
4875 * Started a manual in LyX. For now it's just a quick merge of the
4871 various internal docstrings and READMEs. Later it may grow into a
4876 various internal docstrings and READMEs. Later it may grow into a
4872 nice, full-blown manual.
4877 nice, full-blown manual.
4873
4878
4874 * Set up a distutils based installer. Installation should now be
4879 * Set up a distutils based installer. Installation should now be
4875 trivially simple for end-users.
4880 trivially simple for end-users.
4876
4881
4877 2001-12-11 Fernando Perez <fperez@colorado.edu>
4882 2001-12-11 Fernando Perez <fperez@colorado.edu>
4878
4883
4879 * Released 0.2.0. First public release, announced it at
4884 * Released 0.2.0. First public release, announced it at
4880 comp.lang.python. From now on, just bugfixes...
4885 comp.lang.python. From now on, just bugfixes...
4881
4886
4882 * Went through all the files, set copyright/license notices and
4887 * Went through all the files, set copyright/license notices and
4883 cleaned up things. Ready for release.
4888 cleaned up things. Ready for release.
4884
4889
4885 2001-12-10 Fernando Perez <fperez@colorado.edu>
4890 2001-12-10 Fernando Perez <fperez@colorado.edu>
4886
4891
4887 * Changed the first-time installer not to use tarfiles. It's more
4892 * Changed the first-time installer not to use tarfiles. It's more
4888 robust now and less unix-dependent. Also makes it easier for
4893 robust now and less unix-dependent. Also makes it easier for
4889 people to later upgrade versions.
4894 people to later upgrade versions.
4890
4895
4891 * Changed @exit to @abort to reflect the fact that it's pretty
4896 * Changed @exit to @abort to reflect the fact that it's pretty
4892 brutal (a sys.exit()). The difference between @abort and Ctrl-D
4897 brutal (a sys.exit()). The difference between @abort and Ctrl-D
4893 becomes significant only when IPyhton is embedded: in that case,
4898 becomes significant only when IPyhton is embedded: in that case,
4894 C-D closes IPython only, but @abort kills the enclosing program
4899 C-D closes IPython only, but @abort kills the enclosing program
4895 too (unless it had called IPython inside a try catching
4900 too (unless it had called IPython inside a try catching
4896 SystemExit).
4901 SystemExit).
4897
4902
4898 * Created Shell module which exposes the actuall IPython Shell
4903 * Created Shell module which exposes the actuall IPython Shell
4899 classes, currently the normal and the embeddable one. This at
4904 classes, currently the normal and the embeddable one. This at
4900 least offers a stable interface we won't need to change when
4905 least offers a stable interface we won't need to change when
4901 (later) the internals are rewritten. That rewrite will be confined
4906 (later) the internals are rewritten. That rewrite will be confined
4902 to iplib and ipmaker, but the Shell interface should remain as is.
4907 to iplib and ipmaker, but the Shell interface should remain as is.
4903
4908
4904 * Added embed module which offers an embeddable IPShell object,
4909 * Added embed module which offers an embeddable IPShell object,
4905 useful to fire up IPython *inside* a running program. Great for
4910 useful to fire up IPython *inside* a running program. Great for
4906 debugging or dynamical data analysis.
4911 debugging or dynamical data analysis.
4907
4912
4908 2001-12-08 Fernando Perez <fperez@colorado.edu>
4913 2001-12-08 Fernando Perez <fperez@colorado.edu>
4909
4914
4910 * Fixed small bug preventing seeing info from methods of defined
4915 * Fixed small bug preventing seeing info from methods of defined
4911 objects (incorrect namespace in _ofind()).
4916 objects (incorrect namespace in _ofind()).
4912
4917
4913 * Documentation cleanup. Moved the main usage docstrings to a
4918 * Documentation cleanup. Moved the main usage docstrings to a
4914 separate file, usage.py (cleaner to maintain, and hopefully in the
4919 separate file, usage.py (cleaner to maintain, and hopefully in the
4915 future some perlpod-like way of producing interactive, man and
4920 future some perlpod-like way of producing interactive, man and
4916 html docs out of it will be found).
4921 html docs out of it will be found).
4917
4922
4918 * Added @profile to see your profile at any time.
4923 * Added @profile to see your profile at any time.
4919
4924
4920 * Added @p as an alias for 'print'. It's especially convenient if
4925 * Added @p as an alias for 'print'. It's especially convenient if
4921 using automagic ('p x' prints x).
4926 using automagic ('p x' prints x).
4922
4927
4923 * Small cleanups and fixes after a pychecker run.
4928 * Small cleanups and fixes after a pychecker run.
4924
4929
4925 * Changed the @cd command to handle @cd - and @cd -<n> for
4930 * Changed the @cd command to handle @cd - and @cd -<n> for
4926 visiting any directory in _dh.
4931 visiting any directory in _dh.
4927
4932
4928 * Introduced _dh, a history of visited directories. @dhist prints
4933 * Introduced _dh, a history of visited directories. @dhist prints
4929 it out with numbers.
4934 it out with numbers.
4930
4935
4931 2001-12-07 Fernando Perez <fperez@colorado.edu>
4936 2001-12-07 Fernando Perez <fperez@colorado.edu>
4932
4937
4933 * Released 0.1.22
4938 * Released 0.1.22
4934
4939
4935 * Made initialization a bit more robust against invalid color
4940 * Made initialization a bit more robust against invalid color
4936 options in user input (exit, not traceback-crash).
4941 options in user input (exit, not traceback-crash).
4937
4942
4938 * Changed the bug crash reporter to write the report only in the
4943 * Changed the bug crash reporter to write the report only in the
4939 user's .ipython directory. That way IPython won't litter people's
4944 user's .ipython directory. That way IPython won't litter people's
4940 hard disks with crash files all over the place. Also print on
4945 hard disks with crash files all over the place. Also print on
4941 screen the necessary mail command.
4946 screen the necessary mail command.
4942
4947
4943 * With the new ultraTB, implemented LightBG color scheme for light
4948 * With the new ultraTB, implemented LightBG color scheme for light
4944 background terminals. A lot of people like white backgrounds, so I
4949 background terminals. A lot of people like white backgrounds, so I
4945 guess we should at least give them something readable.
4950 guess we should at least give them something readable.
4946
4951
4947 2001-12-06 Fernando Perez <fperez@colorado.edu>
4952 2001-12-06 Fernando Perez <fperez@colorado.edu>
4948
4953
4949 * Modified the structure of ultraTB. Now there's a proper class
4954 * Modified the structure of ultraTB. Now there's a proper class
4950 for tables of color schemes which allow adding schemes easily and
4955 for tables of color schemes which allow adding schemes easily and
4951 switching the active scheme without creating a new instance every
4956 switching the active scheme without creating a new instance every
4952 time (which was ridiculous). The syntax for creating new schemes
4957 time (which was ridiculous). The syntax for creating new schemes
4953 is also cleaner. I think ultraTB is finally done, with a clean
4958 is also cleaner. I think ultraTB is finally done, with a clean
4954 class structure. Names are also much cleaner (now there's proper
4959 class structure. Names are also much cleaner (now there's proper
4955 color tables, no need for every variable to also have 'color' in
4960 color tables, no need for every variable to also have 'color' in
4956 its name).
4961 its name).
4957
4962
4958 * Broke down genutils into separate files. Now genutils only
4963 * Broke down genutils into separate files. Now genutils only
4959 contains utility functions, and classes have been moved to their
4964 contains utility functions, and classes have been moved to their
4960 own files (they had enough independent functionality to warrant
4965 own files (they had enough independent functionality to warrant
4961 it): ConfigLoader, OutputTrap, Struct.
4966 it): ConfigLoader, OutputTrap, Struct.
4962
4967
4963 2001-12-05 Fernando Perez <fperez@colorado.edu>
4968 2001-12-05 Fernando Perez <fperez@colorado.edu>
4964
4969
4965 * IPython turns 21! Released version 0.1.21, as a candidate for
4970 * IPython turns 21! Released version 0.1.21, as a candidate for
4966 public consumption. If all goes well, release in a few days.
4971 public consumption. If all goes well, release in a few days.
4967
4972
4968 * Fixed path bug (files in Extensions/ directory wouldn't be found
4973 * Fixed path bug (files in Extensions/ directory wouldn't be found
4969 unless IPython/ was explicitly in sys.path).
4974 unless IPython/ was explicitly in sys.path).
4970
4975
4971 * Extended the FlexCompleter class as MagicCompleter to allow
4976 * Extended the FlexCompleter class as MagicCompleter to allow
4972 completion of @-starting lines.
4977 completion of @-starting lines.
4973
4978
4974 * Created __release__.py file as a central repository for release
4979 * Created __release__.py file as a central repository for release
4975 info that other files can read from.
4980 info that other files can read from.
4976
4981
4977 * Fixed small bug in logging: when logging was turned on in
4982 * Fixed small bug in logging: when logging was turned on in
4978 mid-session, old lines with special meanings (!@?) were being
4983 mid-session, old lines with special meanings (!@?) were being
4979 logged without the prepended comment, which is necessary since
4984 logged without the prepended comment, which is necessary since
4980 they are not truly valid python syntax. This should make session
4985 they are not truly valid python syntax. This should make session
4981 restores produce less errors.
4986 restores produce less errors.
4982
4987
4983 * The namespace cleanup forced me to make a FlexCompleter class
4988 * The namespace cleanup forced me to make a FlexCompleter class
4984 which is nothing but a ripoff of rlcompleter, but with selectable
4989 which is nothing but a ripoff of rlcompleter, but with selectable
4985 namespace (rlcompleter only works in __main__.__dict__). I'll try
4990 namespace (rlcompleter only works in __main__.__dict__). I'll try
4986 to submit a note to the authors to see if this change can be
4991 to submit a note to the authors to see if this change can be
4987 incorporated in future rlcompleter releases (Dec.6: done)
4992 incorporated in future rlcompleter releases (Dec.6: done)
4988
4993
4989 * More fixes to namespace handling. It was a mess! Now all
4994 * More fixes to namespace handling. It was a mess! Now all
4990 explicit references to __main__.__dict__ are gone (except when
4995 explicit references to __main__.__dict__ are gone (except when
4991 really needed) and everything is handled through the namespace
4996 really needed) and everything is handled through the namespace
4992 dicts in the IPython instance. We seem to be getting somewhere
4997 dicts in the IPython instance. We seem to be getting somewhere
4993 with this, finally...
4998 with this, finally...
4994
4999
4995 * Small documentation updates.
5000 * Small documentation updates.
4996
5001
4997 * Created the Extensions directory under IPython (with an
5002 * Created the Extensions directory under IPython (with an
4998 __init__.py). Put the PhysicalQ stuff there. This directory should
5003 __init__.py). Put the PhysicalQ stuff there. This directory should
4999 be used for all special-purpose extensions.
5004 be used for all special-purpose extensions.
5000
5005
5001 * File renaming:
5006 * File renaming:
5002 ipythonlib --> ipmaker
5007 ipythonlib --> ipmaker
5003 ipplib --> iplib
5008 ipplib --> iplib
5004 This makes a bit more sense in terms of what these files actually do.
5009 This makes a bit more sense in terms of what these files actually do.
5005
5010
5006 * Moved all the classes and functions in ipythonlib to ipplib, so
5011 * Moved all the classes and functions in ipythonlib to ipplib, so
5007 now ipythonlib only has make_IPython(). This will ease up its
5012 now ipythonlib only has make_IPython(). This will ease up its
5008 splitting in smaller functional chunks later.
5013 splitting in smaller functional chunks later.
5009
5014
5010 * Cleaned up (done, I think) output of @whos. Better column
5015 * Cleaned up (done, I think) output of @whos. Better column
5011 formatting, and now shows str(var) for as much as it can, which is
5016 formatting, and now shows str(var) for as much as it can, which is
5012 typically what one gets with a 'print var'.
5017 typically what one gets with a 'print var'.
5013
5018
5014 2001-12-04 Fernando Perez <fperez@colorado.edu>
5019 2001-12-04 Fernando Perez <fperez@colorado.edu>
5015
5020
5016 * Fixed namespace problems. Now builtin/IPyhton/user names get
5021 * Fixed namespace problems. Now builtin/IPyhton/user names get
5017 properly reported in their namespace. Internal namespace handling
5022 properly reported in their namespace. Internal namespace handling
5018 is finally getting decent (not perfect yet, but much better than
5023 is finally getting decent (not perfect yet, but much better than
5019 the ad-hoc mess we had).
5024 the ad-hoc mess we had).
5020
5025
5021 * Removed -exit option. If people just want to run a python
5026 * Removed -exit option. If people just want to run a python
5022 script, that's what the normal interpreter is for. Less
5027 script, that's what the normal interpreter is for. Less
5023 unnecessary options, less chances for bugs.
5028 unnecessary options, less chances for bugs.
5024
5029
5025 * Added a crash handler which generates a complete post-mortem if
5030 * Added a crash handler which generates a complete post-mortem if
5026 IPython crashes. This will help a lot in tracking bugs down the
5031 IPython crashes. This will help a lot in tracking bugs down the
5027 road.
5032 road.
5028
5033
5029 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
5034 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
5030 which were boud to functions being reassigned would bypass the
5035 which were boud to functions being reassigned would bypass the
5031 logger, breaking the sync of _il with the prompt counter. This
5036 logger, breaking the sync of _il with the prompt counter. This
5032 would then crash IPython later when a new line was logged.
5037 would then crash IPython later when a new line was logged.
5033
5038
5034 2001-12-02 Fernando Perez <fperez@colorado.edu>
5039 2001-12-02 Fernando Perez <fperez@colorado.edu>
5035
5040
5036 * Made IPython a package. This means people don't have to clutter
5041 * Made IPython a package. This means people don't have to clutter
5037 their sys.path with yet another directory. Changed the INSTALL
5042 their sys.path with yet another directory. Changed the INSTALL
5038 file accordingly.
5043 file accordingly.
5039
5044
5040 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
5045 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
5041 sorts its output (so @who shows it sorted) and @whos formats the
5046 sorts its output (so @who shows it sorted) and @whos formats the
5042 table according to the width of the first column. Nicer, easier to
5047 table according to the width of the first column. Nicer, easier to
5043 read. Todo: write a generic table_format() which takes a list of
5048 read. Todo: write a generic table_format() which takes a list of
5044 lists and prints it nicely formatted, with optional row/column
5049 lists and prints it nicely formatted, with optional row/column
5045 separators and proper padding and justification.
5050 separators and proper padding and justification.
5046
5051
5047 * Released 0.1.20
5052 * Released 0.1.20
5048
5053
5049 * Fixed bug in @log which would reverse the inputcache list (a
5054 * Fixed bug in @log which would reverse the inputcache list (a
5050 copy operation was missing).
5055 copy operation was missing).
5051
5056
5052 * Code cleanup. @config was changed to use page(). Better, since
5057 * Code cleanup. @config was changed to use page(). Better, since
5053 its output is always quite long.
5058 its output is always quite long.
5054
5059
5055 * Itpl is back as a dependency. I was having too many problems
5060 * Itpl is back as a dependency. I was having too many problems
5056 getting the parametric aliases to work reliably, and it's just
5061 getting the parametric aliases to work reliably, and it's just
5057 easier to code weird string operations with it than playing %()s
5062 easier to code weird string operations with it than playing %()s
5058 games. It's only ~6k, so I don't think it's too big a deal.
5063 games. It's only ~6k, so I don't think it's too big a deal.
5059
5064
5060 * Found (and fixed) a very nasty bug with history. !lines weren't
5065 * Found (and fixed) a very nasty bug with history. !lines weren't
5061 getting cached, and the out of sync caches would crash
5066 getting cached, and the out of sync caches would crash
5062 IPython. Fixed it by reorganizing the prefilter/handlers/logger
5067 IPython. Fixed it by reorganizing the prefilter/handlers/logger
5063 division of labor a bit better. Bug fixed, cleaner structure.
5068 division of labor a bit better. Bug fixed, cleaner structure.
5064
5069
5065 2001-12-01 Fernando Perez <fperez@colorado.edu>
5070 2001-12-01 Fernando Perez <fperez@colorado.edu>
5066
5071
5067 * Released 0.1.19
5072 * Released 0.1.19
5068
5073
5069 * Added option -n to @hist to prevent line number printing. Much
5074 * Added option -n to @hist to prevent line number printing. Much
5070 easier to copy/paste code this way.
5075 easier to copy/paste code this way.
5071
5076
5072 * Created global _il to hold the input list. Allows easy
5077 * Created global _il to hold the input list. Allows easy
5073 re-execution of blocks of code by slicing it (inspired by Janko's
5078 re-execution of blocks of code by slicing it (inspired by Janko's
5074 comment on 'macros').
5079 comment on 'macros').
5075
5080
5076 * Small fixes and doc updates.
5081 * Small fixes and doc updates.
5077
5082
5078 * Rewrote @history function (was @h). Renamed it to @hist, @h is
5083 * Rewrote @history function (was @h). Renamed it to @hist, @h is
5079 much too fragile with automagic. Handles properly multi-line
5084 much too fragile with automagic. Handles properly multi-line
5080 statements and takes parameters.
5085 statements and takes parameters.
5081
5086
5082 2001-11-30 Fernando Perez <fperez@colorado.edu>
5087 2001-11-30 Fernando Perez <fperez@colorado.edu>
5083
5088
5084 * Version 0.1.18 released.
5089 * Version 0.1.18 released.
5085
5090
5086 * Fixed nasty namespace bug in initial module imports.
5091 * Fixed nasty namespace bug in initial module imports.
5087
5092
5088 * Added copyright/license notes to all code files (except
5093 * Added copyright/license notes to all code files (except
5089 DPyGetOpt). For the time being, LGPL. That could change.
5094 DPyGetOpt). For the time being, LGPL. That could change.
5090
5095
5091 * Rewrote a much nicer README, updated INSTALL, cleaned up
5096 * Rewrote a much nicer README, updated INSTALL, cleaned up
5092 ipythonrc-* samples.
5097 ipythonrc-* samples.
5093
5098
5094 * Overall code/documentation cleanup. Basically ready for
5099 * Overall code/documentation cleanup. Basically ready for
5095 release. Only remaining thing: licence decision (LGPL?).
5100 release. Only remaining thing: licence decision (LGPL?).
5096
5101
5097 * Converted load_config to a class, ConfigLoader. Now recursion
5102 * Converted load_config to a class, ConfigLoader. Now recursion
5098 control is better organized. Doesn't include the same file twice.
5103 control is better organized. Doesn't include the same file twice.
5099
5104
5100 2001-11-29 Fernando Perez <fperez@colorado.edu>
5105 2001-11-29 Fernando Perez <fperez@colorado.edu>
5101
5106
5102 * Got input history working. Changed output history variables from
5107 * Got input history working. Changed output history variables from
5103 _p to _o so that _i is for input and _o for output. Just cleaner
5108 _p to _o so that _i is for input and _o for output. Just cleaner
5104 convention.
5109 convention.
5105
5110
5106 * Implemented parametric aliases. This pretty much allows the
5111 * Implemented parametric aliases. This pretty much allows the
5107 alias system to offer full-blown shell convenience, I think.
5112 alias system to offer full-blown shell convenience, I think.
5108
5113
5109 * Version 0.1.17 released, 0.1.18 opened.
5114 * Version 0.1.17 released, 0.1.18 opened.
5110
5115
5111 * dot_ipython/ipythonrc (alias): added documentation.
5116 * dot_ipython/ipythonrc (alias): added documentation.
5112 (xcolor): Fixed small bug (xcolors -> xcolor)
5117 (xcolor): Fixed small bug (xcolors -> xcolor)
5113
5118
5114 * Changed the alias system. Now alias is a magic command to define
5119 * Changed the alias system. Now alias is a magic command to define
5115 aliases just like the shell. Rationale: the builtin magics should
5120 aliases just like the shell. Rationale: the builtin magics should
5116 be there for things deeply connected to IPython's
5121 be there for things deeply connected to IPython's
5117 architecture. And this is a much lighter system for what I think
5122 architecture. And this is a much lighter system for what I think
5118 is the really important feature: allowing users to define quickly
5123 is the really important feature: allowing users to define quickly
5119 magics that will do shell things for them, so they can customize
5124 magics that will do shell things for them, so they can customize
5120 IPython easily to match their work habits. If someone is really
5125 IPython easily to match their work habits. If someone is really
5121 desperate to have another name for a builtin alias, they can
5126 desperate to have another name for a builtin alias, they can
5122 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
5127 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
5123 works.
5128 works.
5124
5129
5125 2001-11-28 Fernando Perez <fperez@colorado.edu>
5130 2001-11-28 Fernando Perez <fperez@colorado.edu>
5126
5131
5127 * Changed @file so that it opens the source file at the proper
5132 * Changed @file so that it opens the source file at the proper
5128 line. Since it uses less, if your EDITOR environment is
5133 line. Since it uses less, if your EDITOR environment is
5129 configured, typing v will immediately open your editor of choice
5134 configured, typing v will immediately open your editor of choice
5130 right at the line where the object is defined. Not as quick as
5135 right at the line where the object is defined. Not as quick as
5131 having a direct @edit command, but for all intents and purposes it
5136 having a direct @edit command, but for all intents and purposes it
5132 works. And I don't have to worry about writing @edit to deal with
5137 works. And I don't have to worry about writing @edit to deal with
5133 all the editors, less does that.
5138 all the editors, less does that.
5134
5139
5135 * Version 0.1.16 released, 0.1.17 opened.
5140 * Version 0.1.16 released, 0.1.17 opened.
5136
5141
5137 * Fixed some nasty bugs in the page/page_dumb combo that could
5142 * Fixed some nasty bugs in the page/page_dumb combo that could
5138 crash IPython.
5143 crash IPython.
5139
5144
5140 2001-11-27 Fernando Perez <fperez@colorado.edu>
5145 2001-11-27 Fernando Perez <fperez@colorado.edu>
5141
5146
5142 * Version 0.1.15 released, 0.1.16 opened.
5147 * Version 0.1.15 released, 0.1.16 opened.
5143
5148
5144 * Finally got ? and ?? to work for undefined things: now it's
5149 * Finally got ? and ?? to work for undefined things: now it's
5145 possible to type {}.get? and get information about the get method
5150 possible to type {}.get? and get information about the get method
5146 of dicts, or os.path? even if only os is defined (so technically
5151 of dicts, or os.path? even if only os is defined (so technically
5147 os.path isn't). Works at any level. For example, after import os,
5152 os.path isn't). Works at any level. For example, after import os,
5148 os?, os.path?, os.path.abspath? all work. This is great, took some
5153 os?, os.path?, os.path.abspath? all work. This is great, took some
5149 work in _ofind.
5154 work in _ofind.
5150
5155
5151 * Fixed more bugs with logging. The sanest way to do it was to add
5156 * Fixed more bugs with logging. The sanest way to do it was to add
5152 to @log a 'mode' parameter. Killed two in one shot (this mode
5157 to @log a 'mode' parameter. Killed two in one shot (this mode
5153 option was a request of Janko's). I think it's finally clean
5158 option was a request of Janko's). I think it's finally clean
5154 (famous last words).
5159 (famous last words).
5155
5160
5156 * Added a page_dumb() pager which does a decent job of paging on
5161 * Added a page_dumb() pager which does a decent job of paging on
5157 screen, if better things (like less) aren't available. One less
5162 screen, if better things (like less) aren't available. One less
5158 unix dependency (someday maybe somebody will port this to
5163 unix dependency (someday maybe somebody will port this to
5159 windows).
5164 windows).
5160
5165
5161 * Fixed problem in magic_log: would lock of logging out if log
5166 * Fixed problem in magic_log: would lock of logging out if log
5162 creation failed (because it would still think it had succeeded).
5167 creation failed (because it would still think it had succeeded).
5163
5168
5164 * Improved the page() function using curses to auto-detect screen
5169 * Improved the page() function using curses to auto-detect screen
5165 size. Now it can make a much better decision on whether to print
5170 size. Now it can make a much better decision on whether to print
5166 or page a string. Option screen_length was modified: a value 0
5171 or page a string. Option screen_length was modified: a value 0
5167 means auto-detect, and that's the default now.
5172 means auto-detect, and that's the default now.
5168
5173
5169 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
5174 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
5170 go out. I'll test it for a few days, then talk to Janko about
5175 go out. I'll test it for a few days, then talk to Janko about
5171 licences and announce it.
5176 licences and announce it.
5172
5177
5173 * Fixed the length of the auto-generated ---> prompt which appears
5178 * Fixed the length of the auto-generated ---> prompt which appears
5174 for auto-parens and auto-quotes. Getting this right isn't trivial,
5179 for auto-parens and auto-quotes. Getting this right isn't trivial,
5175 with all the color escapes, different prompt types and optional
5180 with all the color escapes, different prompt types and optional
5176 separators. But it seems to be working in all the combinations.
5181 separators. But it seems to be working in all the combinations.
5177
5182
5178 2001-11-26 Fernando Perez <fperez@colorado.edu>
5183 2001-11-26 Fernando Perez <fperez@colorado.edu>
5179
5184
5180 * Wrote a regexp filter to get option types from the option names
5185 * Wrote a regexp filter to get option types from the option names
5181 string. This eliminates the need to manually keep two duplicate
5186 string. This eliminates the need to manually keep two duplicate
5182 lists.
5187 lists.
5183
5188
5184 * Removed the unneeded check_option_names. Now options are handled
5189 * Removed the unneeded check_option_names. Now options are handled
5185 in a much saner manner and it's easy to visually check that things
5190 in a much saner manner and it's easy to visually check that things
5186 are ok.
5191 are ok.
5187
5192
5188 * Updated version numbers on all files I modified to carry a
5193 * Updated version numbers on all files I modified to carry a
5189 notice so Janko and Nathan have clear version markers.
5194 notice so Janko and Nathan have clear version markers.
5190
5195
5191 * Updated docstring for ultraTB with my changes. I should send
5196 * Updated docstring for ultraTB with my changes. I should send
5192 this to Nathan.
5197 this to Nathan.
5193
5198
5194 * Lots of small fixes. Ran everything through pychecker again.
5199 * Lots of small fixes. Ran everything through pychecker again.
5195
5200
5196 * Made loading of deep_reload an cmd line option. If it's not too
5201 * Made loading of deep_reload an cmd line option. If it's not too
5197 kosher, now people can just disable it. With -nodeep_reload it's
5202 kosher, now people can just disable it. With -nodeep_reload it's
5198 still available as dreload(), it just won't overwrite reload().
5203 still available as dreload(), it just won't overwrite reload().
5199
5204
5200 * Moved many options to the no| form (-opt and -noopt
5205 * Moved many options to the no| form (-opt and -noopt
5201 accepted). Cleaner.
5206 accepted). Cleaner.
5202
5207
5203 * Changed magic_log so that if called with no parameters, it uses
5208 * Changed magic_log so that if called with no parameters, it uses
5204 'rotate' mode. That way auto-generated logs aren't automatically
5209 'rotate' mode. That way auto-generated logs aren't automatically
5205 over-written. For normal logs, now a backup is made if it exists
5210 over-written. For normal logs, now a backup is made if it exists
5206 (only 1 level of backups). A new 'backup' mode was added to the
5211 (only 1 level of backups). A new 'backup' mode was added to the
5207 Logger class to support this. This was a request by Janko.
5212 Logger class to support this. This was a request by Janko.
5208
5213
5209 * Added @logoff/@logon to stop/restart an active log.
5214 * Added @logoff/@logon to stop/restart an active log.
5210
5215
5211 * Fixed a lot of bugs in log saving/replay. It was pretty
5216 * Fixed a lot of bugs in log saving/replay. It was pretty
5212 broken. Now special lines (!@,/) appear properly in the command
5217 broken. Now special lines (!@,/) appear properly in the command
5213 history after a log replay.
5218 history after a log replay.
5214
5219
5215 * Tried and failed to implement full session saving via pickle. My
5220 * Tried and failed to implement full session saving via pickle. My
5216 idea was to pickle __main__.__dict__, but modules can't be
5221 idea was to pickle __main__.__dict__, but modules can't be
5217 pickled. This would be a better alternative to replaying logs, but
5222 pickled. This would be a better alternative to replaying logs, but
5218 seems quite tricky to get to work. Changed -session to be called
5223 seems quite tricky to get to work. Changed -session to be called
5219 -logplay, which more accurately reflects what it does. And if we
5224 -logplay, which more accurately reflects what it does. And if we
5220 ever get real session saving working, -session is now available.
5225 ever get real session saving working, -session is now available.
5221
5226
5222 * Implemented color schemes for prompts also. As for tracebacks,
5227 * Implemented color schemes for prompts also. As for tracebacks,
5223 currently only NoColor and Linux are supported. But now the
5228 currently only NoColor and Linux are supported. But now the
5224 infrastructure is in place, based on a generic ColorScheme
5229 infrastructure is in place, based on a generic ColorScheme
5225 class. So writing and activating new schemes both for the prompts
5230 class. So writing and activating new schemes both for the prompts
5226 and the tracebacks should be straightforward.
5231 and the tracebacks should be straightforward.
5227
5232
5228 * Version 0.1.13 released, 0.1.14 opened.
5233 * Version 0.1.13 released, 0.1.14 opened.
5229
5234
5230 * Changed handling of options for output cache. Now counter is
5235 * Changed handling of options for output cache. Now counter is
5231 hardwired starting at 1 and one specifies the maximum number of
5236 hardwired starting at 1 and one specifies the maximum number of
5232 entries *in the outcache* (not the max prompt counter). This is
5237 entries *in the outcache* (not the max prompt counter). This is
5233 much better, since many statements won't increase the cache
5238 much better, since many statements won't increase the cache
5234 count. It also eliminated some confusing options, now there's only
5239 count. It also eliminated some confusing options, now there's only
5235 one: cache_size.
5240 one: cache_size.
5236
5241
5237 * Added 'alias' magic function and magic_alias option in the
5242 * Added 'alias' magic function and magic_alias option in the
5238 ipythonrc file. Now the user can easily define whatever names he
5243 ipythonrc file. Now the user can easily define whatever names he
5239 wants for the magic functions without having to play weird
5244 wants for the magic functions without having to play weird
5240 namespace games. This gives IPython a real shell-like feel.
5245 namespace games. This gives IPython a real shell-like feel.
5241
5246
5242 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
5247 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
5243 @ or not).
5248 @ or not).
5244
5249
5245 This was one of the last remaining 'visible' bugs (that I know
5250 This was one of the last remaining 'visible' bugs (that I know
5246 of). I think if I can clean up the session loading so it works
5251 of). I think if I can clean up the session loading so it works
5247 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
5252 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
5248 about licensing).
5253 about licensing).
5249
5254
5250 2001-11-25 Fernando Perez <fperez@colorado.edu>
5255 2001-11-25 Fernando Perez <fperez@colorado.edu>
5251
5256
5252 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
5257 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
5253 there's a cleaner distinction between what ? and ?? show.
5258 there's a cleaner distinction between what ? and ?? show.
5254
5259
5255 * Added screen_length option. Now the user can define his own
5260 * Added screen_length option. Now the user can define his own
5256 screen size for page() operations.
5261 screen size for page() operations.
5257
5262
5258 * Implemented magic shell-like functions with automatic code
5263 * Implemented magic shell-like functions with automatic code
5259 generation. Now adding another function is just a matter of adding
5264 generation. Now adding another function is just a matter of adding
5260 an entry to a dict, and the function is dynamically generated at
5265 an entry to a dict, and the function is dynamically generated at
5261 run-time. Python has some really cool features!
5266 run-time. Python has some really cool features!
5262
5267
5263 * Renamed many options to cleanup conventions a little. Now all
5268 * Renamed many options to cleanup conventions a little. Now all
5264 are lowercase, and only underscores where needed. Also in the code
5269 are lowercase, and only underscores where needed. Also in the code
5265 option name tables are clearer.
5270 option name tables are clearer.
5266
5271
5267 * Changed prompts a little. Now input is 'In [n]:' instead of
5272 * Changed prompts a little. Now input is 'In [n]:' instead of
5268 'In[n]:='. This allows it the numbers to be aligned with the
5273 'In[n]:='. This allows it the numbers to be aligned with the
5269 Out[n] numbers, and removes usage of ':=' which doesn't exist in
5274 Out[n] numbers, and removes usage of ':=' which doesn't exist in
5270 Python (it was a Mathematica thing). The '...' continuation prompt
5275 Python (it was a Mathematica thing). The '...' continuation prompt
5271 was also changed a little to align better.
5276 was also changed a little to align better.
5272
5277
5273 * Fixed bug when flushing output cache. Not all _p<n> variables
5278 * Fixed bug when flushing output cache. Not all _p<n> variables
5274 exist, so their deletion needs to be wrapped in a try:
5279 exist, so their deletion needs to be wrapped in a try:
5275
5280
5276 * Figured out how to properly use inspect.formatargspec() (it
5281 * Figured out how to properly use inspect.formatargspec() (it
5277 requires the args preceded by *). So I removed all the code from
5282 requires the args preceded by *). So I removed all the code from
5278 _get_pdef in Magic, which was just replicating that.
5283 _get_pdef in Magic, which was just replicating that.
5279
5284
5280 * Added test to prefilter to allow redefining magic function names
5285 * Added test to prefilter to allow redefining magic function names
5281 as variables. This is ok, since the @ form is always available,
5286 as variables. This is ok, since the @ form is always available,
5282 but whe should allow the user to define a variable called 'ls' if
5287 but whe should allow the user to define a variable called 'ls' if
5283 he needs it.
5288 he needs it.
5284
5289
5285 * Moved the ToDo information from README into a separate ToDo.
5290 * Moved the ToDo information from README into a separate ToDo.
5286
5291
5287 * General code cleanup and small bugfixes. I think it's close to a
5292 * General code cleanup and small bugfixes. I think it's close to a
5288 state where it can be released, obviously with a big 'beta'
5293 state where it can be released, obviously with a big 'beta'
5289 warning on it.
5294 warning on it.
5290
5295
5291 * Got the magic function split to work. Now all magics are defined
5296 * Got the magic function split to work. Now all magics are defined
5292 in a separate class. It just organizes things a bit, and now
5297 in a separate class. It just organizes things a bit, and now
5293 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
5298 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
5294 was too long).
5299 was too long).
5295
5300
5296 * Changed @clear to @reset to avoid potential confusions with
5301 * Changed @clear to @reset to avoid potential confusions with
5297 the shell command clear. Also renamed @cl to @clear, which does
5302 the shell command clear. Also renamed @cl to @clear, which does
5298 exactly what people expect it to from their shell experience.
5303 exactly what people expect it to from their shell experience.
5299
5304
5300 Added a check to the @reset command (since it's so
5305 Added a check to the @reset command (since it's so
5301 destructive, it's probably a good idea to ask for confirmation).
5306 destructive, it's probably a good idea to ask for confirmation).
5302 But now reset only works for full namespace resetting. Since the
5307 But now reset only works for full namespace resetting. Since the
5303 del keyword is already there for deleting a few specific
5308 del keyword is already there for deleting a few specific
5304 variables, I don't see the point of having a redundant magic
5309 variables, I don't see the point of having a redundant magic
5305 function for the same task.
5310 function for the same task.
5306
5311
5307 2001-11-24 Fernando Perez <fperez@colorado.edu>
5312 2001-11-24 Fernando Perez <fperez@colorado.edu>
5308
5313
5309 * Updated the builtin docs (esp. the ? ones).
5314 * Updated the builtin docs (esp. the ? ones).
5310
5315
5311 * Ran all the code through pychecker. Not terribly impressed with
5316 * Ran all the code through pychecker. Not terribly impressed with
5312 it: lots of spurious warnings and didn't really find anything of
5317 it: lots of spurious warnings and didn't really find anything of
5313 substance (just a few modules being imported and not used).
5318 substance (just a few modules being imported and not used).
5314
5319
5315 * Implemented the new ultraTB functionality into IPython. New
5320 * Implemented the new ultraTB functionality into IPython. New
5316 option: xcolors. This chooses color scheme. xmode now only selects
5321 option: xcolors. This chooses color scheme. xmode now only selects
5317 between Plain and Verbose. Better orthogonality.
5322 between Plain and Verbose. Better orthogonality.
5318
5323
5319 * Large rewrite of ultraTB. Much cleaner now, with a separation of
5324 * Large rewrite of ultraTB. Much cleaner now, with a separation of
5320 mode and color scheme for the exception handlers. Now it's
5325 mode and color scheme for the exception handlers. Now it's
5321 possible to have the verbose traceback with no coloring.
5326 possible to have the verbose traceback with no coloring.
5322
5327
5323 2001-11-23 Fernando Perez <fperez@colorado.edu>
5328 2001-11-23 Fernando Perez <fperez@colorado.edu>
5324
5329
5325 * Version 0.1.12 released, 0.1.13 opened.
5330 * Version 0.1.12 released, 0.1.13 opened.
5326
5331
5327 * Removed option to set auto-quote and auto-paren escapes by
5332 * Removed option to set auto-quote and auto-paren escapes by
5328 user. The chances of breaking valid syntax are just too high. If
5333 user. The chances of breaking valid syntax are just too high. If
5329 someone *really* wants, they can always dig into the code.
5334 someone *really* wants, they can always dig into the code.
5330
5335
5331 * Made prompt separators configurable.
5336 * Made prompt separators configurable.
5332
5337
5333 2001-11-22 Fernando Perez <fperez@colorado.edu>
5338 2001-11-22 Fernando Perez <fperez@colorado.edu>
5334
5339
5335 * Small bugfixes in many places.
5340 * Small bugfixes in many places.
5336
5341
5337 * Removed the MyCompleter class from ipplib. It seemed redundant
5342 * Removed the MyCompleter class from ipplib. It seemed redundant
5338 with the C-p,C-n history search functionality. Less code to
5343 with the C-p,C-n history search functionality. Less code to
5339 maintain.
5344 maintain.
5340
5345
5341 * Moved all the original ipython.py code into ipythonlib.py. Right
5346 * Moved all the original ipython.py code into ipythonlib.py. Right
5342 now it's just one big dump into a function called make_IPython, so
5347 now it's just one big dump into a function called make_IPython, so
5343 no real modularity has been gained. But at least it makes the
5348 no real modularity has been gained. But at least it makes the
5344 wrapper script tiny, and since ipythonlib is a module, it gets
5349 wrapper script tiny, and since ipythonlib is a module, it gets
5345 compiled and startup is much faster.
5350 compiled and startup is much faster.
5346
5351
5347 This is a reasobably 'deep' change, so we should test it for a
5352 This is a reasobably 'deep' change, so we should test it for a
5348 while without messing too much more with the code.
5353 while without messing too much more with the code.
5349
5354
5350 2001-11-21 Fernando Perez <fperez@colorado.edu>
5355 2001-11-21 Fernando Perez <fperez@colorado.edu>
5351
5356
5352 * Version 0.1.11 released, 0.1.12 opened for further work.
5357 * Version 0.1.11 released, 0.1.12 opened for further work.
5353
5358
5354 * Removed dependency on Itpl. It was only needed in one place. It
5359 * Removed dependency on Itpl. It was only needed in one place. It
5355 would be nice if this became part of python, though. It makes life
5360 would be nice if this became part of python, though. It makes life
5356 *a lot* easier in some cases.
5361 *a lot* easier in some cases.
5357
5362
5358 * Simplified the prefilter code a bit. Now all handlers are
5363 * Simplified the prefilter code a bit. Now all handlers are
5359 expected to explicitly return a value (at least a blank string).
5364 expected to explicitly return a value (at least a blank string).
5360
5365
5361 * Heavy edits in ipplib. Removed the help system altogether. Now
5366 * Heavy edits in ipplib. Removed the help system altogether. Now
5362 obj?/?? is used for inspecting objects, a magic @doc prints
5367 obj?/?? is used for inspecting objects, a magic @doc prints
5363 docstrings, and full-blown Python help is accessed via the 'help'
5368 docstrings, and full-blown Python help is accessed via the 'help'
5364 keyword. This cleans up a lot of code (less to maintain) and does
5369 keyword. This cleans up a lot of code (less to maintain) and does
5365 the job. Since 'help' is now a standard Python component, might as
5370 the job. Since 'help' is now a standard Python component, might as
5366 well use it and remove duplicate functionality.
5371 well use it and remove duplicate functionality.
5367
5372
5368 Also removed the option to use ipplib as a standalone program. By
5373 Also removed the option to use ipplib as a standalone program. By
5369 now it's too dependent on other parts of IPython to function alone.
5374 now it's too dependent on other parts of IPython to function alone.
5370
5375
5371 * Fixed bug in genutils.pager. It would crash if the pager was
5376 * Fixed bug in genutils.pager. It would crash if the pager was
5372 exited immediately after opening (broken pipe).
5377 exited immediately after opening (broken pipe).
5373
5378
5374 * Trimmed down the VerboseTB reporting a little. The header is
5379 * Trimmed down the VerboseTB reporting a little. The header is
5375 much shorter now and the repeated exception arguments at the end
5380 much shorter now and the repeated exception arguments at the end
5376 have been removed. For interactive use the old header seemed a bit
5381 have been removed. For interactive use the old header seemed a bit
5377 excessive.
5382 excessive.
5378
5383
5379 * Fixed small bug in output of @whos for variables with multi-word
5384 * Fixed small bug in output of @whos for variables with multi-word
5380 types (only first word was displayed).
5385 types (only first word was displayed).
5381
5386
5382 2001-11-17 Fernando Perez <fperez@colorado.edu>
5387 2001-11-17 Fernando Perez <fperez@colorado.edu>
5383
5388
5384 * Version 0.1.10 released, 0.1.11 opened for further work.
5389 * Version 0.1.10 released, 0.1.11 opened for further work.
5385
5390
5386 * Modified dirs and friends. dirs now *returns* the stack (not
5391 * Modified dirs and friends. dirs now *returns* the stack (not
5387 prints), so one can manipulate it as a variable. Convenient to
5392 prints), so one can manipulate it as a variable. Convenient to
5388 travel along many directories.
5393 travel along many directories.
5389
5394
5390 * Fixed bug in magic_pdef: would only work with functions with
5395 * Fixed bug in magic_pdef: would only work with functions with
5391 arguments with default values.
5396 arguments with default values.
5392
5397
5393 2001-11-14 Fernando Perez <fperez@colorado.edu>
5398 2001-11-14 Fernando Perez <fperez@colorado.edu>
5394
5399
5395 * Added the PhysicsInput stuff to dot_ipython so it ships as an
5400 * Added the PhysicsInput stuff to dot_ipython so it ships as an
5396 example with IPython. Various other minor fixes and cleanups.
5401 example with IPython. Various other minor fixes and cleanups.
5397
5402
5398 * Version 0.1.9 released, 0.1.10 opened for further work.
5403 * Version 0.1.9 released, 0.1.10 opened for further work.
5399
5404
5400 * Added sys.path to the list of directories searched in the
5405 * Added sys.path to the list of directories searched in the
5401 execfile= option. It used to be the current directory and the
5406 execfile= option. It used to be the current directory and the
5402 user's IPYTHONDIR only.
5407 user's IPYTHONDIR only.
5403
5408
5404 2001-11-13 Fernando Perez <fperez@colorado.edu>
5409 2001-11-13 Fernando Perez <fperez@colorado.edu>
5405
5410
5406 * Reinstated the raw_input/prefilter separation that Janko had
5411 * Reinstated the raw_input/prefilter separation that Janko had
5407 initially. This gives a more convenient setup for extending the
5412 initially. This gives a more convenient setup for extending the
5408 pre-processor from the outside: raw_input always gets a string,
5413 pre-processor from the outside: raw_input always gets a string,
5409 and prefilter has to process it. We can then redefine prefilter
5414 and prefilter has to process it. We can then redefine prefilter
5410 from the outside and implement extensions for special
5415 from the outside and implement extensions for special
5411 purposes.
5416 purposes.
5412
5417
5413 Today I got one for inputting PhysicalQuantity objects
5418 Today I got one for inputting PhysicalQuantity objects
5414 (from Scientific) without needing any function calls at
5419 (from Scientific) without needing any function calls at
5415 all. Extremely convenient, and it's all done as a user-level
5420 all. Extremely convenient, and it's all done as a user-level
5416 extension (no IPython code was touched). Now instead of:
5421 extension (no IPython code was touched). Now instead of:
5417 a = PhysicalQuantity(4.2,'m/s**2')
5422 a = PhysicalQuantity(4.2,'m/s**2')
5418 one can simply say
5423 one can simply say
5419 a = 4.2 m/s**2
5424 a = 4.2 m/s**2
5420 or even
5425 or even
5421 a = 4.2 m/s^2
5426 a = 4.2 m/s^2
5422
5427
5423 I use this, but it's also a proof of concept: IPython really is
5428 I use this, but it's also a proof of concept: IPython really is
5424 fully user-extensible, even at the level of the parsing of the
5429 fully user-extensible, even at the level of the parsing of the
5425 command line. It's not trivial, but it's perfectly doable.
5430 command line. It's not trivial, but it's perfectly doable.
5426
5431
5427 * Added 'add_flip' method to inclusion conflict resolver. Fixes
5432 * Added 'add_flip' method to inclusion conflict resolver. Fixes
5428 the problem of modules being loaded in the inverse order in which
5433 the problem of modules being loaded in the inverse order in which
5429 they were defined in
5434 they were defined in
5430
5435
5431 * Version 0.1.8 released, 0.1.9 opened for further work.
5436 * Version 0.1.8 released, 0.1.9 opened for further work.
5432
5437
5433 * Added magics pdef, source and file. They respectively show the
5438 * Added magics pdef, source and file. They respectively show the
5434 definition line ('prototype' in C), source code and full python
5439 definition line ('prototype' in C), source code and full python
5435 file for any callable object. The object inspector oinfo uses
5440 file for any callable object. The object inspector oinfo uses
5436 these to show the same information.
5441 these to show the same information.
5437
5442
5438 * Version 0.1.7 released, 0.1.8 opened for further work.
5443 * Version 0.1.7 released, 0.1.8 opened for further work.
5439
5444
5440 * Separated all the magic functions into a class called Magic. The
5445 * Separated all the magic functions into a class called Magic. The
5441 InteractiveShell class was becoming too big for Xemacs to handle
5446 InteractiveShell class was becoming too big for Xemacs to handle
5442 (de-indenting a line would lock it up for 10 seconds while it
5447 (de-indenting a line would lock it up for 10 seconds while it
5443 backtracked on the whole class!)
5448 backtracked on the whole class!)
5444
5449
5445 FIXME: didn't work. It can be done, but right now namespaces are
5450 FIXME: didn't work. It can be done, but right now namespaces are
5446 all messed up. Do it later (reverted it for now, so at least
5451 all messed up. Do it later (reverted it for now, so at least
5447 everything works as before).
5452 everything works as before).
5448
5453
5449 * Got the object introspection system (magic_oinfo) working! I
5454 * Got the object introspection system (magic_oinfo) working! I
5450 think this is pretty much ready for release to Janko, so he can
5455 think this is pretty much ready for release to Janko, so he can
5451 test it for a while and then announce it. Pretty much 100% of what
5456 test it for a while and then announce it. Pretty much 100% of what
5452 I wanted for the 'phase 1' release is ready. Happy, tired.
5457 I wanted for the 'phase 1' release is ready. Happy, tired.
5453
5458
5454 2001-11-12 Fernando Perez <fperez@colorado.edu>
5459 2001-11-12 Fernando Perez <fperez@colorado.edu>
5455
5460
5456 * Version 0.1.6 released, 0.1.7 opened for further work.
5461 * Version 0.1.6 released, 0.1.7 opened for further work.
5457
5462
5458 * Fixed bug in printing: it used to test for truth before
5463 * Fixed bug in printing: it used to test for truth before
5459 printing, so 0 wouldn't print. Now checks for None.
5464 printing, so 0 wouldn't print. Now checks for None.
5460
5465
5461 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
5466 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
5462 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
5467 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
5463 reaches by hand into the outputcache. Think of a better way to do
5468 reaches by hand into the outputcache. Think of a better way to do
5464 this later.
5469 this later.
5465
5470
5466 * Various small fixes thanks to Nathan's comments.
5471 * Various small fixes thanks to Nathan's comments.
5467
5472
5468 * Changed magic_pprint to magic_Pprint. This way it doesn't
5473 * Changed magic_pprint to magic_Pprint. This way it doesn't
5469 collide with pprint() and the name is consistent with the command
5474 collide with pprint() and the name is consistent with the command
5470 line option.
5475 line option.
5471
5476
5472 * Changed prompt counter behavior to be fully like
5477 * Changed prompt counter behavior to be fully like
5473 Mathematica's. That is, even input that doesn't return a result
5478 Mathematica's. That is, even input that doesn't return a result
5474 raises the prompt counter. The old behavior was kind of confusing
5479 raises the prompt counter. The old behavior was kind of confusing
5475 (getting the same prompt number several times if the operation
5480 (getting the same prompt number several times if the operation
5476 didn't return a result).
5481 didn't return a result).
5477
5482
5478 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
5483 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
5479
5484
5480 * Fixed -Classic mode (wasn't working anymore).
5485 * Fixed -Classic mode (wasn't working anymore).
5481
5486
5482 * Added colored prompts using Nathan's new code. Colors are
5487 * Added colored prompts using Nathan's new code. Colors are
5483 currently hardwired, they can be user-configurable. For
5488 currently hardwired, they can be user-configurable. For
5484 developers, they can be chosen in file ipythonlib.py, at the
5489 developers, they can be chosen in file ipythonlib.py, at the
5485 beginning of the CachedOutput class def.
5490 beginning of the CachedOutput class def.
5486
5491
5487 2001-11-11 Fernando Perez <fperez@colorado.edu>
5492 2001-11-11 Fernando Perez <fperez@colorado.edu>
5488
5493
5489 * Version 0.1.5 released, 0.1.6 opened for further work.
5494 * Version 0.1.5 released, 0.1.6 opened for further work.
5490
5495
5491 * Changed magic_env to *return* the environment as a dict (not to
5496 * Changed magic_env to *return* the environment as a dict (not to
5492 print it). This way it prints, but it can also be processed.
5497 print it). This way it prints, but it can also be processed.
5493
5498
5494 * Added Verbose exception reporting to interactive
5499 * Added Verbose exception reporting to interactive
5495 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
5500 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
5496 traceback. Had to make some changes to the ultraTB file. This is
5501 traceback. Had to make some changes to the ultraTB file. This is
5497 probably the last 'big' thing in my mental todo list. This ties
5502 probably the last 'big' thing in my mental todo list. This ties
5498 in with the next entry:
5503 in with the next entry:
5499
5504
5500 * Changed -Xi and -Xf to a single -xmode option. Now all the user
5505 * Changed -Xi and -Xf to a single -xmode option. Now all the user
5501 has to specify is Plain, Color or Verbose for all exception
5506 has to specify is Plain, Color or Verbose for all exception
5502 handling.
5507 handling.
5503
5508
5504 * Removed ShellServices option. All this can really be done via
5509 * Removed ShellServices option. All this can really be done via
5505 the magic system. It's easier to extend, cleaner and has automatic
5510 the magic system. It's easier to extend, cleaner and has automatic
5506 namespace protection and documentation.
5511 namespace protection and documentation.
5507
5512
5508 2001-11-09 Fernando Perez <fperez@colorado.edu>
5513 2001-11-09 Fernando Perez <fperez@colorado.edu>
5509
5514
5510 * Fixed bug in output cache flushing (missing parameter to
5515 * Fixed bug in output cache flushing (missing parameter to
5511 __init__). Other small bugs fixed (found using pychecker).
5516 __init__). Other small bugs fixed (found using pychecker).
5512
5517
5513 * Version 0.1.4 opened for bugfixing.
5518 * Version 0.1.4 opened for bugfixing.
5514
5519
5515 2001-11-07 Fernando Perez <fperez@colorado.edu>
5520 2001-11-07 Fernando Perez <fperez@colorado.edu>
5516
5521
5517 * Version 0.1.3 released, mainly because of the raw_input bug.
5522 * Version 0.1.3 released, mainly because of the raw_input bug.
5518
5523
5519 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
5524 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
5520 and when testing for whether things were callable, a call could
5525 and when testing for whether things were callable, a call could
5521 actually be made to certain functions. They would get called again
5526 actually be made to certain functions. They would get called again
5522 once 'really' executed, with a resulting double call. A disaster
5527 once 'really' executed, with a resulting double call. A disaster
5523 in many cases (list.reverse() would never work!).
5528 in many cases (list.reverse() would never work!).
5524
5529
5525 * Removed prefilter() function, moved its code to raw_input (which
5530 * Removed prefilter() function, moved its code to raw_input (which
5526 after all was just a near-empty caller for prefilter). This saves
5531 after all was just a near-empty caller for prefilter). This saves
5527 a function call on every prompt, and simplifies the class a tiny bit.
5532 a function call on every prompt, and simplifies the class a tiny bit.
5528
5533
5529 * Fix _ip to __ip name in magic example file.
5534 * Fix _ip to __ip name in magic example file.
5530
5535
5531 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
5536 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
5532 work with non-gnu versions of tar.
5537 work with non-gnu versions of tar.
5533
5538
5534 2001-11-06 Fernando Perez <fperez@colorado.edu>
5539 2001-11-06 Fernando Perez <fperez@colorado.edu>
5535
5540
5536 * Version 0.1.2. Just to keep track of the recent changes.
5541 * Version 0.1.2. Just to keep track of the recent changes.
5537
5542
5538 * Fixed nasty bug in output prompt routine. It used to check 'if
5543 * Fixed nasty bug in output prompt routine. It used to check 'if
5539 arg != None...'. Problem is, this fails if arg implements a
5544 arg != None...'. Problem is, this fails if arg implements a
5540 special comparison (__cmp__) which disallows comparing to
5545 special comparison (__cmp__) which disallows comparing to
5541 None. Found it when trying to use the PhysicalQuantity module from
5546 None. Found it when trying to use the PhysicalQuantity module from
5542 ScientificPython.
5547 ScientificPython.
5543
5548
5544 2001-11-05 Fernando Perez <fperez@colorado.edu>
5549 2001-11-05 Fernando Perez <fperez@colorado.edu>
5545
5550
5546 * Also added dirs. Now the pushd/popd/dirs family functions
5551 * Also added dirs. Now the pushd/popd/dirs family functions
5547 basically like the shell, with the added convenience of going home
5552 basically like the shell, with the added convenience of going home
5548 when called with no args.
5553 when called with no args.
5549
5554
5550 * pushd/popd slightly modified to mimic shell behavior more
5555 * pushd/popd slightly modified to mimic shell behavior more
5551 closely.
5556 closely.
5552
5557
5553 * Added env,pushd,popd from ShellServices as magic functions. I
5558 * Added env,pushd,popd from ShellServices as magic functions. I
5554 think the cleanest will be to port all desired functions from
5559 think the cleanest will be to port all desired functions from
5555 ShellServices as magics and remove ShellServices altogether. This
5560 ShellServices as magics and remove ShellServices altogether. This
5556 will provide a single, clean way of adding functionality
5561 will provide a single, clean way of adding functionality
5557 (shell-type or otherwise) to IP.
5562 (shell-type or otherwise) to IP.
5558
5563
5559 2001-11-04 Fernando Perez <fperez@colorado.edu>
5564 2001-11-04 Fernando Perez <fperez@colorado.edu>
5560
5565
5561 * Added .ipython/ directory to sys.path. This way users can keep
5566 * Added .ipython/ directory to sys.path. This way users can keep
5562 customizations there and access them via import.
5567 customizations there and access them via import.
5563
5568
5564 2001-11-03 Fernando Perez <fperez@colorado.edu>
5569 2001-11-03 Fernando Perez <fperez@colorado.edu>
5565
5570
5566 * Opened version 0.1.1 for new changes.
5571 * Opened version 0.1.1 for new changes.
5567
5572
5568 * Changed version number to 0.1.0: first 'public' release, sent to
5573 * Changed version number to 0.1.0: first 'public' release, sent to
5569 Nathan and Janko.
5574 Nathan and Janko.
5570
5575
5571 * Lots of small fixes and tweaks.
5576 * Lots of small fixes and tweaks.
5572
5577
5573 * Minor changes to whos format. Now strings are shown, snipped if
5578 * Minor changes to whos format. Now strings are shown, snipped if
5574 too long.
5579 too long.
5575
5580
5576 * Changed ShellServices to work on __main__ so they show up in @who
5581 * Changed ShellServices to work on __main__ so they show up in @who
5577
5582
5578 * Help also works with ? at the end of a line:
5583 * Help also works with ? at the end of a line:
5579 ?sin and sin?
5584 ?sin and sin?
5580 both produce the same effect. This is nice, as often I use the
5585 both produce the same effect. This is nice, as often I use the
5581 tab-complete to find the name of a method, but I used to then have
5586 tab-complete to find the name of a method, but I used to then have
5582 to go to the beginning of the line to put a ? if I wanted more
5587 to go to the beginning of the line to put a ? if I wanted more
5583 info. Now I can just add the ? and hit return. Convenient.
5588 info. Now I can just add the ? and hit return. Convenient.
5584
5589
5585 2001-11-02 Fernando Perez <fperez@colorado.edu>
5590 2001-11-02 Fernando Perez <fperez@colorado.edu>
5586
5591
5587 * Python version check (>=2.1) added.
5592 * Python version check (>=2.1) added.
5588
5593
5589 * Added LazyPython documentation. At this point the docs are quite
5594 * Added LazyPython documentation. At this point the docs are quite
5590 a mess. A cleanup is in order.
5595 a mess. A cleanup is in order.
5591
5596
5592 * Auto-installer created. For some bizarre reason, the zipfiles
5597 * Auto-installer created. For some bizarre reason, the zipfiles
5593 module isn't working on my system. So I made a tar version
5598 module isn't working on my system. So I made a tar version
5594 (hopefully the command line options in various systems won't kill
5599 (hopefully the command line options in various systems won't kill
5595 me).
5600 me).
5596
5601
5597 * Fixes to Struct in genutils. Now all dictionary-like methods are
5602 * Fixes to Struct in genutils. Now all dictionary-like methods are
5598 protected (reasonably).
5603 protected (reasonably).
5599
5604
5600 * Added pager function to genutils and changed ? to print usage
5605 * Added pager function to genutils and changed ? to print usage
5601 note through it (it was too long).
5606 note through it (it was too long).
5602
5607
5603 * Added the LazyPython functionality. Works great! I changed the
5608 * Added the LazyPython functionality. Works great! I changed the
5604 auto-quote escape to ';', it's on home row and next to '. But
5609 auto-quote escape to ';', it's on home row and next to '. But
5605 both auto-quote and auto-paren (still /) escapes are command-line
5610 both auto-quote and auto-paren (still /) escapes are command-line
5606 parameters.
5611 parameters.
5607
5612
5608
5613
5609 2001-11-01 Fernando Perez <fperez@colorado.edu>
5614 2001-11-01 Fernando Perez <fperez@colorado.edu>
5610
5615
5611 * Version changed to 0.0.7. Fairly large change: configuration now
5616 * Version changed to 0.0.7. Fairly large change: configuration now
5612 is all stored in a directory, by default .ipython. There, all
5617 is all stored in a directory, by default .ipython. There, all
5613 config files have normal looking names (not .names)
5618 config files have normal looking names (not .names)
5614
5619
5615 * Version 0.0.6 Released first to Lucas and Archie as a test
5620 * Version 0.0.6 Released first to Lucas and Archie as a test
5616 run. Since it's the first 'semi-public' release, change version to
5621 run. Since it's the first 'semi-public' release, change version to
5617 > 0.0.6 for any changes now.
5622 > 0.0.6 for any changes now.
5618
5623
5619 * Stuff I had put in the ipplib.py changelog:
5624 * Stuff I had put in the ipplib.py changelog:
5620
5625
5621 Changes to InteractiveShell:
5626 Changes to InteractiveShell:
5622
5627
5623 - Made the usage message a parameter.
5628 - Made the usage message a parameter.
5624
5629
5625 - Require the name of the shell variable to be given. It's a bit
5630 - Require the name of the shell variable to be given. It's a bit
5626 of a hack, but allows the name 'shell' not to be hardwired in the
5631 of a hack, but allows the name 'shell' not to be hardwired in the
5627 magic (@) handler, which is problematic b/c it requires
5632 magic (@) handler, which is problematic b/c it requires
5628 polluting the global namespace with 'shell'. This in turn is
5633 polluting the global namespace with 'shell'. This in turn is
5629 fragile: if a user redefines a variable called shell, things
5634 fragile: if a user redefines a variable called shell, things
5630 break.
5635 break.
5631
5636
5632 - magic @: all functions available through @ need to be defined
5637 - magic @: all functions available through @ need to be defined
5633 as magic_<name>, even though they can be called simply as
5638 as magic_<name>, even though they can be called simply as
5634 @<name>. This allows the special command @magic to gather
5639 @<name>. This allows the special command @magic to gather
5635 information automatically about all existing magic functions,
5640 information automatically about all existing magic functions,
5636 even if they are run-time user extensions, by parsing the shell
5641 even if they are run-time user extensions, by parsing the shell
5637 instance __dict__ looking for special magic_ names.
5642 instance __dict__ looking for special magic_ names.
5638
5643
5639 - mainloop: added *two* local namespace parameters. This allows
5644 - mainloop: added *two* local namespace parameters. This allows
5640 the class to differentiate between parameters which were there
5645 the class to differentiate between parameters which were there
5641 before and after command line initialization was processed. This
5646 before and after command line initialization was processed. This
5642 way, later @who can show things loaded at startup by the
5647 way, later @who can show things loaded at startup by the
5643 user. This trick was necessary to make session saving/reloading
5648 user. This trick was necessary to make session saving/reloading
5644 really work: ideally after saving/exiting/reloading a session,
5649 really work: ideally after saving/exiting/reloading a session,
5645 *everything* should look the same, including the output of @who. I
5650 *everything* should look the same, including the output of @who. I
5646 was only able to make this work with this double namespace
5651 was only able to make this work with this double namespace
5647 trick.
5652 trick.
5648
5653
5649 - added a header to the logfile which allows (almost) full
5654 - added a header to the logfile which allows (almost) full
5650 session restoring.
5655 session restoring.
5651
5656
5652 - prepend lines beginning with @ or !, with a and log
5657 - prepend lines beginning with @ or !, with a and log
5653 them. Why? !lines: may be useful to know what you did @lines:
5658 them. Why? !lines: may be useful to know what you did @lines:
5654 they may affect session state. So when restoring a session, at
5659 they may affect session state. So when restoring a session, at
5655 least inform the user of their presence. I couldn't quite get
5660 least inform the user of their presence. I couldn't quite get
5656 them to properly re-execute, but at least the user is warned.
5661 them to properly re-execute, but at least the user is warned.
5657
5662
5658 * Started ChangeLog.
5663 * Started ChangeLog.
General Comments 0
You need to be logged in to leave comments. Login now