##// END OF EJS Templates
Fix xrepr for ifiles (Bug detected by Paul Mueller).
walter.doerwald -
Show More
@@ -1,2153 +1,2153 b''
1 # -*- coding: iso-8859-1 -*-
1 # -*- coding: iso-8859-1 -*-
2
2
3 """
3 """
4 ``ipipe`` provides classes to be used in an interactive Python session. Doing a
4 ``ipipe`` provides classes to be used in an interactive Python session. Doing a
5 ``from ipipe import *`` is the preferred way to do this. The name of all
5 ``from ipipe import *`` is the preferred way to do this. The name of all
6 objects imported this way starts with ``i`` to minimize collisions.
6 objects imported this way starts with ``i`` to minimize collisions.
7
7
8 ``ipipe`` supports "pipeline expressions", which is something resembling Unix
8 ``ipipe`` supports "pipeline expressions", which is something resembling Unix
9 pipes. An example is:
9 pipes. An example is:
10
10
11 >>> ienv | isort("key.lower()")
11 >>> ienv | isort("key.lower()")
12
12
13 This gives a listing of all environment variables sorted by name.
13 This gives a listing of all environment variables sorted by name.
14
14
15
15
16 There are three types of objects in a pipeline expression:
16 There are three types of objects in a pipeline expression:
17
17
18 * ``Table``s: These objects produce items. Examples are ``ils`` (listing the
18 * ``Table``s: These objects produce items. Examples are ``ils`` (listing the
19 current directory, ``ienv`` (listing environment variables), ``ipwd`` (listing
19 current directory, ``ienv`` (listing environment variables), ``ipwd`` (listing
20 user accounts) and ``igrp`` (listing user groups). A ``Table`` must be the
20 user accounts) and ``igrp`` (listing user groups). A ``Table`` must be the
21 first object in a pipe expression.
21 first object in a pipe expression.
22
22
23 * ``Pipe``s: These objects sit in the middle of a pipe expression. They
23 * ``Pipe``s: These objects sit in the middle of a pipe expression. They
24 transform the input in some way (e.g. filtering or sorting it). Examples are:
24 transform the input in some way (e.g. filtering or sorting it). Examples are:
25 ``ifilter`` (which filters the input pipe), ``isort`` (which sorts the input
25 ``ifilter`` (which filters the input pipe), ``isort`` (which sorts the input
26 pipe) and ``ieval`` (which evaluates a function or expression for each object
26 pipe) and ``ieval`` (which evaluates a function or expression for each object
27 in the input pipe).
27 in the input pipe).
28
28
29 * ``Display``s: These objects can be put as the last object in a pipeline
29 * ``Display``s: These objects can be put as the last object in a pipeline
30 expression. There are responsible for displaying the result of the pipeline
30 expression. There are responsible for displaying the result of the pipeline
31 expression. If a pipeline expression doesn't end in a display object a default
31 expression. If a pipeline expression doesn't end in a display object a default
32 display objects will be used. One example is ``ibrowse`` which is a ``curses``
32 display objects will be used. One example is ``ibrowse`` which is a ``curses``
33 based browser.
33 based browser.
34
34
35
35
36 Adding support for pipeline expressions to your own objects can be done through
36 Adding support for pipeline expressions to your own objects can be done through
37 three extensions points (all of them optional):
37 three extensions points (all of them optional):
38
38
39 * An object that will be displayed as a row by a ``Display`` object should
39 * An object that will be displayed as a row by a ``Display`` object should
40 implement the method ``__xattrs__(self, mode)`` method or register an
40 implement the method ``__xattrs__(self, mode)`` method or register an
41 implementation of the generic function ``xattrs``. For more info see ``xattrs``.
41 implementation of the generic function ``xattrs``. For more info see ``xattrs``.
42
42
43 * When an object ``foo`` is displayed by a ``Display`` object, the generic
43 * When an object ``foo`` is displayed by a ``Display`` object, the generic
44 function ``xrepr`` is used.
44 function ``xrepr`` is used.
45
45
46 * Objects that can be iterated by ``Pipe``s must iterable. For special cases,
46 * Objects that can be iterated by ``Pipe``s must iterable. For special cases,
47 where iteration for display is different than the normal iteration a special
47 where iteration for display is different than the normal iteration a special
48 implementation can be registered with the generic function ``xiter``. This makes
48 implementation can be registered with the generic function ``xiter``. This makes
49 it possible to use dictionaries and modules in pipeline expressions, for example:
49 it possible to use dictionaries and modules in pipeline expressions, for example:
50
50
51 >>> import sys
51 >>> import sys
52 >>> sys | ifilter("isinstance(value, int)") | idump
52 >>> sys | ifilter("isinstance(value, int)") | idump
53 key |value
53 key |value
54 api_version| 1012
54 api_version| 1012
55 dllhandle | 503316480
55 dllhandle | 503316480
56 hexversion | 33817328
56 hexversion | 33817328
57 maxint |2147483647
57 maxint |2147483647
58 maxunicode | 65535
58 maxunicode | 65535
59 >>> sys.modules | ifilter("_.value is not None") | isort("_.key.lower()")
59 >>> sys.modules | ifilter("_.value is not None") | isort("_.key.lower()")
60 ...
60 ...
61
61
62 Note: The expression strings passed to ``ifilter()`` and ``isort()`` can
62 Note: The expression strings passed to ``ifilter()`` and ``isort()`` can
63 refer to the object to be filtered or sorted via the variable ``_`` and to any
63 refer to the object to be filtered or sorted via the variable ``_`` and to any
64 of the attributes of the object, i.e.:
64 of the attributes of the object, i.e.:
65
65
66 >>> sys.modules | ifilter("_.value is not None") | isort("_.key.lower()")
66 >>> sys.modules | ifilter("_.value is not None") | isort("_.key.lower()")
67
67
68 does the same as
68 does the same as
69
69
70 >>> sys.modules | ifilter("value is not None") | isort("key.lower()")
70 >>> sys.modules | ifilter("value is not None") | isort("key.lower()")
71
71
72 In addition to expression strings, it's possible to pass callables (taking
72 In addition to expression strings, it's possible to pass callables (taking
73 the object as an argument) to ``ifilter()``, ``isort()`` and ``ieval()``:
73 the object as an argument) to ``ifilter()``, ``isort()`` and ``ieval()``:
74
74
75 >>> sys | ifilter(lambda _:isinstance(_.value, int)) \
75 >>> sys | ifilter(lambda _:isinstance(_.value, int)) \
76 ... | ieval(lambda _: (_.key, hex(_.value))) | idump
76 ... | ieval(lambda _: (_.key, hex(_.value))) | idump
77 0 |1
77 0 |1
78 api_version|0x3f4
78 api_version|0x3f4
79 dllhandle |0x1e000000
79 dllhandle |0x1e000000
80 hexversion |0x20402f0
80 hexversion |0x20402f0
81 maxint |0x7fffffff
81 maxint |0x7fffffff
82 maxunicode |0xffff
82 maxunicode |0xffff
83 """
83 """
84
84
85 import sys, os, os.path, stat, glob, new, csv, datetime, types
85 import sys, os, os.path, stat, glob, new, csv, datetime, types
86 import itertools, mimetypes
86 import itertools, mimetypes
87
87
88 try: # Python 2.3 compatibility
88 try: # Python 2.3 compatibility
89 import collections
89 import collections
90 except ImportError:
90 except ImportError:
91 deque = list
91 deque = list
92 else:
92 else:
93 deque = collections.deque
93 deque = collections.deque
94
94
95 try: # Python 2.3 compatibility
95 try: # Python 2.3 compatibility
96 set
96 set
97 except NameError:
97 except NameError:
98 import sets
98 import sets
99 set = sets.Set
99 set = sets.Set
100
100
101 try: # Python 2.3 compatibility
101 try: # Python 2.3 compatibility
102 sorted
102 sorted
103 except NameError:
103 except NameError:
104 def sorted(iterator, key=None, reverse=False):
104 def sorted(iterator, key=None, reverse=False):
105 items = list(iterator)
105 items = list(iterator)
106 if key is not None:
106 if key is not None:
107 items.sort(lambda i1, i2: cmp(key(i1), key(i2)))
107 items.sort(lambda i1, i2: cmp(key(i1), key(i2)))
108 else:
108 else:
109 items.sort()
109 items.sort()
110 if reverse:
110 if reverse:
111 items.reverse()
111 items.reverse()
112 return items
112 return items
113
113
114 try:
114 try:
115 import pwd
115 import pwd
116 except ImportError:
116 except ImportError:
117 pwd = None
117 pwd = None
118
118
119 try:
119 try:
120 import grp
120 import grp
121 except ImportError:
121 except ImportError:
122 grp = None
122 grp = None
123
123
124 from IPython.external import simplegeneric
124 from IPython.external import simplegeneric
125
125
126 import path
126 import path
127 try:
127 try:
128 from IPython import genutils, ipapi
128 from IPython import genutils, ipapi
129 except ImportError:
129 except ImportError:
130 genutils = None
130 genutils = None
131 ipapi = None
131 ipapi = None
132
132
133 import astyle
133 import astyle
134
134
135
135
136 __all__ = [
136 __all__ = [
137 "ifile", "ils", "iglob", "iwalk", "ipwdentry", "ipwd", "igrpentry", "igrp",
137 "ifile", "ils", "iglob", "iwalk", "ipwdentry", "ipwd", "igrpentry", "igrp",
138 "icsv", "ix", "ichain", "isort", "ifilter", "ieval", "ienum", "ienv",
138 "icsv", "ix", "ichain", "isort", "ifilter", "ieval", "ienum", "ienv",
139 "idump", "iless"
139 "idump", "iless"
140 ]
140 ]
141
141
142
142
143 os.stat_float_times(True) # enable microseconds
143 os.stat_float_times(True) # enable microseconds
144
144
145
145
146 class AttrNamespace(object):
146 class AttrNamespace(object):
147 """
147 """
148 Helper class that is used for providing a namespace for evaluating
148 Helper class that is used for providing a namespace for evaluating
149 expressions containing attribute names of an object.
149 expressions containing attribute names of an object.
150 """
150 """
151 def __init__(self, wrapped):
151 def __init__(self, wrapped):
152 self.wrapped = wrapped
152 self.wrapped = wrapped
153
153
154 def __getitem__(self, name):
154 def __getitem__(self, name):
155 if name == "_":
155 if name == "_":
156 return self.wrapped
156 return self.wrapped
157 try:
157 try:
158 return getattr(self.wrapped, name)
158 return getattr(self.wrapped, name)
159 except AttributeError:
159 except AttributeError:
160 raise KeyError(name)
160 raise KeyError(name)
161
161
162 # Python 2.3 compatibility
162 # Python 2.3 compatibility
163 # use eval workaround to find out which names are used in the
163 # use eval workaround to find out which names are used in the
164 # eval string and put them into the locals. This works for most
164 # eval string and put them into the locals. This works for most
165 # normal uses case, bizarre ones like accessing the locals()
165 # normal uses case, bizarre ones like accessing the locals()
166 # will fail
166 # will fail
167 try:
167 try:
168 eval("_", None, AttrNamespace(None))
168 eval("_", None, AttrNamespace(None))
169 except TypeError:
169 except TypeError:
170 real_eval = eval
170 real_eval = eval
171 def eval(codestring, _globals, _locals):
171 def eval(codestring, _globals, _locals):
172 """
172 """
173 eval(source[, globals[, locals]]) -> value
173 eval(source[, globals[, locals]]) -> value
174
174
175 Evaluate the source in the context of globals and locals.
175 Evaluate the source in the context of globals and locals.
176 The source may be a string representing a Python expression
176 The source may be a string representing a Python expression
177 or a code object as returned by compile().
177 or a code object as returned by compile().
178 The globals must be a dictionary and locals can be any mappping.
178 The globals must be a dictionary and locals can be any mappping.
179
179
180 This function is a workaround for the shortcomings of
180 This function is a workaround for the shortcomings of
181 Python 2.3's eval.
181 Python 2.3's eval.
182 """
182 """
183
183
184 if isinstance(codestring, basestring):
184 if isinstance(codestring, basestring):
185 code = compile(codestring, "_eval", "eval")
185 code = compile(codestring, "_eval", "eval")
186 else:
186 else:
187 code = codestring
187 code = codestring
188 newlocals = {}
188 newlocals = {}
189 for name in code.co_names:
189 for name in code.co_names:
190 try:
190 try:
191 newlocals[name] = _locals[name]
191 newlocals[name] = _locals[name]
192 except KeyError:
192 except KeyError:
193 pass
193 pass
194 return real_eval(code, _globals, newlocals)
194 return real_eval(code, _globals, newlocals)
195
195
196
196
197 noitem = object()
197 noitem = object()
198
198
199
199
200 def item(iterator, index, default=noitem):
200 def item(iterator, index, default=noitem):
201 """
201 """
202 Return the ``index``th item from the iterator ``iterator``.
202 Return the ``index``th item from the iterator ``iterator``.
203 ``index`` must be an integer (negative integers are relative to the
203 ``index`` must be an integer (negative integers are relative to the
204 end (i.e. the last items produced by the iterator)).
204 end (i.e. the last items produced by the iterator)).
205
205
206 If ``default`` is given, this will be the default value when
206 If ``default`` is given, this will be the default value when
207 the iterator doesn't contain an item at this position. Otherwise an
207 the iterator doesn't contain an item at this position. Otherwise an
208 ``IndexError`` will be raised.
208 ``IndexError`` will be raised.
209
209
210 Note that using this function will partially or totally exhaust the
210 Note that using this function will partially or totally exhaust the
211 iterator.
211 iterator.
212 """
212 """
213 i = index
213 i = index
214 if i>=0:
214 if i>=0:
215 for item in iterator:
215 for item in iterator:
216 if not i:
216 if not i:
217 return item
217 return item
218 i -= 1
218 i -= 1
219 else:
219 else:
220 i = -index
220 i = -index
221 cache = deque()
221 cache = deque()
222 for item in iterator:
222 for item in iterator:
223 cache.append(item)
223 cache.append(item)
224 if len(cache)>i:
224 if len(cache)>i:
225 cache.popleft()
225 cache.popleft()
226 if len(cache)==i:
226 if len(cache)==i:
227 return cache.popleft()
227 return cache.popleft()
228 if default is noitem:
228 if default is noitem:
229 raise IndexError(index)
229 raise IndexError(index)
230 else:
230 else:
231 return default
231 return default
232
232
233
233
234 def getglobals(g):
234 def getglobals(g):
235 """
235 """
236 Return the global namespace that is used for expression strings in
236 Return the global namespace that is used for expression strings in
237 ``ifilter`` and others. This is ``g`` or (if ``g`` is ``None``) IPython's
237 ``ifilter`` and others. This is ``g`` or (if ``g`` is ``None``) IPython's
238 user namespace.
238 user namespace.
239 """
239 """
240 if g is None:
240 if g is None:
241 if ipapi is not None:
241 if ipapi is not None:
242 api = ipapi.get()
242 api = ipapi.get()
243 if api is not None:
243 if api is not None:
244 return api.user_ns
244 return api.user_ns
245 return globals()
245 return globals()
246 return g
246 return g
247
247
248
248
249 class Descriptor(object):
249 class Descriptor(object):
250 """
250 """
251 A ``Descriptor`` object is used for describing the attributes of objects.
251 A ``Descriptor`` object is used for describing the attributes of objects.
252 """
252 """
253 def __hash__(self):
253 def __hash__(self):
254 return hash(self.__class__) ^ hash(self.key())
254 return hash(self.__class__) ^ hash(self.key())
255
255
256 def __eq__(self, other):
256 def __eq__(self, other):
257 return self.__class__ is other.__class__ and self.key() == other.key()
257 return self.__class__ is other.__class__ and self.key() == other.key()
258
258
259 def __ne__(self, other):
259 def __ne__(self, other):
260 return self.__class__ is not other.__class__ or self.key() != other.key()
260 return self.__class__ is not other.__class__ or self.key() != other.key()
261
261
262 def key(self):
262 def key(self):
263 pass
263 pass
264
264
265 def name(self):
265 def name(self):
266 """
266 """
267 Return the name of this attribute for display by a ``Display`` object
267 Return the name of this attribute for display by a ``Display`` object
268 (e.g. as a column title).
268 (e.g. as a column title).
269 """
269 """
270 key = self.key()
270 key = self.key()
271 if key is None:
271 if key is None:
272 return "_"
272 return "_"
273 return str(key)
273 return str(key)
274
274
275 def attrtype(self, obj):
275 def attrtype(self, obj):
276 """
276 """
277 Return the type of this attribute (i.e. something like "attribute" or
277 Return the type of this attribute (i.e. something like "attribute" or
278 "method").
278 "method").
279 """
279 """
280
280
281 def valuetype(self, obj):
281 def valuetype(self, obj):
282 """
282 """
283 Return the type of this attribute value of the object ``obj``.
283 Return the type of this attribute value of the object ``obj``.
284 """
284 """
285
285
286 def value(self, obj):
286 def value(self, obj):
287 """
287 """
288 Return the value of this attribute of the object ``obj``.
288 Return the value of this attribute of the object ``obj``.
289 """
289 """
290
290
291 def doc(self, obj):
291 def doc(self, obj):
292 """
292 """
293 Return the documentation for this attribute.
293 Return the documentation for this attribute.
294 """
294 """
295
295
296 def shortdoc(self, obj):
296 def shortdoc(self, obj):
297 """
297 """
298 Return a short documentation for this attribute (defaulting to the
298 Return a short documentation for this attribute (defaulting to the
299 first line).
299 first line).
300 """
300 """
301 doc = self.doc(obj)
301 doc = self.doc(obj)
302 if doc is not None:
302 if doc is not None:
303 doc = doc.strip().splitlines()[0].strip()
303 doc = doc.strip().splitlines()[0].strip()
304 return doc
304 return doc
305
305
306 def iter(self, obj):
306 def iter(self, obj):
307 """
307 """
308 Return an iterator for this attribute of the object ``obj``.
308 Return an iterator for this attribute of the object ``obj``.
309 """
309 """
310 return xiter(self.value(obj))
310 return xiter(self.value(obj))
311
311
312
312
313 class SelfDescriptor(Descriptor):
313 class SelfDescriptor(Descriptor):
314 """
314 """
315 A ``SelfDescriptor`` describes the object itself.
315 A ``SelfDescriptor`` describes the object itself.
316 """
316 """
317 def key(self):
317 def key(self):
318 return None
318 return None
319
319
320 def attrtype(self, obj):
320 def attrtype(self, obj):
321 return "self"
321 return "self"
322
322
323 def valuetype(self, obj):
323 def valuetype(self, obj):
324 return type(obj)
324 return type(obj)
325
325
326 def value(self, obj):
326 def value(self, obj):
327 return obj
327 return obj
328
328
329 def __repr__(self):
329 def __repr__(self):
330 return "Self"
330 return "Self"
331
331
332 selfdescriptor = SelfDescriptor() # there's no need for more than one
332 selfdescriptor = SelfDescriptor() # there's no need for more than one
333
333
334
334
335 class AttributeDescriptor(Descriptor):
335 class AttributeDescriptor(Descriptor):
336 """
336 """
337 An ``AttributeDescriptor`` describes a simple attribute of an object.
337 An ``AttributeDescriptor`` describes a simple attribute of an object.
338 """
338 """
339 __slots__ = ("_name", "_doc")
339 __slots__ = ("_name", "_doc")
340
340
341 def __init__(self, name, doc=None):
341 def __init__(self, name, doc=None):
342 self._name = name
342 self._name = name
343 self._doc = doc
343 self._doc = doc
344
344
345 def key(self):
345 def key(self):
346 return self._name
346 return self._name
347
347
348 def doc(self, obj):
348 def doc(self, obj):
349 return self._doc
349 return self._doc
350
350
351 def attrtype(self, obj):
351 def attrtype(self, obj):
352 return "attr"
352 return "attr"
353
353
354 def valuetype(self, obj):
354 def valuetype(self, obj):
355 return type(getattr(obj, self._name))
355 return type(getattr(obj, self._name))
356
356
357 def value(self, obj):
357 def value(self, obj):
358 return getattr(obj, self._name)
358 return getattr(obj, self._name)
359
359
360 def __repr__(self):
360 def __repr__(self):
361 if self._doc is None:
361 if self._doc is None:
362 return "Attribute(%r)" % self._name
362 return "Attribute(%r)" % self._name
363 else:
363 else:
364 return "Attribute(%r, %r)" % (self._name, self._doc)
364 return "Attribute(%r, %r)" % (self._name, self._doc)
365
365
366
366
367 class IndexDescriptor(Descriptor):
367 class IndexDescriptor(Descriptor):
368 """
368 """
369 An ``IndexDescriptor`` describes an "attribute" of an object that is fetched
369 An ``IndexDescriptor`` describes an "attribute" of an object that is fetched
370 via ``__getitem__``.
370 via ``__getitem__``.
371 """
371 """
372 __slots__ = ("_index",)
372 __slots__ = ("_index",)
373
373
374 def __init__(self, index):
374 def __init__(self, index):
375 self._index = index
375 self._index = index
376
376
377 def key(self):
377 def key(self):
378 return self._index
378 return self._index
379
379
380 def attrtype(self, obj):
380 def attrtype(self, obj):
381 return "item"
381 return "item"
382
382
383 def valuetype(self, obj):
383 def valuetype(self, obj):
384 return type(obj[self._index])
384 return type(obj[self._index])
385
385
386 def value(self, obj):
386 def value(self, obj):
387 return obj[self._index]
387 return obj[self._index]
388
388
389 def __repr__(self):
389 def __repr__(self):
390 return "Index(%r)" % self._index
390 return "Index(%r)" % self._index
391
391
392
392
393 class MethodDescriptor(Descriptor):
393 class MethodDescriptor(Descriptor):
394 """
394 """
395 A ``MethodDescriptor`` describes a method of an object that can be called
395 A ``MethodDescriptor`` describes a method of an object that can be called
396 without argument. Note that this method shouldn't change the object.
396 without argument. Note that this method shouldn't change the object.
397 """
397 """
398 __slots__ = ("_name", "_doc")
398 __slots__ = ("_name", "_doc")
399
399
400 def __init__(self, name, doc=None):
400 def __init__(self, name, doc=None):
401 self._name = name
401 self._name = name
402 self._doc = doc
402 self._doc = doc
403
403
404 def key(self):
404 def key(self):
405 return self._name
405 return self._name
406
406
407 def doc(self, obj):
407 def doc(self, obj):
408 if self._doc is None:
408 if self._doc is None:
409 return getattr(obj, self._name).__doc__
409 return getattr(obj, self._name).__doc__
410 return self._doc
410 return self._doc
411
411
412 def attrtype(self, obj):
412 def attrtype(self, obj):
413 return "method"
413 return "method"
414
414
415 def valuetype(self, obj):
415 def valuetype(self, obj):
416 return type(self.value(obj))
416 return type(self.value(obj))
417
417
418 def value(self, obj):
418 def value(self, obj):
419 return getattr(obj, self._name)()
419 return getattr(obj, self._name)()
420
420
421 def __repr__(self):
421 def __repr__(self):
422 if self._doc is None:
422 if self._doc is None:
423 return "Method(%r)" % self._name
423 return "Method(%r)" % self._name
424 else:
424 else:
425 return "Method(%r, %r)" % (self._name, self._doc)
425 return "Method(%r, %r)" % (self._name, self._doc)
426
426
427
427
428 class IterAttributeDescriptor(Descriptor):
428 class IterAttributeDescriptor(Descriptor):
429 """
429 """
430 An ``IterAttributeDescriptor`` works like an ``AttributeDescriptor`` but
430 An ``IterAttributeDescriptor`` works like an ``AttributeDescriptor`` but
431 doesn't return an attribute values (because this value might be e.g. a large
431 doesn't return an attribute values (because this value might be e.g. a large
432 list).
432 list).
433 """
433 """
434 __slots__ = ("_name", "_doc")
434 __slots__ = ("_name", "_doc")
435
435
436 def __init__(self, name, doc=None):
436 def __init__(self, name, doc=None):
437 self._name = name
437 self._name = name
438 self._doc = doc
438 self._doc = doc
439
439
440 def key(self):
440 def key(self):
441 return self._name
441 return self._name
442
442
443 def doc(self, obj):
443 def doc(self, obj):
444 return self._doc
444 return self._doc
445
445
446 def attrtype(self, obj):
446 def attrtype(self, obj):
447 return "iter"
447 return "iter"
448
448
449 def valuetype(self, obj):
449 def valuetype(self, obj):
450 return noitem
450 return noitem
451
451
452 def value(self, obj):
452 def value(self, obj):
453 return noitem
453 return noitem
454
454
455 def iter(self, obj):
455 def iter(self, obj):
456 return xiter(getattr(obj, self._name))
456 return xiter(getattr(obj, self._name))
457
457
458 def __repr__(self):
458 def __repr__(self):
459 if self._doc is None:
459 if self._doc is None:
460 return "IterAttribute(%r)" % self._name
460 return "IterAttribute(%r)" % self._name
461 else:
461 else:
462 return "IterAttribute(%r, %r)" % (self._name, self._doc)
462 return "IterAttribute(%r, %r)" % (self._name, self._doc)
463
463
464
464
465 class IterMethodDescriptor(Descriptor):
465 class IterMethodDescriptor(Descriptor):
466 """
466 """
467 An ``IterMethodDescriptor`` works like an ``MethodDescriptor`` but doesn't
467 An ``IterMethodDescriptor`` works like an ``MethodDescriptor`` but doesn't
468 return an attribute values (because this value might be e.g. a large list).
468 return an attribute values (because this value might be e.g. a large list).
469 """
469 """
470 __slots__ = ("_name", "_doc")
470 __slots__ = ("_name", "_doc")
471
471
472 def __init__(self, name, doc=None):
472 def __init__(self, name, doc=None):
473 self._name = name
473 self._name = name
474 self._doc = doc
474 self._doc = doc
475
475
476 def key(self):
476 def key(self):
477 return self._name
477 return self._name
478
478
479 def doc(self, obj):
479 def doc(self, obj):
480 if self._doc is None:
480 if self._doc is None:
481 return getattr(obj, self._name).__doc__
481 return getattr(obj, self._name).__doc__
482 return self._doc
482 return self._doc
483
483
484 def attrtype(self, obj):
484 def attrtype(self, obj):
485 return "itermethod"
485 return "itermethod"
486
486
487 def valuetype(self, obj):
487 def valuetype(self, obj):
488 return noitem
488 return noitem
489
489
490 def value(self, obj):
490 def value(self, obj):
491 return noitem
491 return noitem
492
492
493 def iter(self, obj):
493 def iter(self, obj):
494 return xiter(getattr(obj, self._name)())
494 return xiter(getattr(obj, self._name)())
495
495
496 def __repr__(self):
496 def __repr__(self):
497 if self._doc is None:
497 if self._doc is None:
498 return "IterMethod(%r)" % self._name
498 return "IterMethod(%r)" % self._name
499 else:
499 else:
500 return "IterMethod(%r, %r)" % (self._name, self._doc)
500 return "IterMethod(%r, %r)" % (self._name, self._doc)
501
501
502
502
503 class FunctionDescriptor(Descriptor):
503 class FunctionDescriptor(Descriptor):
504 """
504 """
505 A ``FunctionDescriptor`` turns a function into a descriptor. The function
505 A ``FunctionDescriptor`` turns a function into a descriptor. The function
506 will be called with the object to get the type and value of the attribute.
506 will be called with the object to get the type and value of the attribute.
507 """
507 """
508 __slots__ = ("_function", "_name", "_doc")
508 __slots__ = ("_function", "_name", "_doc")
509
509
510 def __init__(self, function, name=None, doc=None):
510 def __init__(self, function, name=None, doc=None):
511 self._function = function
511 self._function = function
512 self._name = name
512 self._name = name
513 self._doc = doc
513 self._doc = doc
514
514
515 def key(self):
515 def key(self):
516 return self._function
516 return self._function
517
517
518 def name(self):
518 def name(self):
519 if self._name is not None:
519 if self._name is not None:
520 return self._name
520 return self._name
521 return getattr(self._function, "__xname__", self._function.__name__)
521 return getattr(self._function, "__xname__", self._function.__name__)
522
522
523 def doc(self, obj):
523 def doc(self, obj):
524 if self._doc is None:
524 if self._doc is None:
525 return self._function.__doc__
525 return self._function.__doc__
526 return self._doc
526 return self._doc
527
527
528 def attrtype(self, obj):
528 def attrtype(self, obj):
529 return "function"
529 return "function"
530
530
531 def valuetype(self, obj):
531 def valuetype(self, obj):
532 return type(self._function(obj))
532 return type(self._function(obj))
533
533
534 def value(self, obj):
534 def value(self, obj):
535 return self._function(obj)
535 return self._function(obj)
536
536
537 def __repr__(self):
537 def __repr__(self):
538 if self._doc is None:
538 if self._doc is None:
539 return "Function(%r)" % self._name
539 return "Function(%r)" % self._name
540 else:
540 else:
541 return "Function(%r, %r)" % (self._name, self._doc)
541 return "Function(%r, %r)" % (self._name, self._doc)
542
542
543
543
544 class Table(object):
544 class Table(object):
545 """
545 """
546 A ``Table`` is an object that produces items (just like a normal Python
546 A ``Table`` is an object that produces items (just like a normal Python
547 iterator/generator does) and can be used as the first object in a pipeline
547 iterator/generator does) and can be used as the first object in a pipeline
548 expression. The displayhook will open the default browser for such an object
548 expression. The displayhook will open the default browser for such an object
549 (instead of simply printing the ``repr()`` result).
549 (instead of simply printing the ``repr()`` result).
550 """
550 """
551
551
552 # We want to support ``foo`` and ``foo()`` in pipeline expression:
552 # We want to support ``foo`` and ``foo()`` in pipeline expression:
553 # So we implement the required operators (``|`` and ``+``) in the metaclass,
553 # So we implement the required operators (``|`` and ``+``) in the metaclass,
554 # instantiate the class and forward the operator to the instance
554 # instantiate the class and forward the operator to the instance
555 class __metaclass__(type):
555 class __metaclass__(type):
556 def __iter__(self):
556 def __iter__(self):
557 return iter(self())
557 return iter(self())
558
558
559 def __or__(self, other):
559 def __or__(self, other):
560 return self() | other
560 return self() | other
561
561
562 def __add__(self, other):
562 def __add__(self, other):
563 return self() + other
563 return self() + other
564
564
565 def __radd__(self, other):
565 def __radd__(self, other):
566 return other + self()
566 return other + self()
567
567
568 def __getitem__(self, index):
568 def __getitem__(self, index):
569 return self()[index]
569 return self()[index]
570
570
571 def __getitem__(self, index):
571 def __getitem__(self, index):
572 return item(self, index)
572 return item(self, index)
573
573
574 def __contains__(self, item):
574 def __contains__(self, item):
575 for haveitem in self:
575 for haveitem in self:
576 if item == haveitem:
576 if item == haveitem:
577 return True
577 return True
578 return False
578 return False
579
579
580 def __or__(self, other):
580 def __or__(self, other):
581 # autoinstantiate right hand side
581 # autoinstantiate right hand side
582 if isinstance(other, type) and issubclass(other, (Table, Display)):
582 if isinstance(other, type) and issubclass(other, (Table, Display)):
583 other = other()
583 other = other()
584 # treat simple strings and functions as ``ieval`` instances
584 # treat simple strings and functions as ``ieval`` instances
585 elif not isinstance(other, Display) and not isinstance(other, Table):
585 elif not isinstance(other, Display) and not isinstance(other, Table):
586 other = ieval(other)
586 other = ieval(other)
587 # forward operations to the right hand side
587 # forward operations to the right hand side
588 return other.__ror__(self)
588 return other.__ror__(self)
589
589
590 def __add__(self, other):
590 def __add__(self, other):
591 # autoinstantiate right hand side
591 # autoinstantiate right hand side
592 if isinstance(other, type) and issubclass(other, Table):
592 if isinstance(other, type) and issubclass(other, Table):
593 other = other()
593 other = other()
594 return ichain(self, other)
594 return ichain(self, other)
595
595
596 def __radd__(self, other):
596 def __radd__(self, other):
597 # autoinstantiate left hand side
597 # autoinstantiate left hand side
598 if isinstance(other, type) and issubclass(other, Table):
598 if isinstance(other, type) and issubclass(other, Table):
599 other = other()
599 other = other()
600 return ichain(other, self)
600 return ichain(other, self)
601
601
602
602
603 class Pipe(Table):
603 class Pipe(Table):
604 """
604 """
605 A ``Pipe`` is an object that can be used in a pipeline expression. It
605 A ``Pipe`` is an object that can be used in a pipeline expression. It
606 processes the objects it gets from its input ``Table``/``Pipe``. Note that
606 processes the objects it gets from its input ``Table``/``Pipe``. Note that
607 a ``Pipe`` object can't be used as the first object in a pipeline
607 a ``Pipe`` object can't be used as the first object in a pipeline
608 expression, as it doesn't produces items itself.
608 expression, as it doesn't produces items itself.
609 """
609 """
610 class __metaclass__(Table.__metaclass__):
610 class __metaclass__(Table.__metaclass__):
611 def __ror__(self, input):
611 def __ror__(self, input):
612 return input | self()
612 return input | self()
613
613
614 def __ror__(self, input):
614 def __ror__(self, input):
615 # autoinstantiate left hand side
615 # autoinstantiate left hand side
616 if isinstance(input, type) and issubclass(input, Table):
616 if isinstance(input, type) and issubclass(input, Table):
617 input = input()
617 input = input()
618 self.input = input
618 self.input = input
619 return self
619 return self
620
620
621
621
622 def xrepr(item, mode="default"):
622 def xrepr(item, mode="default"):
623 """
623 """
624 Generic function that adds color output and different display modes to ``repr``.
624 Generic function that adds color output and different display modes to ``repr``.
625
625
626 The result of an ``xrepr`` call is iterable and consists of ``(style, string)``
626 The result of an ``xrepr`` call is iterable and consists of ``(style, string)``
627 tuples. The ``style`` in this tuple must be a ``Style`` object from the
627 tuples. The ``style`` in this tuple must be a ``Style`` object from the
628 ``astring`` module. To reconfigure the output the first yielded tuple can be
628 ``astring`` module. To reconfigure the output the first yielded tuple can be
629 a ``(aligment, full)`` tuple instead of a ``(style, string)`` tuple.
629 a ``(aligment, full)`` tuple instead of a ``(style, string)`` tuple.
630 ``alignment`` can be -1 for left aligned, 0 for centered and 1 for right
630 ``alignment`` can be -1 for left aligned, 0 for centered and 1 for right
631 aligned (the default is left alignment). ``full`` is a boolean that specifies
631 aligned (the default is left alignment). ``full`` is a boolean that specifies
632 whether the complete output must be displayed or the ``Display`` object is
632 whether the complete output must be displayed or the ``Display`` object is
633 allowed to stop output after enough text has been produced (e.g. a syntax
633 allowed to stop output after enough text has been produced (e.g. a syntax
634 highlighted text line would use ``True``, but for a large data structure
634 highlighted text line would use ``True``, but for a large data structure
635 (i.e. a nested list, tuple or dictionary) ``False`` would be used).
635 (i.e. a nested list, tuple or dictionary) ``False`` would be used).
636 The default is full output.
636 The default is full output.
637
637
638 There are four different possible values for ``mode`` depending on where
638 There are four different possible values for ``mode`` depending on where
639 the ``Display`` object will display ``item``:
639 the ``Display`` object will display ``item``:
640
640
641 * ``"header"``: ``item`` will be displayed in a header line (this is used by
641 * ``"header"``: ``item`` will be displayed in a header line (this is used by
642 ``ibrowse``).
642 ``ibrowse``).
643 * ``"footer"``: ``item`` will be displayed in a footer line (this is used by
643 * ``"footer"``: ``item`` will be displayed in a footer line (this is used by
644 ``ibrowse``).
644 ``ibrowse``).
645 * ``"cell"``: ``item`` will be displayed in a table cell/list.
645 * ``"cell"``: ``item`` will be displayed in a table cell/list.
646 * ``"default"``: default mode. If an ``xrepr`` implementation recursively
646 * ``"default"``: default mode. If an ``xrepr`` implementation recursively
647 outputs objects, ``"default"`` must be passed in the recursive calls to
647 outputs objects, ``"default"`` must be passed in the recursive calls to
648 ``xrepr``.
648 ``xrepr``.
649
649
650 If no implementation is registered for ``item``, ``xrepr`` will try the
650 If no implementation is registered for ``item``, ``xrepr`` will try the
651 ``__xrepr__`` method on ``item``. If ``item`` doesn't have an ``__xrepr__``
651 ``__xrepr__`` method on ``item``. If ``item`` doesn't have an ``__xrepr__``
652 method it falls back to ``repr``/``__repr__`` for all modes.
652 method it falls back to ``repr``/``__repr__`` for all modes.
653 """
653 """
654 try:
654 try:
655 func = item.__xrepr__
655 func = item.__xrepr__
656 except AttributeError:
656 except AttributeError:
657 yield (astyle.style_default, repr(item))
657 yield (astyle.style_default, repr(item))
658 else:
658 else:
659 try:
659 try:
660 for x in func(mode):
660 for x in func(mode):
661 yield x
661 yield x
662 except (KeyboardInterrupt, SystemExit):
662 except (KeyboardInterrupt, SystemExit):
663 raise
663 raise
664 except Exception:
664 except Exception:
665 yield (astyle.style_default, repr(item))
665 yield (astyle.style_default, repr(item))
666 xrepr = simplegeneric.generic(xrepr)
666 xrepr = simplegeneric.generic(xrepr)
667
667
668
668
669 def xrepr_none(self, mode="default"):
669 def xrepr_none(self, mode="default"):
670 yield (astyle.style_type_none, repr(self))
670 yield (astyle.style_type_none, repr(self))
671 xrepr.when_object(None)(xrepr_none)
671 xrepr.when_object(None)(xrepr_none)
672
672
673
673
674 def xrepr_noitem(self, mode="default"):
674 def xrepr_noitem(self, mode="default"):
675 yield (2, True)
675 yield (2, True)
676 yield (astyle.style_nodata, "<?>")
676 yield (astyle.style_nodata, "<?>")
677 xrepr.when_object(noitem)(xrepr_noitem)
677 xrepr.when_object(noitem)(xrepr_noitem)
678
678
679
679
680 def xrepr_bool(self, mode="default"):
680 def xrepr_bool(self, mode="default"):
681 yield (astyle.style_type_bool, repr(self))
681 yield (astyle.style_type_bool, repr(self))
682 xrepr.when_type(bool)(xrepr_bool)
682 xrepr.when_type(bool)(xrepr_bool)
683
683
684
684
685 def xrepr_str(self, mode="default"):
685 def xrepr_str(self, mode="default"):
686 if mode == "cell":
686 if mode == "cell":
687 yield (astyle.style_default, repr(self.expandtabs(tab))[1:-1])
687 yield (astyle.style_default, repr(self.expandtabs(tab))[1:-1])
688 else:
688 else:
689 yield (astyle.style_default, repr(self))
689 yield (astyle.style_default, repr(self))
690 xrepr.when_type(str)(xrepr_str)
690 xrepr.when_type(str)(xrepr_str)
691
691
692
692
693 def xrepr_unicode(self, mode="default"):
693 def xrepr_unicode(self, mode="default"):
694 if mode == "cell":
694 if mode == "cell":
695 yield (astyle.style_default, repr(self.expandtabs(tab))[2:-1])
695 yield (astyle.style_default, repr(self.expandtabs(tab))[2:-1])
696 else:
696 else:
697 yield (astyle.style_default, repr(self))
697 yield (astyle.style_default, repr(self))
698 xrepr.when_type(unicode)(xrepr_unicode)
698 xrepr.when_type(unicode)(xrepr_unicode)
699
699
700
700
701 def xrepr_number(self, mode="default"):
701 def xrepr_number(self, mode="default"):
702 yield (1, True)
702 yield (1, True)
703 yield (astyle.style_type_number, repr(self))
703 yield (astyle.style_type_number, repr(self))
704 xrepr.when_type(int)(xrepr_number)
704 xrepr.when_type(int)(xrepr_number)
705 xrepr.when_type(long)(xrepr_number)
705 xrepr.when_type(long)(xrepr_number)
706 xrepr.when_type(float)(xrepr_number)
706 xrepr.when_type(float)(xrepr_number)
707
707
708
708
709 def xrepr_complex(self, mode="default"):
709 def xrepr_complex(self, mode="default"):
710 yield (astyle.style_type_number, repr(self))
710 yield (astyle.style_type_number, repr(self))
711 xrepr.when_type(complex)(xrepr_number)
711 xrepr.when_type(complex)(xrepr_number)
712
712
713
713
714 def xrepr_datetime(self, mode="default"):
714 def xrepr_datetime(self, mode="default"):
715 if mode == "cell":
715 if mode == "cell":
716 # Don't use strftime() here, as this requires year >= 1900
716 # Don't use strftime() here, as this requires year >= 1900
717 yield (astyle.style_type_datetime,
717 yield (astyle.style_type_datetime,
718 "%04d-%02d-%02d %02d:%02d:%02d.%06d" % \
718 "%04d-%02d-%02d %02d:%02d:%02d.%06d" % \
719 (self.year, self.month, self.day,
719 (self.year, self.month, self.day,
720 self.hour, self.minute, self.second,
720 self.hour, self.minute, self.second,
721 self.microsecond),
721 self.microsecond),
722 )
722 )
723 else:
723 else:
724 yield (astyle.style_type_datetime, repr(self))
724 yield (astyle.style_type_datetime, repr(self))
725 xrepr.when_type(datetime.datetime)(xrepr_datetime)
725 xrepr.when_type(datetime.datetime)(xrepr_datetime)
726
726
727
727
728 def xrepr_date(self, mode="default"):
728 def xrepr_date(self, mode="default"):
729 if mode == "cell":
729 if mode == "cell":
730 yield (astyle.style_type_datetime,
730 yield (astyle.style_type_datetime,
731 "%04d-%02d-%02d" % (self.year, self.month, self.day))
731 "%04d-%02d-%02d" % (self.year, self.month, self.day))
732 else:
732 else:
733 yield (astyle.style_type_datetime, repr(self))
733 yield (astyle.style_type_datetime, repr(self))
734 xrepr.when_type(datetime.date)(xrepr_date)
734 xrepr.when_type(datetime.date)(xrepr_date)
735
735
736
736
737 def xrepr_time(self, mode="default"):
737 def xrepr_time(self, mode="default"):
738 if mode == "cell":
738 if mode == "cell":
739 yield (astyle.style_type_datetime,
739 yield (astyle.style_type_datetime,
740 "%02d:%02d:%02d.%06d" % \
740 "%02d:%02d:%02d.%06d" % \
741 (self.hour, self.minute, self.second, self.microsecond))
741 (self.hour, self.minute, self.second, self.microsecond))
742 else:
742 else:
743 yield (astyle.style_type_datetime, repr(self))
743 yield (astyle.style_type_datetime, repr(self))
744 xrepr.when_type(datetime.time)(xrepr_time)
744 xrepr.when_type(datetime.time)(xrepr_time)
745
745
746
746
747 def xrepr_timedelta(self, mode="default"):
747 def xrepr_timedelta(self, mode="default"):
748 yield (astyle.style_type_datetime, repr(self))
748 yield (astyle.style_type_datetime, repr(self))
749 xrepr.when_type(datetime.timedelta)(xrepr_timedelta)
749 xrepr.when_type(datetime.timedelta)(xrepr_timedelta)
750
750
751
751
752 def xrepr_type(self, mode="default"):
752 def xrepr_type(self, mode="default"):
753 if self.__module__ == "__builtin__":
753 if self.__module__ == "__builtin__":
754 yield (astyle.style_type_type, self.__name__)
754 yield (astyle.style_type_type, self.__name__)
755 else:
755 else:
756 yield (astyle.style_type_type, "%s.%s" % (self.__module__, self.__name__))
756 yield (astyle.style_type_type, "%s.%s" % (self.__module__, self.__name__))
757 xrepr.when_type(type)(xrepr_type)
757 xrepr.when_type(type)(xrepr_type)
758
758
759
759
760 def xrepr_exception(self, mode="default"):
760 def xrepr_exception(self, mode="default"):
761 if self.__class__.__module__ == "exceptions":
761 if self.__class__.__module__ == "exceptions":
762 classname = self.__class__.__name__
762 classname = self.__class__.__name__
763 else:
763 else:
764 classname = "%s.%s" % \
764 classname = "%s.%s" % \
765 (self.__class__.__module__, self.__class__.__name__)
765 (self.__class__.__module__, self.__class__.__name__)
766 if mode == "header" or mode == "footer":
766 if mode == "header" or mode == "footer":
767 yield (astyle.style_error, "%s: %s" % (classname, self))
767 yield (astyle.style_error, "%s: %s" % (classname, self))
768 else:
768 else:
769 yield (astyle.style_error, classname)
769 yield (astyle.style_error, classname)
770 xrepr.when_type(Exception)(xrepr_exception)
770 xrepr.when_type(Exception)(xrepr_exception)
771
771
772
772
773 def xrepr_listtuple(self, mode="default"):
773 def xrepr_listtuple(self, mode="default"):
774 if mode == "header" or mode == "footer":
774 if mode == "header" or mode == "footer":
775 if self.__class__.__module__ == "__builtin__":
775 if self.__class__.__module__ == "__builtin__":
776 classname = self.__class__.__name__
776 classname = self.__class__.__name__
777 else:
777 else:
778 classname = "%s.%s" % \
778 classname = "%s.%s" % \
779 (self.__class__.__module__,self.__class__.__name__)
779 (self.__class__.__module__,self.__class__.__name__)
780 yield (astyle.style_default,
780 yield (astyle.style_default,
781 "<%s object with %d items at 0x%x>" % \
781 "<%s object with %d items at 0x%x>" % \
782 (classname, len(self), id(self)))
782 (classname, len(self), id(self)))
783 else:
783 else:
784 yield (-1, False)
784 yield (-1, False)
785 if isinstance(self, list):
785 if isinstance(self, list):
786 yield (astyle.style_default, "[")
786 yield (astyle.style_default, "[")
787 end = "]"
787 end = "]"
788 else:
788 else:
789 yield (astyle.style_default, "(")
789 yield (astyle.style_default, "(")
790 end = ")"
790 end = ")"
791 for (i, subself) in enumerate(self):
791 for (i, subself) in enumerate(self):
792 if i:
792 if i:
793 yield (astyle.style_default, ", ")
793 yield (astyle.style_default, ", ")
794 for part in xrepr(subself, "default"):
794 for part in xrepr(subself, "default"):
795 yield part
795 yield part
796 yield (astyle.style_default, end)
796 yield (astyle.style_default, end)
797 xrepr.when_type(list)(xrepr_listtuple)
797 xrepr.when_type(list)(xrepr_listtuple)
798 xrepr.when_type(tuple)(xrepr_listtuple)
798 xrepr.when_type(tuple)(xrepr_listtuple)
799
799
800
800
801 def xrepr_dict(self, mode="default"):
801 def xrepr_dict(self, mode="default"):
802 if mode == "header" or mode == "footer":
802 if mode == "header" or mode == "footer":
803 if self.__class__.__module__ == "__builtin__":
803 if self.__class__.__module__ == "__builtin__":
804 classname = self.__class__.__name__
804 classname = self.__class__.__name__
805 else:
805 else:
806 classname = "%s.%s" % \
806 classname = "%s.%s" % \
807 (self.__class__.__module__,self.__class__.__name__)
807 (self.__class__.__module__,self.__class__.__name__)
808 yield (astyle.style_default,
808 yield (astyle.style_default,
809 "<%s object with %d items at 0x%x>" % \
809 "<%s object with %d items at 0x%x>" % \
810 (classname, len(self), id(self)))
810 (classname, len(self), id(self)))
811 else:
811 else:
812 yield (-1, False)
812 yield (-1, False)
813 if isinstance(self, dict):
813 if isinstance(self, dict):
814 yield (astyle.style_default, "{")
814 yield (astyle.style_default, "{")
815 end = "}"
815 end = "}"
816 else:
816 else:
817 yield (astyle.style_default, "dictproxy((")
817 yield (astyle.style_default, "dictproxy((")
818 end = "})"
818 end = "})"
819 for (i, (key, value)) in enumerate(self.iteritems()):
819 for (i, (key, value)) in enumerate(self.iteritems()):
820 if i:
820 if i:
821 yield (astyle.style_default, ", ")
821 yield (astyle.style_default, ", ")
822 for part in xrepr(key, "default"):
822 for part in xrepr(key, "default"):
823 yield part
823 yield part
824 yield (astyle.style_default, ": ")
824 yield (astyle.style_default, ": ")
825 for part in xrepr(value, "default"):
825 for part in xrepr(value, "default"):
826 yield part
826 yield part
827 yield (astyle.style_default, end)
827 yield (astyle.style_default, end)
828 xrepr.when_type(dict)(xrepr_dict)
828 xrepr.when_type(dict)(xrepr_dict)
829 xrepr.when_type(types.DictProxyType)(xrepr_dict)
829 xrepr.when_type(types.DictProxyType)(xrepr_dict)
830
830
831
831
832 def upgradexattr(attr):
832 def upgradexattr(attr):
833 """
833 """
834 Convert an attribute descriptor string to a real descriptor object.
834 Convert an attribute descriptor string to a real descriptor object.
835
835
836 If attr already is a descriptor object return if unmodified. A
836 If attr already is a descriptor object return if unmodified. A
837 ``SelfDescriptor`` will be returned if ``attr`` is ``None``. ``"foo"``
837 ``SelfDescriptor`` will be returned if ``attr`` is ``None``. ``"foo"``
838 returns an ``AttributeDescriptor`` for the attribute named ``"foo"``.
838 returns an ``AttributeDescriptor`` for the attribute named ``"foo"``.
839 ``"foo()"`` returns a ``MethodDescriptor`` for the method named ``"foo"``.
839 ``"foo()"`` returns a ``MethodDescriptor`` for the method named ``"foo"``.
840 ``"-foo"`` will return an ``IterAttributeDescriptor`` for the attribute
840 ``"-foo"`` will return an ``IterAttributeDescriptor`` for the attribute
841 named ``"foo"`` and ``"-foo()"`` will return an ``IterMethodDescriptor``
841 named ``"foo"`` and ``"-foo()"`` will return an ``IterMethodDescriptor``
842 for the method named ``"foo"``. Furthermore integer will return the appropriate
842 for the method named ``"foo"``. Furthermore integer will return the appropriate
843 ``IndexDescriptor`` and callables will return a ``FunctionDescriptor``.
843 ``IndexDescriptor`` and callables will return a ``FunctionDescriptor``.
844 """
844 """
845 if attr is None:
845 if attr is None:
846 return selfdescriptor
846 return selfdescriptor
847 elif isinstance(attr, Descriptor):
847 elif isinstance(attr, Descriptor):
848 return attr
848 return attr
849 elif isinstance(attr, str):
849 elif isinstance(attr, str):
850 if attr.endswith("()"):
850 if attr.endswith("()"):
851 if attr.startswith("-"):
851 if attr.startswith("-"):
852 return IterMethodDescriptor(attr[1:-2])
852 return IterMethodDescriptor(attr[1:-2])
853 else:
853 else:
854 return MethodDescriptor(attr[:-2])
854 return MethodDescriptor(attr[:-2])
855 else:
855 else:
856 if attr.startswith("-"):
856 if attr.startswith("-"):
857 return IterAttributeDescriptor(attr[1:])
857 return IterAttributeDescriptor(attr[1:])
858 else:
858 else:
859 return AttributeDescriptor(attr)
859 return AttributeDescriptor(attr)
860 elif isinstance(attr, (int, long)):
860 elif isinstance(attr, (int, long)):
861 return IndexDescriptor(attr)
861 return IndexDescriptor(attr)
862 elif callable(attr):
862 elif callable(attr):
863 return FunctionDescriptor(attr)
863 return FunctionDescriptor(attr)
864 else:
864 else:
865 raise TypeError("can't handle descriptor %r" % attr)
865 raise TypeError("can't handle descriptor %r" % attr)
866
866
867
867
868 def xattrs(item, mode="default"):
868 def xattrs(item, mode="default"):
869 """
869 """
870 Generic function that returns an iterable of attribute descriptors
870 Generic function that returns an iterable of attribute descriptors
871 to be used for displaying the attributes ob the object ``item`` in display
871 to be used for displaying the attributes ob the object ``item`` in display
872 mode ``mode``.
872 mode ``mode``.
873
873
874 There are two possible modes:
874 There are two possible modes:
875
875
876 * ``"detail"``: The ``Display`` object wants to display a detailed list
876 * ``"detail"``: The ``Display`` object wants to display a detailed list
877 of the object attributes.
877 of the object attributes.
878 * ``"default"``: The ``Display`` object wants to display the object in a
878 * ``"default"``: The ``Display`` object wants to display the object in a
879 list view.
879 list view.
880
880
881 If no implementation is registered for the object ``item`` ``xattrs`` falls
881 If no implementation is registered for the object ``item`` ``xattrs`` falls
882 back to trying the ``__xattrs__`` method of the object. If this doesn't
882 back to trying the ``__xattrs__`` method of the object. If this doesn't
883 exist either, ``dir(item)`` is used for ``"detail"`` mode and ``(None,)``
883 exist either, ``dir(item)`` is used for ``"detail"`` mode and ``(None,)``
884 for ``"default"`` mode.
884 for ``"default"`` mode.
885
885
886 The implementation must yield attribute descriptor (see the class
886 The implementation must yield attribute descriptor (see the class
887 ``Descriptor`` for more info). The ``__xattrs__`` method may also return
887 ``Descriptor`` for more info). The ``__xattrs__`` method may also return
888 attribute descriptor string (and ``None``) which will be converted to real
888 attribute descriptor string (and ``None``) which will be converted to real
889 descriptors by ``upgradexattr()``.
889 descriptors by ``upgradexattr()``.
890 """
890 """
891 try:
891 try:
892 func = item.__xattrs__
892 func = item.__xattrs__
893 except AttributeError:
893 except AttributeError:
894 if mode == "detail":
894 if mode == "detail":
895 for attrname in dir(item):
895 for attrname in dir(item):
896 yield AttributeDescriptor(attrname)
896 yield AttributeDescriptor(attrname)
897 else:
897 else:
898 yield selfdescriptor
898 yield selfdescriptor
899 else:
899 else:
900 for attr in func(mode):
900 for attr in func(mode):
901 yield upgradexattr(attr)
901 yield upgradexattr(attr)
902 xattrs = simplegeneric.generic(xattrs)
902 xattrs = simplegeneric.generic(xattrs)
903
903
904
904
905 def xattrs_complex(self, mode="default"):
905 def xattrs_complex(self, mode="default"):
906 if mode == "detail":
906 if mode == "detail":
907 return (AttributeDescriptor("real"), AttributeDescriptor("imag"))
907 return (AttributeDescriptor("real"), AttributeDescriptor("imag"))
908 return (selfdescriptor,)
908 return (selfdescriptor,)
909 xattrs.when_type(complex)(xattrs_complex)
909 xattrs.when_type(complex)(xattrs_complex)
910
910
911
911
912 def _isdict(item):
912 def _isdict(item):
913 try:
913 try:
914 itermeth = item.__class__.__iter__
914 itermeth = item.__class__.__iter__
915 except (AttributeError, TypeError):
915 except (AttributeError, TypeError):
916 return False
916 return False
917 return itermeth is dict.__iter__ or itermeth is types.DictProxyType.__iter__
917 return itermeth is dict.__iter__ or itermeth is types.DictProxyType.__iter__
918
918
919
919
920 def _isstr(item):
920 def _isstr(item):
921 if not isinstance(item, basestring):
921 if not isinstance(item, basestring):
922 return False
922 return False
923 try:
923 try:
924 itermeth = item.__class__.__iter__
924 itermeth = item.__class__.__iter__
925 except AttributeError:
925 except AttributeError:
926 return True
926 return True
927 return False # ``__iter__`` has been redefined
927 return False # ``__iter__`` has been redefined
928
928
929
929
930 def xiter(item):
930 def xiter(item):
931 """
931 """
932 Generic function that implements iteration for pipeline expression. If no
932 Generic function that implements iteration for pipeline expression. If no
933 implementation is registered for ``item`` ``xiter`` falls back to ``iter``.
933 implementation is registered for ``item`` ``xiter`` falls back to ``iter``.
934 """
934 """
935 try:
935 try:
936 func = item.__xiter__
936 func = item.__xiter__
937 except AttributeError:
937 except AttributeError:
938 if _isdict(item):
938 if _isdict(item):
939 def items(item):
939 def items(item):
940 fields = ("key", "value")
940 fields = ("key", "value")
941 for (key, value) in item.iteritems():
941 for (key, value) in item.iteritems():
942 yield Fields(fields, key=key, value=value)
942 yield Fields(fields, key=key, value=value)
943 return items(item)
943 return items(item)
944 elif isinstance(item, new.module):
944 elif isinstance(item, new.module):
945 def items(item):
945 def items(item):
946 fields = ("key", "value")
946 fields = ("key", "value")
947 for key in sorted(item.__dict__):
947 for key in sorted(item.__dict__):
948 yield Fields(fields, key=key, value=getattr(item, key))
948 yield Fields(fields, key=key, value=getattr(item, key))
949 return items(item)
949 return items(item)
950 elif _isstr(item):
950 elif _isstr(item):
951 if not item:
951 if not item:
952 raise ValueError("can't enter empty string")
952 raise ValueError("can't enter empty string")
953 lines = item.splitlines()
953 lines = item.splitlines()
954 if len(lines) == 1:
954 if len(lines) == 1:
955 def iterone(item):
955 def iterone(item):
956 yield item
956 yield item
957 return iterone(item)
957 return iterone(item)
958 else:
958 else:
959 return iter(lines)
959 return iter(lines)
960 return iter(item)
960 return iter(item)
961 else:
961 else:
962 return iter(func()) # iter() just to be safe
962 return iter(func()) # iter() just to be safe
963 xiter = simplegeneric.generic(xiter)
963 xiter = simplegeneric.generic(xiter)
964
964
965
965
966 class ichain(Pipe):
966 class ichain(Pipe):
967 """
967 """
968 Chains multiple ``Table``s into one.
968 Chains multiple ``Table``s into one.
969 """
969 """
970
970
971 def __init__(self, *iters):
971 def __init__(self, *iters):
972 self.iters = iters
972 self.iters = iters
973
973
974 def __iter__(self):
974 def __iter__(self):
975 return itertools.chain(*self.iters)
975 return itertools.chain(*self.iters)
976
976
977 def __xrepr__(self, mode="default"):
977 def __xrepr__(self, mode="default"):
978 if mode == "header" or mode == "footer":
978 if mode == "header" or mode == "footer":
979 for (i, item) in enumerate(self.iters):
979 for (i, item) in enumerate(self.iters):
980 if i:
980 if i:
981 yield (astyle.style_default, "+")
981 yield (astyle.style_default, "+")
982 if isinstance(item, Pipe):
982 if isinstance(item, Pipe):
983 yield (astyle.style_default, "(")
983 yield (astyle.style_default, "(")
984 for part in xrepr(item, mode):
984 for part in xrepr(item, mode):
985 yield part
985 yield part
986 if isinstance(item, Pipe):
986 if isinstance(item, Pipe):
987 yield (astyle.style_default, ")")
987 yield (astyle.style_default, ")")
988 else:
988 else:
989 yield (astyle.style_default, repr(self))
989 yield (astyle.style_default, repr(self))
990
990
991 def __repr__(self):
991 def __repr__(self):
992 args = ", ".join([repr(it) for it in self.iters])
992 args = ", ".join([repr(it) for it in self.iters])
993 return "%s.%s(%s)" % \
993 return "%s.%s(%s)" % \
994 (self.__class__.__module__, self.__class__.__name__, args)
994 (self.__class__.__module__, self.__class__.__name__, args)
995
995
996
996
997 class ifile(path.path):
997 class ifile(path.path):
998 """
998 """
999 file (or directory) object.
999 file (or directory) object.
1000 """
1000 """
1001
1001
1002 def getmode(self):
1002 def getmode(self):
1003 return self.stat().st_mode
1003 return self.stat().st_mode
1004 mode = property(getmode, None, None, "Access mode")
1004 mode = property(getmode, None, None, "Access mode")
1005
1005
1006 def gettype(self):
1006 def gettype(self):
1007 data = [
1007 data = [
1008 (stat.S_ISREG, "file"),
1008 (stat.S_ISREG, "file"),
1009 (stat.S_ISDIR, "dir"),
1009 (stat.S_ISDIR, "dir"),
1010 (stat.S_ISCHR, "chardev"),
1010 (stat.S_ISCHR, "chardev"),
1011 (stat.S_ISBLK, "blockdev"),
1011 (stat.S_ISBLK, "blockdev"),
1012 (stat.S_ISFIFO, "fifo"),
1012 (stat.S_ISFIFO, "fifo"),
1013 (stat.S_ISLNK, "symlink"),
1013 (stat.S_ISLNK, "symlink"),
1014 (stat.S_ISSOCK,"socket"),
1014 (stat.S_ISSOCK,"socket"),
1015 ]
1015 ]
1016 lstat = self.lstat()
1016 lstat = self.lstat()
1017 if lstat is not None:
1017 if lstat is not None:
1018 types = set([text for (func, text) in data if func(lstat.st_mode)])
1018 types = set([text for (func, text) in data if func(lstat.st_mode)])
1019 else:
1019 else:
1020 types = set()
1020 types = set()
1021 m = self.mode
1021 m = self.mode
1022 types.update([text for (func, text) in data if func(m)])
1022 types.update([text for (func, text) in data if func(m)])
1023 return ", ".join(types)
1023 return ", ".join(types)
1024 type = property(gettype, None, None, "file type (file, directory, link, etc.)")
1024 type = property(gettype, None, None, "file type (file, directory, link, etc.)")
1025
1025
1026 def getmodestr(self):
1026 def getmodestr(self):
1027 m = self.mode
1027 m = self.mode
1028 data = [
1028 data = [
1029 (stat.S_IRUSR, "-r"),
1029 (stat.S_IRUSR, "-r"),
1030 (stat.S_IWUSR, "-w"),
1030 (stat.S_IWUSR, "-w"),
1031 (stat.S_IXUSR, "-x"),
1031 (stat.S_IXUSR, "-x"),
1032 (stat.S_IRGRP, "-r"),
1032 (stat.S_IRGRP, "-r"),
1033 (stat.S_IWGRP, "-w"),
1033 (stat.S_IWGRP, "-w"),
1034 (stat.S_IXGRP, "-x"),
1034 (stat.S_IXGRP, "-x"),
1035 (stat.S_IROTH, "-r"),
1035 (stat.S_IROTH, "-r"),
1036 (stat.S_IWOTH, "-w"),
1036 (stat.S_IWOTH, "-w"),
1037 (stat.S_IXOTH, "-x"),
1037 (stat.S_IXOTH, "-x"),
1038 ]
1038 ]
1039 return "".join([text[bool(m&bit)] for (bit, text) in data])
1039 return "".join([text[bool(m&bit)] for (bit, text) in data])
1040
1040
1041 modestr = property(getmodestr, None, None, "Access mode as string")
1041 modestr = property(getmodestr, None, None, "Access mode as string")
1042
1042
1043 def getblocks(self):
1043 def getblocks(self):
1044 return self.stat().st_blocks
1044 return self.stat().st_blocks
1045 blocks = property(getblocks, None, None, "File size in blocks")
1045 blocks = property(getblocks, None, None, "File size in blocks")
1046
1046
1047 def getblksize(self):
1047 def getblksize(self):
1048 return self.stat().st_blksize
1048 return self.stat().st_blksize
1049 blksize = property(getblksize, None, None, "Filesystem block size")
1049 blksize = property(getblksize, None, None, "Filesystem block size")
1050
1050
1051 def getdev(self):
1051 def getdev(self):
1052 return self.stat().st_dev
1052 return self.stat().st_dev
1053 dev = property(getdev)
1053 dev = property(getdev)
1054
1054
1055 def getnlink(self):
1055 def getnlink(self):
1056 return self.stat().st_nlink
1056 return self.stat().st_nlink
1057 nlink = property(getnlink, None, None, "Number of links")
1057 nlink = property(getnlink, None, None, "Number of links")
1058
1058
1059 def getuid(self):
1059 def getuid(self):
1060 return self.stat().st_uid
1060 return self.stat().st_uid
1061 uid = property(getuid, None, None, "User id of file owner")
1061 uid = property(getuid, None, None, "User id of file owner")
1062
1062
1063 def getgid(self):
1063 def getgid(self):
1064 return self.stat().st_gid
1064 return self.stat().st_gid
1065 gid = property(getgid, None, None, "Group id of file owner")
1065 gid = property(getgid, None, None, "Group id of file owner")
1066
1066
1067 def getowner(self):
1067 def getowner(self):
1068 stat = self.stat()
1068 stat = self.stat()
1069 try:
1069 try:
1070 return pwd.getpwuid(stat.st_uid).pw_name
1070 return pwd.getpwuid(stat.st_uid).pw_name
1071 except KeyError:
1071 except KeyError:
1072 return stat.st_uid
1072 return stat.st_uid
1073 owner = property(getowner, None, None, "Owner name (or id)")
1073 owner = property(getowner, None, None, "Owner name (or id)")
1074
1074
1075 def getgroup(self):
1075 def getgroup(self):
1076 stat = self.stat()
1076 stat = self.stat()
1077 try:
1077 try:
1078 return grp.getgrgid(stat.st_gid).gr_name
1078 return grp.getgrgid(stat.st_gid).gr_name
1079 except KeyError:
1079 except KeyError:
1080 return stat.st_gid
1080 return stat.st_gid
1081 group = property(getgroup, None, None, "Group name (or id)")
1081 group = property(getgroup, None, None, "Group name (or id)")
1082
1082
1083 def getadate(self):
1083 def getadate(self):
1084 return datetime.datetime.utcfromtimestamp(self.atime)
1084 return datetime.datetime.utcfromtimestamp(self.atime)
1085 adate = property(getadate, None, None, "Access date")
1085 adate = property(getadate, None, None, "Access date")
1086
1086
1087 def getcdate(self):
1087 def getcdate(self):
1088 return datetime.datetime.utcfromtimestamp(self.ctime)
1088 return datetime.datetime.utcfromtimestamp(self.ctime)
1089 cdate = property(getcdate, None, None, "Creation date")
1089 cdate = property(getcdate, None, None, "Creation date")
1090
1090
1091 def getmdate(self):
1091 def getmdate(self):
1092 return datetime.datetime.utcfromtimestamp(self.mtime)
1092 return datetime.datetime.utcfromtimestamp(self.mtime)
1093 mdate = property(getmdate, None, None, "Modification date")
1093 mdate = property(getmdate, None, None, "Modification date")
1094
1094
1095 def mimetype(self):
1095 def mimetype(self):
1096 """
1096 """
1097 Return MIME type guessed from the extension.
1097 Return MIME type guessed from the extension.
1098 """
1098 """
1099 return mimetypes.guess_type(self.basename())[0]
1099 return mimetypes.guess_type(self.basename())[0]
1100
1100
1101 def encoding(self):
1101 def encoding(self):
1102 """
1102 """
1103 Return guessed compression (like "compress" or "gzip").
1103 Return guessed compression (like "compress" or "gzip").
1104 """
1104 """
1105 return mimetypes.guess_type(self.basename())[1]
1105 return mimetypes.guess_type(self.basename())[1]
1106
1106
1107 def __repr__(self):
1107 def __repr__(self):
1108 return "ifile(%s)" % path._base.__repr__(self)
1108 return "ifile(%s)" % path._base.__repr__(self)
1109
1109
1110 if sys.platform == "win32":
1110 if sys.platform == "win32":
1111 defaultattrs = (None, "type", "size", "modestr", "mdate")
1111 defaultattrs = (None, "type", "size", "modestr", "mdate")
1112 else:
1112 else:
1113 defaultattrs = (None, "type", "size", "modestr", "owner", "group", "mdate")
1113 defaultattrs = (None, "type", "size", "modestr", "owner", "group", "mdate")
1114
1114
1115 def __xattrs__(self, mode="default"):
1115 def __xattrs__(self, mode="default"):
1116 if mode == "detail":
1116 if mode == "detail":
1117 return (
1117 return (
1118 "name",
1118 "name",
1119 "basename()",
1119 "basename()",
1120 "abspath()",
1120 "abspath()",
1121 "realpath()",
1121 "realpath()",
1122 "type",
1122 "type",
1123 "mode",
1123 "mode",
1124 "modestr",
1124 "modestr",
1125 "stat()",
1125 "stat()",
1126 "lstat()",
1126 "lstat()",
1127 "uid",
1127 "uid",
1128 "gid",
1128 "gid",
1129 "owner",
1129 "owner",
1130 "group",
1130 "group",
1131 "dev",
1131 "dev",
1132 "nlink",
1132 "nlink",
1133 "ctime",
1133 "ctime",
1134 "mtime",
1134 "mtime",
1135 "atime",
1135 "atime",
1136 "cdate",
1136 "cdate",
1137 "mdate",
1137 "mdate",
1138 "adate",
1138 "adate",
1139 "size",
1139 "size",
1140 "blocks",
1140 "blocks",
1141 "blksize",
1141 "blksize",
1142 "isdir()",
1142 "isdir()",
1143 "islink()",
1143 "islink()",
1144 "mimetype()",
1144 "mimetype()",
1145 "encoding()",
1145 "encoding()",
1146 "-listdir()",
1146 "-listdir()",
1147 "-dirs()",
1147 "-dirs()",
1148 "-files()",
1148 "-files()",
1149 "-walk()",
1149 "-walk()",
1150 "-walkdirs()",
1150 "-walkdirs()",
1151 "-walkfiles()",
1151 "-walkfiles()",
1152 )
1152 )
1153 else:
1153 else:
1154 return self.defaultattrs
1154 return self.defaultattrs
1155
1155
1156
1156
1157 def xiter_ifile(self):
1157 def xiter_ifile(self):
1158 if self.isdir():
1158 if self.isdir():
1159 yield (self / os.pardir).abspath()
1159 yield (self / os.pardir).abspath()
1160 for child in sorted(self.listdir()):
1160 for child in sorted(self.listdir()):
1161 yield child
1161 yield child
1162 else:
1162 else:
1163 f = self.open("rb")
1163 f = self.open("rb")
1164 for line in f:
1164 for line in f:
1165 yield line
1165 yield line
1166 f.close()
1166 f.close()
1167 xiter.when_type(ifile)(xiter_ifile)
1167 xiter.when_type(ifile)(xiter_ifile)
1168
1168
1169
1169
1170 # We need to implement ``xrepr`` for ``ifile`` as a generic function, because
1170 # We need to implement ``xrepr`` for ``ifile`` as a generic function, because
1171 # otherwise ``xrepr_str`` would kick in.
1171 # otherwise ``xrepr_str`` would kick in.
1172 def xrepr_ifile(self, mode="default"):
1172 def xrepr_ifile(self, mode="default"):
1173 try:
1173 try:
1174 if self.isdir():
1174 if self.isdir():
1175 name = "idir"
1175 name = "idir"
1176 style = astyle.style_dir
1176 style = astyle.style_dir
1177 else:
1177 else:
1178 name = "ifile"
1178 name = "ifile"
1179 style = astyle.style_file
1179 style = astyle.style_file
1180 except IOError:
1180 except IOError:
1181 name = "ifile"
1181 name = "ifile"
1182 style = astyle.style_default
1182 style = astyle.style_default
1183 if mode == "cell" or mode in "header" or mode == "footer":
1183 if mode in ("cell", "header", "footer"):
1184 abspath = repr(path._base(self.normpath()))
1184 abspath = repr(path._base(self.normpath()))
1185 if abspath.startswith("u"):
1185 if abspath.startswith("u"):
1186 abspath = abspath[2:-1]
1186 abspath = abspath[2:-1]
1187 else:
1187 else:
1188 abspath = abspath[1:-1]
1188 abspath = abspath[1:-1]
1189 if mode == "cell":
1189 if mode == "cell":
1190 yield (style, abspath)
1190 yield (style, abspath)
1191 else:
1191 else:
1192 yield (style, "%s(%s)" % (name, abspath))
1192 yield (style, "%s(%s)" % (name, abspath))
1193 else:
1193 else:
1194 yield (style, repr(self))
1194 yield (style, repr(self))
1195 xrepr.when_type(ifile)(xrepr_ifile)
1195 xrepr.when_type(ifile)(xrepr_ifile)
1196
1196
1197
1197
1198 class ils(Table):
1198 class ils(Table):
1199 """
1199 """
1200 List the current (or a specified) directory.
1200 List the current (or a specified) directory.
1201
1201
1202 Examples:
1202 Examples:
1203
1203
1204 >>> ils
1204 >>> ils
1205 >>> ils("/usr/local/lib/python2.4")
1205 >>> ils("/usr/local/lib/python2.4")
1206 >>> ils("~")
1206 >>> ils("~")
1207 """
1207 """
1208 def __init__(self, base=os.curdir, dirs=True, files=True):
1208 def __init__(self, base=os.curdir, dirs=True, files=True):
1209 self.base = os.path.expanduser(base)
1209 self.base = os.path.expanduser(base)
1210 self.dirs = dirs
1210 self.dirs = dirs
1211 self.files = files
1211 self.files = files
1212
1212
1213 def __iter__(self):
1213 def __iter__(self):
1214 base = ifile(self.base)
1214 base = ifile(self.base)
1215 yield (base / os.pardir).abspath()
1215 yield (base / os.pardir).abspath()
1216 for child in sorted(base.listdir()):
1216 for child in sorted(base.listdir()):
1217 if self.dirs:
1217 if self.dirs:
1218 if self.files:
1218 if self.files:
1219 yield child
1219 yield child
1220 else:
1220 else:
1221 if child.isdir():
1221 if child.isdir():
1222 yield child
1222 yield child
1223 elif self.files:
1223 elif self.files:
1224 if not child.isdir():
1224 if not child.isdir():
1225 yield child
1225 yield child
1226
1226
1227 def __xrepr__(self, mode="default"):
1227 def __xrepr__(self, mode="default"):
1228 return xrepr(ifile(self.base), mode)
1228 return xrepr(ifile(self.base), mode)
1229
1229
1230 def __repr__(self):
1230 def __repr__(self):
1231 return "%s.%s(%r)" % \
1231 return "%s.%s(%r)" % \
1232 (self.__class__.__module__, self.__class__.__name__, self.base)
1232 (self.__class__.__module__, self.__class__.__name__, self.base)
1233
1233
1234
1234
1235 class iglob(Table):
1235 class iglob(Table):
1236 """
1236 """
1237 List all files and directories matching a specified pattern.
1237 List all files and directories matching a specified pattern.
1238 (See ``glob.glob()`` for more info.).
1238 (See ``glob.glob()`` for more info.).
1239
1239
1240 Examples:
1240 Examples:
1241
1241
1242 >>> iglob("*.py")
1242 >>> iglob("*.py")
1243 """
1243 """
1244 def __init__(self, glob):
1244 def __init__(self, glob):
1245 self.glob = glob
1245 self.glob = glob
1246
1246
1247 def __iter__(self):
1247 def __iter__(self):
1248 for name in glob.glob(self.glob):
1248 for name in glob.glob(self.glob):
1249 yield ifile(name)
1249 yield ifile(name)
1250
1250
1251 def __xrepr__(self, mode="default"):
1251 def __xrepr__(self, mode="default"):
1252 if mode == "header" or mode == "footer" or mode == "cell":
1252 if mode == "header" or mode == "footer" or mode == "cell":
1253 yield (astyle.style_default,
1253 yield (astyle.style_default,
1254 "%s(%r)" % (self.__class__.__name__, self.glob))
1254 "%s(%r)" % (self.__class__.__name__, self.glob))
1255 else:
1255 else:
1256 yield (astyle.style_default, repr(self))
1256 yield (astyle.style_default, repr(self))
1257
1257
1258 def __repr__(self):
1258 def __repr__(self):
1259 return "%s.%s(%r)" % \
1259 return "%s.%s(%r)" % \
1260 (self.__class__.__module__, self.__class__.__name__, self.glob)
1260 (self.__class__.__module__, self.__class__.__name__, self.glob)
1261
1261
1262
1262
1263 class iwalk(Table):
1263 class iwalk(Table):
1264 """
1264 """
1265 List all files and directories in a directory and it's subdirectory.
1265 List all files and directories in a directory and it's subdirectory.
1266
1266
1267 >>> iwalk
1267 >>> iwalk
1268 >>> iwalk("/usr/local/lib/python2.4")
1268 >>> iwalk("/usr/local/lib/python2.4")
1269 >>> iwalk("~")
1269 >>> iwalk("~")
1270 """
1270 """
1271 def __init__(self, base=os.curdir, dirs=True, files=True):
1271 def __init__(self, base=os.curdir, dirs=True, files=True):
1272 self.base = os.path.expanduser(base)
1272 self.base = os.path.expanduser(base)
1273 self.dirs = dirs
1273 self.dirs = dirs
1274 self.files = files
1274 self.files = files
1275
1275
1276 def __iter__(self):
1276 def __iter__(self):
1277 for (dirpath, dirnames, filenames) in os.walk(self.base):
1277 for (dirpath, dirnames, filenames) in os.walk(self.base):
1278 if self.dirs:
1278 if self.dirs:
1279 for name in sorted(dirnames):
1279 for name in sorted(dirnames):
1280 yield ifile(os.path.join(dirpath, name))
1280 yield ifile(os.path.join(dirpath, name))
1281 if self.files:
1281 if self.files:
1282 for name in sorted(filenames):
1282 for name in sorted(filenames):
1283 yield ifile(os.path.join(dirpath, name))
1283 yield ifile(os.path.join(dirpath, name))
1284
1284
1285 def __xrepr__(self, mode="default"):
1285 def __xrepr__(self, mode="default"):
1286 if mode == "header" or mode == "footer" or mode == "cell":
1286 if mode == "header" or mode == "footer" or mode == "cell":
1287 yield (astyle.style_default,
1287 yield (astyle.style_default,
1288 "%s(%r)" % (self.__class__.__name__, self.base))
1288 "%s(%r)" % (self.__class__.__name__, self.base))
1289 else:
1289 else:
1290 yield (astyle.style_default, repr(self))
1290 yield (astyle.style_default, repr(self))
1291
1291
1292 def __repr__(self):
1292 def __repr__(self):
1293 return "%s.%s(%r)" % \
1293 return "%s.%s(%r)" % \
1294 (self.__class__.__module__, self.__class__.__name__, self.base)
1294 (self.__class__.__module__, self.__class__.__name__, self.base)
1295
1295
1296
1296
1297 class ipwdentry(object):
1297 class ipwdentry(object):
1298 """
1298 """
1299 ``ipwdentry`` objects encapsulate entries in the Unix user account and
1299 ``ipwdentry`` objects encapsulate entries in the Unix user account and
1300 password database.
1300 password database.
1301 """
1301 """
1302 def __init__(self, id):
1302 def __init__(self, id):
1303 self._id = id
1303 self._id = id
1304 self._entry = None
1304 self._entry = None
1305
1305
1306 def __eq__(self, other):
1306 def __eq__(self, other):
1307 return self.__class__ is other.__class__ and self._id == other._id
1307 return self.__class__ is other.__class__ and self._id == other._id
1308
1308
1309 def __ne__(self, other):
1309 def __ne__(self, other):
1310 return self.__class__ is not other.__class__ or self._id != other._id
1310 return self.__class__ is not other.__class__ or self._id != other._id
1311
1311
1312 def _getentry(self):
1312 def _getentry(self):
1313 if self._entry is None:
1313 if self._entry is None:
1314 if isinstance(self._id, basestring):
1314 if isinstance(self._id, basestring):
1315 self._entry = pwd.getpwnam(self._id)
1315 self._entry = pwd.getpwnam(self._id)
1316 else:
1316 else:
1317 self._entry = pwd.getpwuid(self._id)
1317 self._entry = pwd.getpwuid(self._id)
1318 return self._entry
1318 return self._entry
1319
1319
1320 def getname(self):
1320 def getname(self):
1321 if isinstance(self._id, basestring):
1321 if isinstance(self._id, basestring):
1322 return self._id
1322 return self._id
1323 else:
1323 else:
1324 return self._getentry().pw_name
1324 return self._getentry().pw_name
1325 name = property(getname, None, None, "User name")
1325 name = property(getname, None, None, "User name")
1326
1326
1327 def getpasswd(self):
1327 def getpasswd(self):
1328 return self._getentry().pw_passwd
1328 return self._getentry().pw_passwd
1329 passwd = property(getpasswd, None, None, "Password")
1329 passwd = property(getpasswd, None, None, "Password")
1330
1330
1331 def getuid(self):
1331 def getuid(self):
1332 if isinstance(self._id, basestring):
1332 if isinstance(self._id, basestring):
1333 return self._getentry().pw_uid
1333 return self._getentry().pw_uid
1334 else:
1334 else:
1335 return self._id
1335 return self._id
1336 uid = property(getuid, None, None, "User id")
1336 uid = property(getuid, None, None, "User id")
1337
1337
1338 def getgid(self):
1338 def getgid(self):
1339 return self._getentry().pw_gid
1339 return self._getentry().pw_gid
1340 gid = property(getgid, None, None, "Primary group id")
1340 gid = property(getgid, None, None, "Primary group id")
1341
1341
1342 def getgroup(self):
1342 def getgroup(self):
1343 return igrpentry(self.gid)
1343 return igrpentry(self.gid)
1344 group = property(getgroup, None, None, "Group")
1344 group = property(getgroup, None, None, "Group")
1345
1345
1346 def getgecos(self):
1346 def getgecos(self):
1347 return self._getentry().pw_gecos
1347 return self._getentry().pw_gecos
1348 gecos = property(getgecos, None, None, "Information (e.g. full user name)")
1348 gecos = property(getgecos, None, None, "Information (e.g. full user name)")
1349
1349
1350 def getdir(self):
1350 def getdir(self):
1351 return self._getentry().pw_dir
1351 return self._getentry().pw_dir
1352 dir = property(getdir, None, None, "$HOME directory")
1352 dir = property(getdir, None, None, "$HOME directory")
1353
1353
1354 def getshell(self):
1354 def getshell(self):
1355 return self._getentry().pw_shell
1355 return self._getentry().pw_shell
1356 shell = property(getshell, None, None, "Login shell")
1356 shell = property(getshell, None, None, "Login shell")
1357
1357
1358 def __xattrs__(self, mode="default"):
1358 def __xattrs__(self, mode="default"):
1359 return ("name", "passwd", "uid", "gid", "gecos", "dir", "shell")
1359 return ("name", "passwd", "uid", "gid", "gecos", "dir", "shell")
1360
1360
1361 def __repr__(self):
1361 def __repr__(self):
1362 return "%s.%s(%r)" % \
1362 return "%s.%s(%r)" % \
1363 (self.__class__.__module__, self.__class__.__name__, self._id)
1363 (self.__class__.__module__, self.__class__.__name__, self._id)
1364
1364
1365
1365
1366 class ipwd(Table):
1366 class ipwd(Table):
1367 """
1367 """
1368 List all entries in the Unix user account and password database.
1368 List all entries in the Unix user account and password database.
1369
1369
1370 Example:
1370 Example:
1371
1371
1372 >>> ipwd | isort("uid")
1372 >>> ipwd | isort("uid")
1373 """
1373 """
1374 def __iter__(self):
1374 def __iter__(self):
1375 for entry in pwd.getpwall():
1375 for entry in pwd.getpwall():
1376 yield ipwdentry(entry.pw_name)
1376 yield ipwdentry(entry.pw_name)
1377
1377
1378 def __xrepr__(self, mode="default"):
1378 def __xrepr__(self, mode="default"):
1379 if mode == "header" or mode == "footer" or mode == "cell":
1379 if mode == "header" or mode == "footer" or mode == "cell":
1380 yield (astyle.style_default, "%s()" % self.__class__.__name__)
1380 yield (astyle.style_default, "%s()" % self.__class__.__name__)
1381 else:
1381 else:
1382 yield (astyle.style_default, repr(self))
1382 yield (astyle.style_default, repr(self))
1383
1383
1384
1384
1385 class igrpentry(object):
1385 class igrpentry(object):
1386 """
1386 """
1387 ``igrpentry`` objects encapsulate entries in the Unix group database.
1387 ``igrpentry`` objects encapsulate entries in the Unix group database.
1388 """
1388 """
1389 def __init__(self, id):
1389 def __init__(self, id):
1390 self._id = id
1390 self._id = id
1391 self._entry = None
1391 self._entry = None
1392
1392
1393 def __eq__(self, other):
1393 def __eq__(self, other):
1394 return self.__class__ is other.__class__ and self._id == other._id
1394 return self.__class__ is other.__class__ and self._id == other._id
1395
1395
1396 def __ne__(self, other):
1396 def __ne__(self, other):
1397 return self.__class__ is not other.__class__ or self._id != other._id
1397 return self.__class__ is not other.__class__ or self._id != other._id
1398
1398
1399 def _getentry(self):
1399 def _getentry(self):
1400 if self._entry is None:
1400 if self._entry is None:
1401 if isinstance(self._id, basestring):
1401 if isinstance(self._id, basestring):
1402 self._entry = grp.getgrnam(self._id)
1402 self._entry = grp.getgrnam(self._id)
1403 else:
1403 else:
1404 self._entry = grp.getgrgid(self._id)
1404 self._entry = grp.getgrgid(self._id)
1405 return self._entry
1405 return self._entry
1406
1406
1407 def getname(self):
1407 def getname(self):
1408 if isinstance(self._id, basestring):
1408 if isinstance(self._id, basestring):
1409 return self._id
1409 return self._id
1410 else:
1410 else:
1411 return self._getentry().gr_name
1411 return self._getentry().gr_name
1412 name = property(getname, None, None, "Group name")
1412 name = property(getname, None, None, "Group name")
1413
1413
1414 def getpasswd(self):
1414 def getpasswd(self):
1415 return self._getentry().gr_passwd
1415 return self._getentry().gr_passwd
1416 passwd = property(getpasswd, None, None, "Password")
1416 passwd = property(getpasswd, None, None, "Password")
1417
1417
1418 def getgid(self):
1418 def getgid(self):
1419 if isinstance(self._id, basestring):
1419 if isinstance(self._id, basestring):
1420 return self._getentry().gr_gid
1420 return self._getentry().gr_gid
1421 else:
1421 else:
1422 return self._id
1422 return self._id
1423 gid = property(getgid, None, None, "Group id")
1423 gid = property(getgid, None, None, "Group id")
1424
1424
1425 def getmem(self):
1425 def getmem(self):
1426 return self._getentry().gr_mem
1426 return self._getentry().gr_mem
1427 mem = property(getmem, None, None, "Members")
1427 mem = property(getmem, None, None, "Members")
1428
1428
1429 def __xattrs__(self, mode="default"):
1429 def __xattrs__(self, mode="default"):
1430 return ("name", "passwd", "gid", "mem")
1430 return ("name", "passwd", "gid", "mem")
1431
1431
1432 def __xrepr__(self, mode="default"):
1432 def __xrepr__(self, mode="default"):
1433 if mode == "header" or mode == "footer" or mode == "cell":
1433 if mode == "header" or mode == "footer" or mode == "cell":
1434 yield (astyle.style_default, "group ")
1434 yield (astyle.style_default, "group ")
1435 try:
1435 try:
1436 yield (astyle.style_default, self.name)
1436 yield (astyle.style_default, self.name)
1437 except KeyError:
1437 except KeyError:
1438 if isinstance(self._id, basestring):
1438 if isinstance(self._id, basestring):
1439 yield (astyle.style_default, self.name_id)
1439 yield (astyle.style_default, self.name_id)
1440 else:
1440 else:
1441 yield (astyle.style_type_number, str(self._id))
1441 yield (astyle.style_type_number, str(self._id))
1442 else:
1442 else:
1443 yield (astyle.style_default, repr(self))
1443 yield (astyle.style_default, repr(self))
1444
1444
1445 def __iter__(self):
1445 def __iter__(self):
1446 for member in self.mem:
1446 for member in self.mem:
1447 yield ipwdentry(member)
1447 yield ipwdentry(member)
1448
1448
1449 def __repr__(self):
1449 def __repr__(self):
1450 return "%s.%s(%r)" % \
1450 return "%s.%s(%r)" % \
1451 (self.__class__.__module__, self.__class__.__name__, self._id)
1451 (self.__class__.__module__, self.__class__.__name__, self._id)
1452
1452
1453
1453
1454 class igrp(Table):
1454 class igrp(Table):
1455 """
1455 """
1456 This ``Table`` lists all entries in the Unix group database.
1456 This ``Table`` lists all entries in the Unix group database.
1457 """
1457 """
1458 def __iter__(self):
1458 def __iter__(self):
1459 for entry in grp.getgrall():
1459 for entry in grp.getgrall():
1460 yield igrpentry(entry.gr_name)
1460 yield igrpentry(entry.gr_name)
1461
1461
1462 def __xrepr__(self, mode="default"):
1462 def __xrepr__(self, mode="default"):
1463 if mode == "header" or mode == "footer":
1463 if mode == "header" or mode == "footer":
1464 yield (astyle.style_default, "%s()" % self.__class__.__name__)
1464 yield (astyle.style_default, "%s()" % self.__class__.__name__)
1465 else:
1465 else:
1466 yield (astyle.style_default, repr(self))
1466 yield (astyle.style_default, repr(self))
1467
1467
1468
1468
1469 class Fields(object):
1469 class Fields(object):
1470 def __init__(self, fieldnames, **fields):
1470 def __init__(self, fieldnames, **fields):
1471 self.__fieldnames = [upgradexattr(fieldname) for fieldname in fieldnames]
1471 self.__fieldnames = [upgradexattr(fieldname) for fieldname in fieldnames]
1472 for (key, value) in fields.iteritems():
1472 for (key, value) in fields.iteritems():
1473 setattr(self, key, value)
1473 setattr(self, key, value)
1474
1474
1475 def __xattrs__(self, mode="default"):
1475 def __xattrs__(self, mode="default"):
1476 return self.__fieldnames
1476 return self.__fieldnames
1477
1477
1478 def __xrepr__(self, mode="default"):
1478 def __xrepr__(self, mode="default"):
1479 yield (-1, False)
1479 yield (-1, False)
1480 if mode == "header" or mode == "cell":
1480 if mode == "header" or mode == "cell":
1481 yield (astyle.style_default, self.__class__.__name__)
1481 yield (astyle.style_default, self.__class__.__name__)
1482 yield (astyle.style_default, "(")
1482 yield (astyle.style_default, "(")
1483 for (i, f) in enumerate(self.__fieldnames):
1483 for (i, f) in enumerate(self.__fieldnames):
1484 if i:
1484 if i:
1485 yield (astyle.style_default, ", ")
1485 yield (astyle.style_default, ", ")
1486 yield (astyle.style_default, f.name())
1486 yield (astyle.style_default, f.name())
1487 yield (astyle.style_default, "=")
1487 yield (astyle.style_default, "=")
1488 for part in xrepr(getattr(self, f), "default"):
1488 for part in xrepr(getattr(self, f), "default"):
1489 yield part
1489 yield part
1490 yield (astyle.style_default, ")")
1490 yield (astyle.style_default, ")")
1491 elif mode == "footer":
1491 elif mode == "footer":
1492 yield (astyle.style_default, self.__class__.__name__)
1492 yield (astyle.style_default, self.__class__.__name__)
1493 yield (astyle.style_default, "(")
1493 yield (astyle.style_default, "(")
1494 for (i, f) in enumerate(self.__fieldnames):
1494 for (i, f) in enumerate(self.__fieldnames):
1495 if i:
1495 if i:
1496 yield (astyle.style_default, ", ")
1496 yield (astyle.style_default, ", ")
1497 yield (astyle.style_default, f.name())
1497 yield (astyle.style_default, f.name())
1498 yield (astyle.style_default, ")")
1498 yield (astyle.style_default, ")")
1499 else:
1499 else:
1500 yield (astyle.style_default, repr(self))
1500 yield (astyle.style_default, repr(self))
1501
1501
1502
1502
1503 class FieldTable(Table, list):
1503 class FieldTable(Table, list):
1504 def __init__(self, *fields):
1504 def __init__(self, *fields):
1505 Table.__init__(self)
1505 Table.__init__(self)
1506 list.__init__(self)
1506 list.__init__(self)
1507 self.fields = fields
1507 self.fields = fields
1508
1508
1509 def add(self, **fields):
1509 def add(self, **fields):
1510 self.append(Fields(self.fields, **fields))
1510 self.append(Fields(self.fields, **fields))
1511
1511
1512 def __xrepr__(self, mode="default"):
1512 def __xrepr__(self, mode="default"):
1513 yield (-1, False)
1513 yield (-1, False)
1514 if mode == "header" or mode == "footer":
1514 if mode == "header" or mode == "footer":
1515 yield (astyle.style_default, self.__class__.__name__)
1515 yield (astyle.style_default, self.__class__.__name__)
1516 yield (astyle.style_default, "(")
1516 yield (astyle.style_default, "(")
1517 for (i, f) in enumerate(self.__fieldnames):
1517 for (i, f) in enumerate(self.__fieldnames):
1518 if i:
1518 if i:
1519 yield (astyle.style_default, ", ")
1519 yield (astyle.style_default, ", ")
1520 yield (astyle.style_default, f)
1520 yield (astyle.style_default, f)
1521 yield (astyle.style_default, ")")
1521 yield (astyle.style_default, ")")
1522 else:
1522 else:
1523 yield (astyle.style_default, repr(self))
1523 yield (astyle.style_default, repr(self))
1524
1524
1525 def __repr__(self):
1525 def __repr__(self):
1526 return "<%s.%s object with fields=%r at 0x%x>" % \
1526 return "<%s.%s object with fields=%r at 0x%x>" % \
1527 (self.__class__.__module__, self.__class__.__name__,
1527 (self.__class__.__module__, self.__class__.__name__,
1528 ", ".join(map(repr, self.fields)), id(self))
1528 ", ".join(map(repr, self.fields)), id(self))
1529
1529
1530
1530
1531 class List(list):
1531 class List(list):
1532 def __xattrs__(self, mode="default"):
1532 def __xattrs__(self, mode="default"):
1533 return xrange(len(self))
1533 return xrange(len(self))
1534
1534
1535 def __xrepr__(self, mode="default"):
1535 def __xrepr__(self, mode="default"):
1536 yield (-1, False)
1536 yield (-1, False)
1537 if mode == "header" or mode == "cell" or mode == "footer" or mode == "default":
1537 if mode == "header" or mode == "cell" or mode == "footer" or mode == "default":
1538 yield (astyle.style_default, self.__class__.__name__)
1538 yield (astyle.style_default, self.__class__.__name__)
1539 yield (astyle.style_default, "(")
1539 yield (astyle.style_default, "(")
1540 for (i, item) in enumerate(self):
1540 for (i, item) in enumerate(self):
1541 if i:
1541 if i:
1542 yield (astyle.style_default, ", ")
1542 yield (astyle.style_default, ", ")
1543 for part in xrepr(item, "default"):
1543 for part in xrepr(item, "default"):
1544 yield part
1544 yield part
1545 yield (astyle.style_default, ")")
1545 yield (astyle.style_default, ")")
1546 else:
1546 else:
1547 yield (astyle.style_default, repr(self))
1547 yield (astyle.style_default, repr(self))
1548
1548
1549
1549
1550 class ienv(Table):
1550 class ienv(Table):
1551 """
1551 """
1552 List environment variables.
1552 List environment variables.
1553
1553
1554 Example:
1554 Example:
1555
1555
1556 >>> ienv
1556 >>> ienv
1557 """
1557 """
1558
1558
1559 def __iter__(self):
1559 def __iter__(self):
1560 fields = ("key", "value")
1560 fields = ("key", "value")
1561 for (key, value) in os.environ.iteritems():
1561 for (key, value) in os.environ.iteritems():
1562 yield Fields(fields, key=key, value=value)
1562 yield Fields(fields, key=key, value=value)
1563
1563
1564 def __xrepr__(self, mode="default"):
1564 def __xrepr__(self, mode="default"):
1565 if mode == "header" or mode == "cell":
1565 if mode == "header" or mode == "cell":
1566 yield (astyle.style_default, "%s()" % self.__class__.__name__)
1566 yield (astyle.style_default, "%s()" % self.__class__.__name__)
1567 else:
1567 else:
1568 yield (astyle.style_default, repr(self))
1568 yield (astyle.style_default, repr(self))
1569
1569
1570
1570
1571 class icsv(Pipe):
1571 class icsv(Pipe):
1572 """
1572 """
1573 This ``Pipe`` lists turn the input (with must be a pipe outputting lines
1573 This ``Pipe`` lists turn the input (with must be a pipe outputting lines
1574 or an ``ifile``) into lines of CVS columns.
1574 or an ``ifile``) into lines of CVS columns.
1575 """
1575 """
1576 def __init__(self, **csvargs):
1576 def __init__(self, **csvargs):
1577 """
1577 """
1578 Create an ``icsv`` object. ``cvsargs`` will be passed through as
1578 Create an ``icsv`` object. ``cvsargs`` will be passed through as
1579 keyword arguments to ``cvs.reader()``.
1579 keyword arguments to ``cvs.reader()``.
1580 """
1580 """
1581 self.csvargs = csvargs
1581 self.csvargs = csvargs
1582
1582
1583 def __iter__(self):
1583 def __iter__(self):
1584 input = self.input
1584 input = self.input
1585 if isinstance(input, ifile):
1585 if isinstance(input, ifile):
1586 input = input.open("rb")
1586 input = input.open("rb")
1587 reader = csv.reader(input, **self.csvargs)
1587 reader = csv.reader(input, **self.csvargs)
1588 for line in reader:
1588 for line in reader:
1589 yield List(line)
1589 yield List(line)
1590
1590
1591 def __xrepr__(self, mode="default"):
1591 def __xrepr__(self, mode="default"):
1592 yield (-1, False)
1592 yield (-1, False)
1593 if mode == "header" or mode == "footer":
1593 if mode == "header" or mode == "footer":
1594 input = getattr(self, "input", None)
1594 input = getattr(self, "input", None)
1595 if input is not None:
1595 if input is not None:
1596 for part in xrepr(input, mode):
1596 for part in xrepr(input, mode):
1597 yield part
1597 yield part
1598 yield (astyle.style_default, " | ")
1598 yield (astyle.style_default, " | ")
1599 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1599 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1600 for (i, (name, value)) in enumerate(self.csvargs.iteritems()):
1600 for (i, (name, value)) in enumerate(self.csvargs.iteritems()):
1601 if i:
1601 if i:
1602 yield (astyle.style_default, ", ")
1602 yield (astyle.style_default, ", ")
1603 yield (astyle.style_default, name)
1603 yield (astyle.style_default, name)
1604 yield (astyle.style_default, "=")
1604 yield (astyle.style_default, "=")
1605 for part in xrepr(value, "default"):
1605 for part in xrepr(value, "default"):
1606 yield part
1606 yield part
1607 yield (astyle.style_default, ")")
1607 yield (astyle.style_default, ")")
1608 else:
1608 else:
1609 yield (astyle.style_default, repr(self))
1609 yield (astyle.style_default, repr(self))
1610
1610
1611 def __repr__(self):
1611 def __repr__(self):
1612 args = ", ".join(["%s=%r" % item for item in self.csvargs.iteritems()])
1612 args = ", ".join(["%s=%r" % item for item in self.csvargs.iteritems()])
1613 return "<%s.%s %s at 0x%x>" % \
1613 return "<%s.%s %s at 0x%x>" % \
1614 (self.__class__.__module__, self.__class__.__name__, args, id(self))
1614 (self.__class__.__module__, self.__class__.__name__, args, id(self))
1615
1615
1616
1616
1617 class ix(Table):
1617 class ix(Table):
1618 """
1618 """
1619 Execute a system command and list its output as lines
1619 Execute a system command and list its output as lines
1620 (similar to ``os.popen()``).
1620 (similar to ``os.popen()``).
1621
1621
1622 Examples:
1622 Examples:
1623
1623
1624 >>> ix("ps x")
1624 >>> ix("ps x")
1625 >>> ix("find .") | ifile
1625 >>> ix("find .") | ifile
1626 """
1626 """
1627 def __init__(self, cmd):
1627 def __init__(self, cmd):
1628 self.cmd = cmd
1628 self.cmd = cmd
1629 self._pipeout = None
1629 self._pipeout = None
1630
1630
1631 def __iter__(self):
1631 def __iter__(self):
1632 (_pipein, self._pipeout) = os.popen4(self.cmd)
1632 (_pipein, self._pipeout) = os.popen4(self.cmd)
1633 _pipein.close()
1633 _pipein.close()
1634 for l in self._pipeout:
1634 for l in self._pipeout:
1635 yield l.rstrip("\r\n")
1635 yield l.rstrip("\r\n")
1636 self._pipeout.close()
1636 self._pipeout.close()
1637 self._pipeout = None
1637 self._pipeout = None
1638
1638
1639 def __del__(self):
1639 def __del__(self):
1640 if self._pipeout is not None and not self._pipeout.closed:
1640 if self._pipeout is not None and not self._pipeout.closed:
1641 self._pipeout.close()
1641 self._pipeout.close()
1642 self._pipeout = None
1642 self._pipeout = None
1643
1643
1644 def __xrepr__(self, mode="default"):
1644 def __xrepr__(self, mode="default"):
1645 if mode == "header" or mode == "footer":
1645 if mode == "header" or mode == "footer":
1646 yield (astyle.style_default,
1646 yield (astyle.style_default,
1647 "%s(%r)" % (self.__class__.__name__, self.cmd))
1647 "%s(%r)" % (self.__class__.__name__, self.cmd))
1648 else:
1648 else:
1649 yield (astyle.style_default, repr(self))
1649 yield (astyle.style_default, repr(self))
1650
1650
1651 def __repr__(self):
1651 def __repr__(self):
1652 return "%s.%s(%r)" % \
1652 return "%s.%s(%r)" % \
1653 (self.__class__.__module__, self.__class__.__name__, self.cmd)
1653 (self.__class__.__module__, self.__class__.__name__, self.cmd)
1654
1654
1655
1655
1656 class ifilter(Pipe):
1656 class ifilter(Pipe):
1657 """
1657 """
1658 Filter an input pipe. Only objects where an expression evaluates to true
1658 Filter an input pipe. Only objects where an expression evaluates to true
1659 (and doesn't raise an exception) are listed.
1659 (and doesn't raise an exception) are listed.
1660
1660
1661 Examples:
1661 Examples:
1662
1662
1663 >>> ils | ifilter("_.isfile() and size>1000")
1663 >>> ils | ifilter("_.isfile() and size>1000")
1664 >>> igrp | ifilter("len(mem)")
1664 >>> igrp | ifilter("len(mem)")
1665 >>> sys.modules | ifilter(lambda _:_.value is not None)
1665 >>> sys.modules | ifilter(lambda _:_.value is not None)
1666 """
1666 """
1667
1667
1668 def __init__(self, expr, globals=None, errors="raiseifallfail"):
1668 def __init__(self, expr, globals=None, errors="raiseifallfail"):
1669 """
1669 """
1670 Create an ``ifilter`` object. ``expr`` can be a callable or a string
1670 Create an ``ifilter`` object. ``expr`` can be a callable or a string
1671 containing an expression. ``globals`` will be used as the global
1671 containing an expression. ``globals`` will be used as the global
1672 namespace for calling string expressions (defaulting to IPython's
1672 namespace for calling string expressions (defaulting to IPython's
1673 user namespace). ``errors`` specifies how exception during evaluation
1673 user namespace). ``errors`` specifies how exception during evaluation
1674 of ``expr`` are handled:
1674 of ``expr`` are handled:
1675
1675
1676 * ``drop``: drop all items that have errors;
1676 * ``drop``: drop all items that have errors;
1677
1677
1678 * ``keep``: keep all items that have errors;
1678 * ``keep``: keep all items that have errors;
1679
1679
1680 * ``keeperror``: keep the exception of all items that have errors;
1680 * ``keeperror``: keep the exception of all items that have errors;
1681
1681
1682 * ``raise``: raise the exception;
1682 * ``raise``: raise the exception;
1683
1683
1684 * ``raiseifallfail``: raise the first exception if all items have errors;
1684 * ``raiseifallfail``: raise the first exception if all items have errors;
1685 otherwise drop those with errors (this is the default).
1685 otherwise drop those with errors (this is the default).
1686 """
1686 """
1687 self.expr = expr
1687 self.expr = expr
1688 self.globals = globals
1688 self.globals = globals
1689 self.errors = errors
1689 self.errors = errors
1690
1690
1691 def __iter__(self):
1691 def __iter__(self):
1692 if callable(self.expr):
1692 if callable(self.expr):
1693 test = self.expr
1693 test = self.expr
1694 else:
1694 else:
1695 g = getglobals(self.globals)
1695 g = getglobals(self.globals)
1696 expr = compile(self.expr, "ipipe-expression", "eval")
1696 expr = compile(self.expr, "ipipe-expression", "eval")
1697 def test(item):
1697 def test(item):
1698 return eval(expr, g, AttrNamespace(item))
1698 return eval(expr, g, AttrNamespace(item))
1699
1699
1700 ok = 0
1700 ok = 0
1701 exc_info = None
1701 exc_info = None
1702 for item in xiter(self.input):
1702 for item in xiter(self.input):
1703 try:
1703 try:
1704 if test(item):
1704 if test(item):
1705 yield item
1705 yield item
1706 ok += 1
1706 ok += 1
1707 except (KeyboardInterrupt, SystemExit):
1707 except (KeyboardInterrupt, SystemExit):
1708 raise
1708 raise
1709 except Exception, exc:
1709 except Exception, exc:
1710 if self.errors == "drop":
1710 if self.errors == "drop":
1711 pass # Ignore errors
1711 pass # Ignore errors
1712 elif self.errors == "keep":
1712 elif self.errors == "keep":
1713 yield item
1713 yield item
1714 elif self.errors == "keeperror":
1714 elif self.errors == "keeperror":
1715 yield exc
1715 yield exc
1716 elif self.errors == "raise":
1716 elif self.errors == "raise":
1717 raise
1717 raise
1718 elif self.errors == "raiseifallfail":
1718 elif self.errors == "raiseifallfail":
1719 if exc_info is None:
1719 if exc_info is None:
1720 exc_info = sys.exc_info()
1720 exc_info = sys.exc_info()
1721 if not ok and exc_info is not None:
1721 if not ok and exc_info is not None:
1722 raise exc_info[0], exc_info[1], exc_info[2]
1722 raise exc_info[0], exc_info[1], exc_info[2]
1723
1723
1724 def __xrepr__(self, mode="default"):
1724 def __xrepr__(self, mode="default"):
1725 if mode == "header" or mode == "footer":
1725 if mode == "header" or mode == "footer":
1726 input = getattr(self, "input", None)
1726 input = getattr(self, "input", None)
1727 if input is not None:
1727 if input is not None:
1728 for part in xrepr(input, mode):
1728 for part in xrepr(input, mode):
1729 yield part
1729 yield part
1730 yield (astyle.style_default, " | ")
1730 yield (astyle.style_default, " | ")
1731 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1731 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1732 for part in xrepr(self.expr, "default"):
1732 for part in xrepr(self.expr, "default"):
1733 yield part
1733 yield part
1734 yield (astyle.style_default, ")")
1734 yield (astyle.style_default, ")")
1735 else:
1735 else:
1736 yield (astyle.style_default, repr(self))
1736 yield (astyle.style_default, repr(self))
1737
1737
1738 def __repr__(self):
1738 def __repr__(self):
1739 return "<%s.%s expr=%r at 0x%x>" % \
1739 return "<%s.%s expr=%r at 0x%x>" % \
1740 (self.__class__.__module__, self.__class__.__name__,
1740 (self.__class__.__module__, self.__class__.__name__,
1741 self.expr, id(self))
1741 self.expr, id(self))
1742
1742
1743
1743
1744 class ieval(Pipe):
1744 class ieval(Pipe):
1745 """
1745 """
1746 Evaluate an expression for each object in the input pipe.
1746 Evaluate an expression for each object in the input pipe.
1747
1747
1748 Examples:
1748 Examples:
1749
1749
1750 >>> ils | ieval("_.abspath()")
1750 >>> ils | ieval("_.abspath()")
1751 >>> sys.path | ieval(ifile)
1751 >>> sys.path | ieval(ifile)
1752 """
1752 """
1753
1753
1754 def __init__(self, expr, globals=None, errors="raiseifallfail"):
1754 def __init__(self, expr, globals=None, errors="raiseifallfail"):
1755 """
1755 """
1756 Create an ``ieval`` object. ``expr`` can be a callable or a string
1756 Create an ``ieval`` object. ``expr`` can be a callable or a string
1757 containing an expression. For the meaning of ``globals`` and
1757 containing an expression. For the meaning of ``globals`` and
1758 ``errors`` see ``ifilter``.
1758 ``errors`` see ``ifilter``.
1759 """
1759 """
1760 self.expr = expr
1760 self.expr = expr
1761 self.globals = globals
1761 self.globals = globals
1762 self.errors = errors
1762 self.errors = errors
1763
1763
1764 def __iter__(self):
1764 def __iter__(self):
1765 if callable(self.expr):
1765 if callable(self.expr):
1766 do = self.expr
1766 do = self.expr
1767 else:
1767 else:
1768 g = getglobals(self.globals)
1768 g = getglobals(self.globals)
1769 expr = compile(self.expr, "ipipe-expression", "eval")
1769 expr = compile(self.expr, "ipipe-expression", "eval")
1770 def do(item):
1770 def do(item):
1771 return eval(expr, g, AttrNamespace(item))
1771 return eval(expr, g, AttrNamespace(item))
1772
1772
1773 ok = 0
1773 ok = 0
1774 exc_info = None
1774 exc_info = None
1775 for item in xiter(self.input):
1775 for item in xiter(self.input):
1776 try:
1776 try:
1777 yield do(item)
1777 yield do(item)
1778 except (KeyboardInterrupt, SystemExit):
1778 except (KeyboardInterrupt, SystemExit):
1779 raise
1779 raise
1780 except Exception, exc:
1780 except Exception, exc:
1781 if self.errors == "drop":
1781 if self.errors == "drop":
1782 pass # Ignore errors
1782 pass # Ignore errors
1783 elif self.errors == "keep":
1783 elif self.errors == "keep":
1784 yield item
1784 yield item
1785 elif self.errors == "keeperror":
1785 elif self.errors == "keeperror":
1786 yield exc
1786 yield exc
1787 elif self.errors == "raise":
1787 elif self.errors == "raise":
1788 raise
1788 raise
1789 elif self.errors == "raiseifallfail":
1789 elif self.errors == "raiseifallfail":
1790 if exc_info is None:
1790 if exc_info is None:
1791 exc_info = sys.exc_info()
1791 exc_info = sys.exc_info()
1792 if not ok and exc_info is not None:
1792 if not ok and exc_info is not None:
1793 raise exc_info[0], exc_info[1], exc_info[2]
1793 raise exc_info[0], exc_info[1], exc_info[2]
1794
1794
1795 def __xrepr__(self, mode="default"):
1795 def __xrepr__(self, mode="default"):
1796 if mode == "header" or mode == "footer":
1796 if mode == "header" or mode == "footer":
1797 input = getattr(self, "input", None)
1797 input = getattr(self, "input", None)
1798 if input is not None:
1798 if input is not None:
1799 for part in xrepr(input, mode):
1799 for part in xrepr(input, mode):
1800 yield part
1800 yield part
1801 yield (astyle.style_default, " | ")
1801 yield (astyle.style_default, " | ")
1802 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1802 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1803 for part in xrepr(self.expr, "default"):
1803 for part in xrepr(self.expr, "default"):
1804 yield part
1804 yield part
1805 yield (astyle.style_default, ")")
1805 yield (astyle.style_default, ")")
1806 else:
1806 else:
1807 yield (astyle.style_default, repr(self))
1807 yield (astyle.style_default, repr(self))
1808
1808
1809 def __repr__(self):
1809 def __repr__(self):
1810 return "<%s.%s expr=%r at 0x%x>" % \
1810 return "<%s.%s expr=%r at 0x%x>" % \
1811 (self.__class__.__module__, self.__class__.__name__,
1811 (self.__class__.__module__, self.__class__.__name__,
1812 self.expr, id(self))
1812 self.expr, id(self))
1813
1813
1814
1814
1815 class ienum(Pipe):
1815 class ienum(Pipe):
1816 """
1816 """
1817 Enumerate the input pipe (i.e. wrap each input object in an object
1817 Enumerate the input pipe (i.e. wrap each input object in an object
1818 with ``index`` and ``object`` attributes).
1818 with ``index`` and ``object`` attributes).
1819
1819
1820 Examples:
1820 Examples:
1821
1821
1822 >>> xrange(20) | ieval("_,_*_") | ienum | ifilter("index % 2 == 0") | ieval("object")
1822 >>> xrange(20) | ieval("_,_*_") | ienum | ifilter("index % 2 == 0") | ieval("object")
1823 """
1823 """
1824 def __iter__(self):
1824 def __iter__(self):
1825 fields = ("index", "object")
1825 fields = ("index", "object")
1826 for (index, object) in enumerate(xiter(self.input)):
1826 for (index, object) in enumerate(xiter(self.input)):
1827 yield Fields(fields, index=index, object=object)
1827 yield Fields(fields, index=index, object=object)
1828
1828
1829
1829
1830 class isort(Pipe):
1830 class isort(Pipe):
1831 """
1831 """
1832 Sorts the input pipe.
1832 Sorts the input pipe.
1833
1833
1834 Examples:
1834 Examples:
1835
1835
1836 >>> ils | isort("size")
1836 >>> ils | isort("size")
1837 >>> ils | isort("_.isdir(), _.lower()", reverse=True)
1837 >>> ils | isort("_.isdir(), _.lower()", reverse=True)
1838 """
1838 """
1839
1839
1840 def __init__(self, key=None, globals=None, reverse=False):
1840 def __init__(self, key=None, globals=None, reverse=False):
1841 """
1841 """
1842 Create an ``isort`` object. ``key`` can be a callable or a string
1842 Create an ``isort`` object. ``key`` can be a callable or a string
1843 containing an expression (or ``None`` in which case the items
1843 containing an expression (or ``None`` in which case the items
1844 themselves will be sorted). If ``reverse`` is true the sort order
1844 themselves will be sorted). If ``reverse`` is true the sort order
1845 will be reversed. For the meaning of ``globals`` see ``ifilter``.
1845 will be reversed. For the meaning of ``globals`` see ``ifilter``.
1846 """
1846 """
1847 self.key = key
1847 self.key = key
1848 self.globals = globals
1848 self.globals = globals
1849 self.reverse = reverse
1849 self.reverse = reverse
1850
1850
1851 def __iter__(self):
1851 def __iter__(self):
1852 if self.key is None:
1852 if self.key is None:
1853 items = sorted(xiter(self.input), reverse=self.reverse)
1853 items = sorted(xiter(self.input), reverse=self.reverse)
1854 elif callable(self.key):
1854 elif callable(self.key):
1855 items = sorted(xiter(self.input), key=self.key, reverse=self.reverse)
1855 items = sorted(xiter(self.input), key=self.key, reverse=self.reverse)
1856 else:
1856 else:
1857 g = getglobals(self.globals)
1857 g = getglobals(self.globals)
1858 key = compile(self.key, "ipipe-expression", "eval")
1858 key = compile(self.key, "ipipe-expression", "eval")
1859 def realkey(item):
1859 def realkey(item):
1860 return eval(key, g, AttrNamespace(item))
1860 return eval(key, g, AttrNamespace(item))
1861 items = sorted(xiter(self.input), key=realkey, reverse=self.reverse)
1861 items = sorted(xiter(self.input), key=realkey, reverse=self.reverse)
1862 for item in items:
1862 for item in items:
1863 yield item
1863 yield item
1864
1864
1865 def __xrepr__(self, mode="default"):
1865 def __xrepr__(self, mode="default"):
1866 if mode == "header" or mode == "footer":
1866 if mode == "header" or mode == "footer":
1867 input = getattr(self, "input", None)
1867 input = getattr(self, "input", None)
1868 if input is not None:
1868 if input is not None:
1869 for part in xrepr(input, mode):
1869 for part in xrepr(input, mode):
1870 yield part
1870 yield part
1871 yield (astyle.style_default, " | ")
1871 yield (astyle.style_default, " | ")
1872 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1872 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1873 for part in xrepr(self.key, "default"):
1873 for part in xrepr(self.key, "default"):
1874 yield part
1874 yield part
1875 if self.reverse:
1875 if self.reverse:
1876 yield (astyle.style_default, ", ")
1876 yield (astyle.style_default, ", ")
1877 for part in xrepr(True, "default"):
1877 for part in xrepr(True, "default"):
1878 yield part
1878 yield part
1879 yield (astyle.style_default, ")")
1879 yield (astyle.style_default, ")")
1880 else:
1880 else:
1881 yield (astyle.style_default, repr(self))
1881 yield (astyle.style_default, repr(self))
1882
1882
1883 def __repr__(self):
1883 def __repr__(self):
1884 return "<%s.%s key=%r reverse=%r at 0x%x>" % \
1884 return "<%s.%s key=%r reverse=%r at 0x%x>" % \
1885 (self.__class__.__module__, self.__class__.__name__,
1885 (self.__class__.__module__, self.__class__.__name__,
1886 self.key, self.reverse, id(self))
1886 self.key, self.reverse, id(self))
1887
1887
1888
1888
1889 tab = 3 # for expandtabs()
1889 tab = 3 # for expandtabs()
1890
1890
1891 def _format(field):
1891 def _format(field):
1892 if isinstance(field, str):
1892 if isinstance(field, str):
1893 text = repr(field.expandtabs(tab))[1:-1]
1893 text = repr(field.expandtabs(tab))[1:-1]
1894 elif isinstance(field, unicode):
1894 elif isinstance(field, unicode):
1895 text = repr(field.expandtabs(tab))[2:-1]
1895 text = repr(field.expandtabs(tab))[2:-1]
1896 elif isinstance(field, datetime.datetime):
1896 elif isinstance(field, datetime.datetime):
1897 # Don't use strftime() here, as this requires year >= 1900
1897 # Don't use strftime() here, as this requires year >= 1900
1898 text = "%04d-%02d-%02d %02d:%02d:%02d.%06d" % \
1898 text = "%04d-%02d-%02d %02d:%02d:%02d.%06d" % \
1899 (field.year, field.month, field.day,
1899 (field.year, field.month, field.day,
1900 field.hour, field.minute, field.second, field.microsecond)
1900 field.hour, field.minute, field.second, field.microsecond)
1901 elif isinstance(field, datetime.date):
1901 elif isinstance(field, datetime.date):
1902 text = "%04d-%02d-%02d" % (field.year, field.month, field.day)
1902 text = "%04d-%02d-%02d" % (field.year, field.month, field.day)
1903 else:
1903 else:
1904 text = repr(field)
1904 text = repr(field)
1905 return text
1905 return text
1906
1906
1907
1907
1908 class Display(object):
1908 class Display(object):
1909 class __metaclass__(type):
1909 class __metaclass__(type):
1910 def __ror__(self, input):
1910 def __ror__(self, input):
1911 return input | self()
1911 return input | self()
1912
1912
1913 def __ror__(self, input):
1913 def __ror__(self, input):
1914 self.input = input
1914 self.input = input
1915 return self
1915 return self
1916
1916
1917 def display(self):
1917 def display(self):
1918 pass
1918 pass
1919
1919
1920
1920
1921 class iless(Display):
1921 class iless(Display):
1922 cmd = "less --quit-if-one-screen --LONG-PROMPT --LINE-NUMBERS --chop-long-lines --shift=8 --RAW-CONTROL-CHARS"
1922 cmd = "less --quit-if-one-screen --LONG-PROMPT --LINE-NUMBERS --chop-long-lines --shift=8 --RAW-CONTROL-CHARS"
1923
1923
1924 def display(self):
1924 def display(self):
1925 try:
1925 try:
1926 pager = os.popen(self.cmd, "w")
1926 pager = os.popen(self.cmd, "w")
1927 try:
1927 try:
1928 for item in xiter(self.input):
1928 for item in xiter(self.input):
1929 first = False
1929 first = False
1930 for attr in xattrs(item, "default"):
1930 for attr in xattrs(item, "default"):
1931 if first:
1931 if first:
1932 first = False
1932 first = False
1933 else:
1933 else:
1934 pager.write(" ")
1934 pager.write(" ")
1935 attr = upgradexattr(attr)
1935 attr = upgradexattr(attr)
1936 if not isinstance(attr, SelfDescriptor):
1936 if not isinstance(attr, SelfDescriptor):
1937 pager.write(attr.name())
1937 pager.write(attr.name())
1938 pager.write("=")
1938 pager.write("=")
1939 pager.write(str(attr.value(item)))
1939 pager.write(str(attr.value(item)))
1940 pager.write("\n")
1940 pager.write("\n")
1941 finally:
1941 finally:
1942 pager.close()
1942 pager.close()
1943 except Exception, exc:
1943 except Exception, exc:
1944 print "%s: %s" % (exc.__class__.__name__, str(exc))
1944 print "%s: %s" % (exc.__class__.__name__, str(exc))
1945
1945
1946
1946
1947 def xformat(value, mode, maxlength):
1947 def xformat(value, mode, maxlength):
1948 align = None
1948 align = None
1949 full = True
1949 full = True
1950 width = 0
1950 width = 0
1951 text = astyle.Text()
1951 text = astyle.Text()
1952 for (style, part) in xrepr(value, mode):
1952 for (style, part) in xrepr(value, mode):
1953 # only consider the first result
1953 # only consider the first result
1954 if align is None:
1954 if align is None:
1955 if isinstance(style, int):
1955 if isinstance(style, int):
1956 # (style, text) really is (alignment, stop)
1956 # (style, text) really is (alignment, stop)
1957 align = style
1957 align = style
1958 full = part
1958 full = part
1959 continue
1959 continue
1960 else:
1960 else:
1961 align = -1
1961 align = -1
1962 full = True
1962 full = True
1963 if not isinstance(style, int):
1963 if not isinstance(style, int):
1964 text.append((style, part))
1964 text.append((style, part))
1965 width += len(part)
1965 width += len(part)
1966 if width >= maxlength and not full:
1966 if width >= maxlength and not full:
1967 text.append((astyle.style_ellisis, "..."))
1967 text.append((astyle.style_ellisis, "..."))
1968 width += 3
1968 width += 3
1969 break
1969 break
1970 if align is None: # default to left alignment
1970 if align is None: # default to left alignment
1971 align = -1
1971 align = -1
1972 return (align, width, text)
1972 return (align, width, text)
1973
1973
1974
1974
1975 class idump(Display):
1975 class idump(Display):
1976 # The approximate maximum length of a column entry
1976 # The approximate maximum length of a column entry
1977 maxattrlength = 200
1977 maxattrlength = 200
1978
1978
1979 # Style for column names
1979 # Style for column names
1980 style_header = astyle.Style.fromstr("white:black:bold")
1980 style_header = astyle.Style.fromstr("white:black:bold")
1981
1981
1982 def __init__(self, *attrs):
1982 def __init__(self, *attrs):
1983 self.attrs = [upgradexattr(attr) for attr in attrs]
1983 self.attrs = [upgradexattr(attr) for attr in attrs]
1984 self.headerpadchar = " "
1984 self.headerpadchar = " "
1985 self.headersepchar = "|"
1985 self.headersepchar = "|"
1986 self.datapadchar = " "
1986 self.datapadchar = " "
1987 self.datasepchar = "|"
1987 self.datasepchar = "|"
1988
1988
1989 def display(self):
1989 def display(self):
1990 stream = genutils.Term.cout
1990 stream = genutils.Term.cout
1991 allattrs = []
1991 allattrs = []
1992 attrset = set()
1992 attrset = set()
1993 colwidths = {}
1993 colwidths = {}
1994 rows = []
1994 rows = []
1995 for item in xiter(self.input):
1995 for item in xiter(self.input):
1996 row = {}
1996 row = {}
1997 attrs = self.attrs
1997 attrs = self.attrs
1998 if not attrs:
1998 if not attrs:
1999 attrs = xattrs(item, "default")
1999 attrs = xattrs(item, "default")
2000 for attr in attrs:
2000 for attr in attrs:
2001 if attr not in attrset:
2001 if attr not in attrset:
2002 allattrs.append(attr)
2002 allattrs.append(attr)
2003 attrset.add(attr)
2003 attrset.add(attr)
2004 colwidths[attr] = len(attr.name())
2004 colwidths[attr] = len(attr.name())
2005 try:
2005 try:
2006 value = attr.value(item)
2006 value = attr.value(item)
2007 except (KeyboardInterrupt, SystemExit):
2007 except (KeyboardInterrupt, SystemExit):
2008 raise
2008 raise
2009 except Exception, exc:
2009 except Exception, exc:
2010 value = exc
2010 value = exc
2011 (align, width, text) = xformat(value, "cell", self.maxattrlength)
2011 (align, width, text) = xformat(value, "cell", self.maxattrlength)
2012 colwidths[attr] = max(colwidths[attr], width)
2012 colwidths[attr] = max(colwidths[attr], width)
2013 # remember alignment, length and colored parts
2013 # remember alignment, length and colored parts
2014 row[attr] = (align, width, text)
2014 row[attr] = (align, width, text)
2015 rows.append(row)
2015 rows.append(row)
2016
2016
2017 stream.write("\n")
2017 stream.write("\n")
2018 for (i, attr) in enumerate(allattrs):
2018 for (i, attr) in enumerate(allattrs):
2019 attrname = attr.name()
2019 attrname = attr.name()
2020 self.style_header(attrname).write(stream)
2020 self.style_header(attrname).write(stream)
2021 spc = colwidths[attr] - len(attrname)
2021 spc = colwidths[attr] - len(attrname)
2022 if i < len(colwidths)-1:
2022 if i < len(colwidths)-1:
2023 stream.write(self.headerpadchar*spc)
2023 stream.write(self.headerpadchar*spc)
2024 stream.write(self.headersepchar)
2024 stream.write(self.headersepchar)
2025 stream.write("\n")
2025 stream.write("\n")
2026
2026
2027 for row in rows:
2027 for row in rows:
2028 for (i, attr) in enumerate(allattrs):
2028 for (i, attr) in enumerate(allattrs):
2029 (align, width, text) = row[attr]
2029 (align, width, text) = row[attr]
2030 spc = colwidths[attr] - width
2030 spc = colwidths[attr] - width
2031 if align == -1:
2031 if align == -1:
2032 text.write(stream)
2032 text.write(stream)
2033 if i < len(colwidths)-1:
2033 if i < len(colwidths)-1:
2034 stream.write(self.datapadchar*spc)
2034 stream.write(self.datapadchar*spc)
2035 elif align == 0:
2035 elif align == 0:
2036 spc = colwidths[attr] - width
2036 spc = colwidths[attr] - width
2037 spc1 = spc//2
2037 spc1 = spc//2
2038 spc2 = spc-spc1
2038 spc2 = spc-spc1
2039 stream.write(self.datapadchar*spc1)
2039 stream.write(self.datapadchar*spc1)
2040 text.write(stream)
2040 text.write(stream)
2041 if i < len(colwidths)-1:
2041 if i < len(colwidths)-1:
2042 stream.write(self.datapadchar*spc2)
2042 stream.write(self.datapadchar*spc2)
2043 else:
2043 else:
2044 stream.write(self.datapadchar*spc)
2044 stream.write(self.datapadchar*spc)
2045 text.write(stream)
2045 text.write(stream)
2046 if i < len(colwidths)-1:
2046 if i < len(colwidths)-1:
2047 stream.write(self.datasepchar)
2047 stream.write(self.datasepchar)
2048 stream.write("\n")
2048 stream.write("\n")
2049
2049
2050
2050
2051 class AttributeDetail(Table):
2051 class AttributeDetail(Table):
2052 """
2052 """
2053 ``AttributeDetail`` objects are use for displaying a detailed list of object
2053 ``AttributeDetail`` objects are use for displaying a detailed list of object
2054 attributes.
2054 attributes.
2055 """
2055 """
2056 def __init__(self, object, descriptor):
2056 def __init__(self, object, descriptor):
2057 self.object = object
2057 self.object = object
2058 self.descriptor = descriptor
2058 self.descriptor = descriptor
2059
2059
2060 def __iter__(self):
2060 def __iter__(self):
2061 return self.descriptor.iter(self.object)
2061 return self.descriptor.iter(self.object)
2062
2062
2063 def name(self):
2063 def name(self):
2064 return self.descriptor.name()
2064 return self.descriptor.name()
2065
2065
2066 def attrtype(self):
2066 def attrtype(self):
2067 return self.descriptor.attrtype(self.object)
2067 return self.descriptor.attrtype(self.object)
2068
2068
2069 def valuetype(self):
2069 def valuetype(self):
2070 return self.descriptor.valuetype(self.object)
2070 return self.descriptor.valuetype(self.object)
2071
2071
2072 def doc(self):
2072 def doc(self):
2073 return self.descriptor.doc(self.object)
2073 return self.descriptor.doc(self.object)
2074
2074
2075 def shortdoc(self):
2075 def shortdoc(self):
2076 return self.descriptor.shortdoc(self.object)
2076 return self.descriptor.shortdoc(self.object)
2077
2077
2078 def value(self):
2078 def value(self):
2079 return self.descriptor.value(self.object)
2079 return self.descriptor.value(self.object)
2080
2080
2081 def __xattrs__(self, mode="default"):
2081 def __xattrs__(self, mode="default"):
2082 attrs = ("name()", "attrtype()", "valuetype()", "value()", "shortdoc()")
2082 attrs = ("name()", "attrtype()", "valuetype()", "value()", "shortdoc()")
2083 if mode == "detail":
2083 if mode == "detail":
2084 attrs += ("doc()",)
2084 attrs += ("doc()",)
2085 return attrs
2085 return attrs
2086
2086
2087 def __xrepr__(self, mode="default"):
2087 def __xrepr__(self, mode="default"):
2088 yield (-1, True)
2088 yield (-1, True)
2089 valuetype = self.valuetype()
2089 valuetype = self.valuetype()
2090 if valuetype is not noitem:
2090 if valuetype is not noitem:
2091 for part in xrepr(valuetype):
2091 for part in xrepr(valuetype):
2092 yield part
2092 yield part
2093 yield (astyle.style_default, " ")
2093 yield (astyle.style_default, " ")
2094 yield (astyle.style_default, self.attrtype())
2094 yield (astyle.style_default, self.attrtype())
2095 yield (astyle.style_default, " ")
2095 yield (astyle.style_default, " ")
2096 yield (astyle.style_default, self.name())
2096 yield (astyle.style_default, self.name())
2097 yield (astyle.style_default, " of ")
2097 yield (astyle.style_default, " of ")
2098 for part in xrepr(self.object):
2098 for part in xrepr(self.object):
2099 yield part
2099 yield part
2100
2100
2101
2101
2102 try:
2102 try:
2103 from ibrowse import ibrowse
2103 from ibrowse import ibrowse
2104 except ImportError:
2104 except ImportError:
2105 # No curses (probably Windows)
2105 # No curses (probably Windows)
2106 try:
2106 try:
2107 from igrid import igrid
2107 from igrid import igrid
2108 except ImportError:
2108 except ImportError:
2109 # no wx eithevn do => use ``idump`` as the default display.
2109 # no wx eithevn do => use ``idump`` as the default display.
2110 defaultdisplay = idump
2110 defaultdisplay = idump
2111 else:
2111 else:
2112 defaultdisplay = igrid
2112 defaultdisplay = igrid
2113 __all__.append("igrid")
2113 __all__.append("igrid")
2114 else:
2114 else:
2115 defaultdisplay = ibrowse
2115 defaultdisplay = ibrowse
2116 __all__.append("ibrowse")
2116 __all__.append("ibrowse")
2117
2117
2118
2118
2119 # If we're running under IPython, install an IPython displayhook that
2119 # If we're running under IPython, install an IPython displayhook that
2120 # returns the object from Display.display(), else install a displayhook
2120 # returns the object from Display.display(), else install a displayhook
2121 # directly as sys.displayhook
2121 # directly as sys.displayhook
2122 api = None
2122 api = None
2123 if ipapi is not None:
2123 if ipapi is not None:
2124 try:
2124 try:
2125 api = ipapi.get()
2125 api = ipapi.get()
2126 except AttributeError:
2126 except AttributeError:
2127 pass
2127 pass
2128
2128
2129 if api is not None:
2129 if api is not None:
2130 def displayhook(self, obj):
2130 def displayhook(self, obj):
2131 if isinstance(obj, type) and issubclass(obj, Table):
2131 if isinstance(obj, type) and issubclass(obj, Table):
2132 obj = obj()
2132 obj = obj()
2133 if isinstance(obj, Table):
2133 if isinstance(obj, Table):
2134 obj = obj | defaultdisplay
2134 obj = obj | defaultdisplay
2135 if isinstance(obj, Display):
2135 if isinstance(obj, Display):
2136 return obj.display()
2136 return obj.display()
2137 else:
2137 else:
2138 raise ipapi.TryNext
2138 raise ipapi.TryNext
2139 api.set_hook("result_display", displayhook)
2139 api.set_hook("result_display", displayhook)
2140 else:
2140 else:
2141 def installdisplayhook():
2141 def installdisplayhook():
2142 _originalhook = sys.displayhook
2142 _originalhook = sys.displayhook
2143 def displayhook(obj):
2143 def displayhook(obj):
2144 if isinstance(obj, type) and issubclass(obj, Table):
2144 if isinstance(obj, type) and issubclass(obj, Table):
2145 obj = obj()
2145 obj = obj()
2146 if isinstance(obj, Table):
2146 if isinstance(obj, Table):
2147 obj = obj | defaultdisplay
2147 obj = obj | defaultdisplay
2148 if isinstance(obj, Display):
2148 if isinstance(obj, Display):
2149 return obj.display()
2149 return obj.display()
2150 else:
2150 else:
2151 _originalhook(obj)
2151 _originalhook(obj)
2152 sys.displayhook = displayhook
2152 sys.displayhook = displayhook
2153 installdisplayhook()
2153 installdisplayhook()
@@ -1,6682 +1,6687 b''
1 2007-05-17 Walter Doerwald <walter@livinglogic.de>
2
3 * IPython/Extensions/ipipe.py: Fix xrepr for ifiles.
4 (Bug detected by Paul Mueller).
5
1 2007-05-16 Ville Vainio <vivainio@gmail.com>
6 2007-05-16 Ville Vainio <vivainio@gmail.com>
2
7
3 * ipy_profile_sci.py, ipython_win_post_install.py: Create
8 * ipy_profile_sci.py, ipython_win_post_install.py: Create
4 new "sci" profile, effectively a modern version of the old
9 new "sci" profile, effectively a modern version of the old
5 "scipy" profile (which is now slated for deprecation).
10 "scipy" profile (which is now slated for deprecation).
6
11
7 2007-05-15 Ville Vainio <vivainio@gmail.com>
12 2007-05-15 Ville Vainio <vivainio@gmail.com>
8
13
9 * pycolorize.py, pycolor.1: Paul Mueller's patches that
14 * pycolorize.py, pycolor.1: Paul Mueller's patches that
10 make pycolorize read input from stdin when run without arguments.
15 make pycolorize read input from stdin when run without arguments.
11
16
12 * Magic.py: do not require 'PATH' in %rehash/%rehashx. Closes #155
17 * Magic.py: do not require 'PATH' in %rehash/%rehashx. Closes #155
13
18
14 * ipy_rehashdir.py: rename ext_rehashdir to ipy_rehashdir, import
19 * ipy_rehashdir.py: rename ext_rehashdir to ipy_rehashdir, import
15 it in sh profile (instead of ipy_system_conf.py).
20 it in sh profile (instead of ipy_system_conf.py).
16
21
17 * Magic.py, ipy_rehashdir.py, ipy_profile_sh.py: System command
22 * Magic.py, ipy_rehashdir.py, ipy_profile_sh.py: System command
18 aliases are now lower case on windows (MyCommand.exe => mycommand).
23 aliases are now lower case on windows (MyCommand.exe => mycommand).
19
24
20 * macro.py, ipapi.py, iplib.py, Prompts.py: Macro system rehaul.
25 * macro.py, ipapi.py, iplib.py, Prompts.py: Macro system rehaul.
21 Macros are now callable objects that inherit from ipapi.IPyAutocall,
26 Macros are now callable objects that inherit from ipapi.IPyAutocall,
22 i.e. get autocalled regardless of system autocall setting.
27 i.e. get autocalled regardless of system autocall setting.
23
28
24 2007-05-10 Fernando Perez <Fernando.Perez@colorado.edu>
29 2007-05-10 Fernando Perez <Fernando.Perez@colorado.edu>
25
30
26 * IPython/rlineimpl.py: check for clear_history in readline and
31 * IPython/rlineimpl.py: check for clear_history in readline and
27 make it a dummy no-op if not available. This function isn't
32 make it a dummy no-op if not available. This function isn't
28 guaranteed to be in the API and appeared in Python 2.4, so we need
33 guaranteed to be in the API and appeared in Python 2.4, so we need
29 to check it ourselves. Also, clean up this file quite a bit.
34 to check it ourselves. Also, clean up this file quite a bit.
30
35
31 * ipython.1: update man page and full manual with information
36 * ipython.1: update man page and full manual with information
32 about threads (remove outdated warning). Closes #151.
37 about threads (remove outdated warning). Closes #151.
33
38
34 2007-05-09 Fernando Perez <Fernando.Perez@colorado.edu>
39 2007-05-09 Fernando Perez <Fernando.Perez@colorado.edu>
35
40
36 * IPython/Extensions/ipy_constants.py: Add Gael's constants module
41 * IPython/Extensions/ipy_constants.py: Add Gael's constants module
37 in trunk (note that this made it into the 0.8.1 release already,
42 in trunk (note that this made it into the 0.8.1 release already,
38 but the changelogs didn't get coordinated). Many thanks to Gael
43 but the changelogs didn't get coordinated). Many thanks to Gael
39 Varoquaux <gael.varoquaux-AT-normalesup.org>
44 Varoquaux <gael.varoquaux-AT-normalesup.org>
40
45
41 2007-05-09 *** Released version 0.8.1
46 2007-05-09 *** Released version 0.8.1
42
47
43 2007-05-10 Walter Doerwald <walter@livinglogic.de>
48 2007-05-10 Walter Doerwald <walter@livinglogic.de>
44
49
45 * IPython/Extensions/igrid.py: Incorporate html help into
50 * IPython/Extensions/igrid.py: Incorporate html help into
46 the module, so we don't have to search for the file.
51 the module, so we don't have to search for the file.
47
52
48 2007-05-02 Fernando Perez <Fernando.Perez@colorado.edu>
53 2007-05-02 Fernando Perez <Fernando.Perez@colorado.edu>
49
54
50 * test/test_irunner.py (RunnerTestCase._test_runner): Close #147.
55 * test/test_irunner.py (RunnerTestCase._test_runner): Close #147.
51
56
52 2007-04-30 Ville Vainio <vivainio@gmail.com>
57 2007-04-30 Ville Vainio <vivainio@gmail.com>
53
58
54 * iplib.py: (pre_config_initialization) Catch UnicodeDecodeError if the
59 * iplib.py: (pre_config_initialization) Catch UnicodeDecodeError if the
55 user has illegal (non-ascii) home directory name
60 user has illegal (non-ascii) home directory name
56
61
57 2007-04-27 Ville Vainio <vivainio@gmail.com>
62 2007-04-27 Ville Vainio <vivainio@gmail.com>
58
63
59 * platutils_win32.py: implement set_term_title for windows
64 * platutils_win32.py: implement set_term_title for windows
60
65
61 * Update version number
66 * Update version number
62
67
63 * ipy_profile_sh.py: more informative prompt (2 dir levels)
68 * ipy_profile_sh.py: more informative prompt (2 dir levels)
64
69
65 2007-04-26 Walter Doerwald <walter@livinglogic.de>
70 2007-04-26 Walter Doerwald <walter@livinglogic.de>
66
71
67 * IPython/Extensions/igrid.py: (igrid) Fix bug that surfaced
72 * IPython/Extensions/igrid.py: (igrid) Fix bug that surfaced
68 when the igrid input raised an exception. (Patch by Nik Tautenhahn,
73 when the igrid input raised an exception. (Patch by Nik Tautenhahn,
69 bug discovered by Ville).
74 bug discovered by Ville).
70
75
71 2007-04-26 Ville Vainio <vivainio@gmail.com>
76 2007-04-26 Ville Vainio <vivainio@gmail.com>
72
77
73 * Extensions/ipy_completers.py: Olivier's module completer now
78 * Extensions/ipy_completers.py: Olivier's module completer now
74 saves the list of root modules if it takes > 4 secs on the first run.
79 saves the list of root modules if it takes > 4 secs on the first run.
75
80
76 * Magic.py (%rehashx): %rehashx now clears the completer cache
81 * Magic.py (%rehashx): %rehashx now clears the completer cache
77
82
78
83
79 2007-04-26 Fernando Perez <Fernando.Perez@colorado.edu>
84 2007-04-26 Fernando Perez <Fernando.Perez@colorado.edu>
80
85
81 * ipython.el: fix incorrect color scheme, reported by Stefan.
86 * ipython.el: fix incorrect color scheme, reported by Stefan.
82 Closes #149.
87 Closes #149.
83
88
84 * IPython/PyColorize.py (Parser.format2): fix state-handling
89 * IPython/PyColorize.py (Parser.format2): fix state-handling
85 logic. I still don't like how that code handles state, but at
90 logic. I still don't like how that code handles state, but at
86 least now it should be correct, if inelegant. Closes #146.
91 least now it should be correct, if inelegant. Closes #146.
87
92
88 2007-04-25 Ville Vainio <vivainio@gmail.com>
93 2007-04-25 Ville Vainio <vivainio@gmail.com>
89
94
90 * Extensions/ipy_which.py: added extension for %which magic, works
95 * Extensions/ipy_which.py: added extension for %which magic, works
91 a lot like unix 'which' but also finds and expands aliases, and
96 a lot like unix 'which' but also finds and expands aliases, and
92 allows wildcards.
97 allows wildcards.
93
98
94 * ipapi.py (expand_alias): Now actually *return* the expanded alias,
99 * ipapi.py (expand_alias): Now actually *return* the expanded alias,
95 as opposed to returning nothing.
100 as opposed to returning nothing.
96
101
97 * UserConfig/ipy_user_conf.py, ipy_profile_sh.py: do not import
102 * UserConfig/ipy_user_conf.py, ipy_profile_sh.py: do not import
98 ipy_stock_completers on default profile, do import on sh profile.
103 ipy_stock_completers on default profile, do import on sh profile.
99
104
100 2007-04-22 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
105 2007-04-22 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
101
106
102 * Fix bug in iplib.py/safe_execfile when launching ipython with a script
107 * Fix bug in iplib.py/safe_execfile when launching ipython with a script
103 like ipython.py foo.py which raised a IndexError.
108 like ipython.py foo.py which raised a IndexError.
104
109
105 2007-04-21 Ville Vainio <vivainio@gmail.com>
110 2007-04-21 Ville Vainio <vivainio@gmail.com>
106
111
107 * Extensions/ipy_extutil.py: added extension to manage other ipython
112 * Extensions/ipy_extutil.py: added extension to manage other ipython
108 extensions. Now only supports 'ls' == list extensions.
113 extensions. Now only supports 'ls' == list extensions.
109
114
110 2007-04-20 Fernando Perez <Fernando.Perez@colorado.edu>
115 2007-04-20 Fernando Perez <Fernando.Perez@colorado.edu>
111
116
112 * IPython/Debugger.py (BdbQuit_excepthook): fix small bug that
117 * IPython/Debugger.py (BdbQuit_excepthook): fix small bug that
113 would prevent use of the exception system outside of a running
118 would prevent use of the exception system outside of a running
114 IPython instance.
119 IPython instance.
115
120
116 2007-04-20 Ville Vainio <vivainio@gmail.com>
121 2007-04-20 Ville Vainio <vivainio@gmail.com>
117
122
118 * Extensions/ipy_render.py: added extension for easy
123 * Extensions/ipy_render.py: added extension for easy
119 interactive text template rendering (to clipboard). Uses Ka-Ping Yee's
124 interactive text template rendering (to clipboard). Uses Ka-Ping Yee's
120 'Iptl' template notation,
125 'Iptl' template notation,
121
126
122 * Extensions/ipy_completers.py: introduced Olivier Lauzanne's
127 * Extensions/ipy_completers.py: introduced Olivier Lauzanne's
123 safer & faster 'import' completer.
128 safer & faster 'import' completer.
124
129
125 * ipapi.py: Introduced new ipapi methods, _ip.defmacro(name, value)
130 * ipapi.py: Introduced new ipapi methods, _ip.defmacro(name, value)
126 and _ip.defalias(name, command).
131 and _ip.defalias(name, command).
127
132
128 * Extensions/ipy_exportdb.py: New extension for exporting all the
133 * Extensions/ipy_exportdb.py: New extension for exporting all the
129 %store'd data in a portable format (normal ipapi calls like
134 %store'd data in a portable format (normal ipapi calls like
130 defmacro() etc.)
135 defmacro() etc.)
131
136
132 2007-04-19 Ville Vainio <vivainio@gmail.com>
137 2007-04-19 Ville Vainio <vivainio@gmail.com>
133
138
134 * upgrade_dir.py: skip junk files like *.pyc
139 * upgrade_dir.py: skip junk files like *.pyc
135
140
136 * Release.py: version number to 0.8.1
141 * Release.py: version number to 0.8.1
137
142
138 2007-04-18 Ville Vainio <vivainio@gmail.com>
143 2007-04-18 Ville Vainio <vivainio@gmail.com>
139
144
140 * iplib.py (safe_execfile): make "ipython foo.py" work with 2.5.1c1
145 * iplib.py (safe_execfile): make "ipython foo.py" work with 2.5.1c1
141 and later on win32.
146 and later on win32.
142
147
143 2007-04-16 Ville Vainio <vivainio@gmail.com>
148 2007-04-16 Ville Vainio <vivainio@gmail.com>
144
149
145 * iplib.py (showtraceback): Do not crash when running w/o readline.
150 * iplib.py (showtraceback): Do not crash when running w/o readline.
146
151
147 2007-04-12 Walter Doerwald <walter@livinglogic.de>
152 2007-04-12 Walter Doerwald <walter@livinglogic.de>
148
153
149 * IPython/Extensions/ipipe.py: (ils) Directoy listings are now
154 * IPython/Extensions/ipipe.py: (ils) Directoy listings are now
150 sorted (case sensitive with files and dirs mixed).
155 sorted (case sensitive with files and dirs mixed).
151
156
152 2007-04-10 Fernando Perez <Fernando.Perez@colorado.edu>
157 2007-04-10 Fernando Perez <Fernando.Perez@colorado.edu>
153
158
154 * IPython/Release.py (version): Open trunk for 0.8.1 development.
159 * IPython/Release.py (version): Open trunk for 0.8.1 development.
155
160
156 2007-04-10 *** Released version 0.8.0
161 2007-04-10 *** Released version 0.8.0
157
162
158 2007-04-07 Fernando Perez <Fernando.Perez@colorado.edu>
163 2007-04-07 Fernando Perez <Fernando.Perez@colorado.edu>
159
164
160 * Tag 0.8.0 for release.
165 * Tag 0.8.0 for release.
161
166
162 * IPython/iplib.py (reloadhist): add API function to cleanly
167 * IPython/iplib.py (reloadhist): add API function to cleanly
163 reload the readline history, which was growing inappropriately on
168 reload the readline history, which was growing inappropriately on
164 every %run call.
169 every %run call.
165
170
166 * win32_manual_post_install.py (run): apply last part of Nicolas
171 * win32_manual_post_install.py (run): apply last part of Nicolas
167 Pernetty's patch (I'd accidentally applied it in a different
172 Pernetty's patch (I'd accidentally applied it in a different
168 directory and this particular file didn't get patched).
173 directory and this particular file didn't get patched).
169
174
170 2007-04-05 Fernando Perez <Fernando.Perez@colorado.edu>
175 2007-04-05 Fernando Perez <Fernando.Perez@colorado.edu>
171
176
172 * IPython/Shell.py (MAIN_THREAD_ID): get rid of my stupid hack to
177 * IPython/Shell.py (MAIN_THREAD_ID): get rid of my stupid hack to
173 find the main thread id and use the proper API call. Thanks to
178 find the main thread id and use the proper API call. Thanks to
174 Stefan for the fix.
179 Stefan for the fix.
175
180
176 * test/test_prefilter.py (esc_handler_tests): udpate one of Dan's
181 * test/test_prefilter.py (esc_handler_tests): udpate one of Dan's
177 unit tests to reflect fixed ticket #52, and add more tests sent by
182 unit tests to reflect fixed ticket #52, and add more tests sent by
178 him.
183 him.
179
184
180 * IPython/iplib.py (raw_input): restore the readline completer
185 * IPython/iplib.py (raw_input): restore the readline completer
181 state on every input, in case third-party code messed it up.
186 state on every input, in case third-party code messed it up.
182 (_prefilter): revert recent addition of early-escape checks which
187 (_prefilter): revert recent addition of early-escape checks which
183 prevent many valid alias calls from working.
188 prevent many valid alias calls from working.
184
189
185 * IPython/Shell.py (MTInteractiveShell.runcode): add a tracking
190 * IPython/Shell.py (MTInteractiveShell.runcode): add a tracking
186 flag for sigint handler so we don't run a full signal() call on
191 flag for sigint handler so we don't run a full signal() call on
187 each runcode access.
192 each runcode access.
188
193
189 * IPython/Magic.py (magic_whos): small improvement to diagnostic
194 * IPython/Magic.py (magic_whos): small improvement to diagnostic
190 message.
195 message.
191
196
192 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
197 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
193
198
194 * IPython/Shell.py (sigint_handler): I *THINK* I finally got
199 * IPython/Shell.py (sigint_handler): I *THINK* I finally got
195 asynchronous exceptions working, i.e., Ctrl-C can actually
200 asynchronous exceptions working, i.e., Ctrl-C can actually
196 interrupt long-running code in the multithreaded shells.
201 interrupt long-running code in the multithreaded shells.
197
202
198 This is using Tomer Filiba's great ctypes-based trick:
203 This is using Tomer Filiba's great ctypes-based trick:
199 http://sebulba.wikispaces.com/recipe+thread2. I'd already tried
204 http://sebulba.wikispaces.com/recipe+thread2. I'd already tried
200 this in the past, but hadn't been able to make it work before. So
205 this in the past, but hadn't been able to make it work before. So
201 far it looks like it's actually running, but this needs more
206 far it looks like it's actually running, but this needs more
202 testing. If it really works, I'll be *very* happy, and we'll owe
207 testing. If it really works, I'll be *very* happy, and we'll owe
203 a huge thank you to Tomer. My current implementation is ugly,
208 a huge thank you to Tomer. My current implementation is ugly,
204 hackish and uses nasty globals, but I don't want to try and clean
209 hackish and uses nasty globals, but I don't want to try and clean
205 anything up until we know if it actually works.
210 anything up until we know if it actually works.
206
211
207 NOTE: this feature needs ctypes to work. ctypes is included in
212 NOTE: this feature needs ctypes to work. ctypes is included in
208 Python2.5, but 2.4 users will need to manually install it. This
213 Python2.5, but 2.4 users will need to manually install it. This
209 feature makes multi-threaded shells so much more usable that it's
214 feature makes multi-threaded shells so much more usable that it's
210 a minor price to pay (ctypes is very easy to install, already a
215 a minor price to pay (ctypes is very easy to install, already a
211 requirement for win32 and available in major linux distros).
216 requirement for win32 and available in major linux distros).
212
217
213 2007-04-04 Ville Vainio <vivainio@gmail.com>
218 2007-04-04 Ville Vainio <vivainio@gmail.com>
214
219
215 * Extensions/ipy_completers.py, ipy_stock_completers.py:
220 * Extensions/ipy_completers.py, ipy_stock_completers.py:
216 Moved implementations of 'bundled' completers to ipy_completers.py,
221 Moved implementations of 'bundled' completers to ipy_completers.py,
217 they are only enabled in ipy_stock_completers.py.
222 they are only enabled in ipy_stock_completers.py.
218
223
219 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
224 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
220
225
221 * IPython/PyColorize.py (Parser.format2): Fix identation of
226 * IPython/PyColorize.py (Parser.format2): Fix identation of
222 colorzied output and return early if color scheme is NoColor, to
227 colorzied output and return early if color scheme is NoColor, to
223 avoid unnecessary and expensive tokenization. Closes #131.
228 avoid unnecessary and expensive tokenization. Closes #131.
224
229
225 2007-04-03 Fernando Perez <Fernando.Perez@colorado.edu>
230 2007-04-03 Fernando Perez <Fernando.Perez@colorado.edu>
226
231
227 * IPython/Debugger.py: disable the use of pydb version 1.17. It
232 * IPython/Debugger.py: disable the use of pydb version 1.17. It
228 has a critical bug (a missing import that makes post-mortem not
233 has a critical bug (a missing import that makes post-mortem not
229 work at all). Unfortunately as of this time, this is the version
234 work at all). Unfortunately as of this time, this is the version
230 shipped with Ubuntu Edgy, so quite a few people have this one. I
235 shipped with Ubuntu Edgy, so quite a few people have this one. I
231 hope Edgy will update to a more recent package.
236 hope Edgy will update to a more recent package.
232
237
233 2007-04-02 Fernando Perez <Fernando.Perez@colorado.edu>
238 2007-04-02 Fernando Perez <Fernando.Perez@colorado.edu>
234
239
235 * IPython/iplib.py (_prefilter): close #52, second part of a patch
240 * IPython/iplib.py (_prefilter): close #52, second part of a patch
236 set by Stefan (only the first part had been applied before).
241 set by Stefan (only the first part had been applied before).
237
242
238 * IPython/Extensions/ipy_stock_completers.py (module_completer):
243 * IPython/Extensions/ipy_stock_completers.py (module_completer):
239 remove usage of the dangerous pkgutil.walk_packages(). See
244 remove usage of the dangerous pkgutil.walk_packages(). See
240 details in comments left in the code.
245 details in comments left in the code.
241
246
242 * IPython/Magic.py (magic_whos): add support for numpy arrays
247 * IPython/Magic.py (magic_whos): add support for numpy arrays
243 similar to what we had for Numeric.
248 similar to what we had for Numeric.
244
249
245 * IPython/completer.py (IPCompleter.complete): extend the
250 * IPython/completer.py (IPCompleter.complete): extend the
246 complete() call API to support completions by other mechanisms
251 complete() call API to support completions by other mechanisms
247 than readline. Closes #109.
252 than readline. Closes #109.
248
253
249 * IPython/iplib.py (safe_execfile): add a safeguard under Win32 to
254 * IPython/iplib.py (safe_execfile): add a safeguard under Win32 to
250 protect against a bug in Python's execfile(). Closes #123.
255 protect against a bug in Python's execfile(). Closes #123.
251
256
252 2007-04-01 Fernando Perez <Fernando.Perez@colorado.edu>
257 2007-04-01 Fernando Perez <Fernando.Perez@colorado.edu>
253
258
254 * IPython/iplib.py (split_user_input): ensure that when splitting
259 * IPython/iplib.py (split_user_input): ensure that when splitting
255 user input, the part that can be treated as a python name is pure
260 user input, the part that can be treated as a python name is pure
256 ascii (Python identifiers MUST be pure ascii). Part of the
261 ascii (Python identifiers MUST be pure ascii). Part of the
257 ongoing Unicode support work.
262 ongoing Unicode support work.
258
263
259 * IPython/Prompts.py (prompt_specials_color): Add \N for the
264 * IPython/Prompts.py (prompt_specials_color): Add \N for the
260 actual prompt number, without any coloring. This allows users to
265 actual prompt number, without any coloring. This allows users to
261 produce numbered prompts with their own colors. Added after a
266 produce numbered prompts with their own colors. Added after a
262 report/request by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
267 report/request by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
263
268
264 2007-03-31 Walter Doerwald <walter@livinglogic.de>
269 2007-03-31 Walter Doerwald <walter@livinglogic.de>
265
270
266 * IPython/Extensions/igrid.py: Map the return key
271 * IPython/Extensions/igrid.py: Map the return key
267 to enter() and shift-return to enterattr().
272 to enter() and shift-return to enterattr().
268
273
269 2007-03-30 Fernando Perez <Fernando.Perez@colorado.edu>
274 2007-03-30 Fernando Perez <Fernando.Perez@colorado.edu>
270
275
271 * IPython/Magic.py (magic_psearch): add unicode support by
276 * IPython/Magic.py (magic_psearch): add unicode support by
272 encoding to ascii the input, since this routine also only deals
277 encoding to ascii the input, since this routine also only deals
273 with valid Python names. Fixes a bug reported by Stefan.
278 with valid Python names. Fixes a bug reported by Stefan.
274
279
275 2007-03-29 Fernando Perez <Fernando.Perez@colorado.edu>
280 2007-03-29 Fernando Perez <Fernando.Perez@colorado.edu>
276
281
277 * IPython/Magic.py (_inspect): convert unicode input into ascii
282 * IPython/Magic.py (_inspect): convert unicode input into ascii
278 before trying to evaluate it as a Python identifier. This fixes a
283 before trying to evaluate it as a Python identifier. This fixes a
279 problem that the new unicode support had introduced when analyzing
284 problem that the new unicode support had introduced when analyzing
280 long definition lines for functions.
285 long definition lines for functions.
281
286
282 2007-03-24 Walter Doerwald <walter@livinglogic.de>
287 2007-03-24 Walter Doerwald <walter@livinglogic.de>
283
288
284 * IPython/Extensions/igrid.py: Fix picking. Using
289 * IPython/Extensions/igrid.py: Fix picking. Using
285 igrid with wxPython 2.6 and -wthread should work now.
290 igrid with wxPython 2.6 and -wthread should work now.
286 igrid.display() simply tries to create a frame without
291 igrid.display() simply tries to create a frame without
287 an application. Only if this fails an application is created.
292 an application. Only if this fails an application is created.
288
293
289 2007-03-23 Walter Doerwald <walter@livinglogic.de>
294 2007-03-23 Walter Doerwald <walter@livinglogic.de>
290
295
291 * IPython/Extensions/path.py: Updated to version 2.2.
296 * IPython/Extensions/path.py: Updated to version 2.2.
292
297
293 2007-03-23 Ville Vainio <vivainio@gmail.com>
298 2007-03-23 Ville Vainio <vivainio@gmail.com>
294
299
295 * iplib.py: recursive alias expansion now works better, so that
300 * iplib.py: recursive alias expansion now works better, so that
296 cases like 'top' -> 'd:/cygwin/top' -> 'ls :/cygwin/top'
301 cases like 'top' -> 'd:/cygwin/top' -> 'ls :/cygwin/top'
297 doesn't trip up the process, if 'd' has been aliased to 'ls'.
302 doesn't trip up the process, if 'd' has been aliased to 'ls'.
298
303
299 * Extensions/ipy_gnuglobal.py added, provides %global magic
304 * Extensions/ipy_gnuglobal.py added, provides %global magic
300 for users of http://www.gnu.org/software/global
305 for users of http://www.gnu.org/software/global
301
306
302 * iplib.py: '!command /?' now doesn't invoke IPython's help system.
307 * iplib.py: '!command /?' now doesn't invoke IPython's help system.
303 Closes #52. Patch by Stefan van der Walt.
308 Closes #52. Patch by Stefan van der Walt.
304
309
305 2007-03-23 Fernando Perez <Fernando.Perez@colorado.edu>
310 2007-03-23 Fernando Perez <Fernando.Perez@colorado.edu>
306
311
307 * IPython/FakeModule.py (FakeModule.__init__): Small fix to
312 * IPython/FakeModule.py (FakeModule.__init__): Small fix to
308 respect the __file__ attribute when using %run. Thanks to a bug
313 respect the __file__ attribute when using %run. Thanks to a bug
309 report by Sebastian Rooks <sebastian.rooks-AT-free.fr>.
314 report by Sebastian Rooks <sebastian.rooks-AT-free.fr>.
310
315
311 2007-03-22 Fernando Perez <Fernando.Perez@colorado.edu>
316 2007-03-22 Fernando Perez <Fernando.Perez@colorado.edu>
312
317
313 * IPython/iplib.py (raw_input): Fix mishandling of unicode at
318 * IPython/iplib.py (raw_input): Fix mishandling of unicode at
314 input. Patch sent by Stefan.
319 input. Patch sent by Stefan.
315
320
316 2007-03-20 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
321 2007-03-20 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
317 * IPython/Extensions/ipy_stock_completer.py
322 * IPython/Extensions/ipy_stock_completer.py
318 shlex_split, fix bug in shlex_split. len function
323 shlex_split, fix bug in shlex_split. len function
319 call was missing an if statement. Caused shlex_split to
324 call was missing an if statement. Caused shlex_split to
320 sometimes return "" as last element.
325 sometimes return "" as last element.
321
326
322 2007-03-18 Fernando Perez <Fernando.Perez@colorado.edu>
327 2007-03-18 Fernando Perez <Fernando.Perez@colorado.edu>
323
328
324 * IPython/completer.py
329 * IPython/completer.py
325 (IPCompleter.file_matches.single_dir_expand): fix a problem
330 (IPCompleter.file_matches.single_dir_expand): fix a problem
326 reported by Stefan, where directories containign a single subdir
331 reported by Stefan, where directories containign a single subdir
327 would be completed too early.
332 would be completed too early.
328
333
329 * IPython/Shell.py (_load_pylab): Make the execution of 'from
334 * IPython/Shell.py (_load_pylab): Make the execution of 'from
330 pylab import *' when -pylab is given be optional. A new flag,
335 pylab import *' when -pylab is given be optional. A new flag,
331 pylab_import_all controls this behavior, the default is True for
336 pylab_import_all controls this behavior, the default is True for
332 backwards compatibility.
337 backwards compatibility.
333
338
334 * IPython/ultraTB.py (_formatTracebackLines): Added (slightly
339 * IPython/ultraTB.py (_formatTracebackLines): Added (slightly
335 modified) R. Bernstein's patch for fully syntax highlighted
340 modified) R. Bernstein's patch for fully syntax highlighted
336 tracebacks. The functionality is also available under ultraTB for
341 tracebacks. The functionality is also available under ultraTB for
337 non-ipython users (someone using ultraTB but outside an ipython
342 non-ipython users (someone using ultraTB but outside an ipython
338 session). They can select the color scheme by setting the
343 session). They can select the color scheme by setting the
339 module-level global DEFAULT_SCHEME. The highlight functionality
344 module-level global DEFAULT_SCHEME. The highlight functionality
340 also works when debugging.
345 also works when debugging.
341
346
342 * IPython/genutils.py (IOStream.close): small patch by
347 * IPython/genutils.py (IOStream.close): small patch by
343 R. Bernstein for improved pydb support.
348 R. Bernstein for improved pydb support.
344
349
345 * IPython/Debugger.py (Pdb.format_stack_entry): Added patch by
350 * IPython/Debugger.py (Pdb.format_stack_entry): Added patch by
346 DaveS <davls@telus.net> to improve support of debugging under
351 DaveS <davls@telus.net> to improve support of debugging under
347 NTEmacs, including improved pydb behavior.
352 NTEmacs, including improved pydb behavior.
348
353
349 * IPython/Magic.py (magic_prun): Fix saving of profile info for
354 * IPython/Magic.py (magic_prun): Fix saving of profile info for
350 Python 2.5, where the stats object API changed a little. Thanks
355 Python 2.5, where the stats object API changed a little. Thanks
351 to a bug report by Paul Smith <paul.smith-AT-catugmt.com>.
356 to a bug report by Paul Smith <paul.smith-AT-catugmt.com>.
352
357
353 * IPython/ColorANSI.py (InputTermColors.Normal): applied Nicolas
358 * IPython/ColorANSI.py (InputTermColors.Normal): applied Nicolas
354 Pernetty's patch to improve support for (X)Emacs under Win32.
359 Pernetty's patch to improve support for (X)Emacs under Win32.
355
360
356 2007-03-17 Fernando Perez <Fernando.Perez@colorado.edu>
361 2007-03-17 Fernando Perez <Fernando.Perez@colorado.edu>
357
362
358 * IPython/Shell.py (hijack_wx): ipmort WX with current semantics
363 * IPython/Shell.py (hijack_wx): ipmort WX with current semantics
359 to quiet a deprecation warning that fires with Wx 2.8. Thanks to
364 to quiet a deprecation warning that fires with Wx 2.8. Thanks to
360 a report by Nik Tautenhahn.
365 a report by Nik Tautenhahn.
361
366
362 2007-03-16 Walter Doerwald <walter@livinglogic.de>
367 2007-03-16 Walter Doerwald <walter@livinglogic.de>
363
368
364 * setup.py: Add the igrid help files to the list of data files
369 * setup.py: Add the igrid help files to the list of data files
365 to be installed alongside igrid.
370 to be installed alongside igrid.
366 * IPython/Extensions/igrid.py: (Patch by Nik Tautenhahn)
371 * IPython/Extensions/igrid.py: (Patch by Nik Tautenhahn)
367 Show the input object of the igrid browser as the window tile.
372 Show the input object of the igrid browser as the window tile.
368 Show the object the cursor is on in the statusbar.
373 Show the object the cursor is on in the statusbar.
369
374
370 2007-03-15 Ville Vainio <vivainio@gmail.com>
375 2007-03-15 Ville Vainio <vivainio@gmail.com>
371
376
372 * Extensions/ipy_stock_completers.py: Fixed exception
377 * Extensions/ipy_stock_completers.py: Fixed exception
373 on mismatching quotes in %run completer. Patch by
378 on mismatching quotes in %run completer. Patch by
374 JοΏ½rgen Stenarson. Closes #127.
379 JοΏ½rgen Stenarson. Closes #127.
375
380
376 2007-03-14 Ville Vainio <vivainio@gmail.com>
381 2007-03-14 Ville Vainio <vivainio@gmail.com>
377
382
378 * Extensions/ext_rehashdir.py: Do not do auto_alias
383 * Extensions/ext_rehashdir.py: Do not do auto_alias
379 in %rehashdir, it clobbers %store'd aliases.
384 in %rehashdir, it clobbers %store'd aliases.
380
385
381 * UserConfig/ipy_profile_sh.py: envpersist.py extension
386 * UserConfig/ipy_profile_sh.py: envpersist.py extension
382 (beefed up %env) imported for sh profile.
387 (beefed up %env) imported for sh profile.
383
388
384 2007-03-10 Walter Doerwald <walter@livinglogic.de>
389 2007-03-10 Walter Doerwald <walter@livinglogic.de>
385
390
386 * IPython/Extensions/ipipe.py: Prefer ibrowse over igrid
391 * IPython/Extensions/ipipe.py: Prefer ibrowse over igrid
387 as the default browser.
392 as the default browser.
388 * IPython/Extensions/igrid.py: Make a few igrid attributes private.
393 * IPython/Extensions/igrid.py: Make a few igrid attributes private.
389 As igrid displays all attributes it ever encounters, fetch() (which has
394 As igrid displays all attributes it ever encounters, fetch() (which has
390 been renamed to _fetch()) doesn't have to recalculate the display attributes
395 been renamed to _fetch()) doesn't have to recalculate the display attributes
391 every time a new item is fetched. This should speed up scrolling.
396 every time a new item is fetched. This should speed up scrolling.
392
397
393 2007-03-10 Fernando Perez <Fernando.Perez@colorado.edu>
398 2007-03-10 Fernando Perez <Fernando.Perez@colorado.edu>
394
399
395 * IPython/iplib.py (InteractiveShell.__init__): fix for Alex
400 * IPython/iplib.py (InteractiveShell.__init__): fix for Alex
396 Schmolck's recently reported tab-completion bug (my previous one
401 Schmolck's recently reported tab-completion bug (my previous one
397 had a problem). Patch by Dan Milstein <danmil-AT-comcast.net>.
402 had a problem). Patch by Dan Milstein <danmil-AT-comcast.net>.
398
403
399 2007-03-09 Walter Doerwald <walter@livinglogic.de>
404 2007-03-09 Walter Doerwald <walter@livinglogic.de>
400
405
401 * IPython/Extensions/igrid.py: Patch by Nik Tautenhahn:
406 * IPython/Extensions/igrid.py: Patch by Nik Tautenhahn:
402 Close help window if exiting igrid.
407 Close help window if exiting igrid.
403
408
404 2007-03-02 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
409 2007-03-02 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
405
410
406 * IPython/Extensions/ipy_defaults.py: Check if readline is available
411 * IPython/Extensions/ipy_defaults.py: Check if readline is available
407 before calling functions from readline.
412 before calling functions from readline.
408
413
409 2007-03-02 Walter Doerwald <walter@livinglogic.de>
414 2007-03-02 Walter Doerwald <walter@livinglogic.de>
410
415
411 * IPython/Extensions/igrid.py: Add Nik Tautenhahns igrid extension.
416 * IPython/Extensions/igrid.py: Add Nik Tautenhahns igrid extension.
412 igrid is a wxPython-based display object for ipipe. If your system has
417 igrid is a wxPython-based display object for ipipe. If your system has
413 wx installed igrid will be the default display. Without wx ipipe falls
418 wx installed igrid will be the default display. Without wx ipipe falls
414 back to ibrowse (which needs curses). If no curses is installed ipipe
419 back to ibrowse (which needs curses). If no curses is installed ipipe
415 falls back to idump.
420 falls back to idump.
416
421
417 2007-03-01 Fernando Perez <Fernando.Perez@colorado.edu>
422 2007-03-01 Fernando Perez <Fernando.Perez@colorado.edu>
418
423
419 * IPython/iplib.py (split_user_inputBROKEN): temporarily disable
424 * IPython/iplib.py (split_user_inputBROKEN): temporarily disable
420 my changes from yesterday, they introduced bugs. Will reactivate
425 my changes from yesterday, they introduced bugs. Will reactivate
421 once I get a correct solution, which will be much easier thanks to
426 once I get a correct solution, which will be much easier thanks to
422 Dan Milstein's new prefilter test suite.
427 Dan Milstein's new prefilter test suite.
423
428
424 2007-02-28 Fernando Perez <Fernando.Perez@colorado.edu>
429 2007-02-28 Fernando Perez <Fernando.Perez@colorado.edu>
425
430
426 * IPython/iplib.py (split_user_input): fix input splitting so we
431 * IPython/iplib.py (split_user_input): fix input splitting so we
427 don't attempt attribute accesses on things that can't possibly be
432 don't attempt attribute accesses on things that can't possibly be
428 valid Python attributes. After a bug report by Alex Schmolck.
433 valid Python attributes. After a bug report by Alex Schmolck.
429 (InteractiveShell.__init__): brown-paper bag fix; regexp broke
434 (InteractiveShell.__init__): brown-paper bag fix; regexp broke
430 %magic with explicit % prefix.
435 %magic with explicit % prefix.
431
436
432 2007-02-27 Fernando Perez <Fernando.Perez@colorado.edu>
437 2007-02-27 Fernando Perez <Fernando.Perez@colorado.edu>
433
438
434 * IPython/Shell.py (IPShellGTK.mainloop): update threads calls to
439 * IPython/Shell.py (IPShellGTK.mainloop): update threads calls to
435 avoid a DeprecationWarning from GTK.
440 avoid a DeprecationWarning from GTK.
436
441
437 2007-02-22 Fernando Perez <Fernando.Perez@colorado.edu>
442 2007-02-22 Fernando Perez <Fernando.Perez@colorado.edu>
438
443
439 * IPython/genutils.py (clock): I modified clock() to return total
444 * IPython/genutils.py (clock): I modified clock() to return total
440 time, user+system. This is a more commonly needed metric. I also
445 time, user+system. This is a more commonly needed metric. I also
441 introduced the new clocku/clocks to get only user/system time if
446 introduced the new clocku/clocks to get only user/system time if
442 one wants those instead.
447 one wants those instead.
443
448
444 ***WARNING: API CHANGE*** clock() used to return only user time,
449 ***WARNING: API CHANGE*** clock() used to return only user time,
445 so if you want exactly the same results as before, use clocku
450 so if you want exactly the same results as before, use clocku
446 instead.
451 instead.
447
452
448 2007-02-22 Ville Vainio <vivainio@gmail.com>
453 2007-02-22 Ville Vainio <vivainio@gmail.com>
449
454
450 * IPython/Extensions/ipy_p4.py: Extension for improved
455 * IPython/Extensions/ipy_p4.py: Extension for improved
451 p4 (perforce version control system) experience.
456 p4 (perforce version control system) experience.
452 Adds %p4 magic with p4 command completion and
457 Adds %p4 magic with p4 command completion and
453 automatic -G argument (marshall output as python dict)
458 automatic -G argument (marshall output as python dict)
454
459
455 2007-02-19 Fernando Perez <Fernando.Perez@colorado.edu>
460 2007-02-19 Fernando Perez <Fernando.Perez@colorado.edu>
456
461
457 * IPython/demo.py (Demo.re_stop): make dashes optional in demo
462 * IPython/demo.py (Demo.re_stop): make dashes optional in demo
458 stop marks.
463 stop marks.
459 (ClearingMixin): a simple mixin to easily make a Demo class clear
464 (ClearingMixin): a simple mixin to easily make a Demo class clear
460 the screen in between blocks and have empty marquees. The
465 the screen in between blocks and have empty marquees. The
461 ClearDemo and ClearIPDemo classes that use it are included.
466 ClearDemo and ClearIPDemo classes that use it are included.
462
467
463 2007-02-18 Fernando Perez <Fernando.Perez@colorado.edu>
468 2007-02-18 Fernando Perez <Fernando.Perez@colorado.edu>
464
469
465 * IPython/irunner.py (pexpect_monkeypatch): patch pexpect to
470 * IPython/irunner.py (pexpect_monkeypatch): patch pexpect to
466 protect against exceptions at Python shutdown time. Patch
471 protect against exceptions at Python shutdown time. Patch
467 sumbmitted to upstream.
472 sumbmitted to upstream.
468
473
469 2007-02-14 Walter Doerwald <walter@livinglogic.de>
474 2007-02-14 Walter Doerwald <walter@livinglogic.de>
470
475
471 * IPython/Extensions/ibrowse.py: If entering the first object level
476 * IPython/Extensions/ibrowse.py: If entering the first object level
472 (i.e. the object for which the browser has been started) fails,
477 (i.e. the object for which the browser has been started) fails,
473 now the error is raised directly (aborting the browser) instead of
478 now the error is raised directly (aborting the browser) instead of
474 running into an empty levels list later.
479 running into an empty levels list later.
475
480
476 2007-02-03 Walter Doerwald <walter@livinglogic.de>
481 2007-02-03 Walter Doerwald <walter@livinglogic.de>
477
482
478 * IPython/Extensions/ipipe.py: Add an xrepr implementation
483 * IPython/Extensions/ipipe.py: Add an xrepr implementation
479 for the noitem object.
484 for the noitem object.
480
485
481 2007-01-31 Fernando Perez <Fernando.Perez@colorado.edu>
486 2007-01-31 Fernando Perez <Fernando.Perez@colorado.edu>
482
487
483 * IPython/completer.py (Completer.attr_matches): Fix small
488 * IPython/completer.py (Completer.attr_matches): Fix small
484 tab-completion bug with Enthought Traits objects with units.
489 tab-completion bug with Enthought Traits objects with units.
485 Thanks to a bug report by Tom Denniston
490 Thanks to a bug report by Tom Denniston
486 <tom.denniston-AT-alum.dartmouth.org>.
491 <tom.denniston-AT-alum.dartmouth.org>.
487
492
488 2007-01-27 Fernando Perez <Fernando.Perez@colorado.edu>
493 2007-01-27 Fernando Perez <Fernando.Perez@colorado.edu>
489
494
490 * IPython/Extensions/ipy_stock_completers.py (runlistpy): fix a
495 * IPython/Extensions/ipy_stock_completers.py (runlistpy): fix a
491 bug where only .ipy or .py would be completed. Once the first
496 bug where only .ipy or .py would be completed. Once the first
492 argument to %run has been given, all completions are valid because
497 argument to %run has been given, all completions are valid because
493 they are the arguments to the script, which may well be non-python
498 they are the arguments to the script, which may well be non-python
494 filenames.
499 filenames.
495
500
496 * IPython/irunner.py (InteractiveRunner.run_source): major updates
501 * IPython/irunner.py (InteractiveRunner.run_source): major updates
497 to irunner to allow it to correctly support real doctesting of
502 to irunner to allow it to correctly support real doctesting of
498 out-of-process ipython code.
503 out-of-process ipython code.
499
504
500 * IPython/Magic.py (magic_cd): Make the setting of the terminal
505 * IPython/Magic.py (magic_cd): Make the setting of the terminal
501 title an option (-noterm_title) because it completely breaks
506 title an option (-noterm_title) because it completely breaks
502 doctesting.
507 doctesting.
503
508
504 * IPython/demo.py: fix IPythonDemo class that was not actually working.
509 * IPython/demo.py: fix IPythonDemo class that was not actually working.
505
510
506 2007-01-24 Fernando Perez <Fernando.Perez@colorado.edu>
511 2007-01-24 Fernando Perez <Fernando.Perez@colorado.edu>
507
512
508 * IPython/irunner.py (main): fix small bug where extensions were
513 * IPython/irunner.py (main): fix small bug where extensions were
509 not being correctly recognized.
514 not being correctly recognized.
510
515
511 2007-01-23 Walter Doerwald <walter@livinglogic.de>
516 2007-01-23 Walter Doerwald <walter@livinglogic.de>
512
517
513 * IPython/Extensions/ipipe.py (xiter): Make sure that iterating
518 * IPython/Extensions/ipipe.py (xiter): Make sure that iterating
514 a string containing a single line yields the string itself as the
519 a string containing a single line yields the string itself as the
515 only item.
520 only item.
516
521
517 * IPython/Extensions/ibrowse.py (ibrowse): Avoid entering an
522 * IPython/Extensions/ibrowse.py (ibrowse): Avoid entering an
518 object if it's the same as the one on the last level (This avoids
523 object if it's the same as the one on the last level (This avoids
519 infinite recursion for one line strings).
524 infinite recursion for one line strings).
520
525
521 2007-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
526 2007-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
522
527
523 * IPython/ultraTB.py (AutoFormattedTB.__call__): properly flush
528 * IPython/ultraTB.py (AutoFormattedTB.__call__): properly flush
524 all output streams before printing tracebacks. This ensures that
529 all output streams before printing tracebacks. This ensures that
525 user output doesn't end up interleaved with traceback output.
530 user output doesn't end up interleaved with traceback output.
526
531
527 2007-01-10 Ville Vainio <vivainio@gmail.com>
532 2007-01-10 Ville Vainio <vivainio@gmail.com>
528
533
529 * Extensions/envpersist.py: Turbocharged %env that remembers
534 * Extensions/envpersist.py: Turbocharged %env that remembers
530 env vars across sessions; e.g. "%env PATH+=;/opt/scripts" or
535 env vars across sessions; e.g. "%env PATH+=;/opt/scripts" or
531 "%env VISUAL=jed".
536 "%env VISUAL=jed".
532
537
533 2007-01-05 Fernando Perez <Fernando.Perez@colorado.edu>
538 2007-01-05 Fernando Perez <Fernando.Perez@colorado.edu>
534
539
535 * IPython/iplib.py (showtraceback): ensure that we correctly call
540 * IPython/iplib.py (showtraceback): ensure that we correctly call
536 custom handlers in all cases (some with pdb were slipping through,
541 custom handlers in all cases (some with pdb were slipping through,
537 but I'm not exactly sure why).
542 but I'm not exactly sure why).
538
543
539 * IPython/Debugger.py (Tracer.__init__): added new class to
544 * IPython/Debugger.py (Tracer.__init__): added new class to
540 support set_trace-like usage of IPython's enhanced debugger.
545 support set_trace-like usage of IPython's enhanced debugger.
541
546
542 2006-12-24 Ville Vainio <vivainio@gmail.com>
547 2006-12-24 Ville Vainio <vivainio@gmail.com>
543
548
544 * ipmaker.py: more informative message when ipy_user_conf
549 * ipmaker.py: more informative message when ipy_user_conf
545 import fails (suggest running %upgrade).
550 import fails (suggest running %upgrade).
546
551
547 * tools/run_ipy_in_profiler.py: Utility to see where
552 * tools/run_ipy_in_profiler.py: Utility to see where
548 the time during IPython startup is spent.
553 the time during IPython startup is spent.
549
554
550 2006-12-20 Ville Vainio <vivainio@gmail.com>
555 2006-12-20 Ville Vainio <vivainio@gmail.com>
551
556
552 * 0.7.3 is out - merge all from 0.7.3 branch to trunk
557 * 0.7.3 is out - merge all from 0.7.3 branch to trunk
553
558
554 * ipapi.py: Add new ipapi method, expand_alias.
559 * ipapi.py: Add new ipapi method, expand_alias.
555
560
556 * Release.py: Bump up version to 0.7.4.svn
561 * Release.py: Bump up version to 0.7.4.svn
557
562
558 2006-12-17 Ville Vainio <vivainio@gmail.com>
563 2006-12-17 Ville Vainio <vivainio@gmail.com>
559
564
560 * Extensions/jobctrl.py: Fixed &cmd arg arg...
565 * Extensions/jobctrl.py: Fixed &cmd arg arg...
561 to work properly on posix too
566 to work properly on posix too
562
567
563 * Release.py: Update revnum (version is still just 0.7.3).
568 * Release.py: Update revnum (version is still just 0.7.3).
564
569
565 2006-12-15 Ville Vainio <vivainio@gmail.com>
570 2006-12-15 Ville Vainio <vivainio@gmail.com>
566
571
567 * scripts/ipython_win_post_install: create ipython.py in
572 * scripts/ipython_win_post_install: create ipython.py in
568 prefix + "/scripts".
573 prefix + "/scripts".
569
574
570 * Release.py: Update version to 0.7.3.
575 * Release.py: Update version to 0.7.3.
571
576
572 2006-12-14 Ville Vainio <vivainio@gmail.com>
577 2006-12-14 Ville Vainio <vivainio@gmail.com>
573
578
574 * scripts/ipython_win_post_install: Overwrite old shortcuts
579 * scripts/ipython_win_post_install: Overwrite old shortcuts
575 if they already exist
580 if they already exist
576
581
577 * Release.py: release 0.7.3rc2
582 * Release.py: release 0.7.3rc2
578
583
579 2006-12-13 Ville Vainio <vivainio@gmail.com>
584 2006-12-13 Ville Vainio <vivainio@gmail.com>
580
585
581 * Branch and update Release.py for 0.7.3rc1
586 * Branch and update Release.py for 0.7.3rc1
582
587
583 2006-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
588 2006-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
584
589
585 * IPython/Shell.py (IPShellWX): update for current WX naming
590 * IPython/Shell.py (IPShellWX): update for current WX naming
586 conventions, to avoid a deprecation warning with current WX
591 conventions, to avoid a deprecation warning with current WX
587 versions. Thanks to a report by Danny Shevitz.
592 versions. Thanks to a report by Danny Shevitz.
588
593
589 2006-12-12 Ville Vainio <vivainio@gmail.com>
594 2006-12-12 Ville Vainio <vivainio@gmail.com>
590
595
591 * ipmaker.py: apply david cournapeau's patch to make
596 * ipmaker.py: apply david cournapeau's patch to make
592 import_some work properly even when ipythonrc does
597 import_some work properly even when ipythonrc does
593 import_some on empty list (it was an old bug!).
598 import_some on empty list (it was an old bug!).
594
599
595 * UserConfig/ipy_user_conf.py, UserConfig/ipythonrc:
600 * UserConfig/ipy_user_conf.py, UserConfig/ipythonrc:
596 Add deprecation note to ipythonrc and a url to wiki
601 Add deprecation note to ipythonrc and a url to wiki
597 in ipy_user_conf.py
602 in ipy_user_conf.py
598
603
599
604
600 * Magic.py (%run): %run myscript.ipy now runs myscript.ipy
605 * Magic.py (%run): %run myscript.ipy now runs myscript.ipy
601 as if it was typed on IPython command prompt, i.e.
606 as if it was typed on IPython command prompt, i.e.
602 as IPython script.
607 as IPython script.
603
608
604 * example-magic.py, magic_grepl.py: remove outdated examples
609 * example-magic.py, magic_grepl.py: remove outdated examples
605
610
606 2006-12-11 Fernando Perez <Fernando.Perez@colorado.edu>
611 2006-12-11 Fernando Perez <Fernando.Perez@colorado.edu>
607
612
608 * IPython/iplib.py (debugger): prevent a nasty traceback if %debug
613 * IPython/iplib.py (debugger): prevent a nasty traceback if %debug
609 is called before any exception has occurred.
614 is called before any exception has occurred.
610
615
611 2006-12-08 Ville Vainio <vivainio@gmail.com>
616 2006-12-08 Ville Vainio <vivainio@gmail.com>
612
617
613 * Extensions/ipy_stock_completers.py: fix cd completer
618 * Extensions/ipy_stock_completers.py: fix cd completer
614 to translate /'s to \'s again.
619 to translate /'s to \'s again.
615
620
616 * completer.py: prevent traceback on file completions w/
621 * completer.py: prevent traceback on file completions w/
617 backslash.
622 backslash.
618
623
619 * Release.py: Update release number to 0.7.3b3 for release
624 * Release.py: Update release number to 0.7.3b3 for release
620
625
621 2006-12-07 Ville Vainio <vivainio@gmail.com>
626 2006-12-07 Ville Vainio <vivainio@gmail.com>
622
627
623 * Extensions/ipy_signals.py: Ignore ctrl+C in IPython process
628 * Extensions/ipy_signals.py: Ignore ctrl+C in IPython process
624 while executing external code. Provides more shell-like behaviour
629 while executing external code. Provides more shell-like behaviour
625 and overall better response to ctrl + C / ctrl + break.
630 and overall better response to ctrl + C / ctrl + break.
626
631
627 * tools/make_tarball.py: new script to create tarball straight from svn
632 * tools/make_tarball.py: new script to create tarball straight from svn
628 (setup.py sdist doesn't work on win32).
633 (setup.py sdist doesn't work on win32).
629
634
630 * Extensions/ipy_stock_completers.py: fix cd completer to give up
635 * Extensions/ipy_stock_completers.py: fix cd completer to give up
631 on dirnames with spaces and use the default completer instead.
636 on dirnames with spaces and use the default completer instead.
632
637
633 * Revision.py: Change version to 0.7.3b2 for release.
638 * Revision.py: Change version to 0.7.3b2 for release.
634
639
635 2006-12-05 Ville Vainio <vivainio@gmail.com>
640 2006-12-05 Ville Vainio <vivainio@gmail.com>
636
641
637 * Magic.py, iplib.py, completer.py: Apply R. Bernstein's
642 * Magic.py, iplib.py, completer.py: Apply R. Bernstein's
638 pydb patch 4 (rm debug printing, py 2.5 checking)
643 pydb patch 4 (rm debug printing, py 2.5 checking)
639
644
640 2006-11-30 Walter Doerwald <walter@livinglogic.de>
645 2006-11-30 Walter Doerwald <walter@livinglogic.de>
641 * IPython/Extensions/ibrowse.py: Add two new commands to ibrowse:
646 * IPython/Extensions/ibrowse.py: Add two new commands to ibrowse:
642 "refresh" (mapped to "r") refreshes the screen by restarting the iterator.
647 "refresh" (mapped to "r") refreshes the screen by restarting the iterator.
643 "refreshfind" (mapped to "R") does the same but tries to go back to the same
648 "refreshfind" (mapped to "R") does the same but tries to go back to the same
644 object the cursor was on before the refresh. The command "markrange" is
649 object the cursor was on before the refresh. The command "markrange" is
645 mapped to "%" now.
650 mapped to "%" now.
646 * IPython/Extensions/ibrowse.py: Make igrpentry and ipwdentry comparable.
651 * IPython/Extensions/ibrowse.py: Make igrpentry and ipwdentry comparable.
647
652
648 2006-11-29 Fernando Perez <Fernando.Perez@colorado.edu>
653 2006-11-29 Fernando Perez <Fernando.Perez@colorado.edu>
649
654
650 * IPython/Magic.py (magic_debug): new %debug magic to activate the
655 * IPython/Magic.py (magic_debug): new %debug magic to activate the
651 interactive debugger on the last traceback, without having to call
656 interactive debugger on the last traceback, without having to call
652 %pdb and rerun your code. Made minor changes in various modules,
657 %pdb and rerun your code. Made minor changes in various modules,
653 should automatically recognize pydb if available.
658 should automatically recognize pydb if available.
654
659
655 2006-11-28 Ville Vainio <vivainio@gmail.com>
660 2006-11-28 Ville Vainio <vivainio@gmail.com>
656
661
657 * completer.py: If the text start with !, show file completions
662 * completer.py: If the text start with !, show file completions
658 properly. This helps when trying to complete command name
663 properly. This helps when trying to complete command name
659 for shell escapes.
664 for shell escapes.
660
665
661 2006-11-27 Ville Vainio <vivainio@gmail.com>
666 2006-11-27 Ville Vainio <vivainio@gmail.com>
662
667
663 * ipy_stock_completers.py: bzr completer submitted by Stefan van
668 * ipy_stock_completers.py: bzr completer submitted by Stefan van
664 der Walt. Clean up svn and hg completers by using a common
669 der Walt. Clean up svn and hg completers by using a common
665 vcs_completer.
670 vcs_completer.
666
671
667 2006-11-26 Ville Vainio <vivainio@gmail.com>
672 2006-11-26 Ville Vainio <vivainio@gmail.com>
668
673
669 * Remove ipconfig and %config; you should use _ip.options structure
674 * Remove ipconfig and %config; you should use _ip.options structure
670 directly instead!
675 directly instead!
671
676
672 * genutils.py: add wrap_deprecated function for deprecating callables
677 * genutils.py: add wrap_deprecated function for deprecating callables
673
678
674 * iplib.py: deprecate ipmagic, ipsystem, ipalias. Use _ip.magic and
679 * iplib.py: deprecate ipmagic, ipsystem, ipalias. Use _ip.magic and
675 _ip.system instead. ipalias is redundant.
680 _ip.system instead. ipalias is redundant.
676
681
677 * Magic.py: %rehashdir no longer aliases 'cmdname' to 'cmdname.exe' on
682 * Magic.py: %rehashdir no longer aliases 'cmdname' to 'cmdname.exe' on
678 win32, but just 'cmdname'. Other extensions (non-'exe') are still made
683 win32, but just 'cmdname'. Other extensions (non-'exe') are still made
679 explicit.
684 explicit.
680
685
681 * ipy_stock_completers.py: 'hg' (mercurial VCS) now has a custom
686 * ipy_stock_completers.py: 'hg' (mercurial VCS) now has a custom
682 completer. Try it by entering 'hg ' and pressing tab.
687 completer. Try it by entering 'hg ' and pressing tab.
683
688
684 * macro.py: Give Macro a useful __repr__ method
689 * macro.py: Give Macro a useful __repr__ method
685
690
686 * Magic.py: %whos abbreviates the typename of Macro for brevity.
691 * Magic.py: %whos abbreviates the typename of Macro for brevity.
687
692
688 2006-11-24 Walter Doerwald <walter@livinglogic.de>
693 2006-11-24 Walter Doerwald <walter@livinglogic.de>
689 * IPython/Extensions/astyle.py: Do a relative import of ipipe, so that
694 * IPython/Extensions/astyle.py: Do a relative import of ipipe, so that
690 we don't get a duplicate ipipe module, where registration of the xrepr
695 we don't get a duplicate ipipe module, where registration of the xrepr
691 implementation for Text is useless.
696 implementation for Text is useless.
692
697
693 * IPython/Extensions/ipipe.py: Fix __xrepr__() implementation for ils.
698 * IPython/Extensions/ipipe.py: Fix __xrepr__() implementation for ils.
694
699
695 * IPython/Extensions/ibrowse.py: Fix keymapping for the enter command.
700 * IPython/Extensions/ibrowse.py: Fix keymapping for the enter command.
696
701
697 2006-11-24 Ville Vainio <vivainio@gmail.com>
702 2006-11-24 Ville Vainio <vivainio@gmail.com>
698
703
699 * Magic.py, manual_base.lyx: Kirill Smelkov patch:
704 * Magic.py, manual_base.lyx: Kirill Smelkov patch:
700 try to use "cProfile" instead of the slower pure python
705 try to use "cProfile" instead of the slower pure python
701 "profile"
706 "profile"
702
707
703 2006-11-23 Ville Vainio <vivainio@gmail.com>
708 2006-11-23 Ville Vainio <vivainio@gmail.com>
704
709
705 * manual_base.lyx: Kirill Smelkov patch: Fix wrong
710 * manual_base.lyx: Kirill Smelkov patch: Fix wrong
706 Qt+IPython+Designer link in documentation.
711 Qt+IPython+Designer link in documentation.
707
712
708 * Extensions/ipy_pydb.py: R. Bernstein's patch for passing
713 * Extensions/ipy_pydb.py: R. Bernstein's patch for passing
709 correct Pdb object to %pydb.
714 correct Pdb object to %pydb.
710
715
711
716
712 2006-11-22 Walter Doerwald <walter@livinglogic.de>
717 2006-11-22 Walter Doerwald <walter@livinglogic.de>
713 * IPython/Extensions/astyle.py: Text needs it's own implemenation of the
718 * IPython/Extensions/astyle.py: Text needs it's own implemenation of the
714 generic xrepr(), otherwise the list implementation would kick in.
719 generic xrepr(), otherwise the list implementation would kick in.
715
720
716 2006-11-21 Ville Vainio <vivainio@gmail.com>
721 2006-11-21 Ville Vainio <vivainio@gmail.com>
717
722
718 * upgrade_dir.py: Now actually overwrites a nonmodified user file
723 * upgrade_dir.py: Now actually overwrites a nonmodified user file
719 with one from UserConfig.
724 with one from UserConfig.
720
725
721 * ipy_profile_sh.py: Add dummy "depth" to var_expand lambda,
726 * ipy_profile_sh.py: Add dummy "depth" to var_expand lambda,
722 it was missing which broke the sh profile.
727 it was missing which broke the sh profile.
723
728
724 * completer.py: file completer now uses explicit '/' instead
729 * completer.py: file completer now uses explicit '/' instead
725 of os.path.join, expansion of 'foo' was broken on win32
730 of os.path.join, expansion of 'foo' was broken on win32
726 if there was one directory with name 'foobar'.
731 if there was one directory with name 'foobar'.
727
732
728 * A bunch of patches from Kirill Smelkov:
733 * A bunch of patches from Kirill Smelkov:
729
734
730 * [patch 9/9] doc: point bug-tracker URL to IPythons trac-tickets.
735 * [patch 9/9] doc: point bug-tracker URL to IPythons trac-tickets.
731
736
732 * [patch 7/9] Implement %page -r (page in raw mode) -
737 * [patch 7/9] Implement %page -r (page in raw mode) -
733
738
734 * [patch 5/9] ScientificPython webpage has moved
739 * [patch 5/9] ScientificPython webpage has moved
735
740
736 * [patch 4/9] The manual mentions %ds, should be %dhist
741 * [patch 4/9] The manual mentions %ds, should be %dhist
737
742
738 * [patch 3/9] Kill old bits from %prun doc.
743 * [patch 3/9] Kill old bits from %prun doc.
739
744
740 * [patch 1/9] Fix typos here and there.
745 * [patch 1/9] Fix typos here and there.
741
746
742 2006-11-08 Ville Vainio <vivainio@gmail.com>
747 2006-11-08 Ville Vainio <vivainio@gmail.com>
743
748
744 * completer.py (attr_matches): catch all exceptions raised
749 * completer.py (attr_matches): catch all exceptions raised
745 by eval of expr with dots.
750 by eval of expr with dots.
746
751
747 2006-11-07 Fernando Perez <Fernando.Perez@colorado.edu>
752 2006-11-07 Fernando Perez <Fernando.Perez@colorado.edu>
748
753
749 * IPython/iplib.py (runsource): Prepend an 'if 1:' to the user
754 * IPython/iplib.py (runsource): Prepend an 'if 1:' to the user
750 input if it starts with whitespace. This allows you to paste
755 input if it starts with whitespace. This allows you to paste
751 indented input from any editor without manually having to type in
756 indented input from any editor without manually having to type in
752 the 'if 1:', which is convenient when working interactively.
757 the 'if 1:', which is convenient when working interactively.
753 Slightly modifed version of a patch by Bo Peng
758 Slightly modifed version of a patch by Bo Peng
754 <bpeng-AT-rice.edu>.
759 <bpeng-AT-rice.edu>.
755
760
756 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
761 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
757
762
758 * IPython/irunner.py (main): modified irunner so it automatically
763 * IPython/irunner.py (main): modified irunner so it automatically
759 recognizes the right runner to use based on the extension (.py for
764 recognizes the right runner to use based on the extension (.py for
760 python, .ipy for ipython and .sage for sage).
765 python, .ipy for ipython and .sage for sage).
761
766
762 * IPython/iplib.py (InteractiveShell.ipconfig): new builtin, also
767 * IPython/iplib.py (InteractiveShell.ipconfig): new builtin, also
763 visible in ipapi as ip.config(), to programatically control the
768 visible in ipapi as ip.config(), to programatically control the
764 internal rc object. There's an accompanying %config magic for
769 internal rc object. There's an accompanying %config magic for
765 interactive use, which has been enhanced to match the
770 interactive use, which has been enhanced to match the
766 funtionality in ipconfig.
771 funtionality in ipconfig.
767
772
768 * IPython/Magic.py (magic_system_verbose): Change %system_verbose
773 * IPython/Magic.py (magic_system_verbose): Change %system_verbose
769 so it's not just a toggle, it now takes an argument. Add support
774 so it's not just a toggle, it now takes an argument. Add support
770 for a customizable header when making system calls, as the new
775 for a customizable header when making system calls, as the new
771 system_header variable in the ipythonrc file.
776 system_header variable in the ipythonrc file.
772
777
773 2006-11-03 Walter Doerwald <walter@livinglogic.de>
778 2006-11-03 Walter Doerwald <walter@livinglogic.de>
774
779
775 * IPython/Extensions/ipipe.py: xrepr(), xiter() and xattrs() are now
780 * IPython/Extensions/ipipe.py: xrepr(), xiter() and xattrs() are now
776 generic functions (using Philip J. Eby's simplegeneric package).
781 generic functions (using Philip J. Eby's simplegeneric package).
777 This makes it possible to customize the display of third-party classes
782 This makes it possible to customize the display of third-party classes
778 without having to monkeypatch them. xiter() no longer supports a mode
783 without having to monkeypatch them. xiter() no longer supports a mode
779 argument and the XMode class has been removed. The same functionality can
784 argument and the XMode class has been removed. The same functionality can
780 be implemented via IterAttributeDescriptor and IterMethodDescriptor.
785 be implemented via IterAttributeDescriptor and IterMethodDescriptor.
781 One consequence of the switch to generic functions is that xrepr() and
786 One consequence of the switch to generic functions is that xrepr() and
782 xattrs() implementation must define the default value for the mode
787 xattrs() implementation must define the default value for the mode
783 argument themselves and xattrs() implementations must return real
788 argument themselves and xattrs() implementations must return real
784 descriptors.
789 descriptors.
785
790
786 * IPython/external: This new subpackage will contain all third-party
791 * IPython/external: This new subpackage will contain all third-party
787 packages that are bundled with IPython. (The first one is simplegeneric).
792 packages that are bundled with IPython. (The first one is simplegeneric).
788
793
789 * IPython/Extensions/ipipe.py (ifile/ils): Readd output of the parent
794 * IPython/Extensions/ipipe.py (ifile/ils): Readd output of the parent
790 directory which as been dropped in r1703.
795 directory which as been dropped in r1703.
791
796
792 * IPython/Extensions/ipipe.py (iless): Fixed.
797 * IPython/Extensions/ipipe.py (iless): Fixed.
793
798
794 * IPython/Extensions/ibrowse: Fixed sorting under Python 2.3.
799 * IPython/Extensions/ibrowse: Fixed sorting under Python 2.3.
795
800
796 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
801 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
797
802
798 * IPython/iplib.py (InteractiveShell.var_expand): fix stack
803 * IPython/iplib.py (InteractiveShell.var_expand): fix stack
799 handling in variable expansion so that shells and magics recognize
804 handling in variable expansion so that shells and magics recognize
800 function local scopes correctly. Bug reported by Brian.
805 function local scopes correctly. Bug reported by Brian.
801
806
802 * scripts/ipython: remove the very first entry in sys.path which
807 * scripts/ipython: remove the very first entry in sys.path which
803 Python auto-inserts for scripts, so that sys.path under IPython is
808 Python auto-inserts for scripts, so that sys.path under IPython is
804 as similar as possible to that under plain Python.
809 as similar as possible to that under plain Python.
805
810
806 * IPython/completer.py (IPCompleter.file_matches): Fix
811 * IPython/completer.py (IPCompleter.file_matches): Fix
807 tab-completion so that quotes are not closed unless the completion
812 tab-completion so that quotes are not closed unless the completion
808 is unambiguous. After a request by Stefan. Minor cleanups in
813 is unambiguous. After a request by Stefan. Minor cleanups in
809 ipy_stock_completers.
814 ipy_stock_completers.
810
815
811 2006-11-02 Ville Vainio <vivainio@gmail.com>
816 2006-11-02 Ville Vainio <vivainio@gmail.com>
812
817
813 * ipy_stock_completers.py: Add %run and %cd completers.
818 * ipy_stock_completers.py: Add %run and %cd completers.
814
819
815 * completer.py: Try running custom completer for both
820 * completer.py: Try running custom completer for both
816 "foo" and "%foo" if the command is just "foo". Ignore case
821 "foo" and "%foo" if the command is just "foo". Ignore case
817 when filtering possible completions.
822 when filtering possible completions.
818
823
819 * UserConfig/ipy_user_conf.py: install stock completers as default
824 * UserConfig/ipy_user_conf.py: install stock completers as default
820
825
821 * iplib.py (history_saving_wrapper), debugger(), ipy_pydb.py:
826 * iplib.py (history_saving_wrapper), debugger(), ipy_pydb.py:
822 simplified readline history save / restore through a wrapper
827 simplified readline history save / restore through a wrapper
823 function
828 function
824
829
825
830
826 2006-10-31 Ville Vainio <vivainio@gmail.com>
831 2006-10-31 Ville Vainio <vivainio@gmail.com>
827
832
828 * strdispatch.py, completer.py, ipy_stock_completers.py:
833 * strdispatch.py, completer.py, ipy_stock_completers.py:
829 Allow str_key ("command") in completer hooks. Implement
834 Allow str_key ("command") in completer hooks. Implement
830 trivial completer for 'import' (stdlib modules only). Rename
835 trivial completer for 'import' (stdlib modules only). Rename
831 ipy_linux_package_managers.py to ipy_stock_completers.py.
836 ipy_linux_package_managers.py to ipy_stock_completers.py.
832 SVN completer.
837 SVN completer.
833
838
834 * Extensions/ledit.py: %magic line editor for easily and
839 * Extensions/ledit.py: %magic line editor for easily and
835 incrementally manipulating lists of strings. The magic command
840 incrementally manipulating lists of strings. The magic command
836 name is %led.
841 name is %led.
837
842
838 2006-10-30 Ville Vainio <vivainio@gmail.com>
843 2006-10-30 Ville Vainio <vivainio@gmail.com>
839
844
840 * Debugger.py, iplib.py (debugger()): Add last set of Rocky
845 * Debugger.py, iplib.py (debugger()): Add last set of Rocky
841 Bernsteins's patches for pydb integration.
846 Bernsteins's patches for pydb integration.
842 http://bashdb.sourceforge.net/pydb/
847 http://bashdb.sourceforge.net/pydb/
843
848
844 * strdispatch.py, iplib.py, completer.py, IPython/__init__.py,
849 * strdispatch.py, iplib.py, completer.py, IPython/__init__.py,
845 Extensions/ipy_linux_package_managers.py, hooks.py: Implement
850 Extensions/ipy_linux_package_managers.py, hooks.py: Implement
846 custom completer hook to allow the users to implement their own
851 custom completer hook to allow the users to implement their own
847 completers. See ipy_linux_package_managers.py for example. The
852 completers. See ipy_linux_package_managers.py for example. The
848 hook name is 'complete_command'.
853 hook name is 'complete_command'.
849
854
850 2006-10-28 Fernando Perez <Fernando.Perez@colorado.edu>
855 2006-10-28 Fernando Perez <Fernando.Perez@colorado.edu>
851
856
852 * IPython/UserConfig/ipythonrc-scipy: minor cleanups to remove old
857 * IPython/UserConfig/ipythonrc-scipy: minor cleanups to remove old
853 Numeric leftovers.
858 Numeric leftovers.
854
859
855 * ipython.el (py-execute-region): apply Stefan's patch to fix
860 * ipython.el (py-execute-region): apply Stefan's patch to fix
856 garbled results if the python shell hasn't been previously started.
861 garbled results if the python shell hasn't been previously started.
857
862
858 * IPython/genutils.py (arg_split): moved to genutils, since it's a
863 * IPython/genutils.py (arg_split): moved to genutils, since it's a
859 pretty generic function and useful for other things.
864 pretty generic function and useful for other things.
860
865
861 * IPython/OInspect.py (getsource): Add customizable source
866 * IPython/OInspect.py (getsource): Add customizable source
862 extractor. After a request/patch form W. Stein (SAGE).
867 extractor. After a request/patch form W. Stein (SAGE).
863
868
864 * IPython/irunner.py (InteractiveRunner.run_source): reset tty
869 * IPython/irunner.py (InteractiveRunner.run_source): reset tty
865 window size to a more reasonable value from what pexpect does,
870 window size to a more reasonable value from what pexpect does,
866 since their choice causes wrapping bugs with long input lines.
871 since their choice causes wrapping bugs with long input lines.
867
872
868 2006-10-28 Ville Vainio <vivainio@gmail.com>
873 2006-10-28 Ville Vainio <vivainio@gmail.com>
869
874
870 * Magic.py (%run): Save and restore the readline history from
875 * Magic.py (%run): Save and restore the readline history from
871 file around %run commands to prevent side effects from
876 file around %run commands to prevent side effects from
872 %runned programs that might use readline (e.g. pydb).
877 %runned programs that might use readline (e.g. pydb).
873
878
874 * extensions/ipy_pydb.py: Adds %pydb magic when imported, for
879 * extensions/ipy_pydb.py: Adds %pydb magic when imported, for
875 invoking the pydb enhanced debugger.
880 invoking the pydb enhanced debugger.
876
881
877 2006-10-23 Walter Doerwald <walter@livinglogic.de>
882 2006-10-23 Walter Doerwald <walter@livinglogic.de>
878
883
879 * IPython/Extensions/ipipe.py (ifile): Remove all methods that
884 * IPython/Extensions/ipipe.py (ifile): Remove all methods that
880 call the base class method and propagate the return value to
885 call the base class method and propagate the return value to
881 ifile. This is now done by path itself.
886 ifile. This is now done by path itself.
882
887
883 2006-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
888 2006-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
884
889
885 * IPython/ipapi.py (IPApi.__init__): Added new entry to public
890 * IPython/ipapi.py (IPApi.__init__): Added new entry to public
886 api: set_crash_handler(), to expose the ability to change the
891 api: set_crash_handler(), to expose the ability to change the
887 internal crash handler.
892 internal crash handler.
888
893
889 * IPython/CrashHandler.py (CrashHandler.__init__): abstract out
894 * IPython/CrashHandler.py (CrashHandler.__init__): abstract out
890 the various parameters of the crash handler so that apps using
895 the various parameters of the crash handler so that apps using
891 IPython as their engine can customize crash handling. Ipmlemented
896 IPython as their engine can customize crash handling. Ipmlemented
892 at the request of SAGE.
897 at the request of SAGE.
893
898
894 2006-10-14 Ville Vainio <vivainio@gmail.com>
899 2006-10-14 Ville Vainio <vivainio@gmail.com>
895
900
896 * Magic.py, ipython.el: applied first "safe" part of Rocky
901 * Magic.py, ipython.el: applied first "safe" part of Rocky
897 Bernstein's patch set for pydb integration.
902 Bernstein's patch set for pydb integration.
898
903
899 * Magic.py (%unalias, %alias): %store'd aliases can now be
904 * Magic.py (%unalias, %alias): %store'd aliases can now be
900 removed with '%unalias'. %alias w/o args now shows most
905 removed with '%unalias'. %alias w/o args now shows most
901 interesting (stored / manually defined) aliases last
906 interesting (stored / manually defined) aliases last
902 where they catch the eye w/o scrolling.
907 where they catch the eye w/o scrolling.
903
908
904 * Magic.py (%rehashx), ext_rehashdir.py: files with
909 * Magic.py (%rehashx), ext_rehashdir.py: files with
905 'py' extension are always considered executable, even
910 'py' extension are always considered executable, even
906 when not in PATHEXT environment variable.
911 when not in PATHEXT environment variable.
907
912
908 2006-10-12 Ville Vainio <vivainio@gmail.com>
913 2006-10-12 Ville Vainio <vivainio@gmail.com>
909
914
910 * jobctrl.py: Add new "jobctrl" extension for spawning background
915 * jobctrl.py: Add new "jobctrl" extension for spawning background
911 processes with "&find /". 'import jobctrl' to try it out. Requires
916 processes with "&find /". 'import jobctrl' to try it out. Requires
912 'subprocess' module, standard in python 2.4+.
917 'subprocess' module, standard in python 2.4+.
913
918
914 * iplib.py (expand_aliases, handle_alias): Aliases expand transitively,
919 * iplib.py (expand_aliases, handle_alias): Aliases expand transitively,
915 so if foo -> bar and bar -> baz, then foo -> baz.
920 so if foo -> bar and bar -> baz, then foo -> baz.
916
921
917 2006-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
922 2006-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
918
923
919 * IPython/Magic.py (Magic.parse_options): add a new posix option
924 * IPython/Magic.py (Magic.parse_options): add a new posix option
920 to allow parsing of input args in magics that doesn't strip quotes
925 to allow parsing of input args in magics that doesn't strip quotes
921 (if posix=False). This also closes %timeit bug reported by
926 (if posix=False). This also closes %timeit bug reported by
922 Stefan.
927 Stefan.
923
928
924 2006-10-03 Ville Vainio <vivainio@gmail.com>
929 2006-10-03 Ville Vainio <vivainio@gmail.com>
925
930
926 * iplib.py (raw_input, interact): Return ValueError catching for
931 * iplib.py (raw_input, interact): Return ValueError catching for
927 raw_input. Fixes infinite loop for sys.stdin.close() or
932 raw_input. Fixes infinite loop for sys.stdin.close() or
928 sys.stdout.close().
933 sys.stdout.close().
929
934
930 2006-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
935 2006-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
931
936
932 * IPython/irunner.py (InteractiveRunner.run_source): small fixes
937 * IPython/irunner.py (InteractiveRunner.run_source): small fixes
933 to help in handling doctests. irunner is now pretty useful for
938 to help in handling doctests. irunner is now pretty useful for
934 running standalone scripts and simulate a full interactive session
939 running standalone scripts and simulate a full interactive session
935 in a format that can be then pasted as a doctest.
940 in a format that can be then pasted as a doctest.
936
941
937 * IPython/iplib.py (InteractiveShell.__init__): Install exit/quit
942 * IPython/iplib.py (InteractiveShell.__init__): Install exit/quit
938 on top of the default (useless) ones. This also fixes the nasty
943 on top of the default (useless) ones. This also fixes the nasty
939 way in which 2.5's Quitter() exits (reverted [1785]).
944 way in which 2.5's Quitter() exits (reverted [1785]).
940
945
941 * IPython/Debugger.py (Pdb.__init__): Fix ipdb to work with python
946 * IPython/Debugger.py (Pdb.__init__): Fix ipdb to work with python
942 2.5.
947 2.5.
943
948
944 * IPython/ultraTB.py (TBTools.set_colors): Make sure that ipdb
949 * IPython/ultraTB.py (TBTools.set_colors): Make sure that ipdb
945 color scheme is updated as well when color scheme is changed
950 color scheme is updated as well when color scheme is changed
946 interactively.
951 interactively.
947
952
948 2006-09-27 Ville Vainio <vivainio@gmail.com>
953 2006-09-27 Ville Vainio <vivainio@gmail.com>
949
954
950 * iplib.py (raw_input): python 2.5 closes stdin on quit -> avoid
955 * iplib.py (raw_input): python 2.5 closes stdin on quit -> avoid
951 infinite loop and just exit. It's a hack, but will do for a while.
956 infinite loop and just exit. It's a hack, but will do for a while.
952
957
953 2006-08-25 Walter Doerwald <walter@livinglogic.de>
958 2006-08-25 Walter Doerwald <walter@livinglogic.de>
954
959
955 * IPython/Extensions/ipipe.py (ils): Add arguments dirs and files to
960 * IPython/Extensions/ipipe.py (ils): Add arguments dirs and files to
956 the constructor, this makes it possible to get a list of only directories
961 the constructor, this makes it possible to get a list of only directories
957 or only files.
962 or only files.
958
963
959 2006-08-12 Ville Vainio <vivainio@gmail.com>
964 2006-08-12 Ville Vainio <vivainio@gmail.com>
960
965
961 * Fakemodule.py, OInspect.py: Reverted 2006-08-11 mods,
966 * Fakemodule.py, OInspect.py: Reverted 2006-08-11 mods,
962 they broke unittest
967 they broke unittest
963
968
964 2006-08-11 Ville Vainio <vivainio@gmail.com>
969 2006-08-11 Ville Vainio <vivainio@gmail.com>
965
970
966 * Fakemodule.py, OInspect.py: remove 2006-08-09 monkepatch
971 * Fakemodule.py, OInspect.py: remove 2006-08-09 monkepatch
967 by resolving issue properly, i.e. by inheriting FakeModule
972 by resolving issue properly, i.e. by inheriting FakeModule
968 from types.ModuleType. Pickling ipython interactive data
973 from types.ModuleType. Pickling ipython interactive data
969 should still work as usual (testing appreciated).
974 should still work as usual (testing appreciated).
970
975
971 2006-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
976 2006-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
972
977
973 * IPython/OInspect.py: monkeypatch inspect from the stdlib if
978 * IPython/OInspect.py: monkeypatch inspect from the stdlib if
974 running under python 2.3 with code from 2.4 to fix a bug with
979 running under python 2.3 with code from 2.4 to fix a bug with
975 help(). Reported by the Debian maintainers, Norbert Tretkowski
980 help(). Reported by the Debian maintainers, Norbert Tretkowski
976 <norbert-AT-tretkowski.de> and Alexandre Fayolle
981 <norbert-AT-tretkowski.de> and Alexandre Fayolle
977 <afayolle-AT-debian.org>.
982 <afayolle-AT-debian.org>.
978
983
979 2006-08-04 Walter Doerwald <walter@livinglogic.de>
984 2006-08-04 Walter Doerwald <walter@livinglogic.de>
980
985
981 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
986 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
982 (which was displaying "quit" twice).
987 (which was displaying "quit" twice).
983
988
984 2006-07-28 Walter Doerwald <walter@livinglogic.de>
989 2006-07-28 Walter Doerwald <walter@livinglogic.de>
985
990
986 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
991 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
987 the mode argument).
992 the mode argument).
988
993
989 2006-07-27 Walter Doerwald <walter@livinglogic.de>
994 2006-07-27 Walter Doerwald <walter@livinglogic.de>
990
995
991 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
996 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
992 not running under IPython.
997 not running under IPython.
993
998
994 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
999 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
995 and make it iterable (iterating over the attribute itself). Add two new
1000 and make it iterable (iterating over the attribute itself). Add two new
996 magic strings for __xattrs__(): If the string starts with "-", the attribute
1001 magic strings for __xattrs__(): If the string starts with "-", the attribute
997 will not be displayed in ibrowse's detail view (but it can still be
1002 will not be displayed in ibrowse's detail view (but it can still be
998 iterated over). This makes it possible to add attributes that are large
1003 iterated over). This makes it possible to add attributes that are large
999 lists or generator methods to the detail view. Replace magic attribute names
1004 lists or generator methods to the detail view. Replace magic attribute names
1000 and _attrname() and _getattr() with "descriptors": For each type of magic
1005 and _attrname() and _getattr() with "descriptors": For each type of magic
1001 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
1006 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
1002 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
1007 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
1003 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
1008 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
1004 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
1009 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
1005 are still supported.
1010 are still supported.
1006
1011
1007 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
1012 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
1008 fails in ibrowse.fetch(), the exception object is added as the last item
1013 fails in ibrowse.fetch(), the exception object is added as the last item
1009 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
1014 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
1010 a generator throws an exception midway through execution.
1015 a generator throws an exception midway through execution.
1011
1016
1012 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
1017 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
1013 encoding into methods.
1018 encoding into methods.
1014
1019
1015 2006-07-26 Ville Vainio <vivainio@gmail.com>
1020 2006-07-26 Ville Vainio <vivainio@gmail.com>
1016
1021
1017 * iplib.py: history now stores multiline input as single
1022 * iplib.py: history now stores multiline input as single
1018 history entries. Patch by Jorgen Cederlof.
1023 history entries. Patch by Jorgen Cederlof.
1019
1024
1020 2006-07-18 Walter Doerwald <walter@livinglogic.de>
1025 2006-07-18 Walter Doerwald <walter@livinglogic.de>
1021
1026
1022 * IPython/Extensions/ibrowse.py: Make cursor visible over
1027 * IPython/Extensions/ibrowse.py: Make cursor visible over
1023 non existing attributes.
1028 non existing attributes.
1024
1029
1025 2006-07-14 Walter Doerwald <walter@livinglogic.de>
1030 2006-07-14 Walter Doerwald <walter@livinglogic.de>
1026
1031
1027 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
1032 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
1028 error output of the running command doesn't mess up the screen.
1033 error output of the running command doesn't mess up the screen.
1029
1034
1030 2006-07-13 Walter Doerwald <walter@livinglogic.de>
1035 2006-07-13 Walter Doerwald <walter@livinglogic.de>
1031
1036
1032 * IPython/Extensions/ipipe.py (isort): Make isort usable without
1037 * IPython/Extensions/ipipe.py (isort): Make isort usable without
1033 argument. This sorts the items themselves.
1038 argument. This sorts the items themselves.
1034
1039
1035 2006-07-12 Walter Doerwald <walter@livinglogic.de>
1040 2006-07-12 Walter Doerwald <walter@livinglogic.de>
1036
1041
1037 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
1042 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
1038 Compile expression strings into code objects. This should speed
1043 Compile expression strings into code objects. This should speed
1039 up ifilter and friends somewhat.
1044 up ifilter and friends somewhat.
1040
1045
1041 2006-07-08 Ville Vainio <vivainio@gmail.com>
1046 2006-07-08 Ville Vainio <vivainio@gmail.com>
1042
1047
1043 * Magic.py: %cpaste now strips > from the beginning of lines
1048 * Magic.py: %cpaste now strips > from the beginning of lines
1044 to ease pasting quoted code from emails. Contributed by
1049 to ease pasting quoted code from emails. Contributed by
1045 Stefan van der Walt.
1050 Stefan van der Walt.
1046
1051
1047 2006-06-29 Ville Vainio <vivainio@gmail.com>
1052 2006-06-29 Ville Vainio <vivainio@gmail.com>
1048
1053
1049 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
1054 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
1050 mode, patch contributed by Darren Dale. NEEDS TESTING!
1055 mode, patch contributed by Darren Dale. NEEDS TESTING!
1051
1056
1052 2006-06-28 Walter Doerwald <walter@livinglogic.de>
1057 2006-06-28 Walter Doerwald <walter@livinglogic.de>
1053
1058
1054 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
1059 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
1055 a blue background. Fix fetching new display rows when the browser
1060 a blue background. Fix fetching new display rows when the browser
1056 scrolls more than a screenful (e.g. by using the goto command).
1061 scrolls more than a screenful (e.g. by using the goto command).
1057
1062
1058 2006-06-27 Ville Vainio <vivainio@gmail.com>
1063 2006-06-27 Ville Vainio <vivainio@gmail.com>
1059
1064
1060 * Magic.py (_inspect, _ofind) Apply David Huard's
1065 * Magic.py (_inspect, _ofind) Apply David Huard's
1061 patch for displaying the correct docstring for 'property'
1066 patch for displaying the correct docstring for 'property'
1062 attributes.
1067 attributes.
1063
1068
1064 2006-06-23 Walter Doerwald <walter@livinglogic.de>
1069 2006-06-23 Walter Doerwald <walter@livinglogic.de>
1065
1070
1066 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
1071 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
1067 commands into the methods implementing them.
1072 commands into the methods implementing them.
1068
1073
1069 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
1074 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
1070
1075
1071 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
1076 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
1072 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
1077 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
1073 autoindent support was authored by Jin Liu.
1078 autoindent support was authored by Jin Liu.
1074
1079
1075 2006-06-22 Walter Doerwald <walter@livinglogic.de>
1080 2006-06-22 Walter Doerwald <walter@livinglogic.de>
1076
1081
1077 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
1082 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
1078 for keymaps with a custom class that simplifies handling.
1083 for keymaps with a custom class that simplifies handling.
1079
1084
1080 2006-06-19 Walter Doerwald <walter@livinglogic.de>
1085 2006-06-19 Walter Doerwald <walter@livinglogic.de>
1081
1086
1082 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
1087 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
1083 resizing. This requires Python 2.5 to work.
1088 resizing. This requires Python 2.5 to work.
1084
1089
1085 2006-06-16 Walter Doerwald <walter@livinglogic.de>
1090 2006-06-16 Walter Doerwald <walter@livinglogic.de>
1086
1091
1087 * IPython/Extensions/ibrowse.py: Add two new commands to
1092 * IPython/Extensions/ibrowse.py: Add two new commands to
1088 ibrowse: "hideattr" (mapped to "h") hides the attribute under
1093 ibrowse: "hideattr" (mapped to "h") hides the attribute under
1089 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
1094 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
1090 attributes again. Remapped the help command to "?". Display
1095 attributes again. Remapped the help command to "?". Display
1091 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
1096 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
1092 as keys for the "home" and "end" commands. Add three new commands
1097 as keys for the "home" and "end" commands. Add three new commands
1093 to the input mode for "find" and friends: "delend" (CTRL-K)
1098 to the input mode for "find" and friends: "delend" (CTRL-K)
1094 deletes to the end of line. "incsearchup" searches upwards in the
1099 deletes to the end of line. "incsearchup" searches upwards in the
1095 command history for an input that starts with the text before the cursor.
1100 command history for an input that starts with the text before the cursor.
1096 "incsearchdown" does the same downwards. Removed a bogus mapping of
1101 "incsearchdown" does the same downwards. Removed a bogus mapping of
1097 the x key to "delete".
1102 the x key to "delete".
1098
1103
1099 2006-06-15 Ville Vainio <vivainio@gmail.com>
1104 2006-06-15 Ville Vainio <vivainio@gmail.com>
1100
1105
1101 * iplib.py, hooks.py: Added new generate_prompt hook that can be
1106 * iplib.py, hooks.py: Added new generate_prompt hook that can be
1102 used to create prompts dynamically, instead of the "old" way of
1107 used to create prompts dynamically, instead of the "old" way of
1103 assigning "magic" strings to prompt_in1 and prompt_in2. The old
1108 assigning "magic" strings to prompt_in1 and prompt_in2. The old
1104 way still works (it's invoked by the default hook), of course.
1109 way still works (it's invoked by the default hook), of course.
1105
1110
1106 * Prompts.py: added generate_output_prompt hook for altering output
1111 * Prompts.py: added generate_output_prompt hook for altering output
1107 prompt
1112 prompt
1108
1113
1109 * Release.py: Changed version string to 0.7.3.svn.
1114 * Release.py: Changed version string to 0.7.3.svn.
1110
1115
1111 2006-06-15 Walter Doerwald <walter@livinglogic.de>
1116 2006-06-15 Walter Doerwald <walter@livinglogic.de>
1112
1117
1113 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
1118 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
1114 the call to fetch() always tries to fetch enough data for at least one
1119 the call to fetch() always tries to fetch enough data for at least one
1115 full screen. This makes it possible to simply call moveto(0,0,True) in
1120 full screen. This makes it possible to simply call moveto(0,0,True) in
1116 the constructor. Fix typos and removed the obsolete goto attribute.
1121 the constructor. Fix typos and removed the obsolete goto attribute.
1117
1122
1118 2006-06-12 Ville Vainio <vivainio@gmail.com>
1123 2006-06-12 Ville Vainio <vivainio@gmail.com>
1119
1124
1120 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
1125 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
1121 allowing $variable interpolation within multiline statements,
1126 allowing $variable interpolation within multiline statements,
1122 though so far only with "sh" profile for a testing period.
1127 though so far only with "sh" profile for a testing period.
1123 The patch also enables splitting long commands with \ but it
1128 The patch also enables splitting long commands with \ but it
1124 doesn't work properly yet.
1129 doesn't work properly yet.
1125
1130
1126 2006-06-12 Walter Doerwald <walter@livinglogic.de>
1131 2006-06-12 Walter Doerwald <walter@livinglogic.de>
1127
1132
1128 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
1133 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
1129 input history and the position of the cursor in the input history for
1134 input history and the position of the cursor in the input history for
1130 the find, findbackwards and goto command.
1135 the find, findbackwards and goto command.
1131
1136
1132 2006-06-10 Walter Doerwald <walter@livinglogic.de>
1137 2006-06-10 Walter Doerwald <walter@livinglogic.de>
1133
1138
1134 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
1139 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
1135 implements the basic functionality of browser commands that require
1140 implements the basic functionality of browser commands that require
1136 input. Reimplement the goto, find and findbackwards commands as
1141 input. Reimplement the goto, find and findbackwards commands as
1137 subclasses of _CommandInput. Add an input history and keymaps to those
1142 subclasses of _CommandInput. Add an input history and keymaps to those
1138 commands. Add "\r" as a keyboard shortcut for the enterdefault and
1143 commands. Add "\r" as a keyboard shortcut for the enterdefault and
1139 execute commands.
1144 execute commands.
1140
1145
1141 2006-06-07 Ville Vainio <vivainio@gmail.com>
1146 2006-06-07 Ville Vainio <vivainio@gmail.com>
1142
1147
1143 * iplib.py: ipython mybatch.ipy exits ipython immediately after
1148 * iplib.py: ipython mybatch.ipy exits ipython immediately after
1144 running the batch files instead of leaving the session open.
1149 running the batch files instead of leaving the session open.
1145
1150
1146 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
1151 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
1147
1152
1148 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
1153 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
1149 the original fix was incomplete. Patch submitted by W. Maier.
1154 the original fix was incomplete. Patch submitted by W. Maier.
1150
1155
1151 2006-06-07 Ville Vainio <vivainio@gmail.com>
1156 2006-06-07 Ville Vainio <vivainio@gmail.com>
1152
1157
1153 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
1158 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
1154 Confirmation prompts can be supressed by 'quiet' option.
1159 Confirmation prompts can be supressed by 'quiet' option.
1155 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
1160 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
1156
1161
1157 2006-06-06 *** Released version 0.7.2
1162 2006-06-06 *** Released version 0.7.2
1158
1163
1159 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
1164 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
1160
1165
1161 * IPython/Release.py (version): Made 0.7.2 final for release.
1166 * IPython/Release.py (version): Made 0.7.2 final for release.
1162 Repo tagged and release cut.
1167 Repo tagged and release cut.
1163
1168
1164 2006-06-05 Ville Vainio <vivainio@gmail.com>
1169 2006-06-05 Ville Vainio <vivainio@gmail.com>
1165
1170
1166 * Magic.py (magic_rehashx): Honor no_alias list earlier in
1171 * Magic.py (magic_rehashx): Honor no_alias list earlier in
1167 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
1172 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
1168
1173
1169 * upgrade_dir.py: try import 'path' module a bit harder
1174 * upgrade_dir.py: try import 'path' module a bit harder
1170 (for %upgrade)
1175 (for %upgrade)
1171
1176
1172 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
1177 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
1173
1178
1174 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
1179 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
1175 instead of looping 20 times.
1180 instead of looping 20 times.
1176
1181
1177 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
1182 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
1178 correctly at initialization time. Bug reported by Krishna Mohan
1183 correctly at initialization time. Bug reported by Krishna Mohan
1179 Gundu <gkmohan-AT-gmail.com> on the user list.
1184 Gundu <gkmohan-AT-gmail.com> on the user list.
1180
1185
1181 * IPython/Release.py (version): Mark 0.7.2 version to start
1186 * IPython/Release.py (version): Mark 0.7.2 version to start
1182 testing for release on 06/06.
1187 testing for release on 06/06.
1183
1188
1184 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
1189 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
1185
1190
1186 * scripts/irunner: thin script interface so users don't have to
1191 * scripts/irunner: thin script interface so users don't have to
1187 find the module and call it as an executable, since modules rarely
1192 find the module and call it as an executable, since modules rarely
1188 live in people's PATH.
1193 live in people's PATH.
1189
1194
1190 * IPython/irunner.py (InteractiveRunner.__init__): added
1195 * IPython/irunner.py (InteractiveRunner.__init__): added
1191 delaybeforesend attribute to control delays with newer versions of
1196 delaybeforesend attribute to control delays with newer versions of
1192 pexpect. Thanks to detailed help from pexpect's author, Noah
1197 pexpect. Thanks to detailed help from pexpect's author, Noah
1193 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
1198 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
1194 correctly (it works in NoColor mode).
1199 correctly (it works in NoColor mode).
1195
1200
1196 * IPython/iplib.py (handle_normal): fix nasty crash reported on
1201 * IPython/iplib.py (handle_normal): fix nasty crash reported on
1197 SAGE list, from improper log() calls.
1202 SAGE list, from improper log() calls.
1198
1203
1199 2006-05-31 Ville Vainio <vivainio@gmail.com>
1204 2006-05-31 Ville Vainio <vivainio@gmail.com>
1200
1205
1201 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
1206 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
1202 with args in parens to work correctly with dirs that have spaces.
1207 with args in parens to work correctly with dirs that have spaces.
1203
1208
1204 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
1209 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
1205
1210
1206 * IPython/Logger.py (Logger.logstart): add option to log raw input
1211 * IPython/Logger.py (Logger.logstart): add option to log raw input
1207 instead of the processed one. A -r flag was added to the
1212 instead of the processed one. A -r flag was added to the
1208 %logstart magic used for controlling logging.
1213 %logstart magic used for controlling logging.
1209
1214
1210 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
1215 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
1211
1216
1212 * IPython/iplib.py (InteractiveShell.__init__): add check for the
1217 * IPython/iplib.py (InteractiveShell.__init__): add check for the
1213 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
1218 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
1214 recognize the option. After a bug report by Will Maier. This
1219 recognize the option. After a bug report by Will Maier. This
1215 closes #64 (will do it after confirmation from W. Maier).
1220 closes #64 (will do it after confirmation from W. Maier).
1216
1221
1217 * IPython/irunner.py: New module to run scripts as if manually
1222 * IPython/irunner.py: New module to run scripts as if manually
1218 typed into an interactive environment, based on pexpect. After a
1223 typed into an interactive environment, based on pexpect. After a
1219 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
1224 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
1220 ipython-user list. Simple unittests in the tests/ directory.
1225 ipython-user list. Simple unittests in the tests/ directory.
1221
1226
1222 * tools/release: add Will Maier, OpenBSD port maintainer, to
1227 * tools/release: add Will Maier, OpenBSD port maintainer, to
1223 recepients list. We are now officially part of the OpenBSD ports:
1228 recepients list. We are now officially part of the OpenBSD ports:
1224 http://www.openbsd.org/ports.html ! Many thanks to Will for the
1229 http://www.openbsd.org/ports.html ! Many thanks to Will for the
1225 work.
1230 work.
1226
1231
1227 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
1232 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
1228
1233
1229 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
1234 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
1230 so that it doesn't break tkinter apps.
1235 so that it doesn't break tkinter apps.
1231
1236
1232 * IPython/iplib.py (_prefilter): fix bug where aliases would
1237 * IPython/iplib.py (_prefilter): fix bug where aliases would
1233 shadow variables when autocall was fully off. Reported by SAGE
1238 shadow variables when autocall was fully off. Reported by SAGE
1234 author William Stein.
1239 author William Stein.
1235
1240
1236 * IPython/OInspect.py (Inspector.__init__): add a flag to control
1241 * IPython/OInspect.py (Inspector.__init__): add a flag to control
1237 at what detail level strings are computed when foo? is requested.
1242 at what detail level strings are computed when foo? is requested.
1238 This allows users to ask for example that the string form of an
1243 This allows users to ask for example that the string form of an
1239 object is only computed when foo?? is called, or even never, by
1244 object is only computed when foo?? is called, or even never, by
1240 setting the object_info_string_level >= 2 in the configuration
1245 setting the object_info_string_level >= 2 in the configuration
1241 file. This new option has been added and documented. After a
1246 file. This new option has been added and documented. After a
1242 request by SAGE to be able to control the printing of very large
1247 request by SAGE to be able to control the printing of very large
1243 objects more easily.
1248 objects more easily.
1244
1249
1245 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
1250 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
1246
1251
1247 * IPython/ipmaker.py (make_IPython): remove the ipython call path
1252 * IPython/ipmaker.py (make_IPython): remove the ipython call path
1248 from sys.argv, to be 100% consistent with how Python itself works
1253 from sys.argv, to be 100% consistent with how Python itself works
1249 (as seen for example with python -i file.py). After a bug report
1254 (as seen for example with python -i file.py). After a bug report
1250 by Jeffrey Collins.
1255 by Jeffrey Collins.
1251
1256
1252 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
1257 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
1253 nasty bug which was preventing custom namespaces with -pylab,
1258 nasty bug which was preventing custom namespaces with -pylab,
1254 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
1259 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
1255 compatibility (long gone from mpl).
1260 compatibility (long gone from mpl).
1256
1261
1257 * IPython/ipapi.py (make_session): name change: create->make. We
1262 * IPython/ipapi.py (make_session): name change: create->make. We
1258 use make in other places (ipmaker,...), it's shorter and easier to
1263 use make in other places (ipmaker,...), it's shorter and easier to
1259 type and say, etc. I'm trying to clean things before 0.7.2 so
1264 type and say, etc. I'm trying to clean things before 0.7.2 so
1260 that I can keep things stable wrt to ipapi in the chainsaw branch.
1265 that I can keep things stable wrt to ipapi in the chainsaw branch.
1261
1266
1262 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
1267 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
1263 python-mode recognizes our debugger mode. Add support for
1268 python-mode recognizes our debugger mode. Add support for
1264 autoindent inside (X)emacs. After a patch sent in by Jin Liu
1269 autoindent inside (X)emacs. After a patch sent in by Jin Liu
1265 <m.liu.jin-AT-gmail.com> originally written by
1270 <m.liu.jin-AT-gmail.com> originally written by
1266 doxgen-AT-newsmth.net (with minor modifications for xemacs
1271 doxgen-AT-newsmth.net (with minor modifications for xemacs
1267 compatibility)
1272 compatibility)
1268
1273
1269 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
1274 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
1270 tracebacks when walking the stack so that the stack tracking system
1275 tracebacks when walking the stack so that the stack tracking system
1271 in emacs' python-mode can identify the frames correctly.
1276 in emacs' python-mode can identify the frames correctly.
1272
1277
1273 * IPython/ipmaker.py (make_IPython): make the internal (and
1278 * IPython/ipmaker.py (make_IPython): make the internal (and
1274 default config) autoedit_syntax value false by default. Too many
1279 default config) autoedit_syntax value false by default. Too many
1275 users have complained to me (both on and off-list) about problems
1280 users have complained to me (both on and off-list) about problems
1276 with this option being on by default, so I'm making it default to
1281 with this option being on by default, so I'm making it default to
1277 off. It can still be enabled by anyone via the usual mechanisms.
1282 off. It can still be enabled by anyone via the usual mechanisms.
1278
1283
1279 * IPython/completer.py (Completer.attr_matches): add support for
1284 * IPython/completer.py (Completer.attr_matches): add support for
1280 PyCrust-style _getAttributeNames magic method. Patch contributed
1285 PyCrust-style _getAttributeNames magic method. Patch contributed
1281 by <mscott-AT-goldenspud.com>. Closes #50.
1286 by <mscott-AT-goldenspud.com>. Closes #50.
1282
1287
1283 * IPython/iplib.py (InteractiveShell.__init__): remove the
1288 * IPython/iplib.py (InteractiveShell.__init__): remove the
1284 deletion of exit/quit from __builtin__, which can break
1289 deletion of exit/quit from __builtin__, which can break
1285 third-party tools like the Zope debugging console. The
1290 third-party tools like the Zope debugging console. The
1286 %exit/%quit magics remain. In general, it's probably a good idea
1291 %exit/%quit magics remain. In general, it's probably a good idea
1287 not to delete anything from __builtin__, since we never know what
1292 not to delete anything from __builtin__, since we never know what
1288 that will break. In any case, python now (for 2.5) will support
1293 that will break. In any case, python now (for 2.5) will support
1289 'real' exit/quit, so this issue is moot. Closes #55.
1294 'real' exit/quit, so this issue is moot. Closes #55.
1290
1295
1291 * IPython/genutils.py (with_obj): rename the 'with' function to
1296 * IPython/genutils.py (with_obj): rename the 'with' function to
1292 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
1297 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
1293 becomes a language keyword. Closes #53.
1298 becomes a language keyword. Closes #53.
1294
1299
1295 * IPython/FakeModule.py (FakeModule.__init__): add a proper
1300 * IPython/FakeModule.py (FakeModule.__init__): add a proper
1296 __file__ attribute to this so it fools more things into thinking
1301 __file__ attribute to this so it fools more things into thinking
1297 it is a real module. Closes #59.
1302 it is a real module. Closes #59.
1298
1303
1299 * IPython/Magic.py (magic_edit): add -n option to open the editor
1304 * IPython/Magic.py (magic_edit): add -n option to open the editor
1300 at a specific line number. After a patch by Stefan van der Walt.
1305 at a specific line number. After a patch by Stefan van der Walt.
1301
1306
1302 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
1307 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
1303
1308
1304 * IPython/iplib.py (edit_syntax_error): fix crash when for some
1309 * IPython/iplib.py (edit_syntax_error): fix crash when for some
1305 reason the file could not be opened. After automatic crash
1310 reason the file could not be opened. After automatic crash
1306 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
1311 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
1307 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
1312 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
1308 (_should_recompile): Don't fire editor if using %bg, since there
1313 (_should_recompile): Don't fire editor if using %bg, since there
1309 is no file in the first place. From the same report as above.
1314 is no file in the first place. From the same report as above.
1310 (raw_input): protect against faulty third-party prefilters. After
1315 (raw_input): protect against faulty third-party prefilters. After
1311 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
1316 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
1312 while running under SAGE.
1317 while running under SAGE.
1313
1318
1314 2006-05-23 Ville Vainio <vivainio@gmail.com>
1319 2006-05-23 Ville Vainio <vivainio@gmail.com>
1315
1320
1316 * ipapi.py: Stripped down ip.to_user_ns() to work only as
1321 * ipapi.py: Stripped down ip.to_user_ns() to work only as
1317 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
1322 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
1318 now returns None (again), unless dummy is specifically allowed by
1323 now returns None (again), unless dummy is specifically allowed by
1319 ipapi.get(allow_dummy=True).
1324 ipapi.get(allow_dummy=True).
1320
1325
1321 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
1326 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
1322
1327
1323 * IPython: remove all 2.2-compatibility objects and hacks from
1328 * IPython: remove all 2.2-compatibility objects and hacks from
1324 everywhere, since we only support 2.3 at this point. Docs
1329 everywhere, since we only support 2.3 at this point. Docs
1325 updated.
1330 updated.
1326
1331
1327 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
1332 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
1328 Anything requiring extra validation can be turned into a Python
1333 Anything requiring extra validation can be turned into a Python
1329 property in the future. I used a property for the db one b/c
1334 property in the future. I used a property for the db one b/c
1330 there was a nasty circularity problem with the initialization
1335 there was a nasty circularity problem with the initialization
1331 order, which right now I don't have time to clean up.
1336 order, which right now I don't have time to clean up.
1332
1337
1333 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
1338 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
1334 another locking bug reported by Jorgen. I'm not 100% sure though,
1339 another locking bug reported by Jorgen. I'm not 100% sure though,
1335 so more testing is needed...
1340 so more testing is needed...
1336
1341
1337 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
1342 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
1338
1343
1339 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
1344 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
1340 local variables from any routine in user code (typically executed
1345 local variables from any routine in user code (typically executed
1341 with %run) directly into the interactive namespace. Very useful
1346 with %run) directly into the interactive namespace. Very useful
1342 when doing complex debugging.
1347 when doing complex debugging.
1343 (IPythonNotRunning): Changed the default None object to a dummy
1348 (IPythonNotRunning): Changed the default None object to a dummy
1344 whose attributes can be queried as well as called without
1349 whose attributes can be queried as well as called without
1345 exploding, to ease writing code which works transparently both in
1350 exploding, to ease writing code which works transparently both in
1346 and out of ipython and uses some of this API.
1351 and out of ipython and uses some of this API.
1347
1352
1348 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
1353 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
1349
1354
1350 * IPython/hooks.py (result_display): Fix the fact that our display
1355 * IPython/hooks.py (result_display): Fix the fact that our display
1351 hook was using str() instead of repr(), as the default python
1356 hook was using str() instead of repr(), as the default python
1352 console does. This had gone unnoticed b/c it only happened if
1357 console does. This had gone unnoticed b/c it only happened if
1353 %Pprint was off, but the inconsistency was there.
1358 %Pprint was off, but the inconsistency was there.
1354
1359
1355 2006-05-15 Ville Vainio <vivainio@gmail.com>
1360 2006-05-15 Ville Vainio <vivainio@gmail.com>
1356
1361
1357 * Oinspect.py: Only show docstring for nonexisting/binary files
1362 * Oinspect.py: Only show docstring for nonexisting/binary files
1358 when doing object??, closing ticket #62
1363 when doing object??, closing ticket #62
1359
1364
1360 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
1365 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
1361
1366
1362 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
1367 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
1363 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
1368 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
1364 was being released in a routine which hadn't checked if it had
1369 was being released in a routine which hadn't checked if it had
1365 been the one to acquire it.
1370 been the one to acquire it.
1366
1371
1367 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
1372 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
1368
1373
1369 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
1374 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
1370
1375
1371 2006-04-11 Ville Vainio <vivainio@gmail.com>
1376 2006-04-11 Ville Vainio <vivainio@gmail.com>
1372
1377
1373 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
1378 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
1374 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
1379 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
1375 prefilters, allowing stuff like magics and aliases in the file.
1380 prefilters, allowing stuff like magics and aliases in the file.
1376
1381
1377 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
1382 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
1378 added. Supported now are "%clear in" and "%clear out" (clear input and
1383 added. Supported now are "%clear in" and "%clear out" (clear input and
1379 output history, respectively). Also fixed CachedOutput.flush to
1384 output history, respectively). Also fixed CachedOutput.flush to
1380 properly flush the output cache.
1385 properly flush the output cache.
1381
1386
1382 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
1387 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
1383 half-success (and fail explicitly).
1388 half-success (and fail explicitly).
1384
1389
1385 2006-03-28 Ville Vainio <vivainio@gmail.com>
1390 2006-03-28 Ville Vainio <vivainio@gmail.com>
1386
1391
1387 * iplib.py: Fix quoting of aliases so that only argless ones
1392 * iplib.py: Fix quoting of aliases so that only argless ones
1388 are quoted
1393 are quoted
1389
1394
1390 2006-03-28 Ville Vainio <vivainio@gmail.com>
1395 2006-03-28 Ville Vainio <vivainio@gmail.com>
1391
1396
1392 * iplib.py: Quote aliases with spaces in the name.
1397 * iplib.py: Quote aliases with spaces in the name.
1393 "c:\program files\blah\bin" is now legal alias target.
1398 "c:\program files\blah\bin" is now legal alias target.
1394
1399
1395 * ext_rehashdir.py: Space no longer allowed as arg
1400 * ext_rehashdir.py: Space no longer allowed as arg
1396 separator, since space is legal in path names.
1401 separator, since space is legal in path names.
1397
1402
1398 2006-03-16 Ville Vainio <vivainio@gmail.com>
1403 2006-03-16 Ville Vainio <vivainio@gmail.com>
1399
1404
1400 * upgrade_dir.py: Take path.py from Extensions, correcting
1405 * upgrade_dir.py: Take path.py from Extensions, correcting
1401 %upgrade magic
1406 %upgrade magic
1402
1407
1403 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
1408 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
1404
1409
1405 * hooks.py: Only enclose editor binary in quotes if legal and
1410 * hooks.py: Only enclose editor binary in quotes if legal and
1406 necessary (space in the name, and is an existing file). Fixes a bug
1411 necessary (space in the name, and is an existing file). Fixes a bug
1407 reported by Zachary Pincus.
1412 reported by Zachary Pincus.
1408
1413
1409 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
1414 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
1410
1415
1411 * Manual: thanks to a tip on proper color handling for Emacs, by
1416 * Manual: thanks to a tip on proper color handling for Emacs, by
1412 Eric J Haywiser <ejh1-AT-MIT.EDU>.
1417 Eric J Haywiser <ejh1-AT-MIT.EDU>.
1413
1418
1414 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
1419 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
1415 by applying the provided patch. Thanks to Liu Jin
1420 by applying the provided patch. Thanks to Liu Jin
1416 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
1421 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
1417 XEmacs/Linux, I'm trusting the submitter that it actually helps
1422 XEmacs/Linux, I'm trusting the submitter that it actually helps
1418 under win32/GNU Emacs. Will revisit if any problems are reported.
1423 under win32/GNU Emacs. Will revisit if any problems are reported.
1419
1424
1420 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1425 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1421
1426
1422 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
1427 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
1423 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
1428 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
1424
1429
1425 2006-03-12 Ville Vainio <vivainio@gmail.com>
1430 2006-03-12 Ville Vainio <vivainio@gmail.com>
1426
1431
1427 * Magic.py (magic_timeit): Added %timeit magic, contributed by
1432 * Magic.py (magic_timeit): Added %timeit magic, contributed by
1428 Torsten Marek.
1433 Torsten Marek.
1429
1434
1430 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1435 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1431
1436
1432 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
1437 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
1433 line ranges works again.
1438 line ranges works again.
1434
1439
1435 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
1440 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
1436
1441
1437 * IPython/iplib.py (showtraceback): add back sys.last_traceback
1442 * IPython/iplib.py (showtraceback): add back sys.last_traceback
1438 and friends, after a discussion with Zach Pincus on ipython-user.
1443 and friends, after a discussion with Zach Pincus on ipython-user.
1439 I'm not 100% sure, but after thinking about it quite a bit, it may
1444 I'm not 100% sure, but after thinking about it quite a bit, it may
1440 be OK. Testing with the multithreaded shells didn't reveal any
1445 be OK. Testing with the multithreaded shells didn't reveal any
1441 problems, but let's keep an eye out.
1446 problems, but let's keep an eye out.
1442
1447
1443 In the process, I fixed a few things which were calling
1448 In the process, I fixed a few things which were calling
1444 self.InteractiveTB() directly (like safe_execfile), which is a
1449 self.InteractiveTB() directly (like safe_execfile), which is a
1445 mistake: ALL exception reporting should be done by calling
1450 mistake: ALL exception reporting should be done by calling
1446 self.showtraceback(), which handles state and tab-completion and
1451 self.showtraceback(), which handles state and tab-completion and
1447 more.
1452 more.
1448
1453
1449 2006-03-01 Ville Vainio <vivainio@gmail.com>
1454 2006-03-01 Ville Vainio <vivainio@gmail.com>
1450
1455
1451 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
1456 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
1452 To use, do "from ipipe import *".
1457 To use, do "from ipipe import *".
1453
1458
1454 2006-02-24 Ville Vainio <vivainio@gmail.com>
1459 2006-02-24 Ville Vainio <vivainio@gmail.com>
1455
1460
1456 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
1461 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
1457 "cleanly" and safely than the older upgrade mechanism.
1462 "cleanly" and safely than the older upgrade mechanism.
1458
1463
1459 2006-02-21 Ville Vainio <vivainio@gmail.com>
1464 2006-02-21 Ville Vainio <vivainio@gmail.com>
1460
1465
1461 * Magic.py: %save works again.
1466 * Magic.py: %save works again.
1462
1467
1463 2006-02-15 Ville Vainio <vivainio@gmail.com>
1468 2006-02-15 Ville Vainio <vivainio@gmail.com>
1464
1469
1465 * Magic.py: %Pprint works again
1470 * Magic.py: %Pprint works again
1466
1471
1467 * Extensions/ipy_sane_defaults.py: Provide everything provided
1472 * Extensions/ipy_sane_defaults.py: Provide everything provided
1468 in default ipythonrc, to make it possible to have a completely empty
1473 in default ipythonrc, to make it possible to have a completely empty
1469 ipythonrc (and thus completely rc-file free configuration)
1474 ipythonrc (and thus completely rc-file free configuration)
1470
1475
1471 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
1476 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
1472
1477
1473 * IPython/hooks.py (editor): quote the call to the editor command,
1478 * IPython/hooks.py (editor): quote the call to the editor command,
1474 to allow commands with spaces in them. Problem noted by watching
1479 to allow commands with spaces in them. Problem noted by watching
1475 Ian Oswald's video about textpad under win32 at
1480 Ian Oswald's video about textpad under win32 at
1476 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
1481 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
1477
1482
1478 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
1483 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
1479 describing magics (we haven't used @ for a loong time).
1484 describing magics (we haven't used @ for a loong time).
1480
1485
1481 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
1486 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
1482 contributed by marienz to close
1487 contributed by marienz to close
1483 http://www.scipy.net/roundup/ipython/issue53.
1488 http://www.scipy.net/roundup/ipython/issue53.
1484
1489
1485 2006-02-10 Ville Vainio <vivainio@gmail.com>
1490 2006-02-10 Ville Vainio <vivainio@gmail.com>
1486
1491
1487 * genutils.py: getoutput now works in win32 too
1492 * genutils.py: getoutput now works in win32 too
1488
1493
1489 * completer.py: alias and magic completion only invoked
1494 * completer.py: alias and magic completion only invoked
1490 at the first "item" in the line, to avoid "cd %store"
1495 at the first "item" in the line, to avoid "cd %store"
1491 nonsense.
1496 nonsense.
1492
1497
1493 2006-02-09 Ville Vainio <vivainio@gmail.com>
1498 2006-02-09 Ville Vainio <vivainio@gmail.com>
1494
1499
1495 * test/*: Added a unit testing framework (finally).
1500 * test/*: Added a unit testing framework (finally).
1496 '%run runtests.py' to run test_*.
1501 '%run runtests.py' to run test_*.
1497
1502
1498 * ipapi.py: Exposed runlines and set_custom_exc
1503 * ipapi.py: Exposed runlines and set_custom_exc
1499
1504
1500 2006-02-07 Ville Vainio <vivainio@gmail.com>
1505 2006-02-07 Ville Vainio <vivainio@gmail.com>
1501
1506
1502 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
1507 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
1503 instead use "f(1 2)" as before.
1508 instead use "f(1 2)" as before.
1504
1509
1505 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
1510 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
1506
1511
1507 * IPython/demo.py (IPythonDemo): Add new classes to the demo
1512 * IPython/demo.py (IPythonDemo): Add new classes to the demo
1508 facilities, for demos processed by the IPython input filter
1513 facilities, for demos processed by the IPython input filter
1509 (IPythonDemo), and for running a script one-line-at-a-time as a
1514 (IPythonDemo), and for running a script one-line-at-a-time as a
1510 demo, both for pure Python (LineDemo) and for IPython-processed
1515 demo, both for pure Python (LineDemo) and for IPython-processed
1511 input (IPythonLineDemo). After a request by Dave Kohel, from the
1516 input (IPythonLineDemo). After a request by Dave Kohel, from the
1512 SAGE team.
1517 SAGE team.
1513 (Demo.edit): added an edit() method to the demo objects, to edit
1518 (Demo.edit): added an edit() method to the demo objects, to edit
1514 the in-memory copy of the last executed block.
1519 the in-memory copy of the last executed block.
1515
1520
1516 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
1521 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
1517 processing to %edit, %macro and %save. These commands can now be
1522 processing to %edit, %macro and %save. These commands can now be
1518 invoked on the unprocessed input as it was typed by the user
1523 invoked on the unprocessed input as it was typed by the user
1519 (without any prefilters applied). After requests by the SAGE team
1524 (without any prefilters applied). After requests by the SAGE team
1520 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
1525 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
1521
1526
1522 2006-02-01 Ville Vainio <vivainio@gmail.com>
1527 2006-02-01 Ville Vainio <vivainio@gmail.com>
1523
1528
1524 * setup.py, eggsetup.py: easy_install ipython==dev works
1529 * setup.py, eggsetup.py: easy_install ipython==dev works
1525 correctly now (on Linux)
1530 correctly now (on Linux)
1526
1531
1527 * ipy_user_conf,ipmaker: user config changes, removed spurious
1532 * ipy_user_conf,ipmaker: user config changes, removed spurious
1528 warnings
1533 warnings
1529
1534
1530 * iplib: if rc.banner is string, use it as is.
1535 * iplib: if rc.banner is string, use it as is.
1531
1536
1532 * Magic: %pycat accepts a string argument and pages it's contents.
1537 * Magic: %pycat accepts a string argument and pages it's contents.
1533
1538
1534
1539
1535 2006-01-30 Ville Vainio <vivainio@gmail.com>
1540 2006-01-30 Ville Vainio <vivainio@gmail.com>
1536
1541
1537 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
1542 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
1538 Now %store and bookmarks work through PickleShare, meaning that
1543 Now %store and bookmarks work through PickleShare, meaning that
1539 concurrent access is possible and all ipython sessions see the
1544 concurrent access is possible and all ipython sessions see the
1540 same database situation all the time, instead of snapshot of
1545 same database situation all the time, instead of snapshot of
1541 the situation when the session was started. Hence, %bookmark
1546 the situation when the session was started. Hence, %bookmark
1542 results are immediately accessible from othes sessions. The database
1547 results are immediately accessible from othes sessions. The database
1543 is also available for use by user extensions. See:
1548 is also available for use by user extensions. See:
1544 http://www.python.org/pypi/pickleshare
1549 http://www.python.org/pypi/pickleshare
1545
1550
1546 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
1551 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
1547
1552
1548 * aliases can now be %store'd
1553 * aliases can now be %store'd
1549
1554
1550 * path.py moved to Extensions so that pickleshare does not need
1555 * path.py moved to Extensions so that pickleshare does not need
1551 IPython-specific import. Extensions added to pythonpath right
1556 IPython-specific import. Extensions added to pythonpath right
1552 at __init__.
1557 at __init__.
1553
1558
1554 * iplib.py: ipalias deprecated/redundant; aliases are converted and
1559 * iplib.py: ipalias deprecated/redundant; aliases are converted and
1555 called with _ip.system and the pre-transformed command string.
1560 called with _ip.system and the pre-transformed command string.
1556
1561
1557 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
1562 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
1558
1563
1559 * IPython/iplib.py (interact): Fix that we were not catching
1564 * IPython/iplib.py (interact): Fix that we were not catching
1560 KeyboardInterrupt exceptions properly. I'm not quite sure why the
1565 KeyboardInterrupt exceptions properly. I'm not quite sure why the
1561 logic here had to change, but it's fixed now.
1566 logic here had to change, but it's fixed now.
1562
1567
1563 2006-01-29 Ville Vainio <vivainio@gmail.com>
1568 2006-01-29 Ville Vainio <vivainio@gmail.com>
1564
1569
1565 * iplib.py: Try to import pyreadline on Windows.
1570 * iplib.py: Try to import pyreadline on Windows.
1566
1571
1567 2006-01-27 Ville Vainio <vivainio@gmail.com>
1572 2006-01-27 Ville Vainio <vivainio@gmail.com>
1568
1573
1569 * iplib.py: Expose ipapi as _ip in builtin namespace.
1574 * iplib.py: Expose ipapi as _ip in builtin namespace.
1570 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
1575 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
1571 and ip_set_hook (-> _ip.set_hook) redundant. % and !
1576 and ip_set_hook (-> _ip.set_hook) redundant. % and !
1572 syntax now produce _ip.* variant of the commands.
1577 syntax now produce _ip.* variant of the commands.
1573
1578
1574 * "_ip.options().autoedit_syntax = 2" automatically throws
1579 * "_ip.options().autoedit_syntax = 2" automatically throws
1575 user to editor for syntax error correction without prompting.
1580 user to editor for syntax error correction without prompting.
1576
1581
1577 2006-01-27 Ville Vainio <vivainio@gmail.com>
1582 2006-01-27 Ville Vainio <vivainio@gmail.com>
1578
1583
1579 * ipmaker.py: Give "realistic" sys.argv for scripts (without
1584 * ipmaker.py: Give "realistic" sys.argv for scripts (without
1580 'ipython' at argv[0]) executed through command line.
1585 'ipython' at argv[0]) executed through command line.
1581 NOTE: this DEPRECATES calling ipython with multiple scripts
1586 NOTE: this DEPRECATES calling ipython with multiple scripts
1582 ("ipython a.py b.py c.py")
1587 ("ipython a.py b.py c.py")
1583
1588
1584 * iplib.py, hooks.py: Added configurable input prefilter,
1589 * iplib.py, hooks.py: Added configurable input prefilter,
1585 named 'input_prefilter'. See ext_rescapture.py for example
1590 named 'input_prefilter'. See ext_rescapture.py for example
1586 usage.
1591 usage.
1587
1592
1588 * ext_rescapture.py, Magic.py: Better system command output capture
1593 * ext_rescapture.py, Magic.py: Better system command output capture
1589 through 'var = !ls' (deprecates user-visible %sc). Same notation
1594 through 'var = !ls' (deprecates user-visible %sc). Same notation
1590 applies for magics, 'var = %alias' assigns alias list to var.
1595 applies for magics, 'var = %alias' assigns alias list to var.
1591
1596
1592 * ipapi.py: added meta() for accessing extension-usable data store.
1597 * ipapi.py: added meta() for accessing extension-usable data store.
1593
1598
1594 * iplib.py: added InteractiveShell.getapi(). New magics should be
1599 * iplib.py: added InteractiveShell.getapi(). New magics should be
1595 written doing self.getapi() instead of using the shell directly.
1600 written doing self.getapi() instead of using the shell directly.
1596
1601
1597 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
1602 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
1598 %store foo >> ~/myfoo.txt to store variables to files (in clean
1603 %store foo >> ~/myfoo.txt to store variables to files (in clean
1599 textual form, not a restorable pickle).
1604 textual form, not a restorable pickle).
1600
1605
1601 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
1606 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
1602
1607
1603 * usage.py, Magic.py: added %quickref
1608 * usage.py, Magic.py: added %quickref
1604
1609
1605 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
1610 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
1606
1611
1607 * GetoptErrors when invoking magics etc. with wrong args
1612 * GetoptErrors when invoking magics etc. with wrong args
1608 are now more helpful:
1613 are now more helpful:
1609 GetoptError: option -l not recognized (allowed: "qb" )
1614 GetoptError: option -l not recognized (allowed: "qb" )
1610
1615
1611 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
1616 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
1612
1617
1613 * IPython/demo.py (Demo.show): Flush stdout after each block, so
1618 * IPython/demo.py (Demo.show): Flush stdout after each block, so
1614 computationally intensive blocks don't appear to stall the demo.
1619 computationally intensive blocks don't appear to stall the demo.
1615
1620
1616 2006-01-24 Ville Vainio <vivainio@gmail.com>
1621 2006-01-24 Ville Vainio <vivainio@gmail.com>
1617
1622
1618 * iplib.py, hooks.py: 'result_display' hook can return a non-None
1623 * iplib.py, hooks.py: 'result_display' hook can return a non-None
1619 value to manipulate resulting history entry.
1624 value to manipulate resulting history entry.
1620
1625
1621 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
1626 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
1622 to instance methods of IPApi class, to make extending an embedded
1627 to instance methods of IPApi class, to make extending an embedded
1623 IPython feasible. See ext_rehashdir.py for example usage.
1628 IPython feasible. See ext_rehashdir.py for example usage.
1624
1629
1625 * Merged 1071-1076 from branches/0.7.1
1630 * Merged 1071-1076 from branches/0.7.1
1626
1631
1627
1632
1628 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
1633 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
1629
1634
1630 * tools/release (daystamp): Fix build tools to use the new
1635 * tools/release (daystamp): Fix build tools to use the new
1631 eggsetup.py script to build lightweight eggs.
1636 eggsetup.py script to build lightweight eggs.
1632
1637
1633 * Applied changesets 1062 and 1064 before 0.7.1 release.
1638 * Applied changesets 1062 and 1064 before 0.7.1 release.
1634
1639
1635 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
1640 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
1636 see the raw input history (without conversions like %ls ->
1641 see the raw input history (without conversions like %ls ->
1637 ipmagic("ls")). After a request from W. Stein, SAGE
1642 ipmagic("ls")). After a request from W. Stein, SAGE
1638 (http://modular.ucsd.edu/sage) developer. This information is
1643 (http://modular.ucsd.edu/sage) developer. This information is
1639 stored in the input_hist_raw attribute of the IPython instance, so
1644 stored in the input_hist_raw attribute of the IPython instance, so
1640 developers can access it if needed (it's an InputList instance).
1645 developers can access it if needed (it's an InputList instance).
1641
1646
1642 * Versionstring = 0.7.2.svn
1647 * Versionstring = 0.7.2.svn
1643
1648
1644 * eggsetup.py: A separate script for constructing eggs, creates
1649 * eggsetup.py: A separate script for constructing eggs, creates
1645 proper launch scripts even on Windows (an .exe file in
1650 proper launch scripts even on Windows (an .exe file in
1646 \python24\scripts).
1651 \python24\scripts).
1647
1652
1648 * ipapi.py: launch_new_instance, launch entry point needed for the
1653 * ipapi.py: launch_new_instance, launch entry point needed for the
1649 egg.
1654 egg.
1650
1655
1651 2006-01-23 Ville Vainio <vivainio@gmail.com>
1656 2006-01-23 Ville Vainio <vivainio@gmail.com>
1652
1657
1653 * Added %cpaste magic for pasting python code
1658 * Added %cpaste magic for pasting python code
1654
1659
1655 2006-01-22 Ville Vainio <vivainio@gmail.com>
1660 2006-01-22 Ville Vainio <vivainio@gmail.com>
1656
1661
1657 * Merge from branches/0.7.1 into trunk, revs 1052-1057
1662 * Merge from branches/0.7.1 into trunk, revs 1052-1057
1658
1663
1659 * Versionstring = 0.7.2.svn
1664 * Versionstring = 0.7.2.svn
1660
1665
1661 * eggsetup.py: A separate script for constructing eggs, creates
1666 * eggsetup.py: A separate script for constructing eggs, creates
1662 proper launch scripts even on Windows (an .exe file in
1667 proper launch scripts even on Windows (an .exe file in
1663 \python24\scripts).
1668 \python24\scripts).
1664
1669
1665 * ipapi.py: launch_new_instance, launch entry point needed for the
1670 * ipapi.py: launch_new_instance, launch entry point needed for the
1666 egg.
1671 egg.
1667
1672
1668 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
1673 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
1669
1674
1670 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
1675 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
1671 %pfile foo would print the file for foo even if it was a binary.
1676 %pfile foo would print the file for foo even if it was a binary.
1672 Now, extensions '.so' and '.dll' are skipped.
1677 Now, extensions '.so' and '.dll' are skipped.
1673
1678
1674 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
1679 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
1675 bug, where macros would fail in all threaded modes. I'm not 100%
1680 bug, where macros would fail in all threaded modes. I'm not 100%
1676 sure, so I'm going to put out an rc instead of making a release
1681 sure, so I'm going to put out an rc instead of making a release
1677 today, and wait for feedback for at least a few days.
1682 today, and wait for feedback for at least a few days.
1678
1683
1679 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
1684 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
1680 it...) the handling of pasting external code with autoindent on.
1685 it...) the handling of pasting external code with autoindent on.
1681 To get out of a multiline input, the rule will appear for most
1686 To get out of a multiline input, the rule will appear for most
1682 users unchanged: two blank lines or change the indent level
1687 users unchanged: two blank lines or change the indent level
1683 proposed by IPython. But there is a twist now: you can
1688 proposed by IPython. But there is a twist now: you can
1684 add/subtract only *one or two spaces*. If you add/subtract three
1689 add/subtract only *one or two spaces*. If you add/subtract three
1685 or more (unless you completely delete the line), IPython will
1690 or more (unless you completely delete the line), IPython will
1686 accept that line, and you'll need to enter a second one of pure
1691 accept that line, and you'll need to enter a second one of pure
1687 whitespace. I know it sounds complicated, but I can't find a
1692 whitespace. I know it sounds complicated, but I can't find a
1688 different solution that covers all the cases, with the right
1693 different solution that covers all the cases, with the right
1689 heuristics. Hopefully in actual use, nobody will really notice
1694 heuristics. Hopefully in actual use, nobody will really notice
1690 all these strange rules and things will 'just work'.
1695 all these strange rules and things will 'just work'.
1691
1696
1692 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
1697 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
1693
1698
1694 * IPython/iplib.py (interact): catch exceptions which can be
1699 * IPython/iplib.py (interact): catch exceptions which can be
1695 triggered asynchronously by signal handlers. Thanks to an
1700 triggered asynchronously by signal handlers. Thanks to an
1696 automatic crash report, submitted by Colin Kingsley
1701 automatic crash report, submitted by Colin Kingsley
1697 <tercel-AT-gentoo.org>.
1702 <tercel-AT-gentoo.org>.
1698
1703
1699 2006-01-20 Ville Vainio <vivainio@gmail.com>
1704 2006-01-20 Ville Vainio <vivainio@gmail.com>
1700
1705
1701 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
1706 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
1702 (%rehashdir, very useful, try it out) of how to extend ipython
1707 (%rehashdir, very useful, try it out) of how to extend ipython
1703 with new magics. Also added Extensions dir to pythonpath to make
1708 with new magics. Also added Extensions dir to pythonpath to make
1704 importing extensions easy.
1709 importing extensions easy.
1705
1710
1706 * %store now complains when trying to store interactively declared
1711 * %store now complains when trying to store interactively declared
1707 classes / instances of those classes.
1712 classes / instances of those classes.
1708
1713
1709 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
1714 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
1710 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
1715 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
1711 if they exist, and ipy_user_conf.py with some defaults is created for
1716 if they exist, and ipy_user_conf.py with some defaults is created for
1712 the user.
1717 the user.
1713
1718
1714 * Startup rehashing done by the config file, not InterpreterExec.
1719 * Startup rehashing done by the config file, not InterpreterExec.
1715 This means system commands are available even without selecting the
1720 This means system commands are available even without selecting the
1716 pysh profile. It's the sensible default after all.
1721 pysh profile. It's the sensible default after all.
1717
1722
1718 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
1723 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
1719
1724
1720 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
1725 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
1721 multiline code with autoindent on working. But I am really not
1726 multiline code with autoindent on working. But I am really not
1722 sure, so this needs more testing. Will commit a debug-enabled
1727 sure, so this needs more testing. Will commit a debug-enabled
1723 version for now, while I test it some more, so that Ville and
1728 version for now, while I test it some more, so that Ville and
1724 others may also catch any problems. Also made
1729 others may also catch any problems. Also made
1725 self.indent_current_str() a method, to ensure that there's no
1730 self.indent_current_str() a method, to ensure that there's no
1726 chance of the indent space count and the corresponding string
1731 chance of the indent space count and the corresponding string
1727 falling out of sync. All code needing the string should just call
1732 falling out of sync. All code needing the string should just call
1728 the method.
1733 the method.
1729
1734
1730 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
1735 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
1731
1736
1732 * IPython/Magic.py (magic_edit): fix check for when users don't
1737 * IPython/Magic.py (magic_edit): fix check for when users don't
1733 save their output files, the try/except was in the wrong section.
1738 save their output files, the try/except was in the wrong section.
1734
1739
1735 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
1740 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
1736
1741
1737 * IPython/Magic.py (magic_run): fix __file__ global missing from
1742 * IPython/Magic.py (magic_run): fix __file__ global missing from
1738 script's namespace when executed via %run. After a report by
1743 script's namespace when executed via %run. After a report by
1739 Vivian.
1744 Vivian.
1740
1745
1741 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
1746 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
1742 when using python 2.4. The parent constructor changed in 2.4, and
1747 when using python 2.4. The parent constructor changed in 2.4, and
1743 we need to track it directly (we can't call it, as it messes up
1748 we need to track it directly (we can't call it, as it messes up
1744 readline and tab-completion inside our pdb would stop working).
1749 readline and tab-completion inside our pdb would stop working).
1745 After a bug report by R. Bernstein <rocky-AT-panix.com>.
1750 After a bug report by R. Bernstein <rocky-AT-panix.com>.
1746
1751
1747 2006-01-16 Ville Vainio <vivainio@gmail.com>
1752 2006-01-16 Ville Vainio <vivainio@gmail.com>
1748
1753
1749 * Ipython/magic.py: Reverted back to old %edit functionality
1754 * Ipython/magic.py: Reverted back to old %edit functionality
1750 that returns file contents on exit.
1755 that returns file contents on exit.
1751
1756
1752 * IPython/path.py: Added Jason Orendorff's "path" module to
1757 * IPython/path.py: Added Jason Orendorff's "path" module to
1753 IPython tree, http://www.jorendorff.com/articles/python/path/.
1758 IPython tree, http://www.jorendorff.com/articles/python/path/.
1754 You can get path objects conveniently through %sc, and !!, e.g.:
1759 You can get path objects conveniently through %sc, and !!, e.g.:
1755 sc files=ls
1760 sc files=ls
1756 for p in files.paths: # or files.p
1761 for p in files.paths: # or files.p
1757 print p,p.mtime
1762 print p,p.mtime
1758
1763
1759 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
1764 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
1760 now work again without considering the exclusion regexp -
1765 now work again without considering the exclusion regexp -
1761 hence, things like ',foo my/path' turn to 'foo("my/path")'
1766 hence, things like ',foo my/path' turn to 'foo("my/path")'
1762 instead of syntax error.
1767 instead of syntax error.
1763
1768
1764
1769
1765 2006-01-14 Ville Vainio <vivainio@gmail.com>
1770 2006-01-14 Ville Vainio <vivainio@gmail.com>
1766
1771
1767 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
1772 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
1768 ipapi decorators for python 2.4 users, options() provides access to rc
1773 ipapi decorators for python 2.4 users, options() provides access to rc
1769 data.
1774 data.
1770
1775
1771 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
1776 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
1772 as path separators (even on Linux ;-). Space character after
1777 as path separators (even on Linux ;-). Space character after
1773 backslash (as yielded by tab completer) is still space;
1778 backslash (as yielded by tab completer) is still space;
1774 "%cd long\ name" works as expected.
1779 "%cd long\ name" works as expected.
1775
1780
1776 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
1781 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
1777 as "chain of command", with priority. API stays the same,
1782 as "chain of command", with priority. API stays the same,
1778 TryNext exception raised by a hook function signals that
1783 TryNext exception raised by a hook function signals that
1779 current hook failed and next hook should try handling it, as
1784 current hook failed and next hook should try handling it, as
1780 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
1785 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
1781 requested configurable display hook, which is now implemented.
1786 requested configurable display hook, which is now implemented.
1782
1787
1783 2006-01-13 Ville Vainio <vivainio@gmail.com>
1788 2006-01-13 Ville Vainio <vivainio@gmail.com>
1784
1789
1785 * IPython/platutils*.py: platform specific utility functions,
1790 * IPython/platutils*.py: platform specific utility functions,
1786 so far only set_term_title is implemented (change terminal
1791 so far only set_term_title is implemented (change terminal
1787 label in windowing systems). %cd now changes the title to
1792 label in windowing systems). %cd now changes the title to
1788 current dir.
1793 current dir.
1789
1794
1790 * IPython/Release.py: Added myself to "authors" list,
1795 * IPython/Release.py: Added myself to "authors" list,
1791 had to create new files.
1796 had to create new files.
1792
1797
1793 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
1798 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
1794 shell escape; not a known bug but had potential to be one in the
1799 shell escape; not a known bug but had potential to be one in the
1795 future.
1800 future.
1796
1801
1797 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
1802 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
1798 extension API for IPython! See the module for usage example. Fix
1803 extension API for IPython! See the module for usage example. Fix
1799 OInspect for docstring-less magic functions.
1804 OInspect for docstring-less magic functions.
1800
1805
1801
1806
1802 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
1807 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
1803
1808
1804 * IPython/iplib.py (raw_input): temporarily deactivate all
1809 * IPython/iplib.py (raw_input): temporarily deactivate all
1805 attempts at allowing pasting of code with autoindent on. It
1810 attempts at allowing pasting of code with autoindent on. It
1806 introduced bugs (reported by Prabhu) and I can't seem to find a
1811 introduced bugs (reported by Prabhu) and I can't seem to find a
1807 robust combination which works in all cases. Will have to revisit
1812 robust combination which works in all cases. Will have to revisit
1808 later.
1813 later.
1809
1814
1810 * IPython/genutils.py: remove isspace() function. We've dropped
1815 * IPython/genutils.py: remove isspace() function. We've dropped
1811 2.2 compatibility, so it's OK to use the string method.
1816 2.2 compatibility, so it's OK to use the string method.
1812
1817
1813 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1818 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1814
1819
1815 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
1820 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
1816 matching what NOT to autocall on, to include all python binary
1821 matching what NOT to autocall on, to include all python binary
1817 operators (including things like 'and', 'or', 'is' and 'in').
1822 operators (including things like 'and', 'or', 'is' and 'in').
1818 Prompted by a bug report on 'foo & bar', but I realized we had
1823 Prompted by a bug report on 'foo & bar', but I realized we had
1819 many more potential bug cases with other operators. The regexp is
1824 many more potential bug cases with other operators. The regexp is
1820 self.re_exclude_auto, it's fairly commented.
1825 self.re_exclude_auto, it's fairly commented.
1821
1826
1822 2006-01-12 Ville Vainio <vivainio@gmail.com>
1827 2006-01-12 Ville Vainio <vivainio@gmail.com>
1823
1828
1824 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
1829 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
1825 Prettified and hardened string/backslash quoting with ipsystem(),
1830 Prettified and hardened string/backslash quoting with ipsystem(),
1826 ipalias() and ipmagic(). Now even \ characters are passed to
1831 ipalias() and ipmagic(). Now even \ characters are passed to
1827 %magics, !shell escapes and aliases exactly as they are in the
1832 %magics, !shell escapes and aliases exactly as they are in the
1828 ipython command line. Should improve backslash experience,
1833 ipython command line. Should improve backslash experience,
1829 particularly in Windows (path delimiter for some commands that
1834 particularly in Windows (path delimiter for some commands that
1830 won't understand '/'), but Unix benefits as well (regexps). %cd
1835 won't understand '/'), but Unix benefits as well (regexps). %cd
1831 magic still doesn't support backslash path delimiters, though. Also
1836 magic still doesn't support backslash path delimiters, though. Also
1832 deleted all pretense of supporting multiline command strings in
1837 deleted all pretense of supporting multiline command strings in
1833 !system or %magic commands. Thanks to Jerry McRae for suggestions.
1838 !system or %magic commands. Thanks to Jerry McRae for suggestions.
1834
1839
1835 * doc/build_doc_instructions.txt added. Documentation on how to
1840 * doc/build_doc_instructions.txt added. Documentation on how to
1836 use doc/update_manual.py, added yesterday. Both files contributed
1841 use doc/update_manual.py, added yesterday. Both files contributed
1837 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
1842 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
1838 doc/*.sh for deprecation at a later date.
1843 doc/*.sh for deprecation at a later date.
1839
1844
1840 * /ipython.py Added ipython.py to root directory for
1845 * /ipython.py Added ipython.py to root directory for
1841 zero-installation (tar xzvf ipython.tgz; cd ipython; python
1846 zero-installation (tar xzvf ipython.tgz; cd ipython; python
1842 ipython.py) and development convenience (no need to keep doing
1847 ipython.py) and development convenience (no need to keep doing
1843 "setup.py install" between changes).
1848 "setup.py install" between changes).
1844
1849
1845 * Made ! and !! shell escapes work (again) in multiline expressions:
1850 * Made ! and !! shell escapes work (again) in multiline expressions:
1846 if 1:
1851 if 1:
1847 !ls
1852 !ls
1848 !!ls
1853 !!ls
1849
1854
1850 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1855 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1851
1856
1852 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
1857 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
1853 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
1858 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
1854 module in case-insensitive installation. Was causing crashes
1859 module in case-insensitive installation. Was causing crashes
1855 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
1860 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
1856
1861
1857 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
1862 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
1858 <marienz-AT-gentoo.org>, closes
1863 <marienz-AT-gentoo.org>, closes
1859 http://www.scipy.net/roundup/ipython/issue51.
1864 http://www.scipy.net/roundup/ipython/issue51.
1860
1865
1861 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
1866 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
1862
1867
1863 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
1868 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
1864 problem of excessive CPU usage under *nix and keyboard lag under
1869 problem of excessive CPU usage under *nix and keyboard lag under
1865 win32.
1870 win32.
1866
1871
1867 2006-01-10 *** Released version 0.7.0
1872 2006-01-10 *** Released version 0.7.0
1868
1873
1869 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
1874 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
1870
1875
1871 * IPython/Release.py (revision): tag version number to 0.7.0,
1876 * IPython/Release.py (revision): tag version number to 0.7.0,
1872 ready for release.
1877 ready for release.
1873
1878
1874 * IPython/Magic.py (magic_edit): Add print statement to %edit so
1879 * IPython/Magic.py (magic_edit): Add print statement to %edit so
1875 it informs the user of the name of the temp. file used. This can
1880 it informs the user of the name of the temp. file used. This can
1876 help if you decide later to reuse that same file, so you know
1881 help if you decide later to reuse that same file, so you know
1877 where to copy the info from.
1882 where to copy the info from.
1878
1883
1879 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
1884 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
1880
1885
1881 * setup_bdist_egg.py: little script to build an egg. Added
1886 * setup_bdist_egg.py: little script to build an egg. Added
1882 support in the release tools as well.
1887 support in the release tools as well.
1883
1888
1884 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
1889 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
1885
1890
1886 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
1891 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
1887 version selection (new -wxversion command line and ipythonrc
1892 version selection (new -wxversion command line and ipythonrc
1888 parameter). Patch contributed by Arnd Baecker
1893 parameter). Patch contributed by Arnd Baecker
1889 <arnd.baecker-AT-web.de>.
1894 <arnd.baecker-AT-web.de>.
1890
1895
1891 * IPython/iplib.py (embed_mainloop): fix tab-completion in
1896 * IPython/iplib.py (embed_mainloop): fix tab-completion in
1892 embedded instances, for variables defined at the interactive
1897 embedded instances, for variables defined at the interactive
1893 prompt of the embedded ipython. Reported by Arnd.
1898 prompt of the embedded ipython. Reported by Arnd.
1894
1899
1895 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
1900 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
1896 it can be used as a (stateful) toggle, or with a direct parameter.
1901 it can be used as a (stateful) toggle, or with a direct parameter.
1897
1902
1898 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
1903 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
1899 could be triggered in certain cases and cause the traceback
1904 could be triggered in certain cases and cause the traceback
1900 printer not to work.
1905 printer not to work.
1901
1906
1902 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
1907 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
1903
1908
1904 * IPython/iplib.py (_should_recompile): Small fix, closes
1909 * IPython/iplib.py (_should_recompile): Small fix, closes
1905 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
1910 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
1906
1911
1907 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
1912 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
1908
1913
1909 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
1914 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
1910 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
1915 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
1911 Moad for help with tracking it down.
1916 Moad for help with tracking it down.
1912
1917
1913 * IPython/iplib.py (handle_auto): fix autocall handling for
1918 * IPython/iplib.py (handle_auto): fix autocall handling for
1914 objects which support BOTH __getitem__ and __call__ (so that f [x]
1919 objects which support BOTH __getitem__ and __call__ (so that f [x]
1915 is left alone, instead of becoming f([x]) automatically).
1920 is left alone, instead of becoming f([x]) automatically).
1916
1921
1917 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
1922 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
1918 Ville's patch.
1923 Ville's patch.
1919
1924
1920 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
1925 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
1921
1926
1922 * IPython/iplib.py (handle_auto): changed autocall semantics to
1927 * IPython/iplib.py (handle_auto): changed autocall semantics to
1923 include 'smart' mode, where the autocall transformation is NOT
1928 include 'smart' mode, where the autocall transformation is NOT
1924 applied if there are no arguments on the line. This allows you to
1929 applied if there are no arguments on the line. This allows you to
1925 just type 'foo' if foo is a callable to see its internal form,
1930 just type 'foo' if foo is a callable to see its internal form,
1926 instead of having it called with no arguments (typically a
1931 instead of having it called with no arguments (typically a
1927 mistake). The old 'full' autocall still exists: for that, you
1932 mistake). The old 'full' autocall still exists: for that, you
1928 need to set the 'autocall' parameter to 2 in your ipythonrc file.
1933 need to set the 'autocall' parameter to 2 in your ipythonrc file.
1929
1934
1930 * IPython/completer.py (Completer.attr_matches): add
1935 * IPython/completer.py (Completer.attr_matches): add
1931 tab-completion support for Enthoughts' traits. After a report by
1936 tab-completion support for Enthoughts' traits. After a report by
1932 Arnd and a patch by Prabhu.
1937 Arnd and a patch by Prabhu.
1933
1938
1934 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
1939 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
1935
1940
1936 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
1941 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
1937 Schmolck's patch to fix inspect.getinnerframes().
1942 Schmolck's patch to fix inspect.getinnerframes().
1938
1943
1939 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
1944 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
1940 for embedded instances, regarding handling of namespaces and items
1945 for embedded instances, regarding handling of namespaces and items
1941 added to the __builtin__ one. Multiple embedded instances and
1946 added to the __builtin__ one. Multiple embedded instances and
1942 recursive embeddings should work better now (though I'm not sure
1947 recursive embeddings should work better now (though I'm not sure
1943 I've got all the corner cases fixed, that code is a bit of a brain
1948 I've got all the corner cases fixed, that code is a bit of a brain
1944 twister).
1949 twister).
1945
1950
1946 * IPython/Magic.py (magic_edit): added support to edit in-memory
1951 * IPython/Magic.py (magic_edit): added support to edit in-memory
1947 macros (automatically creates the necessary temp files). %edit
1952 macros (automatically creates the necessary temp files). %edit
1948 also doesn't return the file contents anymore, it's just noise.
1953 also doesn't return the file contents anymore, it's just noise.
1949
1954
1950 * IPython/completer.py (Completer.attr_matches): revert change to
1955 * IPython/completer.py (Completer.attr_matches): revert change to
1951 complete only on attributes listed in __all__. I realized it
1956 complete only on attributes listed in __all__. I realized it
1952 cripples the tab-completion system as a tool for exploring the
1957 cripples the tab-completion system as a tool for exploring the
1953 internals of unknown libraries (it renders any non-__all__
1958 internals of unknown libraries (it renders any non-__all__
1954 attribute off-limits). I got bit by this when trying to see
1959 attribute off-limits). I got bit by this when trying to see
1955 something inside the dis module.
1960 something inside the dis module.
1956
1961
1957 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
1962 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
1958
1963
1959 * IPython/iplib.py (InteractiveShell.__init__): add .meta
1964 * IPython/iplib.py (InteractiveShell.__init__): add .meta
1960 namespace for users and extension writers to hold data in. This
1965 namespace for users and extension writers to hold data in. This
1961 follows the discussion in
1966 follows the discussion in
1962 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
1967 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
1963
1968
1964 * IPython/completer.py (IPCompleter.complete): small patch to help
1969 * IPython/completer.py (IPCompleter.complete): small patch to help
1965 tab-completion under Emacs, after a suggestion by John Barnard
1970 tab-completion under Emacs, after a suggestion by John Barnard
1966 <barnarj-AT-ccf.org>.
1971 <barnarj-AT-ccf.org>.
1967
1972
1968 * IPython/Magic.py (Magic.extract_input_slices): added support for
1973 * IPython/Magic.py (Magic.extract_input_slices): added support for
1969 the slice notation in magics to use N-M to represent numbers N...M
1974 the slice notation in magics to use N-M to represent numbers N...M
1970 (closed endpoints). This is used by %macro and %save.
1975 (closed endpoints). This is used by %macro and %save.
1971
1976
1972 * IPython/completer.py (Completer.attr_matches): for modules which
1977 * IPython/completer.py (Completer.attr_matches): for modules which
1973 define __all__, complete only on those. After a patch by Jeffrey
1978 define __all__, complete only on those. After a patch by Jeffrey
1974 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
1979 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
1975 speed up this routine.
1980 speed up this routine.
1976
1981
1977 * IPython/Logger.py (Logger.log): fix a history handling bug. I
1982 * IPython/Logger.py (Logger.log): fix a history handling bug. I
1978 don't know if this is the end of it, but the behavior now is
1983 don't know if this is the end of it, but the behavior now is
1979 certainly much more correct. Note that coupled with macros,
1984 certainly much more correct. Note that coupled with macros,
1980 slightly surprising (at first) behavior may occur: a macro will in
1985 slightly surprising (at first) behavior may occur: a macro will in
1981 general expand to multiple lines of input, so upon exiting, the
1986 general expand to multiple lines of input, so upon exiting, the
1982 in/out counters will both be bumped by the corresponding amount
1987 in/out counters will both be bumped by the corresponding amount
1983 (as if the macro's contents had been typed interactively). Typing
1988 (as if the macro's contents had been typed interactively). Typing
1984 %hist will reveal the intermediate (silently processed) lines.
1989 %hist will reveal the intermediate (silently processed) lines.
1985
1990
1986 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
1991 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
1987 pickle to fail (%run was overwriting __main__ and not restoring
1992 pickle to fail (%run was overwriting __main__ and not restoring
1988 it, but pickle relies on __main__ to operate).
1993 it, but pickle relies on __main__ to operate).
1989
1994
1990 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
1995 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
1991 using properties, but forgot to make the main InteractiveShell
1996 using properties, but forgot to make the main InteractiveShell
1992 class a new-style class. Properties fail silently, and
1997 class a new-style class. Properties fail silently, and
1993 mysteriously, with old-style class (getters work, but
1998 mysteriously, with old-style class (getters work, but
1994 setters don't do anything).
1999 setters don't do anything).
1995
2000
1996 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
2001 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
1997
2002
1998 * IPython/Magic.py (magic_history): fix history reporting bug (I
2003 * IPython/Magic.py (magic_history): fix history reporting bug (I
1999 know some nasties are still there, I just can't seem to find a
2004 know some nasties are still there, I just can't seem to find a
2000 reproducible test case to track them down; the input history is
2005 reproducible test case to track them down; the input history is
2001 falling out of sync...)
2006 falling out of sync...)
2002
2007
2003 * IPython/iplib.py (handle_shell_escape): fix bug where both
2008 * IPython/iplib.py (handle_shell_escape): fix bug where both
2004 aliases and system accesses where broken for indented code (such
2009 aliases and system accesses where broken for indented code (such
2005 as loops).
2010 as loops).
2006
2011
2007 * IPython/genutils.py (shell): fix small but critical bug for
2012 * IPython/genutils.py (shell): fix small but critical bug for
2008 win32 system access.
2013 win32 system access.
2009
2014
2010 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
2015 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
2011
2016
2012 * IPython/iplib.py (showtraceback): remove use of the
2017 * IPython/iplib.py (showtraceback): remove use of the
2013 sys.last_{type/value/traceback} structures, which are non
2018 sys.last_{type/value/traceback} structures, which are non
2014 thread-safe.
2019 thread-safe.
2015 (_prefilter): change control flow to ensure that we NEVER
2020 (_prefilter): change control flow to ensure that we NEVER
2016 introspect objects when autocall is off. This will guarantee that
2021 introspect objects when autocall is off. This will guarantee that
2017 having an input line of the form 'x.y', where access to attribute
2022 having an input line of the form 'x.y', where access to attribute
2018 'y' has side effects, doesn't trigger the side effect TWICE. It
2023 'y' has side effects, doesn't trigger the side effect TWICE. It
2019 is important to note that, with autocall on, these side effects
2024 is important to note that, with autocall on, these side effects
2020 can still happen.
2025 can still happen.
2021 (ipsystem): new builtin, to complete the ip{magic/alias/system}
2026 (ipsystem): new builtin, to complete the ip{magic/alias/system}
2022 trio. IPython offers these three kinds of special calls which are
2027 trio. IPython offers these three kinds of special calls which are
2023 not python code, and it's a good thing to have their call method
2028 not python code, and it's a good thing to have their call method
2024 be accessible as pure python functions (not just special syntax at
2029 be accessible as pure python functions (not just special syntax at
2025 the command line). It gives us a better internal implementation
2030 the command line). It gives us a better internal implementation
2026 structure, as well as exposing these for user scripting more
2031 structure, as well as exposing these for user scripting more
2027 cleanly.
2032 cleanly.
2028
2033
2029 * IPython/macro.py (Macro.__init__): moved macros to a standalone
2034 * IPython/macro.py (Macro.__init__): moved macros to a standalone
2030 file. Now that they'll be more likely to be used with the
2035 file. Now that they'll be more likely to be used with the
2031 persistance system (%store), I want to make sure their module path
2036 persistance system (%store), I want to make sure their module path
2032 doesn't change in the future, so that we don't break things for
2037 doesn't change in the future, so that we don't break things for
2033 users' persisted data.
2038 users' persisted data.
2034
2039
2035 * IPython/iplib.py (autoindent_update): move indentation
2040 * IPython/iplib.py (autoindent_update): move indentation
2036 management into the _text_ processing loop, not the keyboard
2041 management into the _text_ processing loop, not the keyboard
2037 interactive one. This is necessary to correctly process non-typed
2042 interactive one. This is necessary to correctly process non-typed
2038 multiline input (such as macros).
2043 multiline input (such as macros).
2039
2044
2040 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
2045 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
2041 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
2046 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
2042 which was producing problems in the resulting manual.
2047 which was producing problems in the resulting manual.
2043 (magic_whos): improve reporting of instances (show their class,
2048 (magic_whos): improve reporting of instances (show their class,
2044 instead of simply printing 'instance' which isn't terribly
2049 instead of simply printing 'instance' which isn't terribly
2045 informative).
2050 informative).
2046
2051
2047 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
2052 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
2048 (minor mods) to support network shares under win32.
2053 (minor mods) to support network shares under win32.
2049
2054
2050 * IPython/winconsole.py (get_console_size): add new winconsole
2055 * IPython/winconsole.py (get_console_size): add new winconsole
2051 module and fixes to page_dumb() to improve its behavior under
2056 module and fixes to page_dumb() to improve its behavior under
2052 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
2057 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
2053
2058
2054 * IPython/Magic.py (Macro): simplified Macro class to just
2059 * IPython/Magic.py (Macro): simplified Macro class to just
2055 subclass list. We've had only 2.2 compatibility for a very long
2060 subclass list. We've had only 2.2 compatibility for a very long
2056 time, yet I was still avoiding subclassing the builtin types. No
2061 time, yet I was still avoiding subclassing the builtin types. No
2057 more (I'm also starting to use properties, though I won't shift to
2062 more (I'm also starting to use properties, though I won't shift to
2058 2.3-specific features quite yet).
2063 2.3-specific features quite yet).
2059 (magic_store): added Ville's patch for lightweight variable
2064 (magic_store): added Ville's patch for lightweight variable
2060 persistence, after a request on the user list by Matt Wilkie
2065 persistence, after a request on the user list by Matt Wilkie
2061 <maphew-AT-gmail.com>. The new %store magic's docstring has full
2066 <maphew-AT-gmail.com>. The new %store magic's docstring has full
2062 details.
2067 details.
2063
2068
2064 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2069 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2065 changed the default logfile name from 'ipython.log' to
2070 changed the default logfile name from 'ipython.log' to
2066 'ipython_log.py'. These logs are real python files, and now that
2071 'ipython_log.py'. These logs are real python files, and now that
2067 we have much better multiline support, people are more likely to
2072 we have much better multiline support, people are more likely to
2068 want to use them as such. Might as well name them correctly.
2073 want to use them as such. Might as well name them correctly.
2069
2074
2070 * IPython/Magic.py: substantial cleanup. While we can't stop
2075 * IPython/Magic.py: substantial cleanup. While we can't stop
2071 using magics as mixins, due to the existing customizations 'out
2076 using magics as mixins, due to the existing customizations 'out
2072 there' which rely on the mixin naming conventions, at least I
2077 there' which rely on the mixin naming conventions, at least I
2073 cleaned out all cross-class name usage. So once we are OK with
2078 cleaned out all cross-class name usage. So once we are OK with
2074 breaking compatibility, the two systems can be separated.
2079 breaking compatibility, the two systems can be separated.
2075
2080
2076 * IPython/Logger.py: major cleanup. This one is NOT a mixin
2081 * IPython/Logger.py: major cleanup. This one is NOT a mixin
2077 anymore, and the class is a fair bit less hideous as well. New
2082 anymore, and the class is a fair bit less hideous as well. New
2078 features were also introduced: timestamping of input, and logging
2083 features were also introduced: timestamping of input, and logging
2079 of output results. These are user-visible with the -t and -o
2084 of output results. These are user-visible with the -t and -o
2080 options to %logstart. Closes
2085 options to %logstart. Closes
2081 http://www.scipy.net/roundup/ipython/issue11 and a request by
2086 http://www.scipy.net/roundup/ipython/issue11 and a request by
2082 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
2087 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
2083
2088
2084 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
2089 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
2085
2090
2086 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
2091 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
2087 better handle backslashes in paths. See the thread 'More Windows
2092 better handle backslashes in paths. See the thread 'More Windows
2088 questions part 2 - \/ characters revisited' on the iypthon user
2093 questions part 2 - \/ characters revisited' on the iypthon user
2089 list:
2094 list:
2090 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
2095 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
2091
2096
2092 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
2097 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
2093
2098
2094 (InteractiveShell.__init__): change threaded shells to not use the
2099 (InteractiveShell.__init__): change threaded shells to not use the
2095 ipython crash handler. This was causing more problems than not,
2100 ipython crash handler. This was causing more problems than not,
2096 as exceptions in the main thread (GUI code, typically) would
2101 as exceptions in the main thread (GUI code, typically) would
2097 always show up as a 'crash', when they really weren't.
2102 always show up as a 'crash', when they really weren't.
2098
2103
2099 The colors and exception mode commands (%colors/%xmode) have been
2104 The colors and exception mode commands (%colors/%xmode) have been
2100 synchronized to also take this into account, so users can get
2105 synchronized to also take this into account, so users can get
2101 verbose exceptions for their threaded code as well. I also added
2106 verbose exceptions for their threaded code as well. I also added
2102 support for activating pdb inside this exception handler as well,
2107 support for activating pdb inside this exception handler as well,
2103 so now GUI authors can use IPython's enhanced pdb at runtime.
2108 so now GUI authors can use IPython's enhanced pdb at runtime.
2104
2109
2105 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
2110 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
2106 true by default, and add it to the shipped ipythonrc file. Since
2111 true by default, and add it to the shipped ipythonrc file. Since
2107 this asks the user before proceeding, I think it's OK to make it
2112 this asks the user before proceeding, I think it's OK to make it
2108 true by default.
2113 true by default.
2109
2114
2110 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
2115 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
2111 of the previous special-casing of input in the eval loop. I think
2116 of the previous special-casing of input in the eval loop. I think
2112 this is cleaner, as they really are commands and shouldn't have
2117 this is cleaner, as they really are commands and shouldn't have
2113 a special role in the middle of the core code.
2118 a special role in the middle of the core code.
2114
2119
2115 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
2120 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
2116
2121
2117 * IPython/iplib.py (edit_syntax_error): added support for
2122 * IPython/iplib.py (edit_syntax_error): added support for
2118 automatically reopening the editor if the file had a syntax error
2123 automatically reopening the editor if the file had a syntax error
2119 in it. Thanks to scottt who provided the patch at:
2124 in it. Thanks to scottt who provided the patch at:
2120 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
2125 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
2121 version committed).
2126 version committed).
2122
2127
2123 * IPython/iplib.py (handle_normal): add suport for multi-line
2128 * IPython/iplib.py (handle_normal): add suport for multi-line
2124 input with emtpy lines. This fixes
2129 input with emtpy lines. This fixes
2125 http://www.scipy.net/roundup/ipython/issue43 and a similar
2130 http://www.scipy.net/roundup/ipython/issue43 and a similar
2126 discussion on the user list.
2131 discussion on the user list.
2127
2132
2128 WARNING: a behavior change is necessarily introduced to support
2133 WARNING: a behavior change is necessarily introduced to support
2129 blank lines: now a single blank line with whitespace does NOT
2134 blank lines: now a single blank line with whitespace does NOT
2130 break the input loop, which means that when autoindent is on, by
2135 break the input loop, which means that when autoindent is on, by
2131 default hitting return on the next (indented) line does NOT exit.
2136 default hitting return on the next (indented) line does NOT exit.
2132
2137
2133 Instead, to exit a multiline input you can either have:
2138 Instead, to exit a multiline input you can either have:
2134
2139
2135 - TWO whitespace lines (just hit return again), or
2140 - TWO whitespace lines (just hit return again), or
2136 - a single whitespace line of a different length than provided
2141 - a single whitespace line of a different length than provided
2137 by the autoindent (add or remove a space).
2142 by the autoindent (add or remove a space).
2138
2143
2139 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
2144 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
2140 module to better organize all readline-related functionality.
2145 module to better organize all readline-related functionality.
2141 I've deleted FlexCompleter and put all completion clases here.
2146 I've deleted FlexCompleter and put all completion clases here.
2142
2147
2143 * IPython/iplib.py (raw_input): improve indentation management.
2148 * IPython/iplib.py (raw_input): improve indentation management.
2144 It is now possible to paste indented code with autoindent on, and
2149 It is now possible to paste indented code with autoindent on, and
2145 the code is interpreted correctly (though it still looks bad on
2150 the code is interpreted correctly (though it still looks bad on
2146 screen, due to the line-oriented nature of ipython).
2151 screen, due to the line-oriented nature of ipython).
2147 (MagicCompleter.complete): change behavior so that a TAB key on an
2152 (MagicCompleter.complete): change behavior so that a TAB key on an
2148 otherwise empty line actually inserts a tab, instead of completing
2153 otherwise empty line actually inserts a tab, instead of completing
2149 on the entire global namespace. This makes it easier to use the
2154 on the entire global namespace. This makes it easier to use the
2150 TAB key for indentation. After a request by Hans Meine
2155 TAB key for indentation. After a request by Hans Meine
2151 <hans_meine-AT-gmx.net>
2156 <hans_meine-AT-gmx.net>
2152 (_prefilter): add support so that typing plain 'exit' or 'quit'
2157 (_prefilter): add support so that typing plain 'exit' or 'quit'
2153 does a sensible thing. Originally I tried to deviate as little as
2158 does a sensible thing. Originally I tried to deviate as little as
2154 possible from the default python behavior, but even that one may
2159 possible from the default python behavior, but even that one may
2155 change in this direction (thread on python-dev to that effect).
2160 change in this direction (thread on python-dev to that effect).
2156 Regardless, ipython should do the right thing even if CPython's
2161 Regardless, ipython should do the right thing even if CPython's
2157 '>>>' prompt doesn't.
2162 '>>>' prompt doesn't.
2158 (InteractiveShell): removed subclassing code.InteractiveConsole
2163 (InteractiveShell): removed subclassing code.InteractiveConsole
2159 class. By now we'd overridden just about all of its methods: I've
2164 class. By now we'd overridden just about all of its methods: I've
2160 copied the remaining two over, and now ipython is a standalone
2165 copied the remaining two over, and now ipython is a standalone
2161 class. This will provide a clearer picture for the chainsaw
2166 class. This will provide a clearer picture for the chainsaw
2162 branch refactoring.
2167 branch refactoring.
2163
2168
2164 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
2169 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
2165
2170
2166 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
2171 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
2167 failures for objects which break when dir() is called on them.
2172 failures for objects which break when dir() is called on them.
2168
2173
2169 * IPython/FlexCompleter.py (Completer.__init__): Added support for
2174 * IPython/FlexCompleter.py (Completer.__init__): Added support for
2170 distinct local and global namespaces in the completer API. This
2175 distinct local and global namespaces in the completer API. This
2171 change allows us to properly handle completion with distinct
2176 change allows us to properly handle completion with distinct
2172 scopes, including in embedded instances (this had never really
2177 scopes, including in embedded instances (this had never really
2173 worked correctly).
2178 worked correctly).
2174
2179
2175 Note: this introduces a change in the constructor for
2180 Note: this introduces a change in the constructor for
2176 MagicCompleter, as a new global_namespace parameter is now the
2181 MagicCompleter, as a new global_namespace parameter is now the
2177 second argument (the others were bumped one position).
2182 second argument (the others were bumped one position).
2178
2183
2179 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
2184 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
2180
2185
2181 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2186 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2182 embedded instances (which can be done now thanks to Vivian's
2187 embedded instances (which can be done now thanks to Vivian's
2183 frame-handling fixes for pdb).
2188 frame-handling fixes for pdb).
2184 (InteractiveShell.__init__): Fix namespace handling problem in
2189 (InteractiveShell.__init__): Fix namespace handling problem in
2185 embedded instances. We were overwriting __main__ unconditionally,
2190 embedded instances. We were overwriting __main__ unconditionally,
2186 and this should only be done for 'full' (non-embedded) IPython;
2191 and this should only be done for 'full' (non-embedded) IPython;
2187 embedded instances must respect the caller's __main__. Thanks to
2192 embedded instances must respect the caller's __main__. Thanks to
2188 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
2193 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
2189
2194
2190 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
2195 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
2191
2196
2192 * setup.py: added download_url to setup(). This registers the
2197 * setup.py: added download_url to setup(). This registers the
2193 download address at PyPI, which is not only useful to humans
2198 download address at PyPI, which is not only useful to humans
2194 browsing the site, but is also picked up by setuptools (the Eggs
2199 browsing the site, but is also picked up by setuptools (the Eggs
2195 machinery). Thanks to Ville and R. Kern for the info/discussion
2200 machinery). Thanks to Ville and R. Kern for the info/discussion
2196 on this.
2201 on this.
2197
2202
2198 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
2203 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
2199
2204
2200 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
2205 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
2201 This brings a lot of nice functionality to the pdb mode, which now
2206 This brings a lot of nice functionality to the pdb mode, which now
2202 has tab-completion, syntax highlighting, and better stack handling
2207 has tab-completion, syntax highlighting, and better stack handling
2203 than before. Many thanks to Vivian De Smedt
2208 than before. Many thanks to Vivian De Smedt
2204 <vivian-AT-vdesmedt.com> for the original patches.
2209 <vivian-AT-vdesmedt.com> for the original patches.
2205
2210
2206 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
2211 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
2207
2212
2208 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
2213 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
2209 sequence to consistently accept the banner argument. The
2214 sequence to consistently accept the banner argument. The
2210 inconsistency was tripping SAGE, thanks to Gary Zablackis
2215 inconsistency was tripping SAGE, thanks to Gary Zablackis
2211 <gzabl-AT-yahoo.com> for the report.
2216 <gzabl-AT-yahoo.com> for the report.
2212
2217
2213 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2218 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2214
2219
2215 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2220 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2216 Fix bug where a naked 'alias' call in the ipythonrc file would
2221 Fix bug where a naked 'alias' call in the ipythonrc file would
2217 cause a crash. Bug reported by Jorgen Stenarson.
2222 cause a crash. Bug reported by Jorgen Stenarson.
2218
2223
2219 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2224 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2220
2225
2221 * IPython/ipmaker.py (make_IPython): cleanups which should improve
2226 * IPython/ipmaker.py (make_IPython): cleanups which should improve
2222 startup time.
2227 startup time.
2223
2228
2224 * IPython/iplib.py (runcode): my globals 'fix' for embedded
2229 * IPython/iplib.py (runcode): my globals 'fix' for embedded
2225 instances had introduced a bug with globals in normal code. Now
2230 instances had introduced a bug with globals in normal code. Now
2226 it's working in all cases.
2231 it's working in all cases.
2227
2232
2228 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
2233 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
2229 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
2234 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
2230 has been introduced to set the default case sensitivity of the
2235 has been introduced to set the default case sensitivity of the
2231 searches. Users can still select either mode at runtime on a
2236 searches. Users can still select either mode at runtime on a
2232 per-search basis.
2237 per-search basis.
2233
2238
2234 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
2239 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
2235
2240
2236 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
2241 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
2237 attributes in wildcard searches for subclasses. Modified version
2242 attributes in wildcard searches for subclasses. Modified version
2238 of a patch by Jorgen.
2243 of a patch by Jorgen.
2239
2244
2240 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
2245 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
2241
2246
2242 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
2247 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
2243 embedded instances. I added a user_global_ns attribute to the
2248 embedded instances. I added a user_global_ns attribute to the
2244 InteractiveShell class to handle this.
2249 InteractiveShell class to handle this.
2245
2250
2246 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
2251 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
2247
2252
2248 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
2253 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
2249 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
2254 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
2250 (reported under win32, but may happen also in other platforms).
2255 (reported under win32, but may happen also in other platforms).
2251 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
2256 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
2252
2257
2253 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
2258 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
2254
2259
2255 * IPython/Magic.py (magic_psearch): new support for wildcard
2260 * IPython/Magic.py (magic_psearch): new support for wildcard
2256 patterns. Now, typing ?a*b will list all names which begin with a
2261 patterns. Now, typing ?a*b will list all names which begin with a
2257 and end in b, for example. The %psearch magic has full
2262 and end in b, for example. The %psearch magic has full
2258 docstrings. Many thanks to JΓΆrgen Stenarson
2263 docstrings. Many thanks to JΓΆrgen Stenarson
2259 <jorgen.stenarson-AT-bostream.nu>, author of the patches
2264 <jorgen.stenarson-AT-bostream.nu>, author of the patches
2260 implementing this functionality.
2265 implementing this functionality.
2261
2266
2262 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2267 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2263
2268
2264 * Manual: fixed long-standing annoyance of double-dashes (as in
2269 * Manual: fixed long-standing annoyance of double-dashes (as in
2265 --prefix=~, for example) being stripped in the HTML version. This
2270 --prefix=~, for example) being stripped in the HTML version. This
2266 is a latex2html bug, but a workaround was provided. Many thanks
2271 is a latex2html bug, but a workaround was provided. Many thanks
2267 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
2272 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
2268 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
2273 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
2269 rolling. This seemingly small issue had tripped a number of users
2274 rolling. This seemingly small issue had tripped a number of users
2270 when first installing, so I'm glad to see it gone.
2275 when first installing, so I'm glad to see it gone.
2271
2276
2272 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2277 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2273
2278
2274 * IPython/Extensions/numeric_formats.py: fix missing import,
2279 * IPython/Extensions/numeric_formats.py: fix missing import,
2275 reported by Stephen Walton.
2280 reported by Stephen Walton.
2276
2281
2277 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
2282 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
2278
2283
2279 * IPython/demo.py: finish demo module, fully documented now.
2284 * IPython/demo.py: finish demo module, fully documented now.
2280
2285
2281 * IPython/genutils.py (file_read): simple little utility to read a
2286 * IPython/genutils.py (file_read): simple little utility to read a
2282 file and ensure it's closed afterwards.
2287 file and ensure it's closed afterwards.
2283
2288
2284 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
2289 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
2285
2290
2286 * IPython/demo.py (Demo.__init__): added support for individually
2291 * IPython/demo.py (Demo.__init__): added support for individually
2287 tagging blocks for automatic execution.
2292 tagging blocks for automatic execution.
2288
2293
2289 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
2294 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
2290 syntax-highlighted python sources, requested by John.
2295 syntax-highlighted python sources, requested by John.
2291
2296
2292 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
2297 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
2293
2298
2294 * IPython/demo.py (Demo.again): fix bug where again() blocks after
2299 * IPython/demo.py (Demo.again): fix bug where again() blocks after
2295 finishing.
2300 finishing.
2296
2301
2297 * IPython/genutils.py (shlex_split): moved from Magic to here,
2302 * IPython/genutils.py (shlex_split): moved from Magic to here,
2298 where all 2.2 compatibility stuff lives. I needed it for demo.py.
2303 where all 2.2 compatibility stuff lives. I needed it for demo.py.
2299
2304
2300 * IPython/demo.py (Demo.__init__): added support for silent
2305 * IPython/demo.py (Demo.__init__): added support for silent
2301 blocks, improved marks as regexps, docstrings written.
2306 blocks, improved marks as regexps, docstrings written.
2302 (Demo.__init__): better docstring, added support for sys.argv.
2307 (Demo.__init__): better docstring, added support for sys.argv.
2303
2308
2304 * IPython/genutils.py (marquee): little utility used by the demo
2309 * IPython/genutils.py (marquee): little utility used by the demo
2305 code, handy in general.
2310 code, handy in general.
2306
2311
2307 * IPython/demo.py (Demo.__init__): new class for interactive
2312 * IPython/demo.py (Demo.__init__): new class for interactive
2308 demos. Not documented yet, I just wrote it in a hurry for
2313 demos. Not documented yet, I just wrote it in a hurry for
2309 scipy'05. Will docstring later.
2314 scipy'05. Will docstring later.
2310
2315
2311 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
2316 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
2312
2317
2313 * IPython/Shell.py (sigint_handler): Drastic simplification which
2318 * IPython/Shell.py (sigint_handler): Drastic simplification which
2314 also seems to make Ctrl-C work correctly across threads! This is
2319 also seems to make Ctrl-C work correctly across threads! This is
2315 so simple, that I can't beleive I'd missed it before. Needs more
2320 so simple, that I can't beleive I'd missed it before. Needs more
2316 testing, though.
2321 testing, though.
2317 (KBINT): Never mind, revert changes. I'm sure I'd tried something
2322 (KBINT): Never mind, revert changes. I'm sure I'd tried something
2318 like this before...
2323 like this before...
2319
2324
2320 * IPython/genutils.py (get_home_dir): add protection against
2325 * IPython/genutils.py (get_home_dir): add protection against
2321 non-dirs in win32 registry.
2326 non-dirs in win32 registry.
2322
2327
2323 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
2328 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
2324 bug where dict was mutated while iterating (pysh crash).
2329 bug where dict was mutated while iterating (pysh crash).
2325
2330
2326 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
2331 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
2327
2332
2328 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
2333 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
2329 spurious newlines added by this routine. After a report by
2334 spurious newlines added by this routine. After a report by
2330 F. Mantegazza.
2335 F. Mantegazza.
2331
2336
2332 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
2337 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
2333
2338
2334 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
2339 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
2335 calls. These were a leftover from the GTK 1.x days, and can cause
2340 calls. These were a leftover from the GTK 1.x days, and can cause
2336 problems in certain cases (after a report by John Hunter).
2341 problems in certain cases (after a report by John Hunter).
2337
2342
2338 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
2343 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
2339 os.getcwd() fails at init time. Thanks to patch from David Remahl
2344 os.getcwd() fails at init time. Thanks to patch from David Remahl
2340 <chmod007-AT-mac.com>.
2345 <chmod007-AT-mac.com>.
2341 (InteractiveShell.__init__): prevent certain special magics from
2346 (InteractiveShell.__init__): prevent certain special magics from
2342 being shadowed by aliases. Closes
2347 being shadowed by aliases. Closes
2343 http://www.scipy.net/roundup/ipython/issue41.
2348 http://www.scipy.net/roundup/ipython/issue41.
2344
2349
2345 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
2350 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
2346
2351
2347 * IPython/iplib.py (InteractiveShell.complete): Added new
2352 * IPython/iplib.py (InteractiveShell.complete): Added new
2348 top-level completion method to expose the completion mechanism
2353 top-level completion method to expose the completion mechanism
2349 beyond readline-based environments.
2354 beyond readline-based environments.
2350
2355
2351 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
2356 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
2352
2357
2353 * tools/ipsvnc (svnversion): fix svnversion capture.
2358 * tools/ipsvnc (svnversion): fix svnversion capture.
2354
2359
2355 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
2360 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
2356 attribute to self, which was missing. Before, it was set by a
2361 attribute to self, which was missing. Before, it was set by a
2357 routine which in certain cases wasn't being called, so the
2362 routine which in certain cases wasn't being called, so the
2358 instance could end up missing the attribute. This caused a crash.
2363 instance could end up missing the attribute. This caused a crash.
2359 Closes http://www.scipy.net/roundup/ipython/issue40.
2364 Closes http://www.scipy.net/roundup/ipython/issue40.
2360
2365
2361 2005-08-16 Fernando Perez <fperez@colorado.edu>
2366 2005-08-16 Fernando Perez <fperez@colorado.edu>
2362
2367
2363 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
2368 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
2364 contains non-string attribute. Closes
2369 contains non-string attribute. Closes
2365 http://www.scipy.net/roundup/ipython/issue38.
2370 http://www.scipy.net/roundup/ipython/issue38.
2366
2371
2367 2005-08-14 Fernando Perez <fperez@colorado.edu>
2372 2005-08-14 Fernando Perez <fperez@colorado.edu>
2368
2373
2369 * tools/ipsvnc: Minor improvements, to add changeset info.
2374 * tools/ipsvnc: Minor improvements, to add changeset info.
2370
2375
2371 2005-08-12 Fernando Perez <fperez@colorado.edu>
2376 2005-08-12 Fernando Perez <fperez@colorado.edu>
2372
2377
2373 * IPython/iplib.py (runsource): remove self.code_to_run_src
2378 * IPython/iplib.py (runsource): remove self.code_to_run_src
2374 attribute. I realized this is nothing more than
2379 attribute. I realized this is nothing more than
2375 '\n'.join(self.buffer), and having the same data in two different
2380 '\n'.join(self.buffer), and having the same data in two different
2376 places is just asking for synchronization bugs. This may impact
2381 places is just asking for synchronization bugs. This may impact
2377 people who have custom exception handlers, so I need to warn
2382 people who have custom exception handlers, so I need to warn
2378 ipython-dev about it (F. Mantegazza may use them).
2383 ipython-dev about it (F. Mantegazza may use them).
2379
2384
2380 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
2385 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
2381
2386
2382 * IPython/genutils.py: fix 2.2 compatibility (generators)
2387 * IPython/genutils.py: fix 2.2 compatibility (generators)
2383
2388
2384 2005-07-18 Fernando Perez <fperez@colorado.edu>
2389 2005-07-18 Fernando Perez <fperez@colorado.edu>
2385
2390
2386 * IPython/genutils.py (get_home_dir): fix to help users with
2391 * IPython/genutils.py (get_home_dir): fix to help users with
2387 invalid $HOME under win32.
2392 invalid $HOME under win32.
2388
2393
2389 2005-07-17 Fernando Perez <fperez@colorado.edu>
2394 2005-07-17 Fernando Perez <fperez@colorado.edu>
2390
2395
2391 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
2396 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
2392 some old hacks and clean up a bit other routines; code should be
2397 some old hacks and clean up a bit other routines; code should be
2393 simpler and a bit faster.
2398 simpler and a bit faster.
2394
2399
2395 * IPython/iplib.py (interact): removed some last-resort attempts
2400 * IPython/iplib.py (interact): removed some last-resort attempts
2396 to survive broken stdout/stderr. That code was only making it
2401 to survive broken stdout/stderr. That code was only making it
2397 harder to abstract out the i/o (necessary for gui integration),
2402 harder to abstract out the i/o (necessary for gui integration),
2398 and the crashes it could prevent were extremely rare in practice
2403 and the crashes it could prevent were extremely rare in practice
2399 (besides being fully user-induced in a pretty violent manner).
2404 (besides being fully user-induced in a pretty violent manner).
2400
2405
2401 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
2406 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
2402 Nothing major yet, but the code is simpler to read; this should
2407 Nothing major yet, but the code is simpler to read; this should
2403 make it easier to do more serious modifications in the future.
2408 make it easier to do more serious modifications in the future.
2404
2409
2405 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
2410 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
2406 which broke in .15 (thanks to a report by Ville).
2411 which broke in .15 (thanks to a report by Ville).
2407
2412
2408 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
2413 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
2409 be quite correct, I know next to nothing about unicode). This
2414 be quite correct, I know next to nothing about unicode). This
2410 will allow unicode strings to be used in prompts, amongst other
2415 will allow unicode strings to be used in prompts, amongst other
2411 cases. It also will prevent ipython from crashing when unicode
2416 cases. It also will prevent ipython from crashing when unicode
2412 shows up unexpectedly in many places. If ascii encoding fails, we
2417 shows up unexpectedly in many places. If ascii encoding fails, we
2413 assume utf_8. Currently the encoding is not a user-visible
2418 assume utf_8. Currently the encoding is not a user-visible
2414 setting, though it could be made so if there is demand for it.
2419 setting, though it could be made so if there is demand for it.
2415
2420
2416 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
2421 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
2417
2422
2418 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
2423 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
2419
2424
2420 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
2425 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
2421
2426
2422 * IPython/genutils.py: Add 2.2 compatibility here, so all other
2427 * IPython/genutils.py: Add 2.2 compatibility here, so all other
2423 code can work transparently for 2.2/2.3.
2428 code can work transparently for 2.2/2.3.
2424
2429
2425 2005-07-16 Fernando Perez <fperez@colorado.edu>
2430 2005-07-16 Fernando Perez <fperez@colorado.edu>
2426
2431
2427 * IPython/ultraTB.py (ExceptionColors): Make a global variable
2432 * IPython/ultraTB.py (ExceptionColors): Make a global variable
2428 out of the color scheme table used for coloring exception
2433 out of the color scheme table used for coloring exception
2429 tracebacks. This allows user code to add new schemes at runtime.
2434 tracebacks. This allows user code to add new schemes at runtime.
2430 This is a minimally modified version of the patch at
2435 This is a minimally modified version of the patch at
2431 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
2436 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
2432 for the contribution.
2437 for the contribution.
2433
2438
2434 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
2439 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
2435 slightly modified version of the patch in
2440 slightly modified version of the patch in
2436 http://www.scipy.net/roundup/ipython/issue34, which also allows me
2441 http://www.scipy.net/roundup/ipython/issue34, which also allows me
2437 to remove the previous try/except solution (which was costlier).
2442 to remove the previous try/except solution (which was costlier).
2438 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
2443 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
2439
2444
2440 2005-06-08 Fernando Perez <fperez@colorado.edu>
2445 2005-06-08 Fernando Perez <fperez@colorado.edu>
2441
2446
2442 * IPython/iplib.py (write/write_err): Add methods to abstract all
2447 * IPython/iplib.py (write/write_err): Add methods to abstract all
2443 I/O a bit more.
2448 I/O a bit more.
2444
2449
2445 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
2450 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
2446 warning, reported by Aric Hagberg, fix by JD Hunter.
2451 warning, reported by Aric Hagberg, fix by JD Hunter.
2447
2452
2448 2005-06-02 *** Released version 0.6.15
2453 2005-06-02 *** Released version 0.6.15
2449
2454
2450 2005-06-01 Fernando Perez <fperez@colorado.edu>
2455 2005-06-01 Fernando Perez <fperez@colorado.edu>
2451
2456
2452 * IPython/iplib.py (MagicCompleter.file_matches): Fix
2457 * IPython/iplib.py (MagicCompleter.file_matches): Fix
2453 tab-completion of filenames within open-quoted strings. Note that
2458 tab-completion of filenames within open-quoted strings. Note that
2454 this requires that in ~/.ipython/ipythonrc, users change the
2459 this requires that in ~/.ipython/ipythonrc, users change the
2455 readline delimiters configuration to read:
2460 readline delimiters configuration to read:
2456
2461
2457 readline_remove_delims -/~
2462 readline_remove_delims -/~
2458
2463
2459
2464
2460 2005-05-31 *** Released version 0.6.14
2465 2005-05-31 *** Released version 0.6.14
2461
2466
2462 2005-05-29 Fernando Perez <fperez@colorado.edu>
2467 2005-05-29 Fernando Perez <fperez@colorado.edu>
2463
2468
2464 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
2469 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
2465 with files not on the filesystem. Reported by Eliyahu Sandler
2470 with files not on the filesystem. Reported by Eliyahu Sandler
2466 <eli@gondolin.net>
2471 <eli@gondolin.net>
2467
2472
2468 2005-05-22 Fernando Perez <fperez@colorado.edu>
2473 2005-05-22 Fernando Perez <fperez@colorado.edu>
2469
2474
2470 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
2475 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
2471 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
2476 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
2472
2477
2473 2005-05-19 Fernando Perez <fperez@colorado.edu>
2478 2005-05-19 Fernando Perez <fperez@colorado.edu>
2474
2479
2475 * IPython/iplib.py (safe_execfile): close a file which could be
2480 * IPython/iplib.py (safe_execfile): close a file which could be
2476 left open (causing problems in win32, which locks open files).
2481 left open (causing problems in win32, which locks open files).
2477 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
2482 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
2478
2483
2479 2005-05-18 Fernando Perez <fperez@colorado.edu>
2484 2005-05-18 Fernando Perez <fperez@colorado.edu>
2480
2485
2481 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
2486 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
2482 keyword arguments correctly to safe_execfile().
2487 keyword arguments correctly to safe_execfile().
2483
2488
2484 2005-05-13 Fernando Perez <fperez@colorado.edu>
2489 2005-05-13 Fernando Perez <fperez@colorado.edu>
2485
2490
2486 * ipython.1: Added info about Qt to manpage, and threads warning
2491 * ipython.1: Added info about Qt to manpage, and threads warning
2487 to usage page (invoked with --help).
2492 to usage page (invoked with --help).
2488
2493
2489 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
2494 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
2490 new matcher (it goes at the end of the priority list) to do
2495 new matcher (it goes at the end of the priority list) to do
2491 tab-completion on named function arguments. Submitted by George
2496 tab-completion on named function arguments. Submitted by George
2492 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
2497 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
2493 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
2498 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
2494 for more details.
2499 for more details.
2495
2500
2496 * IPython/Magic.py (magic_run): Added new -e flag to ignore
2501 * IPython/Magic.py (magic_run): Added new -e flag to ignore
2497 SystemExit exceptions in the script being run. Thanks to a report
2502 SystemExit exceptions in the script being run. Thanks to a report
2498 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
2503 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
2499 producing very annoying behavior when running unit tests.
2504 producing very annoying behavior when running unit tests.
2500
2505
2501 2005-05-12 Fernando Perez <fperez@colorado.edu>
2506 2005-05-12 Fernando Perez <fperez@colorado.edu>
2502
2507
2503 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
2508 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
2504 which I'd broken (again) due to a changed regexp. In the process,
2509 which I'd broken (again) due to a changed regexp. In the process,
2505 added ';' as an escape to auto-quote the whole line without
2510 added ';' as an escape to auto-quote the whole line without
2506 splitting its arguments. Thanks to a report by Jerry McRae
2511 splitting its arguments. Thanks to a report by Jerry McRae
2507 <qrs0xyc02-AT-sneakemail.com>.
2512 <qrs0xyc02-AT-sneakemail.com>.
2508
2513
2509 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
2514 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
2510 possible crashes caused by a TokenError. Reported by Ed Schofield
2515 possible crashes caused by a TokenError. Reported by Ed Schofield
2511 <schofield-AT-ftw.at>.
2516 <schofield-AT-ftw.at>.
2512
2517
2513 2005-05-06 Fernando Perez <fperez@colorado.edu>
2518 2005-05-06 Fernando Perez <fperez@colorado.edu>
2514
2519
2515 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
2520 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
2516
2521
2517 2005-04-29 Fernando Perez <fperez@colorado.edu>
2522 2005-04-29 Fernando Perez <fperez@colorado.edu>
2518
2523
2519 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
2524 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
2520 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
2525 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
2521 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
2526 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
2522 which provides support for Qt interactive usage (similar to the
2527 which provides support for Qt interactive usage (similar to the
2523 existing one for WX and GTK). This had been often requested.
2528 existing one for WX and GTK). This had been often requested.
2524
2529
2525 2005-04-14 *** Released version 0.6.13
2530 2005-04-14 *** Released version 0.6.13
2526
2531
2527 2005-04-08 Fernando Perez <fperez@colorado.edu>
2532 2005-04-08 Fernando Perez <fperez@colorado.edu>
2528
2533
2529 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
2534 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
2530 from _ofind, which gets called on almost every input line. Now,
2535 from _ofind, which gets called on almost every input line. Now,
2531 we only try to get docstrings if they are actually going to be
2536 we only try to get docstrings if they are actually going to be
2532 used (the overhead of fetching unnecessary docstrings can be
2537 used (the overhead of fetching unnecessary docstrings can be
2533 noticeable for certain objects, such as Pyro proxies).
2538 noticeable for certain objects, such as Pyro proxies).
2534
2539
2535 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
2540 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
2536 for completers. For some reason I had been passing them the state
2541 for completers. For some reason I had been passing them the state
2537 variable, which completers never actually need, and was in
2542 variable, which completers never actually need, and was in
2538 conflict with the rlcompleter API. Custom completers ONLY need to
2543 conflict with the rlcompleter API. Custom completers ONLY need to
2539 take the text parameter.
2544 take the text parameter.
2540
2545
2541 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
2546 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
2542 work correctly in pysh. I've also moved all the logic which used
2547 work correctly in pysh. I've also moved all the logic which used
2543 to be in pysh.py here, which will prevent problems with future
2548 to be in pysh.py here, which will prevent problems with future
2544 upgrades. However, this time I must warn users to update their
2549 upgrades. However, this time I must warn users to update their
2545 pysh profile to include the line
2550 pysh profile to include the line
2546
2551
2547 import_all IPython.Extensions.InterpreterExec
2552 import_all IPython.Extensions.InterpreterExec
2548
2553
2549 because otherwise things won't work for them. They MUST also
2554 because otherwise things won't work for them. They MUST also
2550 delete pysh.py and the line
2555 delete pysh.py and the line
2551
2556
2552 execfile pysh.py
2557 execfile pysh.py
2553
2558
2554 from their ipythonrc-pysh.
2559 from their ipythonrc-pysh.
2555
2560
2556 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
2561 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
2557 robust in the face of objects whose dir() returns non-strings
2562 robust in the face of objects whose dir() returns non-strings
2558 (which it shouldn't, but some broken libs like ITK do). Thanks to
2563 (which it shouldn't, but some broken libs like ITK do). Thanks to
2559 a patch by John Hunter (implemented differently, though). Also
2564 a patch by John Hunter (implemented differently, though). Also
2560 minor improvements by using .extend instead of + on lists.
2565 minor improvements by using .extend instead of + on lists.
2561
2566
2562 * pysh.py:
2567 * pysh.py:
2563
2568
2564 2005-04-06 Fernando Perez <fperez@colorado.edu>
2569 2005-04-06 Fernando Perez <fperez@colorado.edu>
2565
2570
2566 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
2571 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
2567 by default, so that all users benefit from it. Those who don't
2572 by default, so that all users benefit from it. Those who don't
2568 want it can still turn it off.
2573 want it can still turn it off.
2569
2574
2570 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
2575 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
2571 config file, I'd forgotten about this, so users were getting it
2576 config file, I'd forgotten about this, so users were getting it
2572 off by default.
2577 off by default.
2573
2578
2574 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
2579 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
2575 consistency. Now magics can be called in multiline statements,
2580 consistency. Now magics can be called in multiline statements,
2576 and python variables can be expanded in magic calls via $var.
2581 and python variables can be expanded in magic calls via $var.
2577 This makes the magic system behave just like aliases or !system
2582 This makes the magic system behave just like aliases or !system
2578 calls.
2583 calls.
2579
2584
2580 2005-03-28 Fernando Perez <fperez@colorado.edu>
2585 2005-03-28 Fernando Perez <fperez@colorado.edu>
2581
2586
2582 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
2587 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
2583 expensive string additions for building command. Add support for
2588 expensive string additions for building command. Add support for
2584 trailing ';' when autocall is used.
2589 trailing ';' when autocall is used.
2585
2590
2586 2005-03-26 Fernando Perez <fperez@colorado.edu>
2591 2005-03-26 Fernando Perez <fperez@colorado.edu>
2587
2592
2588 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
2593 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
2589 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
2594 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
2590 ipython.el robust against prompts with any number of spaces
2595 ipython.el robust against prompts with any number of spaces
2591 (including 0) after the ':' character.
2596 (including 0) after the ':' character.
2592
2597
2593 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
2598 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
2594 continuation prompt, which misled users to think the line was
2599 continuation prompt, which misled users to think the line was
2595 already indented. Closes debian Bug#300847, reported to me by
2600 already indented. Closes debian Bug#300847, reported to me by
2596 Norbert Tretkowski <tretkowski-AT-inittab.de>.
2601 Norbert Tretkowski <tretkowski-AT-inittab.de>.
2597
2602
2598 2005-03-23 Fernando Perez <fperez@colorado.edu>
2603 2005-03-23 Fernando Perez <fperez@colorado.edu>
2599
2604
2600 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
2605 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
2601 properly aligned if they have embedded newlines.
2606 properly aligned if they have embedded newlines.
2602
2607
2603 * IPython/iplib.py (runlines): Add a public method to expose
2608 * IPython/iplib.py (runlines): Add a public method to expose
2604 IPython's code execution machinery, so that users can run strings
2609 IPython's code execution machinery, so that users can run strings
2605 as if they had been typed at the prompt interactively.
2610 as if they had been typed at the prompt interactively.
2606 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
2611 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
2607 methods which can call the system shell, but with python variable
2612 methods which can call the system shell, but with python variable
2608 expansion. The three such methods are: __IPYTHON__.system,
2613 expansion. The three such methods are: __IPYTHON__.system,
2609 .getoutput and .getoutputerror. These need to be documented in a
2614 .getoutput and .getoutputerror. These need to be documented in a
2610 'public API' section (to be written) of the manual.
2615 'public API' section (to be written) of the manual.
2611
2616
2612 2005-03-20 Fernando Perez <fperez@colorado.edu>
2617 2005-03-20 Fernando Perez <fperez@colorado.edu>
2613
2618
2614 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
2619 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
2615 for custom exception handling. This is quite powerful, and it
2620 for custom exception handling. This is quite powerful, and it
2616 allows for user-installable exception handlers which can trap
2621 allows for user-installable exception handlers which can trap
2617 custom exceptions at runtime and treat them separately from
2622 custom exceptions at runtime and treat them separately from
2618 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
2623 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
2619 Mantegazza <mantegazza-AT-ill.fr>.
2624 Mantegazza <mantegazza-AT-ill.fr>.
2620 (InteractiveShell.set_custom_completer): public API function to
2625 (InteractiveShell.set_custom_completer): public API function to
2621 add new completers at runtime.
2626 add new completers at runtime.
2622
2627
2623 2005-03-19 Fernando Perez <fperez@colorado.edu>
2628 2005-03-19 Fernando Perez <fperez@colorado.edu>
2624
2629
2625 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
2630 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
2626 allow objects which provide their docstrings via non-standard
2631 allow objects which provide their docstrings via non-standard
2627 mechanisms (like Pyro proxies) to still be inspected by ipython's
2632 mechanisms (like Pyro proxies) to still be inspected by ipython's
2628 ? system.
2633 ? system.
2629
2634
2630 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
2635 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
2631 automatic capture system. I tried quite hard to make it work
2636 automatic capture system. I tried quite hard to make it work
2632 reliably, and simply failed. I tried many combinations with the
2637 reliably, and simply failed. I tried many combinations with the
2633 subprocess module, but eventually nothing worked in all needed
2638 subprocess module, but eventually nothing worked in all needed
2634 cases (not blocking stdin for the child, duplicating stdout
2639 cases (not blocking stdin for the child, duplicating stdout
2635 without blocking, etc). The new %sc/%sx still do capture to these
2640 without blocking, etc). The new %sc/%sx still do capture to these
2636 magical list/string objects which make shell use much more
2641 magical list/string objects which make shell use much more
2637 conveninent, so not all is lost.
2642 conveninent, so not all is lost.
2638
2643
2639 XXX - FIX MANUAL for the change above!
2644 XXX - FIX MANUAL for the change above!
2640
2645
2641 (runsource): I copied code.py's runsource() into ipython to modify
2646 (runsource): I copied code.py's runsource() into ipython to modify
2642 it a bit. Now the code object and source to be executed are
2647 it a bit. Now the code object and source to be executed are
2643 stored in ipython. This makes this info accessible to third-party
2648 stored in ipython. This makes this info accessible to third-party
2644 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
2649 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
2645 Mantegazza <mantegazza-AT-ill.fr>.
2650 Mantegazza <mantegazza-AT-ill.fr>.
2646
2651
2647 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
2652 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
2648 history-search via readline (like C-p/C-n). I'd wanted this for a
2653 history-search via readline (like C-p/C-n). I'd wanted this for a
2649 long time, but only recently found out how to do it. For users
2654 long time, but only recently found out how to do it. For users
2650 who already have their ipythonrc files made and want this, just
2655 who already have their ipythonrc files made and want this, just
2651 add:
2656 add:
2652
2657
2653 readline_parse_and_bind "\e[A": history-search-backward
2658 readline_parse_and_bind "\e[A": history-search-backward
2654 readline_parse_and_bind "\e[B": history-search-forward
2659 readline_parse_and_bind "\e[B": history-search-forward
2655
2660
2656 2005-03-18 Fernando Perez <fperez@colorado.edu>
2661 2005-03-18 Fernando Perez <fperez@colorado.edu>
2657
2662
2658 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
2663 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
2659 LSString and SList classes which allow transparent conversions
2664 LSString and SList classes which allow transparent conversions
2660 between list mode and whitespace-separated string.
2665 between list mode and whitespace-separated string.
2661 (magic_r): Fix recursion problem in %r.
2666 (magic_r): Fix recursion problem in %r.
2662
2667
2663 * IPython/genutils.py (LSString): New class to be used for
2668 * IPython/genutils.py (LSString): New class to be used for
2664 automatic storage of the results of all alias/system calls in _o
2669 automatic storage of the results of all alias/system calls in _o
2665 and _e (stdout/err). These provide a .l/.list attribute which
2670 and _e (stdout/err). These provide a .l/.list attribute which
2666 does automatic splitting on newlines. This means that for most
2671 does automatic splitting on newlines. This means that for most
2667 uses, you'll never need to do capturing of output with %sc/%sx
2672 uses, you'll never need to do capturing of output with %sc/%sx
2668 anymore, since ipython keeps this always done for you. Note that
2673 anymore, since ipython keeps this always done for you. Note that
2669 only the LAST results are stored, the _o/e variables are
2674 only the LAST results are stored, the _o/e variables are
2670 overwritten on each call. If you need to save their contents
2675 overwritten on each call. If you need to save their contents
2671 further, simply bind them to any other name.
2676 further, simply bind them to any other name.
2672
2677
2673 2005-03-17 Fernando Perez <fperez@colorado.edu>
2678 2005-03-17 Fernando Perez <fperez@colorado.edu>
2674
2679
2675 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
2680 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
2676 prompt namespace handling.
2681 prompt namespace handling.
2677
2682
2678 2005-03-16 Fernando Perez <fperez@colorado.edu>
2683 2005-03-16 Fernando Perez <fperez@colorado.edu>
2679
2684
2680 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
2685 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
2681 classic prompts to be '>>> ' (final space was missing, and it
2686 classic prompts to be '>>> ' (final space was missing, and it
2682 trips the emacs python mode).
2687 trips the emacs python mode).
2683 (BasePrompt.__str__): Added safe support for dynamic prompt
2688 (BasePrompt.__str__): Added safe support for dynamic prompt
2684 strings. Now you can set your prompt string to be '$x', and the
2689 strings. Now you can set your prompt string to be '$x', and the
2685 value of x will be printed from your interactive namespace. The
2690 value of x will be printed from your interactive namespace. The
2686 interpolation syntax includes the full Itpl support, so
2691 interpolation syntax includes the full Itpl support, so
2687 ${foo()+x+bar()} is a valid prompt string now, and the function
2692 ${foo()+x+bar()} is a valid prompt string now, and the function
2688 calls will be made at runtime.
2693 calls will be made at runtime.
2689
2694
2690 2005-03-15 Fernando Perez <fperez@colorado.edu>
2695 2005-03-15 Fernando Perez <fperez@colorado.edu>
2691
2696
2692 * IPython/Magic.py (magic_history): renamed %hist to %history, to
2697 * IPython/Magic.py (magic_history): renamed %hist to %history, to
2693 avoid name clashes in pylab. %hist still works, it just forwards
2698 avoid name clashes in pylab. %hist still works, it just forwards
2694 the call to %history.
2699 the call to %history.
2695
2700
2696 2005-03-02 *** Released version 0.6.12
2701 2005-03-02 *** Released version 0.6.12
2697
2702
2698 2005-03-02 Fernando Perez <fperez@colorado.edu>
2703 2005-03-02 Fernando Perez <fperez@colorado.edu>
2699
2704
2700 * IPython/iplib.py (handle_magic): log magic calls properly as
2705 * IPython/iplib.py (handle_magic): log magic calls properly as
2701 ipmagic() function calls.
2706 ipmagic() function calls.
2702
2707
2703 * IPython/Magic.py (magic_time): Improved %time to support
2708 * IPython/Magic.py (magic_time): Improved %time to support
2704 statements and provide wall-clock as well as CPU time.
2709 statements and provide wall-clock as well as CPU time.
2705
2710
2706 2005-02-27 Fernando Perez <fperez@colorado.edu>
2711 2005-02-27 Fernando Perez <fperez@colorado.edu>
2707
2712
2708 * IPython/hooks.py: New hooks module, to expose user-modifiable
2713 * IPython/hooks.py: New hooks module, to expose user-modifiable
2709 IPython functionality in a clean manner. For now only the editor
2714 IPython functionality in a clean manner. For now only the editor
2710 hook is actually written, and other thigns which I intend to turn
2715 hook is actually written, and other thigns which I intend to turn
2711 into proper hooks aren't yet there. The display and prefilter
2716 into proper hooks aren't yet there. The display and prefilter
2712 stuff, for example, should be hooks. But at least now the
2717 stuff, for example, should be hooks. But at least now the
2713 framework is in place, and the rest can be moved here with more
2718 framework is in place, and the rest can be moved here with more
2714 time later. IPython had had a .hooks variable for a long time for
2719 time later. IPython had had a .hooks variable for a long time for
2715 this purpose, but I'd never actually used it for anything.
2720 this purpose, but I'd never actually used it for anything.
2716
2721
2717 2005-02-26 Fernando Perez <fperez@colorado.edu>
2722 2005-02-26 Fernando Perez <fperez@colorado.edu>
2718
2723
2719 * IPython/ipmaker.py (make_IPython): make the default ipython
2724 * IPython/ipmaker.py (make_IPython): make the default ipython
2720 directory be called _ipython under win32, to follow more the
2725 directory be called _ipython under win32, to follow more the
2721 naming peculiarities of that platform (where buggy software like
2726 naming peculiarities of that platform (where buggy software like
2722 Visual Sourcesafe breaks with .named directories). Reported by
2727 Visual Sourcesafe breaks with .named directories). Reported by
2723 Ville Vainio.
2728 Ville Vainio.
2724
2729
2725 2005-02-23 Fernando Perez <fperez@colorado.edu>
2730 2005-02-23 Fernando Perez <fperez@colorado.edu>
2726
2731
2727 * IPython/iplib.py (InteractiveShell.__init__): removed a few
2732 * IPython/iplib.py (InteractiveShell.__init__): removed a few
2728 auto_aliases for win32 which were causing problems. Users can
2733 auto_aliases for win32 which were causing problems. Users can
2729 define the ones they personally like.
2734 define the ones they personally like.
2730
2735
2731 2005-02-21 Fernando Perez <fperez@colorado.edu>
2736 2005-02-21 Fernando Perez <fperez@colorado.edu>
2732
2737
2733 * IPython/Magic.py (magic_time): new magic to time execution of
2738 * IPython/Magic.py (magic_time): new magic to time execution of
2734 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
2739 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
2735
2740
2736 2005-02-19 Fernando Perez <fperez@colorado.edu>
2741 2005-02-19 Fernando Perez <fperez@colorado.edu>
2737
2742
2738 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
2743 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
2739 into keys (for prompts, for example).
2744 into keys (for prompts, for example).
2740
2745
2741 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
2746 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
2742 prompts in case users want them. This introduces a small behavior
2747 prompts in case users want them. This introduces a small behavior
2743 change: ipython does not automatically add a space to all prompts
2748 change: ipython does not automatically add a space to all prompts
2744 anymore. To get the old prompts with a space, users should add it
2749 anymore. To get the old prompts with a space, users should add it
2745 manually to their ipythonrc file, so for example prompt_in1 should
2750 manually to their ipythonrc file, so for example prompt_in1 should
2746 now read 'In [\#]: ' instead of 'In [\#]:'.
2751 now read 'In [\#]: ' instead of 'In [\#]:'.
2747 (BasePrompt.__init__): New option prompts_pad_left (only in rc
2752 (BasePrompt.__init__): New option prompts_pad_left (only in rc
2748 file) to control left-padding of secondary prompts.
2753 file) to control left-padding of secondary prompts.
2749
2754
2750 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
2755 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
2751 the profiler can't be imported. Fix for Debian, which removed
2756 the profiler can't be imported. Fix for Debian, which removed
2752 profile.py because of License issues. I applied a slightly
2757 profile.py because of License issues. I applied a slightly
2753 modified version of the original Debian patch at
2758 modified version of the original Debian patch at
2754 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
2759 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
2755
2760
2756 2005-02-17 Fernando Perez <fperez@colorado.edu>
2761 2005-02-17 Fernando Perez <fperez@colorado.edu>
2757
2762
2758 * IPython/genutils.py (native_line_ends): Fix bug which would
2763 * IPython/genutils.py (native_line_ends): Fix bug which would
2759 cause improper line-ends under win32 b/c I was not opening files
2764 cause improper line-ends under win32 b/c I was not opening files
2760 in binary mode. Bug report and fix thanks to Ville.
2765 in binary mode. Bug report and fix thanks to Ville.
2761
2766
2762 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
2767 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
2763 trying to catch spurious foo[1] autocalls. My fix actually broke
2768 trying to catch spurious foo[1] autocalls. My fix actually broke
2764 ',/' autoquote/call with explicit escape (bad regexp).
2769 ',/' autoquote/call with explicit escape (bad regexp).
2765
2770
2766 2005-02-15 *** Released version 0.6.11
2771 2005-02-15 *** Released version 0.6.11
2767
2772
2768 2005-02-14 Fernando Perez <fperez@colorado.edu>
2773 2005-02-14 Fernando Perez <fperez@colorado.edu>
2769
2774
2770 * IPython/background_jobs.py: New background job management
2775 * IPython/background_jobs.py: New background job management
2771 subsystem. This is implemented via a new set of classes, and
2776 subsystem. This is implemented via a new set of classes, and
2772 IPython now provides a builtin 'jobs' object for background job
2777 IPython now provides a builtin 'jobs' object for background job
2773 execution. A convenience %bg magic serves as a lightweight
2778 execution. A convenience %bg magic serves as a lightweight
2774 frontend for starting the more common type of calls. This was
2779 frontend for starting the more common type of calls. This was
2775 inspired by discussions with B. Granger and the BackgroundCommand
2780 inspired by discussions with B. Granger and the BackgroundCommand
2776 class described in the book Python Scripting for Computational
2781 class described in the book Python Scripting for Computational
2777 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
2782 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
2778 (although ultimately no code from this text was used, as IPython's
2783 (although ultimately no code from this text was used, as IPython's
2779 system is a separate implementation).
2784 system is a separate implementation).
2780
2785
2781 * IPython/iplib.py (MagicCompleter.python_matches): add new option
2786 * IPython/iplib.py (MagicCompleter.python_matches): add new option
2782 to control the completion of single/double underscore names
2787 to control the completion of single/double underscore names
2783 separately. As documented in the example ipytonrc file, the
2788 separately. As documented in the example ipytonrc file, the
2784 readline_omit__names variable can now be set to 2, to omit even
2789 readline_omit__names variable can now be set to 2, to omit even
2785 single underscore names. Thanks to a patch by Brian Wong
2790 single underscore names. Thanks to a patch by Brian Wong
2786 <BrianWong-AT-AirgoNetworks.Com>.
2791 <BrianWong-AT-AirgoNetworks.Com>.
2787 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
2792 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
2788 be autocalled as foo([1]) if foo were callable. A problem for
2793 be autocalled as foo([1]) if foo were callable. A problem for
2789 things which are both callable and implement __getitem__.
2794 things which are both callable and implement __getitem__.
2790 (init_readline): Fix autoindentation for win32. Thanks to a patch
2795 (init_readline): Fix autoindentation for win32. Thanks to a patch
2791 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
2796 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
2792
2797
2793 2005-02-12 Fernando Perez <fperez@colorado.edu>
2798 2005-02-12 Fernando Perez <fperez@colorado.edu>
2794
2799
2795 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
2800 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
2796 which I had written long ago to sort out user error messages which
2801 which I had written long ago to sort out user error messages which
2797 may occur during startup. This seemed like a good idea initially,
2802 may occur during startup. This seemed like a good idea initially,
2798 but it has proven a disaster in retrospect. I don't want to
2803 but it has proven a disaster in retrospect. I don't want to
2799 change much code for now, so my fix is to set the internal 'debug'
2804 change much code for now, so my fix is to set the internal 'debug'
2800 flag to true everywhere, whose only job was precisely to control
2805 flag to true everywhere, whose only job was precisely to control
2801 this subsystem. This closes issue 28 (as well as avoiding all
2806 this subsystem. This closes issue 28 (as well as avoiding all
2802 sorts of strange hangups which occur from time to time).
2807 sorts of strange hangups which occur from time to time).
2803
2808
2804 2005-02-07 Fernando Perez <fperez@colorado.edu>
2809 2005-02-07 Fernando Perez <fperez@colorado.edu>
2805
2810
2806 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
2811 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
2807 previous call produced a syntax error.
2812 previous call produced a syntax error.
2808
2813
2809 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
2814 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
2810 classes without constructor.
2815 classes without constructor.
2811
2816
2812 2005-02-06 Fernando Perez <fperez@colorado.edu>
2817 2005-02-06 Fernando Perez <fperez@colorado.edu>
2813
2818
2814 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
2819 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
2815 completions with the results of each matcher, so we return results
2820 completions with the results of each matcher, so we return results
2816 to the user from all namespaces. This breaks with ipython
2821 to the user from all namespaces. This breaks with ipython
2817 tradition, but I think it's a nicer behavior. Now you get all
2822 tradition, but I think it's a nicer behavior. Now you get all
2818 possible completions listed, from all possible namespaces (python,
2823 possible completions listed, from all possible namespaces (python,
2819 filesystem, magics...) After a request by John Hunter
2824 filesystem, magics...) After a request by John Hunter
2820 <jdhunter-AT-nitace.bsd.uchicago.edu>.
2825 <jdhunter-AT-nitace.bsd.uchicago.edu>.
2821
2826
2822 2005-02-05 Fernando Perez <fperez@colorado.edu>
2827 2005-02-05 Fernando Perez <fperez@colorado.edu>
2823
2828
2824 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
2829 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
2825 the call had quote characters in it (the quotes were stripped).
2830 the call had quote characters in it (the quotes were stripped).
2826
2831
2827 2005-01-31 Fernando Perez <fperez@colorado.edu>
2832 2005-01-31 Fernando Perez <fperez@colorado.edu>
2828
2833
2829 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
2834 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
2830 Itpl.itpl() to make the code more robust against psyco
2835 Itpl.itpl() to make the code more robust against psyco
2831 optimizations.
2836 optimizations.
2832
2837
2833 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
2838 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
2834 of causing an exception. Quicker, cleaner.
2839 of causing an exception. Quicker, cleaner.
2835
2840
2836 2005-01-28 Fernando Perez <fperez@colorado.edu>
2841 2005-01-28 Fernando Perez <fperez@colorado.edu>
2837
2842
2838 * scripts/ipython_win_post_install.py (install): hardcode
2843 * scripts/ipython_win_post_install.py (install): hardcode
2839 sys.prefix+'python.exe' as the executable path. It turns out that
2844 sys.prefix+'python.exe' as the executable path. It turns out that
2840 during the post-installation run, sys.executable resolves to the
2845 during the post-installation run, sys.executable resolves to the
2841 name of the binary installer! I should report this as a distutils
2846 name of the binary installer! I should report this as a distutils
2842 bug, I think. I updated the .10 release with this tiny fix, to
2847 bug, I think. I updated the .10 release with this tiny fix, to
2843 avoid annoying the lists further.
2848 avoid annoying the lists further.
2844
2849
2845 2005-01-27 *** Released version 0.6.10
2850 2005-01-27 *** Released version 0.6.10
2846
2851
2847 2005-01-27 Fernando Perez <fperez@colorado.edu>
2852 2005-01-27 Fernando Perez <fperez@colorado.edu>
2848
2853
2849 * IPython/numutils.py (norm): Added 'inf' as optional name for
2854 * IPython/numutils.py (norm): Added 'inf' as optional name for
2850 L-infinity norm, included references to mathworld.com for vector
2855 L-infinity norm, included references to mathworld.com for vector
2851 norm definitions.
2856 norm definitions.
2852 (amin/amax): added amin/amax for array min/max. Similar to what
2857 (amin/amax): added amin/amax for array min/max. Similar to what
2853 pylab ships with after the recent reorganization of names.
2858 pylab ships with after the recent reorganization of names.
2854 (spike/spike_odd): removed deprecated spike/spike_odd functions.
2859 (spike/spike_odd): removed deprecated spike/spike_odd functions.
2855
2860
2856 * ipython.el: committed Alex's recent fixes and improvements.
2861 * ipython.el: committed Alex's recent fixes and improvements.
2857 Tested with python-mode from CVS, and it looks excellent. Since
2862 Tested with python-mode from CVS, and it looks excellent. Since
2858 python-mode hasn't released anything in a while, I'm temporarily
2863 python-mode hasn't released anything in a while, I'm temporarily
2859 putting a copy of today's CVS (v 4.70) of python-mode in:
2864 putting a copy of today's CVS (v 4.70) of python-mode in:
2860 http://ipython.scipy.org/tmp/python-mode.el
2865 http://ipython.scipy.org/tmp/python-mode.el
2861
2866
2862 * scripts/ipython_win_post_install.py (install): Win32 fix to use
2867 * scripts/ipython_win_post_install.py (install): Win32 fix to use
2863 sys.executable for the executable name, instead of assuming it's
2868 sys.executable for the executable name, instead of assuming it's
2864 called 'python.exe' (the post-installer would have produced broken
2869 called 'python.exe' (the post-installer would have produced broken
2865 setups on systems with a differently named python binary).
2870 setups on systems with a differently named python binary).
2866
2871
2867 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
2872 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
2868 references to os.linesep, to make the code more
2873 references to os.linesep, to make the code more
2869 platform-independent. This is also part of the win32 coloring
2874 platform-independent. This is also part of the win32 coloring
2870 fixes.
2875 fixes.
2871
2876
2872 * IPython/genutils.py (page_dumb): Remove attempts to chop long
2877 * IPython/genutils.py (page_dumb): Remove attempts to chop long
2873 lines, which actually cause coloring bugs because the length of
2878 lines, which actually cause coloring bugs because the length of
2874 the line is very difficult to correctly compute with embedded
2879 the line is very difficult to correctly compute with embedded
2875 escapes. This was the source of all the coloring problems under
2880 escapes. This was the source of all the coloring problems under
2876 Win32. I think that _finally_, Win32 users have a properly
2881 Win32. I think that _finally_, Win32 users have a properly
2877 working ipython in all respects. This would never have happened
2882 working ipython in all respects. This would never have happened
2878 if not for Gary Bishop and Viktor Ransmayr's great help and work.
2883 if not for Gary Bishop and Viktor Ransmayr's great help and work.
2879
2884
2880 2005-01-26 *** Released version 0.6.9
2885 2005-01-26 *** Released version 0.6.9
2881
2886
2882 2005-01-25 Fernando Perez <fperez@colorado.edu>
2887 2005-01-25 Fernando Perez <fperez@colorado.edu>
2883
2888
2884 * setup.py: finally, we have a true Windows installer, thanks to
2889 * setup.py: finally, we have a true Windows installer, thanks to
2885 the excellent work of Viktor Ransmayr
2890 the excellent work of Viktor Ransmayr
2886 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
2891 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
2887 Windows users. The setup routine is quite a bit cleaner thanks to
2892 Windows users. The setup routine is quite a bit cleaner thanks to
2888 this, and the post-install script uses the proper functions to
2893 this, and the post-install script uses the proper functions to
2889 allow a clean de-installation using the standard Windows Control
2894 allow a clean de-installation using the standard Windows Control
2890 Panel.
2895 Panel.
2891
2896
2892 * IPython/genutils.py (get_home_dir): changed to use the $HOME
2897 * IPython/genutils.py (get_home_dir): changed to use the $HOME
2893 environment variable under all OSes (including win32) if
2898 environment variable under all OSes (including win32) if
2894 available. This will give consistency to win32 users who have set
2899 available. This will give consistency to win32 users who have set
2895 this variable for any reason. If os.environ['HOME'] fails, the
2900 this variable for any reason. If os.environ['HOME'] fails, the
2896 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
2901 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
2897
2902
2898 2005-01-24 Fernando Perez <fperez@colorado.edu>
2903 2005-01-24 Fernando Perez <fperez@colorado.edu>
2899
2904
2900 * IPython/numutils.py (empty_like): add empty_like(), similar to
2905 * IPython/numutils.py (empty_like): add empty_like(), similar to
2901 zeros_like() but taking advantage of the new empty() Numeric routine.
2906 zeros_like() but taking advantage of the new empty() Numeric routine.
2902
2907
2903 2005-01-23 *** Released version 0.6.8
2908 2005-01-23 *** Released version 0.6.8
2904
2909
2905 2005-01-22 Fernando Perez <fperez@colorado.edu>
2910 2005-01-22 Fernando Perez <fperez@colorado.edu>
2906
2911
2907 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
2912 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
2908 automatic show() calls. After discussing things with JDH, it
2913 automatic show() calls. After discussing things with JDH, it
2909 turns out there are too many corner cases where this can go wrong.
2914 turns out there are too many corner cases where this can go wrong.
2910 It's best not to try to be 'too smart', and simply have ipython
2915 It's best not to try to be 'too smart', and simply have ipython
2911 reproduce as much as possible the default behavior of a normal
2916 reproduce as much as possible the default behavior of a normal
2912 python shell.
2917 python shell.
2913
2918
2914 * IPython/iplib.py (InteractiveShell.__init__): Modified the
2919 * IPython/iplib.py (InteractiveShell.__init__): Modified the
2915 line-splitting regexp and _prefilter() to avoid calling getattr()
2920 line-splitting regexp and _prefilter() to avoid calling getattr()
2916 on assignments. This closes
2921 on assignments. This closes
2917 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
2922 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
2918 readline uses getattr(), so a simple <TAB> keypress is still
2923 readline uses getattr(), so a simple <TAB> keypress is still
2919 enough to trigger getattr() calls on an object.
2924 enough to trigger getattr() calls on an object.
2920
2925
2921 2005-01-21 Fernando Perez <fperez@colorado.edu>
2926 2005-01-21 Fernando Perez <fperez@colorado.edu>
2922
2927
2923 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
2928 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
2924 docstring under pylab so it doesn't mask the original.
2929 docstring under pylab so it doesn't mask the original.
2925
2930
2926 2005-01-21 *** Released version 0.6.7
2931 2005-01-21 *** Released version 0.6.7
2927
2932
2928 2005-01-21 Fernando Perez <fperez@colorado.edu>
2933 2005-01-21 Fernando Perez <fperez@colorado.edu>
2929
2934
2930 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
2935 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
2931 signal handling for win32 users in multithreaded mode.
2936 signal handling for win32 users in multithreaded mode.
2932
2937
2933 2005-01-17 Fernando Perez <fperez@colorado.edu>
2938 2005-01-17 Fernando Perez <fperez@colorado.edu>
2934
2939
2935 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
2940 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
2936 instances with no __init__. After a crash report by Norbert Nemec
2941 instances with no __init__. After a crash report by Norbert Nemec
2937 <Norbert-AT-nemec-online.de>.
2942 <Norbert-AT-nemec-online.de>.
2938
2943
2939 2005-01-14 Fernando Perez <fperez@colorado.edu>
2944 2005-01-14 Fernando Perez <fperez@colorado.edu>
2940
2945
2941 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
2946 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
2942 names for verbose exceptions, when multiple dotted names and the
2947 names for verbose exceptions, when multiple dotted names and the
2943 'parent' object were present on the same line.
2948 'parent' object were present on the same line.
2944
2949
2945 2005-01-11 Fernando Perez <fperez@colorado.edu>
2950 2005-01-11 Fernando Perez <fperez@colorado.edu>
2946
2951
2947 * IPython/genutils.py (flag_calls): new utility to trap and flag
2952 * IPython/genutils.py (flag_calls): new utility to trap and flag
2948 calls in functions. I need it to clean up matplotlib support.
2953 calls in functions. I need it to clean up matplotlib support.
2949 Also removed some deprecated code in genutils.
2954 Also removed some deprecated code in genutils.
2950
2955
2951 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
2956 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
2952 that matplotlib scripts called with %run, which don't call show()
2957 that matplotlib scripts called with %run, which don't call show()
2953 themselves, still have their plotting windows open.
2958 themselves, still have their plotting windows open.
2954
2959
2955 2005-01-05 Fernando Perez <fperez@colorado.edu>
2960 2005-01-05 Fernando Perez <fperez@colorado.edu>
2956
2961
2957 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
2962 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
2958 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
2963 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
2959
2964
2960 2004-12-19 Fernando Perez <fperez@colorado.edu>
2965 2004-12-19 Fernando Perez <fperez@colorado.edu>
2961
2966
2962 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
2967 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
2963 parent_runcode, which was an eyesore. The same result can be
2968 parent_runcode, which was an eyesore. The same result can be
2964 obtained with Python's regular superclass mechanisms.
2969 obtained with Python's regular superclass mechanisms.
2965
2970
2966 2004-12-17 Fernando Perez <fperez@colorado.edu>
2971 2004-12-17 Fernando Perez <fperez@colorado.edu>
2967
2972
2968 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
2973 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
2969 reported by Prabhu.
2974 reported by Prabhu.
2970 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
2975 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
2971 sys.stderr) instead of explicitly calling sys.stderr. This helps
2976 sys.stderr) instead of explicitly calling sys.stderr. This helps
2972 maintain our I/O abstractions clean, for future GUI embeddings.
2977 maintain our I/O abstractions clean, for future GUI embeddings.
2973
2978
2974 * IPython/genutils.py (info): added new utility for sys.stderr
2979 * IPython/genutils.py (info): added new utility for sys.stderr
2975 unified info message handling (thin wrapper around warn()).
2980 unified info message handling (thin wrapper around warn()).
2976
2981
2977 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
2982 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
2978 composite (dotted) names on verbose exceptions.
2983 composite (dotted) names on verbose exceptions.
2979 (VerboseTB.nullrepr): harden against another kind of errors which
2984 (VerboseTB.nullrepr): harden against another kind of errors which
2980 Python's inspect module can trigger, and which were crashing
2985 Python's inspect module can trigger, and which were crashing
2981 IPython. Thanks to a report by Marco Lombardi
2986 IPython. Thanks to a report by Marco Lombardi
2982 <mlombard-AT-ma010192.hq.eso.org>.
2987 <mlombard-AT-ma010192.hq.eso.org>.
2983
2988
2984 2004-12-13 *** Released version 0.6.6
2989 2004-12-13 *** Released version 0.6.6
2985
2990
2986 2004-12-12 Fernando Perez <fperez@colorado.edu>
2991 2004-12-12 Fernando Perez <fperez@colorado.edu>
2987
2992
2988 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
2993 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
2989 generated by pygtk upon initialization if it was built without
2994 generated by pygtk upon initialization if it was built without
2990 threads (for matplotlib users). After a crash reported by
2995 threads (for matplotlib users). After a crash reported by
2991 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
2996 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
2992
2997
2993 * IPython/ipmaker.py (make_IPython): fix small bug in the
2998 * IPython/ipmaker.py (make_IPython): fix small bug in the
2994 import_some parameter for multiple imports.
2999 import_some parameter for multiple imports.
2995
3000
2996 * IPython/iplib.py (ipmagic): simplified the interface of
3001 * IPython/iplib.py (ipmagic): simplified the interface of
2997 ipmagic() to take a single string argument, just as it would be
3002 ipmagic() to take a single string argument, just as it would be
2998 typed at the IPython cmd line.
3003 typed at the IPython cmd line.
2999 (ipalias): Added new ipalias() with an interface identical to
3004 (ipalias): Added new ipalias() with an interface identical to
3000 ipmagic(). This completes exposing a pure python interface to the
3005 ipmagic(). This completes exposing a pure python interface to the
3001 alias and magic system, which can be used in loops or more complex
3006 alias and magic system, which can be used in loops or more complex
3002 code where IPython's automatic line mangling is not active.
3007 code where IPython's automatic line mangling is not active.
3003
3008
3004 * IPython/genutils.py (timing): changed interface of timing to
3009 * IPython/genutils.py (timing): changed interface of timing to
3005 simply run code once, which is the most common case. timings()
3010 simply run code once, which is the most common case. timings()
3006 remains unchanged, for the cases where you want multiple runs.
3011 remains unchanged, for the cases where you want multiple runs.
3007
3012
3008 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
3013 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
3009 bug where Python2.2 crashes with exec'ing code which does not end
3014 bug where Python2.2 crashes with exec'ing code which does not end
3010 in a single newline. Python 2.3 is OK, so I hadn't noticed this
3015 in a single newline. Python 2.3 is OK, so I hadn't noticed this
3011 before.
3016 before.
3012
3017
3013 2004-12-10 Fernando Perez <fperez@colorado.edu>
3018 2004-12-10 Fernando Perez <fperez@colorado.edu>
3014
3019
3015 * IPython/Magic.py (Magic.magic_prun): changed name of option from
3020 * IPython/Magic.py (Magic.magic_prun): changed name of option from
3016 -t to -T, to accomodate the new -t flag in %run (the %run and
3021 -t to -T, to accomodate the new -t flag in %run (the %run and
3017 %prun options are kind of intermixed, and it's not easy to change
3022 %prun options are kind of intermixed, and it's not easy to change
3018 this with the limitations of python's getopt).
3023 this with the limitations of python's getopt).
3019
3024
3020 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
3025 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
3021 the execution of scripts. It's not as fine-tuned as timeit.py,
3026 the execution of scripts. It's not as fine-tuned as timeit.py,
3022 but it works from inside ipython (and under 2.2, which lacks
3027 but it works from inside ipython (and under 2.2, which lacks
3023 timeit.py). Optionally a number of runs > 1 can be given for
3028 timeit.py). Optionally a number of runs > 1 can be given for
3024 timing very short-running code.
3029 timing very short-running code.
3025
3030
3026 * IPython/genutils.py (uniq_stable): new routine which returns a
3031 * IPython/genutils.py (uniq_stable): new routine which returns a
3027 list of unique elements in any iterable, but in stable order of
3032 list of unique elements in any iterable, but in stable order of
3028 appearance. I needed this for the ultraTB fixes, and it's a handy
3033 appearance. I needed this for the ultraTB fixes, and it's a handy
3029 utility.
3034 utility.
3030
3035
3031 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
3036 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
3032 dotted names in Verbose exceptions. This had been broken since
3037 dotted names in Verbose exceptions. This had been broken since
3033 the very start, now x.y will properly be printed in a Verbose
3038 the very start, now x.y will properly be printed in a Verbose
3034 traceback, instead of x being shown and y appearing always as an
3039 traceback, instead of x being shown and y appearing always as an
3035 'undefined global'. Getting this to work was a bit tricky,
3040 'undefined global'. Getting this to work was a bit tricky,
3036 because by default python tokenizers are stateless. Saved by
3041 because by default python tokenizers are stateless. Saved by
3037 python's ability to easily add a bit of state to an arbitrary
3042 python's ability to easily add a bit of state to an arbitrary
3038 function (without needing to build a full-blown callable object).
3043 function (without needing to build a full-blown callable object).
3039
3044
3040 Also big cleanup of this code, which had horrendous runtime
3045 Also big cleanup of this code, which had horrendous runtime
3041 lookups of zillions of attributes for colorization. Moved all
3046 lookups of zillions of attributes for colorization. Moved all
3042 this code into a few templates, which make it cleaner and quicker.
3047 this code into a few templates, which make it cleaner and quicker.
3043
3048
3044 Printout quality was also improved for Verbose exceptions: one
3049 Printout quality was also improved for Verbose exceptions: one
3045 variable per line, and memory addresses are printed (this can be
3050 variable per line, and memory addresses are printed (this can be
3046 quite handy in nasty debugging situations, which is what Verbose
3051 quite handy in nasty debugging situations, which is what Verbose
3047 is for).
3052 is for).
3048
3053
3049 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
3054 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
3050 the command line as scripts to be loaded by embedded instances.
3055 the command line as scripts to be loaded by embedded instances.
3051 Doing so has the potential for an infinite recursion if there are
3056 Doing so has the potential for an infinite recursion if there are
3052 exceptions thrown in the process. This fixes a strange crash
3057 exceptions thrown in the process. This fixes a strange crash
3053 reported by Philippe MULLER <muller-AT-irit.fr>.
3058 reported by Philippe MULLER <muller-AT-irit.fr>.
3054
3059
3055 2004-12-09 Fernando Perez <fperez@colorado.edu>
3060 2004-12-09 Fernando Perez <fperez@colorado.edu>
3056
3061
3057 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
3062 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
3058 to reflect new names in matplotlib, which now expose the
3063 to reflect new names in matplotlib, which now expose the
3059 matlab-compatible interface via a pylab module instead of the
3064 matlab-compatible interface via a pylab module instead of the
3060 'matlab' name. The new code is backwards compatible, so users of
3065 'matlab' name. The new code is backwards compatible, so users of
3061 all matplotlib versions are OK. Patch by J. Hunter.
3066 all matplotlib versions are OK. Patch by J. Hunter.
3062
3067
3063 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
3068 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
3064 of __init__ docstrings for instances (class docstrings are already
3069 of __init__ docstrings for instances (class docstrings are already
3065 automatically printed). Instances with customized docstrings
3070 automatically printed). Instances with customized docstrings
3066 (indep. of the class) are also recognized and all 3 separate
3071 (indep. of the class) are also recognized and all 3 separate
3067 docstrings are printed (instance, class, constructor). After some
3072 docstrings are printed (instance, class, constructor). After some
3068 comments/suggestions by J. Hunter.
3073 comments/suggestions by J. Hunter.
3069
3074
3070 2004-12-05 Fernando Perez <fperez@colorado.edu>
3075 2004-12-05 Fernando Perez <fperez@colorado.edu>
3071
3076
3072 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
3077 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
3073 warnings when tab-completion fails and triggers an exception.
3078 warnings when tab-completion fails and triggers an exception.
3074
3079
3075 2004-12-03 Fernando Perez <fperez@colorado.edu>
3080 2004-12-03 Fernando Perez <fperez@colorado.edu>
3076
3081
3077 * IPython/Magic.py (magic_prun): Fix bug where an exception would
3082 * IPython/Magic.py (magic_prun): Fix bug where an exception would
3078 be triggered when using 'run -p'. An incorrect option flag was
3083 be triggered when using 'run -p'. An incorrect option flag was
3079 being set ('d' instead of 'D').
3084 being set ('d' instead of 'D').
3080 (manpage): fix missing escaped \- sign.
3085 (manpage): fix missing escaped \- sign.
3081
3086
3082 2004-11-30 *** Released version 0.6.5
3087 2004-11-30 *** Released version 0.6.5
3083
3088
3084 2004-11-30 Fernando Perez <fperez@colorado.edu>
3089 2004-11-30 Fernando Perez <fperez@colorado.edu>
3085
3090
3086 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
3091 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
3087 setting with -d option.
3092 setting with -d option.
3088
3093
3089 * setup.py (docfiles): Fix problem where the doc glob I was using
3094 * setup.py (docfiles): Fix problem where the doc glob I was using
3090 was COMPLETELY BROKEN. It was giving the right files by pure
3095 was COMPLETELY BROKEN. It was giving the right files by pure
3091 accident, but failed once I tried to include ipython.el. Note:
3096 accident, but failed once I tried to include ipython.el. Note:
3092 glob() does NOT allow you to do exclusion on multiple endings!
3097 glob() does NOT allow you to do exclusion on multiple endings!
3093
3098
3094 2004-11-29 Fernando Perez <fperez@colorado.edu>
3099 2004-11-29 Fernando Perez <fperez@colorado.edu>
3095
3100
3096 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
3101 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
3097 the manpage as the source. Better formatting & consistency.
3102 the manpage as the source. Better formatting & consistency.
3098
3103
3099 * IPython/Magic.py (magic_run): Added new -d option, to run
3104 * IPython/Magic.py (magic_run): Added new -d option, to run
3100 scripts under the control of the python pdb debugger. Note that
3105 scripts under the control of the python pdb debugger. Note that
3101 this required changing the %prun option -d to -D, to avoid a clash
3106 this required changing the %prun option -d to -D, to avoid a clash
3102 (since %run must pass options to %prun, and getopt is too dumb to
3107 (since %run must pass options to %prun, and getopt is too dumb to
3103 handle options with string values with embedded spaces). Thanks
3108 handle options with string values with embedded spaces). Thanks
3104 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
3109 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
3105 (magic_who_ls): added type matching to %who and %whos, so that one
3110 (magic_who_ls): added type matching to %who and %whos, so that one
3106 can filter their output to only include variables of certain
3111 can filter their output to only include variables of certain
3107 types. Another suggestion by Matthew.
3112 types. Another suggestion by Matthew.
3108 (magic_whos): Added memory summaries in kb and Mb for arrays.
3113 (magic_whos): Added memory summaries in kb and Mb for arrays.
3109 (magic_who): Improve formatting (break lines every 9 vars).
3114 (magic_who): Improve formatting (break lines every 9 vars).
3110
3115
3111 2004-11-28 Fernando Perez <fperez@colorado.edu>
3116 2004-11-28 Fernando Perez <fperez@colorado.edu>
3112
3117
3113 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
3118 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
3114 cache when empty lines were present.
3119 cache when empty lines were present.
3115
3120
3116 2004-11-24 Fernando Perez <fperez@colorado.edu>
3121 2004-11-24 Fernando Perez <fperez@colorado.edu>
3117
3122
3118 * IPython/usage.py (__doc__): document the re-activated threading
3123 * IPython/usage.py (__doc__): document the re-activated threading
3119 options for WX and GTK.
3124 options for WX and GTK.
3120
3125
3121 2004-11-23 Fernando Perez <fperez@colorado.edu>
3126 2004-11-23 Fernando Perez <fperez@colorado.edu>
3122
3127
3123 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
3128 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
3124 the -wthread and -gthread options, along with a new -tk one to try
3129 the -wthread and -gthread options, along with a new -tk one to try
3125 and coordinate Tk threading with wx/gtk. The tk support is very
3130 and coordinate Tk threading with wx/gtk. The tk support is very
3126 platform dependent, since it seems to require Tcl and Tk to be
3131 platform dependent, since it seems to require Tcl and Tk to be
3127 built with threads (Fedora1/2 appears NOT to have it, but in
3132 built with threads (Fedora1/2 appears NOT to have it, but in
3128 Prabhu's Debian boxes it works OK). But even with some Tk
3133 Prabhu's Debian boxes it works OK). But even with some Tk
3129 limitations, this is a great improvement.
3134 limitations, this is a great improvement.
3130
3135
3131 * IPython/Prompts.py (prompt_specials_color): Added \t for time
3136 * IPython/Prompts.py (prompt_specials_color): Added \t for time
3132 info in user prompts. Patch by Prabhu.
3137 info in user prompts. Patch by Prabhu.
3133
3138
3134 2004-11-18 Fernando Perez <fperez@colorado.edu>
3139 2004-11-18 Fernando Perez <fperez@colorado.edu>
3135
3140
3136 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
3141 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
3137 EOFErrors and bail, to avoid infinite loops if a non-terminating
3142 EOFErrors and bail, to avoid infinite loops if a non-terminating
3138 file is fed into ipython. Patch submitted in issue 19 by user,
3143 file is fed into ipython. Patch submitted in issue 19 by user,
3139 many thanks.
3144 many thanks.
3140
3145
3141 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
3146 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
3142 autoquote/parens in continuation prompts, which can cause lots of
3147 autoquote/parens in continuation prompts, which can cause lots of
3143 problems. Closes roundup issue 20.
3148 problems. Closes roundup issue 20.
3144
3149
3145 2004-11-17 Fernando Perez <fperez@colorado.edu>
3150 2004-11-17 Fernando Perez <fperez@colorado.edu>
3146
3151
3147 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
3152 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
3148 reported as debian bug #280505. I'm not sure my local changelog
3153 reported as debian bug #280505. I'm not sure my local changelog
3149 entry has the proper debian format (Jack?).
3154 entry has the proper debian format (Jack?).
3150
3155
3151 2004-11-08 *** Released version 0.6.4
3156 2004-11-08 *** Released version 0.6.4
3152
3157
3153 2004-11-08 Fernando Perez <fperez@colorado.edu>
3158 2004-11-08 Fernando Perez <fperez@colorado.edu>
3154
3159
3155 * IPython/iplib.py (init_readline): Fix exit message for Windows
3160 * IPython/iplib.py (init_readline): Fix exit message for Windows
3156 when readline is active. Thanks to a report by Eric Jones
3161 when readline is active. Thanks to a report by Eric Jones
3157 <eric-AT-enthought.com>.
3162 <eric-AT-enthought.com>.
3158
3163
3159 2004-11-07 Fernando Perez <fperez@colorado.edu>
3164 2004-11-07 Fernando Perez <fperez@colorado.edu>
3160
3165
3161 * IPython/genutils.py (page): Add a trap for OSError exceptions,
3166 * IPython/genutils.py (page): Add a trap for OSError exceptions,
3162 sometimes seen by win2k/cygwin users.
3167 sometimes seen by win2k/cygwin users.
3163
3168
3164 2004-11-06 Fernando Perez <fperez@colorado.edu>
3169 2004-11-06 Fernando Perez <fperez@colorado.edu>
3165
3170
3166 * IPython/iplib.py (interact): Change the handling of %Exit from
3171 * IPython/iplib.py (interact): Change the handling of %Exit from
3167 trying to propagate a SystemExit to an internal ipython flag.
3172 trying to propagate a SystemExit to an internal ipython flag.
3168 This is less elegant than using Python's exception mechanism, but
3173 This is less elegant than using Python's exception mechanism, but
3169 I can't get that to work reliably with threads, so under -pylab
3174 I can't get that to work reliably with threads, so under -pylab
3170 %Exit was hanging IPython. Cross-thread exception handling is
3175 %Exit was hanging IPython. Cross-thread exception handling is
3171 really a bitch. Thaks to a bug report by Stephen Walton
3176 really a bitch. Thaks to a bug report by Stephen Walton
3172 <stephen.walton-AT-csun.edu>.
3177 <stephen.walton-AT-csun.edu>.
3173
3178
3174 2004-11-04 Fernando Perez <fperez@colorado.edu>
3179 2004-11-04 Fernando Perez <fperez@colorado.edu>
3175
3180
3176 * IPython/iplib.py (raw_input_original): store a pointer to the
3181 * IPython/iplib.py (raw_input_original): store a pointer to the
3177 true raw_input to harden against code which can modify it
3182 true raw_input to harden against code which can modify it
3178 (wx.py.PyShell does this and would otherwise crash ipython).
3183 (wx.py.PyShell does this and would otherwise crash ipython).
3179 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
3184 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
3180
3185
3181 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
3186 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
3182 Ctrl-C problem, which does not mess up the input line.
3187 Ctrl-C problem, which does not mess up the input line.
3183
3188
3184 2004-11-03 Fernando Perez <fperez@colorado.edu>
3189 2004-11-03 Fernando Perez <fperez@colorado.edu>
3185
3190
3186 * IPython/Release.py: Changed licensing to BSD, in all files.
3191 * IPython/Release.py: Changed licensing to BSD, in all files.
3187 (name): lowercase name for tarball/RPM release.
3192 (name): lowercase name for tarball/RPM release.
3188
3193
3189 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
3194 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
3190 use throughout ipython.
3195 use throughout ipython.
3191
3196
3192 * IPython/Magic.py (Magic._ofind): Switch to using the new
3197 * IPython/Magic.py (Magic._ofind): Switch to using the new
3193 OInspect.getdoc() function.
3198 OInspect.getdoc() function.
3194
3199
3195 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
3200 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
3196 of the line currently being canceled via Ctrl-C. It's extremely
3201 of the line currently being canceled via Ctrl-C. It's extremely
3197 ugly, but I don't know how to do it better (the problem is one of
3202 ugly, but I don't know how to do it better (the problem is one of
3198 handling cross-thread exceptions).
3203 handling cross-thread exceptions).
3199
3204
3200 2004-10-28 Fernando Perez <fperez@colorado.edu>
3205 2004-10-28 Fernando Perez <fperez@colorado.edu>
3201
3206
3202 * IPython/Shell.py (signal_handler): add signal handlers to trap
3207 * IPython/Shell.py (signal_handler): add signal handlers to trap
3203 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
3208 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
3204 report by Francesc Alted.
3209 report by Francesc Alted.
3205
3210
3206 2004-10-21 Fernando Perez <fperez@colorado.edu>
3211 2004-10-21 Fernando Perez <fperez@colorado.edu>
3207
3212
3208 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
3213 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
3209 to % for pysh syntax extensions.
3214 to % for pysh syntax extensions.
3210
3215
3211 2004-10-09 Fernando Perez <fperez@colorado.edu>
3216 2004-10-09 Fernando Perez <fperez@colorado.edu>
3212
3217
3213 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
3218 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
3214 arrays to print a more useful summary, without calling str(arr).
3219 arrays to print a more useful summary, without calling str(arr).
3215 This avoids the problem of extremely lengthy computations which
3220 This avoids the problem of extremely lengthy computations which
3216 occur if arr is large, and appear to the user as a system lockup
3221 occur if arr is large, and appear to the user as a system lockup
3217 with 100% cpu activity. After a suggestion by Kristian Sandberg
3222 with 100% cpu activity. After a suggestion by Kristian Sandberg
3218 <Kristian.Sandberg@colorado.edu>.
3223 <Kristian.Sandberg@colorado.edu>.
3219 (Magic.__init__): fix bug in global magic escapes not being
3224 (Magic.__init__): fix bug in global magic escapes not being
3220 correctly set.
3225 correctly set.
3221
3226
3222 2004-10-08 Fernando Perez <fperez@colorado.edu>
3227 2004-10-08 Fernando Perez <fperez@colorado.edu>
3223
3228
3224 * IPython/Magic.py (__license__): change to absolute imports of
3229 * IPython/Magic.py (__license__): change to absolute imports of
3225 ipython's own internal packages, to start adapting to the absolute
3230 ipython's own internal packages, to start adapting to the absolute
3226 import requirement of PEP-328.
3231 import requirement of PEP-328.
3227
3232
3228 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
3233 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
3229 files, and standardize author/license marks through the Release
3234 files, and standardize author/license marks through the Release
3230 module instead of having per/file stuff (except for files with
3235 module instead of having per/file stuff (except for files with
3231 particular licenses, like the MIT/PSF-licensed codes).
3236 particular licenses, like the MIT/PSF-licensed codes).
3232
3237
3233 * IPython/Debugger.py: remove dead code for python 2.1
3238 * IPython/Debugger.py: remove dead code for python 2.1
3234
3239
3235 2004-10-04 Fernando Perez <fperez@colorado.edu>
3240 2004-10-04 Fernando Perez <fperez@colorado.edu>
3236
3241
3237 * IPython/iplib.py (ipmagic): New function for accessing magics
3242 * IPython/iplib.py (ipmagic): New function for accessing magics
3238 via a normal python function call.
3243 via a normal python function call.
3239
3244
3240 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
3245 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
3241 from '@' to '%', to accomodate the new @decorator syntax of python
3246 from '@' to '%', to accomodate the new @decorator syntax of python
3242 2.4.
3247 2.4.
3243
3248
3244 2004-09-29 Fernando Perez <fperez@colorado.edu>
3249 2004-09-29 Fernando Perez <fperez@colorado.edu>
3245
3250
3246 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
3251 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
3247 matplotlib.use to prevent running scripts which try to switch
3252 matplotlib.use to prevent running scripts which try to switch
3248 interactive backends from within ipython. This will just crash
3253 interactive backends from within ipython. This will just crash
3249 the python interpreter, so we can't allow it (but a detailed error
3254 the python interpreter, so we can't allow it (but a detailed error
3250 is given to the user).
3255 is given to the user).
3251
3256
3252 2004-09-28 Fernando Perez <fperez@colorado.edu>
3257 2004-09-28 Fernando Perez <fperez@colorado.edu>
3253
3258
3254 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
3259 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
3255 matplotlib-related fixes so that using @run with non-matplotlib
3260 matplotlib-related fixes so that using @run with non-matplotlib
3256 scripts doesn't pop up spurious plot windows. This requires
3261 scripts doesn't pop up spurious plot windows. This requires
3257 matplotlib >= 0.63, where I had to make some changes as well.
3262 matplotlib >= 0.63, where I had to make some changes as well.
3258
3263
3259 * IPython/ipmaker.py (make_IPython): update version requirement to
3264 * IPython/ipmaker.py (make_IPython): update version requirement to
3260 python 2.2.
3265 python 2.2.
3261
3266
3262 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
3267 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
3263 banner arg for embedded customization.
3268 banner arg for embedded customization.
3264
3269
3265 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
3270 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
3266 explicit uses of __IP as the IPython's instance name. Now things
3271 explicit uses of __IP as the IPython's instance name. Now things
3267 are properly handled via the shell.name value. The actual code
3272 are properly handled via the shell.name value. The actual code
3268 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
3273 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
3269 is much better than before. I'll clean things completely when the
3274 is much better than before. I'll clean things completely when the
3270 magic stuff gets a real overhaul.
3275 magic stuff gets a real overhaul.
3271
3276
3272 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
3277 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
3273 minor changes to debian dir.
3278 minor changes to debian dir.
3274
3279
3275 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
3280 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
3276 pointer to the shell itself in the interactive namespace even when
3281 pointer to the shell itself in the interactive namespace even when
3277 a user-supplied dict is provided. This is needed for embedding
3282 a user-supplied dict is provided. This is needed for embedding
3278 purposes (found by tests with Michel Sanner).
3283 purposes (found by tests with Michel Sanner).
3279
3284
3280 2004-09-27 Fernando Perez <fperez@colorado.edu>
3285 2004-09-27 Fernando Perez <fperez@colorado.edu>
3281
3286
3282 * IPython/UserConfig/ipythonrc: remove []{} from
3287 * IPython/UserConfig/ipythonrc: remove []{} from
3283 readline_remove_delims, so that things like [modname.<TAB> do
3288 readline_remove_delims, so that things like [modname.<TAB> do
3284 proper completion. This disables [].TAB, but that's a less common
3289 proper completion. This disables [].TAB, but that's a less common
3285 case than module names in list comprehensions, for example.
3290 case than module names in list comprehensions, for example.
3286 Thanks to a report by Andrea Riciputi.
3291 Thanks to a report by Andrea Riciputi.
3287
3292
3288 2004-09-09 Fernando Perez <fperez@colorado.edu>
3293 2004-09-09 Fernando Perez <fperez@colorado.edu>
3289
3294
3290 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
3295 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
3291 blocking problems in win32 and osx. Fix by John.
3296 blocking problems in win32 and osx. Fix by John.
3292
3297
3293 2004-09-08 Fernando Perez <fperez@colorado.edu>
3298 2004-09-08 Fernando Perez <fperez@colorado.edu>
3294
3299
3295 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
3300 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
3296 for Win32 and OSX. Fix by John Hunter.
3301 for Win32 and OSX. Fix by John Hunter.
3297
3302
3298 2004-08-30 *** Released version 0.6.3
3303 2004-08-30 *** Released version 0.6.3
3299
3304
3300 2004-08-30 Fernando Perez <fperez@colorado.edu>
3305 2004-08-30 Fernando Perez <fperez@colorado.edu>
3301
3306
3302 * setup.py (isfile): Add manpages to list of dependent files to be
3307 * setup.py (isfile): Add manpages to list of dependent files to be
3303 updated.
3308 updated.
3304
3309
3305 2004-08-27 Fernando Perez <fperez@colorado.edu>
3310 2004-08-27 Fernando Perez <fperez@colorado.edu>
3306
3311
3307 * IPython/Shell.py (start): I've disabled -wthread and -gthread
3312 * IPython/Shell.py (start): I've disabled -wthread and -gthread
3308 for now. They don't really work with standalone WX/GTK code
3313 for now. They don't really work with standalone WX/GTK code
3309 (though matplotlib IS working fine with both of those backends).
3314 (though matplotlib IS working fine with both of those backends).
3310 This will neeed much more testing. I disabled most things with
3315 This will neeed much more testing. I disabled most things with
3311 comments, so turning it back on later should be pretty easy.
3316 comments, so turning it back on later should be pretty easy.
3312
3317
3313 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
3318 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
3314 autocalling of expressions like r'foo', by modifying the line
3319 autocalling of expressions like r'foo', by modifying the line
3315 split regexp. Closes
3320 split regexp. Closes
3316 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
3321 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
3317 Riley <ipythonbugs-AT-sabi.net>.
3322 Riley <ipythonbugs-AT-sabi.net>.
3318 (InteractiveShell.mainloop): honor --nobanner with banner
3323 (InteractiveShell.mainloop): honor --nobanner with banner
3319 extensions.
3324 extensions.
3320
3325
3321 * IPython/Shell.py: Significant refactoring of all classes, so
3326 * IPython/Shell.py: Significant refactoring of all classes, so
3322 that we can really support ALL matplotlib backends and threading
3327 that we can really support ALL matplotlib backends and threading
3323 models (John spotted a bug with Tk which required this). Now we
3328 models (John spotted a bug with Tk which required this). Now we
3324 should support single-threaded, WX-threads and GTK-threads, both
3329 should support single-threaded, WX-threads and GTK-threads, both
3325 for generic code and for matplotlib.
3330 for generic code and for matplotlib.
3326
3331
3327 * IPython/ipmaker.py (__call__): Changed -mpthread option to
3332 * IPython/ipmaker.py (__call__): Changed -mpthread option to
3328 -pylab, to simplify things for users. Will also remove the pylab
3333 -pylab, to simplify things for users. Will also remove the pylab
3329 profile, since now all of matplotlib configuration is directly
3334 profile, since now all of matplotlib configuration is directly
3330 handled here. This also reduces startup time.
3335 handled here. This also reduces startup time.
3331
3336
3332 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
3337 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
3333 shell wasn't being correctly called. Also in IPShellWX.
3338 shell wasn't being correctly called. Also in IPShellWX.
3334
3339
3335 * IPython/iplib.py (InteractiveShell.__init__): Added option to
3340 * IPython/iplib.py (InteractiveShell.__init__): Added option to
3336 fine-tune banner.
3341 fine-tune banner.
3337
3342
3338 * IPython/numutils.py (spike): Deprecate these spike functions,
3343 * IPython/numutils.py (spike): Deprecate these spike functions,
3339 delete (long deprecated) gnuplot_exec handler.
3344 delete (long deprecated) gnuplot_exec handler.
3340
3345
3341 2004-08-26 Fernando Perez <fperez@colorado.edu>
3346 2004-08-26 Fernando Perez <fperez@colorado.edu>
3342
3347
3343 * ipython.1: Update for threading options, plus some others which
3348 * ipython.1: Update for threading options, plus some others which
3344 were missing.
3349 were missing.
3345
3350
3346 * IPython/ipmaker.py (__call__): Added -wthread option for
3351 * IPython/ipmaker.py (__call__): Added -wthread option for
3347 wxpython thread handling. Make sure threading options are only
3352 wxpython thread handling. Make sure threading options are only
3348 valid at the command line.
3353 valid at the command line.
3349
3354
3350 * scripts/ipython: moved shell selection into a factory function
3355 * scripts/ipython: moved shell selection into a factory function
3351 in Shell.py, to keep the starter script to a minimum.
3356 in Shell.py, to keep the starter script to a minimum.
3352
3357
3353 2004-08-25 Fernando Perez <fperez@colorado.edu>
3358 2004-08-25 Fernando Perez <fperez@colorado.edu>
3354
3359
3355 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
3360 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
3356 John. Along with some recent changes he made to matplotlib, the
3361 John. Along with some recent changes he made to matplotlib, the
3357 next versions of both systems should work very well together.
3362 next versions of both systems should work very well together.
3358
3363
3359 2004-08-24 Fernando Perez <fperez@colorado.edu>
3364 2004-08-24 Fernando Perez <fperez@colorado.edu>
3360
3365
3361 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
3366 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
3362 tried to switch the profiling to using hotshot, but I'm getting
3367 tried to switch the profiling to using hotshot, but I'm getting
3363 strange errors from prof.runctx() there. I may be misreading the
3368 strange errors from prof.runctx() there. I may be misreading the
3364 docs, but it looks weird. For now the profiling code will
3369 docs, but it looks weird. For now the profiling code will
3365 continue to use the standard profiler.
3370 continue to use the standard profiler.
3366
3371
3367 2004-08-23 Fernando Perez <fperez@colorado.edu>
3372 2004-08-23 Fernando Perez <fperez@colorado.edu>
3368
3373
3369 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
3374 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
3370 threaded shell, by John Hunter. It's not quite ready yet, but
3375 threaded shell, by John Hunter. It's not quite ready yet, but
3371 close.
3376 close.
3372
3377
3373 2004-08-22 Fernando Perez <fperez@colorado.edu>
3378 2004-08-22 Fernando Perez <fperez@colorado.edu>
3374
3379
3375 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
3380 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
3376 in Magic and ultraTB.
3381 in Magic and ultraTB.
3377
3382
3378 * ipython.1: document threading options in manpage.
3383 * ipython.1: document threading options in manpage.
3379
3384
3380 * scripts/ipython: Changed name of -thread option to -gthread,
3385 * scripts/ipython: Changed name of -thread option to -gthread,
3381 since this is GTK specific. I want to leave the door open for a
3386 since this is GTK specific. I want to leave the door open for a
3382 -wthread option for WX, which will most likely be necessary. This
3387 -wthread option for WX, which will most likely be necessary. This
3383 change affects usage and ipmaker as well.
3388 change affects usage and ipmaker as well.
3384
3389
3385 * IPython/Shell.py (matplotlib_shell): Add a factory function to
3390 * IPython/Shell.py (matplotlib_shell): Add a factory function to
3386 handle the matplotlib shell issues. Code by John Hunter
3391 handle the matplotlib shell issues. Code by John Hunter
3387 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3392 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3388 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
3393 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
3389 broken (and disabled for end users) for now, but it puts the
3394 broken (and disabled for end users) for now, but it puts the
3390 infrastructure in place.
3395 infrastructure in place.
3391
3396
3392 2004-08-21 Fernando Perez <fperez@colorado.edu>
3397 2004-08-21 Fernando Perez <fperez@colorado.edu>
3393
3398
3394 * ipythonrc-pylab: Add matplotlib support.
3399 * ipythonrc-pylab: Add matplotlib support.
3395
3400
3396 * matplotlib_config.py: new files for matplotlib support, part of
3401 * matplotlib_config.py: new files for matplotlib support, part of
3397 the pylab profile.
3402 the pylab profile.
3398
3403
3399 * IPython/usage.py (__doc__): documented the threading options.
3404 * IPython/usage.py (__doc__): documented the threading options.
3400
3405
3401 2004-08-20 Fernando Perez <fperez@colorado.edu>
3406 2004-08-20 Fernando Perez <fperez@colorado.edu>
3402
3407
3403 * ipython: Modified the main calling routine to handle the -thread
3408 * ipython: Modified the main calling routine to handle the -thread
3404 and -mpthread options. This needs to be done as a top-level hack,
3409 and -mpthread options. This needs to be done as a top-level hack,
3405 because it determines which class to instantiate for IPython
3410 because it determines which class to instantiate for IPython
3406 itself.
3411 itself.
3407
3412
3408 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
3413 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
3409 classes to support multithreaded GTK operation without blocking,
3414 classes to support multithreaded GTK operation without blocking,
3410 and matplotlib with all backends. This is a lot of still very
3415 and matplotlib with all backends. This is a lot of still very
3411 experimental code, and threads are tricky. So it may still have a
3416 experimental code, and threads are tricky. So it may still have a
3412 few rough edges... This code owes a lot to
3417 few rough edges... This code owes a lot to
3413 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
3418 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
3414 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
3419 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
3415 to John Hunter for all the matplotlib work.
3420 to John Hunter for all the matplotlib work.
3416
3421
3417 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
3422 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
3418 options for gtk thread and matplotlib support.
3423 options for gtk thread and matplotlib support.
3419
3424
3420 2004-08-16 Fernando Perez <fperez@colorado.edu>
3425 2004-08-16 Fernando Perez <fperez@colorado.edu>
3421
3426
3422 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
3427 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
3423 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
3428 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
3424 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
3429 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
3425
3430
3426 2004-08-11 Fernando Perez <fperez@colorado.edu>
3431 2004-08-11 Fernando Perez <fperez@colorado.edu>
3427
3432
3428 * setup.py (isfile): Fix build so documentation gets updated for
3433 * setup.py (isfile): Fix build so documentation gets updated for
3429 rpms (it was only done for .tgz builds).
3434 rpms (it was only done for .tgz builds).
3430
3435
3431 2004-08-10 Fernando Perez <fperez@colorado.edu>
3436 2004-08-10 Fernando Perez <fperez@colorado.edu>
3432
3437
3433 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
3438 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
3434
3439
3435 * iplib.py : Silence syntax error exceptions in tab-completion.
3440 * iplib.py : Silence syntax error exceptions in tab-completion.
3436
3441
3437 2004-08-05 Fernando Perez <fperez@colorado.edu>
3442 2004-08-05 Fernando Perez <fperez@colorado.edu>
3438
3443
3439 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
3444 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
3440 'color off' mark for continuation prompts. This was causing long
3445 'color off' mark for continuation prompts. This was causing long
3441 continuation lines to mis-wrap.
3446 continuation lines to mis-wrap.
3442
3447
3443 2004-08-01 Fernando Perez <fperez@colorado.edu>
3448 2004-08-01 Fernando Perez <fperez@colorado.edu>
3444
3449
3445 * IPython/ipmaker.py (make_IPython): Allow the shell class used
3450 * IPython/ipmaker.py (make_IPython): Allow the shell class used
3446 for building ipython to be a parameter. All this is necessary
3451 for building ipython to be a parameter. All this is necessary
3447 right now to have a multithreaded version, but this insane
3452 right now to have a multithreaded version, but this insane
3448 non-design will be cleaned up soon. For now, it's a hack that
3453 non-design will be cleaned up soon. For now, it's a hack that
3449 works.
3454 works.
3450
3455
3451 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
3456 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
3452 args in various places. No bugs so far, but it's a dangerous
3457 args in various places. No bugs so far, but it's a dangerous
3453 practice.
3458 practice.
3454
3459
3455 2004-07-31 Fernando Perez <fperez@colorado.edu>
3460 2004-07-31 Fernando Perez <fperez@colorado.edu>
3456
3461
3457 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
3462 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
3458 fix completion of files with dots in their names under most
3463 fix completion of files with dots in their names under most
3459 profiles (pysh was OK because the completion order is different).
3464 profiles (pysh was OK because the completion order is different).
3460
3465
3461 2004-07-27 Fernando Perez <fperez@colorado.edu>
3466 2004-07-27 Fernando Perez <fperez@colorado.edu>
3462
3467
3463 * IPython/iplib.py (InteractiveShell.__init__): build dict of
3468 * IPython/iplib.py (InteractiveShell.__init__): build dict of
3464 keywords manually, b/c the one in keyword.py was removed in python
3469 keywords manually, b/c the one in keyword.py was removed in python
3465 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
3470 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
3466 This is NOT a bug under python 2.3 and earlier.
3471 This is NOT a bug under python 2.3 and earlier.
3467
3472
3468 2004-07-26 Fernando Perez <fperez@colorado.edu>
3473 2004-07-26 Fernando Perez <fperez@colorado.edu>
3469
3474
3470 * IPython/ultraTB.py (VerboseTB.text): Add another
3475 * IPython/ultraTB.py (VerboseTB.text): Add another
3471 linecache.checkcache() call to try to prevent inspect.py from
3476 linecache.checkcache() call to try to prevent inspect.py from
3472 crashing under python 2.3. I think this fixes
3477 crashing under python 2.3. I think this fixes
3473 http://www.scipy.net/roundup/ipython/issue17.
3478 http://www.scipy.net/roundup/ipython/issue17.
3474
3479
3475 2004-07-26 *** Released version 0.6.2
3480 2004-07-26 *** Released version 0.6.2
3476
3481
3477 2004-07-26 Fernando Perez <fperez@colorado.edu>
3482 2004-07-26 Fernando Perez <fperez@colorado.edu>
3478
3483
3479 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
3484 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
3480 fail for any number.
3485 fail for any number.
3481 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
3486 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
3482 empty bookmarks.
3487 empty bookmarks.
3483
3488
3484 2004-07-26 *** Released version 0.6.1
3489 2004-07-26 *** Released version 0.6.1
3485
3490
3486 2004-07-26 Fernando Perez <fperez@colorado.edu>
3491 2004-07-26 Fernando Perez <fperez@colorado.edu>
3487
3492
3488 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
3493 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
3489
3494
3490 * IPython/iplib.py (protect_filename): Applied Ville's patch for
3495 * IPython/iplib.py (protect_filename): Applied Ville's patch for
3491 escaping '()[]{}' in filenames.
3496 escaping '()[]{}' in filenames.
3492
3497
3493 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
3498 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
3494 Python 2.2 users who lack a proper shlex.split.
3499 Python 2.2 users who lack a proper shlex.split.
3495
3500
3496 2004-07-19 Fernando Perez <fperez@colorado.edu>
3501 2004-07-19 Fernando Perez <fperez@colorado.edu>
3497
3502
3498 * IPython/iplib.py (InteractiveShell.init_readline): Add support
3503 * IPython/iplib.py (InteractiveShell.init_readline): Add support
3499 for reading readline's init file. I follow the normal chain:
3504 for reading readline's init file. I follow the normal chain:
3500 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
3505 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
3501 report by Mike Heeter. This closes
3506 report by Mike Heeter. This closes
3502 http://www.scipy.net/roundup/ipython/issue16.
3507 http://www.scipy.net/roundup/ipython/issue16.
3503
3508
3504 2004-07-18 Fernando Perez <fperez@colorado.edu>
3509 2004-07-18 Fernando Perez <fperez@colorado.edu>
3505
3510
3506 * IPython/iplib.py (__init__): Add better handling of '\' under
3511 * IPython/iplib.py (__init__): Add better handling of '\' under
3507 Win32 for filenames. After a patch by Ville.
3512 Win32 for filenames. After a patch by Ville.
3508
3513
3509 2004-07-17 Fernando Perez <fperez@colorado.edu>
3514 2004-07-17 Fernando Perez <fperez@colorado.edu>
3510
3515
3511 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3516 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3512 autocalling would be triggered for 'foo is bar' if foo is
3517 autocalling would be triggered for 'foo is bar' if foo is
3513 callable. I also cleaned up the autocall detection code to use a
3518 callable. I also cleaned up the autocall detection code to use a
3514 regexp, which is faster. Bug reported by Alexander Schmolck.
3519 regexp, which is faster. Bug reported by Alexander Schmolck.
3515
3520
3516 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
3521 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
3517 '?' in them would confuse the help system. Reported by Alex
3522 '?' in them would confuse the help system. Reported by Alex
3518 Schmolck.
3523 Schmolck.
3519
3524
3520 2004-07-16 Fernando Perez <fperez@colorado.edu>
3525 2004-07-16 Fernando Perez <fperez@colorado.edu>
3521
3526
3522 * IPython/GnuplotInteractive.py (__all__): added plot2.
3527 * IPython/GnuplotInteractive.py (__all__): added plot2.
3523
3528
3524 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
3529 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
3525 plotting dictionaries, lists or tuples of 1d arrays.
3530 plotting dictionaries, lists or tuples of 1d arrays.
3526
3531
3527 * IPython/Magic.py (Magic.magic_hist): small clenaups and
3532 * IPython/Magic.py (Magic.magic_hist): small clenaups and
3528 optimizations.
3533 optimizations.
3529
3534
3530 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
3535 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
3531 the information which was there from Janko's original IPP code:
3536 the information which was there from Janko's original IPP code:
3532
3537
3533 03.05.99 20:53 porto.ifm.uni-kiel.de
3538 03.05.99 20:53 porto.ifm.uni-kiel.de
3534 --Started changelog.
3539 --Started changelog.
3535 --make clear do what it say it does
3540 --make clear do what it say it does
3536 --added pretty output of lines from inputcache
3541 --added pretty output of lines from inputcache
3537 --Made Logger a mixin class, simplifies handling of switches
3542 --Made Logger a mixin class, simplifies handling of switches
3538 --Added own completer class. .string<TAB> expands to last history
3543 --Added own completer class. .string<TAB> expands to last history
3539 line which starts with string. The new expansion is also present
3544 line which starts with string. The new expansion is also present
3540 with Ctrl-r from the readline library. But this shows, who this
3545 with Ctrl-r from the readline library. But this shows, who this
3541 can be done for other cases.
3546 can be done for other cases.
3542 --Added convention that all shell functions should accept a
3547 --Added convention that all shell functions should accept a
3543 parameter_string This opens the door for different behaviour for
3548 parameter_string This opens the door for different behaviour for
3544 each function. @cd is a good example of this.
3549 each function. @cd is a good example of this.
3545
3550
3546 04.05.99 12:12 porto.ifm.uni-kiel.de
3551 04.05.99 12:12 porto.ifm.uni-kiel.de
3547 --added logfile rotation
3552 --added logfile rotation
3548 --added new mainloop method which freezes first the namespace
3553 --added new mainloop method which freezes first the namespace
3549
3554
3550 07.05.99 21:24 porto.ifm.uni-kiel.de
3555 07.05.99 21:24 porto.ifm.uni-kiel.de
3551 --added the docreader classes. Now there is a help system.
3556 --added the docreader classes. Now there is a help system.
3552 -This is only a first try. Currently it's not easy to put new
3557 -This is only a first try. Currently it's not easy to put new
3553 stuff in the indices. But this is the way to go. Info would be
3558 stuff in the indices. But this is the way to go. Info would be
3554 better, but HTML is every where and not everybody has an info
3559 better, but HTML is every where and not everybody has an info
3555 system installed and it's not so easy to change html-docs to info.
3560 system installed and it's not so easy to change html-docs to info.
3556 --added global logfile option
3561 --added global logfile option
3557 --there is now a hook for object inspection method pinfo needs to
3562 --there is now a hook for object inspection method pinfo needs to
3558 be provided for this. Can be reached by two '??'.
3563 be provided for this. Can be reached by two '??'.
3559
3564
3560 08.05.99 20:51 porto.ifm.uni-kiel.de
3565 08.05.99 20:51 porto.ifm.uni-kiel.de
3561 --added a README
3566 --added a README
3562 --bug in rc file. Something has changed so functions in the rc
3567 --bug in rc file. Something has changed so functions in the rc
3563 file need to reference the shell and not self. Not clear if it's a
3568 file need to reference the shell and not self. Not clear if it's a
3564 bug or feature.
3569 bug or feature.
3565 --changed rc file for new behavior
3570 --changed rc file for new behavior
3566
3571
3567 2004-07-15 Fernando Perez <fperez@colorado.edu>
3572 2004-07-15 Fernando Perez <fperez@colorado.edu>
3568
3573
3569 * IPython/Logger.py (Logger.log): fixed recent bug where the input
3574 * IPython/Logger.py (Logger.log): fixed recent bug where the input
3570 cache was falling out of sync in bizarre manners when multi-line
3575 cache was falling out of sync in bizarre manners when multi-line
3571 input was present. Minor optimizations and cleanup.
3576 input was present. Minor optimizations and cleanup.
3572
3577
3573 (Logger): Remove old Changelog info for cleanup. This is the
3578 (Logger): Remove old Changelog info for cleanup. This is the
3574 information which was there from Janko's original code:
3579 information which was there from Janko's original code:
3575
3580
3576 Changes to Logger: - made the default log filename a parameter
3581 Changes to Logger: - made the default log filename a parameter
3577
3582
3578 - put a check for lines beginning with !@? in log(). Needed
3583 - put a check for lines beginning with !@? in log(). Needed
3579 (even if the handlers properly log their lines) for mid-session
3584 (even if the handlers properly log their lines) for mid-session
3580 logging activation to work properly. Without this, lines logged
3585 logging activation to work properly. Without this, lines logged
3581 in mid session, which get read from the cache, would end up
3586 in mid session, which get read from the cache, would end up
3582 'bare' (with !@? in the open) in the log. Now they are caught
3587 'bare' (with !@? in the open) in the log. Now they are caught
3583 and prepended with a #.
3588 and prepended with a #.
3584
3589
3585 * IPython/iplib.py (InteractiveShell.init_readline): added check
3590 * IPython/iplib.py (InteractiveShell.init_readline): added check
3586 in case MagicCompleter fails to be defined, so we don't crash.
3591 in case MagicCompleter fails to be defined, so we don't crash.
3587
3592
3588 2004-07-13 Fernando Perez <fperez@colorado.edu>
3593 2004-07-13 Fernando Perez <fperez@colorado.edu>
3589
3594
3590 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
3595 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
3591 of EPS if the requested filename ends in '.eps'.
3596 of EPS if the requested filename ends in '.eps'.
3592
3597
3593 2004-07-04 Fernando Perez <fperez@colorado.edu>
3598 2004-07-04 Fernando Perez <fperez@colorado.edu>
3594
3599
3595 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
3600 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
3596 escaping of quotes when calling the shell.
3601 escaping of quotes when calling the shell.
3597
3602
3598 2004-07-02 Fernando Perez <fperez@colorado.edu>
3603 2004-07-02 Fernando Perez <fperez@colorado.edu>
3599
3604
3600 * IPython/Prompts.py (CachedOutput.update): Fix problem with
3605 * IPython/Prompts.py (CachedOutput.update): Fix problem with
3601 gettext not working because we were clobbering '_'. Fixes
3606 gettext not working because we were clobbering '_'. Fixes
3602 http://www.scipy.net/roundup/ipython/issue6.
3607 http://www.scipy.net/roundup/ipython/issue6.
3603
3608
3604 2004-07-01 Fernando Perez <fperez@colorado.edu>
3609 2004-07-01 Fernando Perez <fperez@colorado.edu>
3605
3610
3606 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
3611 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
3607 into @cd. Patch by Ville.
3612 into @cd. Patch by Ville.
3608
3613
3609 * IPython/iplib.py (InteractiveShell.post_config_initialization):
3614 * IPython/iplib.py (InteractiveShell.post_config_initialization):
3610 new function to store things after ipmaker runs. Patch by Ville.
3615 new function to store things after ipmaker runs. Patch by Ville.
3611 Eventually this will go away once ipmaker is removed and the class
3616 Eventually this will go away once ipmaker is removed and the class
3612 gets cleaned up, but for now it's ok. Key functionality here is
3617 gets cleaned up, but for now it's ok. Key functionality here is
3613 the addition of the persistent storage mechanism, a dict for
3618 the addition of the persistent storage mechanism, a dict for
3614 keeping data across sessions (for now just bookmarks, but more can
3619 keeping data across sessions (for now just bookmarks, but more can
3615 be implemented later).
3620 be implemented later).
3616
3621
3617 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
3622 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
3618 persistent across sections. Patch by Ville, I modified it
3623 persistent across sections. Patch by Ville, I modified it
3619 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
3624 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
3620 added a '-l' option to list all bookmarks.
3625 added a '-l' option to list all bookmarks.
3621
3626
3622 * IPython/iplib.py (InteractiveShell.atexit_operations): new
3627 * IPython/iplib.py (InteractiveShell.atexit_operations): new
3623 center for cleanup. Registered with atexit.register(). I moved
3628 center for cleanup. Registered with atexit.register(). I moved
3624 here the old exit_cleanup(). After a patch by Ville.
3629 here the old exit_cleanup(). After a patch by Ville.
3625
3630
3626 * IPython/Magic.py (get_py_filename): added '~' to the accepted
3631 * IPython/Magic.py (get_py_filename): added '~' to the accepted
3627 characters in the hacked shlex_split for python 2.2.
3632 characters in the hacked shlex_split for python 2.2.
3628
3633
3629 * IPython/iplib.py (file_matches): more fixes to filenames with
3634 * IPython/iplib.py (file_matches): more fixes to filenames with
3630 whitespace in them. It's not perfect, but limitations in python's
3635 whitespace in them. It's not perfect, but limitations in python's
3631 readline make it impossible to go further.
3636 readline make it impossible to go further.
3632
3637
3633 2004-06-29 Fernando Perez <fperez@colorado.edu>
3638 2004-06-29 Fernando Perez <fperez@colorado.edu>
3634
3639
3635 * IPython/iplib.py (file_matches): escape whitespace correctly in
3640 * IPython/iplib.py (file_matches): escape whitespace correctly in
3636 filename completions. Bug reported by Ville.
3641 filename completions. Bug reported by Ville.
3637
3642
3638 2004-06-28 Fernando Perez <fperez@colorado.edu>
3643 2004-06-28 Fernando Perez <fperez@colorado.edu>
3639
3644
3640 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
3645 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
3641 the history file will be called 'history-PROFNAME' (or just
3646 the history file will be called 'history-PROFNAME' (or just
3642 'history' if no profile is loaded). I was getting annoyed at
3647 'history' if no profile is loaded). I was getting annoyed at
3643 getting my Numerical work history clobbered by pysh sessions.
3648 getting my Numerical work history clobbered by pysh sessions.
3644
3649
3645 * IPython/iplib.py (InteractiveShell.__init__): Internal
3650 * IPython/iplib.py (InteractiveShell.__init__): Internal
3646 getoutputerror() function so that we can honor the system_verbose
3651 getoutputerror() function so that we can honor the system_verbose
3647 flag for _all_ system calls. I also added escaping of #
3652 flag for _all_ system calls. I also added escaping of #
3648 characters here to avoid confusing Itpl.
3653 characters here to avoid confusing Itpl.
3649
3654
3650 * IPython/Magic.py (shlex_split): removed call to shell in
3655 * IPython/Magic.py (shlex_split): removed call to shell in
3651 parse_options and replaced it with shlex.split(). The annoying
3656 parse_options and replaced it with shlex.split(). The annoying
3652 part was that in Python 2.2, shlex.split() doesn't exist, so I had
3657 part was that in Python 2.2, shlex.split() doesn't exist, so I had
3653 to backport it from 2.3, with several frail hacks (the shlex
3658 to backport it from 2.3, with several frail hacks (the shlex
3654 module is rather limited in 2.2). Thanks to a suggestion by Ville
3659 module is rather limited in 2.2). Thanks to a suggestion by Ville
3655 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
3660 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
3656 problem.
3661 problem.
3657
3662
3658 (Magic.magic_system_verbose): new toggle to print the actual
3663 (Magic.magic_system_verbose): new toggle to print the actual
3659 system calls made by ipython. Mainly for debugging purposes.
3664 system calls made by ipython. Mainly for debugging purposes.
3660
3665
3661 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
3666 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
3662 doesn't support persistence. Reported (and fix suggested) by
3667 doesn't support persistence. Reported (and fix suggested) by
3663 Travis Caldwell <travis_caldwell2000@yahoo.com>.
3668 Travis Caldwell <travis_caldwell2000@yahoo.com>.
3664
3669
3665 2004-06-26 Fernando Perez <fperez@colorado.edu>
3670 2004-06-26 Fernando Perez <fperez@colorado.edu>
3666
3671
3667 * IPython/Logger.py (Logger.log): fix to handle correctly empty
3672 * IPython/Logger.py (Logger.log): fix to handle correctly empty
3668 continue prompts.
3673 continue prompts.
3669
3674
3670 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
3675 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
3671 function (basically a big docstring) and a few more things here to
3676 function (basically a big docstring) and a few more things here to
3672 speedup startup. pysh.py is now very lightweight. We want because
3677 speedup startup. pysh.py is now very lightweight. We want because
3673 it gets execfile'd, while InterpreterExec gets imported, so
3678 it gets execfile'd, while InterpreterExec gets imported, so
3674 byte-compilation saves time.
3679 byte-compilation saves time.
3675
3680
3676 2004-06-25 Fernando Perez <fperez@colorado.edu>
3681 2004-06-25 Fernando Perez <fperez@colorado.edu>
3677
3682
3678 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
3683 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
3679 -NUM', which was recently broken.
3684 -NUM', which was recently broken.
3680
3685
3681 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
3686 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
3682 in multi-line input (but not !!, which doesn't make sense there).
3687 in multi-line input (but not !!, which doesn't make sense there).
3683
3688
3684 * IPython/UserConfig/ipythonrc: made autoindent on by default.
3689 * IPython/UserConfig/ipythonrc: made autoindent on by default.
3685 It's just too useful, and people can turn it off in the less
3690 It's just too useful, and people can turn it off in the less
3686 common cases where it's a problem.
3691 common cases where it's a problem.
3687
3692
3688 2004-06-24 Fernando Perez <fperez@colorado.edu>
3693 2004-06-24 Fernando Perez <fperez@colorado.edu>
3689
3694
3690 * IPython/iplib.py (InteractiveShell._prefilter): big change -
3695 * IPython/iplib.py (InteractiveShell._prefilter): big change -
3691 special syntaxes (like alias calling) is now allied in multi-line
3696 special syntaxes (like alias calling) is now allied in multi-line
3692 input. This is still _very_ experimental, but it's necessary for
3697 input. This is still _very_ experimental, but it's necessary for
3693 efficient shell usage combining python looping syntax with system
3698 efficient shell usage combining python looping syntax with system
3694 calls. For now it's restricted to aliases, I don't think it
3699 calls. For now it's restricted to aliases, I don't think it
3695 really even makes sense to have this for magics.
3700 really even makes sense to have this for magics.
3696
3701
3697 2004-06-23 Fernando Perez <fperez@colorado.edu>
3702 2004-06-23 Fernando Perez <fperez@colorado.edu>
3698
3703
3699 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
3704 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
3700 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
3705 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
3701
3706
3702 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
3707 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
3703 extensions under Windows (after code sent by Gary Bishop). The
3708 extensions under Windows (after code sent by Gary Bishop). The
3704 extensions considered 'executable' are stored in IPython's rc
3709 extensions considered 'executable' are stored in IPython's rc
3705 structure as win_exec_ext.
3710 structure as win_exec_ext.
3706
3711
3707 * IPython/genutils.py (shell): new function, like system() but
3712 * IPython/genutils.py (shell): new function, like system() but
3708 without return value. Very useful for interactive shell work.
3713 without return value. Very useful for interactive shell work.
3709
3714
3710 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
3715 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
3711 delete aliases.
3716 delete aliases.
3712
3717
3713 * IPython/iplib.py (InteractiveShell.alias_table_update): make
3718 * IPython/iplib.py (InteractiveShell.alias_table_update): make
3714 sure that the alias table doesn't contain python keywords.
3719 sure that the alias table doesn't contain python keywords.
3715
3720
3716 2004-06-21 Fernando Perez <fperez@colorado.edu>
3721 2004-06-21 Fernando Perez <fperez@colorado.edu>
3717
3722
3718 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
3723 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
3719 non-existent items are found in $PATH. Reported by Thorsten.
3724 non-existent items are found in $PATH. Reported by Thorsten.
3720
3725
3721 2004-06-20 Fernando Perez <fperez@colorado.edu>
3726 2004-06-20 Fernando Perez <fperez@colorado.edu>
3722
3727
3723 * IPython/iplib.py (complete): modified the completer so that the
3728 * IPython/iplib.py (complete): modified the completer so that the
3724 order of priorities can be easily changed at runtime.
3729 order of priorities can be easily changed at runtime.
3725
3730
3726 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
3731 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
3727 Modified to auto-execute all lines beginning with '~', '/' or '.'.
3732 Modified to auto-execute all lines beginning with '~', '/' or '.'.
3728
3733
3729 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
3734 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
3730 expand Python variables prepended with $ in all system calls. The
3735 expand Python variables prepended with $ in all system calls. The
3731 same was done to InteractiveShell.handle_shell_escape. Now all
3736 same was done to InteractiveShell.handle_shell_escape. Now all
3732 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
3737 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
3733 expansion of python variables and expressions according to the
3738 expansion of python variables and expressions according to the
3734 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
3739 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
3735
3740
3736 Though PEP-215 has been rejected, a similar (but simpler) one
3741 Though PEP-215 has been rejected, a similar (but simpler) one
3737 seems like it will go into Python 2.4, PEP-292 -
3742 seems like it will go into Python 2.4, PEP-292 -
3738 http://www.python.org/peps/pep-0292.html.
3743 http://www.python.org/peps/pep-0292.html.
3739
3744
3740 I'll keep the full syntax of PEP-215, since IPython has since the
3745 I'll keep the full syntax of PEP-215, since IPython has since the
3741 start used Ka-Ping Yee's reference implementation discussed there
3746 start used Ka-Ping Yee's reference implementation discussed there
3742 (Itpl), and I actually like the powerful semantics it offers.
3747 (Itpl), and I actually like the powerful semantics it offers.
3743
3748
3744 In order to access normal shell variables, the $ has to be escaped
3749 In order to access normal shell variables, the $ has to be escaped
3745 via an extra $. For example:
3750 via an extra $. For example:
3746
3751
3747 In [7]: PATH='a python variable'
3752 In [7]: PATH='a python variable'
3748
3753
3749 In [8]: !echo $PATH
3754 In [8]: !echo $PATH
3750 a python variable
3755 a python variable
3751
3756
3752 In [9]: !echo $$PATH
3757 In [9]: !echo $$PATH
3753 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
3758 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
3754
3759
3755 (Magic.parse_options): escape $ so the shell doesn't evaluate
3760 (Magic.parse_options): escape $ so the shell doesn't evaluate
3756 things prematurely.
3761 things prematurely.
3757
3762
3758 * IPython/iplib.py (InteractiveShell.call_alias): added the
3763 * IPython/iplib.py (InteractiveShell.call_alias): added the
3759 ability for aliases to expand python variables via $.
3764 ability for aliases to expand python variables via $.
3760
3765
3761 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
3766 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
3762 system, now there's a @rehash/@rehashx pair of magics. These work
3767 system, now there's a @rehash/@rehashx pair of magics. These work
3763 like the csh rehash command, and can be invoked at any time. They
3768 like the csh rehash command, and can be invoked at any time. They
3764 build a table of aliases to everything in the user's $PATH
3769 build a table of aliases to everything in the user's $PATH
3765 (@rehash uses everything, @rehashx is slower but only adds
3770 (@rehash uses everything, @rehashx is slower but only adds
3766 executable files). With this, the pysh.py-based shell profile can
3771 executable files). With this, the pysh.py-based shell profile can
3767 now simply call rehash upon startup, and full access to all
3772 now simply call rehash upon startup, and full access to all
3768 programs in the user's path is obtained.
3773 programs in the user's path is obtained.
3769
3774
3770 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
3775 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
3771 functionality is now fully in place. I removed the old dynamic
3776 functionality is now fully in place. I removed the old dynamic
3772 code generation based approach, in favor of a much lighter one
3777 code generation based approach, in favor of a much lighter one
3773 based on a simple dict. The advantage is that this allows me to
3778 based on a simple dict. The advantage is that this allows me to
3774 now have thousands of aliases with negligible cost (unthinkable
3779 now have thousands of aliases with negligible cost (unthinkable
3775 with the old system).
3780 with the old system).
3776
3781
3777 2004-06-19 Fernando Perez <fperez@colorado.edu>
3782 2004-06-19 Fernando Perez <fperez@colorado.edu>
3778
3783
3779 * IPython/iplib.py (__init__): extended MagicCompleter class to
3784 * IPython/iplib.py (__init__): extended MagicCompleter class to
3780 also complete (last in priority) on user aliases.
3785 also complete (last in priority) on user aliases.
3781
3786
3782 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
3787 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
3783 call to eval.
3788 call to eval.
3784 (ItplNS.__init__): Added a new class which functions like Itpl,
3789 (ItplNS.__init__): Added a new class which functions like Itpl,
3785 but allows configuring the namespace for the evaluation to occur
3790 but allows configuring the namespace for the evaluation to occur
3786 in.
3791 in.
3787
3792
3788 2004-06-18 Fernando Perez <fperez@colorado.edu>
3793 2004-06-18 Fernando Perez <fperez@colorado.edu>
3789
3794
3790 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
3795 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
3791 better message when 'exit' or 'quit' are typed (a common newbie
3796 better message when 'exit' or 'quit' are typed (a common newbie
3792 confusion).
3797 confusion).
3793
3798
3794 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
3799 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
3795 check for Windows users.
3800 check for Windows users.
3796
3801
3797 * IPython/iplib.py (InteractiveShell.user_setup): removed
3802 * IPython/iplib.py (InteractiveShell.user_setup): removed
3798 disabling of colors for Windows. I'll test at runtime and issue a
3803 disabling of colors for Windows. I'll test at runtime and issue a
3799 warning if Gary's readline isn't found, as to nudge users to
3804 warning if Gary's readline isn't found, as to nudge users to
3800 download it.
3805 download it.
3801
3806
3802 2004-06-16 Fernando Perez <fperez@colorado.edu>
3807 2004-06-16 Fernando Perez <fperez@colorado.edu>
3803
3808
3804 * IPython/genutils.py (Stream.__init__): changed to print errors
3809 * IPython/genutils.py (Stream.__init__): changed to print errors
3805 to sys.stderr. I had a circular dependency here. Now it's
3810 to sys.stderr. I had a circular dependency here. Now it's
3806 possible to run ipython as IDLE's shell (consider this pre-alpha,
3811 possible to run ipython as IDLE's shell (consider this pre-alpha,
3807 since true stdout things end up in the starting terminal instead
3812 since true stdout things end up in the starting terminal instead
3808 of IDLE's out).
3813 of IDLE's out).
3809
3814
3810 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
3815 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
3811 users who haven't # updated their prompt_in2 definitions. Remove
3816 users who haven't # updated their prompt_in2 definitions. Remove
3812 eventually.
3817 eventually.
3813 (multiple_replace): added credit to original ASPN recipe.
3818 (multiple_replace): added credit to original ASPN recipe.
3814
3819
3815 2004-06-15 Fernando Perez <fperez@colorado.edu>
3820 2004-06-15 Fernando Perez <fperez@colorado.edu>
3816
3821
3817 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
3822 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
3818 list of auto-defined aliases.
3823 list of auto-defined aliases.
3819
3824
3820 2004-06-13 Fernando Perez <fperez@colorado.edu>
3825 2004-06-13 Fernando Perez <fperez@colorado.edu>
3821
3826
3822 * setup.py (scriptfiles): Don't trigger win_post_install unless an
3827 * setup.py (scriptfiles): Don't trigger win_post_install unless an
3823 install was really requested (so setup.py can be used for other
3828 install was really requested (so setup.py can be used for other
3824 things under Windows).
3829 things under Windows).
3825
3830
3826 2004-06-10 Fernando Perez <fperez@colorado.edu>
3831 2004-06-10 Fernando Perez <fperez@colorado.edu>
3827
3832
3828 * IPython/Logger.py (Logger.create_log): Manually remove any old
3833 * IPython/Logger.py (Logger.create_log): Manually remove any old
3829 backup, since os.remove may fail under Windows. Fixes bug
3834 backup, since os.remove may fail under Windows. Fixes bug
3830 reported by Thorsten.
3835 reported by Thorsten.
3831
3836
3832 2004-06-09 Fernando Perez <fperez@colorado.edu>
3837 2004-06-09 Fernando Perez <fperez@colorado.edu>
3833
3838
3834 * examples/example-embed.py: fixed all references to %n (replaced
3839 * examples/example-embed.py: fixed all references to %n (replaced
3835 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
3840 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
3836 for all examples and the manual as well.
3841 for all examples and the manual as well.
3837
3842
3838 2004-06-08 Fernando Perez <fperez@colorado.edu>
3843 2004-06-08 Fernando Perez <fperez@colorado.edu>
3839
3844
3840 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
3845 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
3841 alignment and color management. All 3 prompt subsystems now
3846 alignment and color management. All 3 prompt subsystems now
3842 inherit from BasePrompt.
3847 inherit from BasePrompt.
3843
3848
3844 * tools/release: updates for windows installer build and tag rpms
3849 * tools/release: updates for windows installer build and tag rpms
3845 with python version (since paths are fixed).
3850 with python version (since paths are fixed).
3846
3851
3847 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
3852 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
3848 which will become eventually obsolete. Also fixed the default
3853 which will become eventually obsolete. Also fixed the default
3849 prompt_in2 to use \D, so at least new users start with the correct
3854 prompt_in2 to use \D, so at least new users start with the correct
3850 defaults.
3855 defaults.
3851 WARNING: Users with existing ipythonrc files will need to apply
3856 WARNING: Users with existing ipythonrc files will need to apply
3852 this fix manually!
3857 this fix manually!
3853
3858
3854 * setup.py: make windows installer (.exe). This is finally the
3859 * setup.py: make windows installer (.exe). This is finally the
3855 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
3860 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
3856 which I hadn't included because it required Python 2.3 (or recent
3861 which I hadn't included because it required Python 2.3 (or recent
3857 distutils).
3862 distutils).
3858
3863
3859 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
3864 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
3860 usage of new '\D' escape.
3865 usage of new '\D' escape.
3861
3866
3862 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
3867 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
3863 lacks os.getuid())
3868 lacks os.getuid())
3864 (CachedOutput.set_colors): Added the ability to turn coloring
3869 (CachedOutput.set_colors): Added the ability to turn coloring
3865 on/off with @colors even for manually defined prompt colors. It
3870 on/off with @colors even for manually defined prompt colors. It
3866 uses a nasty global, but it works safely and via the generic color
3871 uses a nasty global, but it works safely and via the generic color
3867 handling mechanism.
3872 handling mechanism.
3868 (Prompt2.__init__): Introduced new escape '\D' for continuation
3873 (Prompt2.__init__): Introduced new escape '\D' for continuation
3869 prompts. It represents the counter ('\#') as dots.
3874 prompts. It represents the counter ('\#') as dots.
3870 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
3875 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
3871 need to update their ipythonrc files and replace '%n' with '\D' in
3876 need to update their ipythonrc files and replace '%n' with '\D' in
3872 their prompt_in2 settings everywhere. Sorry, but there's
3877 their prompt_in2 settings everywhere. Sorry, but there's
3873 otherwise no clean way to get all prompts to properly align. The
3878 otherwise no clean way to get all prompts to properly align. The
3874 ipythonrc shipped with IPython has been updated.
3879 ipythonrc shipped with IPython has been updated.
3875
3880
3876 2004-06-07 Fernando Perez <fperez@colorado.edu>
3881 2004-06-07 Fernando Perez <fperez@colorado.edu>
3877
3882
3878 * setup.py (isfile): Pass local_icons option to latex2html, so the
3883 * setup.py (isfile): Pass local_icons option to latex2html, so the
3879 resulting HTML file is self-contained. Thanks to
3884 resulting HTML file is self-contained. Thanks to
3880 dryice-AT-liu.com.cn for the tip.
3885 dryice-AT-liu.com.cn for the tip.
3881
3886
3882 * pysh.py: I created a new profile 'shell', which implements a
3887 * pysh.py: I created a new profile 'shell', which implements a
3883 _rudimentary_ IPython-based shell. This is in NO WAY a realy
3888 _rudimentary_ IPython-based shell. This is in NO WAY a realy
3884 system shell, nor will it become one anytime soon. It's mainly
3889 system shell, nor will it become one anytime soon. It's mainly
3885 meant to illustrate the use of the new flexible bash-like prompts.
3890 meant to illustrate the use of the new flexible bash-like prompts.
3886 I guess it could be used by hardy souls for true shell management,
3891 I guess it could be used by hardy souls for true shell management,
3887 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
3892 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
3888 profile. This uses the InterpreterExec extension provided by
3893 profile. This uses the InterpreterExec extension provided by
3889 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
3894 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
3890
3895
3891 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
3896 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
3892 auto-align itself with the length of the previous input prompt
3897 auto-align itself with the length of the previous input prompt
3893 (taking into account the invisible color escapes).
3898 (taking into account the invisible color escapes).
3894 (CachedOutput.__init__): Large restructuring of this class. Now
3899 (CachedOutput.__init__): Large restructuring of this class. Now
3895 all three prompts (primary1, primary2, output) are proper objects,
3900 all three prompts (primary1, primary2, output) are proper objects,
3896 managed by the 'parent' CachedOutput class. The code is still a
3901 managed by the 'parent' CachedOutput class. The code is still a
3897 bit hackish (all prompts share state via a pointer to the cache),
3902 bit hackish (all prompts share state via a pointer to the cache),
3898 but it's overall far cleaner than before.
3903 but it's overall far cleaner than before.
3899
3904
3900 * IPython/genutils.py (getoutputerror): modified to add verbose,
3905 * IPython/genutils.py (getoutputerror): modified to add verbose,
3901 debug and header options. This makes the interface of all getout*
3906 debug and header options. This makes the interface of all getout*
3902 functions uniform.
3907 functions uniform.
3903 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
3908 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
3904
3909
3905 * IPython/Magic.py (Magic.default_option): added a function to
3910 * IPython/Magic.py (Magic.default_option): added a function to
3906 allow registering default options for any magic command. This
3911 allow registering default options for any magic command. This
3907 makes it easy to have profiles which customize the magics globally
3912 makes it easy to have profiles which customize the magics globally
3908 for a certain use. The values set through this function are
3913 for a certain use. The values set through this function are
3909 picked up by the parse_options() method, which all magics should
3914 picked up by the parse_options() method, which all magics should
3910 use to parse their options.
3915 use to parse their options.
3911
3916
3912 * IPython/genutils.py (warn): modified the warnings framework to
3917 * IPython/genutils.py (warn): modified the warnings framework to
3913 use the Term I/O class. I'm trying to slowly unify all of
3918 use the Term I/O class. I'm trying to slowly unify all of
3914 IPython's I/O operations to pass through Term.
3919 IPython's I/O operations to pass through Term.
3915
3920
3916 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
3921 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
3917 the secondary prompt to correctly match the length of the primary
3922 the secondary prompt to correctly match the length of the primary
3918 one for any prompt. Now multi-line code will properly line up
3923 one for any prompt. Now multi-line code will properly line up
3919 even for path dependent prompts, such as the new ones available
3924 even for path dependent prompts, such as the new ones available
3920 via the prompt_specials.
3925 via the prompt_specials.
3921
3926
3922 2004-06-06 Fernando Perez <fperez@colorado.edu>
3927 2004-06-06 Fernando Perez <fperez@colorado.edu>
3923
3928
3924 * IPython/Prompts.py (prompt_specials): Added the ability to have
3929 * IPython/Prompts.py (prompt_specials): Added the ability to have
3925 bash-like special sequences in the prompts, which get
3930 bash-like special sequences in the prompts, which get
3926 automatically expanded. Things like hostname, current working
3931 automatically expanded. Things like hostname, current working
3927 directory and username are implemented already, but it's easy to
3932 directory and username are implemented already, but it's easy to
3928 add more in the future. Thanks to a patch by W.J. van der Laan
3933 add more in the future. Thanks to a patch by W.J. van der Laan
3929 <gnufnork-AT-hetdigitalegat.nl>
3934 <gnufnork-AT-hetdigitalegat.nl>
3930 (prompt_specials): Added color support for prompt strings, so
3935 (prompt_specials): Added color support for prompt strings, so
3931 users can define arbitrary color setups for their prompts.
3936 users can define arbitrary color setups for their prompts.
3932
3937
3933 2004-06-05 Fernando Perez <fperez@colorado.edu>
3938 2004-06-05 Fernando Perez <fperez@colorado.edu>
3934
3939
3935 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
3940 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
3936 code to load Gary Bishop's readline and configure it
3941 code to load Gary Bishop's readline and configure it
3937 automatically. Thanks to Gary for help on this.
3942 automatically. Thanks to Gary for help on this.
3938
3943
3939 2004-06-01 Fernando Perez <fperez@colorado.edu>
3944 2004-06-01 Fernando Perez <fperez@colorado.edu>
3940
3945
3941 * IPython/Logger.py (Logger.create_log): fix bug for logging
3946 * IPython/Logger.py (Logger.create_log): fix bug for logging
3942 with no filename (previous fix was incomplete).
3947 with no filename (previous fix was incomplete).
3943
3948
3944 2004-05-25 Fernando Perez <fperez@colorado.edu>
3949 2004-05-25 Fernando Perez <fperez@colorado.edu>
3945
3950
3946 * IPython/Magic.py (Magic.parse_options): fix bug where naked
3951 * IPython/Magic.py (Magic.parse_options): fix bug where naked
3947 parens would get passed to the shell.
3952 parens would get passed to the shell.
3948
3953
3949 2004-05-20 Fernando Perez <fperez@colorado.edu>
3954 2004-05-20 Fernando Perez <fperez@colorado.edu>
3950
3955
3951 * IPython/Magic.py (Magic.magic_prun): changed default profile
3956 * IPython/Magic.py (Magic.magic_prun): changed default profile
3952 sort order to 'time' (the more common profiling need).
3957 sort order to 'time' (the more common profiling need).
3953
3958
3954 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
3959 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
3955 so that source code shown is guaranteed in sync with the file on
3960 so that source code shown is guaranteed in sync with the file on
3956 disk (also changed in psource). Similar fix to the one for
3961 disk (also changed in psource). Similar fix to the one for
3957 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
3962 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
3958 <yann.ledu-AT-noos.fr>.
3963 <yann.ledu-AT-noos.fr>.
3959
3964
3960 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
3965 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
3961 with a single option would not be correctly parsed. Closes
3966 with a single option would not be correctly parsed. Closes
3962 http://www.scipy.net/roundup/ipython/issue14. This bug had been
3967 http://www.scipy.net/roundup/ipython/issue14. This bug had been
3963 introduced in 0.6.0 (on 2004-05-06).
3968 introduced in 0.6.0 (on 2004-05-06).
3964
3969
3965 2004-05-13 *** Released version 0.6.0
3970 2004-05-13 *** Released version 0.6.0
3966
3971
3967 2004-05-13 Fernando Perez <fperez@colorado.edu>
3972 2004-05-13 Fernando Perez <fperez@colorado.edu>
3968
3973
3969 * debian/: Added debian/ directory to CVS, so that debian support
3974 * debian/: Added debian/ directory to CVS, so that debian support
3970 is publicly accessible. The debian package is maintained by Jack
3975 is publicly accessible. The debian package is maintained by Jack
3971 Moffit <jack-AT-xiph.org>.
3976 Moffit <jack-AT-xiph.org>.
3972
3977
3973 * Documentation: included the notes about an ipython-based system
3978 * Documentation: included the notes about an ipython-based system
3974 shell (the hypothetical 'pysh') into the new_design.pdf document,
3979 shell (the hypothetical 'pysh') into the new_design.pdf document,
3975 so that these ideas get distributed to users along with the
3980 so that these ideas get distributed to users along with the
3976 official documentation.
3981 official documentation.
3977
3982
3978 2004-05-10 Fernando Perez <fperez@colorado.edu>
3983 2004-05-10 Fernando Perez <fperez@colorado.edu>
3979
3984
3980 * IPython/Logger.py (Logger.create_log): fix recently introduced
3985 * IPython/Logger.py (Logger.create_log): fix recently introduced
3981 bug (misindented line) where logstart would fail when not given an
3986 bug (misindented line) where logstart would fail when not given an
3982 explicit filename.
3987 explicit filename.
3983
3988
3984 2004-05-09 Fernando Perez <fperez@colorado.edu>
3989 2004-05-09 Fernando Perez <fperez@colorado.edu>
3985
3990
3986 * IPython/Magic.py (Magic.parse_options): skip system call when
3991 * IPython/Magic.py (Magic.parse_options): skip system call when
3987 there are no options to look for. Faster, cleaner for the common
3992 there are no options to look for. Faster, cleaner for the common
3988 case.
3993 case.
3989
3994
3990 * Documentation: many updates to the manual: describing Windows
3995 * Documentation: many updates to the manual: describing Windows
3991 support better, Gnuplot updates, credits, misc small stuff. Also
3996 support better, Gnuplot updates, credits, misc small stuff. Also
3992 updated the new_design doc a bit.
3997 updated the new_design doc a bit.
3993
3998
3994 2004-05-06 *** Released version 0.6.0.rc1
3999 2004-05-06 *** Released version 0.6.0.rc1
3995
4000
3996 2004-05-06 Fernando Perez <fperez@colorado.edu>
4001 2004-05-06 Fernando Perez <fperez@colorado.edu>
3997
4002
3998 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
4003 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
3999 operations to use the vastly more efficient list/''.join() method.
4004 operations to use the vastly more efficient list/''.join() method.
4000 (FormattedTB.text): Fix
4005 (FormattedTB.text): Fix
4001 http://www.scipy.net/roundup/ipython/issue12 - exception source
4006 http://www.scipy.net/roundup/ipython/issue12 - exception source
4002 extract not updated after reload. Thanks to Mike Salib
4007 extract not updated after reload. Thanks to Mike Salib
4003 <msalib-AT-mit.edu> for pinning the source of the problem.
4008 <msalib-AT-mit.edu> for pinning the source of the problem.
4004 Fortunately, the solution works inside ipython and doesn't require
4009 Fortunately, the solution works inside ipython and doesn't require
4005 any changes to python proper.
4010 any changes to python proper.
4006
4011
4007 * IPython/Magic.py (Magic.parse_options): Improved to process the
4012 * IPython/Magic.py (Magic.parse_options): Improved to process the
4008 argument list as a true shell would (by actually using the
4013 argument list as a true shell would (by actually using the
4009 underlying system shell). This way, all @magics automatically get
4014 underlying system shell). This way, all @magics automatically get
4010 shell expansion for variables. Thanks to a comment by Alex
4015 shell expansion for variables. Thanks to a comment by Alex
4011 Schmolck.
4016 Schmolck.
4012
4017
4013 2004-04-04 Fernando Perez <fperez@colorado.edu>
4018 2004-04-04 Fernando Perez <fperez@colorado.edu>
4014
4019
4015 * IPython/iplib.py (InteractiveShell.interact): Added a special
4020 * IPython/iplib.py (InteractiveShell.interact): Added a special
4016 trap for a debugger quit exception, which is basically impossible
4021 trap for a debugger quit exception, which is basically impossible
4017 to handle by normal mechanisms, given what pdb does to the stack.
4022 to handle by normal mechanisms, given what pdb does to the stack.
4018 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
4023 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
4019
4024
4020 2004-04-03 Fernando Perez <fperez@colorado.edu>
4025 2004-04-03 Fernando Perez <fperez@colorado.edu>
4021
4026
4022 * IPython/genutils.py (Term): Standardized the names of the Term
4027 * IPython/genutils.py (Term): Standardized the names of the Term
4023 class streams to cin/cout/cerr, following C++ naming conventions
4028 class streams to cin/cout/cerr, following C++ naming conventions
4024 (I can't use in/out/err because 'in' is not a valid attribute
4029 (I can't use in/out/err because 'in' is not a valid attribute
4025 name).
4030 name).
4026
4031
4027 * IPython/iplib.py (InteractiveShell.interact): don't increment
4032 * IPython/iplib.py (InteractiveShell.interact): don't increment
4028 the prompt if there's no user input. By Daniel 'Dang' Griffith
4033 the prompt if there's no user input. By Daniel 'Dang' Griffith
4029 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
4034 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
4030 Francois Pinard.
4035 Francois Pinard.
4031
4036
4032 2004-04-02 Fernando Perez <fperez@colorado.edu>
4037 2004-04-02 Fernando Perez <fperez@colorado.edu>
4033
4038
4034 * IPython/genutils.py (Stream.__init__): Modified to survive at
4039 * IPython/genutils.py (Stream.__init__): Modified to survive at
4035 least importing in contexts where stdin/out/err aren't true file
4040 least importing in contexts where stdin/out/err aren't true file
4036 objects, such as PyCrust (they lack fileno() and mode). However,
4041 objects, such as PyCrust (they lack fileno() and mode). However,
4037 the recovery facilities which rely on these things existing will
4042 the recovery facilities which rely on these things existing will
4038 not work.
4043 not work.
4039
4044
4040 2004-04-01 Fernando Perez <fperez@colorado.edu>
4045 2004-04-01 Fernando Perez <fperez@colorado.edu>
4041
4046
4042 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
4047 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
4043 use the new getoutputerror() function, so it properly
4048 use the new getoutputerror() function, so it properly
4044 distinguishes stdout/err.
4049 distinguishes stdout/err.
4045
4050
4046 * IPython/genutils.py (getoutputerror): added a function to
4051 * IPython/genutils.py (getoutputerror): added a function to
4047 capture separately the standard output and error of a command.
4052 capture separately the standard output and error of a command.
4048 After a comment from dang on the mailing lists. This code is
4053 After a comment from dang on the mailing lists. This code is
4049 basically a modified version of commands.getstatusoutput(), from
4054 basically a modified version of commands.getstatusoutput(), from
4050 the standard library.
4055 the standard library.
4051
4056
4052 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
4057 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
4053 '!!' as a special syntax (shorthand) to access @sx.
4058 '!!' as a special syntax (shorthand) to access @sx.
4054
4059
4055 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
4060 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
4056 command and return its output as a list split on '\n'.
4061 command and return its output as a list split on '\n'.
4057
4062
4058 2004-03-31 Fernando Perez <fperez@colorado.edu>
4063 2004-03-31 Fernando Perez <fperez@colorado.edu>
4059
4064
4060 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
4065 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
4061 method to dictionaries used as FakeModule instances if they lack
4066 method to dictionaries used as FakeModule instances if they lack
4062 it. At least pydoc in python2.3 breaks for runtime-defined
4067 it. At least pydoc in python2.3 breaks for runtime-defined
4063 functions without this hack. At some point I need to _really_
4068 functions without this hack. At some point I need to _really_
4064 understand what FakeModule is doing, because it's a gross hack.
4069 understand what FakeModule is doing, because it's a gross hack.
4065 But it solves Arnd's problem for now...
4070 But it solves Arnd's problem for now...
4066
4071
4067 2004-02-27 Fernando Perez <fperez@colorado.edu>
4072 2004-02-27 Fernando Perez <fperez@colorado.edu>
4068
4073
4069 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
4074 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
4070 mode would behave erratically. Also increased the number of
4075 mode would behave erratically. Also increased the number of
4071 possible logs in rotate mod to 999. Thanks to Rod Holland
4076 possible logs in rotate mod to 999. Thanks to Rod Holland
4072 <rhh@StructureLABS.com> for the report and fixes.
4077 <rhh@StructureLABS.com> for the report and fixes.
4073
4078
4074 2004-02-26 Fernando Perez <fperez@colorado.edu>
4079 2004-02-26 Fernando Perez <fperez@colorado.edu>
4075
4080
4076 * IPython/genutils.py (page): Check that the curses module really
4081 * IPython/genutils.py (page): Check that the curses module really
4077 has the initscr attribute before trying to use it. For some
4082 has the initscr attribute before trying to use it. For some
4078 reason, the Solaris curses module is missing this. I think this
4083 reason, the Solaris curses module is missing this. I think this
4079 should be considered a Solaris python bug, but I'm not sure.
4084 should be considered a Solaris python bug, but I'm not sure.
4080
4085
4081 2004-01-17 Fernando Perez <fperez@colorado.edu>
4086 2004-01-17 Fernando Perez <fperez@colorado.edu>
4082
4087
4083 * IPython/genutils.py (Stream.__init__): Changes to try to make
4088 * IPython/genutils.py (Stream.__init__): Changes to try to make
4084 ipython robust against stdin/out/err being closed by the user.
4089 ipython robust against stdin/out/err being closed by the user.
4085 This is 'user error' (and blocks a normal python session, at least
4090 This is 'user error' (and blocks a normal python session, at least
4086 the stdout case). However, Ipython should be able to survive such
4091 the stdout case). However, Ipython should be able to survive such
4087 instances of abuse as gracefully as possible. To simplify the
4092 instances of abuse as gracefully as possible. To simplify the
4088 coding and maintain compatibility with Gary Bishop's Term
4093 coding and maintain compatibility with Gary Bishop's Term
4089 contributions, I've made use of classmethods for this. I think
4094 contributions, I've made use of classmethods for this. I think
4090 this introduces a dependency on python 2.2.
4095 this introduces a dependency on python 2.2.
4091
4096
4092 2004-01-13 Fernando Perez <fperez@colorado.edu>
4097 2004-01-13 Fernando Perez <fperez@colorado.edu>
4093
4098
4094 * IPython/numutils.py (exp_safe): simplified the code a bit and
4099 * IPython/numutils.py (exp_safe): simplified the code a bit and
4095 removed the need for importing the kinds module altogether.
4100 removed the need for importing the kinds module altogether.
4096
4101
4097 2004-01-06 Fernando Perez <fperez@colorado.edu>
4102 2004-01-06 Fernando Perez <fperez@colorado.edu>
4098
4103
4099 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
4104 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
4100 a magic function instead, after some community feedback. No
4105 a magic function instead, after some community feedback. No
4101 special syntax will exist for it, but its name is deliberately
4106 special syntax will exist for it, but its name is deliberately
4102 very short.
4107 very short.
4103
4108
4104 2003-12-20 Fernando Perez <fperez@colorado.edu>
4109 2003-12-20 Fernando Perez <fperez@colorado.edu>
4105
4110
4106 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
4111 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
4107 new functionality, to automagically assign the result of a shell
4112 new functionality, to automagically assign the result of a shell
4108 command to a variable. I'll solicit some community feedback on
4113 command to a variable. I'll solicit some community feedback on
4109 this before making it permanent.
4114 this before making it permanent.
4110
4115
4111 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
4116 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
4112 requested about callables for which inspect couldn't obtain a
4117 requested about callables for which inspect couldn't obtain a
4113 proper argspec. Thanks to a crash report sent by Etienne
4118 proper argspec. Thanks to a crash report sent by Etienne
4114 Posthumus <etienne-AT-apple01.cs.vu.nl>.
4119 Posthumus <etienne-AT-apple01.cs.vu.nl>.
4115
4120
4116 2003-12-09 Fernando Perez <fperez@colorado.edu>
4121 2003-12-09 Fernando Perez <fperez@colorado.edu>
4117
4122
4118 * IPython/genutils.py (page): patch for the pager to work across
4123 * IPython/genutils.py (page): patch for the pager to work across
4119 various versions of Windows. By Gary Bishop.
4124 various versions of Windows. By Gary Bishop.
4120
4125
4121 2003-12-04 Fernando Perez <fperez@colorado.edu>
4126 2003-12-04 Fernando Perez <fperez@colorado.edu>
4122
4127
4123 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
4128 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
4124 Gnuplot.py version 1.7, whose internal names changed quite a bit.
4129 Gnuplot.py version 1.7, whose internal names changed quite a bit.
4125 While I tested this and it looks ok, there may still be corner
4130 While I tested this and it looks ok, there may still be corner
4126 cases I've missed.
4131 cases I've missed.
4127
4132
4128 2003-12-01 Fernando Perez <fperez@colorado.edu>
4133 2003-12-01 Fernando Perez <fperez@colorado.edu>
4129
4134
4130 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
4135 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
4131 where a line like 'p,q=1,2' would fail because the automagic
4136 where a line like 'p,q=1,2' would fail because the automagic
4132 system would be triggered for @p.
4137 system would be triggered for @p.
4133
4138
4134 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
4139 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
4135 cleanups, code unmodified.
4140 cleanups, code unmodified.
4136
4141
4137 * IPython/genutils.py (Term): added a class for IPython to handle
4142 * IPython/genutils.py (Term): added a class for IPython to handle
4138 output. In most cases it will just be a proxy for stdout/err, but
4143 output. In most cases it will just be a proxy for stdout/err, but
4139 having this allows modifications to be made for some platforms,
4144 having this allows modifications to be made for some platforms,
4140 such as handling color escapes under Windows. All of this code
4145 such as handling color escapes under Windows. All of this code
4141 was contributed by Gary Bishop, with minor modifications by me.
4146 was contributed by Gary Bishop, with minor modifications by me.
4142 The actual changes affect many files.
4147 The actual changes affect many files.
4143
4148
4144 2003-11-30 Fernando Perez <fperez@colorado.edu>
4149 2003-11-30 Fernando Perez <fperez@colorado.edu>
4145
4150
4146 * IPython/iplib.py (file_matches): new completion code, courtesy
4151 * IPython/iplib.py (file_matches): new completion code, courtesy
4147 of Jeff Collins. This enables filename completion again under
4152 of Jeff Collins. This enables filename completion again under
4148 python 2.3, which disabled it at the C level.
4153 python 2.3, which disabled it at the C level.
4149
4154
4150 2003-11-11 Fernando Perez <fperez@colorado.edu>
4155 2003-11-11 Fernando Perez <fperez@colorado.edu>
4151
4156
4152 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
4157 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
4153 for Numeric.array(map(...)), but often convenient.
4158 for Numeric.array(map(...)), but often convenient.
4154
4159
4155 2003-11-05 Fernando Perez <fperez@colorado.edu>
4160 2003-11-05 Fernando Perez <fperez@colorado.edu>
4156
4161
4157 * IPython/numutils.py (frange): Changed a call from int() to
4162 * IPython/numutils.py (frange): Changed a call from int() to
4158 int(round()) to prevent a problem reported with arange() in the
4163 int(round()) to prevent a problem reported with arange() in the
4159 numpy list.
4164 numpy list.
4160
4165
4161 2003-10-06 Fernando Perez <fperez@colorado.edu>
4166 2003-10-06 Fernando Perez <fperez@colorado.edu>
4162
4167
4163 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
4168 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
4164 prevent crashes if sys lacks an argv attribute (it happens with
4169 prevent crashes if sys lacks an argv attribute (it happens with
4165 embedded interpreters which build a bare-bones sys module).
4170 embedded interpreters which build a bare-bones sys module).
4166 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
4171 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
4167
4172
4168 2003-09-24 Fernando Perez <fperez@colorado.edu>
4173 2003-09-24 Fernando Perez <fperez@colorado.edu>
4169
4174
4170 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
4175 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
4171 to protect against poorly written user objects where __getattr__
4176 to protect against poorly written user objects where __getattr__
4172 raises exceptions other than AttributeError. Thanks to a bug
4177 raises exceptions other than AttributeError. Thanks to a bug
4173 report by Oliver Sander <osander-AT-gmx.de>.
4178 report by Oliver Sander <osander-AT-gmx.de>.
4174
4179
4175 * IPython/FakeModule.py (FakeModule.__repr__): this method was
4180 * IPython/FakeModule.py (FakeModule.__repr__): this method was
4176 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
4181 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
4177
4182
4178 2003-09-09 Fernando Perez <fperez@colorado.edu>
4183 2003-09-09 Fernando Perez <fperez@colorado.edu>
4179
4184
4180 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
4185 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
4181 unpacking a list whith a callable as first element would
4186 unpacking a list whith a callable as first element would
4182 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
4187 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
4183 Collins.
4188 Collins.
4184
4189
4185 2003-08-25 *** Released version 0.5.0
4190 2003-08-25 *** Released version 0.5.0
4186
4191
4187 2003-08-22 Fernando Perez <fperez@colorado.edu>
4192 2003-08-22 Fernando Perez <fperez@colorado.edu>
4188
4193
4189 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
4194 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
4190 improperly defined user exceptions. Thanks to feedback from Mark
4195 improperly defined user exceptions. Thanks to feedback from Mark
4191 Russell <mrussell-AT-verio.net>.
4196 Russell <mrussell-AT-verio.net>.
4192
4197
4193 2003-08-20 Fernando Perez <fperez@colorado.edu>
4198 2003-08-20 Fernando Perez <fperez@colorado.edu>
4194
4199
4195 * IPython/OInspect.py (Inspector.pinfo): changed String Form
4200 * IPython/OInspect.py (Inspector.pinfo): changed String Form
4196 printing so that it would print multi-line string forms starting
4201 printing so that it would print multi-line string forms starting
4197 with a new line. This way the formatting is better respected for
4202 with a new line. This way the formatting is better respected for
4198 objects which work hard to make nice string forms.
4203 objects which work hard to make nice string forms.
4199
4204
4200 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
4205 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
4201 autocall would overtake data access for objects with both
4206 autocall would overtake data access for objects with both
4202 __getitem__ and __call__.
4207 __getitem__ and __call__.
4203
4208
4204 2003-08-19 *** Released version 0.5.0-rc1
4209 2003-08-19 *** Released version 0.5.0-rc1
4205
4210
4206 2003-08-19 Fernando Perez <fperez@colorado.edu>
4211 2003-08-19 Fernando Perez <fperez@colorado.edu>
4207
4212
4208 * IPython/deep_reload.py (load_tail): single tiny change here
4213 * IPython/deep_reload.py (load_tail): single tiny change here
4209 seems to fix the long-standing bug of dreload() failing to work
4214 seems to fix the long-standing bug of dreload() failing to work
4210 for dotted names. But this module is pretty tricky, so I may have
4215 for dotted names. But this module is pretty tricky, so I may have
4211 missed some subtlety. Needs more testing!.
4216 missed some subtlety. Needs more testing!.
4212
4217
4213 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
4218 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
4214 exceptions which have badly implemented __str__ methods.
4219 exceptions which have badly implemented __str__ methods.
4215 (VerboseTB.text): harden against inspect.getinnerframes crashing,
4220 (VerboseTB.text): harden against inspect.getinnerframes crashing,
4216 which I've been getting reports about from Python 2.3 users. I
4221 which I've been getting reports about from Python 2.3 users. I
4217 wish I had a simple test case to reproduce the problem, so I could
4222 wish I had a simple test case to reproduce the problem, so I could
4218 either write a cleaner workaround or file a bug report if
4223 either write a cleaner workaround or file a bug report if
4219 necessary.
4224 necessary.
4220
4225
4221 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
4226 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
4222 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
4227 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
4223 a bug report by Tjabo Kloppenburg.
4228 a bug report by Tjabo Kloppenburg.
4224
4229
4225 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
4230 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
4226 crashes. Wrapped the pdb call in a blanket try/except, since pdb
4231 crashes. Wrapped the pdb call in a blanket try/except, since pdb
4227 seems rather unstable. Thanks to a bug report by Tjabo
4232 seems rather unstable. Thanks to a bug report by Tjabo
4228 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
4233 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
4229
4234
4230 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
4235 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
4231 this out soon because of the critical fixes in the inner loop for
4236 this out soon because of the critical fixes in the inner loop for
4232 generators.
4237 generators.
4233
4238
4234 * IPython/Magic.py (Magic.getargspec): removed. This (and
4239 * IPython/Magic.py (Magic.getargspec): removed. This (and
4235 _get_def) have been obsoleted by OInspect for a long time, I
4240 _get_def) have been obsoleted by OInspect for a long time, I
4236 hadn't noticed that they were dead code.
4241 hadn't noticed that they were dead code.
4237 (Magic._ofind): restored _ofind functionality for a few literals
4242 (Magic._ofind): restored _ofind functionality for a few literals
4238 (those in ["''",'""','[]','{}','()']). But it won't work anymore
4243 (those in ["''",'""','[]','{}','()']). But it won't work anymore
4239 for things like "hello".capitalize?, since that would require a
4244 for things like "hello".capitalize?, since that would require a
4240 potentially dangerous eval() again.
4245 potentially dangerous eval() again.
4241
4246
4242 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
4247 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
4243 logic a bit more to clean up the escapes handling and minimize the
4248 logic a bit more to clean up the escapes handling and minimize the
4244 use of _ofind to only necessary cases. The interactive 'feel' of
4249 use of _ofind to only necessary cases. The interactive 'feel' of
4245 IPython should have improved quite a bit with the changes in
4250 IPython should have improved quite a bit with the changes in
4246 _prefilter and _ofind (besides being far safer than before).
4251 _prefilter and _ofind (besides being far safer than before).
4247
4252
4248 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
4253 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
4249 obscure, never reported). Edit would fail to find the object to
4254 obscure, never reported). Edit would fail to find the object to
4250 edit under some circumstances.
4255 edit under some circumstances.
4251 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
4256 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
4252 which were causing double-calling of generators. Those eval calls
4257 which were causing double-calling of generators. Those eval calls
4253 were _very_ dangerous, since code with side effects could be
4258 were _very_ dangerous, since code with side effects could be
4254 triggered. As they say, 'eval is evil'... These were the
4259 triggered. As they say, 'eval is evil'... These were the
4255 nastiest evals in IPython. Besides, _ofind is now far simpler,
4260 nastiest evals in IPython. Besides, _ofind is now far simpler,
4256 and it should also be quite a bit faster. Its use of inspect is
4261 and it should also be quite a bit faster. Its use of inspect is
4257 also safer, so perhaps some of the inspect-related crashes I've
4262 also safer, so perhaps some of the inspect-related crashes I've
4258 seen lately with Python 2.3 might be taken care of. That will
4263 seen lately with Python 2.3 might be taken care of. That will
4259 need more testing.
4264 need more testing.
4260
4265
4261 2003-08-17 Fernando Perez <fperez@colorado.edu>
4266 2003-08-17 Fernando Perez <fperez@colorado.edu>
4262
4267
4263 * IPython/iplib.py (InteractiveShell._prefilter): significant
4268 * IPython/iplib.py (InteractiveShell._prefilter): significant
4264 simplifications to the logic for handling user escapes. Faster
4269 simplifications to the logic for handling user escapes. Faster
4265 and simpler code.
4270 and simpler code.
4266
4271
4267 2003-08-14 Fernando Perez <fperez@colorado.edu>
4272 2003-08-14 Fernando Perez <fperez@colorado.edu>
4268
4273
4269 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
4274 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
4270 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
4275 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
4271 but it should be quite a bit faster. And the recursive version
4276 but it should be quite a bit faster. And the recursive version
4272 generated O(log N) intermediate storage for all rank>1 arrays,
4277 generated O(log N) intermediate storage for all rank>1 arrays,
4273 even if they were contiguous.
4278 even if they were contiguous.
4274 (l1norm): Added this function.
4279 (l1norm): Added this function.
4275 (norm): Added this function for arbitrary norms (including
4280 (norm): Added this function for arbitrary norms (including
4276 l-infinity). l1 and l2 are still special cases for convenience
4281 l-infinity). l1 and l2 are still special cases for convenience
4277 and speed.
4282 and speed.
4278
4283
4279 2003-08-03 Fernando Perez <fperez@colorado.edu>
4284 2003-08-03 Fernando Perez <fperez@colorado.edu>
4280
4285
4281 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
4286 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
4282 exceptions, which now raise PendingDeprecationWarnings in Python
4287 exceptions, which now raise PendingDeprecationWarnings in Python
4283 2.3. There were some in Magic and some in Gnuplot2.
4288 2.3. There were some in Magic and some in Gnuplot2.
4284
4289
4285 2003-06-30 Fernando Perez <fperez@colorado.edu>
4290 2003-06-30 Fernando Perez <fperez@colorado.edu>
4286
4291
4287 * IPython/genutils.py (page): modified to call curses only for
4292 * IPython/genutils.py (page): modified to call curses only for
4288 terminals where TERM=='xterm'. After problems under many other
4293 terminals where TERM=='xterm'. After problems under many other
4289 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
4294 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
4290
4295
4291 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
4296 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
4292 would be triggered when readline was absent. This was just an old
4297 would be triggered when readline was absent. This was just an old
4293 debugging statement I'd forgotten to take out.
4298 debugging statement I'd forgotten to take out.
4294
4299
4295 2003-06-20 Fernando Perez <fperez@colorado.edu>
4300 2003-06-20 Fernando Perez <fperez@colorado.edu>
4296
4301
4297 * IPython/genutils.py (clock): modified to return only user time
4302 * IPython/genutils.py (clock): modified to return only user time
4298 (not counting system time), after a discussion on scipy. While
4303 (not counting system time), after a discussion on scipy. While
4299 system time may be a useful quantity occasionally, it may much
4304 system time may be a useful quantity occasionally, it may much
4300 more easily be skewed by occasional swapping or other similar
4305 more easily be skewed by occasional swapping or other similar
4301 activity.
4306 activity.
4302
4307
4303 2003-06-05 Fernando Perez <fperez@colorado.edu>
4308 2003-06-05 Fernando Perez <fperez@colorado.edu>
4304
4309
4305 * IPython/numutils.py (identity): new function, for building
4310 * IPython/numutils.py (identity): new function, for building
4306 arbitrary rank Kronecker deltas (mostly backwards compatible with
4311 arbitrary rank Kronecker deltas (mostly backwards compatible with
4307 Numeric.identity)
4312 Numeric.identity)
4308
4313
4309 2003-06-03 Fernando Perez <fperez@colorado.edu>
4314 2003-06-03 Fernando Perez <fperez@colorado.edu>
4310
4315
4311 * IPython/iplib.py (InteractiveShell.handle_magic): protect
4316 * IPython/iplib.py (InteractiveShell.handle_magic): protect
4312 arguments passed to magics with spaces, to allow trailing '\' to
4317 arguments passed to magics with spaces, to allow trailing '\' to
4313 work normally (mainly for Windows users).
4318 work normally (mainly for Windows users).
4314
4319
4315 2003-05-29 Fernando Perez <fperez@colorado.edu>
4320 2003-05-29 Fernando Perez <fperez@colorado.edu>
4316
4321
4317 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
4322 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
4318 instead of pydoc.help. This fixes a bizarre behavior where
4323 instead of pydoc.help. This fixes a bizarre behavior where
4319 printing '%s' % locals() would trigger the help system. Now
4324 printing '%s' % locals() would trigger the help system. Now
4320 ipython behaves like normal python does.
4325 ipython behaves like normal python does.
4321
4326
4322 Note that if one does 'from pydoc import help', the bizarre
4327 Note that if one does 'from pydoc import help', the bizarre
4323 behavior returns, but this will also happen in normal python, so
4328 behavior returns, but this will also happen in normal python, so
4324 it's not an ipython bug anymore (it has to do with how pydoc.help
4329 it's not an ipython bug anymore (it has to do with how pydoc.help
4325 is implemented).
4330 is implemented).
4326
4331
4327 2003-05-22 Fernando Perez <fperez@colorado.edu>
4332 2003-05-22 Fernando Perez <fperez@colorado.edu>
4328
4333
4329 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
4334 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
4330 return [] instead of None when nothing matches, also match to end
4335 return [] instead of None when nothing matches, also match to end
4331 of line. Patch by Gary Bishop.
4336 of line. Patch by Gary Bishop.
4332
4337
4333 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
4338 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
4334 protection as before, for files passed on the command line. This
4339 protection as before, for files passed on the command line. This
4335 prevents the CrashHandler from kicking in if user files call into
4340 prevents the CrashHandler from kicking in if user files call into
4336 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
4341 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
4337 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
4342 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
4338
4343
4339 2003-05-20 *** Released version 0.4.0
4344 2003-05-20 *** Released version 0.4.0
4340
4345
4341 2003-05-20 Fernando Perez <fperez@colorado.edu>
4346 2003-05-20 Fernando Perez <fperez@colorado.edu>
4342
4347
4343 * setup.py: added support for manpages. It's a bit hackish b/c of
4348 * setup.py: added support for manpages. It's a bit hackish b/c of
4344 a bug in the way the bdist_rpm distutils target handles gzipped
4349 a bug in the way the bdist_rpm distutils target handles gzipped
4345 manpages, but it works. After a patch by Jack.
4350 manpages, but it works. After a patch by Jack.
4346
4351
4347 2003-05-19 Fernando Perez <fperez@colorado.edu>
4352 2003-05-19 Fernando Perez <fperez@colorado.edu>
4348
4353
4349 * IPython/numutils.py: added a mockup of the kinds module, since
4354 * IPython/numutils.py: added a mockup of the kinds module, since
4350 it was recently removed from Numeric. This way, numutils will
4355 it was recently removed from Numeric. This way, numutils will
4351 work for all users even if they are missing kinds.
4356 work for all users even if they are missing kinds.
4352
4357
4353 * IPython/Magic.py (Magic._ofind): Harden against an inspect
4358 * IPython/Magic.py (Magic._ofind): Harden against an inspect
4354 failure, which can occur with SWIG-wrapped extensions. After a
4359 failure, which can occur with SWIG-wrapped extensions. After a
4355 crash report from Prabhu.
4360 crash report from Prabhu.
4356
4361
4357 2003-05-16 Fernando Perez <fperez@colorado.edu>
4362 2003-05-16 Fernando Perez <fperez@colorado.edu>
4358
4363
4359 * IPython/iplib.py (InteractiveShell.excepthook): New method to
4364 * IPython/iplib.py (InteractiveShell.excepthook): New method to
4360 protect ipython from user code which may call directly
4365 protect ipython from user code which may call directly
4361 sys.excepthook (this looks like an ipython crash to the user, even
4366 sys.excepthook (this looks like an ipython crash to the user, even
4362 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4367 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4363 This is especially important to help users of WxWindows, but may
4368 This is especially important to help users of WxWindows, but may
4364 also be useful in other cases.
4369 also be useful in other cases.
4365
4370
4366 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
4371 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
4367 an optional tb_offset to be specified, and to preserve exception
4372 an optional tb_offset to be specified, and to preserve exception
4368 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4373 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4369
4374
4370 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
4375 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
4371
4376
4372 2003-05-15 Fernando Perez <fperez@colorado.edu>
4377 2003-05-15 Fernando Perez <fperez@colorado.edu>
4373
4378
4374 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
4379 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
4375 installing for a new user under Windows.
4380 installing for a new user under Windows.
4376
4381
4377 2003-05-12 Fernando Perez <fperez@colorado.edu>
4382 2003-05-12 Fernando Perez <fperez@colorado.edu>
4378
4383
4379 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
4384 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
4380 handler for Emacs comint-based lines. Currently it doesn't do
4385 handler for Emacs comint-based lines. Currently it doesn't do
4381 much (but importantly, it doesn't update the history cache). In
4386 much (but importantly, it doesn't update the history cache). In
4382 the future it may be expanded if Alex needs more functionality
4387 the future it may be expanded if Alex needs more functionality
4383 there.
4388 there.
4384
4389
4385 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
4390 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
4386 info to crash reports.
4391 info to crash reports.
4387
4392
4388 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
4393 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
4389 just like Python's -c. Also fixed crash with invalid -color
4394 just like Python's -c. Also fixed crash with invalid -color
4390 option value at startup. Thanks to Will French
4395 option value at startup. Thanks to Will French
4391 <wfrench-AT-bestweb.net> for the bug report.
4396 <wfrench-AT-bestweb.net> for the bug report.
4392
4397
4393 2003-05-09 Fernando Perez <fperez@colorado.edu>
4398 2003-05-09 Fernando Perez <fperez@colorado.edu>
4394
4399
4395 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
4400 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
4396 to EvalDict (it's a mapping, after all) and simplified its code
4401 to EvalDict (it's a mapping, after all) and simplified its code
4397 quite a bit, after a nice discussion on c.l.py where Gustavo
4402 quite a bit, after a nice discussion on c.l.py where Gustavo
4398 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
4403 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
4399
4404
4400 2003-04-30 Fernando Perez <fperez@colorado.edu>
4405 2003-04-30 Fernando Perez <fperez@colorado.edu>
4401
4406
4402 * IPython/genutils.py (timings_out): modified it to reduce its
4407 * IPython/genutils.py (timings_out): modified it to reduce its
4403 overhead in the common reps==1 case.
4408 overhead in the common reps==1 case.
4404
4409
4405 2003-04-29 Fernando Perez <fperez@colorado.edu>
4410 2003-04-29 Fernando Perez <fperez@colorado.edu>
4406
4411
4407 * IPython/genutils.py (timings_out): Modified to use the resource
4412 * IPython/genutils.py (timings_out): Modified to use the resource
4408 module, which avoids the wraparound problems of time.clock().
4413 module, which avoids the wraparound problems of time.clock().
4409
4414
4410 2003-04-17 *** Released version 0.2.15pre4
4415 2003-04-17 *** Released version 0.2.15pre4
4411
4416
4412 2003-04-17 Fernando Perez <fperez@colorado.edu>
4417 2003-04-17 Fernando Perez <fperez@colorado.edu>
4413
4418
4414 * setup.py (scriptfiles): Split windows-specific stuff over to a
4419 * setup.py (scriptfiles): Split windows-specific stuff over to a
4415 separate file, in an attempt to have a Windows GUI installer.
4420 separate file, in an attempt to have a Windows GUI installer.
4416 That didn't work, but part of the groundwork is done.
4421 That didn't work, but part of the groundwork is done.
4417
4422
4418 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
4423 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
4419 indent/unindent with 4 spaces. Particularly useful in combination
4424 indent/unindent with 4 spaces. Particularly useful in combination
4420 with the new auto-indent option.
4425 with the new auto-indent option.
4421
4426
4422 2003-04-16 Fernando Perez <fperez@colorado.edu>
4427 2003-04-16 Fernando Perez <fperez@colorado.edu>
4423
4428
4424 * IPython/Magic.py: various replacements of self.rc for
4429 * IPython/Magic.py: various replacements of self.rc for
4425 self.shell.rc. A lot more remains to be done to fully disentangle
4430 self.shell.rc. A lot more remains to be done to fully disentangle
4426 this class from the main Shell class.
4431 this class from the main Shell class.
4427
4432
4428 * IPython/GnuplotRuntime.py: added checks for mouse support so
4433 * IPython/GnuplotRuntime.py: added checks for mouse support so
4429 that we don't try to enable it if the current gnuplot doesn't
4434 that we don't try to enable it if the current gnuplot doesn't
4430 really support it. Also added checks so that we don't try to
4435 really support it. Also added checks so that we don't try to
4431 enable persist under Windows (where Gnuplot doesn't recognize the
4436 enable persist under Windows (where Gnuplot doesn't recognize the
4432 option).
4437 option).
4433
4438
4434 * IPython/iplib.py (InteractiveShell.interact): Added optional
4439 * IPython/iplib.py (InteractiveShell.interact): Added optional
4435 auto-indenting code, after a patch by King C. Shu
4440 auto-indenting code, after a patch by King C. Shu
4436 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
4441 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
4437 get along well with pasting indented code. If I ever figure out
4442 get along well with pasting indented code. If I ever figure out
4438 how to make that part go well, it will become on by default.
4443 how to make that part go well, it will become on by default.
4439
4444
4440 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
4445 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
4441 crash ipython if there was an unmatched '%' in the user's prompt
4446 crash ipython if there was an unmatched '%' in the user's prompt
4442 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4447 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4443
4448
4444 * IPython/iplib.py (InteractiveShell.interact): removed the
4449 * IPython/iplib.py (InteractiveShell.interact): removed the
4445 ability to ask the user whether he wants to crash or not at the
4450 ability to ask the user whether he wants to crash or not at the
4446 'last line' exception handler. Calling functions at that point
4451 'last line' exception handler. Calling functions at that point
4447 changes the stack, and the error reports would have incorrect
4452 changes the stack, and the error reports would have incorrect
4448 tracebacks.
4453 tracebacks.
4449
4454
4450 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
4455 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
4451 pass through a peger a pretty-printed form of any object. After a
4456 pass through a peger a pretty-printed form of any object. After a
4452 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
4457 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
4453
4458
4454 2003-04-14 Fernando Perez <fperez@colorado.edu>
4459 2003-04-14 Fernando Perez <fperez@colorado.edu>
4455
4460
4456 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
4461 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
4457 all files in ~ would be modified at first install (instead of
4462 all files in ~ would be modified at first install (instead of
4458 ~/.ipython). This could be potentially disastrous, as the
4463 ~/.ipython). This could be potentially disastrous, as the
4459 modification (make line-endings native) could damage binary files.
4464 modification (make line-endings native) could damage binary files.
4460
4465
4461 2003-04-10 Fernando Perez <fperez@colorado.edu>
4466 2003-04-10 Fernando Perez <fperez@colorado.edu>
4462
4467
4463 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
4468 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
4464 handle only lines which are invalid python. This now means that
4469 handle only lines which are invalid python. This now means that
4465 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
4470 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
4466 for the bug report.
4471 for the bug report.
4467
4472
4468 2003-04-01 Fernando Perez <fperez@colorado.edu>
4473 2003-04-01 Fernando Perez <fperez@colorado.edu>
4469
4474
4470 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
4475 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
4471 where failing to set sys.last_traceback would crash pdb.pm().
4476 where failing to set sys.last_traceback would crash pdb.pm().
4472 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
4477 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
4473 report.
4478 report.
4474
4479
4475 2003-03-25 Fernando Perez <fperez@colorado.edu>
4480 2003-03-25 Fernando Perez <fperez@colorado.edu>
4476
4481
4477 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
4482 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
4478 before printing it (it had a lot of spurious blank lines at the
4483 before printing it (it had a lot of spurious blank lines at the
4479 end).
4484 end).
4480
4485
4481 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
4486 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
4482 output would be sent 21 times! Obviously people don't use this
4487 output would be sent 21 times! Obviously people don't use this
4483 too often, or I would have heard about it.
4488 too often, or I would have heard about it.
4484
4489
4485 2003-03-24 Fernando Perez <fperez@colorado.edu>
4490 2003-03-24 Fernando Perez <fperez@colorado.edu>
4486
4491
4487 * setup.py (scriptfiles): renamed the data_files parameter from
4492 * setup.py (scriptfiles): renamed the data_files parameter from
4488 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
4493 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
4489 for the patch.
4494 for the patch.
4490
4495
4491 2003-03-20 Fernando Perez <fperez@colorado.edu>
4496 2003-03-20 Fernando Perez <fperez@colorado.edu>
4492
4497
4493 * IPython/genutils.py (error): added error() and fatal()
4498 * IPython/genutils.py (error): added error() and fatal()
4494 functions.
4499 functions.
4495
4500
4496 2003-03-18 *** Released version 0.2.15pre3
4501 2003-03-18 *** Released version 0.2.15pre3
4497
4502
4498 2003-03-18 Fernando Perez <fperez@colorado.edu>
4503 2003-03-18 Fernando Perez <fperez@colorado.edu>
4499
4504
4500 * setupext/install_data_ext.py
4505 * setupext/install_data_ext.py
4501 (install_data_ext.initialize_options): Class contributed by Jack
4506 (install_data_ext.initialize_options): Class contributed by Jack
4502 Moffit for fixing the old distutils hack. He is sending this to
4507 Moffit for fixing the old distutils hack. He is sending this to
4503 the distutils folks so in the future we may not need it as a
4508 the distutils folks so in the future we may not need it as a
4504 private fix.
4509 private fix.
4505
4510
4506 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
4511 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
4507 changes for Debian packaging. See his patch for full details.
4512 changes for Debian packaging. See his patch for full details.
4508 The old distutils hack of making the ipythonrc* files carry a
4513 The old distutils hack of making the ipythonrc* files carry a
4509 bogus .py extension is gone, at last. Examples were moved to a
4514 bogus .py extension is gone, at last. Examples were moved to a
4510 separate subdir under doc/, and the separate executable scripts
4515 separate subdir under doc/, and the separate executable scripts
4511 now live in their own directory. Overall a great cleanup. The
4516 now live in their own directory. Overall a great cleanup. The
4512 manual was updated to use the new files, and setup.py has been
4517 manual was updated to use the new files, and setup.py has been
4513 fixed for this setup.
4518 fixed for this setup.
4514
4519
4515 * IPython/PyColorize.py (Parser.usage): made non-executable and
4520 * IPython/PyColorize.py (Parser.usage): made non-executable and
4516 created a pycolor wrapper around it to be included as a script.
4521 created a pycolor wrapper around it to be included as a script.
4517
4522
4518 2003-03-12 *** Released version 0.2.15pre2
4523 2003-03-12 *** Released version 0.2.15pre2
4519
4524
4520 2003-03-12 Fernando Perez <fperez@colorado.edu>
4525 2003-03-12 Fernando Perez <fperez@colorado.edu>
4521
4526
4522 * IPython/ColorANSI.py (make_color_table): Finally fixed the
4527 * IPython/ColorANSI.py (make_color_table): Finally fixed the
4523 long-standing problem with garbage characters in some terminals.
4528 long-standing problem with garbage characters in some terminals.
4524 The issue was really that the \001 and \002 escapes must _only_ be
4529 The issue was really that the \001 and \002 escapes must _only_ be
4525 passed to input prompts (which call readline), but _never_ to
4530 passed to input prompts (which call readline), but _never_ to
4526 normal text to be printed on screen. I changed ColorANSI to have
4531 normal text to be printed on screen. I changed ColorANSI to have
4527 two classes: TermColors and InputTermColors, each with the
4532 two classes: TermColors and InputTermColors, each with the
4528 appropriate escapes for input prompts or normal text. The code in
4533 appropriate escapes for input prompts or normal text. The code in
4529 Prompts.py got slightly more complicated, but this very old and
4534 Prompts.py got slightly more complicated, but this very old and
4530 annoying bug is finally fixed.
4535 annoying bug is finally fixed.
4531
4536
4532 All the credit for nailing down the real origin of this problem
4537 All the credit for nailing down the real origin of this problem
4533 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
4538 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
4534 *Many* thanks to him for spending quite a bit of effort on this.
4539 *Many* thanks to him for spending quite a bit of effort on this.
4535
4540
4536 2003-03-05 *** Released version 0.2.15pre1
4541 2003-03-05 *** Released version 0.2.15pre1
4537
4542
4538 2003-03-03 Fernando Perez <fperez@colorado.edu>
4543 2003-03-03 Fernando Perez <fperez@colorado.edu>
4539
4544
4540 * IPython/FakeModule.py: Moved the former _FakeModule to a
4545 * IPython/FakeModule.py: Moved the former _FakeModule to a
4541 separate file, because it's also needed by Magic (to fix a similar
4546 separate file, because it's also needed by Magic (to fix a similar
4542 pickle-related issue in @run).
4547 pickle-related issue in @run).
4543
4548
4544 2003-03-02 Fernando Perez <fperez@colorado.edu>
4549 2003-03-02 Fernando Perez <fperez@colorado.edu>
4545
4550
4546 * IPython/Magic.py (Magic.magic_autocall): new magic to control
4551 * IPython/Magic.py (Magic.magic_autocall): new magic to control
4547 the autocall option at runtime.
4552 the autocall option at runtime.
4548 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
4553 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
4549 across Magic.py to start separating Magic from InteractiveShell.
4554 across Magic.py to start separating Magic from InteractiveShell.
4550 (Magic._ofind): Fixed to return proper namespace for dotted
4555 (Magic._ofind): Fixed to return proper namespace for dotted
4551 names. Before, a dotted name would always return 'not currently
4556 names. Before, a dotted name would always return 'not currently
4552 defined', because it would find the 'parent'. s.x would be found,
4557 defined', because it would find the 'parent'. s.x would be found,
4553 but since 'x' isn't defined by itself, it would get confused.
4558 but since 'x' isn't defined by itself, it would get confused.
4554 (Magic.magic_run): Fixed pickling problems reported by Ralf
4559 (Magic.magic_run): Fixed pickling problems reported by Ralf
4555 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
4560 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
4556 that I'd used when Mike Heeter reported similar issues at the
4561 that I'd used when Mike Heeter reported similar issues at the
4557 top-level, but now for @run. It boils down to injecting the
4562 top-level, but now for @run. It boils down to injecting the
4558 namespace where code is being executed with something that looks
4563 namespace where code is being executed with something that looks
4559 enough like a module to fool pickle.dump(). Since a pickle stores
4564 enough like a module to fool pickle.dump(). Since a pickle stores
4560 a named reference to the importing module, we need this for
4565 a named reference to the importing module, we need this for
4561 pickles to save something sensible.
4566 pickles to save something sensible.
4562
4567
4563 * IPython/ipmaker.py (make_IPython): added an autocall option.
4568 * IPython/ipmaker.py (make_IPython): added an autocall option.
4564
4569
4565 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
4570 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
4566 the auto-eval code. Now autocalling is an option, and the code is
4571 the auto-eval code. Now autocalling is an option, and the code is
4567 also vastly safer. There is no more eval() involved at all.
4572 also vastly safer. There is no more eval() involved at all.
4568
4573
4569 2003-03-01 Fernando Perez <fperez@colorado.edu>
4574 2003-03-01 Fernando Perez <fperez@colorado.edu>
4570
4575
4571 * IPython/Magic.py (Magic._ofind): Changed interface to return a
4576 * IPython/Magic.py (Magic._ofind): Changed interface to return a
4572 dict with named keys instead of a tuple.
4577 dict with named keys instead of a tuple.
4573
4578
4574 * IPython: Started using CVS for IPython as of 0.2.15pre1.
4579 * IPython: Started using CVS for IPython as of 0.2.15pre1.
4575
4580
4576 * setup.py (make_shortcut): Fixed message about directories
4581 * setup.py (make_shortcut): Fixed message about directories
4577 created during Windows installation (the directories were ok, just
4582 created during Windows installation (the directories were ok, just
4578 the printed message was misleading). Thanks to Chris Liechti
4583 the printed message was misleading). Thanks to Chris Liechti
4579 <cliechti-AT-gmx.net> for the heads up.
4584 <cliechti-AT-gmx.net> for the heads up.
4580
4585
4581 2003-02-21 Fernando Perez <fperez@colorado.edu>
4586 2003-02-21 Fernando Perez <fperez@colorado.edu>
4582
4587
4583 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
4588 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
4584 of ValueError exception when checking for auto-execution. This
4589 of ValueError exception when checking for auto-execution. This
4585 one is raised by things like Numeric arrays arr.flat when the
4590 one is raised by things like Numeric arrays arr.flat when the
4586 array is non-contiguous.
4591 array is non-contiguous.
4587
4592
4588 2003-01-31 Fernando Perez <fperez@colorado.edu>
4593 2003-01-31 Fernando Perez <fperez@colorado.edu>
4589
4594
4590 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
4595 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
4591 not return any value at all (even though the command would get
4596 not return any value at all (even though the command would get
4592 executed).
4597 executed).
4593 (xsys): Flush stdout right after printing the command to ensure
4598 (xsys): Flush stdout right after printing the command to ensure
4594 proper ordering of commands and command output in the total
4599 proper ordering of commands and command output in the total
4595 output.
4600 output.
4596 (SystemExec/xsys/bq): Switched the names of xsys/bq and
4601 (SystemExec/xsys/bq): Switched the names of xsys/bq and
4597 system/getoutput as defaults. The old ones are kept for
4602 system/getoutput as defaults. The old ones are kept for
4598 compatibility reasons, so no code which uses this library needs
4603 compatibility reasons, so no code which uses this library needs
4599 changing.
4604 changing.
4600
4605
4601 2003-01-27 *** Released version 0.2.14
4606 2003-01-27 *** Released version 0.2.14
4602
4607
4603 2003-01-25 Fernando Perez <fperez@colorado.edu>
4608 2003-01-25 Fernando Perez <fperez@colorado.edu>
4604
4609
4605 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
4610 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
4606 functions defined in previous edit sessions could not be re-edited
4611 functions defined in previous edit sessions could not be re-edited
4607 (because the temp files were immediately removed). Now temp files
4612 (because the temp files were immediately removed). Now temp files
4608 are removed only at IPython's exit.
4613 are removed only at IPython's exit.
4609 (Magic.magic_run): Improved @run to perform shell-like expansions
4614 (Magic.magic_run): Improved @run to perform shell-like expansions
4610 on its arguments (~users and $VARS). With this, @run becomes more
4615 on its arguments (~users and $VARS). With this, @run becomes more
4611 like a normal command-line.
4616 like a normal command-line.
4612
4617
4613 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
4618 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
4614 bugs related to embedding and cleaned up that code. A fairly
4619 bugs related to embedding and cleaned up that code. A fairly
4615 important one was the impossibility to access the global namespace
4620 important one was the impossibility to access the global namespace
4616 through the embedded IPython (only local variables were visible).
4621 through the embedded IPython (only local variables were visible).
4617
4622
4618 2003-01-14 Fernando Perez <fperez@colorado.edu>
4623 2003-01-14 Fernando Perez <fperez@colorado.edu>
4619
4624
4620 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
4625 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
4621 auto-calling to be a bit more conservative. Now it doesn't get
4626 auto-calling to be a bit more conservative. Now it doesn't get
4622 triggered if any of '!=()<>' are in the rest of the input line, to
4627 triggered if any of '!=()<>' are in the rest of the input line, to
4623 allow comparing callables. Thanks to Alex for the heads up.
4628 allow comparing callables. Thanks to Alex for the heads up.
4624
4629
4625 2003-01-07 Fernando Perez <fperez@colorado.edu>
4630 2003-01-07 Fernando Perez <fperez@colorado.edu>
4626
4631
4627 * IPython/genutils.py (page): fixed estimation of the number of
4632 * IPython/genutils.py (page): fixed estimation of the number of
4628 lines in a string to be paged to simply count newlines. This
4633 lines in a string to be paged to simply count newlines. This
4629 prevents over-guessing due to embedded escape sequences. A better
4634 prevents over-guessing due to embedded escape sequences. A better
4630 long-term solution would involve stripping out the control chars
4635 long-term solution would involve stripping out the control chars
4631 for the count, but it's potentially so expensive I just don't
4636 for the count, but it's potentially so expensive I just don't
4632 think it's worth doing.
4637 think it's worth doing.
4633
4638
4634 2002-12-19 *** Released version 0.2.14pre50
4639 2002-12-19 *** Released version 0.2.14pre50
4635
4640
4636 2002-12-19 Fernando Perez <fperez@colorado.edu>
4641 2002-12-19 Fernando Perez <fperez@colorado.edu>
4637
4642
4638 * tools/release (version): Changed release scripts to inform
4643 * tools/release (version): Changed release scripts to inform
4639 Andrea and build a NEWS file with a list of recent changes.
4644 Andrea and build a NEWS file with a list of recent changes.
4640
4645
4641 * IPython/ColorANSI.py (__all__): changed terminal detection
4646 * IPython/ColorANSI.py (__all__): changed terminal detection
4642 code. Seems to work better for xterms without breaking
4647 code. Seems to work better for xterms without breaking
4643 konsole. Will need more testing to determine if WinXP and Mac OSX
4648 konsole. Will need more testing to determine if WinXP and Mac OSX
4644 also work ok.
4649 also work ok.
4645
4650
4646 2002-12-18 *** Released version 0.2.14pre49
4651 2002-12-18 *** Released version 0.2.14pre49
4647
4652
4648 2002-12-18 Fernando Perez <fperez@colorado.edu>
4653 2002-12-18 Fernando Perez <fperez@colorado.edu>
4649
4654
4650 * Docs: added new info about Mac OSX, from Andrea.
4655 * Docs: added new info about Mac OSX, from Andrea.
4651
4656
4652 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
4657 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
4653 allow direct plotting of python strings whose format is the same
4658 allow direct plotting of python strings whose format is the same
4654 of gnuplot data files.
4659 of gnuplot data files.
4655
4660
4656 2002-12-16 Fernando Perez <fperez@colorado.edu>
4661 2002-12-16 Fernando Perez <fperez@colorado.edu>
4657
4662
4658 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
4663 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
4659 value of exit question to be acknowledged.
4664 value of exit question to be acknowledged.
4660
4665
4661 2002-12-03 Fernando Perez <fperez@colorado.edu>
4666 2002-12-03 Fernando Perez <fperez@colorado.edu>
4662
4667
4663 * IPython/ipmaker.py: removed generators, which had been added
4668 * IPython/ipmaker.py: removed generators, which had been added
4664 by mistake in an earlier debugging run. This was causing trouble
4669 by mistake in an earlier debugging run. This was causing trouble
4665 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
4670 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
4666 for pointing this out.
4671 for pointing this out.
4667
4672
4668 2002-11-17 Fernando Perez <fperez@colorado.edu>
4673 2002-11-17 Fernando Perez <fperez@colorado.edu>
4669
4674
4670 * Manual: updated the Gnuplot section.
4675 * Manual: updated the Gnuplot section.
4671
4676
4672 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
4677 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
4673 a much better split of what goes in Runtime and what goes in
4678 a much better split of what goes in Runtime and what goes in
4674 Interactive.
4679 Interactive.
4675
4680
4676 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
4681 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
4677 being imported from iplib.
4682 being imported from iplib.
4678
4683
4679 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
4684 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
4680 for command-passing. Now the global Gnuplot instance is called
4685 for command-passing. Now the global Gnuplot instance is called
4681 'gp' instead of 'g', which was really a far too fragile and
4686 'gp' instead of 'g', which was really a far too fragile and
4682 common name.
4687 common name.
4683
4688
4684 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
4689 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
4685 bounding boxes generated by Gnuplot for square plots.
4690 bounding boxes generated by Gnuplot for square plots.
4686
4691
4687 * IPython/genutils.py (popkey): new function added. I should
4692 * IPython/genutils.py (popkey): new function added. I should
4688 suggest this on c.l.py as a dict method, it seems useful.
4693 suggest this on c.l.py as a dict method, it seems useful.
4689
4694
4690 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
4695 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
4691 to transparently handle PostScript generation. MUCH better than
4696 to transparently handle PostScript generation. MUCH better than
4692 the previous plot_eps/replot_eps (which I removed now). The code
4697 the previous plot_eps/replot_eps (which I removed now). The code
4693 is also fairly clean and well documented now (including
4698 is also fairly clean and well documented now (including
4694 docstrings).
4699 docstrings).
4695
4700
4696 2002-11-13 Fernando Perez <fperez@colorado.edu>
4701 2002-11-13 Fernando Perez <fperez@colorado.edu>
4697
4702
4698 * IPython/Magic.py (Magic.magic_edit): fixed docstring
4703 * IPython/Magic.py (Magic.magic_edit): fixed docstring
4699 (inconsistent with options).
4704 (inconsistent with options).
4700
4705
4701 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
4706 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
4702 manually disabled, I don't know why. Fixed it.
4707 manually disabled, I don't know why. Fixed it.
4703 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
4708 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
4704 eps output.
4709 eps output.
4705
4710
4706 2002-11-12 Fernando Perez <fperez@colorado.edu>
4711 2002-11-12 Fernando Perez <fperez@colorado.edu>
4707
4712
4708 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
4713 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
4709 don't propagate up to caller. Fixes crash reported by François
4714 don't propagate up to caller. Fixes crash reported by François
4710 Pinard.
4715 Pinard.
4711
4716
4712 2002-11-09 Fernando Perez <fperez@colorado.edu>
4717 2002-11-09 Fernando Perez <fperez@colorado.edu>
4713
4718
4714 * IPython/ipmaker.py (make_IPython): fixed problem with writing
4719 * IPython/ipmaker.py (make_IPython): fixed problem with writing
4715 history file for new users.
4720 history file for new users.
4716 (make_IPython): fixed bug where initial install would leave the
4721 (make_IPython): fixed bug where initial install would leave the
4717 user running in the .ipython dir.
4722 user running in the .ipython dir.
4718 (make_IPython): fixed bug where config dir .ipython would be
4723 (make_IPython): fixed bug where config dir .ipython would be
4719 created regardless of the given -ipythondir option. Thanks to Cory
4724 created regardless of the given -ipythondir option. Thanks to Cory
4720 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
4725 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
4721
4726
4722 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
4727 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
4723 type confirmations. Will need to use it in all of IPython's code
4728 type confirmations. Will need to use it in all of IPython's code
4724 consistently.
4729 consistently.
4725
4730
4726 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
4731 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
4727 context to print 31 lines instead of the default 5. This will make
4732 context to print 31 lines instead of the default 5. This will make
4728 the crash reports extremely detailed in case the problem is in
4733 the crash reports extremely detailed in case the problem is in
4729 libraries I don't have access to.
4734 libraries I don't have access to.
4730
4735
4731 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
4736 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
4732 line of defense' code to still crash, but giving users fair
4737 line of defense' code to still crash, but giving users fair
4733 warning. I don't want internal errors to go unreported: if there's
4738 warning. I don't want internal errors to go unreported: if there's
4734 an internal problem, IPython should crash and generate a full
4739 an internal problem, IPython should crash and generate a full
4735 report.
4740 report.
4736
4741
4737 2002-11-08 Fernando Perez <fperez@colorado.edu>
4742 2002-11-08 Fernando Perez <fperez@colorado.edu>
4738
4743
4739 * IPython/iplib.py (InteractiveShell.interact): added code to trap
4744 * IPython/iplib.py (InteractiveShell.interact): added code to trap
4740 otherwise uncaught exceptions which can appear if people set
4745 otherwise uncaught exceptions which can appear if people set
4741 sys.stdout to something badly broken. Thanks to a crash report
4746 sys.stdout to something badly broken. Thanks to a crash report
4742 from henni-AT-mail.brainbot.com.
4747 from henni-AT-mail.brainbot.com.
4743
4748
4744 2002-11-04 Fernando Perez <fperez@colorado.edu>
4749 2002-11-04 Fernando Perez <fperez@colorado.edu>
4745
4750
4746 * IPython/iplib.py (InteractiveShell.interact): added
4751 * IPython/iplib.py (InteractiveShell.interact): added
4747 __IPYTHON__active to the builtins. It's a flag which goes on when
4752 __IPYTHON__active to the builtins. It's a flag which goes on when
4748 the interaction starts and goes off again when it stops. This
4753 the interaction starts and goes off again when it stops. This
4749 allows embedding code to detect being inside IPython. Before this
4754 allows embedding code to detect being inside IPython. Before this
4750 was done via __IPYTHON__, but that only shows that an IPython
4755 was done via __IPYTHON__, but that only shows that an IPython
4751 instance has been created.
4756 instance has been created.
4752
4757
4753 * IPython/Magic.py (Magic.magic_env): I realized that in a
4758 * IPython/Magic.py (Magic.magic_env): I realized that in a
4754 UserDict, instance.data holds the data as a normal dict. So I
4759 UserDict, instance.data holds the data as a normal dict. So I
4755 modified @env to return os.environ.data instead of rebuilding a
4760 modified @env to return os.environ.data instead of rebuilding a
4756 dict by hand.
4761 dict by hand.
4757
4762
4758 2002-11-02 Fernando Perez <fperez@colorado.edu>
4763 2002-11-02 Fernando Perez <fperez@colorado.edu>
4759
4764
4760 * IPython/genutils.py (warn): changed so that level 1 prints no
4765 * IPython/genutils.py (warn): changed so that level 1 prints no
4761 header. Level 2 is now the default (with 'WARNING' header, as
4766 header. Level 2 is now the default (with 'WARNING' header, as
4762 before). I think I tracked all places where changes were needed in
4767 before). I think I tracked all places where changes were needed in
4763 IPython, but outside code using the old level numbering may have
4768 IPython, but outside code using the old level numbering may have
4764 broken.
4769 broken.
4765
4770
4766 * IPython/iplib.py (InteractiveShell.runcode): added this to
4771 * IPython/iplib.py (InteractiveShell.runcode): added this to
4767 handle the tracebacks in SystemExit traps correctly. The previous
4772 handle the tracebacks in SystemExit traps correctly. The previous
4768 code (through interact) was printing more of the stack than
4773 code (through interact) was printing more of the stack than
4769 necessary, showing IPython internal code to the user.
4774 necessary, showing IPython internal code to the user.
4770
4775
4771 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
4776 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
4772 default. Now that the default at the confirmation prompt is yes,
4777 default. Now that the default at the confirmation prompt is yes,
4773 it's not so intrusive. François' argument that ipython sessions
4778 it's not so intrusive. François' argument that ipython sessions
4774 tend to be complex enough not to lose them from an accidental C-d,
4779 tend to be complex enough not to lose them from an accidental C-d,
4775 is a valid one.
4780 is a valid one.
4776
4781
4777 * IPython/iplib.py (InteractiveShell.interact): added a
4782 * IPython/iplib.py (InteractiveShell.interact): added a
4778 showtraceback() call to the SystemExit trap, and modified the exit
4783 showtraceback() call to the SystemExit trap, and modified the exit
4779 confirmation to have yes as the default.
4784 confirmation to have yes as the default.
4780
4785
4781 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
4786 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
4782 this file. It's been gone from the code for a long time, this was
4787 this file. It's been gone from the code for a long time, this was
4783 simply leftover junk.
4788 simply leftover junk.
4784
4789
4785 2002-11-01 Fernando Perez <fperez@colorado.edu>
4790 2002-11-01 Fernando Perez <fperez@colorado.edu>
4786
4791
4787 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
4792 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
4788 added. If set, IPython now traps EOF and asks for
4793 added. If set, IPython now traps EOF and asks for
4789 confirmation. After a request by François Pinard.
4794 confirmation. After a request by François Pinard.
4790
4795
4791 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
4796 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
4792 of @abort, and with a new (better) mechanism for handling the
4797 of @abort, and with a new (better) mechanism for handling the
4793 exceptions.
4798 exceptions.
4794
4799
4795 2002-10-27 Fernando Perez <fperez@colorado.edu>
4800 2002-10-27 Fernando Perez <fperez@colorado.edu>
4796
4801
4797 * IPython/usage.py (__doc__): updated the --help information and
4802 * IPython/usage.py (__doc__): updated the --help information and
4798 the ipythonrc file to indicate that -log generates
4803 the ipythonrc file to indicate that -log generates
4799 ./ipython.log. Also fixed the corresponding info in @logstart.
4804 ./ipython.log. Also fixed the corresponding info in @logstart.
4800 This and several other fixes in the manuals thanks to reports by
4805 This and several other fixes in the manuals thanks to reports by
4801 François Pinard <pinard-AT-iro.umontreal.ca>.
4806 François Pinard <pinard-AT-iro.umontreal.ca>.
4802
4807
4803 * IPython/Logger.py (Logger.switch_log): Fixed error message to
4808 * IPython/Logger.py (Logger.switch_log): Fixed error message to
4804 refer to @logstart (instead of @log, which doesn't exist).
4809 refer to @logstart (instead of @log, which doesn't exist).
4805
4810
4806 * IPython/iplib.py (InteractiveShell._prefilter): fixed
4811 * IPython/iplib.py (InteractiveShell._prefilter): fixed
4807 AttributeError crash. Thanks to Christopher Armstrong
4812 AttributeError crash. Thanks to Christopher Armstrong
4808 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
4813 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
4809 introduced recently (in 0.2.14pre37) with the fix to the eval
4814 introduced recently (in 0.2.14pre37) with the fix to the eval
4810 problem mentioned below.
4815 problem mentioned below.
4811
4816
4812 2002-10-17 Fernando Perez <fperez@colorado.edu>
4817 2002-10-17 Fernando Perez <fperez@colorado.edu>
4813
4818
4814 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
4819 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
4815 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
4820 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
4816
4821
4817 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
4822 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
4818 this function to fix a problem reported by Alex Schmolck. He saw
4823 this function to fix a problem reported by Alex Schmolck. He saw
4819 it with list comprehensions and generators, which were getting
4824 it with list comprehensions and generators, which were getting
4820 called twice. The real problem was an 'eval' call in testing for
4825 called twice. The real problem was an 'eval' call in testing for
4821 automagic which was evaluating the input line silently.
4826 automagic which was evaluating the input line silently.
4822
4827
4823 This is a potentially very nasty bug, if the input has side
4828 This is a potentially very nasty bug, if the input has side
4824 effects which must not be repeated. The code is much cleaner now,
4829 effects which must not be repeated. The code is much cleaner now,
4825 without any blanket 'except' left and with a regexp test for
4830 without any blanket 'except' left and with a regexp test for
4826 actual function names.
4831 actual function names.
4827
4832
4828 But an eval remains, which I'm not fully comfortable with. I just
4833 But an eval remains, which I'm not fully comfortable with. I just
4829 don't know how to find out if an expression could be a callable in
4834 don't know how to find out if an expression could be a callable in
4830 the user's namespace without doing an eval on the string. However
4835 the user's namespace without doing an eval on the string. However
4831 that string is now much more strictly checked so that no code
4836 that string is now much more strictly checked so that no code
4832 slips by, so the eval should only happen for things that can
4837 slips by, so the eval should only happen for things that can
4833 really be only function/method names.
4838 really be only function/method names.
4834
4839
4835 2002-10-15 Fernando Perez <fperez@colorado.edu>
4840 2002-10-15 Fernando Perez <fperez@colorado.edu>
4836
4841
4837 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
4842 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
4838 OSX information to main manual, removed README_Mac_OSX file from
4843 OSX information to main manual, removed README_Mac_OSX file from
4839 distribution. Also updated credits for recent additions.
4844 distribution. Also updated credits for recent additions.
4840
4845
4841 2002-10-10 Fernando Perez <fperez@colorado.edu>
4846 2002-10-10 Fernando Perez <fperez@colorado.edu>
4842
4847
4843 * README_Mac_OSX: Added a README for Mac OSX users for fixing
4848 * README_Mac_OSX: Added a README for Mac OSX users for fixing
4844 terminal-related issues. Many thanks to Andrea Riciputi
4849 terminal-related issues. Many thanks to Andrea Riciputi
4845 <andrea.riciputi-AT-libero.it> for writing it.
4850 <andrea.riciputi-AT-libero.it> for writing it.
4846
4851
4847 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
4852 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
4848 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4853 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4849
4854
4850 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
4855 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
4851 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
4856 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
4852 <syver-en-AT-online.no> who both submitted patches for this problem.
4857 <syver-en-AT-online.no> who both submitted patches for this problem.
4853
4858
4854 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
4859 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
4855 global embedding to make sure that things don't overwrite user
4860 global embedding to make sure that things don't overwrite user
4856 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
4861 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
4857
4862
4858 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
4863 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
4859 compatibility. Thanks to Hayden Callow
4864 compatibility. Thanks to Hayden Callow
4860 <h.callow-AT-elec.canterbury.ac.nz>
4865 <h.callow-AT-elec.canterbury.ac.nz>
4861
4866
4862 2002-10-04 Fernando Perez <fperez@colorado.edu>
4867 2002-10-04 Fernando Perez <fperez@colorado.edu>
4863
4868
4864 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
4869 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
4865 Gnuplot.File objects.
4870 Gnuplot.File objects.
4866
4871
4867 2002-07-23 Fernando Perez <fperez@colorado.edu>
4872 2002-07-23 Fernando Perez <fperez@colorado.edu>
4868
4873
4869 * IPython/genutils.py (timing): Added timings() and timing() for
4874 * IPython/genutils.py (timing): Added timings() and timing() for
4870 quick access to the most commonly needed data, the execution
4875 quick access to the most commonly needed data, the execution
4871 times. Old timing() renamed to timings_out().
4876 times. Old timing() renamed to timings_out().
4872
4877
4873 2002-07-18 Fernando Perez <fperez@colorado.edu>
4878 2002-07-18 Fernando Perez <fperez@colorado.edu>
4874
4879
4875 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
4880 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
4876 bug with nested instances disrupting the parent's tab completion.
4881 bug with nested instances disrupting the parent's tab completion.
4877
4882
4878 * IPython/iplib.py (all_completions): Added Alex Schmolck's
4883 * IPython/iplib.py (all_completions): Added Alex Schmolck's
4879 all_completions code to begin the emacs integration.
4884 all_completions code to begin the emacs integration.
4880
4885
4881 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
4886 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
4882 argument to allow titling individual arrays when plotting.
4887 argument to allow titling individual arrays when plotting.
4883
4888
4884 2002-07-15 Fernando Perez <fperez@colorado.edu>
4889 2002-07-15 Fernando Perez <fperez@colorado.edu>
4885
4890
4886 * setup.py (make_shortcut): changed to retrieve the value of
4891 * setup.py (make_shortcut): changed to retrieve the value of
4887 'Program Files' directory from the registry (this value changes in
4892 'Program Files' directory from the registry (this value changes in
4888 non-english versions of Windows). Thanks to Thomas Fanslau
4893 non-english versions of Windows). Thanks to Thomas Fanslau
4889 <tfanslau-AT-gmx.de> for the report.
4894 <tfanslau-AT-gmx.de> for the report.
4890
4895
4891 2002-07-10 Fernando Perez <fperez@colorado.edu>
4896 2002-07-10 Fernando Perez <fperez@colorado.edu>
4892
4897
4893 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
4898 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
4894 a bug in pdb, which crashes if a line with only whitespace is
4899 a bug in pdb, which crashes if a line with only whitespace is
4895 entered. Bug report submitted to sourceforge.
4900 entered. Bug report submitted to sourceforge.
4896
4901
4897 2002-07-09 Fernando Perez <fperez@colorado.edu>
4902 2002-07-09 Fernando Perez <fperez@colorado.edu>
4898
4903
4899 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
4904 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
4900 reporting exceptions (it's a bug in inspect.py, I just set a
4905 reporting exceptions (it's a bug in inspect.py, I just set a
4901 workaround).
4906 workaround).
4902
4907
4903 2002-07-08 Fernando Perez <fperez@colorado.edu>
4908 2002-07-08 Fernando Perez <fperez@colorado.edu>
4904
4909
4905 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
4910 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
4906 __IPYTHON__ in __builtins__ to show up in user_ns.
4911 __IPYTHON__ in __builtins__ to show up in user_ns.
4907
4912
4908 2002-07-03 Fernando Perez <fperez@colorado.edu>
4913 2002-07-03 Fernando Perez <fperez@colorado.edu>
4909
4914
4910 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
4915 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
4911 name from @gp_set_instance to @gp_set_default.
4916 name from @gp_set_instance to @gp_set_default.
4912
4917
4913 * IPython/ipmaker.py (make_IPython): default editor value set to
4918 * IPython/ipmaker.py (make_IPython): default editor value set to
4914 '0' (a string), to match the rc file. Otherwise will crash when
4919 '0' (a string), to match the rc file. Otherwise will crash when
4915 .strip() is called on it.
4920 .strip() is called on it.
4916
4921
4917
4922
4918 2002-06-28 Fernando Perez <fperez@colorado.edu>
4923 2002-06-28 Fernando Perez <fperez@colorado.edu>
4919
4924
4920 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
4925 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
4921 of files in current directory when a file is executed via
4926 of files in current directory when a file is executed via
4922 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
4927 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
4923
4928
4924 * setup.py (manfiles): fix for rpm builds, submitted by RA
4929 * setup.py (manfiles): fix for rpm builds, submitted by RA
4925 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
4930 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
4926
4931
4927 * IPython/ipmaker.py (make_IPython): fixed lookup of default
4932 * IPython/ipmaker.py (make_IPython): fixed lookup of default
4928 editor when set to '0'. Problem was, '0' evaluates to True (it's a
4933 editor when set to '0'. Problem was, '0' evaluates to True (it's a
4929 string!). A. Schmolck caught this one.
4934 string!). A. Schmolck caught this one.
4930
4935
4931 2002-06-27 Fernando Perez <fperez@colorado.edu>
4936 2002-06-27 Fernando Perez <fperez@colorado.edu>
4932
4937
4933 * IPython/ipmaker.py (make_IPython): fixed bug when running user
4938 * IPython/ipmaker.py (make_IPython): fixed bug when running user
4934 defined files at the cmd line. __name__ wasn't being set to
4939 defined files at the cmd line. __name__ wasn't being set to
4935 __main__.
4940 __main__.
4936
4941
4937 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
4942 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
4938 regular lists and tuples besides Numeric arrays.
4943 regular lists and tuples besides Numeric arrays.
4939
4944
4940 * IPython/Prompts.py (CachedOutput.__call__): Added output
4945 * IPython/Prompts.py (CachedOutput.__call__): Added output
4941 supression for input ending with ';'. Similar to Mathematica and
4946 supression for input ending with ';'. Similar to Mathematica and
4942 Matlab. The _* vars and Out[] list are still updated, just like
4947 Matlab. The _* vars and Out[] list are still updated, just like
4943 Mathematica behaves.
4948 Mathematica behaves.
4944
4949
4945 2002-06-25 Fernando Perez <fperez@colorado.edu>
4950 2002-06-25 Fernando Perez <fperez@colorado.edu>
4946
4951
4947 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
4952 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
4948 .ini extensions for profiels under Windows.
4953 .ini extensions for profiels under Windows.
4949
4954
4950 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
4955 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
4951 string form. Fix contributed by Alexander Schmolck
4956 string form. Fix contributed by Alexander Schmolck
4952 <a.schmolck-AT-gmx.net>
4957 <a.schmolck-AT-gmx.net>
4953
4958
4954 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
4959 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
4955 pre-configured Gnuplot instance.
4960 pre-configured Gnuplot instance.
4956
4961
4957 2002-06-21 Fernando Perez <fperez@colorado.edu>
4962 2002-06-21 Fernando Perez <fperez@colorado.edu>
4958
4963
4959 * IPython/numutils.py (exp_safe): new function, works around the
4964 * IPython/numutils.py (exp_safe): new function, works around the
4960 underflow problems in Numeric.
4965 underflow problems in Numeric.
4961 (log2): New fn. Safe log in base 2: returns exact integer answer
4966 (log2): New fn. Safe log in base 2: returns exact integer answer
4962 for exact integer powers of 2.
4967 for exact integer powers of 2.
4963
4968
4964 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
4969 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
4965 properly.
4970 properly.
4966
4971
4967 2002-06-20 Fernando Perez <fperez@colorado.edu>
4972 2002-06-20 Fernando Perez <fperez@colorado.edu>
4968
4973
4969 * IPython/genutils.py (timing): new function like
4974 * IPython/genutils.py (timing): new function like
4970 Mathematica's. Similar to time_test, but returns more info.
4975 Mathematica's. Similar to time_test, but returns more info.
4971
4976
4972 2002-06-18 Fernando Perez <fperez@colorado.edu>
4977 2002-06-18 Fernando Perez <fperez@colorado.edu>
4973
4978
4974 * IPython/Magic.py (Magic.magic_save): modified @save and @r
4979 * IPython/Magic.py (Magic.magic_save): modified @save and @r
4975 according to Mike Heeter's suggestions.
4980 according to Mike Heeter's suggestions.
4976
4981
4977 2002-06-16 Fernando Perez <fperez@colorado.edu>
4982 2002-06-16 Fernando Perez <fperez@colorado.edu>
4978
4983
4979 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
4984 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
4980 system. GnuplotMagic is gone as a user-directory option. New files
4985 system. GnuplotMagic is gone as a user-directory option. New files
4981 make it easier to use all the gnuplot stuff both from external
4986 make it easier to use all the gnuplot stuff both from external
4982 programs as well as from IPython. Had to rewrite part of
4987 programs as well as from IPython. Had to rewrite part of
4983 hardcopy() b/c of a strange bug: often the ps files simply don't
4988 hardcopy() b/c of a strange bug: often the ps files simply don't
4984 get created, and require a repeat of the command (often several
4989 get created, and require a repeat of the command (often several
4985 times).
4990 times).
4986
4991
4987 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
4992 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
4988 resolve output channel at call time, so that if sys.stderr has
4993 resolve output channel at call time, so that if sys.stderr has
4989 been redirected by user this gets honored.
4994 been redirected by user this gets honored.
4990
4995
4991 2002-06-13 Fernando Perez <fperez@colorado.edu>
4996 2002-06-13 Fernando Perez <fperez@colorado.edu>
4992
4997
4993 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
4998 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
4994 IPShell. Kept a copy with the old names to avoid breaking people's
4999 IPShell. Kept a copy with the old names to avoid breaking people's
4995 embedded code.
5000 embedded code.
4996
5001
4997 * IPython/ipython: simplified it to the bare minimum after
5002 * IPython/ipython: simplified it to the bare minimum after
4998 Holger's suggestions. Added info about how to use it in
5003 Holger's suggestions. Added info about how to use it in
4999 PYTHONSTARTUP.
5004 PYTHONSTARTUP.
5000
5005
5001 * IPython/Shell.py (IPythonShell): changed the options passing
5006 * IPython/Shell.py (IPythonShell): changed the options passing
5002 from a string with funky %s replacements to a straight list. Maybe
5007 from a string with funky %s replacements to a straight list. Maybe
5003 a bit more typing, but it follows sys.argv conventions, so there's
5008 a bit more typing, but it follows sys.argv conventions, so there's
5004 less special-casing to remember.
5009 less special-casing to remember.
5005
5010
5006 2002-06-12 Fernando Perez <fperez@colorado.edu>
5011 2002-06-12 Fernando Perez <fperez@colorado.edu>
5007
5012
5008 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
5013 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
5009 command. Thanks to a suggestion by Mike Heeter.
5014 command. Thanks to a suggestion by Mike Heeter.
5010 (Magic.magic_pfile): added behavior to look at filenames if given
5015 (Magic.magic_pfile): added behavior to look at filenames if given
5011 arg is not a defined object.
5016 arg is not a defined object.
5012 (Magic.magic_save): New @save function to save code snippets. Also
5017 (Magic.magic_save): New @save function to save code snippets. Also
5013 a Mike Heeter idea.
5018 a Mike Heeter idea.
5014
5019
5015 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
5020 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
5016 plot() and replot(). Much more convenient now, especially for
5021 plot() and replot(). Much more convenient now, especially for
5017 interactive use.
5022 interactive use.
5018
5023
5019 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
5024 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
5020 filenames.
5025 filenames.
5021
5026
5022 2002-06-02 Fernando Perez <fperez@colorado.edu>
5027 2002-06-02 Fernando Perez <fperez@colorado.edu>
5023
5028
5024 * IPython/Struct.py (Struct.__init__): modified to admit
5029 * IPython/Struct.py (Struct.__init__): modified to admit
5025 initialization via another struct.
5030 initialization via another struct.
5026
5031
5027 * IPython/genutils.py (SystemExec.__init__): New stateful
5032 * IPython/genutils.py (SystemExec.__init__): New stateful
5028 interface to xsys and bq. Useful for writing system scripts.
5033 interface to xsys and bq. Useful for writing system scripts.
5029
5034
5030 2002-05-30 Fernando Perez <fperez@colorado.edu>
5035 2002-05-30 Fernando Perez <fperez@colorado.edu>
5031
5036
5032 * MANIFEST.in: Changed docfile selection to exclude all the lyx
5037 * MANIFEST.in: Changed docfile selection to exclude all the lyx
5033 documents. This will make the user download smaller (it's getting
5038 documents. This will make the user download smaller (it's getting
5034 too big).
5039 too big).
5035
5040
5036 2002-05-29 Fernando Perez <fperez@colorado.edu>
5041 2002-05-29 Fernando Perez <fperez@colorado.edu>
5037
5042
5038 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
5043 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
5039 fix problems with shelve and pickle. Seems to work, but I don't
5044 fix problems with shelve and pickle. Seems to work, but I don't
5040 know if corner cases break it. Thanks to Mike Heeter
5045 know if corner cases break it. Thanks to Mike Heeter
5041 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
5046 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
5042
5047
5043 2002-05-24 Fernando Perez <fperez@colorado.edu>
5048 2002-05-24 Fernando Perez <fperez@colorado.edu>
5044
5049
5045 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
5050 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
5046 macros having broken.
5051 macros having broken.
5047
5052
5048 2002-05-21 Fernando Perez <fperez@colorado.edu>
5053 2002-05-21 Fernando Perez <fperez@colorado.edu>
5049
5054
5050 * IPython/Magic.py (Magic.magic_logstart): fixed recently
5055 * IPython/Magic.py (Magic.magic_logstart): fixed recently
5051 introduced logging bug: all history before logging started was
5056 introduced logging bug: all history before logging started was
5052 being written one character per line! This came from the redesign
5057 being written one character per line! This came from the redesign
5053 of the input history as a special list which slices to strings,
5058 of the input history as a special list which slices to strings,
5054 not to lists.
5059 not to lists.
5055
5060
5056 2002-05-20 Fernando Perez <fperez@colorado.edu>
5061 2002-05-20 Fernando Perez <fperez@colorado.edu>
5057
5062
5058 * IPython/Prompts.py (CachedOutput.__init__): made the color table
5063 * IPython/Prompts.py (CachedOutput.__init__): made the color table
5059 be an attribute of all classes in this module. The design of these
5064 be an attribute of all classes in this module. The design of these
5060 classes needs some serious overhauling.
5065 classes needs some serious overhauling.
5061
5066
5062 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
5067 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
5063 which was ignoring '_' in option names.
5068 which was ignoring '_' in option names.
5064
5069
5065 * IPython/ultraTB.py (FormattedTB.__init__): Changed
5070 * IPython/ultraTB.py (FormattedTB.__init__): Changed
5066 'Verbose_novars' to 'Context' and made it the new default. It's a
5071 'Verbose_novars' to 'Context' and made it the new default. It's a
5067 bit more readable and also safer than verbose.
5072 bit more readable and also safer than verbose.
5068
5073
5069 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
5074 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
5070 triple-quoted strings.
5075 triple-quoted strings.
5071
5076
5072 * IPython/OInspect.py (__all__): new module exposing the object
5077 * IPython/OInspect.py (__all__): new module exposing the object
5073 introspection facilities. Now the corresponding magics are dummy
5078 introspection facilities. Now the corresponding magics are dummy
5074 wrappers around this. Having this module will make it much easier
5079 wrappers around this. Having this module will make it much easier
5075 to put these functions into our modified pdb.
5080 to put these functions into our modified pdb.
5076 This new object inspector system uses the new colorizing module,
5081 This new object inspector system uses the new colorizing module,
5077 so source code and other things are nicely syntax highlighted.
5082 so source code and other things are nicely syntax highlighted.
5078
5083
5079 2002-05-18 Fernando Perez <fperez@colorado.edu>
5084 2002-05-18 Fernando Perez <fperez@colorado.edu>
5080
5085
5081 * IPython/ColorANSI.py: Split the coloring tools into a separate
5086 * IPython/ColorANSI.py: Split the coloring tools into a separate
5082 module so I can use them in other code easier (they were part of
5087 module so I can use them in other code easier (they were part of
5083 ultraTB).
5088 ultraTB).
5084
5089
5085 2002-05-17 Fernando Perez <fperez@colorado.edu>
5090 2002-05-17 Fernando Perez <fperez@colorado.edu>
5086
5091
5087 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5092 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5088 fixed it to set the global 'g' also to the called instance, as
5093 fixed it to set the global 'g' also to the called instance, as
5089 long as 'g' was still a gnuplot instance (so it doesn't overwrite
5094 long as 'g' was still a gnuplot instance (so it doesn't overwrite
5090 user's 'g' variables).
5095 user's 'g' variables).
5091
5096
5092 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
5097 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
5093 global variables (aliases to _ih,_oh) so that users which expect
5098 global variables (aliases to _ih,_oh) so that users which expect
5094 In[5] or Out[7] to work aren't unpleasantly surprised.
5099 In[5] or Out[7] to work aren't unpleasantly surprised.
5095 (InputList.__getslice__): new class to allow executing slices of
5100 (InputList.__getslice__): new class to allow executing slices of
5096 input history directly. Very simple class, complements the use of
5101 input history directly. Very simple class, complements the use of
5097 macros.
5102 macros.
5098
5103
5099 2002-05-16 Fernando Perez <fperez@colorado.edu>
5104 2002-05-16 Fernando Perez <fperez@colorado.edu>
5100
5105
5101 * setup.py (docdirbase): make doc directory be just doc/IPython
5106 * setup.py (docdirbase): make doc directory be just doc/IPython
5102 without version numbers, it will reduce clutter for users.
5107 without version numbers, it will reduce clutter for users.
5103
5108
5104 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
5109 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
5105 execfile call to prevent possible memory leak. See for details:
5110 execfile call to prevent possible memory leak. See for details:
5106 http://mail.python.org/pipermail/python-list/2002-February/088476.html
5111 http://mail.python.org/pipermail/python-list/2002-February/088476.html
5107
5112
5108 2002-05-15 Fernando Perez <fperez@colorado.edu>
5113 2002-05-15 Fernando Perez <fperez@colorado.edu>
5109
5114
5110 * IPython/Magic.py (Magic.magic_psource): made the object
5115 * IPython/Magic.py (Magic.magic_psource): made the object
5111 introspection names be more standard: pdoc, pdef, pfile and
5116 introspection names be more standard: pdoc, pdef, pfile and
5112 psource. They all print/page their output, and it makes
5117 psource. They all print/page their output, and it makes
5113 remembering them easier. Kept old names for compatibility as
5118 remembering them easier. Kept old names for compatibility as
5114 aliases.
5119 aliases.
5115
5120
5116 2002-05-14 Fernando Perez <fperez@colorado.edu>
5121 2002-05-14 Fernando Perez <fperez@colorado.edu>
5117
5122
5118 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
5123 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
5119 what the mouse problem was. The trick is to use gnuplot with temp
5124 what the mouse problem was. The trick is to use gnuplot with temp
5120 files and NOT with pipes (for data communication), because having
5125 files and NOT with pipes (for data communication), because having
5121 both pipes and the mouse on is bad news.
5126 both pipes and the mouse on is bad news.
5122
5127
5123 2002-05-13 Fernando Perez <fperez@colorado.edu>
5128 2002-05-13 Fernando Perez <fperez@colorado.edu>
5124
5129
5125 * IPython/Magic.py (Magic._ofind): fixed namespace order search
5130 * IPython/Magic.py (Magic._ofind): fixed namespace order search
5126 bug. Information would be reported about builtins even when
5131 bug. Information would be reported about builtins even when
5127 user-defined functions overrode them.
5132 user-defined functions overrode them.
5128
5133
5129 2002-05-11 Fernando Perez <fperez@colorado.edu>
5134 2002-05-11 Fernando Perez <fperez@colorado.edu>
5130
5135
5131 * IPython/__init__.py (__all__): removed FlexCompleter from
5136 * IPython/__init__.py (__all__): removed FlexCompleter from
5132 __all__ so that things don't fail in platforms without readline.
5137 __all__ so that things don't fail in platforms without readline.
5133
5138
5134 2002-05-10 Fernando Perez <fperez@colorado.edu>
5139 2002-05-10 Fernando Perez <fperez@colorado.edu>
5135
5140
5136 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
5141 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
5137 it requires Numeric, effectively making Numeric a dependency for
5142 it requires Numeric, effectively making Numeric a dependency for
5138 IPython.
5143 IPython.
5139
5144
5140 * Released 0.2.13
5145 * Released 0.2.13
5141
5146
5142 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
5147 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
5143 profiler interface. Now all the major options from the profiler
5148 profiler interface. Now all the major options from the profiler
5144 module are directly supported in IPython, both for single
5149 module are directly supported in IPython, both for single
5145 expressions (@prun) and for full programs (@run -p).
5150 expressions (@prun) and for full programs (@run -p).
5146
5151
5147 2002-05-09 Fernando Perez <fperez@colorado.edu>
5152 2002-05-09 Fernando Perez <fperez@colorado.edu>
5148
5153
5149 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
5154 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
5150 magic properly formatted for screen.
5155 magic properly formatted for screen.
5151
5156
5152 * setup.py (make_shortcut): Changed things to put pdf version in
5157 * setup.py (make_shortcut): Changed things to put pdf version in
5153 doc/ instead of doc/manual (had to change lyxport a bit).
5158 doc/ instead of doc/manual (had to change lyxport a bit).
5154
5159
5155 * IPython/Magic.py (Profile.string_stats): made profile runs go
5160 * IPython/Magic.py (Profile.string_stats): made profile runs go
5156 through pager (they are long and a pager allows searching, saving,
5161 through pager (they are long and a pager allows searching, saving,
5157 etc.)
5162 etc.)
5158
5163
5159 2002-05-08 Fernando Perez <fperez@colorado.edu>
5164 2002-05-08 Fernando Perez <fperez@colorado.edu>
5160
5165
5161 * Released 0.2.12
5166 * Released 0.2.12
5162
5167
5163 2002-05-06 Fernando Perez <fperez@colorado.edu>
5168 2002-05-06 Fernando Perez <fperez@colorado.edu>
5164
5169
5165 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
5170 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
5166 introduced); 'hist n1 n2' was broken.
5171 introduced); 'hist n1 n2' was broken.
5167 (Magic.magic_pdb): added optional on/off arguments to @pdb
5172 (Magic.magic_pdb): added optional on/off arguments to @pdb
5168 (Magic.magic_run): added option -i to @run, which executes code in
5173 (Magic.magic_run): added option -i to @run, which executes code in
5169 the IPython namespace instead of a clean one. Also added @irun as
5174 the IPython namespace instead of a clean one. Also added @irun as
5170 an alias to @run -i.
5175 an alias to @run -i.
5171
5176
5172 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5177 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5173 fixed (it didn't really do anything, the namespaces were wrong).
5178 fixed (it didn't really do anything, the namespaces were wrong).
5174
5179
5175 * IPython/Debugger.py (__init__): Added workaround for python 2.1
5180 * IPython/Debugger.py (__init__): Added workaround for python 2.1
5176
5181
5177 * IPython/__init__.py (__all__): Fixed package namespace, now
5182 * IPython/__init__.py (__all__): Fixed package namespace, now
5178 'import IPython' does give access to IPython.<all> as
5183 'import IPython' does give access to IPython.<all> as
5179 expected. Also renamed __release__ to Release.
5184 expected. Also renamed __release__ to Release.
5180
5185
5181 * IPython/Debugger.py (__license__): created new Pdb class which
5186 * IPython/Debugger.py (__license__): created new Pdb class which
5182 functions like a drop-in for the normal pdb.Pdb but does NOT
5187 functions like a drop-in for the normal pdb.Pdb but does NOT
5183 import readline by default. This way it doesn't muck up IPython's
5188 import readline by default. This way it doesn't muck up IPython's
5184 readline handling, and now tab-completion finally works in the
5189 readline handling, and now tab-completion finally works in the
5185 debugger -- sort of. It completes things globally visible, but the
5190 debugger -- sort of. It completes things globally visible, but the
5186 completer doesn't track the stack as pdb walks it. That's a bit
5191 completer doesn't track the stack as pdb walks it. That's a bit
5187 tricky, and I'll have to implement it later.
5192 tricky, and I'll have to implement it later.
5188
5193
5189 2002-05-05 Fernando Perez <fperez@colorado.edu>
5194 2002-05-05 Fernando Perez <fperez@colorado.edu>
5190
5195
5191 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
5196 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
5192 magic docstrings when printed via ? (explicit \'s were being
5197 magic docstrings when printed via ? (explicit \'s were being
5193 printed).
5198 printed).
5194
5199
5195 * IPython/ipmaker.py (make_IPython): fixed namespace
5200 * IPython/ipmaker.py (make_IPython): fixed namespace
5196 identification bug. Now variables loaded via logs or command-line
5201 identification bug. Now variables loaded via logs or command-line
5197 files are recognized in the interactive namespace by @who.
5202 files are recognized in the interactive namespace by @who.
5198
5203
5199 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
5204 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
5200 log replay system stemming from the string form of Structs.
5205 log replay system stemming from the string form of Structs.
5201
5206
5202 * IPython/Magic.py (Macro.__init__): improved macros to properly
5207 * IPython/Magic.py (Macro.__init__): improved macros to properly
5203 handle magic commands in them.
5208 handle magic commands in them.
5204 (Magic.magic_logstart): usernames are now expanded so 'logstart
5209 (Magic.magic_logstart): usernames are now expanded so 'logstart
5205 ~/mylog' now works.
5210 ~/mylog' now works.
5206
5211
5207 * IPython/iplib.py (complete): fixed bug where paths starting with
5212 * IPython/iplib.py (complete): fixed bug where paths starting with
5208 '/' would be completed as magic names.
5213 '/' would be completed as magic names.
5209
5214
5210 2002-05-04 Fernando Perez <fperez@colorado.edu>
5215 2002-05-04 Fernando Perez <fperez@colorado.edu>
5211
5216
5212 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
5217 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
5213 allow running full programs under the profiler's control.
5218 allow running full programs under the profiler's control.
5214
5219
5215 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
5220 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
5216 mode to report exceptions verbosely but without formatting
5221 mode to report exceptions verbosely but without formatting
5217 variables. This addresses the issue of ipython 'freezing' (it's
5222 variables. This addresses the issue of ipython 'freezing' (it's
5218 not frozen, but caught in an expensive formatting loop) when huge
5223 not frozen, but caught in an expensive formatting loop) when huge
5219 variables are in the context of an exception.
5224 variables are in the context of an exception.
5220 (VerboseTB.text): Added '--->' markers at line where exception was
5225 (VerboseTB.text): Added '--->' markers at line where exception was
5221 triggered. Much clearer to read, especially in NoColor modes.
5226 triggered. Much clearer to read, especially in NoColor modes.
5222
5227
5223 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
5228 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
5224 implemented in reverse when changing to the new parse_options().
5229 implemented in reverse when changing to the new parse_options().
5225
5230
5226 2002-05-03 Fernando Perez <fperez@colorado.edu>
5231 2002-05-03 Fernando Perez <fperez@colorado.edu>
5227
5232
5228 * IPython/Magic.py (Magic.parse_options): new function so that
5233 * IPython/Magic.py (Magic.parse_options): new function so that
5229 magics can parse options easier.
5234 magics can parse options easier.
5230 (Magic.magic_prun): new function similar to profile.run(),
5235 (Magic.magic_prun): new function similar to profile.run(),
5231 suggested by Chris Hart.
5236 suggested by Chris Hart.
5232 (Magic.magic_cd): fixed behavior so that it only changes if
5237 (Magic.magic_cd): fixed behavior so that it only changes if
5233 directory actually is in history.
5238 directory actually is in history.
5234
5239
5235 * IPython/usage.py (__doc__): added information about potential
5240 * IPython/usage.py (__doc__): added information about potential
5236 slowness of Verbose exception mode when there are huge data
5241 slowness of Verbose exception mode when there are huge data
5237 structures to be formatted (thanks to Archie Paulson).
5242 structures to be formatted (thanks to Archie Paulson).
5238
5243
5239 * IPython/ipmaker.py (make_IPython): Changed default logging
5244 * IPython/ipmaker.py (make_IPython): Changed default logging
5240 (when simply called with -log) to use curr_dir/ipython.log in
5245 (when simply called with -log) to use curr_dir/ipython.log in
5241 rotate mode. Fixed crash which was occuring with -log before
5246 rotate mode. Fixed crash which was occuring with -log before
5242 (thanks to Jim Boyle).
5247 (thanks to Jim Boyle).
5243
5248
5244 2002-05-01 Fernando Perez <fperez@colorado.edu>
5249 2002-05-01 Fernando Perez <fperez@colorado.edu>
5245
5250
5246 * Released 0.2.11 for these fixes (mainly the ultraTB one which
5251 * Released 0.2.11 for these fixes (mainly the ultraTB one which
5247 was nasty -- though somewhat of a corner case).
5252 was nasty -- though somewhat of a corner case).
5248
5253
5249 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
5254 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
5250 text (was a bug).
5255 text (was a bug).
5251
5256
5252 2002-04-30 Fernando Perez <fperez@colorado.edu>
5257 2002-04-30 Fernando Perez <fperez@colorado.edu>
5253
5258
5254 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
5259 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
5255 a print after ^D or ^C from the user so that the In[] prompt
5260 a print after ^D or ^C from the user so that the In[] prompt
5256 doesn't over-run the gnuplot one.
5261 doesn't over-run the gnuplot one.
5257
5262
5258 2002-04-29 Fernando Perez <fperez@colorado.edu>
5263 2002-04-29 Fernando Perez <fperez@colorado.edu>
5259
5264
5260 * Released 0.2.10
5265 * Released 0.2.10
5261
5266
5262 * IPython/__release__.py (version): get date dynamically.
5267 * IPython/__release__.py (version): get date dynamically.
5263
5268
5264 * Misc. documentation updates thanks to Arnd's comments. Also ran
5269 * Misc. documentation updates thanks to Arnd's comments. Also ran
5265 a full spellcheck on the manual (hadn't been done in a while).
5270 a full spellcheck on the manual (hadn't been done in a while).
5266
5271
5267 2002-04-27 Fernando Perez <fperez@colorado.edu>
5272 2002-04-27 Fernando Perez <fperez@colorado.edu>
5268
5273
5269 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
5274 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
5270 starting a log in mid-session would reset the input history list.
5275 starting a log in mid-session would reset the input history list.
5271
5276
5272 2002-04-26 Fernando Perez <fperez@colorado.edu>
5277 2002-04-26 Fernando Perez <fperez@colorado.edu>
5273
5278
5274 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
5279 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
5275 all files were being included in an update. Now anything in
5280 all files were being included in an update. Now anything in
5276 UserConfig that matches [A-Za-z]*.py will go (this excludes
5281 UserConfig that matches [A-Za-z]*.py will go (this excludes
5277 __init__.py)
5282 __init__.py)
5278
5283
5279 2002-04-25 Fernando Perez <fperez@colorado.edu>
5284 2002-04-25 Fernando Perez <fperez@colorado.edu>
5280
5285
5281 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
5286 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
5282 to __builtins__ so that any form of embedded or imported code can
5287 to __builtins__ so that any form of embedded or imported code can
5283 test for being inside IPython.
5288 test for being inside IPython.
5284
5289
5285 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
5290 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
5286 changed to GnuplotMagic because it's now an importable module,
5291 changed to GnuplotMagic because it's now an importable module,
5287 this makes the name follow that of the standard Gnuplot module.
5292 this makes the name follow that of the standard Gnuplot module.
5288 GnuplotMagic can now be loaded at any time in mid-session.
5293 GnuplotMagic can now be loaded at any time in mid-session.
5289
5294
5290 2002-04-24 Fernando Perez <fperez@colorado.edu>
5295 2002-04-24 Fernando Perez <fperez@colorado.edu>
5291
5296
5292 * IPython/numutils.py: removed SIUnits. It doesn't properly set
5297 * IPython/numutils.py: removed SIUnits. It doesn't properly set
5293 the globals (IPython has its own namespace) and the
5298 the globals (IPython has its own namespace) and the
5294 PhysicalQuantity stuff is much better anyway.
5299 PhysicalQuantity stuff is much better anyway.
5295
5300
5296 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
5301 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
5297 embedding example to standard user directory for
5302 embedding example to standard user directory for
5298 distribution. Also put it in the manual.
5303 distribution. Also put it in the manual.
5299
5304
5300 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
5305 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
5301 instance as first argument (so it doesn't rely on some obscure
5306 instance as first argument (so it doesn't rely on some obscure
5302 hidden global).
5307 hidden global).
5303
5308
5304 * IPython/UserConfig/ipythonrc.py: put () back in accepted
5309 * IPython/UserConfig/ipythonrc.py: put () back in accepted
5305 delimiters. While it prevents ().TAB from working, it allows
5310 delimiters. While it prevents ().TAB from working, it allows
5306 completions in open (... expressions. This is by far a more common
5311 completions in open (... expressions. This is by far a more common
5307 case.
5312 case.
5308
5313
5309 2002-04-23 Fernando Perez <fperez@colorado.edu>
5314 2002-04-23 Fernando Perez <fperez@colorado.edu>
5310
5315
5311 * IPython/Extensions/InterpreterPasteInput.py: new
5316 * IPython/Extensions/InterpreterPasteInput.py: new
5312 syntax-processing module for pasting lines with >>> or ... at the
5317 syntax-processing module for pasting lines with >>> or ... at the
5313 start.
5318 start.
5314
5319
5315 * IPython/Extensions/PhysicalQ_Interactive.py
5320 * IPython/Extensions/PhysicalQ_Interactive.py
5316 (PhysicalQuantityInteractive.__int__): fixed to work with either
5321 (PhysicalQuantityInteractive.__int__): fixed to work with either
5317 Numeric or math.
5322 Numeric or math.
5318
5323
5319 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
5324 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
5320 provided profiles. Now we have:
5325 provided profiles. Now we have:
5321 -math -> math module as * and cmath with its own namespace.
5326 -math -> math module as * and cmath with its own namespace.
5322 -numeric -> Numeric as *, plus gnuplot & grace
5327 -numeric -> Numeric as *, plus gnuplot & grace
5323 -physics -> same as before
5328 -physics -> same as before
5324
5329
5325 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
5330 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
5326 user-defined magics wouldn't be found by @magic if they were
5331 user-defined magics wouldn't be found by @magic if they were
5327 defined as class methods. Also cleaned up the namespace search
5332 defined as class methods. Also cleaned up the namespace search
5328 logic and the string building (to use %s instead of many repeated
5333 logic and the string building (to use %s instead of many repeated
5329 string adds).
5334 string adds).
5330
5335
5331 * IPython/UserConfig/example-magic.py (magic_foo): updated example
5336 * IPython/UserConfig/example-magic.py (magic_foo): updated example
5332 of user-defined magics to operate with class methods (cleaner, in
5337 of user-defined magics to operate with class methods (cleaner, in
5333 line with the gnuplot code).
5338 line with the gnuplot code).
5334
5339
5335 2002-04-22 Fernando Perez <fperez@colorado.edu>
5340 2002-04-22 Fernando Perez <fperez@colorado.edu>
5336
5341
5337 * setup.py: updated dependency list so that manual is updated when
5342 * setup.py: updated dependency list so that manual is updated when
5338 all included files change.
5343 all included files change.
5339
5344
5340 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
5345 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
5341 the delimiter removal option (the fix is ugly right now).
5346 the delimiter removal option (the fix is ugly right now).
5342
5347
5343 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
5348 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
5344 all of the math profile (quicker loading, no conflict between
5349 all of the math profile (quicker loading, no conflict between
5345 g-9.8 and g-gnuplot).
5350 g-9.8 and g-gnuplot).
5346
5351
5347 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
5352 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
5348 name of post-mortem files to IPython_crash_report.txt.
5353 name of post-mortem files to IPython_crash_report.txt.
5349
5354
5350 * Cleanup/update of the docs. Added all the new readline info and
5355 * Cleanup/update of the docs. Added all the new readline info and
5351 formatted all lists as 'real lists'.
5356 formatted all lists as 'real lists'.
5352
5357
5353 * IPython/ipmaker.py (make_IPython): removed now-obsolete
5358 * IPython/ipmaker.py (make_IPython): removed now-obsolete
5354 tab-completion options, since the full readline parse_and_bind is
5359 tab-completion options, since the full readline parse_and_bind is
5355 now accessible.
5360 now accessible.
5356
5361
5357 * IPython/iplib.py (InteractiveShell.init_readline): Changed
5362 * IPython/iplib.py (InteractiveShell.init_readline): Changed
5358 handling of readline options. Now users can specify any string to
5363 handling of readline options. Now users can specify any string to
5359 be passed to parse_and_bind(), as well as the delimiters to be
5364 be passed to parse_and_bind(), as well as the delimiters to be
5360 removed.
5365 removed.
5361 (InteractiveShell.__init__): Added __name__ to the global
5366 (InteractiveShell.__init__): Added __name__ to the global
5362 namespace so that things like Itpl which rely on its existence
5367 namespace so that things like Itpl which rely on its existence
5363 don't crash.
5368 don't crash.
5364 (InteractiveShell._prefilter): Defined the default with a _ so
5369 (InteractiveShell._prefilter): Defined the default with a _ so
5365 that prefilter() is easier to override, while the default one
5370 that prefilter() is easier to override, while the default one
5366 remains available.
5371 remains available.
5367
5372
5368 2002-04-18 Fernando Perez <fperez@colorado.edu>
5373 2002-04-18 Fernando Perez <fperez@colorado.edu>
5369
5374
5370 * Added information about pdb in the docs.
5375 * Added information about pdb in the docs.
5371
5376
5372 2002-04-17 Fernando Perez <fperez@colorado.edu>
5377 2002-04-17 Fernando Perez <fperez@colorado.edu>
5373
5378
5374 * IPython/ipmaker.py (make_IPython): added rc_override option to
5379 * IPython/ipmaker.py (make_IPython): added rc_override option to
5375 allow passing config options at creation time which may override
5380 allow passing config options at creation time which may override
5376 anything set in the config files or command line. This is
5381 anything set in the config files or command line. This is
5377 particularly useful for configuring embedded instances.
5382 particularly useful for configuring embedded instances.
5378
5383
5379 2002-04-15 Fernando Perez <fperez@colorado.edu>
5384 2002-04-15 Fernando Perez <fperez@colorado.edu>
5380
5385
5381 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
5386 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
5382 crash embedded instances because of the input cache falling out of
5387 crash embedded instances because of the input cache falling out of
5383 sync with the output counter.
5388 sync with the output counter.
5384
5389
5385 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
5390 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
5386 mode which calls pdb after an uncaught exception in IPython itself.
5391 mode which calls pdb after an uncaught exception in IPython itself.
5387
5392
5388 2002-04-14 Fernando Perez <fperez@colorado.edu>
5393 2002-04-14 Fernando Perez <fperez@colorado.edu>
5389
5394
5390 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
5395 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
5391 readline, fix it back after each call.
5396 readline, fix it back after each call.
5392
5397
5393 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
5398 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
5394 method to force all access via __call__(), which guarantees that
5399 method to force all access via __call__(), which guarantees that
5395 traceback references are properly deleted.
5400 traceback references are properly deleted.
5396
5401
5397 * IPython/Prompts.py (CachedOutput._display): minor fixes to
5402 * IPython/Prompts.py (CachedOutput._display): minor fixes to
5398 improve printing when pprint is in use.
5403 improve printing when pprint is in use.
5399
5404
5400 2002-04-13 Fernando Perez <fperez@colorado.edu>
5405 2002-04-13 Fernando Perez <fperez@colorado.edu>
5401
5406
5402 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
5407 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
5403 exceptions aren't caught anymore. If the user triggers one, he
5408 exceptions aren't caught anymore. If the user triggers one, he
5404 should know why he's doing it and it should go all the way up,
5409 should know why he's doing it and it should go all the way up,
5405 just like any other exception. So now @abort will fully kill the
5410 just like any other exception. So now @abort will fully kill the
5406 embedded interpreter and the embedding code (unless that happens
5411 embedded interpreter and the embedding code (unless that happens
5407 to catch SystemExit).
5412 to catch SystemExit).
5408
5413
5409 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
5414 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
5410 and a debugger() method to invoke the interactive pdb debugger
5415 and a debugger() method to invoke the interactive pdb debugger
5411 after printing exception information. Also added the corresponding
5416 after printing exception information. Also added the corresponding
5412 -pdb option and @pdb magic to control this feature, and updated
5417 -pdb option and @pdb magic to control this feature, and updated
5413 the docs. After a suggestion from Christopher Hart
5418 the docs. After a suggestion from Christopher Hart
5414 (hart-AT-caltech.edu).
5419 (hart-AT-caltech.edu).
5415
5420
5416 2002-04-12 Fernando Perez <fperez@colorado.edu>
5421 2002-04-12 Fernando Perez <fperez@colorado.edu>
5417
5422
5418 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
5423 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
5419 the exception handlers defined by the user (not the CrashHandler)
5424 the exception handlers defined by the user (not the CrashHandler)
5420 so that user exceptions don't trigger an ipython bug report.
5425 so that user exceptions don't trigger an ipython bug report.
5421
5426
5422 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
5427 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
5423 configurable (it should have always been so).
5428 configurable (it should have always been so).
5424
5429
5425 2002-03-26 Fernando Perez <fperez@colorado.edu>
5430 2002-03-26 Fernando Perez <fperez@colorado.edu>
5426
5431
5427 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
5432 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
5428 and there to fix embedding namespace issues. This should all be
5433 and there to fix embedding namespace issues. This should all be
5429 done in a more elegant way.
5434 done in a more elegant way.
5430
5435
5431 2002-03-25 Fernando Perez <fperez@colorado.edu>
5436 2002-03-25 Fernando Perez <fperez@colorado.edu>
5432
5437
5433 * IPython/genutils.py (get_home_dir): Try to make it work under
5438 * IPython/genutils.py (get_home_dir): Try to make it work under
5434 win9x also.
5439 win9x also.
5435
5440
5436 2002-03-20 Fernando Perez <fperez@colorado.edu>
5441 2002-03-20 Fernando Perez <fperez@colorado.edu>
5437
5442
5438 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
5443 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
5439 sys.displayhook untouched upon __init__.
5444 sys.displayhook untouched upon __init__.
5440
5445
5441 2002-03-19 Fernando Perez <fperez@colorado.edu>
5446 2002-03-19 Fernando Perez <fperez@colorado.edu>
5442
5447
5443 * Released 0.2.9 (for embedding bug, basically).
5448 * Released 0.2.9 (for embedding bug, basically).
5444
5449
5445 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
5450 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
5446 exceptions so that enclosing shell's state can be restored.
5451 exceptions so that enclosing shell's state can be restored.
5447
5452
5448 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
5453 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
5449 naming conventions in the .ipython/ dir.
5454 naming conventions in the .ipython/ dir.
5450
5455
5451 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
5456 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
5452 from delimiters list so filenames with - in them get expanded.
5457 from delimiters list so filenames with - in them get expanded.
5453
5458
5454 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
5459 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
5455 sys.displayhook not being properly restored after an embedded call.
5460 sys.displayhook not being properly restored after an embedded call.
5456
5461
5457 2002-03-18 Fernando Perez <fperez@colorado.edu>
5462 2002-03-18 Fernando Perez <fperez@colorado.edu>
5458
5463
5459 * Released 0.2.8
5464 * Released 0.2.8
5460
5465
5461 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
5466 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
5462 some files weren't being included in a -upgrade.
5467 some files weren't being included in a -upgrade.
5463 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
5468 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
5464 on' so that the first tab completes.
5469 on' so that the first tab completes.
5465 (InteractiveShell.handle_magic): fixed bug with spaces around
5470 (InteractiveShell.handle_magic): fixed bug with spaces around
5466 quotes breaking many magic commands.
5471 quotes breaking many magic commands.
5467
5472
5468 * setup.py: added note about ignoring the syntax error messages at
5473 * setup.py: added note about ignoring the syntax error messages at
5469 installation.
5474 installation.
5470
5475
5471 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
5476 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
5472 streamlining the gnuplot interface, now there's only one magic @gp.
5477 streamlining the gnuplot interface, now there's only one magic @gp.
5473
5478
5474 2002-03-17 Fernando Perez <fperez@colorado.edu>
5479 2002-03-17 Fernando Perez <fperez@colorado.edu>
5475
5480
5476 * IPython/UserConfig/magic_gnuplot.py: new name for the
5481 * IPython/UserConfig/magic_gnuplot.py: new name for the
5477 example-magic_pm.py file. Much enhanced system, now with a shell
5482 example-magic_pm.py file. Much enhanced system, now with a shell
5478 for communicating directly with gnuplot, one command at a time.
5483 for communicating directly with gnuplot, one command at a time.
5479
5484
5480 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
5485 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
5481 setting __name__=='__main__'.
5486 setting __name__=='__main__'.
5482
5487
5483 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
5488 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
5484 mini-shell for accessing gnuplot from inside ipython. Should
5489 mini-shell for accessing gnuplot from inside ipython. Should
5485 extend it later for grace access too. Inspired by Arnd's
5490 extend it later for grace access too. Inspired by Arnd's
5486 suggestion.
5491 suggestion.
5487
5492
5488 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
5493 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
5489 calling magic functions with () in their arguments. Thanks to Arnd
5494 calling magic functions with () in their arguments. Thanks to Arnd
5490 Baecker for pointing this to me.
5495 Baecker for pointing this to me.
5491
5496
5492 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
5497 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
5493 infinitely for integer or complex arrays (only worked with floats).
5498 infinitely for integer or complex arrays (only worked with floats).
5494
5499
5495 2002-03-16 Fernando Perez <fperez@colorado.edu>
5500 2002-03-16 Fernando Perez <fperez@colorado.edu>
5496
5501
5497 * setup.py: Merged setup and setup_windows into a single script
5502 * setup.py: Merged setup and setup_windows into a single script
5498 which properly handles things for windows users.
5503 which properly handles things for windows users.
5499
5504
5500 2002-03-15 Fernando Perez <fperez@colorado.edu>
5505 2002-03-15 Fernando Perez <fperez@colorado.edu>
5501
5506
5502 * Big change to the manual: now the magics are all automatically
5507 * Big change to the manual: now the magics are all automatically
5503 documented. This information is generated from their docstrings
5508 documented. This information is generated from their docstrings
5504 and put in a latex file included by the manual lyx file. This way
5509 and put in a latex file included by the manual lyx file. This way
5505 we get always up to date information for the magics. The manual
5510 we get always up to date information for the magics. The manual
5506 now also has proper version information, also auto-synced.
5511 now also has proper version information, also auto-synced.
5507
5512
5508 For this to work, an undocumented --magic_docstrings option was added.
5513 For this to work, an undocumented --magic_docstrings option was added.
5509
5514
5510 2002-03-13 Fernando Perez <fperez@colorado.edu>
5515 2002-03-13 Fernando Perez <fperez@colorado.edu>
5511
5516
5512 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
5517 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
5513 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
5518 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
5514
5519
5515 2002-03-12 Fernando Perez <fperez@colorado.edu>
5520 2002-03-12 Fernando Perez <fperez@colorado.edu>
5516
5521
5517 * IPython/ultraTB.py (TermColors): changed color escapes again to
5522 * IPython/ultraTB.py (TermColors): changed color escapes again to
5518 fix the (old, reintroduced) line-wrapping bug. Basically, if
5523 fix the (old, reintroduced) line-wrapping bug. Basically, if
5519 \001..\002 aren't given in the color escapes, lines get wrapped
5524 \001..\002 aren't given in the color escapes, lines get wrapped
5520 weirdly. But giving those screws up old xterms and emacs terms. So
5525 weirdly. But giving those screws up old xterms and emacs terms. So
5521 I added some logic for emacs terms to be ok, but I can't identify old
5526 I added some logic for emacs terms to be ok, but I can't identify old
5522 xterms separately ($TERM=='xterm' for many terminals, like konsole).
5527 xterms separately ($TERM=='xterm' for many terminals, like konsole).
5523
5528
5524 2002-03-10 Fernando Perez <fperez@colorado.edu>
5529 2002-03-10 Fernando Perez <fperez@colorado.edu>
5525
5530
5526 * IPython/usage.py (__doc__): Various documentation cleanups and
5531 * IPython/usage.py (__doc__): Various documentation cleanups and
5527 updates, both in usage docstrings and in the manual.
5532 updates, both in usage docstrings and in the manual.
5528
5533
5529 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
5534 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
5530 handling of caching. Set minimum acceptabe value for having a
5535 handling of caching. Set minimum acceptabe value for having a
5531 cache at 20 values.
5536 cache at 20 values.
5532
5537
5533 * IPython/iplib.py (InteractiveShell.user_setup): moved the
5538 * IPython/iplib.py (InteractiveShell.user_setup): moved the
5534 install_first_time function to a method, renamed it and added an
5539 install_first_time function to a method, renamed it and added an
5535 'upgrade' mode. Now people can update their config directory with
5540 'upgrade' mode. Now people can update their config directory with
5536 a simple command line switch (-upgrade, also new).
5541 a simple command line switch (-upgrade, also new).
5537
5542
5538 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
5543 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
5539 @file (convenient for automagic users under Python >= 2.2).
5544 @file (convenient for automagic users under Python >= 2.2).
5540 Removed @files (it seemed more like a plural than an abbrev. of
5545 Removed @files (it seemed more like a plural than an abbrev. of
5541 'file show').
5546 'file show').
5542
5547
5543 * IPython/iplib.py (install_first_time): Fixed crash if there were
5548 * IPython/iplib.py (install_first_time): Fixed crash if there were
5544 backup files ('~') in .ipython/ install directory.
5549 backup files ('~') in .ipython/ install directory.
5545
5550
5546 * IPython/ipmaker.py (make_IPython): fixes for new prompt
5551 * IPython/ipmaker.py (make_IPython): fixes for new prompt
5547 system. Things look fine, but these changes are fairly
5552 system. Things look fine, but these changes are fairly
5548 intrusive. Test them for a few days.
5553 intrusive. Test them for a few days.
5549
5554
5550 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
5555 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
5551 the prompts system. Now all in/out prompt strings are user
5556 the prompts system. Now all in/out prompt strings are user
5552 controllable. This is particularly useful for embedding, as one
5557 controllable. This is particularly useful for embedding, as one
5553 can tag embedded instances with particular prompts.
5558 can tag embedded instances with particular prompts.
5554
5559
5555 Also removed global use of sys.ps1/2, which now allows nested
5560 Also removed global use of sys.ps1/2, which now allows nested
5556 embeddings without any problems. Added command-line options for
5561 embeddings without any problems. Added command-line options for
5557 the prompt strings.
5562 the prompt strings.
5558
5563
5559 2002-03-08 Fernando Perez <fperez@colorado.edu>
5564 2002-03-08 Fernando Perez <fperez@colorado.edu>
5560
5565
5561 * IPython/UserConfig/example-embed-short.py (ipshell): added
5566 * IPython/UserConfig/example-embed-short.py (ipshell): added
5562 example file with the bare minimum code for embedding.
5567 example file with the bare minimum code for embedding.
5563
5568
5564 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
5569 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
5565 functionality for the embeddable shell to be activated/deactivated
5570 functionality for the embeddable shell to be activated/deactivated
5566 either globally or at each call.
5571 either globally or at each call.
5567
5572
5568 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
5573 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
5569 rewriting the prompt with '--->' for auto-inputs with proper
5574 rewriting the prompt with '--->' for auto-inputs with proper
5570 coloring. Now the previous UGLY hack in handle_auto() is gone, and
5575 coloring. Now the previous UGLY hack in handle_auto() is gone, and
5571 this is handled by the prompts class itself, as it should.
5576 this is handled by the prompts class itself, as it should.
5572
5577
5573 2002-03-05 Fernando Perez <fperez@colorado.edu>
5578 2002-03-05 Fernando Perez <fperez@colorado.edu>
5574
5579
5575 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
5580 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
5576 @logstart to avoid name clashes with the math log function.
5581 @logstart to avoid name clashes with the math log function.
5577
5582
5578 * Big updates to X/Emacs section of the manual.
5583 * Big updates to X/Emacs section of the manual.
5579
5584
5580 * Removed ipython_emacs. Milan explained to me how to pass
5585 * Removed ipython_emacs. Milan explained to me how to pass
5581 arguments to ipython through Emacs. Some day I'm going to end up
5586 arguments to ipython through Emacs. Some day I'm going to end up
5582 learning some lisp...
5587 learning some lisp...
5583
5588
5584 2002-03-04 Fernando Perez <fperez@colorado.edu>
5589 2002-03-04 Fernando Perez <fperez@colorado.edu>
5585
5590
5586 * IPython/ipython_emacs: Created script to be used as the
5591 * IPython/ipython_emacs: Created script to be used as the
5587 py-python-command Emacs variable so we can pass IPython
5592 py-python-command Emacs variable so we can pass IPython
5588 parameters. I can't figure out how to tell Emacs directly to pass
5593 parameters. I can't figure out how to tell Emacs directly to pass
5589 parameters to IPython, so a dummy shell script will do it.
5594 parameters to IPython, so a dummy shell script will do it.
5590
5595
5591 Other enhancements made for things to work better under Emacs'
5596 Other enhancements made for things to work better under Emacs'
5592 various types of terminals. Many thanks to Milan Zamazal
5597 various types of terminals. Many thanks to Milan Zamazal
5593 <pdm-AT-zamazal.org> for all the suggestions and pointers.
5598 <pdm-AT-zamazal.org> for all the suggestions and pointers.
5594
5599
5595 2002-03-01 Fernando Perez <fperez@colorado.edu>
5600 2002-03-01 Fernando Perez <fperez@colorado.edu>
5596
5601
5597 * IPython/ipmaker.py (make_IPython): added a --readline! option so
5602 * IPython/ipmaker.py (make_IPython): added a --readline! option so
5598 that loading of readline is now optional. This gives better
5603 that loading of readline is now optional. This gives better
5599 control to emacs users.
5604 control to emacs users.
5600
5605
5601 * IPython/ultraTB.py (__date__): Modified color escape sequences
5606 * IPython/ultraTB.py (__date__): Modified color escape sequences
5602 and now things work fine under xterm and in Emacs' term buffers
5607 and now things work fine under xterm and in Emacs' term buffers
5603 (though not shell ones). Well, in emacs you get colors, but all
5608 (though not shell ones). Well, in emacs you get colors, but all
5604 seem to be 'light' colors (no difference between dark and light
5609 seem to be 'light' colors (no difference between dark and light
5605 ones). But the garbage chars are gone, and also in xterms. It
5610 ones). But the garbage chars are gone, and also in xterms. It
5606 seems that now I'm using 'cleaner' ansi sequences.
5611 seems that now I'm using 'cleaner' ansi sequences.
5607
5612
5608 2002-02-21 Fernando Perez <fperez@colorado.edu>
5613 2002-02-21 Fernando Perez <fperez@colorado.edu>
5609
5614
5610 * Released 0.2.7 (mainly to publish the scoping fix).
5615 * Released 0.2.7 (mainly to publish the scoping fix).
5611
5616
5612 * IPython/Logger.py (Logger.logstate): added. A corresponding
5617 * IPython/Logger.py (Logger.logstate): added. A corresponding
5613 @logstate magic was created.
5618 @logstate magic was created.
5614
5619
5615 * IPython/Magic.py: fixed nested scoping problem under Python
5620 * IPython/Magic.py: fixed nested scoping problem under Python
5616 2.1.x (automagic wasn't working).
5621 2.1.x (automagic wasn't working).
5617
5622
5618 2002-02-20 Fernando Perez <fperez@colorado.edu>
5623 2002-02-20 Fernando Perez <fperez@colorado.edu>
5619
5624
5620 * Released 0.2.6.
5625 * Released 0.2.6.
5621
5626
5622 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
5627 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
5623 option so that logs can come out without any headers at all.
5628 option so that logs can come out without any headers at all.
5624
5629
5625 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
5630 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
5626 SciPy.
5631 SciPy.
5627
5632
5628 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
5633 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
5629 that embedded IPython calls don't require vars() to be explicitly
5634 that embedded IPython calls don't require vars() to be explicitly
5630 passed. Now they are extracted from the caller's frame (code
5635 passed. Now they are extracted from the caller's frame (code
5631 snatched from Eric Jones' weave). Added better documentation to
5636 snatched from Eric Jones' weave). Added better documentation to
5632 the section on embedding and the example file.
5637 the section on embedding and the example file.
5633
5638
5634 * IPython/genutils.py (page): Changed so that under emacs, it just
5639 * IPython/genutils.py (page): Changed so that under emacs, it just
5635 prints the string. You can then page up and down in the emacs
5640 prints the string. You can then page up and down in the emacs
5636 buffer itself. This is how the builtin help() works.
5641 buffer itself. This is how the builtin help() works.
5637
5642
5638 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
5643 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
5639 macro scoping: macros need to be executed in the user's namespace
5644 macro scoping: macros need to be executed in the user's namespace
5640 to work as if they had been typed by the user.
5645 to work as if they had been typed by the user.
5641
5646
5642 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
5647 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
5643 execute automatically (no need to type 'exec...'). They then
5648 execute automatically (no need to type 'exec...'). They then
5644 behave like 'true macros'. The printing system was also modified
5649 behave like 'true macros'. The printing system was also modified
5645 for this to work.
5650 for this to work.
5646
5651
5647 2002-02-19 Fernando Perez <fperez@colorado.edu>
5652 2002-02-19 Fernando Perez <fperez@colorado.edu>
5648
5653
5649 * IPython/genutils.py (page_file): new function for paging files
5654 * IPython/genutils.py (page_file): new function for paging files
5650 in an OS-independent way. Also necessary for file viewing to work
5655 in an OS-independent way. Also necessary for file viewing to work
5651 well inside Emacs buffers.
5656 well inside Emacs buffers.
5652 (page): Added checks for being in an emacs buffer.
5657 (page): Added checks for being in an emacs buffer.
5653 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
5658 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
5654 same bug in iplib.
5659 same bug in iplib.
5655
5660
5656 2002-02-18 Fernando Perez <fperez@colorado.edu>
5661 2002-02-18 Fernando Perez <fperez@colorado.edu>
5657
5662
5658 * IPython/iplib.py (InteractiveShell.init_readline): modified use
5663 * IPython/iplib.py (InteractiveShell.init_readline): modified use
5659 of readline so that IPython can work inside an Emacs buffer.
5664 of readline so that IPython can work inside an Emacs buffer.
5660
5665
5661 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
5666 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
5662 method signatures (they weren't really bugs, but it looks cleaner
5667 method signatures (they weren't really bugs, but it looks cleaner
5663 and keeps PyChecker happy).
5668 and keeps PyChecker happy).
5664
5669
5665 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
5670 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
5666 for implementing various user-defined hooks. Currently only
5671 for implementing various user-defined hooks. Currently only
5667 display is done.
5672 display is done.
5668
5673
5669 * IPython/Prompts.py (CachedOutput._display): changed display
5674 * IPython/Prompts.py (CachedOutput._display): changed display
5670 functions so that they can be dynamically changed by users easily.
5675 functions so that they can be dynamically changed by users easily.
5671
5676
5672 * IPython/Extensions/numeric_formats.py (num_display): added an
5677 * IPython/Extensions/numeric_formats.py (num_display): added an
5673 extension for printing NumPy arrays in flexible manners. It
5678 extension for printing NumPy arrays in flexible manners. It
5674 doesn't do anything yet, but all the structure is in
5679 doesn't do anything yet, but all the structure is in
5675 place. Ultimately the plan is to implement output format control
5680 place. Ultimately the plan is to implement output format control
5676 like in Octave.
5681 like in Octave.
5677
5682
5678 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
5683 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
5679 methods are found at run-time by all the automatic machinery.
5684 methods are found at run-time by all the automatic machinery.
5680
5685
5681 2002-02-17 Fernando Perez <fperez@colorado.edu>
5686 2002-02-17 Fernando Perez <fperez@colorado.edu>
5682
5687
5683 * setup_Windows.py (make_shortcut): documented. Cleaned up the
5688 * setup_Windows.py (make_shortcut): documented. Cleaned up the
5684 whole file a little.
5689 whole file a little.
5685
5690
5686 * ToDo: closed this document. Now there's a new_design.lyx
5691 * ToDo: closed this document. Now there's a new_design.lyx
5687 document for all new ideas. Added making a pdf of it for the
5692 document for all new ideas. Added making a pdf of it for the
5688 end-user distro.
5693 end-user distro.
5689
5694
5690 * IPython/Logger.py (Logger.switch_log): Created this to replace
5695 * IPython/Logger.py (Logger.switch_log): Created this to replace
5691 logon() and logoff(). It also fixes a nasty crash reported by
5696 logon() and logoff(). It also fixes a nasty crash reported by
5692 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
5697 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
5693
5698
5694 * IPython/iplib.py (complete): got auto-completion to work with
5699 * IPython/iplib.py (complete): got auto-completion to work with
5695 automagic (I had wanted this for a long time).
5700 automagic (I had wanted this for a long time).
5696
5701
5697 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
5702 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
5698 to @file, since file() is now a builtin and clashes with automagic
5703 to @file, since file() is now a builtin and clashes with automagic
5699 for @file.
5704 for @file.
5700
5705
5701 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
5706 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
5702 of this was previously in iplib, which had grown to more than 2000
5707 of this was previously in iplib, which had grown to more than 2000
5703 lines, way too long. No new functionality, but it makes managing
5708 lines, way too long. No new functionality, but it makes managing
5704 the code a bit easier.
5709 the code a bit easier.
5705
5710
5706 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
5711 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
5707 information to crash reports.
5712 information to crash reports.
5708
5713
5709 2002-02-12 Fernando Perez <fperez@colorado.edu>
5714 2002-02-12 Fernando Perez <fperez@colorado.edu>
5710
5715
5711 * Released 0.2.5.
5716 * Released 0.2.5.
5712
5717
5713 2002-02-11 Fernando Perez <fperez@colorado.edu>
5718 2002-02-11 Fernando Perez <fperez@colorado.edu>
5714
5719
5715 * Wrote a relatively complete Windows installer. It puts
5720 * Wrote a relatively complete Windows installer. It puts
5716 everything in place, creates Start Menu entries and fixes the
5721 everything in place, creates Start Menu entries and fixes the
5717 color issues. Nothing fancy, but it works.
5722 color issues. Nothing fancy, but it works.
5718
5723
5719 2002-02-10 Fernando Perez <fperez@colorado.edu>
5724 2002-02-10 Fernando Perez <fperez@colorado.edu>
5720
5725
5721 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
5726 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
5722 os.path.expanduser() call so that we can type @run ~/myfile.py and
5727 os.path.expanduser() call so that we can type @run ~/myfile.py and
5723 have thigs work as expected.
5728 have thigs work as expected.
5724
5729
5725 * IPython/genutils.py (page): fixed exception handling so things
5730 * IPython/genutils.py (page): fixed exception handling so things
5726 work both in Unix and Windows correctly. Quitting a pager triggers
5731 work both in Unix and Windows correctly. Quitting a pager triggers
5727 an IOError/broken pipe in Unix, and in windows not finding a pager
5732 an IOError/broken pipe in Unix, and in windows not finding a pager
5728 is also an IOError, so I had to actually look at the return value
5733 is also an IOError, so I had to actually look at the return value
5729 of the exception, not just the exception itself. Should be ok now.
5734 of the exception, not just the exception itself. Should be ok now.
5730
5735
5731 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
5736 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
5732 modified to allow case-insensitive color scheme changes.
5737 modified to allow case-insensitive color scheme changes.
5733
5738
5734 2002-02-09 Fernando Perez <fperez@colorado.edu>
5739 2002-02-09 Fernando Perez <fperez@colorado.edu>
5735
5740
5736 * IPython/genutils.py (native_line_ends): new function to leave
5741 * IPython/genutils.py (native_line_ends): new function to leave
5737 user config files with os-native line-endings.
5742 user config files with os-native line-endings.
5738
5743
5739 * README and manual updates.
5744 * README and manual updates.
5740
5745
5741 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
5746 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
5742 instead of StringType to catch Unicode strings.
5747 instead of StringType to catch Unicode strings.
5743
5748
5744 * IPython/genutils.py (filefind): fixed bug for paths with
5749 * IPython/genutils.py (filefind): fixed bug for paths with
5745 embedded spaces (very common in Windows).
5750 embedded spaces (very common in Windows).
5746
5751
5747 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
5752 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
5748 files under Windows, so that they get automatically associated
5753 files under Windows, so that they get automatically associated
5749 with a text editor. Windows makes it a pain to handle
5754 with a text editor. Windows makes it a pain to handle
5750 extension-less files.
5755 extension-less files.
5751
5756
5752 * IPython/iplib.py (InteractiveShell.init_readline): Made the
5757 * IPython/iplib.py (InteractiveShell.init_readline): Made the
5753 warning about readline only occur for Posix. In Windows there's no
5758 warning about readline only occur for Posix. In Windows there's no
5754 way to get readline, so why bother with the warning.
5759 way to get readline, so why bother with the warning.
5755
5760
5756 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
5761 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
5757 for __str__ instead of dir(self), since dir() changed in 2.2.
5762 for __str__ instead of dir(self), since dir() changed in 2.2.
5758
5763
5759 * Ported to Windows! Tested on XP, I suspect it should work fine
5764 * Ported to Windows! Tested on XP, I suspect it should work fine
5760 on NT/2000, but I don't think it will work on 98 et al. That
5765 on NT/2000, but I don't think it will work on 98 et al. That
5761 series of Windows is such a piece of junk anyway that I won't try
5766 series of Windows is such a piece of junk anyway that I won't try
5762 porting it there. The XP port was straightforward, showed a few
5767 porting it there. The XP port was straightforward, showed a few
5763 bugs here and there (fixed all), in particular some string
5768 bugs here and there (fixed all), in particular some string
5764 handling stuff which required considering Unicode strings (which
5769 handling stuff which required considering Unicode strings (which
5765 Windows uses). This is good, but hasn't been too tested :) No
5770 Windows uses). This is good, but hasn't been too tested :) No
5766 fancy installer yet, I'll put a note in the manual so people at
5771 fancy installer yet, I'll put a note in the manual so people at
5767 least make manually a shortcut.
5772 least make manually a shortcut.
5768
5773
5769 * IPython/iplib.py (Magic.magic_colors): Unified the color options
5774 * IPython/iplib.py (Magic.magic_colors): Unified the color options
5770 into a single one, "colors". This now controls both prompt and
5775 into a single one, "colors". This now controls both prompt and
5771 exception color schemes, and can be changed both at startup
5776 exception color schemes, and can be changed both at startup
5772 (either via command-line switches or via ipythonrc files) and at
5777 (either via command-line switches or via ipythonrc files) and at
5773 runtime, with @colors.
5778 runtime, with @colors.
5774 (Magic.magic_run): renamed @prun to @run and removed the old
5779 (Magic.magic_run): renamed @prun to @run and removed the old
5775 @run. The two were too similar to warrant keeping both.
5780 @run. The two were too similar to warrant keeping both.
5776
5781
5777 2002-02-03 Fernando Perez <fperez@colorado.edu>
5782 2002-02-03 Fernando Perez <fperez@colorado.edu>
5778
5783
5779 * IPython/iplib.py (install_first_time): Added comment on how to
5784 * IPython/iplib.py (install_first_time): Added comment on how to
5780 configure the color options for first-time users. Put a <return>
5785 configure the color options for first-time users. Put a <return>
5781 request at the end so that small-terminal users get a chance to
5786 request at the end so that small-terminal users get a chance to
5782 read the startup info.
5787 read the startup info.
5783
5788
5784 2002-01-23 Fernando Perez <fperez@colorado.edu>
5789 2002-01-23 Fernando Perez <fperez@colorado.edu>
5785
5790
5786 * IPython/iplib.py (CachedOutput.update): Changed output memory
5791 * IPython/iplib.py (CachedOutput.update): Changed output memory
5787 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
5792 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
5788 input history we still use _i. Did this b/c these variable are
5793 input history we still use _i. Did this b/c these variable are
5789 very commonly used in interactive work, so the less we need to
5794 very commonly used in interactive work, so the less we need to
5790 type the better off we are.
5795 type the better off we are.
5791 (Magic.magic_prun): updated @prun to better handle the namespaces
5796 (Magic.magic_prun): updated @prun to better handle the namespaces
5792 the file will run in, including a fix for __name__ not being set
5797 the file will run in, including a fix for __name__ not being set
5793 before.
5798 before.
5794
5799
5795 2002-01-20 Fernando Perez <fperez@colorado.edu>
5800 2002-01-20 Fernando Perez <fperez@colorado.edu>
5796
5801
5797 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
5802 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
5798 extra garbage for Python 2.2. Need to look more carefully into
5803 extra garbage for Python 2.2. Need to look more carefully into
5799 this later.
5804 this later.
5800
5805
5801 2002-01-19 Fernando Perez <fperez@colorado.edu>
5806 2002-01-19 Fernando Perez <fperez@colorado.edu>
5802
5807
5803 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
5808 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
5804 display SyntaxError exceptions properly formatted when they occur
5809 display SyntaxError exceptions properly formatted when they occur
5805 (they can be triggered by imported code).
5810 (they can be triggered by imported code).
5806
5811
5807 2002-01-18 Fernando Perez <fperez@colorado.edu>
5812 2002-01-18 Fernando Perez <fperez@colorado.edu>
5808
5813
5809 * IPython/iplib.py (InteractiveShell.safe_execfile): now
5814 * IPython/iplib.py (InteractiveShell.safe_execfile): now
5810 SyntaxError exceptions are reported nicely formatted, instead of
5815 SyntaxError exceptions are reported nicely formatted, instead of
5811 spitting out only offset information as before.
5816 spitting out only offset information as before.
5812 (Magic.magic_prun): Added the @prun function for executing
5817 (Magic.magic_prun): Added the @prun function for executing
5813 programs with command line args inside IPython.
5818 programs with command line args inside IPython.
5814
5819
5815 2002-01-16 Fernando Perez <fperez@colorado.edu>
5820 2002-01-16 Fernando Perez <fperez@colorado.edu>
5816
5821
5817 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
5822 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
5818 to *not* include the last item given in a range. This brings their
5823 to *not* include the last item given in a range. This brings their
5819 behavior in line with Python's slicing:
5824 behavior in line with Python's slicing:
5820 a[n1:n2] -> a[n1]...a[n2-1]
5825 a[n1:n2] -> a[n1]...a[n2-1]
5821 It may be a bit less convenient, but I prefer to stick to Python's
5826 It may be a bit less convenient, but I prefer to stick to Python's
5822 conventions *everywhere*, so users never have to wonder.
5827 conventions *everywhere*, so users never have to wonder.
5823 (Magic.magic_macro): Added @macro function to ease the creation of
5828 (Magic.magic_macro): Added @macro function to ease the creation of
5824 macros.
5829 macros.
5825
5830
5826 2002-01-05 Fernando Perez <fperez@colorado.edu>
5831 2002-01-05 Fernando Perez <fperez@colorado.edu>
5827
5832
5828 * Released 0.2.4.
5833 * Released 0.2.4.
5829
5834
5830 * IPython/iplib.py (Magic.magic_pdef):
5835 * IPython/iplib.py (Magic.magic_pdef):
5831 (InteractiveShell.safe_execfile): report magic lines and error
5836 (InteractiveShell.safe_execfile): report magic lines and error
5832 lines without line numbers so one can easily copy/paste them for
5837 lines without line numbers so one can easily copy/paste them for
5833 re-execution.
5838 re-execution.
5834
5839
5835 * Updated manual with recent changes.
5840 * Updated manual with recent changes.
5836
5841
5837 * IPython/iplib.py (Magic.magic_oinfo): added constructor
5842 * IPython/iplib.py (Magic.magic_oinfo): added constructor
5838 docstring printing when class? is called. Very handy for knowing
5843 docstring printing when class? is called. Very handy for knowing
5839 how to create class instances (as long as __init__ is well
5844 how to create class instances (as long as __init__ is well
5840 documented, of course :)
5845 documented, of course :)
5841 (Magic.magic_doc): print both class and constructor docstrings.
5846 (Magic.magic_doc): print both class and constructor docstrings.
5842 (Magic.magic_pdef): give constructor info if passed a class and
5847 (Magic.magic_pdef): give constructor info if passed a class and
5843 __call__ info for callable object instances.
5848 __call__ info for callable object instances.
5844
5849
5845 2002-01-04 Fernando Perez <fperez@colorado.edu>
5850 2002-01-04 Fernando Perez <fperez@colorado.edu>
5846
5851
5847 * Made deep_reload() off by default. It doesn't always work
5852 * Made deep_reload() off by default. It doesn't always work
5848 exactly as intended, so it's probably safer to have it off. It's
5853 exactly as intended, so it's probably safer to have it off. It's
5849 still available as dreload() anyway, so nothing is lost.
5854 still available as dreload() anyway, so nothing is lost.
5850
5855
5851 2002-01-02 Fernando Perez <fperez@colorado.edu>
5856 2002-01-02 Fernando Perez <fperez@colorado.edu>
5852
5857
5853 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
5858 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
5854 so I wanted an updated release).
5859 so I wanted an updated release).
5855
5860
5856 2001-12-27 Fernando Perez <fperez@colorado.edu>
5861 2001-12-27 Fernando Perez <fperez@colorado.edu>
5857
5862
5858 * IPython/iplib.py (InteractiveShell.interact): Added the original
5863 * IPython/iplib.py (InteractiveShell.interact): Added the original
5859 code from 'code.py' for this module in order to change the
5864 code from 'code.py' for this module in order to change the
5860 handling of a KeyboardInterrupt. This was necessary b/c otherwise
5865 handling of a KeyboardInterrupt. This was necessary b/c otherwise
5861 the history cache would break when the user hit Ctrl-C, and
5866 the history cache would break when the user hit Ctrl-C, and
5862 interact() offers no way to add any hooks to it.
5867 interact() offers no way to add any hooks to it.
5863
5868
5864 2001-12-23 Fernando Perez <fperez@colorado.edu>
5869 2001-12-23 Fernando Perez <fperez@colorado.edu>
5865
5870
5866 * setup.py: added check for 'MANIFEST' before trying to remove
5871 * setup.py: added check for 'MANIFEST' before trying to remove
5867 it. Thanks to Sean Reifschneider.
5872 it. Thanks to Sean Reifschneider.
5868
5873
5869 2001-12-22 Fernando Perez <fperez@colorado.edu>
5874 2001-12-22 Fernando Perez <fperez@colorado.edu>
5870
5875
5871 * Released 0.2.2.
5876 * Released 0.2.2.
5872
5877
5873 * Finished (reasonably) writing the manual. Later will add the
5878 * Finished (reasonably) writing the manual. Later will add the
5874 python-standard navigation stylesheets, but for the time being
5879 python-standard navigation stylesheets, but for the time being
5875 it's fairly complete. Distribution will include html and pdf
5880 it's fairly complete. Distribution will include html and pdf
5876 versions.
5881 versions.
5877
5882
5878 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
5883 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
5879 (MayaVi author).
5884 (MayaVi author).
5880
5885
5881 2001-12-21 Fernando Perez <fperez@colorado.edu>
5886 2001-12-21 Fernando Perez <fperez@colorado.edu>
5882
5887
5883 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
5888 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
5884 good public release, I think (with the manual and the distutils
5889 good public release, I think (with the manual and the distutils
5885 installer). The manual can use some work, but that can go
5890 installer). The manual can use some work, but that can go
5886 slowly. Otherwise I think it's quite nice for end users. Next
5891 slowly. Otherwise I think it's quite nice for end users. Next
5887 summer, rewrite the guts of it...
5892 summer, rewrite the guts of it...
5888
5893
5889 * Changed format of ipythonrc files to use whitespace as the
5894 * Changed format of ipythonrc files to use whitespace as the
5890 separator instead of an explicit '='. Cleaner.
5895 separator instead of an explicit '='. Cleaner.
5891
5896
5892 2001-12-20 Fernando Perez <fperez@colorado.edu>
5897 2001-12-20 Fernando Perez <fperez@colorado.edu>
5893
5898
5894 * Started a manual in LyX. For now it's just a quick merge of the
5899 * Started a manual in LyX. For now it's just a quick merge of the
5895 various internal docstrings and READMEs. Later it may grow into a
5900 various internal docstrings and READMEs. Later it may grow into a
5896 nice, full-blown manual.
5901 nice, full-blown manual.
5897
5902
5898 * Set up a distutils based installer. Installation should now be
5903 * Set up a distutils based installer. Installation should now be
5899 trivially simple for end-users.
5904 trivially simple for end-users.
5900
5905
5901 2001-12-11 Fernando Perez <fperez@colorado.edu>
5906 2001-12-11 Fernando Perez <fperez@colorado.edu>
5902
5907
5903 * Released 0.2.0. First public release, announced it at
5908 * Released 0.2.0. First public release, announced it at
5904 comp.lang.python. From now on, just bugfixes...
5909 comp.lang.python. From now on, just bugfixes...
5905
5910
5906 * Went through all the files, set copyright/license notices and
5911 * Went through all the files, set copyright/license notices and
5907 cleaned up things. Ready for release.
5912 cleaned up things. Ready for release.
5908
5913
5909 2001-12-10 Fernando Perez <fperez@colorado.edu>
5914 2001-12-10 Fernando Perez <fperez@colorado.edu>
5910
5915
5911 * Changed the first-time installer not to use tarfiles. It's more
5916 * Changed the first-time installer not to use tarfiles. It's more
5912 robust now and less unix-dependent. Also makes it easier for
5917 robust now and less unix-dependent. Also makes it easier for
5913 people to later upgrade versions.
5918 people to later upgrade versions.
5914
5919
5915 * Changed @exit to @abort to reflect the fact that it's pretty
5920 * Changed @exit to @abort to reflect the fact that it's pretty
5916 brutal (a sys.exit()). The difference between @abort and Ctrl-D
5921 brutal (a sys.exit()). The difference between @abort and Ctrl-D
5917 becomes significant only when IPyhton is embedded: in that case,
5922 becomes significant only when IPyhton is embedded: in that case,
5918 C-D closes IPython only, but @abort kills the enclosing program
5923 C-D closes IPython only, but @abort kills the enclosing program
5919 too (unless it had called IPython inside a try catching
5924 too (unless it had called IPython inside a try catching
5920 SystemExit).
5925 SystemExit).
5921
5926
5922 * Created Shell module which exposes the actuall IPython Shell
5927 * Created Shell module which exposes the actuall IPython Shell
5923 classes, currently the normal and the embeddable one. This at
5928 classes, currently the normal and the embeddable one. This at
5924 least offers a stable interface we won't need to change when
5929 least offers a stable interface we won't need to change when
5925 (later) the internals are rewritten. That rewrite will be confined
5930 (later) the internals are rewritten. That rewrite will be confined
5926 to iplib and ipmaker, but the Shell interface should remain as is.
5931 to iplib and ipmaker, but the Shell interface should remain as is.
5927
5932
5928 * Added embed module which offers an embeddable IPShell object,
5933 * Added embed module which offers an embeddable IPShell object,
5929 useful to fire up IPython *inside* a running program. Great for
5934 useful to fire up IPython *inside* a running program. Great for
5930 debugging or dynamical data analysis.
5935 debugging or dynamical data analysis.
5931
5936
5932 2001-12-08 Fernando Perez <fperez@colorado.edu>
5937 2001-12-08 Fernando Perez <fperez@colorado.edu>
5933
5938
5934 * Fixed small bug preventing seeing info from methods of defined
5939 * Fixed small bug preventing seeing info from methods of defined
5935 objects (incorrect namespace in _ofind()).
5940 objects (incorrect namespace in _ofind()).
5936
5941
5937 * Documentation cleanup. Moved the main usage docstrings to a
5942 * Documentation cleanup. Moved the main usage docstrings to a
5938 separate file, usage.py (cleaner to maintain, and hopefully in the
5943 separate file, usage.py (cleaner to maintain, and hopefully in the
5939 future some perlpod-like way of producing interactive, man and
5944 future some perlpod-like way of producing interactive, man and
5940 html docs out of it will be found).
5945 html docs out of it will be found).
5941
5946
5942 * Added @profile to see your profile at any time.
5947 * Added @profile to see your profile at any time.
5943
5948
5944 * Added @p as an alias for 'print'. It's especially convenient if
5949 * Added @p as an alias for 'print'. It's especially convenient if
5945 using automagic ('p x' prints x).
5950 using automagic ('p x' prints x).
5946
5951
5947 * Small cleanups and fixes after a pychecker run.
5952 * Small cleanups and fixes after a pychecker run.
5948
5953
5949 * Changed the @cd command to handle @cd - and @cd -<n> for
5954 * Changed the @cd command to handle @cd - and @cd -<n> for
5950 visiting any directory in _dh.
5955 visiting any directory in _dh.
5951
5956
5952 * Introduced _dh, a history of visited directories. @dhist prints
5957 * Introduced _dh, a history of visited directories. @dhist prints
5953 it out with numbers.
5958 it out with numbers.
5954
5959
5955 2001-12-07 Fernando Perez <fperez@colorado.edu>
5960 2001-12-07 Fernando Perez <fperez@colorado.edu>
5956
5961
5957 * Released 0.1.22
5962 * Released 0.1.22
5958
5963
5959 * Made initialization a bit more robust against invalid color
5964 * Made initialization a bit more robust against invalid color
5960 options in user input (exit, not traceback-crash).
5965 options in user input (exit, not traceback-crash).
5961
5966
5962 * Changed the bug crash reporter to write the report only in the
5967 * Changed the bug crash reporter to write the report only in the
5963 user's .ipython directory. That way IPython won't litter people's
5968 user's .ipython directory. That way IPython won't litter people's
5964 hard disks with crash files all over the place. Also print on
5969 hard disks with crash files all over the place. Also print on
5965 screen the necessary mail command.
5970 screen the necessary mail command.
5966
5971
5967 * With the new ultraTB, implemented LightBG color scheme for light
5972 * With the new ultraTB, implemented LightBG color scheme for light
5968 background terminals. A lot of people like white backgrounds, so I
5973 background terminals. A lot of people like white backgrounds, so I
5969 guess we should at least give them something readable.
5974 guess we should at least give them something readable.
5970
5975
5971 2001-12-06 Fernando Perez <fperez@colorado.edu>
5976 2001-12-06 Fernando Perez <fperez@colorado.edu>
5972
5977
5973 * Modified the structure of ultraTB. Now there's a proper class
5978 * Modified the structure of ultraTB. Now there's a proper class
5974 for tables of color schemes which allow adding schemes easily and
5979 for tables of color schemes which allow adding schemes easily and
5975 switching the active scheme without creating a new instance every
5980 switching the active scheme without creating a new instance every
5976 time (which was ridiculous). The syntax for creating new schemes
5981 time (which was ridiculous). The syntax for creating new schemes
5977 is also cleaner. I think ultraTB is finally done, with a clean
5982 is also cleaner. I think ultraTB is finally done, with a clean
5978 class structure. Names are also much cleaner (now there's proper
5983 class structure. Names are also much cleaner (now there's proper
5979 color tables, no need for every variable to also have 'color' in
5984 color tables, no need for every variable to also have 'color' in
5980 its name).
5985 its name).
5981
5986
5982 * Broke down genutils into separate files. Now genutils only
5987 * Broke down genutils into separate files. Now genutils only
5983 contains utility functions, and classes have been moved to their
5988 contains utility functions, and classes have been moved to their
5984 own files (they had enough independent functionality to warrant
5989 own files (they had enough independent functionality to warrant
5985 it): ConfigLoader, OutputTrap, Struct.
5990 it): ConfigLoader, OutputTrap, Struct.
5986
5991
5987 2001-12-05 Fernando Perez <fperez@colorado.edu>
5992 2001-12-05 Fernando Perez <fperez@colorado.edu>
5988
5993
5989 * IPython turns 21! Released version 0.1.21, as a candidate for
5994 * IPython turns 21! Released version 0.1.21, as a candidate for
5990 public consumption. If all goes well, release in a few days.
5995 public consumption. If all goes well, release in a few days.
5991
5996
5992 * Fixed path bug (files in Extensions/ directory wouldn't be found
5997 * Fixed path bug (files in Extensions/ directory wouldn't be found
5993 unless IPython/ was explicitly in sys.path).
5998 unless IPython/ was explicitly in sys.path).
5994
5999
5995 * Extended the FlexCompleter class as MagicCompleter to allow
6000 * Extended the FlexCompleter class as MagicCompleter to allow
5996 completion of @-starting lines.
6001 completion of @-starting lines.
5997
6002
5998 * Created __release__.py file as a central repository for release
6003 * Created __release__.py file as a central repository for release
5999 info that other files can read from.
6004 info that other files can read from.
6000
6005
6001 * Fixed small bug in logging: when logging was turned on in
6006 * Fixed small bug in logging: when logging was turned on in
6002 mid-session, old lines with special meanings (!@?) were being
6007 mid-session, old lines with special meanings (!@?) were being
6003 logged without the prepended comment, which is necessary since
6008 logged without the prepended comment, which is necessary since
6004 they are not truly valid python syntax. This should make session
6009 they are not truly valid python syntax. This should make session
6005 restores produce less errors.
6010 restores produce less errors.
6006
6011
6007 * The namespace cleanup forced me to make a FlexCompleter class
6012 * The namespace cleanup forced me to make a FlexCompleter class
6008 which is nothing but a ripoff of rlcompleter, but with selectable
6013 which is nothing but a ripoff of rlcompleter, but with selectable
6009 namespace (rlcompleter only works in __main__.__dict__). I'll try
6014 namespace (rlcompleter only works in __main__.__dict__). I'll try
6010 to submit a note to the authors to see if this change can be
6015 to submit a note to the authors to see if this change can be
6011 incorporated in future rlcompleter releases (Dec.6: done)
6016 incorporated in future rlcompleter releases (Dec.6: done)
6012
6017
6013 * More fixes to namespace handling. It was a mess! Now all
6018 * More fixes to namespace handling. It was a mess! Now all
6014 explicit references to __main__.__dict__ are gone (except when
6019 explicit references to __main__.__dict__ are gone (except when
6015 really needed) and everything is handled through the namespace
6020 really needed) and everything is handled through the namespace
6016 dicts in the IPython instance. We seem to be getting somewhere
6021 dicts in the IPython instance. We seem to be getting somewhere
6017 with this, finally...
6022 with this, finally...
6018
6023
6019 * Small documentation updates.
6024 * Small documentation updates.
6020
6025
6021 * Created the Extensions directory under IPython (with an
6026 * Created the Extensions directory under IPython (with an
6022 __init__.py). Put the PhysicalQ stuff there. This directory should
6027 __init__.py). Put the PhysicalQ stuff there. This directory should
6023 be used for all special-purpose extensions.
6028 be used for all special-purpose extensions.
6024
6029
6025 * File renaming:
6030 * File renaming:
6026 ipythonlib --> ipmaker
6031 ipythonlib --> ipmaker
6027 ipplib --> iplib
6032 ipplib --> iplib
6028 This makes a bit more sense in terms of what these files actually do.
6033 This makes a bit more sense in terms of what these files actually do.
6029
6034
6030 * Moved all the classes and functions in ipythonlib to ipplib, so
6035 * Moved all the classes and functions in ipythonlib to ipplib, so
6031 now ipythonlib only has make_IPython(). This will ease up its
6036 now ipythonlib only has make_IPython(). This will ease up its
6032 splitting in smaller functional chunks later.
6037 splitting in smaller functional chunks later.
6033
6038
6034 * Cleaned up (done, I think) output of @whos. Better column
6039 * Cleaned up (done, I think) output of @whos. Better column
6035 formatting, and now shows str(var) for as much as it can, which is
6040 formatting, and now shows str(var) for as much as it can, which is
6036 typically what one gets with a 'print var'.
6041 typically what one gets with a 'print var'.
6037
6042
6038 2001-12-04 Fernando Perez <fperez@colorado.edu>
6043 2001-12-04 Fernando Perez <fperez@colorado.edu>
6039
6044
6040 * Fixed namespace problems. Now builtin/IPyhton/user names get
6045 * Fixed namespace problems. Now builtin/IPyhton/user names get
6041 properly reported in their namespace. Internal namespace handling
6046 properly reported in their namespace. Internal namespace handling
6042 is finally getting decent (not perfect yet, but much better than
6047 is finally getting decent (not perfect yet, but much better than
6043 the ad-hoc mess we had).
6048 the ad-hoc mess we had).
6044
6049
6045 * Removed -exit option. If people just want to run a python
6050 * Removed -exit option. If people just want to run a python
6046 script, that's what the normal interpreter is for. Less
6051 script, that's what the normal interpreter is for. Less
6047 unnecessary options, less chances for bugs.
6052 unnecessary options, less chances for bugs.
6048
6053
6049 * Added a crash handler which generates a complete post-mortem if
6054 * Added a crash handler which generates a complete post-mortem if
6050 IPython crashes. This will help a lot in tracking bugs down the
6055 IPython crashes. This will help a lot in tracking bugs down the
6051 road.
6056 road.
6052
6057
6053 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
6058 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
6054 which were boud to functions being reassigned would bypass the
6059 which were boud to functions being reassigned would bypass the
6055 logger, breaking the sync of _il with the prompt counter. This
6060 logger, breaking the sync of _il with the prompt counter. This
6056 would then crash IPython later when a new line was logged.
6061 would then crash IPython later when a new line was logged.
6057
6062
6058 2001-12-02 Fernando Perez <fperez@colorado.edu>
6063 2001-12-02 Fernando Perez <fperez@colorado.edu>
6059
6064
6060 * Made IPython a package. This means people don't have to clutter
6065 * Made IPython a package. This means people don't have to clutter
6061 their sys.path with yet another directory. Changed the INSTALL
6066 their sys.path with yet another directory. Changed the INSTALL
6062 file accordingly.
6067 file accordingly.
6063
6068
6064 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
6069 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
6065 sorts its output (so @who shows it sorted) and @whos formats the
6070 sorts its output (so @who shows it sorted) and @whos formats the
6066 table according to the width of the first column. Nicer, easier to
6071 table according to the width of the first column. Nicer, easier to
6067 read. Todo: write a generic table_format() which takes a list of
6072 read. Todo: write a generic table_format() which takes a list of
6068 lists and prints it nicely formatted, with optional row/column
6073 lists and prints it nicely formatted, with optional row/column
6069 separators and proper padding and justification.
6074 separators and proper padding and justification.
6070
6075
6071 * Released 0.1.20
6076 * Released 0.1.20
6072
6077
6073 * Fixed bug in @log which would reverse the inputcache list (a
6078 * Fixed bug in @log which would reverse the inputcache list (a
6074 copy operation was missing).
6079 copy operation was missing).
6075
6080
6076 * Code cleanup. @config was changed to use page(). Better, since
6081 * Code cleanup. @config was changed to use page(). Better, since
6077 its output is always quite long.
6082 its output is always quite long.
6078
6083
6079 * Itpl is back as a dependency. I was having too many problems
6084 * Itpl is back as a dependency. I was having too many problems
6080 getting the parametric aliases to work reliably, and it's just
6085 getting the parametric aliases to work reliably, and it's just
6081 easier to code weird string operations with it than playing %()s
6086 easier to code weird string operations with it than playing %()s
6082 games. It's only ~6k, so I don't think it's too big a deal.
6087 games. It's only ~6k, so I don't think it's too big a deal.
6083
6088
6084 * Found (and fixed) a very nasty bug with history. !lines weren't
6089 * Found (and fixed) a very nasty bug with history. !lines weren't
6085 getting cached, and the out of sync caches would crash
6090 getting cached, and the out of sync caches would crash
6086 IPython. Fixed it by reorganizing the prefilter/handlers/logger
6091 IPython. Fixed it by reorganizing the prefilter/handlers/logger
6087 division of labor a bit better. Bug fixed, cleaner structure.
6092 division of labor a bit better. Bug fixed, cleaner structure.
6088
6093
6089 2001-12-01 Fernando Perez <fperez@colorado.edu>
6094 2001-12-01 Fernando Perez <fperez@colorado.edu>
6090
6095
6091 * Released 0.1.19
6096 * Released 0.1.19
6092
6097
6093 * Added option -n to @hist to prevent line number printing. Much
6098 * Added option -n to @hist to prevent line number printing. Much
6094 easier to copy/paste code this way.
6099 easier to copy/paste code this way.
6095
6100
6096 * Created global _il to hold the input list. Allows easy
6101 * Created global _il to hold the input list. Allows easy
6097 re-execution of blocks of code by slicing it (inspired by Janko's
6102 re-execution of blocks of code by slicing it (inspired by Janko's
6098 comment on 'macros').
6103 comment on 'macros').
6099
6104
6100 * Small fixes and doc updates.
6105 * Small fixes and doc updates.
6101
6106
6102 * Rewrote @history function (was @h). Renamed it to @hist, @h is
6107 * Rewrote @history function (was @h). Renamed it to @hist, @h is
6103 much too fragile with automagic. Handles properly multi-line
6108 much too fragile with automagic. Handles properly multi-line
6104 statements and takes parameters.
6109 statements and takes parameters.
6105
6110
6106 2001-11-30 Fernando Perez <fperez@colorado.edu>
6111 2001-11-30 Fernando Perez <fperez@colorado.edu>
6107
6112
6108 * Version 0.1.18 released.
6113 * Version 0.1.18 released.
6109
6114
6110 * Fixed nasty namespace bug in initial module imports.
6115 * Fixed nasty namespace bug in initial module imports.
6111
6116
6112 * Added copyright/license notes to all code files (except
6117 * Added copyright/license notes to all code files (except
6113 DPyGetOpt). For the time being, LGPL. That could change.
6118 DPyGetOpt). For the time being, LGPL. That could change.
6114
6119
6115 * Rewrote a much nicer README, updated INSTALL, cleaned up
6120 * Rewrote a much nicer README, updated INSTALL, cleaned up
6116 ipythonrc-* samples.
6121 ipythonrc-* samples.
6117
6122
6118 * Overall code/documentation cleanup. Basically ready for
6123 * Overall code/documentation cleanup. Basically ready for
6119 release. Only remaining thing: licence decision (LGPL?).
6124 release. Only remaining thing: licence decision (LGPL?).
6120
6125
6121 * Converted load_config to a class, ConfigLoader. Now recursion
6126 * Converted load_config to a class, ConfigLoader. Now recursion
6122 control is better organized. Doesn't include the same file twice.
6127 control is better organized. Doesn't include the same file twice.
6123
6128
6124 2001-11-29 Fernando Perez <fperez@colorado.edu>
6129 2001-11-29 Fernando Perez <fperez@colorado.edu>
6125
6130
6126 * Got input history working. Changed output history variables from
6131 * Got input history working. Changed output history variables from
6127 _p to _o so that _i is for input and _o for output. Just cleaner
6132 _p to _o so that _i is for input and _o for output. Just cleaner
6128 convention.
6133 convention.
6129
6134
6130 * Implemented parametric aliases. This pretty much allows the
6135 * Implemented parametric aliases. This pretty much allows the
6131 alias system to offer full-blown shell convenience, I think.
6136 alias system to offer full-blown shell convenience, I think.
6132
6137
6133 * Version 0.1.17 released, 0.1.18 opened.
6138 * Version 0.1.17 released, 0.1.18 opened.
6134
6139
6135 * dot_ipython/ipythonrc (alias): added documentation.
6140 * dot_ipython/ipythonrc (alias): added documentation.
6136 (xcolor): Fixed small bug (xcolors -> xcolor)
6141 (xcolor): Fixed small bug (xcolors -> xcolor)
6137
6142
6138 * Changed the alias system. Now alias is a magic command to define
6143 * Changed the alias system. Now alias is a magic command to define
6139 aliases just like the shell. Rationale: the builtin magics should
6144 aliases just like the shell. Rationale: the builtin magics should
6140 be there for things deeply connected to IPython's
6145 be there for things deeply connected to IPython's
6141 architecture. And this is a much lighter system for what I think
6146 architecture. And this is a much lighter system for what I think
6142 is the really important feature: allowing users to define quickly
6147 is the really important feature: allowing users to define quickly
6143 magics that will do shell things for them, so they can customize
6148 magics that will do shell things for them, so they can customize
6144 IPython easily to match their work habits. If someone is really
6149 IPython easily to match their work habits. If someone is really
6145 desperate to have another name for a builtin alias, they can
6150 desperate to have another name for a builtin alias, they can
6146 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
6151 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
6147 works.
6152 works.
6148
6153
6149 2001-11-28 Fernando Perez <fperez@colorado.edu>
6154 2001-11-28 Fernando Perez <fperez@colorado.edu>
6150
6155
6151 * Changed @file so that it opens the source file at the proper
6156 * Changed @file so that it opens the source file at the proper
6152 line. Since it uses less, if your EDITOR environment is
6157 line. Since it uses less, if your EDITOR environment is
6153 configured, typing v will immediately open your editor of choice
6158 configured, typing v will immediately open your editor of choice
6154 right at the line where the object is defined. Not as quick as
6159 right at the line where the object is defined. Not as quick as
6155 having a direct @edit command, but for all intents and purposes it
6160 having a direct @edit command, but for all intents and purposes it
6156 works. And I don't have to worry about writing @edit to deal with
6161 works. And I don't have to worry about writing @edit to deal with
6157 all the editors, less does that.
6162 all the editors, less does that.
6158
6163
6159 * Version 0.1.16 released, 0.1.17 opened.
6164 * Version 0.1.16 released, 0.1.17 opened.
6160
6165
6161 * Fixed some nasty bugs in the page/page_dumb combo that could
6166 * Fixed some nasty bugs in the page/page_dumb combo that could
6162 crash IPython.
6167 crash IPython.
6163
6168
6164 2001-11-27 Fernando Perez <fperez@colorado.edu>
6169 2001-11-27 Fernando Perez <fperez@colorado.edu>
6165
6170
6166 * Version 0.1.15 released, 0.1.16 opened.
6171 * Version 0.1.15 released, 0.1.16 opened.
6167
6172
6168 * Finally got ? and ?? to work for undefined things: now it's
6173 * Finally got ? and ?? to work for undefined things: now it's
6169 possible to type {}.get? and get information about the get method
6174 possible to type {}.get? and get information about the get method
6170 of dicts, or os.path? even if only os is defined (so technically
6175 of dicts, or os.path? even if only os is defined (so technically
6171 os.path isn't). Works at any level. For example, after import os,
6176 os.path isn't). Works at any level. For example, after import os,
6172 os?, os.path?, os.path.abspath? all work. This is great, took some
6177 os?, os.path?, os.path.abspath? all work. This is great, took some
6173 work in _ofind.
6178 work in _ofind.
6174
6179
6175 * Fixed more bugs with logging. The sanest way to do it was to add
6180 * Fixed more bugs with logging. The sanest way to do it was to add
6176 to @log a 'mode' parameter. Killed two in one shot (this mode
6181 to @log a 'mode' parameter. Killed two in one shot (this mode
6177 option was a request of Janko's). I think it's finally clean
6182 option was a request of Janko's). I think it's finally clean
6178 (famous last words).
6183 (famous last words).
6179
6184
6180 * Added a page_dumb() pager which does a decent job of paging on
6185 * Added a page_dumb() pager which does a decent job of paging on
6181 screen, if better things (like less) aren't available. One less
6186 screen, if better things (like less) aren't available. One less
6182 unix dependency (someday maybe somebody will port this to
6187 unix dependency (someday maybe somebody will port this to
6183 windows).
6188 windows).
6184
6189
6185 * Fixed problem in magic_log: would lock of logging out if log
6190 * Fixed problem in magic_log: would lock of logging out if log
6186 creation failed (because it would still think it had succeeded).
6191 creation failed (because it would still think it had succeeded).
6187
6192
6188 * Improved the page() function using curses to auto-detect screen
6193 * Improved the page() function using curses to auto-detect screen
6189 size. Now it can make a much better decision on whether to print
6194 size. Now it can make a much better decision on whether to print
6190 or page a string. Option screen_length was modified: a value 0
6195 or page a string. Option screen_length was modified: a value 0
6191 means auto-detect, and that's the default now.
6196 means auto-detect, and that's the default now.
6192
6197
6193 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
6198 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
6194 go out. I'll test it for a few days, then talk to Janko about
6199 go out. I'll test it for a few days, then talk to Janko about
6195 licences and announce it.
6200 licences and announce it.
6196
6201
6197 * Fixed the length of the auto-generated ---> prompt which appears
6202 * Fixed the length of the auto-generated ---> prompt which appears
6198 for auto-parens and auto-quotes. Getting this right isn't trivial,
6203 for auto-parens and auto-quotes. Getting this right isn't trivial,
6199 with all the color escapes, different prompt types and optional
6204 with all the color escapes, different prompt types and optional
6200 separators. But it seems to be working in all the combinations.
6205 separators. But it seems to be working in all the combinations.
6201
6206
6202 2001-11-26 Fernando Perez <fperez@colorado.edu>
6207 2001-11-26 Fernando Perez <fperez@colorado.edu>
6203
6208
6204 * Wrote a regexp filter to get option types from the option names
6209 * Wrote a regexp filter to get option types from the option names
6205 string. This eliminates the need to manually keep two duplicate
6210 string. This eliminates the need to manually keep two duplicate
6206 lists.
6211 lists.
6207
6212
6208 * Removed the unneeded check_option_names. Now options are handled
6213 * Removed the unneeded check_option_names. Now options are handled
6209 in a much saner manner and it's easy to visually check that things
6214 in a much saner manner and it's easy to visually check that things
6210 are ok.
6215 are ok.
6211
6216
6212 * Updated version numbers on all files I modified to carry a
6217 * Updated version numbers on all files I modified to carry a
6213 notice so Janko and Nathan have clear version markers.
6218 notice so Janko and Nathan have clear version markers.
6214
6219
6215 * Updated docstring for ultraTB with my changes. I should send
6220 * Updated docstring for ultraTB with my changes. I should send
6216 this to Nathan.
6221 this to Nathan.
6217
6222
6218 * Lots of small fixes. Ran everything through pychecker again.
6223 * Lots of small fixes. Ran everything through pychecker again.
6219
6224
6220 * Made loading of deep_reload an cmd line option. If it's not too
6225 * Made loading of deep_reload an cmd line option. If it's not too
6221 kosher, now people can just disable it. With -nodeep_reload it's
6226 kosher, now people can just disable it. With -nodeep_reload it's
6222 still available as dreload(), it just won't overwrite reload().
6227 still available as dreload(), it just won't overwrite reload().
6223
6228
6224 * Moved many options to the no| form (-opt and -noopt
6229 * Moved many options to the no| form (-opt and -noopt
6225 accepted). Cleaner.
6230 accepted). Cleaner.
6226
6231
6227 * Changed magic_log so that if called with no parameters, it uses
6232 * Changed magic_log so that if called with no parameters, it uses
6228 'rotate' mode. That way auto-generated logs aren't automatically
6233 'rotate' mode. That way auto-generated logs aren't automatically
6229 over-written. For normal logs, now a backup is made if it exists
6234 over-written. For normal logs, now a backup is made if it exists
6230 (only 1 level of backups). A new 'backup' mode was added to the
6235 (only 1 level of backups). A new 'backup' mode was added to the
6231 Logger class to support this. This was a request by Janko.
6236 Logger class to support this. This was a request by Janko.
6232
6237
6233 * Added @logoff/@logon to stop/restart an active log.
6238 * Added @logoff/@logon to stop/restart an active log.
6234
6239
6235 * Fixed a lot of bugs in log saving/replay. It was pretty
6240 * Fixed a lot of bugs in log saving/replay. It was pretty
6236 broken. Now special lines (!@,/) appear properly in the command
6241 broken. Now special lines (!@,/) appear properly in the command
6237 history after a log replay.
6242 history after a log replay.
6238
6243
6239 * Tried and failed to implement full session saving via pickle. My
6244 * Tried and failed to implement full session saving via pickle. My
6240 idea was to pickle __main__.__dict__, but modules can't be
6245 idea was to pickle __main__.__dict__, but modules can't be
6241 pickled. This would be a better alternative to replaying logs, but
6246 pickled. This would be a better alternative to replaying logs, but
6242 seems quite tricky to get to work. Changed -session to be called
6247 seems quite tricky to get to work. Changed -session to be called
6243 -logplay, which more accurately reflects what it does. And if we
6248 -logplay, which more accurately reflects what it does. And if we
6244 ever get real session saving working, -session is now available.
6249 ever get real session saving working, -session is now available.
6245
6250
6246 * Implemented color schemes for prompts also. As for tracebacks,
6251 * Implemented color schemes for prompts also. As for tracebacks,
6247 currently only NoColor and Linux are supported. But now the
6252 currently only NoColor and Linux are supported. But now the
6248 infrastructure is in place, based on a generic ColorScheme
6253 infrastructure is in place, based on a generic ColorScheme
6249 class. So writing and activating new schemes both for the prompts
6254 class. So writing and activating new schemes both for the prompts
6250 and the tracebacks should be straightforward.
6255 and the tracebacks should be straightforward.
6251
6256
6252 * Version 0.1.13 released, 0.1.14 opened.
6257 * Version 0.1.13 released, 0.1.14 opened.
6253
6258
6254 * Changed handling of options for output cache. Now counter is
6259 * Changed handling of options for output cache. Now counter is
6255 hardwired starting at 1 and one specifies the maximum number of
6260 hardwired starting at 1 and one specifies the maximum number of
6256 entries *in the outcache* (not the max prompt counter). This is
6261 entries *in the outcache* (not the max prompt counter). This is
6257 much better, since many statements won't increase the cache
6262 much better, since many statements won't increase the cache
6258 count. It also eliminated some confusing options, now there's only
6263 count. It also eliminated some confusing options, now there's only
6259 one: cache_size.
6264 one: cache_size.
6260
6265
6261 * Added 'alias' magic function and magic_alias option in the
6266 * Added 'alias' magic function and magic_alias option in the
6262 ipythonrc file. Now the user can easily define whatever names he
6267 ipythonrc file. Now the user can easily define whatever names he
6263 wants for the magic functions without having to play weird
6268 wants for the magic functions without having to play weird
6264 namespace games. This gives IPython a real shell-like feel.
6269 namespace games. This gives IPython a real shell-like feel.
6265
6270
6266 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
6271 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
6267 @ or not).
6272 @ or not).
6268
6273
6269 This was one of the last remaining 'visible' bugs (that I know
6274 This was one of the last remaining 'visible' bugs (that I know
6270 of). I think if I can clean up the session loading so it works
6275 of). I think if I can clean up the session loading so it works
6271 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
6276 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
6272 about licensing).
6277 about licensing).
6273
6278
6274 2001-11-25 Fernando Perez <fperez@colorado.edu>
6279 2001-11-25 Fernando Perez <fperez@colorado.edu>
6275
6280
6276 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
6281 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
6277 there's a cleaner distinction between what ? and ?? show.
6282 there's a cleaner distinction between what ? and ?? show.
6278
6283
6279 * Added screen_length option. Now the user can define his own
6284 * Added screen_length option. Now the user can define his own
6280 screen size for page() operations.
6285 screen size for page() operations.
6281
6286
6282 * Implemented magic shell-like functions with automatic code
6287 * Implemented magic shell-like functions with automatic code
6283 generation. Now adding another function is just a matter of adding
6288 generation. Now adding another function is just a matter of adding
6284 an entry to a dict, and the function is dynamically generated at
6289 an entry to a dict, and the function is dynamically generated at
6285 run-time. Python has some really cool features!
6290 run-time. Python has some really cool features!
6286
6291
6287 * Renamed many options to cleanup conventions a little. Now all
6292 * Renamed many options to cleanup conventions a little. Now all
6288 are lowercase, and only underscores where needed. Also in the code
6293 are lowercase, and only underscores where needed. Also in the code
6289 option name tables are clearer.
6294 option name tables are clearer.
6290
6295
6291 * Changed prompts a little. Now input is 'In [n]:' instead of
6296 * Changed prompts a little. Now input is 'In [n]:' instead of
6292 'In[n]:='. This allows it the numbers to be aligned with the
6297 'In[n]:='. This allows it the numbers to be aligned with the
6293 Out[n] numbers, and removes usage of ':=' which doesn't exist in
6298 Out[n] numbers, and removes usage of ':=' which doesn't exist in
6294 Python (it was a Mathematica thing). The '...' continuation prompt
6299 Python (it was a Mathematica thing). The '...' continuation prompt
6295 was also changed a little to align better.
6300 was also changed a little to align better.
6296
6301
6297 * Fixed bug when flushing output cache. Not all _p<n> variables
6302 * Fixed bug when flushing output cache. Not all _p<n> variables
6298 exist, so their deletion needs to be wrapped in a try:
6303 exist, so their deletion needs to be wrapped in a try:
6299
6304
6300 * Figured out how to properly use inspect.formatargspec() (it
6305 * Figured out how to properly use inspect.formatargspec() (it
6301 requires the args preceded by *). So I removed all the code from
6306 requires the args preceded by *). So I removed all the code from
6302 _get_pdef in Magic, which was just replicating that.
6307 _get_pdef in Magic, which was just replicating that.
6303
6308
6304 * Added test to prefilter to allow redefining magic function names
6309 * Added test to prefilter to allow redefining magic function names
6305 as variables. This is ok, since the @ form is always available,
6310 as variables. This is ok, since the @ form is always available,
6306 but whe should allow the user to define a variable called 'ls' if
6311 but whe should allow the user to define a variable called 'ls' if
6307 he needs it.
6312 he needs it.
6308
6313
6309 * Moved the ToDo information from README into a separate ToDo.
6314 * Moved the ToDo information from README into a separate ToDo.
6310
6315
6311 * General code cleanup and small bugfixes. I think it's close to a
6316 * General code cleanup and small bugfixes. I think it's close to a
6312 state where it can be released, obviously with a big 'beta'
6317 state where it can be released, obviously with a big 'beta'
6313 warning on it.
6318 warning on it.
6314
6319
6315 * Got the magic function split to work. Now all magics are defined
6320 * Got the magic function split to work. Now all magics are defined
6316 in a separate class. It just organizes things a bit, and now
6321 in a separate class. It just organizes things a bit, and now
6317 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
6322 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
6318 was too long).
6323 was too long).
6319
6324
6320 * Changed @clear to @reset to avoid potential confusions with
6325 * Changed @clear to @reset to avoid potential confusions with
6321 the shell command clear. Also renamed @cl to @clear, which does
6326 the shell command clear. Also renamed @cl to @clear, which does
6322 exactly what people expect it to from their shell experience.
6327 exactly what people expect it to from their shell experience.
6323
6328
6324 Added a check to the @reset command (since it's so
6329 Added a check to the @reset command (since it's so
6325 destructive, it's probably a good idea to ask for confirmation).
6330 destructive, it's probably a good idea to ask for confirmation).
6326 But now reset only works for full namespace resetting. Since the
6331 But now reset only works for full namespace resetting. Since the
6327 del keyword is already there for deleting a few specific
6332 del keyword is already there for deleting a few specific
6328 variables, I don't see the point of having a redundant magic
6333 variables, I don't see the point of having a redundant magic
6329 function for the same task.
6334 function for the same task.
6330
6335
6331 2001-11-24 Fernando Perez <fperez@colorado.edu>
6336 2001-11-24 Fernando Perez <fperez@colorado.edu>
6332
6337
6333 * Updated the builtin docs (esp. the ? ones).
6338 * Updated the builtin docs (esp. the ? ones).
6334
6339
6335 * Ran all the code through pychecker. Not terribly impressed with
6340 * Ran all the code through pychecker. Not terribly impressed with
6336 it: lots of spurious warnings and didn't really find anything of
6341 it: lots of spurious warnings and didn't really find anything of
6337 substance (just a few modules being imported and not used).
6342 substance (just a few modules being imported and not used).
6338
6343
6339 * Implemented the new ultraTB functionality into IPython. New
6344 * Implemented the new ultraTB functionality into IPython. New
6340 option: xcolors. This chooses color scheme. xmode now only selects
6345 option: xcolors. This chooses color scheme. xmode now only selects
6341 between Plain and Verbose. Better orthogonality.
6346 between Plain and Verbose. Better orthogonality.
6342
6347
6343 * Large rewrite of ultraTB. Much cleaner now, with a separation of
6348 * Large rewrite of ultraTB. Much cleaner now, with a separation of
6344 mode and color scheme for the exception handlers. Now it's
6349 mode and color scheme for the exception handlers. Now it's
6345 possible to have the verbose traceback with no coloring.
6350 possible to have the verbose traceback with no coloring.
6346
6351
6347 2001-11-23 Fernando Perez <fperez@colorado.edu>
6352 2001-11-23 Fernando Perez <fperez@colorado.edu>
6348
6353
6349 * Version 0.1.12 released, 0.1.13 opened.
6354 * Version 0.1.12 released, 0.1.13 opened.
6350
6355
6351 * Removed option to set auto-quote and auto-paren escapes by
6356 * Removed option to set auto-quote and auto-paren escapes by
6352 user. The chances of breaking valid syntax are just too high. If
6357 user. The chances of breaking valid syntax are just too high. If
6353 someone *really* wants, they can always dig into the code.
6358 someone *really* wants, they can always dig into the code.
6354
6359
6355 * Made prompt separators configurable.
6360 * Made prompt separators configurable.
6356
6361
6357 2001-11-22 Fernando Perez <fperez@colorado.edu>
6362 2001-11-22 Fernando Perez <fperez@colorado.edu>
6358
6363
6359 * Small bugfixes in many places.
6364 * Small bugfixes in many places.
6360
6365
6361 * Removed the MyCompleter class from ipplib. It seemed redundant
6366 * Removed the MyCompleter class from ipplib. It seemed redundant
6362 with the C-p,C-n history search functionality. Less code to
6367 with the C-p,C-n history search functionality. Less code to
6363 maintain.
6368 maintain.
6364
6369
6365 * Moved all the original ipython.py code into ipythonlib.py. Right
6370 * Moved all the original ipython.py code into ipythonlib.py. Right
6366 now it's just one big dump into a function called make_IPython, so
6371 now it's just one big dump into a function called make_IPython, so
6367 no real modularity has been gained. But at least it makes the
6372 no real modularity has been gained. But at least it makes the
6368 wrapper script tiny, and since ipythonlib is a module, it gets
6373 wrapper script tiny, and since ipythonlib is a module, it gets
6369 compiled and startup is much faster.
6374 compiled and startup is much faster.
6370
6375
6371 This is a reasobably 'deep' change, so we should test it for a
6376 This is a reasobably 'deep' change, so we should test it for a
6372 while without messing too much more with the code.
6377 while without messing too much more with the code.
6373
6378
6374 2001-11-21 Fernando Perez <fperez@colorado.edu>
6379 2001-11-21 Fernando Perez <fperez@colorado.edu>
6375
6380
6376 * Version 0.1.11 released, 0.1.12 opened for further work.
6381 * Version 0.1.11 released, 0.1.12 opened for further work.
6377
6382
6378 * Removed dependency on Itpl. It was only needed in one place. It
6383 * Removed dependency on Itpl. It was only needed in one place. It
6379 would be nice if this became part of python, though. It makes life
6384 would be nice if this became part of python, though. It makes life
6380 *a lot* easier in some cases.
6385 *a lot* easier in some cases.
6381
6386
6382 * Simplified the prefilter code a bit. Now all handlers are
6387 * Simplified the prefilter code a bit. Now all handlers are
6383 expected to explicitly return a value (at least a blank string).
6388 expected to explicitly return a value (at least a blank string).
6384
6389
6385 * Heavy edits in ipplib. Removed the help system altogether. Now
6390 * Heavy edits in ipplib. Removed the help system altogether. Now
6386 obj?/?? is used for inspecting objects, a magic @doc prints
6391 obj?/?? is used for inspecting objects, a magic @doc prints
6387 docstrings, and full-blown Python help is accessed via the 'help'
6392 docstrings, and full-blown Python help is accessed via the 'help'
6388 keyword. This cleans up a lot of code (less to maintain) and does
6393 keyword. This cleans up a lot of code (less to maintain) and does
6389 the job. Since 'help' is now a standard Python component, might as
6394 the job. Since 'help' is now a standard Python component, might as
6390 well use it and remove duplicate functionality.
6395 well use it and remove duplicate functionality.
6391
6396
6392 Also removed the option to use ipplib as a standalone program. By
6397 Also removed the option to use ipplib as a standalone program. By
6393 now it's too dependent on other parts of IPython to function alone.
6398 now it's too dependent on other parts of IPython to function alone.
6394
6399
6395 * Fixed bug in genutils.pager. It would crash if the pager was
6400 * Fixed bug in genutils.pager. It would crash if the pager was
6396 exited immediately after opening (broken pipe).
6401 exited immediately after opening (broken pipe).
6397
6402
6398 * Trimmed down the VerboseTB reporting a little. The header is
6403 * Trimmed down the VerboseTB reporting a little. The header is
6399 much shorter now and the repeated exception arguments at the end
6404 much shorter now and the repeated exception arguments at the end
6400 have been removed. For interactive use the old header seemed a bit
6405 have been removed. For interactive use the old header seemed a bit
6401 excessive.
6406 excessive.
6402
6407
6403 * Fixed small bug in output of @whos for variables with multi-word
6408 * Fixed small bug in output of @whos for variables with multi-word
6404 types (only first word was displayed).
6409 types (only first word was displayed).
6405
6410
6406 2001-11-17 Fernando Perez <fperez@colorado.edu>
6411 2001-11-17 Fernando Perez <fperez@colorado.edu>
6407
6412
6408 * Version 0.1.10 released, 0.1.11 opened for further work.
6413 * Version 0.1.10 released, 0.1.11 opened for further work.
6409
6414
6410 * Modified dirs and friends. dirs now *returns* the stack (not
6415 * Modified dirs and friends. dirs now *returns* the stack (not
6411 prints), so one can manipulate it as a variable. Convenient to
6416 prints), so one can manipulate it as a variable. Convenient to
6412 travel along many directories.
6417 travel along many directories.
6413
6418
6414 * Fixed bug in magic_pdef: would only work with functions with
6419 * Fixed bug in magic_pdef: would only work with functions with
6415 arguments with default values.
6420 arguments with default values.
6416
6421
6417 2001-11-14 Fernando Perez <fperez@colorado.edu>
6422 2001-11-14 Fernando Perez <fperez@colorado.edu>
6418
6423
6419 * Added the PhysicsInput stuff to dot_ipython so it ships as an
6424 * Added the PhysicsInput stuff to dot_ipython so it ships as an
6420 example with IPython. Various other minor fixes and cleanups.
6425 example with IPython. Various other minor fixes and cleanups.
6421
6426
6422 * Version 0.1.9 released, 0.1.10 opened for further work.
6427 * Version 0.1.9 released, 0.1.10 opened for further work.
6423
6428
6424 * Added sys.path to the list of directories searched in the
6429 * Added sys.path to the list of directories searched in the
6425 execfile= option. It used to be the current directory and the
6430 execfile= option. It used to be the current directory and the
6426 user's IPYTHONDIR only.
6431 user's IPYTHONDIR only.
6427
6432
6428 2001-11-13 Fernando Perez <fperez@colorado.edu>
6433 2001-11-13 Fernando Perez <fperez@colorado.edu>
6429
6434
6430 * Reinstated the raw_input/prefilter separation that Janko had
6435 * Reinstated the raw_input/prefilter separation that Janko had
6431 initially. This gives a more convenient setup for extending the
6436 initially. This gives a more convenient setup for extending the
6432 pre-processor from the outside: raw_input always gets a string,
6437 pre-processor from the outside: raw_input always gets a string,
6433 and prefilter has to process it. We can then redefine prefilter
6438 and prefilter has to process it. We can then redefine prefilter
6434 from the outside and implement extensions for special
6439 from the outside and implement extensions for special
6435 purposes.
6440 purposes.
6436
6441
6437 Today I got one for inputting PhysicalQuantity objects
6442 Today I got one for inputting PhysicalQuantity objects
6438 (from Scientific) without needing any function calls at
6443 (from Scientific) without needing any function calls at
6439 all. Extremely convenient, and it's all done as a user-level
6444 all. Extremely convenient, and it's all done as a user-level
6440 extension (no IPython code was touched). Now instead of:
6445 extension (no IPython code was touched). Now instead of:
6441 a = PhysicalQuantity(4.2,'m/s**2')
6446 a = PhysicalQuantity(4.2,'m/s**2')
6442 one can simply say
6447 one can simply say
6443 a = 4.2 m/s**2
6448 a = 4.2 m/s**2
6444 or even
6449 or even
6445 a = 4.2 m/s^2
6450 a = 4.2 m/s^2
6446
6451
6447 I use this, but it's also a proof of concept: IPython really is
6452 I use this, but it's also a proof of concept: IPython really is
6448 fully user-extensible, even at the level of the parsing of the
6453 fully user-extensible, even at the level of the parsing of the
6449 command line. It's not trivial, but it's perfectly doable.
6454 command line. It's not trivial, but it's perfectly doable.
6450
6455
6451 * Added 'add_flip' method to inclusion conflict resolver. Fixes
6456 * Added 'add_flip' method to inclusion conflict resolver. Fixes
6452 the problem of modules being loaded in the inverse order in which
6457 the problem of modules being loaded in the inverse order in which
6453 they were defined in
6458 they were defined in
6454
6459
6455 * Version 0.1.8 released, 0.1.9 opened for further work.
6460 * Version 0.1.8 released, 0.1.9 opened for further work.
6456
6461
6457 * Added magics pdef, source and file. They respectively show the
6462 * Added magics pdef, source and file. They respectively show the
6458 definition line ('prototype' in C), source code and full python
6463 definition line ('prototype' in C), source code and full python
6459 file for any callable object. The object inspector oinfo uses
6464 file for any callable object. The object inspector oinfo uses
6460 these to show the same information.
6465 these to show the same information.
6461
6466
6462 * Version 0.1.7 released, 0.1.8 opened for further work.
6467 * Version 0.1.7 released, 0.1.8 opened for further work.
6463
6468
6464 * Separated all the magic functions into a class called Magic. The
6469 * Separated all the magic functions into a class called Magic. The
6465 InteractiveShell class was becoming too big for Xemacs to handle
6470 InteractiveShell class was becoming too big for Xemacs to handle
6466 (de-indenting a line would lock it up for 10 seconds while it
6471 (de-indenting a line would lock it up for 10 seconds while it
6467 backtracked on the whole class!)
6472 backtracked on the whole class!)
6468
6473
6469 FIXME: didn't work. It can be done, but right now namespaces are
6474 FIXME: didn't work. It can be done, but right now namespaces are
6470 all messed up. Do it later (reverted it for now, so at least
6475 all messed up. Do it later (reverted it for now, so at least
6471 everything works as before).
6476 everything works as before).
6472
6477
6473 * Got the object introspection system (magic_oinfo) working! I
6478 * Got the object introspection system (magic_oinfo) working! I
6474 think this is pretty much ready for release to Janko, so he can
6479 think this is pretty much ready for release to Janko, so he can
6475 test it for a while and then announce it. Pretty much 100% of what
6480 test it for a while and then announce it. Pretty much 100% of what
6476 I wanted for the 'phase 1' release is ready. Happy, tired.
6481 I wanted for the 'phase 1' release is ready. Happy, tired.
6477
6482
6478 2001-11-12 Fernando Perez <fperez@colorado.edu>
6483 2001-11-12 Fernando Perez <fperez@colorado.edu>
6479
6484
6480 * Version 0.1.6 released, 0.1.7 opened for further work.
6485 * Version 0.1.6 released, 0.1.7 opened for further work.
6481
6486
6482 * Fixed bug in printing: it used to test for truth before
6487 * Fixed bug in printing: it used to test for truth before
6483 printing, so 0 wouldn't print. Now checks for None.
6488 printing, so 0 wouldn't print. Now checks for None.
6484
6489
6485 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
6490 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
6486 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
6491 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
6487 reaches by hand into the outputcache. Think of a better way to do
6492 reaches by hand into the outputcache. Think of a better way to do
6488 this later.
6493 this later.
6489
6494
6490 * Various small fixes thanks to Nathan's comments.
6495 * Various small fixes thanks to Nathan's comments.
6491
6496
6492 * Changed magic_pprint to magic_Pprint. This way it doesn't
6497 * Changed magic_pprint to magic_Pprint. This way it doesn't
6493 collide with pprint() and the name is consistent with the command
6498 collide with pprint() and the name is consistent with the command
6494 line option.
6499 line option.
6495
6500
6496 * Changed prompt counter behavior to be fully like
6501 * Changed prompt counter behavior to be fully like
6497 Mathematica's. That is, even input that doesn't return a result
6502 Mathematica's. That is, even input that doesn't return a result
6498 raises the prompt counter. The old behavior was kind of confusing
6503 raises the prompt counter. The old behavior was kind of confusing
6499 (getting the same prompt number several times if the operation
6504 (getting the same prompt number several times if the operation
6500 didn't return a result).
6505 didn't return a result).
6501
6506
6502 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
6507 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
6503
6508
6504 * Fixed -Classic mode (wasn't working anymore).
6509 * Fixed -Classic mode (wasn't working anymore).
6505
6510
6506 * Added colored prompts using Nathan's new code. Colors are
6511 * Added colored prompts using Nathan's new code. Colors are
6507 currently hardwired, they can be user-configurable. For
6512 currently hardwired, they can be user-configurable. For
6508 developers, they can be chosen in file ipythonlib.py, at the
6513 developers, they can be chosen in file ipythonlib.py, at the
6509 beginning of the CachedOutput class def.
6514 beginning of the CachedOutput class def.
6510
6515
6511 2001-11-11 Fernando Perez <fperez@colorado.edu>
6516 2001-11-11 Fernando Perez <fperez@colorado.edu>
6512
6517
6513 * Version 0.1.5 released, 0.1.6 opened for further work.
6518 * Version 0.1.5 released, 0.1.6 opened for further work.
6514
6519
6515 * Changed magic_env to *return* the environment as a dict (not to
6520 * Changed magic_env to *return* the environment as a dict (not to
6516 print it). This way it prints, but it can also be processed.
6521 print it). This way it prints, but it can also be processed.
6517
6522
6518 * Added Verbose exception reporting to interactive
6523 * Added Verbose exception reporting to interactive
6519 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
6524 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
6520 traceback. Had to make some changes to the ultraTB file. This is
6525 traceback. Had to make some changes to the ultraTB file. This is
6521 probably the last 'big' thing in my mental todo list. This ties
6526 probably the last 'big' thing in my mental todo list. This ties
6522 in with the next entry:
6527 in with the next entry:
6523
6528
6524 * Changed -Xi and -Xf to a single -xmode option. Now all the user
6529 * Changed -Xi and -Xf to a single -xmode option. Now all the user
6525 has to specify is Plain, Color or Verbose for all exception
6530 has to specify is Plain, Color or Verbose for all exception
6526 handling.
6531 handling.
6527
6532
6528 * Removed ShellServices option. All this can really be done via
6533 * Removed ShellServices option. All this can really be done via
6529 the magic system. It's easier to extend, cleaner and has automatic
6534 the magic system. It's easier to extend, cleaner and has automatic
6530 namespace protection and documentation.
6535 namespace protection and documentation.
6531
6536
6532 2001-11-09 Fernando Perez <fperez@colorado.edu>
6537 2001-11-09 Fernando Perez <fperez@colorado.edu>
6533
6538
6534 * Fixed bug in output cache flushing (missing parameter to
6539 * Fixed bug in output cache flushing (missing parameter to
6535 __init__). Other small bugs fixed (found using pychecker).
6540 __init__). Other small bugs fixed (found using pychecker).
6536
6541
6537 * Version 0.1.4 opened for bugfixing.
6542 * Version 0.1.4 opened for bugfixing.
6538
6543
6539 2001-11-07 Fernando Perez <fperez@colorado.edu>
6544 2001-11-07 Fernando Perez <fperez@colorado.edu>
6540
6545
6541 * Version 0.1.3 released, mainly because of the raw_input bug.
6546 * Version 0.1.3 released, mainly because of the raw_input bug.
6542
6547
6543 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
6548 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
6544 and when testing for whether things were callable, a call could
6549 and when testing for whether things were callable, a call could
6545 actually be made to certain functions. They would get called again
6550 actually be made to certain functions. They would get called again
6546 once 'really' executed, with a resulting double call. A disaster
6551 once 'really' executed, with a resulting double call. A disaster
6547 in many cases (list.reverse() would never work!).
6552 in many cases (list.reverse() would never work!).
6548
6553
6549 * Removed prefilter() function, moved its code to raw_input (which
6554 * Removed prefilter() function, moved its code to raw_input (which
6550 after all was just a near-empty caller for prefilter). This saves
6555 after all was just a near-empty caller for prefilter). This saves
6551 a function call on every prompt, and simplifies the class a tiny bit.
6556 a function call on every prompt, and simplifies the class a tiny bit.
6552
6557
6553 * Fix _ip to __ip name in magic example file.
6558 * Fix _ip to __ip name in magic example file.
6554
6559
6555 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
6560 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
6556 work with non-gnu versions of tar.
6561 work with non-gnu versions of tar.
6557
6562
6558 2001-11-06 Fernando Perez <fperez@colorado.edu>
6563 2001-11-06 Fernando Perez <fperez@colorado.edu>
6559
6564
6560 * Version 0.1.2. Just to keep track of the recent changes.
6565 * Version 0.1.2. Just to keep track of the recent changes.
6561
6566
6562 * Fixed nasty bug in output prompt routine. It used to check 'if
6567 * Fixed nasty bug in output prompt routine. It used to check 'if
6563 arg != None...'. Problem is, this fails if arg implements a
6568 arg != None...'. Problem is, this fails if arg implements a
6564 special comparison (__cmp__) which disallows comparing to
6569 special comparison (__cmp__) which disallows comparing to
6565 None. Found it when trying to use the PhysicalQuantity module from
6570 None. Found it when trying to use the PhysicalQuantity module from
6566 ScientificPython.
6571 ScientificPython.
6567
6572
6568 2001-11-05 Fernando Perez <fperez@colorado.edu>
6573 2001-11-05 Fernando Perez <fperez@colorado.edu>
6569
6574
6570 * Also added dirs. Now the pushd/popd/dirs family functions
6575 * Also added dirs. Now the pushd/popd/dirs family functions
6571 basically like the shell, with the added convenience of going home
6576 basically like the shell, with the added convenience of going home
6572 when called with no args.
6577 when called with no args.
6573
6578
6574 * pushd/popd slightly modified to mimic shell behavior more
6579 * pushd/popd slightly modified to mimic shell behavior more
6575 closely.
6580 closely.
6576
6581
6577 * Added env,pushd,popd from ShellServices as magic functions. I
6582 * Added env,pushd,popd from ShellServices as magic functions. I
6578 think the cleanest will be to port all desired functions from
6583 think the cleanest will be to port all desired functions from
6579 ShellServices as magics and remove ShellServices altogether. This
6584 ShellServices as magics and remove ShellServices altogether. This
6580 will provide a single, clean way of adding functionality
6585 will provide a single, clean way of adding functionality
6581 (shell-type or otherwise) to IP.
6586 (shell-type or otherwise) to IP.
6582
6587
6583 2001-11-04 Fernando Perez <fperez@colorado.edu>
6588 2001-11-04 Fernando Perez <fperez@colorado.edu>
6584
6589
6585 * Added .ipython/ directory to sys.path. This way users can keep
6590 * Added .ipython/ directory to sys.path. This way users can keep
6586 customizations there and access them via import.
6591 customizations there and access them via import.
6587
6592
6588 2001-11-03 Fernando Perez <fperez@colorado.edu>
6593 2001-11-03 Fernando Perez <fperez@colorado.edu>
6589
6594
6590 * Opened version 0.1.1 for new changes.
6595 * Opened version 0.1.1 for new changes.
6591
6596
6592 * Changed version number to 0.1.0: first 'public' release, sent to
6597 * Changed version number to 0.1.0: first 'public' release, sent to
6593 Nathan and Janko.
6598 Nathan and Janko.
6594
6599
6595 * Lots of small fixes and tweaks.
6600 * Lots of small fixes and tweaks.
6596
6601
6597 * Minor changes to whos format. Now strings are shown, snipped if
6602 * Minor changes to whos format. Now strings are shown, snipped if
6598 too long.
6603 too long.
6599
6604
6600 * Changed ShellServices to work on __main__ so they show up in @who
6605 * Changed ShellServices to work on __main__ so they show up in @who
6601
6606
6602 * Help also works with ? at the end of a line:
6607 * Help also works with ? at the end of a line:
6603 ?sin and sin?
6608 ?sin and sin?
6604 both produce the same effect. This is nice, as often I use the
6609 both produce the same effect. This is nice, as often I use the
6605 tab-complete to find the name of a method, but I used to then have
6610 tab-complete to find the name of a method, but I used to then have
6606 to go to the beginning of the line to put a ? if I wanted more
6611 to go to the beginning of the line to put a ? if I wanted more
6607 info. Now I can just add the ? and hit return. Convenient.
6612 info. Now I can just add the ? and hit return. Convenient.
6608
6613
6609 2001-11-02 Fernando Perez <fperez@colorado.edu>
6614 2001-11-02 Fernando Perez <fperez@colorado.edu>
6610
6615
6611 * Python version check (>=2.1) added.
6616 * Python version check (>=2.1) added.
6612
6617
6613 * Added LazyPython documentation. At this point the docs are quite
6618 * Added LazyPython documentation. At this point the docs are quite
6614 a mess. A cleanup is in order.
6619 a mess. A cleanup is in order.
6615
6620
6616 * Auto-installer created. For some bizarre reason, the zipfiles
6621 * Auto-installer created. For some bizarre reason, the zipfiles
6617 module isn't working on my system. So I made a tar version
6622 module isn't working on my system. So I made a tar version
6618 (hopefully the command line options in various systems won't kill
6623 (hopefully the command line options in various systems won't kill
6619 me).
6624 me).
6620
6625
6621 * Fixes to Struct in genutils. Now all dictionary-like methods are
6626 * Fixes to Struct in genutils. Now all dictionary-like methods are
6622 protected (reasonably).
6627 protected (reasonably).
6623
6628
6624 * Added pager function to genutils and changed ? to print usage
6629 * Added pager function to genutils and changed ? to print usage
6625 note through it (it was too long).
6630 note through it (it was too long).
6626
6631
6627 * Added the LazyPython functionality. Works great! I changed the
6632 * Added the LazyPython functionality. Works great! I changed the
6628 auto-quote escape to ';', it's on home row and next to '. But
6633 auto-quote escape to ';', it's on home row and next to '. But
6629 both auto-quote and auto-paren (still /) escapes are command-line
6634 both auto-quote and auto-paren (still /) escapes are command-line
6630 parameters.
6635 parameters.
6631
6636
6632
6637
6633 2001-11-01 Fernando Perez <fperez@colorado.edu>
6638 2001-11-01 Fernando Perez <fperez@colorado.edu>
6634
6639
6635 * Version changed to 0.0.7. Fairly large change: configuration now
6640 * Version changed to 0.0.7. Fairly large change: configuration now
6636 is all stored in a directory, by default .ipython. There, all
6641 is all stored in a directory, by default .ipython. There, all
6637 config files have normal looking names (not .names)
6642 config files have normal looking names (not .names)
6638
6643
6639 * Version 0.0.6 Released first to Lucas and Archie as a test
6644 * Version 0.0.6 Released first to Lucas and Archie as a test
6640 run. Since it's the first 'semi-public' release, change version to
6645 run. Since it's the first 'semi-public' release, change version to
6641 > 0.0.6 for any changes now.
6646 > 0.0.6 for any changes now.
6642
6647
6643 * Stuff I had put in the ipplib.py changelog:
6648 * Stuff I had put in the ipplib.py changelog:
6644
6649
6645 Changes to InteractiveShell:
6650 Changes to InteractiveShell:
6646
6651
6647 - Made the usage message a parameter.
6652 - Made the usage message a parameter.
6648
6653
6649 - Require the name of the shell variable to be given. It's a bit
6654 - Require the name of the shell variable to be given. It's a bit
6650 of a hack, but allows the name 'shell' not to be hardwired in the
6655 of a hack, but allows the name 'shell' not to be hardwired in the
6651 magic (@) handler, which is problematic b/c it requires
6656 magic (@) handler, which is problematic b/c it requires
6652 polluting the global namespace with 'shell'. This in turn is
6657 polluting the global namespace with 'shell'. This in turn is
6653 fragile: if a user redefines a variable called shell, things
6658 fragile: if a user redefines a variable called shell, things
6654 break.
6659 break.
6655
6660
6656 - magic @: all functions available through @ need to be defined
6661 - magic @: all functions available through @ need to be defined
6657 as magic_<name>, even though they can be called simply as
6662 as magic_<name>, even though they can be called simply as
6658 @<name>. This allows the special command @magic to gather
6663 @<name>. This allows the special command @magic to gather
6659 information automatically about all existing magic functions,
6664 information automatically about all existing magic functions,
6660 even if they are run-time user extensions, by parsing the shell
6665 even if they are run-time user extensions, by parsing the shell
6661 instance __dict__ looking for special magic_ names.
6666 instance __dict__ looking for special magic_ names.
6662
6667
6663 - mainloop: added *two* local namespace parameters. This allows
6668 - mainloop: added *two* local namespace parameters. This allows
6664 the class to differentiate between parameters which were there
6669 the class to differentiate between parameters which were there
6665 before and after command line initialization was processed. This
6670 before and after command line initialization was processed. This
6666 way, later @who can show things loaded at startup by the
6671 way, later @who can show things loaded at startup by the
6667 user. This trick was necessary to make session saving/reloading
6672 user. This trick was necessary to make session saving/reloading
6668 really work: ideally after saving/exiting/reloading a session,
6673 really work: ideally after saving/exiting/reloading a session,
6669 *everything* should look the same, including the output of @who. I
6674 *everything* should look the same, including the output of @who. I
6670 was only able to make this work with this double namespace
6675 was only able to make this work with this double namespace
6671 trick.
6676 trick.
6672
6677
6673 - added a header to the logfile which allows (almost) full
6678 - added a header to the logfile which allows (almost) full
6674 session restoring.
6679 session restoring.
6675
6680
6676 - prepend lines beginning with @ or !, with a and log
6681 - prepend lines beginning with @ or !, with a and log
6677 them. Why? !lines: may be useful to know what you did @lines:
6682 them. Why? !lines: may be useful to know what you did @lines:
6678 they may affect session state. So when restoring a session, at
6683 they may affect session state. So when restoring a session, at
6679 least inform the user of their presence. I couldn't quite get
6684 least inform the user of their presence. I couldn't quite get
6680 them to properly re-execute, but at least the user is warned.
6685 them to properly re-execute, but at least the user is warned.
6681
6686
6682 * Started ChangeLog.
6687 * Started ChangeLog.
General Comments 0
You need to be logged in to leave comments. Login now