##// END OF EJS Templates
Added a new table icap, which executes a Python string...
walter.doerwald -
Show More
@@ -1,2175 +1,2250 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, StringIO
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",
138 "icsv", "ix", "ichain", "isort", "ifilter", "ieval", "ienum",
139 "ienv", "ihist", "idump", "iless"
139 "ienv", "ihist", "icap", "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 in ("cell", "header", "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 ihist(Table):
1571 class ihist(Table):
1572 """
1572 """
1573 IPython input history
1573 IPython input history
1574
1574
1575 Example:
1575 Example:
1576
1576
1577 >>> ihist
1577 >>> ihist
1578 >>> ihist(True) (raw mode)
1578 >>> ihist(True) (raw mode)
1579 """
1579 """
1580 def __init__(self, raw=True):
1580 def __init__(self, raw=True):
1581 self.raw = raw
1581 self.raw = raw
1582
1582
1583 def __iter__(self):
1583 def __iter__(self):
1584 api = ipapi.get()
1584 api = ipapi.get()
1585 if self.raw:
1585 if self.raw:
1586 for line in api.IP.input_hist_raw:
1586 for line in api.IP.input_hist_raw:
1587 yield line.rstrip("\n")
1587 yield line.rstrip("\n")
1588 else:
1588 else:
1589 for line in api.IP.input_hist:
1589 for line in api.IP.input_hist:
1590 yield line.rstrip("\n")
1590 yield line.rstrip("\n")
1591
1591
1592
1592
1593 class icsv(Pipe):
1593 class icsv(Pipe):
1594 """
1594 """
1595 This ``Pipe`` lists turn the input (with must be a pipe outputting lines
1595 This ``Pipe`` lists turn the input (with must be a pipe outputting lines
1596 or an ``ifile``) into lines of CVS columns.
1596 or an ``ifile``) into lines of CVS columns.
1597 """
1597 """
1598 def __init__(self, **csvargs):
1598 def __init__(self, **csvargs):
1599 """
1599 """
1600 Create an ``icsv`` object. ``cvsargs`` will be passed through as
1600 Create an ``icsv`` object. ``cvsargs`` will be passed through as
1601 keyword arguments to ``cvs.reader()``.
1601 keyword arguments to ``cvs.reader()``.
1602 """
1602 """
1603 self.csvargs = csvargs
1603 self.csvargs = csvargs
1604
1604
1605 def __iter__(self):
1605 def __iter__(self):
1606 input = self.input
1606 input = self.input
1607 if isinstance(input, ifile):
1607 if isinstance(input, ifile):
1608 input = input.open("rb")
1608 input = input.open("rb")
1609 reader = csv.reader(input, **self.csvargs)
1609 reader = csv.reader(input, **self.csvargs)
1610 for line in reader:
1610 for line in reader:
1611 yield List(line)
1611 yield List(line)
1612
1612
1613 def __xrepr__(self, mode="default"):
1613 def __xrepr__(self, mode="default"):
1614 yield (-1, False)
1614 yield (-1, False)
1615 if mode == "header" or mode == "footer":
1615 if mode == "header" or mode == "footer":
1616 input = getattr(self, "input", None)
1616 input = getattr(self, "input", None)
1617 if input is not None:
1617 if input is not None:
1618 for part in xrepr(input, mode):
1618 for part in xrepr(input, mode):
1619 yield part
1619 yield part
1620 yield (astyle.style_default, " | ")
1620 yield (astyle.style_default, " | ")
1621 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1621 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1622 for (i, (name, value)) in enumerate(self.csvargs.iteritems()):
1622 for (i, (name, value)) in enumerate(self.csvargs.iteritems()):
1623 if i:
1623 if i:
1624 yield (astyle.style_default, ", ")
1624 yield (astyle.style_default, ", ")
1625 yield (astyle.style_default, name)
1625 yield (astyle.style_default, name)
1626 yield (astyle.style_default, "=")
1626 yield (astyle.style_default, "=")
1627 for part in xrepr(value, "default"):
1627 for part in xrepr(value, "default"):
1628 yield part
1628 yield part
1629 yield (astyle.style_default, ")")
1629 yield (astyle.style_default, ")")
1630 else:
1630 else:
1631 yield (astyle.style_default, repr(self))
1631 yield (astyle.style_default, repr(self))
1632
1632
1633 def __repr__(self):
1633 def __repr__(self):
1634 args = ", ".join(["%s=%r" % item for item in self.csvargs.iteritems()])
1634 args = ", ".join(["%s=%r" % item for item in self.csvargs.iteritems()])
1635 return "<%s.%s %s at 0x%x>" % \
1635 return "<%s.%s %s at 0x%x>" % \
1636 (self.__class__.__module__, self.__class__.__name__, args, id(self))
1636 (self.__class__.__module__, self.__class__.__name__, args, id(self))
1637
1637
1638
1638
1639 class ix(Table):
1639 class ix(Table):
1640 """
1640 """
1641 Execute a system command and list its output as lines
1641 Execute a system command and list its output as lines
1642 (similar to ``os.popen()``).
1642 (similar to ``os.popen()``).
1643
1643
1644 Examples:
1644 Examples:
1645
1645
1646 >>> ix("ps x")
1646 >>> ix("ps x")
1647 >>> ix("find .") | ifile
1647 >>> ix("find .") | ifile
1648 """
1648 """
1649 def __init__(self, cmd):
1649 def __init__(self, cmd):
1650 self.cmd = cmd
1650 self.cmd = cmd
1651 self._pipeout = None
1651 self._pipeout = None
1652
1652
1653 def __iter__(self):
1653 def __iter__(self):
1654 (_pipein, self._pipeout) = os.popen4(self.cmd)
1654 (_pipein, self._pipeout) = os.popen4(self.cmd)
1655 _pipein.close()
1655 _pipein.close()
1656 for l in self._pipeout:
1656 for l in self._pipeout:
1657 yield l.rstrip("\r\n")
1657 yield l.rstrip("\r\n")
1658 self._pipeout.close()
1658 self._pipeout.close()
1659 self._pipeout = None
1659 self._pipeout = None
1660
1660
1661 def __del__(self):
1661 def __del__(self):
1662 if self._pipeout is not None and not self._pipeout.closed:
1662 if self._pipeout is not None and not self._pipeout.closed:
1663 self._pipeout.close()
1663 self._pipeout.close()
1664 self._pipeout = None
1664 self._pipeout = None
1665
1665
1666 def __xrepr__(self, mode="default"):
1666 def __xrepr__(self, mode="default"):
1667 if mode == "header" or mode == "footer":
1667 if mode == "header" or mode == "footer":
1668 yield (astyle.style_default,
1668 yield (astyle.style_default,
1669 "%s(%r)" % (self.__class__.__name__, self.cmd))
1669 "%s(%r)" % (self.__class__.__name__, self.cmd))
1670 else:
1670 else:
1671 yield (astyle.style_default, repr(self))
1671 yield (astyle.style_default, repr(self))
1672
1672
1673 def __repr__(self):
1673 def __repr__(self):
1674 return "%s.%s(%r)" % \
1674 return "%s.%s(%r)" % \
1675 (self.__class__.__module__, self.__class__.__name__, self.cmd)
1675 (self.__class__.__module__, self.__class__.__name__, self.cmd)
1676
1676
1677
1677
1678 class ifilter(Pipe):
1678 class ifilter(Pipe):
1679 """
1679 """
1680 Filter an input pipe. Only objects where an expression evaluates to true
1680 Filter an input pipe. Only objects where an expression evaluates to true
1681 (and doesn't raise an exception) are listed.
1681 (and doesn't raise an exception) are listed.
1682
1682
1683 Examples:
1683 Examples:
1684
1684
1685 >>> ils | ifilter("_.isfile() and size>1000")
1685 >>> ils | ifilter("_.isfile() and size>1000")
1686 >>> igrp | ifilter("len(mem)")
1686 >>> igrp | ifilter("len(mem)")
1687 >>> sys.modules | ifilter(lambda _:_.value is not None)
1687 >>> sys.modules | ifilter(lambda _:_.value is not None)
1688 """
1688 """
1689
1689
1690 def __init__(self, expr, globals=None, errors="raiseifallfail"):
1690 def __init__(self, expr, globals=None, errors="raiseifallfail"):
1691 """
1691 """
1692 Create an ``ifilter`` object. ``expr`` can be a callable or a string
1692 Create an ``ifilter`` object. ``expr`` can be a callable or a string
1693 containing an expression. ``globals`` will be used as the global
1693 containing an expression. ``globals`` will be used as the global
1694 namespace for calling string expressions (defaulting to IPython's
1694 namespace for calling string expressions (defaulting to IPython's
1695 user namespace). ``errors`` specifies how exception during evaluation
1695 user namespace). ``errors`` specifies how exception during evaluation
1696 of ``expr`` are handled:
1696 of ``expr`` are handled:
1697
1697
1698 * ``drop``: drop all items that have errors;
1698 * ``drop``: drop all items that have errors;
1699
1699
1700 * ``keep``: keep all items that have errors;
1700 * ``keep``: keep all items that have errors;
1701
1701
1702 * ``keeperror``: keep the exception of all items that have errors;
1702 * ``keeperror``: keep the exception of all items that have errors;
1703
1703
1704 * ``raise``: raise the exception;
1704 * ``raise``: raise the exception;
1705
1705
1706 * ``raiseifallfail``: raise the first exception if all items have errors;
1706 * ``raiseifallfail``: raise the first exception if all items have errors;
1707 otherwise drop those with errors (this is the default).
1707 otherwise drop those with errors (this is the default).
1708 """
1708 """
1709 self.expr = expr
1709 self.expr = expr
1710 self.globals = globals
1710 self.globals = globals
1711 self.errors = errors
1711 self.errors = errors
1712
1712
1713 def __iter__(self):
1713 def __iter__(self):
1714 if callable(self.expr):
1714 if callable(self.expr):
1715 test = self.expr
1715 test = self.expr
1716 else:
1716 else:
1717 g = getglobals(self.globals)
1717 g = getglobals(self.globals)
1718 expr = compile(self.expr, "ipipe-expression", "eval")
1718 expr = compile(self.expr, "ipipe-expression", "eval")
1719 def test(item):
1719 def test(item):
1720 return eval(expr, g, AttrNamespace(item))
1720 return eval(expr, g, AttrNamespace(item))
1721
1721
1722 ok = 0
1722 ok = 0
1723 exc_info = None
1723 exc_info = None
1724 for item in xiter(self.input):
1724 for item in xiter(self.input):
1725 try:
1725 try:
1726 if test(item):
1726 if test(item):
1727 yield item
1727 yield item
1728 ok += 1
1728 ok += 1
1729 except (KeyboardInterrupt, SystemExit):
1729 except (KeyboardInterrupt, SystemExit):
1730 raise
1730 raise
1731 except Exception, exc:
1731 except Exception, exc:
1732 if self.errors == "drop":
1732 if self.errors == "drop":
1733 pass # Ignore errors
1733 pass # Ignore errors
1734 elif self.errors == "keep":
1734 elif self.errors == "keep":
1735 yield item
1735 yield item
1736 elif self.errors == "keeperror":
1736 elif self.errors == "keeperror":
1737 yield exc
1737 yield exc
1738 elif self.errors == "raise":
1738 elif self.errors == "raise":
1739 raise
1739 raise
1740 elif self.errors == "raiseifallfail":
1740 elif self.errors == "raiseifallfail":
1741 if exc_info is None:
1741 if exc_info is None:
1742 exc_info = sys.exc_info()
1742 exc_info = sys.exc_info()
1743 if not ok and exc_info is not None:
1743 if not ok and exc_info is not None:
1744 raise exc_info[0], exc_info[1], exc_info[2]
1744 raise exc_info[0], exc_info[1], exc_info[2]
1745
1745
1746 def __xrepr__(self, mode="default"):
1746 def __xrepr__(self, mode="default"):
1747 if mode == "header" or mode == "footer":
1747 if mode == "header" or mode == "footer":
1748 input = getattr(self, "input", None)
1748 input = getattr(self, "input", None)
1749 if input is not None:
1749 if input is not None:
1750 for part in xrepr(input, mode):
1750 for part in xrepr(input, mode):
1751 yield part
1751 yield part
1752 yield (astyle.style_default, " | ")
1752 yield (astyle.style_default, " | ")
1753 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1753 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1754 for part in xrepr(self.expr, "default"):
1754 for part in xrepr(self.expr, "default"):
1755 yield part
1755 yield part
1756 yield (astyle.style_default, ")")
1756 yield (astyle.style_default, ")")
1757 else:
1757 else:
1758 yield (astyle.style_default, repr(self))
1758 yield (astyle.style_default, repr(self))
1759
1759
1760 def __repr__(self):
1760 def __repr__(self):
1761 return "<%s.%s expr=%r at 0x%x>" % \
1761 return "<%s.%s expr=%r at 0x%x>" % \
1762 (self.__class__.__module__, self.__class__.__name__,
1762 (self.__class__.__module__, self.__class__.__name__,
1763 self.expr, id(self))
1763 self.expr, id(self))
1764
1764
1765
1765
1766 class ieval(Pipe):
1766 class ieval(Pipe):
1767 """
1767 """
1768 Evaluate an expression for each object in the input pipe.
1768 Evaluate an expression for each object in the input pipe.
1769
1769
1770 Examples:
1770 Examples:
1771
1771
1772 >>> ils | ieval("_.abspath()")
1772 >>> ils | ieval("_.abspath()")
1773 >>> sys.path | ieval(ifile)
1773 >>> sys.path | ieval(ifile)
1774 """
1774 """
1775
1775
1776 def __init__(self, expr, globals=None, errors="raiseifallfail"):
1776 def __init__(self, expr, globals=None, errors="raiseifallfail"):
1777 """
1777 """
1778 Create an ``ieval`` object. ``expr`` can be a callable or a string
1778 Create an ``ieval`` object. ``expr`` can be a callable or a string
1779 containing an expression. For the meaning of ``globals`` and
1779 containing an expression. For the meaning of ``globals`` and
1780 ``errors`` see ``ifilter``.
1780 ``errors`` see ``ifilter``.
1781 """
1781 """
1782 self.expr = expr
1782 self.expr = expr
1783 self.globals = globals
1783 self.globals = globals
1784 self.errors = errors
1784 self.errors = errors
1785
1785
1786 def __iter__(self):
1786 def __iter__(self):
1787 if callable(self.expr):
1787 if callable(self.expr):
1788 do = self.expr
1788 do = self.expr
1789 else:
1789 else:
1790 g = getglobals(self.globals)
1790 g = getglobals(self.globals)
1791 expr = compile(self.expr, "ipipe-expression", "eval")
1791 expr = compile(self.expr, "ipipe-expression", "eval")
1792 def do(item):
1792 def do(item):
1793 return eval(expr, g, AttrNamespace(item))
1793 return eval(expr, g, AttrNamespace(item))
1794
1794
1795 ok = 0
1795 ok = 0
1796 exc_info = None
1796 exc_info = None
1797 for item in xiter(self.input):
1797 for item in xiter(self.input):
1798 try:
1798 try:
1799 yield do(item)
1799 yield do(item)
1800 except (KeyboardInterrupt, SystemExit):
1800 except (KeyboardInterrupt, SystemExit):
1801 raise
1801 raise
1802 except Exception, exc:
1802 except Exception, exc:
1803 if self.errors == "drop":
1803 if self.errors == "drop":
1804 pass # Ignore errors
1804 pass # Ignore errors
1805 elif self.errors == "keep":
1805 elif self.errors == "keep":
1806 yield item
1806 yield item
1807 elif self.errors == "keeperror":
1807 elif self.errors == "keeperror":
1808 yield exc
1808 yield exc
1809 elif self.errors == "raise":
1809 elif self.errors == "raise":
1810 raise
1810 raise
1811 elif self.errors == "raiseifallfail":
1811 elif self.errors == "raiseifallfail":
1812 if exc_info is None:
1812 if exc_info is None:
1813 exc_info = sys.exc_info()
1813 exc_info = sys.exc_info()
1814 if not ok and exc_info is not None:
1814 if not ok and exc_info is not None:
1815 raise exc_info[0], exc_info[1], exc_info[2]
1815 raise exc_info[0], exc_info[1], exc_info[2]
1816
1816
1817 def __xrepr__(self, mode="default"):
1817 def __xrepr__(self, mode="default"):
1818 if mode == "header" or mode == "footer":
1818 if mode == "header" or mode == "footer":
1819 input = getattr(self, "input", None)
1819 input = getattr(self, "input", None)
1820 if input is not None:
1820 if input is not None:
1821 for part in xrepr(input, mode):
1821 for part in xrepr(input, mode):
1822 yield part
1822 yield part
1823 yield (astyle.style_default, " | ")
1823 yield (astyle.style_default, " | ")
1824 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1824 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1825 for part in xrepr(self.expr, "default"):
1825 for part in xrepr(self.expr, "default"):
1826 yield part
1826 yield part
1827 yield (astyle.style_default, ")")
1827 yield (astyle.style_default, ")")
1828 else:
1828 else:
1829 yield (astyle.style_default, repr(self))
1829 yield (astyle.style_default, repr(self))
1830
1830
1831 def __repr__(self):
1831 def __repr__(self):
1832 return "<%s.%s expr=%r at 0x%x>" % \
1832 return "<%s.%s expr=%r at 0x%x>" % \
1833 (self.__class__.__module__, self.__class__.__name__,
1833 (self.__class__.__module__, self.__class__.__name__,
1834 self.expr, id(self))
1834 self.expr, id(self))
1835
1835
1836
1836
1837 class ienum(Pipe):
1837 class ienum(Pipe):
1838 """
1838 """
1839 Enumerate the input pipe (i.e. wrap each input object in an object
1839 Enumerate the input pipe (i.e. wrap each input object in an object
1840 with ``index`` and ``object`` attributes).
1840 with ``index`` and ``object`` attributes).
1841
1841
1842 Examples:
1842 Examples:
1843
1843
1844 >>> xrange(20) | ieval("_,_*_") | ienum | ifilter("index % 2 == 0") | ieval("object")
1844 >>> xrange(20) | ieval("_,_*_") | ienum | ifilter("index % 2 == 0") | ieval("object")
1845 """
1845 """
1846 def __iter__(self):
1846 def __iter__(self):
1847 fields = ("index", "object")
1847 fields = ("index", "object")
1848 for (index, object) in enumerate(xiter(self.input)):
1848 for (index, object) in enumerate(xiter(self.input)):
1849 yield Fields(fields, index=index, object=object)
1849 yield Fields(fields, index=index, object=object)
1850
1850
1851
1851
1852 class isort(Pipe):
1852 class isort(Pipe):
1853 """
1853 """
1854 Sorts the input pipe.
1854 Sorts the input pipe.
1855
1855
1856 Examples:
1856 Examples:
1857
1857
1858 >>> ils | isort("size")
1858 >>> ils | isort("size")
1859 >>> ils | isort("_.isdir(), _.lower()", reverse=True)
1859 >>> ils | isort("_.isdir(), _.lower()", reverse=True)
1860 """
1860 """
1861
1861
1862 def __init__(self, key=None, globals=None, reverse=False):
1862 def __init__(self, key=None, globals=None, reverse=False):
1863 """
1863 """
1864 Create an ``isort`` object. ``key`` can be a callable or a string
1864 Create an ``isort`` object. ``key`` can be a callable or a string
1865 containing an expression (or ``None`` in which case the items
1865 containing an expression (or ``None`` in which case the items
1866 themselves will be sorted). If ``reverse`` is true the sort order
1866 themselves will be sorted). If ``reverse`` is true the sort order
1867 will be reversed. For the meaning of ``globals`` see ``ifilter``.
1867 will be reversed. For the meaning of ``globals`` see ``ifilter``.
1868 """
1868 """
1869 self.key = key
1869 self.key = key
1870 self.globals = globals
1870 self.globals = globals
1871 self.reverse = reverse
1871 self.reverse = reverse
1872
1872
1873 def __iter__(self):
1873 def __iter__(self):
1874 if self.key is None:
1874 if self.key is None:
1875 items = sorted(xiter(self.input), reverse=self.reverse)
1875 items = sorted(xiter(self.input), reverse=self.reverse)
1876 elif callable(self.key):
1876 elif callable(self.key):
1877 items = sorted(xiter(self.input), key=self.key, reverse=self.reverse)
1877 items = sorted(xiter(self.input), key=self.key, reverse=self.reverse)
1878 else:
1878 else:
1879 g = getglobals(self.globals)
1879 g = getglobals(self.globals)
1880 key = compile(self.key, "ipipe-expression", "eval")
1880 key = compile(self.key, "ipipe-expression", "eval")
1881 def realkey(item):
1881 def realkey(item):
1882 return eval(key, g, AttrNamespace(item))
1882 return eval(key, g, AttrNamespace(item))
1883 items = sorted(xiter(self.input), key=realkey, reverse=self.reverse)
1883 items = sorted(xiter(self.input), key=realkey, reverse=self.reverse)
1884 for item in items:
1884 for item in items:
1885 yield item
1885 yield item
1886
1886
1887 def __xrepr__(self, mode="default"):
1887 def __xrepr__(self, mode="default"):
1888 if mode == "header" or mode == "footer":
1888 if mode == "header" or mode == "footer":
1889 input = getattr(self, "input", None)
1889 input = getattr(self, "input", None)
1890 if input is not None:
1890 if input is not None:
1891 for part in xrepr(input, mode):
1891 for part in xrepr(input, mode):
1892 yield part
1892 yield part
1893 yield (astyle.style_default, " | ")
1893 yield (astyle.style_default, " | ")
1894 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1894 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1895 for part in xrepr(self.key, "default"):
1895 for part in xrepr(self.key, "default"):
1896 yield part
1896 yield part
1897 if self.reverse:
1897 if self.reverse:
1898 yield (astyle.style_default, ", ")
1898 yield (astyle.style_default, ", ")
1899 for part in xrepr(True, "default"):
1899 for part in xrepr(True, "default"):
1900 yield part
1900 yield part
1901 yield (astyle.style_default, ")")
1901 yield (astyle.style_default, ")")
1902 else:
1902 else:
1903 yield (astyle.style_default, repr(self))
1903 yield (astyle.style_default, repr(self))
1904
1904
1905 def __repr__(self):
1905 def __repr__(self):
1906 return "<%s.%s key=%r reverse=%r at 0x%x>" % \
1906 return "<%s.%s key=%r reverse=%r at 0x%x>" % \
1907 (self.__class__.__module__, self.__class__.__name__,
1907 (self.__class__.__module__, self.__class__.__name__,
1908 self.key, self.reverse, id(self))
1908 self.key, self.reverse, id(self))
1909
1909
1910
1910
1911 tab = 3 # for expandtabs()
1911 tab = 3 # for expandtabs()
1912
1912
1913 def _format(field):
1913 def _format(field):
1914 if isinstance(field, str):
1914 if isinstance(field, str):
1915 text = repr(field.expandtabs(tab))[1:-1]
1915 text = repr(field.expandtabs(tab))[1:-1]
1916 elif isinstance(field, unicode):
1916 elif isinstance(field, unicode):
1917 text = repr(field.expandtabs(tab))[2:-1]
1917 text = repr(field.expandtabs(tab))[2:-1]
1918 elif isinstance(field, datetime.datetime):
1918 elif isinstance(field, datetime.datetime):
1919 # Don't use strftime() here, as this requires year >= 1900
1919 # Don't use strftime() here, as this requires year >= 1900
1920 text = "%04d-%02d-%02d %02d:%02d:%02d.%06d" % \
1920 text = "%04d-%02d-%02d %02d:%02d:%02d.%06d" % \
1921 (field.year, field.month, field.day,
1921 (field.year, field.month, field.day,
1922 field.hour, field.minute, field.second, field.microsecond)
1922 field.hour, field.minute, field.second, field.microsecond)
1923 elif isinstance(field, datetime.date):
1923 elif isinstance(field, datetime.date):
1924 text = "%04d-%02d-%02d" % (field.year, field.month, field.day)
1924 text = "%04d-%02d-%02d" % (field.year, field.month, field.day)
1925 else:
1925 else:
1926 text = repr(field)
1926 text = repr(field)
1927 return text
1927 return text
1928
1928
1929
1929
1930 class Display(object):
1930 class Display(object):
1931 class __metaclass__(type):
1931 class __metaclass__(type):
1932 def __ror__(self, input):
1932 def __ror__(self, input):
1933 return input | self()
1933 return input | self()
1934
1934
1935 def __ror__(self, input):
1935 def __ror__(self, input):
1936 self.input = input
1936 self.input = input
1937 return self
1937 return self
1938
1938
1939 def display(self):
1939 def display(self):
1940 pass
1940 pass
1941
1941
1942
1942
1943 class iless(Display):
1943 class iless(Display):
1944 cmd = "less --quit-if-one-screen --LONG-PROMPT --LINE-NUMBERS --chop-long-lines --shift=8 --RAW-CONTROL-CHARS"
1944 cmd = "less --quit-if-one-screen --LONG-PROMPT --LINE-NUMBERS --chop-long-lines --shift=8 --RAW-CONTROL-CHARS"
1945
1945
1946 def display(self):
1946 def display(self):
1947 try:
1947 try:
1948 pager = os.popen(self.cmd, "w")
1948 pager = os.popen(self.cmd, "w")
1949 try:
1949 try:
1950 for item in xiter(self.input):
1950 for item in xiter(self.input):
1951 first = False
1951 first = False
1952 for attr in xattrs(item, "default"):
1952 for attr in xattrs(item, "default"):
1953 if first:
1953 if first:
1954 first = False
1954 first = False
1955 else:
1955 else:
1956 pager.write(" ")
1956 pager.write(" ")
1957 attr = upgradexattr(attr)
1957 attr = upgradexattr(attr)
1958 if not isinstance(attr, SelfDescriptor):
1958 if not isinstance(attr, SelfDescriptor):
1959 pager.write(attr.name())
1959 pager.write(attr.name())
1960 pager.write("=")
1960 pager.write("=")
1961 pager.write(str(attr.value(item)))
1961 pager.write(str(attr.value(item)))
1962 pager.write("\n")
1962 pager.write("\n")
1963 finally:
1963 finally:
1964 pager.close()
1964 pager.close()
1965 except Exception, exc:
1965 except Exception, exc:
1966 print "%s: %s" % (exc.__class__.__name__, str(exc))
1966 print "%s: %s" % (exc.__class__.__name__, str(exc))
1967
1967
1968
1968
1969 class _RedirectIO(object):
1970 def __init__(self,*args,**kwargs):
1971 """
1972 Map the system output streams to self.
1973 """
1974 self.stream = StringIO.StringIO()
1975 self.stdout = sys.stdout
1976 sys.stdout = self
1977 self.stderr = sys.stderr
1978 sys.stderr = self
1979
1980 def write(self, text):
1981 """
1982 Write both to screen and to self.
1983 """
1984 self.stream.write(text)
1985 self.stdout.write(text)
1986 if "\n" in text:
1987 self.stdout.flush()
1988
1989 def writelines(self, lines):
1990 """
1991 Write lines both to screen and to self.
1992 """
1993 self.stream.writelines(lines)
1994 self.stdout.writelines(lines)
1995 self.stdout.flush()
1996
1997 def restore(self):
1998 """
1999 Restore the default system streams.
2000 """
2001 self.stdout.flush()
2002 self.stderr.flush()
2003 sys.stdout = self.stdout
2004 sys.stderr = self.stderr
2005
2006
2007 class icap(Table):
2008 """
2009 Execute a python string and capture any output to stderr/stdout.
2010
2011 Examples:
2012
2013 >>> import time
2014 >>> icap("for i in range(10): print i, time.sleep(0.1)")
2015
2016 """
2017 def __init__(self, expr, globals=None):
2018 self.expr = expr
2019 self.globals = globals
2020 log = _RedirectIO()
2021 try:
2022 exec(expr, getglobals(globals))
2023 finally:
2024 log.restore()
2025 self.stream = log.stream
2026
2027 def __iter__(self):
2028 self.stream.seek(0)
2029 for line in self.stream:
2030 yield line.rstrip("\r\n")
2031
2032 def __xrepr__(self, mode="default"):
2033 if mode == "header" or mode == "footer":
2034 yield (astyle.style_default,
2035 "%s(%r)" % (self.__class__.__name__, self.expr))
2036 else:
2037 yield (astyle.style_default, repr(self))
2038
2039 def __repr__(self):
2040 return "%s.%s(%r)" % \
2041 (self.__class__.__module__, self.__class__.__name__, self.expr)
2042
2043
1969 def xformat(value, mode, maxlength):
2044 def xformat(value, mode, maxlength):
1970 align = None
2045 align = None
1971 full = True
2046 full = True
1972 width = 0
2047 width = 0
1973 text = astyle.Text()
2048 text = astyle.Text()
1974 for (style, part) in xrepr(value, mode):
2049 for (style, part) in xrepr(value, mode):
1975 # only consider the first result
2050 # only consider the first result
1976 if align is None:
2051 if align is None:
1977 if isinstance(style, int):
2052 if isinstance(style, int):
1978 # (style, text) really is (alignment, stop)
2053 # (style, text) really is (alignment, stop)
1979 align = style
2054 align = style
1980 full = part
2055 full = part
1981 continue
2056 continue
1982 else:
2057 else:
1983 align = -1
2058 align = -1
1984 full = True
2059 full = True
1985 if not isinstance(style, int):
2060 if not isinstance(style, int):
1986 text.append((style, part))
2061 text.append((style, part))
1987 width += len(part)
2062 width += len(part)
1988 if width >= maxlength and not full:
2063 if width >= maxlength and not full:
1989 text.append((astyle.style_ellisis, "..."))
2064 text.append((astyle.style_ellisis, "..."))
1990 width += 3
2065 width += 3
1991 break
2066 break
1992 if align is None: # default to left alignment
2067 if align is None: # default to left alignment
1993 align = -1
2068 align = -1
1994 return (align, width, text)
2069 return (align, width, text)
1995
2070
1996
2071
1997 class idump(Display):
2072 class idump(Display):
1998 # The approximate maximum length of a column entry
2073 # The approximate maximum length of a column entry
1999 maxattrlength = 200
2074 maxattrlength = 200
2000
2075
2001 # Style for column names
2076 # Style for column names
2002 style_header = astyle.Style.fromstr("white:black:bold")
2077 style_header = astyle.Style.fromstr("white:black:bold")
2003
2078
2004 def __init__(self, *attrs):
2079 def __init__(self, *attrs):
2005 self.attrs = [upgradexattr(attr) for attr in attrs]
2080 self.attrs = [upgradexattr(attr) for attr in attrs]
2006 self.headerpadchar = " "
2081 self.headerpadchar = " "
2007 self.headersepchar = "|"
2082 self.headersepchar = "|"
2008 self.datapadchar = " "
2083 self.datapadchar = " "
2009 self.datasepchar = "|"
2084 self.datasepchar = "|"
2010
2085
2011 def display(self):
2086 def display(self):
2012 stream = genutils.Term.cout
2087 stream = genutils.Term.cout
2013 allattrs = []
2088 allattrs = []
2014 attrset = set()
2089 attrset = set()
2015 colwidths = {}
2090 colwidths = {}
2016 rows = []
2091 rows = []
2017 for item in xiter(self.input):
2092 for item in xiter(self.input):
2018 row = {}
2093 row = {}
2019 attrs = self.attrs
2094 attrs = self.attrs
2020 if not attrs:
2095 if not attrs:
2021 attrs = xattrs(item, "default")
2096 attrs = xattrs(item, "default")
2022 for attr in attrs:
2097 for attr in attrs:
2023 if attr not in attrset:
2098 if attr not in attrset:
2024 allattrs.append(attr)
2099 allattrs.append(attr)
2025 attrset.add(attr)
2100 attrset.add(attr)
2026 colwidths[attr] = len(attr.name())
2101 colwidths[attr] = len(attr.name())
2027 try:
2102 try:
2028 value = attr.value(item)
2103 value = attr.value(item)
2029 except (KeyboardInterrupt, SystemExit):
2104 except (KeyboardInterrupt, SystemExit):
2030 raise
2105 raise
2031 except Exception, exc:
2106 except Exception, exc:
2032 value = exc
2107 value = exc
2033 (align, width, text) = xformat(value, "cell", self.maxattrlength)
2108 (align, width, text) = xformat(value, "cell", self.maxattrlength)
2034 colwidths[attr] = max(colwidths[attr], width)
2109 colwidths[attr] = max(colwidths[attr], width)
2035 # remember alignment, length and colored parts
2110 # remember alignment, length and colored parts
2036 row[attr] = (align, width, text)
2111 row[attr] = (align, width, text)
2037 rows.append(row)
2112 rows.append(row)
2038
2113
2039 stream.write("\n")
2114 stream.write("\n")
2040 for (i, attr) in enumerate(allattrs):
2115 for (i, attr) in enumerate(allattrs):
2041 attrname = attr.name()
2116 attrname = attr.name()
2042 self.style_header(attrname).write(stream)
2117 self.style_header(attrname).write(stream)
2043 spc = colwidths[attr] - len(attrname)
2118 spc = colwidths[attr] - len(attrname)
2044 if i < len(colwidths)-1:
2119 if i < len(colwidths)-1:
2045 stream.write(self.headerpadchar*spc)
2120 stream.write(self.headerpadchar*spc)
2046 stream.write(self.headersepchar)
2121 stream.write(self.headersepchar)
2047 stream.write("\n")
2122 stream.write("\n")
2048
2123
2049 for row in rows:
2124 for row in rows:
2050 for (i, attr) in enumerate(allattrs):
2125 for (i, attr) in enumerate(allattrs):
2051 (align, width, text) = row[attr]
2126 (align, width, text) = row[attr]
2052 spc = colwidths[attr] - width
2127 spc = colwidths[attr] - width
2053 if align == -1:
2128 if align == -1:
2054 text.write(stream)
2129 text.write(stream)
2055 if i < len(colwidths)-1:
2130 if i < len(colwidths)-1:
2056 stream.write(self.datapadchar*spc)
2131 stream.write(self.datapadchar*spc)
2057 elif align == 0:
2132 elif align == 0:
2058 spc = colwidths[attr] - width
2133 spc = colwidths[attr] - width
2059 spc1 = spc//2
2134 spc1 = spc//2
2060 spc2 = spc-spc1
2135 spc2 = spc-spc1
2061 stream.write(self.datapadchar*spc1)
2136 stream.write(self.datapadchar*spc1)
2062 text.write(stream)
2137 text.write(stream)
2063 if i < len(colwidths)-1:
2138 if i < len(colwidths)-1:
2064 stream.write(self.datapadchar*spc2)
2139 stream.write(self.datapadchar*spc2)
2065 else:
2140 else:
2066 stream.write(self.datapadchar*spc)
2141 stream.write(self.datapadchar*spc)
2067 text.write(stream)
2142 text.write(stream)
2068 if i < len(colwidths)-1:
2143 if i < len(colwidths)-1:
2069 stream.write(self.datasepchar)
2144 stream.write(self.datasepchar)
2070 stream.write("\n")
2145 stream.write("\n")
2071
2146
2072
2147
2073 class AttributeDetail(Table):
2148 class AttributeDetail(Table):
2074 """
2149 """
2075 ``AttributeDetail`` objects are use for displaying a detailed list of object
2150 ``AttributeDetail`` objects are use for displaying a detailed list of object
2076 attributes.
2151 attributes.
2077 """
2152 """
2078 def __init__(self, object, descriptor):
2153 def __init__(self, object, descriptor):
2079 self.object = object
2154 self.object = object
2080 self.descriptor = descriptor
2155 self.descriptor = descriptor
2081
2156
2082 def __iter__(self):
2157 def __iter__(self):
2083 return self.descriptor.iter(self.object)
2158 return self.descriptor.iter(self.object)
2084
2159
2085 def name(self):
2160 def name(self):
2086 return self.descriptor.name()
2161 return self.descriptor.name()
2087
2162
2088 def attrtype(self):
2163 def attrtype(self):
2089 return self.descriptor.attrtype(self.object)
2164 return self.descriptor.attrtype(self.object)
2090
2165
2091 def valuetype(self):
2166 def valuetype(self):
2092 return self.descriptor.valuetype(self.object)
2167 return self.descriptor.valuetype(self.object)
2093
2168
2094 def doc(self):
2169 def doc(self):
2095 return self.descriptor.doc(self.object)
2170 return self.descriptor.doc(self.object)
2096
2171
2097 def shortdoc(self):
2172 def shortdoc(self):
2098 return self.descriptor.shortdoc(self.object)
2173 return self.descriptor.shortdoc(self.object)
2099
2174
2100 def value(self):
2175 def value(self):
2101 return self.descriptor.value(self.object)
2176 return self.descriptor.value(self.object)
2102
2177
2103 def __xattrs__(self, mode="default"):
2178 def __xattrs__(self, mode="default"):
2104 attrs = ("name()", "attrtype()", "valuetype()", "value()", "shortdoc()")
2179 attrs = ("name()", "attrtype()", "valuetype()", "value()", "shortdoc()")
2105 if mode == "detail":
2180 if mode == "detail":
2106 attrs += ("doc()",)
2181 attrs += ("doc()",)
2107 return attrs
2182 return attrs
2108
2183
2109 def __xrepr__(self, mode="default"):
2184 def __xrepr__(self, mode="default"):
2110 yield (-1, True)
2185 yield (-1, True)
2111 valuetype = self.valuetype()
2186 valuetype = self.valuetype()
2112 if valuetype is not noitem:
2187 if valuetype is not noitem:
2113 for part in xrepr(valuetype):
2188 for part in xrepr(valuetype):
2114 yield part
2189 yield part
2115 yield (astyle.style_default, " ")
2190 yield (astyle.style_default, " ")
2116 yield (astyle.style_default, self.attrtype())
2191 yield (astyle.style_default, self.attrtype())
2117 yield (astyle.style_default, " ")
2192 yield (astyle.style_default, " ")
2118 yield (astyle.style_default, self.name())
2193 yield (astyle.style_default, self.name())
2119 yield (astyle.style_default, " of ")
2194 yield (astyle.style_default, " of ")
2120 for part in xrepr(self.object):
2195 for part in xrepr(self.object):
2121 yield part
2196 yield part
2122
2197
2123
2198
2124 try:
2199 try:
2125 from ibrowse import ibrowse
2200 from ibrowse import ibrowse
2126 except ImportError:
2201 except ImportError:
2127 # No curses (probably Windows)
2202 # No curses (probably Windows)
2128 try:
2203 try:
2129 from igrid import igrid
2204 from igrid import igrid
2130 except ImportError:
2205 except ImportError:
2131 # no wx eithevn do => use ``idump`` as the default display.
2206 # no wx eithevn do => use ``idump`` as the default display.
2132 defaultdisplay = idump
2207 defaultdisplay = idump
2133 else:
2208 else:
2134 defaultdisplay = igrid
2209 defaultdisplay = igrid
2135 __all__.append("igrid")
2210 __all__.append("igrid")
2136 else:
2211 else:
2137 defaultdisplay = ibrowse
2212 defaultdisplay = ibrowse
2138 __all__.append("ibrowse")
2213 __all__.append("ibrowse")
2139
2214
2140
2215
2141 # If we're running under IPython, install an IPython displayhook that
2216 # If we're running under IPython, install an IPython displayhook that
2142 # returns the object from Display.display(), else install a displayhook
2217 # returns the object from Display.display(), else install a displayhook
2143 # directly as sys.displayhook
2218 # directly as sys.displayhook
2144 api = None
2219 api = None
2145 if ipapi is not None:
2220 if ipapi is not None:
2146 try:
2221 try:
2147 api = ipapi.get()
2222 api = ipapi.get()
2148 except AttributeError:
2223 except AttributeError:
2149 pass
2224 pass
2150
2225
2151 if api is not None:
2226 if api is not None:
2152 def displayhook(self, obj):
2227 def displayhook(self, obj):
2153 if isinstance(obj, type) and issubclass(obj, Table):
2228 if isinstance(obj, type) and issubclass(obj, Table):
2154 obj = obj()
2229 obj = obj()
2155 if isinstance(obj, Table):
2230 if isinstance(obj, Table):
2156 obj = obj | defaultdisplay
2231 obj = obj | defaultdisplay
2157 if isinstance(obj, Display):
2232 if isinstance(obj, Display):
2158 return obj.display()
2233 return obj.display()
2159 else:
2234 else:
2160 raise ipapi.TryNext
2235 raise ipapi.TryNext
2161 api.set_hook("result_display", displayhook)
2236 api.set_hook("result_display", displayhook)
2162 else:
2237 else:
2163 def installdisplayhook():
2238 def installdisplayhook():
2164 _originalhook = sys.displayhook
2239 _originalhook = sys.displayhook
2165 def displayhook(obj):
2240 def displayhook(obj):
2166 if isinstance(obj, type) and issubclass(obj, Table):
2241 if isinstance(obj, type) and issubclass(obj, Table):
2167 obj = obj()
2242 obj = obj()
2168 if isinstance(obj, Table):
2243 if isinstance(obj, Table):
2169 obj = obj | defaultdisplay
2244 obj = obj | defaultdisplay
2170 if isinstance(obj, Display):
2245 if isinstance(obj, Display):
2171 return obj.display()
2246 return obj.display()
2172 else:
2247 else:
2173 _originalhook(obj)
2248 _originalhook(obj)
2174 sys.displayhook = displayhook
2249 sys.displayhook = displayhook
2175 installdisplayhook()
2250 installdisplayhook()
@@ -1,6791 +1,6797 b''
1 2007-06-05 Walter Doerwald <walter@livinglogic.de>
2
3 * IPython/Extensions/ipipe.py: Added a new table icap, which executes a
4 Python string and captures the output. (Idea and original patch by
5 St�fan van der Walt)
6
1 2007-06-01 Fernando Perez <Fernando.Perez@colorado.edu>
7 2007-06-01 Fernando Perez <Fernando.Perez@colorado.edu>
2
8
3 * IPython/ultraTB.py (VerboseTB.text): update printing of
9 * IPython/ultraTB.py (VerboseTB.text): update printing of
4 exception types for Python 2.5 (now all exceptions in the stdlib
10 exception types for Python 2.5 (now all exceptions in the stdlib
5 are new-style classes).
11 are new-style classes).
6
12
7 2007-05-31 Walter Doerwald <walter@livinglogic.de>
13 2007-05-31 Walter Doerwald <walter@livinglogic.de>
8
14
9 * IPython/Extensions/igrid.py: Add new commands refresh and
15 * IPython/Extensions/igrid.py: Add new commands refresh and
10 refresh_timer (mapped to "R"/"F5" and to the menu) which restarts
16 refresh_timer (mapped to "R"/"F5" and to the menu) which restarts
11 the iterator once (refresh) or after every x seconds (refresh_timer).
17 the iterator once (refresh) or after every x seconds (refresh_timer).
12 Add a working implementation of "searchexpression", where the text
18 Add a working implementation of "searchexpression", where the text
13 entered is not the text to search for, but an expression that must
19 entered is not the text to search for, but an expression that must
14 be true. Added display of shortcuts to the menu. Added commands "pickinput"
20 be true. Added display of shortcuts to the menu. Added commands "pickinput"
15 and "pickinputattr" that put the object or attribute under the cursor
21 and "pickinputattr" that put the object or attribute under the cursor
16 in the input line. Split the statusbar to be able to display the currently
22 in the input line. Split the statusbar to be able to display the currently
17 active refresh interval. (Patch by Nik Tautenhahn)
23 active refresh interval. (Patch by Nik Tautenhahn)
18
24
19 2007-05-29 J�rgen Stenarson <jorgen.stenarson@bostream.nu>
25 2007-05-29 J�rgen Stenarson <jorgen.stenarson@bostream.nu>
20
26
21 * fixing set_term_title to use ctypes as default
27 * fixing set_term_title to use ctypes as default
22
28
23 * fixing set_term_title fallback to work when curent dir
29 * fixing set_term_title fallback to work when curent dir
24 is on a windows network share
30 is on a windows network share
25
31
26 2007-05-28 Ville Vainio <vivainio@gmail.com>
32 2007-05-28 Ville Vainio <vivainio@gmail.com>
27
33
28 * %cpaste: strip + with > from left (diffs).
34 * %cpaste: strip + with > from left (diffs).
29
35
30 * iplib.py: Fix crash when readline not installed
36 * iplib.py: Fix crash when readline not installed
31
37
32 2007-05-26 Ville Vainio <vivainio@gmail.com>
38 2007-05-26 Ville Vainio <vivainio@gmail.com>
33
39
34 * generics.py: intruduce easy to extend result_display generic
40 * generics.py: intruduce easy to extend result_display generic
35 function (using simplegeneric.py).
41 function (using simplegeneric.py).
36
42
37 * Fixed the append functionality of %set.
43 * Fixed the append functionality of %set.
38
44
39 2007-05-25 Ville Vainio <vivainio@gmail.com>
45 2007-05-25 Ville Vainio <vivainio@gmail.com>
40
46
41 * New magic: %rep (fetch / run old commands from history)
47 * New magic: %rep (fetch / run old commands from history)
42
48
43 * New extension: mglob (%mglob magic), for powerful glob / find /filter
49 * New extension: mglob (%mglob magic), for powerful glob / find /filter
44 like functionality
50 like functionality
45
51
46 % maghistory.py: %hist -g PATTERM greps the history for pattern
52 % maghistory.py: %hist -g PATTERM greps the history for pattern
47
53
48 2007-05-24 Walter Doerwald <walter@livinglogic.de>
54 2007-05-24 Walter Doerwald <walter@livinglogic.de>
49
55
50 * IPython/Extensions/ipipe.py: Added a Table ihist that can be used to
56 * IPython/Extensions/ipipe.py: Added a Table ihist that can be used to
51 browse the IPython input history
57 browse the IPython input history
52
58
53 * IPython/Extensions/ibrowse.py: Added two command to ibrowse: pickinput
59 * IPython/Extensions/ibrowse.py: Added two command to ibrowse: pickinput
54 (mapped to "i") can be used to put the object under the curser in the input
60 (mapped to "i") can be used to put the object under the curser in the input
55 line. pickinputattr (mapped to "I") does the same for the attribute under
61 line. pickinputattr (mapped to "I") does the same for the attribute under
56 the cursor.
62 the cursor.
57
63
58 2007-05-24 Ville Vainio <vivainio@gmail.com>
64 2007-05-24 Ville Vainio <vivainio@gmail.com>
59
65
60 * Grand magic cleansing (changeset [2380]):
66 * Grand magic cleansing (changeset [2380]):
61
67
62 * Introduce ipy_legacy.py where the following magics were
68 * Introduce ipy_legacy.py where the following magics were
63 moved:
69 moved:
64
70
65 pdef pdoc psource pfile rehash dhist Quit p r automagic autocall
71 pdef pdoc psource pfile rehash dhist Quit p r automagic autocall
66
72
67 If you need them, either use default profile or "import ipy_legacy"
73 If you need them, either use default profile or "import ipy_legacy"
68 in your ipy_user_conf.py
74 in your ipy_user_conf.py
69
75
70 * Move sh and scipy profile to Extensions from UserConfig. this implies
76 * Move sh and scipy profile to Extensions from UserConfig. this implies
71 you should not edit them, but you don't need to run %upgrade when
77 you should not edit them, but you don't need to run %upgrade when
72 upgrading IPython anymore.
78 upgrading IPython anymore.
73
79
74 * %hist/%history now operates in "raw" mode by default. To get the old
80 * %hist/%history now operates in "raw" mode by default. To get the old
75 behaviour, run '%hist -n' (native mode).
81 behaviour, run '%hist -n' (native mode).
76
82
77 * split ipy_stock_completers.py to ipy_stock_completers.py and
83 * split ipy_stock_completers.py to ipy_stock_completers.py and
78 ipy_app_completers.py. Stock completers (%cd, import, %run) are now
84 ipy_app_completers.py. Stock completers (%cd, import, %run) are now
79 installed as default.
85 installed as default.
80
86
81 * sh profile now installs ipy_signals.py, for (hopefully) better ctrl+c
87 * sh profile now installs ipy_signals.py, for (hopefully) better ctrl+c
82 handling.
88 handling.
83
89
84 * iplib.py, ipapi.py: _ip.set_next_input(s) sets the next ("default")
90 * iplib.py, ipapi.py: _ip.set_next_input(s) sets the next ("default")
85 input if readline is available.
91 input if readline is available.
86
92
87 2007-05-23 Ville Vainio <vivainio@gmail.com>
93 2007-05-23 Ville Vainio <vivainio@gmail.com>
88
94
89 * macro.py: %store uses __getstate__ properly
95 * macro.py: %store uses __getstate__ properly
90
96
91 * exesetup.py: added new setup script for creating
97 * exesetup.py: added new setup script for creating
92 standalone IPython executables with py2exe (i.e.
98 standalone IPython executables with py2exe (i.e.
93 no python installation required).
99 no python installation required).
94
100
95 * Removed ipythonrc-scipy, ipy_profile_scipy.py takes
101 * Removed ipythonrc-scipy, ipy_profile_scipy.py takes
96 its place.
102 its place.
97
103
98 * rlineimpl.py, genutils.py (get_home_dir): py2exe support
104 * rlineimpl.py, genutils.py (get_home_dir): py2exe support
99
105
100 2007-05-21 Ville Vainio <vivainio@gmail.com>
106 2007-05-21 Ville Vainio <vivainio@gmail.com>
101
107
102 * platutil_win32.py (set_term_title): handle
108 * platutil_win32.py (set_term_title): handle
103 failure of 'title' system call properly.
109 failure of 'title' system call properly.
104
110
105 2007-05-17 Walter Doerwald <walter@livinglogic.de>
111 2007-05-17 Walter Doerwald <walter@livinglogic.de>
106
112
107 * IPython/Extensions/ipipe.py: Fix xrepr for ifiles.
113 * IPython/Extensions/ipipe.py: Fix xrepr for ifiles.
108 (Bug detected by Paul Mueller).
114 (Bug detected by Paul Mueller).
109
115
110 2007-05-16 Ville Vainio <vivainio@gmail.com>
116 2007-05-16 Ville Vainio <vivainio@gmail.com>
111
117
112 * ipy_profile_sci.py, ipython_win_post_install.py: Create
118 * ipy_profile_sci.py, ipython_win_post_install.py: Create
113 new "sci" profile, effectively a modern version of the old
119 new "sci" profile, effectively a modern version of the old
114 "scipy" profile (which is now slated for deprecation).
120 "scipy" profile (which is now slated for deprecation).
115
121
116 2007-05-15 Ville Vainio <vivainio@gmail.com>
122 2007-05-15 Ville Vainio <vivainio@gmail.com>
117
123
118 * pycolorize.py, pycolor.1: Paul Mueller's patches that
124 * pycolorize.py, pycolor.1: Paul Mueller's patches that
119 make pycolorize read input from stdin when run without arguments.
125 make pycolorize read input from stdin when run without arguments.
120
126
121 * Magic.py: do not require 'PATH' in %rehash/%rehashx. Closes #155
127 * Magic.py: do not require 'PATH' in %rehash/%rehashx. Closes #155
122
128
123 * ipy_rehashdir.py: rename ext_rehashdir to ipy_rehashdir, import
129 * ipy_rehashdir.py: rename ext_rehashdir to ipy_rehashdir, import
124 it in sh profile (instead of ipy_system_conf.py).
130 it in sh profile (instead of ipy_system_conf.py).
125
131
126 * Magic.py, ipy_rehashdir.py, ipy_profile_sh.py: System command
132 * Magic.py, ipy_rehashdir.py, ipy_profile_sh.py: System command
127 aliases are now lower case on windows (MyCommand.exe => mycommand).
133 aliases are now lower case on windows (MyCommand.exe => mycommand).
128
134
129 * macro.py, ipapi.py, iplib.py, Prompts.py: Macro system rehaul.
135 * macro.py, ipapi.py, iplib.py, Prompts.py: Macro system rehaul.
130 Macros are now callable objects that inherit from ipapi.IPyAutocall,
136 Macros are now callable objects that inherit from ipapi.IPyAutocall,
131 i.e. get autocalled regardless of system autocall setting.
137 i.e. get autocalled regardless of system autocall setting.
132
138
133 2007-05-10 Fernando Perez <Fernando.Perez@colorado.edu>
139 2007-05-10 Fernando Perez <Fernando.Perez@colorado.edu>
134
140
135 * IPython/rlineimpl.py: check for clear_history in readline and
141 * IPython/rlineimpl.py: check for clear_history in readline and
136 make it a dummy no-op if not available. This function isn't
142 make it a dummy no-op if not available. This function isn't
137 guaranteed to be in the API and appeared in Python 2.4, so we need
143 guaranteed to be in the API and appeared in Python 2.4, so we need
138 to check it ourselves. Also, clean up this file quite a bit.
144 to check it ourselves. Also, clean up this file quite a bit.
139
145
140 * ipython.1: update man page and full manual with information
146 * ipython.1: update man page and full manual with information
141 about threads (remove outdated warning). Closes #151.
147 about threads (remove outdated warning). Closes #151.
142
148
143 2007-05-09 Fernando Perez <Fernando.Perez@colorado.edu>
149 2007-05-09 Fernando Perez <Fernando.Perez@colorado.edu>
144
150
145 * IPython/Extensions/ipy_constants.py: Add Gael's constants module
151 * IPython/Extensions/ipy_constants.py: Add Gael's constants module
146 in trunk (note that this made it into the 0.8.1 release already,
152 in trunk (note that this made it into the 0.8.1 release already,
147 but the changelogs didn't get coordinated). Many thanks to Gael
153 but the changelogs didn't get coordinated). Many thanks to Gael
148 Varoquaux <gael.varoquaux-AT-normalesup.org>
154 Varoquaux <gael.varoquaux-AT-normalesup.org>
149
155
150 2007-05-09 *** Released version 0.8.1
156 2007-05-09 *** Released version 0.8.1
151
157
152 2007-05-10 Walter Doerwald <walter@livinglogic.de>
158 2007-05-10 Walter Doerwald <walter@livinglogic.de>
153
159
154 * IPython/Extensions/igrid.py: Incorporate html help into
160 * IPython/Extensions/igrid.py: Incorporate html help into
155 the module, so we don't have to search for the file.
161 the module, so we don't have to search for the file.
156
162
157 2007-05-02 Fernando Perez <Fernando.Perez@colorado.edu>
163 2007-05-02 Fernando Perez <Fernando.Perez@colorado.edu>
158
164
159 * test/test_irunner.py (RunnerTestCase._test_runner): Close #147.
165 * test/test_irunner.py (RunnerTestCase._test_runner): Close #147.
160
166
161 2007-04-30 Ville Vainio <vivainio@gmail.com>
167 2007-04-30 Ville Vainio <vivainio@gmail.com>
162
168
163 * iplib.py: (pre_config_initialization) Catch UnicodeDecodeError if the
169 * iplib.py: (pre_config_initialization) Catch UnicodeDecodeError if the
164 user has illegal (non-ascii) home directory name
170 user has illegal (non-ascii) home directory name
165
171
166 2007-04-27 Ville Vainio <vivainio@gmail.com>
172 2007-04-27 Ville Vainio <vivainio@gmail.com>
167
173
168 * platutils_win32.py: implement set_term_title for windows
174 * platutils_win32.py: implement set_term_title for windows
169
175
170 * Update version number
176 * Update version number
171
177
172 * ipy_profile_sh.py: more informative prompt (2 dir levels)
178 * ipy_profile_sh.py: more informative prompt (2 dir levels)
173
179
174 2007-04-26 Walter Doerwald <walter@livinglogic.de>
180 2007-04-26 Walter Doerwald <walter@livinglogic.de>
175
181
176 * IPython/Extensions/igrid.py: (igrid) Fix bug that surfaced
182 * IPython/Extensions/igrid.py: (igrid) Fix bug that surfaced
177 when the igrid input raised an exception. (Patch by Nik Tautenhahn,
183 when the igrid input raised an exception. (Patch by Nik Tautenhahn,
178 bug discovered by Ville).
184 bug discovered by Ville).
179
185
180 2007-04-26 Ville Vainio <vivainio@gmail.com>
186 2007-04-26 Ville Vainio <vivainio@gmail.com>
181
187
182 * Extensions/ipy_completers.py: Olivier's module completer now
188 * Extensions/ipy_completers.py: Olivier's module completer now
183 saves the list of root modules if it takes > 4 secs on the first run.
189 saves the list of root modules if it takes > 4 secs on the first run.
184
190
185 * Magic.py (%rehashx): %rehashx now clears the completer cache
191 * Magic.py (%rehashx): %rehashx now clears the completer cache
186
192
187
193
188 2007-04-26 Fernando Perez <Fernando.Perez@colorado.edu>
194 2007-04-26 Fernando Perez <Fernando.Perez@colorado.edu>
189
195
190 * ipython.el: fix incorrect color scheme, reported by Stefan.
196 * ipython.el: fix incorrect color scheme, reported by Stefan.
191 Closes #149.
197 Closes #149.
192
198
193 * IPython/PyColorize.py (Parser.format2): fix state-handling
199 * IPython/PyColorize.py (Parser.format2): fix state-handling
194 logic. I still don't like how that code handles state, but at
200 logic. I still don't like how that code handles state, but at
195 least now it should be correct, if inelegant. Closes #146.
201 least now it should be correct, if inelegant. Closes #146.
196
202
197 2007-04-25 Ville Vainio <vivainio@gmail.com>
203 2007-04-25 Ville Vainio <vivainio@gmail.com>
198
204
199 * Extensions/ipy_which.py: added extension for %which magic, works
205 * Extensions/ipy_which.py: added extension for %which magic, works
200 a lot like unix 'which' but also finds and expands aliases, and
206 a lot like unix 'which' but also finds and expands aliases, and
201 allows wildcards.
207 allows wildcards.
202
208
203 * ipapi.py (expand_alias): Now actually *return* the expanded alias,
209 * ipapi.py (expand_alias): Now actually *return* the expanded alias,
204 as opposed to returning nothing.
210 as opposed to returning nothing.
205
211
206 * UserConfig/ipy_user_conf.py, ipy_profile_sh.py: do not import
212 * UserConfig/ipy_user_conf.py, ipy_profile_sh.py: do not import
207 ipy_stock_completers on default profile, do import on sh profile.
213 ipy_stock_completers on default profile, do import on sh profile.
208
214
209 2007-04-22 J�rgen Stenarson <jorgen.stenarson@bostream.nu>
215 2007-04-22 J�rgen Stenarson <jorgen.stenarson@bostream.nu>
210
216
211 * Fix bug in iplib.py/safe_execfile when launching ipython with a script
217 * Fix bug in iplib.py/safe_execfile when launching ipython with a script
212 like ipython.py foo.py which raised a IndexError.
218 like ipython.py foo.py which raised a IndexError.
213
219
214 2007-04-21 Ville Vainio <vivainio@gmail.com>
220 2007-04-21 Ville Vainio <vivainio@gmail.com>
215
221
216 * Extensions/ipy_extutil.py: added extension to manage other ipython
222 * Extensions/ipy_extutil.py: added extension to manage other ipython
217 extensions. Now only supports 'ls' == list extensions.
223 extensions. Now only supports 'ls' == list extensions.
218
224
219 2007-04-20 Fernando Perez <Fernando.Perez@colorado.edu>
225 2007-04-20 Fernando Perez <Fernando.Perez@colorado.edu>
220
226
221 * IPython/Debugger.py (BdbQuit_excepthook): fix small bug that
227 * IPython/Debugger.py (BdbQuit_excepthook): fix small bug that
222 would prevent use of the exception system outside of a running
228 would prevent use of the exception system outside of a running
223 IPython instance.
229 IPython instance.
224
230
225 2007-04-20 Ville Vainio <vivainio@gmail.com>
231 2007-04-20 Ville Vainio <vivainio@gmail.com>
226
232
227 * Extensions/ipy_render.py: added extension for easy
233 * Extensions/ipy_render.py: added extension for easy
228 interactive text template rendering (to clipboard). Uses Ka-Ping Yee's
234 interactive text template rendering (to clipboard). Uses Ka-Ping Yee's
229 'Iptl' template notation,
235 'Iptl' template notation,
230
236
231 * Extensions/ipy_completers.py: introduced Olivier Lauzanne's
237 * Extensions/ipy_completers.py: introduced Olivier Lauzanne's
232 safer & faster 'import' completer.
238 safer & faster 'import' completer.
233
239
234 * ipapi.py: Introduced new ipapi methods, _ip.defmacro(name, value)
240 * ipapi.py: Introduced new ipapi methods, _ip.defmacro(name, value)
235 and _ip.defalias(name, command).
241 and _ip.defalias(name, command).
236
242
237 * Extensions/ipy_exportdb.py: New extension for exporting all the
243 * Extensions/ipy_exportdb.py: New extension for exporting all the
238 %store'd data in a portable format (normal ipapi calls like
244 %store'd data in a portable format (normal ipapi calls like
239 defmacro() etc.)
245 defmacro() etc.)
240
246
241 2007-04-19 Ville Vainio <vivainio@gmail.com>
247 2007-04-19 Ville Vainio <vivainio@gmail.com>
242
248
243 * upgrade_dir.py: skip junk files like *.pyc
249 * upgrade_dir.py: skip junk files like *.pyc
244
250
245 * Release.py: version number to 0.8.1
251 * Release.py: version number to 0.8.1
246
252
247 2007-04-18 Ville Vainio <vivainio@gmail.com>
253 2007-04-18 Ville Vainio <vivainio@gmail.com>
248
254
249 * iplib.py (safe_execfile): make "ipython foo.py" work with 2.5.1c1
255 * iplib.py (safe_execfile): make "ipython foo.py" work with 2.5.1c1
250 and later on win32.
256 and later on win32.
251
257
252 2007-04-16 Ville Vainio <vivainio@gmail.com>
258 2007-04-16 Ville Vainio <vivainio@gmail.com>
253
259
254 * iplib.py (showtraceback): Do not crash when running w/o readline.
260 * iplib.py (showtraceback): Do not crash when running w/o readline.
255
261
256 2007-04-12 Walter Doerwald <walter@livinglogic.de>
262 2007-04-12 Walter Doerwald <walter@livinglogic.de>
257
263
258 * IPython/Extensions/ipipe.py: (ils) Directoy listings are now
264 * IPython/Extensions/ipipe.py: (ils) Directoy listings are now
259 sorted (case sensitive with files and dirs mixed).
265 sorted (case sensitive with files and dirs mixed).
260
266
261 2007-04-10 Fernando Perez <Fernando.Perez@colorado.edu>
267 2007-04-10 Fernando Perez <Fernando.Perez@colorado.edu>
262
268
263 * IPython/Release.py (version): Open trunk for 0.8.1 development.
269 * IPython/Release.py (version): Open trunk for 0.8.1 development.
264
270
265 2007-04-10 *** Released version 0.8.0
271 2007-04-10 *** Released version 0.8.0
266
272
267 2007-04-07 Fernando Perez <Fernando.Perez@colorado.edu>
273 2007-04-07 Fernando Perez <Fernando.Perez@colorado.edu>
268
274
269 * Tag 0.8.0 for release.
275 * Tag 0.8.0 for release.
270
276
271 * IPython/iplib.py (reloadhist): add API function to cleanly
277 * IPython/iplib.py (reloadhist): add API function to cleanly
272 reload the readline history, which was growing inappropriately on
278 reload the readline history, which was growing inappropriately on
273 every %run call.
279 every %run call.
274
280
275 * win32_manual_post_install.py (run): apply last part of Nicolas
281 * win32_manual_post_install.py (run): apply last part of Nicolas
276 Pernetty's patch (I'd accidentally applied it in a different
282 Pernetty's patch (I'd accidentally applied it in a different
277 directory and this particular file didn't get patched).
283 directory and this particular file didn't get patched).
278
284
279 2007-04-05 Fernando Perez <Fernando.Perez@colorado.edu>
285 2007-04-05 Fernando Perez <Fernando.Perez@colorado.edu>
280
286
281 * IPython/Shell.py (MAIN_THREAD_ID): get rid of my stupid hack to
287 * IPython/Shell.py (MAIN_THREAD_ID): get rid of my stupid hack to
282 find the main thread id and use the proper API call. Thanks to
288 find the main thread id and use the proper API call. Thanks to
283 Stefan for the fix.
289 Stefan for the fix.
284
290
285 * test/test_prefilter.py (esc_handler_tests): udpate one of Dan's
291 * test/test_prefilter.py (esc_handler_tests): udpate one of Dan's
286 unit tests to reflect fixed ticket #52, and add more tests sent by
292 unit tests to reflect fixed ticket #52, and add more tests sent by
287 him.
293 him.
288
294
289 * IPython/iplib.py (raw_input): restore the readline completer
295 * IPython/iplib.py (raw_input): restore the readline completer
290 state on every input, in case third-party code messed it up.
296 state on every input, in case third-party code messed it up.
291 (_prefilter): revert recent addition of early-escape checks which
297 (_prefilter): revert recent addition of early-escape checks which
292 prevent many valid alias calls from working.
298 prevent many valid alias calls from working.
293
299
294 * IPython/Shell.py (MTInteractiveShell.runcode): add a tracking
300 * IPython/Shell.py (MTInteractiveShell.runcode): add a tracking
295 flag for sigint handler so we don't run a full signal() call on
301 flag for sigint handler so we don't run a full signal() call on
296 each runcode access.
302 each runcode access.
297
303
298 * IPython/Magic.py (magic_whos): small improvement to diagnostic
304 * IPython/Magic.py (magic_whos): small improvement to diagnostic
299 message.
305 message.
300
306
301 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
307 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
302
308
303 * IPython/Shell.py (sigint_handler): I *THINK* I finally got
309 * IPython/Shell.py (sigint_handler): I *THINK* I finally got
304 asynchronous exceptions working, i.e., Ctrl-C can actually
310 asynchronous exceptions working, i.e., Ctrl-C can actually
305 interrupt long-running code in the multithreaded shells.
311 interrupt long-running code in the multithreaded shells.
306
312
307 This is using Tomer Filiba's great ctypes-based trick:
313 This is using Tomer Filiba's great ctypes-based trick:
308 http://sebulba.wikispaces.com/recipe+thread2. I'd already tried
314 http://sebulba.wikispaces.com/recipe+thread2. I'd already tried
309 this in the past, but hadn't been able to make it work before. So
315 this in the past, but hadn't been able to make it work before. So
310 far it looks like it's actually running, but this needs more
316 far it looks like it's actually running, but this needs more
311 testing. If it really works, I'll be *very* happy, and we'll owe
317 testing. If it really works, I'll be *very* happy, and we'll owe
312 a huge thank you to Tomer. My current implementation is ugly,
318 a huge thank you to Tomer. My current implementation is ugly,
313 hackish and uses nasty globals, but I don't want to try and clean
319 hackish and uses nasty globals, but I don't want to try and clean
314 anything up until we know if it actually works.
320 anything up until we know if it actually works.
315
321
316 NOTE: this feature needs ctypes to work. ctypes is included in
322 NOTE: this feature needs ctypes to work. ctypes is included in
317 Python2.5, but 2.4 users will need to manually install it. This
323 Python2.5, but 2.4 users will need to manually install it. This
318 feature makes multi-threaded shells so much more usable that it's
324 feature makes multi-threaded shells so much more usable that it's
319 a minor price to pay (ctypes is very easy to install, already a
325 a minor price to pay (ctypes is very easy to install, already a
320 requirement for win32 and available in major linux distros).
326 requirement for win32 and available in major linux distros).
321
327
322 2007-04-04 Ville Vainio <vivainio@gmail.com>
328 2007-04-04 Ville Vainio <vivainio@gmail.com>
323
329
324 * Extensions/ipy_completers.py, ipy_stock_completers.py:
330 * Extensions/ipy_completers.py, ipy_stock_completers.py:
325 Moved implementations of 'bundled' completers to ipy_completers.py,
331 Moved implementations of 'bundled' completers to ipy_completers.py,
326 they are only enabled in ipy_stock_completers.py.
332 they are only enabled in ipy_stock_completers.py.
327
333
328 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
334 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
329
335
330 * IPython/PyColorize.py (Parser.format2): Fix identation of
336 * IPython/PyColorize.py (Parser.format2): Fix identation of
331 colorzied output and return early if color scheme is NoColor, to
337 colorzied output and return early if color scheme is NoColor, to
332 avoid unnecessary and expensive tokenization. Closes #131.
338 avoid unnecessary and expensive tokenization. Closes #131.
333
339
334 2007-04-03 Fernando Perez <Fernando.Perez@colorado.edu>
340 2007-04-03 Fernando Perez <Fernando.Perez@colorado.edu>
335
341
336 * IPython/Debugger.py: disable the use of pydb version 1.17. It
342 * IPython/Debugger.py: disable the use of pydb version 1.17. It
337 has a critical bug (a missing import that makes post-mortem not
343 has a critical bug (a missing import that makes post-mortem not
338 work at all). Unfortunately as of this time, this is the version
344 work at all). Unfortunately as of this time, this is the version
339 shipped with Ubuntu Edgy, so quite a few people have this one. I
345 shipped with Ubuntu Edgy, so quite a few people have this one. I
340 hope Edgy will update to a more recent package.
346 hope Edgy will update to a more recent package.
341
347
342 2007-04-02 Fernando Perez <Fernando.Perez@colorado.edu>
348 2007-04-02 Fernando Perez <Fernando.Perez@colorado.edu>
343
349
344 * IPython/iplib.py (_prefilter): close #52, second part of a patch
350 * IPython/iplib.py (_prefilter): close #52, second part of a patch
345 set by Stefan (only the first part had been applied before).
351 set by Stefan (only the first part had been applied before).
346
352
347 * IPython/Extensions/ipy_stock_completers.py (module_completer):
353 * IPython/Extensions/ipy_stock_completers.py (module_completer):
348 remove usage of the dangerous pkgutil.walk_packages(). See
354 remove usage of the dangerous pkgutil.walk_packages(). See
349 details in comments left in the code.
355 details in comments left in the code.
350
356
351 * IPython/Magic.py (magic_whos): add support for numpy arrays
357 * IPython/Magic.py (magic_whos): add support for numpy arrays
352 similar to what we had for Numeric.
358 similar to what we had for Numeric.
353
359
354 * IPython/completer.py (IPCompleter.complete): extend the
360 * IPython/completer.py (IPCompleter.complete): extend the
355 complete() call API to support completions by other mechanisms
361 complete() call API to support completions by other mechanisms
356 than readline. Closes #109.
362 than readline. Closes #109.
357
363
358 * IPython/iplib.py (safe_execfile): add a safeguard under Win32 to
364 * IPython/iplib.py (safe_execfile): add a safeguard under Win32 to
359 protect against a bug in Python's execfile(). Closes #123.
365 protect against a bug in Python's execfile(). Closes #123.
360
366
361 2007-04-01 Fernando Perez <Fernando.Perez@colorado.edu>
367 2007-04-01 Fernando Perez <Fernando.Perez@colorado.edu>
362
368
363 * IPython/iplib.py (split_user_input): ensure that when splitting
369 * IPython/iplib.py (split_user_input): ensure that when splitting
364 user input, the part that can be treated as a python name is pure
370 user input, the part that can be treated as a python name is pure
365 ascii (Python identifiers MUST be pure ascii). Part of the
371 ascii (Python identifiers MUST be pure ascii). Part of the
366 ongoing Unicode support work.
372 ongoing Unicode support work.
367
373
368 * IPython/Prompts.py (prompt_specials_color): Add \N for the
374 * IPython/Prompts.py (prompt_specials_color): Add \N for the
369 actual prompt number, without any coloring. This allows users to
375 actual prompt number, without any coloring. This allows users to
370 produce numbered prompts with their own colors. Added after a
376 produce numbered prompts with their own colors. Added after a
371 report/request by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
377 report/request by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
372
378
373 2007-03-31 Walter Doerwald <walter@livinglogic.de>
379 2007-03-31 Walter Doerwald <walter@livinglogic.de>
374
380
375 * IPython/Extensions/igrid.py: Map the return key
381 * IPython/Extensions/igrid.py: Map the return key
376 to enter() and shift-return to enterattr().
382 to enter() and shift-return to enterattr().
377
383
378 2007-03-30 Fernando Perez <Fernando.Perez@colorado.edu>
384 2007-03-30 Fernando Perez <Fernando.Perez@colorado.edu>
379
385
380 * IPython/Magic.py (magic_psearch): add unicode support by
386 * IPython/Magic.py (magic_psearch): add unicode support by
381 encoding to ascii the input, since this routine also only deals
387 encoding to ascii the input, since this routine also only deals
382 with valid Python names. Fixes a bug reported by Stefan.
388 with valid Python names. Fixes a bug reported by Stefan.
383
389
384 2007-03-29 Fernando Perez <Fernando.Perez@colorado.edu>
390 2007-03-29 Fernando Perez <Fernando.Perez@colorado.edu>
385
391
386 * IPython/Magic.py (_inspect): convert unicode input into ascii
392 * IPython/Magic.py (_inspect): convert unicode input into ascii
387 before trying to evaluate it as a Python identifier. This fixes a
393 before trying to evaluate it as a Python identifier. This fixes a
388 problem that the new unicode support had introduced when analyzing
394 problem that the new unicode support had introduced when analyzing
389 long definition lines for functions.
395 long definition lines for functions.
390
396
391 2007-03-24 Walter Doerwald <walter@livinglogic.de>
397 2007-03-24 Walter Doerwald <walter@livinglogic.de>
392
398
393 * IPython/Extensions/igrid.py: Fix picking. Using
399 * IPython/Extensions/igrid.py: Fix picking. Using
394 igrid with wxPython 2.6 and -wthread should work now.
400 igrid with wxPython 2.6 and -wthread should work now.
395 igrid.display() simply tries to create a frame without
401 igrid.display() simply tries to create a frame without
396 an application. Only if this fails an application is created.
402 an application. Only if this fails an application is created.
397
403
398 2007-03-23 Walter Doerwald <walter@livinglogic.de>
404 2007-03-23 Walter Doerwald <walter@livinglogic.de>
399
405
400 * IPython/Extensions/path.py: Updated to version 2.2.
406 * IPython/Extensions/path.py: Updated to version 2.2.
401
407
402 2007-03-23 Ville Vainio <vivainio@gmail.com>
408 2007-03-23 Ville Vainio <vivainio@gmail.com>
403
409
404 * iplib.py: recursive alias expansion now works better, so that
410 * iplib.py: recursive alias expansion now works better, so that
405 cases like 'top' -> 'd:/cygwin/top' -> 'ls :/cygwin/top'
411 cases like 'top' -> 'd:/cygwin/top' -> 'ls :/cygwin/top'
406 doesn't trip up the process, if 'd' has been aliased to 'ls'.
412 doesn't trip up the process, if 'd' has been aliased to 'ls'.
407
413
408 * Extensions/ipy_gnuglobal.py added, provides %global magic
414 * Extensions/ipy_gnuglobal.py added, provides %global magic
409 for users of http://www.gnu.org/software/global
415 for users of http://www.gnu.org/software/global
410
416
411 * iplib.py: '!command /?' now doesn't invoke IPython's help system.
417 * iplib.py: '!command /?' now doesn't invoke IPython's help system.
412 Closes #52. Patch by Stefan van der Walt.
418 Closes #52. Patch by Stefan van der Walt.
413
419
414 2007-03-23 Fernando Perez <Fernando.Perez@colorado.edu>
420 2007-03-23 Fernando Perez <Fernando.Perez@colorado.edu>
415
421
416 * IPython/FakeModule.py (FakeModule.__init__): Small fix to
422 * IPython/FakeModule.py (FakeModule.__init__): Small fix to
417 respect the __file__ attribute when using %run. Thanks to a bug
423 respect the __file__ attribute when using %run. Thanks to a bug
418 report by Sebastian Rooks <sebastian.rooks-AT-free.fr>.
424 report by Sebastian Rooks <sebastian.rooks-AT-free.fr>.
419
425
420 2007-03-22 Fernando Perez <Fernando.Perez@colorado.edu>
426 2007-03-22 Fernando Perez <Fernando.Perez@colorado.edu>
421
427
422 * IPython/iplib.py (raw_input): Fix mishandling of unicode at
428 * IPython/iplib.py (raw_input): Fix mishandling of unicode at
423 input. Patch sent by Stefan.
429 input. Patch sent by Stefan.
424
430
425 2007-03-20 J�rgen Stenarson <jorgen.stenarson@bostream.nu>
431 2007-03-20 J�rgen Stenarson <jorgen.stenarson@bostream.nu>
426 * IPython/Extensions/ipy_stock_completer.py
432 * IPython/Extensions/ipy_stock_completer.py
427 shlex_split, fix bug in shlex_split. len function
433 shlex_split, fix bug in shlex_split. len function
428 call was missing an if statement. Caused shlex_split to
434 call was missing an if statement. Caused shlex_split to
429 sometimes return "" as last element.
435 sometimes return "" as last element.
430
436
431 2007-03-18 Fernando Perez <Fernando.Perez@colorado.edu>
437 2007-03-18 Fernando Perez <Fernando.Perez@colorado.edu>
432
438
433 * IPython/completer.py
439 * IPython/completer.py
434 (IPCompleter.file_matches.single_dir_expand): fix a problem
440 (IPCompleter.file_matches.single_dir_expand): fix a problem
435 reported by Stefan, where directories containign a single subdir
441 reported by Stefan, where directories containign a single subdir
436 would be completed too early.
442 would be completed too early.
437
443
438 * IPython/Shell.py (_load_pylab): Make the execution of 'from
444 * IPython/Shell.py (_load_pylab): Make the execution of 'from
439 pylab import *' when -pylab is given be optional. A new flag,
445 pylab import *' when -pylab is given be optional. A new flag,
440 pylab_import_all controls this behavior, the default is True for
446 pylab_import_all controls this behavior, the default is True for
441 backwards compatibility.
447 backwards compatibility.
442
448
443 * IPython/ultraTB.py (_formatTracebackLines): Added (slightly
449 * IPython/ultraTB.py (_formatTracebackLines): Added (slightly
444 modified) R. Bernstein's patch for fully syntax highlighted
450 modified) R. Bernstein's patch for fully syntax highlighted
445 tracebacks. The functionality is also available under ultraTB for
451 tracebacks. The functionality is also available under ultraTB for
446 non-ipython users (someone using ultraTB but outside an ipython
452 non-ipython users (someone using ultraTB but outside an ipython
447 session). They can select the color scheme by setting the
453 session). They can select the color scheme by setting the
448 module-level global DEFAULT_SCHEME. The highlight functionality
454 module-level global DEFAULT_SCHEME. The highlight functionality
449 also works when debugging.
455 also works when debugging.
450
456
451 * IPython/genutils.py (IOStream.close): small patch by
457 * IPython/genutils.py (IOStream.close): small patch by
452 R. Bernstein for improved pydb support.
458 R. Bernstein for improved pydb support.
453
459
454 * IPython/Debugger.py (Pdb.format_stack_entry): Added patch by
460 * IPython/Debugger.py (Pdb.format_stack_entry): Added patch by
455 DaveS <davls@telus.net> to improve support of debugging under
461 DaveS <davls@telus.net> to improve support of debugging under
456 NTEmacs, including improved pydb behavior.
462 NTEmacs, including improved pydb behavior.
457
463
458 * IPython/Magic.py (magic_prun): Fix saving of profile info for
464 * IPython/Magic.py (magic_prun): Fix saving of profile info for
459 Python 2.5, where the stats object API changed a little. Thanks
465 Python 2.5, where the stats object API changed a little. Thanks
460 to a bug report by Paul Smith <paul.smith-AT-catugmt.com>.
466 to a bug report by Paul Smith <paul.smith-AT-catugmt.com>.
461
467
462 * IPython/ColorANSI.py (InputTermColors.Normal): applied Nicolas
468 * IPython/ColorANSI.py (InputTermColors.Normal): applied Nicolas
463 Pernetty's patch to improve support for (X)Emacs under Win32.
469 Pernetty's patch to improve support for (X)Emacs under Win32.
464
470
465 2007-03-17 Fernando Perez <Fernando.Perez@colorado.edu>
471 2007-03-17 Fernando Perez <Fernando.Perez@colorado.edu>
466
472
467 * IPython/Shell.py (hijack_wx): ipmort WX with current semantics
473 * IPython/Shell.py (hijack_wx): ipmort WX with current semantics
468 to quiet a deprecation warning that fires with Wx 2.8. Thanks to
474 to quiet a deprecation warning that fires with Wx 2.8. Thanks to
469 a report by Nik Tautenhahn.
475 a report by Nik Tautenhahn.
470
476
471 2007-03-16 Walter Doerwald <walter@livinglogic.de>
477 2007-03-16 Walter Doerwald <walter@livinglogic.de>
472
478
473 * setup.py: Add the igrid help files to the list of data files
479 * setup.py: Add the igrid help files to the list of data files
474 to be installed alongside igrid.
480 to be installed alongside igrid.
475 * IPython/Extensions/igrid.py: (Patch by Nik Tautenhahn)
481 * IPython/Extensions/igrid.py: (Patch by Nik Tautenhahn)
476 Show the input object of the igrid browser as the window tile.
482 Show the input object of the igrid browser as the window tile.
477 Show the object the cursor is on in the statusbar.
483 Show the object the cursor is on in the statusbar.
478
484
479 2007-03-15 Ville Vainio <vivainio@gmail.com>
485 2007-03-15 Ville Vainio <vivainio@gmail.com>
480
486
481 * Extensions/ipy_stock_completers.py: Fixed exception
487 * Extensions/ipy_stock_completers.py: Fixed exception
482 on mismatching quotes in %run completer. Patch by
488 on mismatching quotes in %run completer. Patch by
483 J�rgen Stenarson. Closes #127.
489 J�rgen Stenarson. Closes #127.
484
490
485 2007-03-14 Ville Vainio <vivainio@gmail.com>
491 2007-03-14 Ville Vainio <vivainio@gmail.com>
486
492
487 * Extensions/ext_rehashdir.py: Do not do auto_alias
493 * Extensions/ext_rehashdir.py: Do not do auto_alias
488 in %rehashdir, it clobbers %store'd aliases.
494 in %rehashdir, it clobbers %store'd aliases.
489
495
490 * UserConfig/ipy_profile_sh.py: envpersist.py extension
496 * UserConfig/ipy_profile_sh.py: envpersist.py extension
491 (beefed up %env) imported for sh profile.
497 (beefed up %env) imported for sh profile.
492
498
493 2007-03-10 Walter Doerwald <walter@livinglogic.de>
499 2007-03-10 Walter Doerwald <walter@livinglogic.de>
494
500
495 * IPython/Extensions/ipipe.py: Prefer ibrowse over igrid
501 * IPython/Extensions/ipipe.py: Prefer ibrowse over igrid
496 as the default browser.
502 as the default browser.
497 * IPython/Extensions/igrid.py: Make a few igrid attributes private.
503 * IPython/Extensions/igrid.py: Make a few igrid attributes private.
498 As igrid displays all attributes it ever encounters, fetch() (which has
504 As igrid displays all attributes it ever encounters, fetch() (which has
499 been renamed to _fetch()) doesn't have to recalculate the display attributes
505 been renamed to _fetch()) doesn't have to recalculate the display attributes
500 every time a new item is fetched. This should speed up scrolling.
506 every time a new item is fetched. This should speed up scrolling.
501
507
502 2007-03-10 Fernando Perez <Fernando.Perez@colorado.edu>
508 2007-03-10 Fernando Perez <Fernando.Perez@colorado.edu>
503
509
504 * IPython/iplib.py (InteractiveShell.__init__): fix for Alex
510 * IPython/iplib.py (InteractiveShell.__init__): fix for Alex
505 Schmolck's recently reported tab-completion bug (my previous one
511 Schmolck's recently reported tab-completion bug (my previous one
506 had a problem). Patch by Dan Milstein <danmil-AT-comcast.net>.
512 had a problem). Patch by Dan Milstein <danmil-AT-comcast.net>.
507
513
508 2007-03-09 Walter Doerwald <walter@livinglogic.de>
514 2007-03-09 Walter Doerwald <walter@livinglogic.de>
509
515
510 * IPython/Extensions/igrid.py: Patch by Nik Tautenhahn:
516 * IPython/Extensions/igrid.py: Patch by Nik Tautenhahn:
511 Close help window if exiting igrid.
517 Close help window if exiting igrid.
512
518
513 2007-03-02 J�rgen Stenarson <jorgen.stenarson@bostream.nu>
519 2007-03-02 J�rgen Stenarson <jorgen.stenarson@bostream.nu>
514
520
515 * IPython/Extensions/ipy_defaults.py: Check if readline is available
521 * IPython/Extensions/ipy_defaults.py: Check if readline is available
516 before calling functions from readline.
522 before calling functions from readline.
517
523
518 2007-03-02 Walter Doerwald <walter@livinglogic.de>
524 2007-03-02 Walter Doerwald <walter@livinglogic.de>
519
525
520 * IPython/Extensions/igrid.py: Add Nik Tautenhahns igrid extension.
526 * IPython/Extensions/igrid.py: Add Nik Tautenhahns igrid extension.
521 igrid is a wxPython-based display object for ipipe. If your system has
527 igrid is a wxPython-based display object for ipipe. If your system has
522 wx installed igrid will be the default display. Without wx ipipe falls
528 wx installed igrid will be the default display. Without wx ipipe falls
523 back to ibrowse (which needs curses). If no curses is installed ipipe
529 back to ibrowse (which needs curses). If no curses is installed ipipe
524 falls back to idump.
530 falls back to idump.
525
531
526 2007-03-01 Fernando Perez <Fernando.Perez@colorado.edu>
532 2007-03-01 Fernando Perez <Fernando.Perez@colorado.edu>
527
533
528 * IPython/iplib.py (split_user_inputBROKEN): temporarily disable
534 * IPython/iplib.py (split_user_inputBROKEN): temporarily disable
529 my changes from yesterday, they introduced bugs. Will reactivate
535 my changes from yesterday, they introduced bugs. Will reactivate
530 once I get a correct solution, which will be much easier thanks to
536 once I get a correct solution, which will be much easier thanks to
531 Dan Milstein's new prefilter test suite.
537 Dan Milstein's new prefilter test suite.
532
538
533 2007-02-28 Fernando Perez <Fernando.Perez@colorado.edu>
539 2007-02-28 Fernando Perez <Fernando.Perez@colorado.edu>
534
540
535 * IPython/iplib.py (split_user_input): fix input splitting so we
541 * IPython/iplib.py (split_user_input): fix input splitting so we
536 don't attempt attribute accesses on things that can't possibly be
542 don't attempt attribute accesses on things that can't possibly be
537 valid Python attributes. After a bug report by Alex Schmolck.
543 valid Python attributes. After a bug report by Alex Schmolck.
538 (InteractiveShell.__init__): brown-paper bag fix; regexp broke
544 (InteractiveShell.__init__): brown-paper bag fix; regexp broke
539 %magic with explicit % prefix.
545 %magic with explicit % prefix.
540
546
541 2007-02-27 Fernando Perez <Fernando.Perez@colorado.edu>
547 2007-02-27 Fernando Perez <Fernando.Perez@colorado.edu>
542
548
543 * IPython/Shell.py (IPShellGTK.mainloop): update threads calls to
549 * IPython/Shell.py (IPShellGTK.mainloop): update threads calls to
544 avoid a DeprecationWarning from GTK.
550 avoid a DeprecationWarning from GTK.
545
551
546 2007-02-22 Fernando Perez <Fernando.Perez@colorado.edu>
552 2007-02-22 Fernando Perez <Fernando.Perez@colorado.edu>
547
553
548 * IPython/genutils.py (clock): I modified clock() to return total
554 * IPython/genutils.py (clock): I modified clock() to return total
549 time, user+system. This is a more commonly needed metric. I also
555 time, user+system. This is a more commonly needed metric. I also
550 introduced the new clocku/clocks to get only user/system time if
556 introduced the new clocku/clocks to get only user/system time if
551 one wants those instead.
557 one wants those instead.
552
558
553 ***WARNING: API CHANGE*** clock() used to return only user time,
559 ***WARNING: API CHANGE*** clock() used to return only user time,
554 so if you want exactly the same results as before, use clocku
560 so if you want exactly the same results as before, use clocku
555 instead.
561 instead.
556
562
557 2007-02-22 Ville Vainio <vivainio@gmail.com>
563 2007-02-22 Ville Vainio <vivainio@gmail.com>
558
564
559 * IPython/Extensions/ipy_p4.py: Extension for improved
565 * IPython/Extensions/ipy_p4.py: Extension for improved
560 p4 (perforce version control system) experience.
566 p4 (perforce version control system) experience.
561 Adds %p4 magic with p4 command completion and
567 Adds %p4 magic with p4 command completion and
562 automatic -G argument (marshall output as python dict)
568 automatic -G argument (marshall output as python dict)
563
569
564 2007-02-19 Fernando Perez <Fernando.Perez@colorado.edu>
570 2007-02-19 Fernando Perez <Fernando.Perez@colorado.edu>
565
571
566 * IPython/demo.py (Demo.re_stop): make dashes optional in demo
572 * IPython/demo.py (Demo.re_stop): make dashes optional in demo
567 stop marks.
573 stop marks.
568 (ClearingMixin): a simple mixin to easily make a Demo class clear
574 (ClearingMixin): a simple mixin to easily make a Demo class clear
569 the screen in between blocks and have empty marquees. The
575 the screen in between blocks and have empty marquees. The
570 ClearDemo and ClearIPDemo classes that use it are included.
576 ClearDemo and ClearIPDemo classes that use it are included.
571
577
572 2007-02-18 Fernando Perez <Fernando.Perez@colorado.edu>
578 2007-02-18 Fernando Perez <Fernando.Perez@colorado.edu>
573
579
574 * IPython/irunner.py (pexpect_monkeypatch): patch pexpect to
580 * IPython/irunner.py (pexpect_monkeypatch): patch pexpect to
575 protect against exceptions at Python shutdown time. Patch
581 protect against exceptions at Python shutdown time. Patch
576 sumbmitted to upstream.
582 sumbmitted to upstream.
577
583
578 2007-02-14 Walter Doerwald <walter@livinglogic.de>
584 2007-02-14 Walter Doerwald <walter@livinglogic.de>
579
585
580 * IPython/Extensions/ibrowse.py: If entering the first object level
586 * IPython/Extensions/ibrowse.py: If entering the first object level
581 (i.e. the object for which the browser has been started) fails,
587 (i.e. the object for which the browser has been started) fails,
582 now the error is raised directly (aborting the browser) instead of
588 now the error is raised directly (aborting the browser) instead of
583 running into an empty levels list later.
589 running into an empty levels list later.
584
590
585 2007-02-03 Walter Doerwald <walter@livinglogic.de>
591 2007-02-03 Walter Doerwald <walter@livinglogic.de>
586
592
587 * IPython/Extensions/ipipe.py: Add an xrepr implementation
593 * IPython/Extensions/ipipe.py: Add an xrepr implementation
588 for the noitem object.
594 for the noitem object.
589
595
590 2007-01-31 Fernando Perez <Fernando.Perez@colorado.edu>
596 2007-01-31 Fernando Perez <Fernando.Perez@colorado.edu>
591
597
592 * IPython/completer.py (Completer.attr_matches): Fix small
598 * IPython/completer.py (Completer.attr_matches): Fix small
593 tab-completion bug with Enthought Traits objects with units.
599 tab-completion bug with Enthought Traits objects with units.
594 Thanks to a bug report by Tom Denniston
600 Thanks to a bug report by Tom Denniston
595 <tom.denniston-AT-alum.dartmouth.org>.
601 <tom.denniston-AT-alum.dartmouth.org>.
596
602
597 2007-01-27 Fernando Perez <Fernando.Perez@colorado.edu>
603 2007-01-27 Fernando Perez <Fernando.Perez@colorado.edu>
598
604
599 * IPython/Extensions/ipy_stock_completers.py (runlistpy): fix a
605 * IPython/Extensions/ipy_stock_completers.py (runlistpy): fix a
600 bug where only .ipy or .py would be completed. Once the first
606 bug where only .ipy or .py would be completed. Once the first
601 argument to %run has been given, all completions are valid because
607 argument to %run has been given, all completions are valid because
602 they are the arguments to the script, which may well be non-python
608 they are the arguments to the script, which may well be non-python
603 filenames.
609 filenames.
604
610
605 * IPython/irunner.py (InteractiveRunner.run_source): major updates
611 * IPython/irunner.py (InteractiveRunner.run_source): major updates
606 to irunner to allow it to correctly support real doctesting of
612 to irunner to allow it to correctly support real doctesting of
607 out-of-process ipython code.
613 out-of-process ipython code.
608
614
609 * IPython/Magic.py (magic_cd): Make the setting of the terminal
615 * IPython/Magic.py (magic_cd): Make the setting of the terminal
610 title an option (-noterm_title) because it completely breaks
616 title an option (-noterm_title) because it completely breaks
611 doctesting.
617 doctesting.
612
618
613 * IPython/demo.py: fix IPythonDemo class that was not actually working.
619 * IPython/demo.py: fix IPythonDemo class that was not actually working.
614
620
615 2007-01-24 Fernando Perez <Fernando.Perez@colorado.edu>
621 2007-01-24 Fernando Perez <Fernando.Perez@colorado.edu>
616
622
617 * IPython/irunner.py (main): fix small bug where extensions were
623 * IPython/irunner.py (main): fix small bug where extensions were
618 not being correctly recognized.
624 not being correctly recognized.
619
625
620 2007-01-23 Walter Doerwald <walter@livinglogic.de>
626 2007-01-23 Walter Doerwald <walter@livinglogic.de>
621
627
622 * IPython/Extensions/ipipe.py (xiter): Make sure that iterating
628 * IPython/Extensions/ipipe.py (xiter): Make sure that iterating
623 a string containing a single line yields the string itself as the
629 a string containing a single line yields the string itself as the
624 only item.
630 only item.
625
631
626 * IPython/Extensions/ibrowse.py (ibrowse): Avoid entering an
632 * IPython/Extensions/ibrowse.py (ibrowse): Avoid entering an
627 object if it's the same as the one on the last level (This avoids
633 object if it's the same as the one on the last level (This avoids
628 infinite recursion for one line strings).
634 infinite recursion for one line strings).
629
635
630 2007-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
636 2007-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
631
637
632 * IPython/ultraTB.py (AutoFormattedTB.__call__): properly flush
638 * IPython/ultraTB.py (AutoFormattedTB.__call__): properly flush
633 all output streams before printing tracebacks. This ensures that
639 all output streams before printing tracebacks. This ensures that
634 user output doesn't end up interleaved with traceback output.
640 user output doesn't end up interleaved with traceback output.
635
641
636 2007-01-10 Ville Vainio <vivainio@gmail.com>
642 2007-01-10 Ville Vainio <vivainio@gmail.com>
637
643
638 * Extensions/envpersist.py: Turbocharged %env that remembers
644 * Extensions/envpersist.py: Turbocharged %env that remembers
639 env vars across sessions; e.g. "%env PATH+=;/opt/scripts" or
645 env vars across sessions; e.g. "%env PATH+=;/opt/scripts" or
640 "%env VISUAL=jed".
646 "%env VISUAL=jed".
641
647
642 2007-01-05 Fernando Perez <Fernando.Perez@colorado.edu>
648 2007-01-05 Fernando Perez <Fernando.Perez@colorado.edu>
643
649
644 * IPython/iplib.py (showtraceback): ensure that we correctly call
650 * IPython/iplib.py (showtraceback): ensure that we correctly call
645 custom handlers in all cases (some with pdb were slipping through,
651 custom handlers in all cases (some with pdb were slipping through,
646 but I'm not exactly sure why).
652 but I'm not exactly sure why).
647
653
648 * IPython/Debugger.py (Tracer.__init__): added new class to
654 * IPython/Debugger.py (Tracer.__init__): added new class to
649 support set_trace-like usage of IPython's enhanced debugger.
655 support set_trace-like usage of IPython's enhanced debugger.
650
656
651 2006-12-24 Ville Vainio <vivainio@gmail.com>
657 2006-12-24 Ville Vainio <vivainio@gmail.com>
652
658
653 * ipmaker.py: more informative message when ipy_user_conf
659 * ipmaker.py: more informative message when ipy_user_conf
654 import fails (suggest running %upgrade).
660 import fails (suggest running %upgrade).
655
661
656 * tools/run_ipy_in_profiler.py: Utility to see where
662 * tools/run_ipy_in_profiler.py: Utility to see where
657 the time during IPython startup is spent.
663 the time during IPython startup is spent.
658
664
659 2006-12-20 Ville Vainio <vivainio@gmail.com>
665 2006-12-20 Ville Vainio <vivainio@gmail.com>
660
666
661 * 0.7.3 is out - merge all from 0.7.3 branch to trunk
667 * 0.7.3 is out - merge all from 0.7.3 branch to trunk
662
668
663 * ipapi.py: Add new ipapi method, expand_alias.
669 * ipapi.py: Add new ipapi method, expand_alias.
664
670
665 * Release.py: Bump up version to 0.7.4.svn
671 * Release.py: Bump up version to 0.7.4.svn
666
672
667 2006-12-17 Ville Vainio <vivainio@gmail.com>
673 2006-12-17 Ville Vainio <vivainio@gmail.com>
668
674
669 * Extensions/jobctrl.py: Fixed &cmd arg arg...
675 * Extensions/jobctrl.py: Fixed &cmd arg arg...
670 to work properly on posix too
676 to work properly on posix too
671
677
672 * Release.py: Update revnum (version is still just 0.7.3).
678 * Release.py: Update revnum (version is still just 0.7.3).
673
679
674 2006-12-15 Ville Vainio <vivainio@gmail.com>
680 2006-12-15 Ville Vainio <vivainio@gmail.com>
675
681
676 * scripts/ipython_win_post_install: create ipython.py in
682 * scripts/ipython_win_post_install: create ipython.py in
677 prefix + "/scripts".
683 prefix + "/scripts".
678
684
679 * Release.py: Update version to 0.7.3.
685 * Release.py: Update version to 0.7.3.
680
686
681 2006-12-14 Ville Vainio <vivainio@gmail.com>
687 2006-12-14 Ville Vainio <vivainio@gmail.com>
682
688
683 * scripts/ipython_win_post_install: Overwrite old shortcuts
689 * scripts/ipython_win_post_install: Overwrite old shortcuts
684 if they already exist
690 if they already exist
685
691
686 * Release.py: release 0.7.3rc2
692 * Release.py: release 0.7.3rc2
687
693
688 2006-12-13 Ville Vainio <vivainio@gmail.com>
694 2006-12-13 Ville Vainio <vivainio@gmail.com>
689
695
690 * Branch and update Release.py for 0.7.3rc1
696 * Branch and update Release.py for 0.7.3rc1
691
697
692 2006-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
698 2006-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
693
699
694 * IPython/Shell.py (IPShellWX): update for current WX naming
700 * IPython/Shell.py (IPShellWX): update for current WX naming
695 conventions, to avoid a deprecation warning with current WX
701 conventions, to avoid a deprecation warning with current WX
696 versions. Thanks to a report by Danny Shevitz.
702 versions. Thanks to a report by Danny Shevitz.
697
703
698 2006-12-12 Ville Vainio <vivainio@gmail.com>
704 2006-12-12 Ville Vainio <vivainio@gmail.com>
699
705
700 * ipmaker.py: apply david cournapeau's patch to make
706 * ipmaker.py: apply david cournapeau's patch to make
701 import_some work properly even when ipythonrc does
707 import_some work properly even when ipythonrc does
702 import_some on empty list (it was an old bug!).
708 import_some on empty list (it was an old bug!).
703
709
704 * UserConfig/ipy_user_conf.py, UserConfig/ipythonrc:
710 * UserConfig/ipy_user_conf.py, UserConfig/ipythonrc:
705 Add deprecation note to ipythonrc and a url to wiki
711 Add deprecation note to ipythonrc and a url to wiki
706 in ipy_user_conf.py
712 in ipy_user_conf.py
707
713
708
714
709 * Magic.py (%run): %run myscript.ipy now runs myscript.ipy
715 * Magic.py (%run): %run myscript.ipy now runs myscript.ipy
710 as if it was typed on IPython command prompt, i.e.
716 as if it was typed on IPython command prompt, i.e.
711 as IPython script.
717 as IPython script.
712
718
713 * example-magic.py, magic_grepl.py: remove outdated examples
719 * example-magic.py, magic_grepl.py: remove outdated examples
714
720
715 2006-12-11 Fernando Perez <Fernando.Perez@colorado.edu>
721 2006-12-11 Fernando Perez <Fernando.Perez@colorado.edu>
716
722
717 * IPython/iplib.py (debugger): prevent a nasty traceback if %debug
723 * IPython/iplib.py (debugger): prevent a nasty traceback if %debug
718 is called before any exception has occurred.
724 is called before any exception has occurred.
719
725
720 2006-12-08 Ville Vainio <vivainio@gmail.com>
726 2006-12-08 Ville Vainio <vivainio@gmail.com>
721
727
722 * Extensions/ipy_stock_completers.py: fix cd completer
728 * Extensions/ipy_stock_completers.py: fix cd completer
723 to translate /'s to \'s again.
729 to translate /'s to \'s again.
724
730
725 * completer.py: prevent traceback on file completions w/
731 * completer.py: prevent traceback on file completions w/
726 backslash.
732 backslash.
727
733
728 * Release.py: Update release number to 0.7.3b3 for release
734 * Release.py: Update release number to 0.7.3b3 for release
729
735
730 2006-12-07 Ville Vainio <vivainio@gmail.com>
736 2006-12-07 Ville Vainio <vivainio@gmail.com>
731
737
732 * Extensions/ipy_signals.py: Ignore ctrl+C in IPython process
738 * Extensions/ipy_signals.py: Ignore ctrl+C in IPython process
733 while executing external code. Provides more shell-like behaviour
739 while executing external code. Provides more shell-like behaviour
734 and overall better response to ctrl + C / ctrl + break.
740 and overall better response to ctrl + C / ctrl + break.
735
741
736 * tools/make_tarball.py: new script to create tarball straight from svn
742 * tools/make_tarball.py: new script to create tarball straight from svn
737 (setup.py sdist doesn't work on win32).
743 (setup.py sdist doesn't work on win32).
738
744
739 * Extensions/ipy_stock_completers.py: fix cd completer to give up
745 * Extensions/ipy_stock_completers.py: fix cd completer to give up
740 on dirnames with spaces and use the default completer instead.
746 on dirnames with spaces and use the default completer instead.
741
747
742 * Revision.py: Change version to 0.7.3b2 for release.
748 * Revision.py: Change version to 0.7.3b2 for release.
743
749
744 2006-12-05 Ville Vainio <vivainio@gmail.com>
750 2006-12-05 Ville Vainio <vivainio@gmail.com>
745
751
746 * Magic.py, iplib.py, completer.py: Apply R. Bernstein's
752 * Magic.py, iplib.py, completer.py: Apply R. Bernstein's
747 pydb patch 4 (rm debug printing, py 2.5 checking)
753 pydb patch 4 (rm debug printing, py 2.5 checking)
748
754
749 2006-11-30 Walter Doerwald <walter@livinglogic.de>
755 2006-11-30 Walter Doerwald <walter@livinglogic.de>
750 * IPython/Extensions/ibrowse.py: Add two new commands to ibrowse:
756 * IPython/Extensions/ibrowse.py: Add two new commands to ibrowse:
751 "refresh" (mapped to "r") refreshes the screen by restarting the iterator.
757 "refresh" (mapped to "r") refreshes the screen by restarting the iterator.
752 "refreshfind" (mapped to "R") does the same but tries to go back to the same
758 "refreshfind" (mapped to "R") does the same but tries to go back to the same
753 object the cursor was on before the refresh. The command "markrange" is
759 object the cursor was on before the refresh. The command "markrange" is
754 mapped to "%" now.
760 mapped to "%" now.
755 * IPython/Extensions/ibrowse.py: Make igrpentry and ipwdentry comparable.
761 * IPython/Extensions/ibrowse.py: Make igrpentry and ipwdentry comparable.
756
762
757 2006-11-29 Fernando Perez <Fernando.Perez@colorado.edu>
763 2006-11-29 Fernando Perez <Fernando.Perez@colorado.edu>
758
764
759 * IPython/Magic.py (magic_debug): new %debug magic to activate the
765 * IPython/Magic.py (magic_debug): new %debug magic to activate the
760 interactive debugger on the last traceback, without having to call
766 interactive debugger on the last traceback, without having to call
761 %pdb and rerun your code. Made minor changes in various modules,
767 %pdb and rerun your code. Made minor changes in various modules,
762 should automatically recognize pydb if available.
768 should automatically recognize pydb if available.
763
769
764 2006-11-28 Ville Vainio <vivainio@gmail.com>
770 2006-11-28 Ville Vainio <vivainio@gmail.com>
765
771
766 * completer.py: If the text start with !, show file completions
772 * completer.py: If the text start with !, show file completions
767 properly. This helps when trying to complete command name
773 properly. This helps when trying to complete command name
768 for shell escapes.
774 for shell escapes.
769
775
770 2006-11-27 Ville Vainio <vivainio@gmail.com>
776 2006-11-27 Ville Vainio <vivainio@gmail.com>
771
777
772 * ipy_stock_completers.py: bzr completer submitted by Stefan van
778 * ipy_stock_completers.py: bzr completer submitted by Stefan van
773 der Walt. Clean up svn and hg completers by using a common
779 der Walt. Clean up svn and hg completers by using a common
774 vcs_completer.
780 vcs_completer.
775
781
776 2006-11-26 Ville Vainio <vivainio@gmail.com>
782 2006-11-26 Ville Vainio <vivainio@gmail.com>
777
783
778 * Remove ipconfig and %config; you should use _ip.options structure
784 * Remove ipconfig and %config; you should use _ip.options structure
779 directly instead!
785 directly instead!
780
786
781 * genutils.py: add wrap_deprecated function for deprecating callables
787 * genutils.py: add wrap_deprecated function for deprecating callables
782
788
783 * iplib.py: deprecate ipmagic, ipsystem, ipalias. Use _ip.magic and
789 * iplib.py: deprecate ipmagic, ipsystem, ipalias. Use _ip.magic and
784 _ip.system instead. ipalias is redundant.
790 _ip.system instead. ipalias is redundant.
785
791
786 * Magic.py: %rehashdir no longer aliases 'cmdname' to 'cmdname.exe' on
792 * Magic.py: %rehashdir no longer aliases 'cmdname' to 'cmdname.exe' on
787 win32, but just 'cmdname'. Other extensions (non-'exe') are still made
793 win32, but just 'cmdname'. Other extensions (non-'exe') are still made
788 explicit.
794 explicit.
789
795
790 * ipy_stock_completers.py: 'hg' (mercurial VCS) now has a custom
796 * ipy_stock_completers.py: 'hg' (mercurial VCS) now has a custom
791 completer. Try it by entering 'hg ' and pressing tab.
797 completer. Try it by entering 'hg ' and pressing tab.
792
798
793 * macro.py: Give Macro a useful __repr__ method
799 * macro.py: Give Macro a useful __repr__ method
794
800
795 * Magic.py: %whos abbreviates the typename of Macro for brevity.
801 * Magic.py: %whos abbreviates the typename of Macro for brevity.
796
802
797 2006-11-24 Walter Doerwald <walter@livinglogic.de>
803 2006-11-24 Walter Doerwald <walter@livinglogic.de>
798 * IPython/Extensions/astyle.py: Do a relative import of ipipe, so that
804 * IPython/Extensions/astyle.py: Do a relative import of ipipe, so that
799 we don't get a duplicate ipipe module, where registration of the xrepr
805 we don't get a duplicate ipipe module, where registration of the xrepr
800 implementation for Text is useless.
806 implementation for Text is useless.
801
807
802 * IPython/Extensions/ipipe.py: Fix __xrepr__() implementation for ils.
808 * IPython/Extensions/ipipe.py: Fix __xrepr__() implementation for ils.
803
809
804 * IPython/Extensions/ibrowse.py: Fix keymapping for the enter command.
810 * IPython/Extensions/ibrowse.py: Fix keymapping for the enter command.
805
811
806 2006-11-24 Ville Vainio <vivainio@gmail.com>
812 2006-11-24 Ville Vainio <vivainio@gmail.com>
807
813
808 * Magic.py, manual_base.lyx: Kirill Smelkov patch:
814 * Magic.py, manual_base.lyx: Kirill Smelkov patch:
809 try to use "cProfile" instead of the slower pure python
815 try to use "cProfile" instead of the slower pure python
810 "profile"
816 "profile"
811
817
812 2006-11-23 Ville Vainio <vivainio@gmail.com>
818 2006-11-23 Ville Vainio <vivainio@gmail.com>
813
819
814 * manual_base.lyx: Kirill Smelkov patch: Fix wrong
820 * manual_base.lyx: Kirill Smelkov patch: Fix wrong
815 Qt+IPython+Designer link in documentation.
821 Qt+IPython+Designer link in documentation.
816
822
817 * Extensions/ipy_pydb.py: R. Bernstein's patch for passing
823 * Extensions/ipy_pydb.py: R. Bernstein's patch for passing
818 correct Pdb object to %pydb.
824 correct Pdb object to %pydb.
819
825
820
826
821 2006-11-22 Walter Doerwald <walter@livinglogic.de>
827 2006-11-22 Walter Doerwald <walter@livinglogic.de>
822 * IPython/Extensions/astyle.py: Text needs it's own implemenation of the
828 * IPython/Extensions/astyle.py: Text needs it's own implemenation of the
823 generic xrepr(), otherwise the list implementation would kick in.
829 generic xrepr(), otherwise the list implementation would kick in.
824
830
825 2006-11-21 Ville Vainio <vivainio@gmail.com>
831 2006-11-21 Ville Vainio <vivainio@gmail.com>
826
832
827 * upgrade_dir.py: Now actually overwrites a nonmodified user file
833 * upgrade_dir.py: Now actually overwrites a nonmodified user file
828 with one from UserConfig.
834 with one from UserConfig.
829
835
830 * ipy_profile_sh.py: Add dummy "depth" to var_expand lambda,
836 * ipy_profile_sh.py: Add dummy "depth" to var_expand lambda,
831 it was missing which broke the sh profile.
837 it was missing which broke the sh profile.
832
838
833 * completer.py: file completer now uses explicit '/' instead
839 * completer.py: file completer now uses explicit '/' instead
834 of os.path.join, expansion of 'foo' was broken on win32
840 of os.path.join, expansion of 'foo' was broken on win32
835 if there was one directory with name 'foobar'.
841 if there was one directory with name 'foobar'.
836
842
837 * A bunch of patches from Kirill Smelkov:
843 * A bunch of patches from Kirill Smelkov:
838
844
839 * [patch 9/9] doc: point bug-tracker URL to IPythons trac-tickets.
845 * [patch 9/9] doc: point bug-tracker URL to IPythons trac-tickets.
840
846
841 * [patch 7/9] Implement %page -r (page in raw mode) -
847 * [patch 7/9] Implement %page -r (page in raw mode) -
842
848
843 * [patch 5/9] ScientificPython webpage has moved
849 * [patch 5/9] ScientificPython webpage has moved
844
850
845 * [patch 4/9] The manual mentions %ds, should be %dhist
851 * [patch 4/9] The manual mentions %ds, should be %dhist
846
852
847 * [patch 3/9] Kill old bits from %prun doc.
853 * [patch 3/9] Kill old bits from %prun doc.
848
854
849 * [patch 1/9] Fix typos here and there.
855 * [patch 1/9] Fix typos here and there.
850
856
851 2006-11-08 Ville Vainio <vivainio@gmail.com>
857 2006-11-08 Ville Vainio <vivainio@gmail.com>
852
858
853 * completer.py (attr_matches): catch all exceptions raised
859 * completer.py (attr_matches): catch all exceptions raised
854 by eval of expr with dots.
860 by eval of expr with dots.
855
861
856 2006-11-07 Fernando Perez <Fernando.Perez@colorado.edu>
862 2006-11-07 Fernando Perez <Fernando.Perez@colorado.edu>
857
863
858 * IPython/iplib.py (runsource): Prepend an 'if 1:' to the user
864 * IPython/iplib.py (runsource): Prepend an 'if 1:' to the user
859 input if it starts with whitespace. This allows you to paste
865 input if it starts with whitespace. This allows you to paste
860 indented input from any editor without manually having to type in
866 indented input from any editor without manually having to type in
861 the 'if 1:', which is convenient when working interactively.
867 the 'if 1:', which is convenient when working interactively.
862 Slightly modifed version of a patch by Bo Peng
868 Slightly modifed version of a patch by Bo Peng
863 <bpeng-AT-rice.edu>.
869 <bpeng-AT-rice.edu>.
864
870
865 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
871 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
866
872
867 * IPython/irunner.py (main): modified irunner so it automatically
873 * IPython/irunner.py (main): modified irunner so it automatically
868 recognizes the right runner to use based on the extension (.py for
874 recognizes the right runner to use based on the extension (.py for
869 python, .ipy for ipython and .sage for sage).
875 python, .ipy for ipython and .sage for sage).
870
876
871 * IPython/iplib.py (InteractiveShell.ipconfig): new builtin, also
877 * IPython/iplib.py (InteractiveShell.ipconfig): new builtin, also
872 visible in ipapi as ip.config(), to programatically control the
878 visible in ipapi as ip.config(), to programatically control the
873 internal rc object. There's an accompanying %config magic for
879 internal rc object. There's an accompanying %config magic for
874 interactive use, which has been enhanced to match the
880 interactive use, which has been enhanced to match the
875 funtionality in ipconfig.
881 funtionality in ipconfig.
876
882
877 * IPython/Magic.py (magic_system_verbose): Change %system_verbose
883 * IPython/Magic.py (magic_system_verbose): Change %system_verbose
878 so it's not just a toggle, it now takes an argument. Add support
884 so it's not just a toggle, it now takes an argument. Add support
879 for a customizable header when making system calls, as the new
885 for a customizable header when making system calls, as the new
880 system_header variable in the ipythonrc file.
886 system_header variable in the ipythonrc file.
881
887
882 2006-11-03 Walter Doerwald <walter@livinglogic.de>
888 2006-11-03 Walter Doerwald <walter@livinglogic.de>
883
889
884 * IPython/Extensions/ipipe.py: xrepr(), xiter() and xattrs() are now
890 * IPython/Extensions/ipipe.py: xrepr(), xiter() and xattrs() are now
885 generic functions (using Philip J. Eby's simplegeneric package).
891 generic functions (using Philip J. Eby's simplegeneric package).
886 This makes it possible to customize the display of third-party classes
892 This makes it possible to customize the display of third-party classes
887 without having to monkeypatch them. xiter() no longer supports a mode
893 without having to monkeypatch them. xiter() no longer supports a mode
888 argument and the XMode class has been removed. The same functionality can
894 argument and the XMode class has been removed. The same functionality can
889 be implemented via IterAttributeDescriptor and IterMethodDescriptor.
895 be implemented via IterAttributeDescriptor and IterMethodDescriptor.
890 One consequence of the switch to generic functions is that xrepr() and
896 One consequence of the switch to generic functions is that xrepr() and
891 xattrs() implementation must define the default value for the mode
897 xattrs() implementation must define the default value for the mode
892 argument themselves and xattrs() implementations must return real
898 argument themselves and xattrs() implementations must return real
893 descriptors.
899 descriptors.
894
900
895 * IPython/external: This new subpackage will contain all third-party
901 * IPython/external: This new subpackage will contain all third-party
896 packages that are bundled with IPython. (The first one is simplegeneric).
902 packages that are bundled with IPython. (The first one is simplegeneric).
897
903
898 * IPython/Extensions/ipipe.py (ifile/ils): Readd output of the parent
904 * IPython/Extensions/ipipe.py (ifile/ils): Readd output of the parent
899 directory which as been dropped in r1703.
905 directory which as been dropped in r1703.
900
906
901 * IPython/Extensions/ipipe.py (iless): Fixed.
907 * IPython/Extensions/ipipe.py (iless): Fixed.
902
908
903 * IPython/Extensions/ibrowse: Fixed sorting under Python 2.3.
909 * IPython/Extensions/ibrowse: Fixed sorting under Python 2.3.
904
910
905 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
911 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
906
912
907 * IPython/iplib.py (InteractiveShell.var_expand): fix stack
913 * IPython/iplib.py (InteractiveShell.var_expand): fix stack
908 handling in variable expansion so that shells and magics recognize
914 handling in variable expansion so that shells and magics recognize
909 function local scopes correctly. Bug reported by Brian.
915 function local scopes correctly. Bug reported by Brian.
910
916
911 * scripts/ipython: remove the very first entry in sys.path which
917 * scripts/ipython: remove the very first entry in sys.path which
912 Python auto-inserts for scripts, so that sys.path under IPython is
918 Python auto-inserts for scripts, so that sys.path under IPython is
913 as similar as possible to that under plain Python.
919 as similar as possible to that under plain Python.
914
920
915 * IPython/completer.py (IPCompleter.file_matches): Fix
921 * IPython/completer.py (IPCompleter.file_matches): Fix
916 tab-completion so that quotes are not closed unless the completion
922 tab-completion so that quotes are not closed unless the completion
917 is unambiguous. After a request by Stefan. Minor cleanups in
923 is unambiguous. After a request by Stefan. Minor cleanups in
918 ipy_stock_completers.
924 ipy_stock_completers.
919
925
920 2006-11-02 Ville Vainio <vivainio@gmail.com>
926 2006-11-02 Ville Vainio <vivainio@gmail.com>
921
927
922 * ipy_stock_completers.py: Add %run and %cd completers.
928 * ipy_stock_completers.py: Add %run and %cd completers.
923
929
924 * completer.py: Try running custom completer for both
930 * completer.py: Try running custom completer for both
925 "foo" and "%foo" if the command is just "foo". Ignore case
931 "foo" and "%foo" if the command is just "foo". Ignore case
926 when filtering possible completions.
932 when filtering possible completions.
927
933
928 * UserConfig/ipy_user_conf.py: install stock completers as default
934 * UserConfig/ipy_user_conf.py: install stock completers as default
929
935
930 * iplib.py (history_saving_wrapper), debugger(), ipy_pydb.py:
936 * iplib.py (history_saving_wrapper), debugger(), ipy_pydb.py:
931 simplified readline history save / restore through a wrapper
937 simplified readline history save / restore through a wrapper
932 function
938 function
933
939
934
940
935 2006-10-31 Ville Vainio <vivainio@gmail.com>
941 2006-10-31 Ville Vainio <vivainio@gmail.com>
936
942
937 * strdispatch.py, completer.py, ipy_stock_completers.py:
943 * strdispatch.py, completer.py, ipy_stock_completers.py:
938 Allow str_key ("command") in completer hooks. Implement
944 Allow str_key ("command") in completer hooks. Implement
939 trivial completer for 'import' (stdlib modules only). Rename
945 trivial completer for 'import' (stdlib modules only). Rename
940 ipy_linux_package_managers.py to ipy_stock_completers.py.
946 ipy_linux_package_managers.py to ipy_stock_completers.py.
941 SVN completer.
947 SVN completer.
942
948
943 * Extensions/ledit.py: %magic line editor for easily and
949 * Extensions/ledit.py: %magic line editor for easily and
944 incrementally manipulating lists of strings. The magic command
950 incrementally manipulating lists of strings. The magic command
945 name is %led.
951 name is %led.
946
952
947 2006-10-30 Ville Vainio <vivainio@gmail.com>
953 2006-10-30 Ville Vainio <vivainio@gmail.com>
948
954
949 * Debugger.py, iplib.py (debugger()): Add last set of Rocky
955 * Debugger.py, iplib.py (debugger()): Add last set of Rocky
950 Bernsteins's patches for pydb integration.
956 Bernsteins's patches for pydb integration.
951 http://bashdb.sourceforge.net/pydb/
957 http://bashdb.sourceforge.net/pydb/
952
958
953 * strdispatch.py, iplib.py, completer.py, IPython/__init__.py,
959 * strdispatch.py, iplib.py, completer.py, IPython/__init__.py,
954 Extensions/ipy_linux_package_managers.py, hooks.py: Implement
960 Extensions/ipy_linux_package_managers.py, hooks.py: Implement
955 custom completer hook to allow the users to implement their own
961 custom completer hook to allow the users to implement their own
956 completers. See ipy_linux_package_managers.py for example. The
962 completers. See ipy_linux_package_managers.py for example. The
957 hook name is 'complete_command'.
963 hook name is 'complete_command'.
958
964
959 2006-10-28 Fernando Perez <Fernando.Perez@colorado.edu>
965 2006-10-28 Fernando Perez <Fernando.Perez@colorado.edu>
960
966
961 * IPython/UserConfig/ipythonrc-scipy: minor cleanups to remove old
967 * IPython/UserConfig/ipythonrc-scipy: minor cleanups to remove old
962 Numeric leftovers.
968 Numeric leftovers.
963
969
964 * ipython.el (py-execute-region): apply Stefan's patch to fix
970 * ipython.el (py-execute-region): apply Stefan's patch to fix
965 garbled results if the python shell hasn't been previously started.
971 garbled results if the python shell hasn't been previously started.
966
972
967 * IPython/genutils.py (arg_split): moved to genutils, since it's a
973 * IPython/genutils.py (arg_split): moved to genutils, since it's a
968 pretty generic function and useful for other things.
974 pretty generic function and useful for other things.
969
975
970 * IPython/OInspect.py (getsource): Add customizable source
976 * IPython/OInspect.py (getsource): Add customizable source
971 extractor. After a request/patch form W. Stein (SAGE).
977 extractor. After a request/patch form W. Stein (SAGE).
972
978
973 * IPython/irunner.py (InteractiveRunner.run_source): reset tty
979 * IPython/irunner.py (InteractiveRunner.run_source): reset tty
974 window size to a more reasonable value from what pexpect does,
980 window size to a more reasonable value from what pexpect does,
975 since their choice causes wrapping bugs with long input lines.
981 since their choice causes wrapping bugs with long input lines.
976
982
977 2006-10-28 Ville Vainio <vivainio@gmail.com>
983 2006-10-28 Ville Vainio <vivainio@gmail.com>
978
984
979 * Magic.py (%run): Save and restore the readline history from
985 * Magic.py (%run): Save and restore the readline history from
980 file around %run commands to prevent side effects from
986 file around %run commands to prevent side effects from
981 %runned programs that might use readline (e.g. pydb).
987 %runned programs that might use readline (e.g. pydb).
982
988
983 * extensions/ipy_pydb.py: Adds %pydb magic when imported, for
989 * extensions/ipy_pydb.py: Adds %pydb magic when imported, for
984 invoking the pydb enhanced debugger.
990 invoking the pydb enhanced debugger.
985
991
986 2006-10-23 Walter Doerwald <walter@livinglogic.de>
992 2006-10-23 Walter Doerwald <walter@livinglogic.de>
987
993
988 * IPython/Extensions/ipipe.py (ifile): Remove all methods that
994 * IPython/Extensions/ipipe.py (ifile): Remove all methods that
989 call the base class method and propagate the return value to
995 call the base class method and propagate the return value to
990 ifile. This is now done by path itself.
996 ifile. This is now done by path itself.
991
997
992 2006-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
998 2006-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
993
999
994 * IPython/ipapi.py (IPApi.__init__): Added new entry to public
1000 * IPython/ipapi.py (IPApi.__init__): Added new entry to public
995 api: set_crash_handler(), to expose the ability to change the
1001 api: set_crash_handler(), to expose the ability to change the
996 internal crash handler.
1002 internal crash handler.
997
1003
998 * IPython/CrashHandler.py (CrashHandler.__init__): abstract out
1004 * IPython/CrashHandler.py (CrashHandler.__init__): abstract out
999 the various parameters of the crash handler so that apps using
1005 the various parameters of the crash handler so that apps using
1000 IPython as their engine can customize crash handling. Ipmlemented
1006 IPython as their engine can customize crash handling. Ipmlemented
1001 at the request of SAGE.
1007 at the request of SAGE.
1002
1008
1003 2006-10-14 Ville Vainio <vivainio@gmail.com>
1009 2006-10-14 Ville Vainio <vivainio@gmail.com>
1004
1010
1005 * Magic.py, ipython.el: applied first "safe" part of Rocky
1011 * Magic.py, ipython.el: applied first "safe" part of Rocky
1006 Bernstein's patch set for pydb integration.
1012 Bernstein's patch set for pydb integration.
1007
1013
1008 * Magic.py (%unalias, %alias): %store'd aliases can now be
1014 * Magic.py (%unalias, %alias): %store'd aliases can now be
1009 removed with '%unalias'. %alias w/o args now shows most
1015 removed with '%unalias'. %alias w/o args now shows most
1010 interesting (stored / manually defined) aliases last
1016 interesting (stored / manually defined) aliases last
1011 where they catch the eye w/o scrolling.
1017 where they catch the eye w/o scrolling.
1012
1018
1013 * Magic.py (%rehashx), ext_rehashdir.py: files with
1019 * Magic.py (%rehashx), ext_rehashdir.py: files with
1014 'py' extension are always considered executable, even
1020 'py' extension are always considered executable, even
1015 when not in PATHEXT environment variable.
1021 when not in PATHEXT environment variable.
1016
1022
1017 2006-10-12 Ville Vainio <vivainio@gmail.com>
1023 2006-10-12 Ville Vainio <vivainio@gmail.com>
1018
1024
1019 * jobctrl.py: Add new "jobctrl" extension for spawning background
1025 * jobctrl.py: Add new "jobctrl" extension for spawning background
1020 processes with "&find /". 'import jobctrl' to try it out. Requires
1026 processes with "&find /". 'import jobctrl' to try it out. Requires
1021 'subprocess' module, standard in python 2.4+.
1027 'subprocess' module, standard in python 2.4+.
1022
1028
1023 * iplib.py (expand_aliases, handle_alias): Aliases expand transitively,
1029 * iplib.py (expand_aliases, handle_alias): Aliases expand transitively,
1024 so if foo -> bar and bar -> baz, then foo -> baz.
1030 so if foo -> bar and bar -> baz, then foo -> baz.
1025
1031
1026 2006-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
1032 2006-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
1027
1033
1028 * IPython/Magic.py (Magic.parse_options): add a new posix option
1034 * IPython/Magic.py (Magic.parse_options): add a new posix option
1029 to allow parsing of input args in magics that doesn't strip quotes
1035 to allow parsing of input args in magics that doesn't strip quotes
1030 (if posix=False). This also closes %timeit bug reported by
1036 (if posix=False). This also closes %timeit bug reported by
1031 Stefan.
1037 Stefan.
1032
1038
1033 2006-10-03 Ville Vainio <vivainio@gmail.com>
1039 2006-10-03 Ville Vainio <vivainio@gmail.com>
1034
1040
1035 * iplib.py (raw_input, interact): Return ValueError catching for
1041 * iplib.py (raw_input, interact): Return ValueError catching for
1036 raw_input. Fixes infinite loop for sys.stdin.close() or
1042 raw_input. Fixes infinite loop for sys.stdin.close() or
1037 sys.stdout.close().
1043 sys.stdout.close().
1038
1044
1039 2006-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1045 2006-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1040
1046
1041 * IPython/irunner.py (InteractiveRunner.run_source): small fixes
1047 * IPython/irunner.py (InteractiveRunner.run_source): small fixes
1042 to help in handling doctests. irunner is now pretty useful for
1048 to help in handling doctests. irunner is now pretty useful for
1043 running standalone scripts and simulate a full interactive session
1049 running standalone scripts and simulate a full interactive session
1044 in a format that can be then pasted as a doctest.
1050 in a format that can be then pasted as a doctest.
1045
1051
1046 * IPython/iplib.py (InteractiveShell.__init__): Install exit/quit
1052 * IPython/iplib.py (InteractiveShell.__init__): Install exit/quit
1047 on top of the default (useless) ones. This also fixes the nasty
1053 on top of the default (useless) ones. This also fixes the nasty
1048 way in which 2.5's Quitter() exits (reverted [1785]).
1054 way in which 2.5's Quitter() exits (reverted [1785]).
1049
1055
1050 * IPython/Debugger.py (Pdb.__init__): Fix ipdb to work with python
1056 * IPython/Debugger.py (Pdb.__init__): Fix ipdb to work with python
1051 2.5.
1057 2.5.
1052
1058
1053 * IPython/ultraTB.py (TBTools.set_colors): Make sure that ipdb
1059 * IPython/ultraTB.py (TBTools.set_colors): Make sure that ipdb
1054 color scheme is updated as well when color scheme is changed
1060 color scheme is updated as well when color scheme is changed
1055 interactively.
1061 interactively.
1056
1062
1057 2006-09-27 Ville Vainio <vivainio@gmail.com>
1063 2006-09-27 Ville Vainio <vivainio@gmail.com>
1058
1064
1059 * iplib.py (raw_input): python 2.5 closes stdin on quit -> avoid
1065 * iplib.py (raw_input): python 2.5 closes stdin on quit -> avoid
1060 infinite loop and just exit. It's a hack, but will do for a while.
1066 infinite loop and just exit. It's a hack, but will do for a while.
1061
1067
1062 2006-08-25 Walter Doerwald <walter@livinglogic.de>
1068 2006-08-25 Walter Doerwald <walter@livinglogic.de>
1063
1069
1064 * IPython/Extensions/ipipe.py (ils): Add arguments dirs and files to
1070 * IPython/Extensions/ipipe.py (ils): Add arguments dirs and files to
1065 the constructor, this makes it possible to get a list of only directories
1071 the constructor, this makes it possible to get a list of only directories
1066 or only files.
1072 or only files.
1067
1073
1068 2006-08-12 Ville Vainio <vivainio@gmail.com>
1074 2006-08-12 Ville Vainio <vivainio@gmail.com>
1069
1075
1070 * Fakemodule.py, OInspect.py: Reverted 2006-08-11 mods,
1076 * Fakemodule.py, OInspect.py: Reverted 2006-08-11 mods,
1071 they broke unittest
1077 they broke unittest
1072
1078
1073 2006-08-11 Ville Vainio <vivainio@gmail.com>
1079 2006-08-11 Ville Vainio <vivainio@gmail.com>
1074
1080
1075 * Fakemodule.py, OInspect.py: remove 2006-08-09 monkepatch
1081 * Fakemodule.py, OInspect.py: remove 2006-08-09 monkepatch
1076 by resolving issue properly, i.e. by inheriting FakeModule
1082 by resolving issue properly, i.e. by inheriting FakeModule
1077 from types.ModuleType. Pickling ipython interactive data
1083 from types.ModuleType. Pickling ipython interactive data
1078 should still work as usual (testing appreciated).
1084 should still work as usual (testing appreciated).
1079
1085
1080 2006-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
1086 2006-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
1081
1087
1082 * IPython/OInspect.py: monkeypatch inspect from the stdlib if
1088 * IPython/OInspect.py: monkeypatch inspect from the stdlib if
1083 running under python 2.3 with code from 2.4 to fix a bug with
1089 running under python 2.3 with code from 2.4 to fix a bug with
1084 help(). Reported by the Debian maintainers, Norbert Tretkowski
1090 help(). Reported by the Debian maintainers, Norbert Tretkowski
1085 <norbert-AT-tretkowski.de> and Alexandre Fayolle
1091 <norbert-AT-tretkowski.de> and Alexandre Fayolle
1086 <afayolle-AT-debian.org>.
1092 <afayolle-AT-debian.org>.
1087
1093
1088 2006-08-04 Walter Doerwald <walter@livinglogic.de>
1094 2006-08-04 Walter Doerwald <walter@livinglogic.de>
1089
1095
1090 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
1096 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
1091 (which was displaying "quit" twice).
1097 (which was displaying "quit" twice).
1092
1098
1093 2006-07-28 Walter Doerwald <walter@livinglogic.de>
1099 2006-07-28 Walter Doerwald <walter@livinglogic.de>
1094
1100
1095 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
1101 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
1096 the mode argument).
1102 the mode argument).
1097
1103
1098 2006-07-27 Walter Doerwald <walter@livinglogic.de>
1104 2006-07-27 Walter Doerwald <walter@livinglogic.de>
1099
1105
1100 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
1106 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
1101 not running under IPython.
1107 not running under IPython.
1102
1108
1103 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
1109 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
1104 and make it iterable (iterating over the attribute itself). Add two new
1110 and make it iterable (iterating over the attribute itself). Add two new
1105 magic strings for __xattrs__(): If the string starts with "-", the attribute
1111 magic strings for __xattrs__(): If the string starts with "-", the attribute
1106 will not be displayed in ibrowse's detail view (but it can still be
1112 will not be displayed in ibrowse's detail view (but it can still be
1107 iterated over). This makes it possible to add attributes that are large
1113 iterated over). This makes it possible to add attributes that are large
1108 lists or generator methods to the detail view. Replace magic attribute names
1114 lists or generator methods to the detail view. Replace magic attribute names
1109 and _attrname() and _getattr() with "descriptors": For each type of magic
1115 and _attrname() and _getattr() with "descriptors": For each type of magic
1110 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
1116 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
1111 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
1117 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
1112 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
1118 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
1113 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
1119 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
1114 are still supported.
1120 are still supported.
1115
1121
1116 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
1122 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
1117 fails in ibrowse.fetch(), the exception object is added as the last item
1123 fails in ibrowse.fetch(), the exception object is added as the last item
1118 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
1124 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
1119 a generator throws an exception midway through execution.
1125 a generator throws an exception midway through execution.
1120
1126
1121 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
1127 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
1122 encoding into methods.
1128 encoding into methods.
1123
1129
1124 2006-07-26 Ville Vainio <vivainio@gmail.com>
1130 2006-07-26 Ville Vainio <vivainio@gmail.com>
1125
1131
1126 * iplib.py: history now stores multiline input as single
1132 * iplib.py: history now stores multiline input as single
1127 history entries. Patch by Jorgen Cederlof.
1133 history entries. Patch by Jorgen Cederlof.
1128
1134
1129 2006-07-18 Walter Doerwald <walter@livinglogic.de>
1135 2006-07-18 Walter Doerwald <walter@livinglogic.de>
1130
1136
1131 * IPython/Extensions/ibrowse.py: Make cursor visible over
1137 * IPython/Extensions/ibrowse.py: Make cursor visible over
1132 non existing attributes.
1138 non existing attributes.
1133
1139
1134 2006-07-14 Walter Doerwald <walter@livinglogic.de>
1140 2006-07-14 Walter Doerwald <walter@livinglogic.de>
1135
1141
1136 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
1142 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
1137 error output of the running command doesn't mess up the screen.
1143 error output of the running command doesn't mess up the screen.
1138
1144
1139 2006-07-13 Walter Doerwald <walter@livinglogic.de>
1145 2006-07-13 Walter Doerwald <walter@livinglogic.de>
1140
1146
1141 * IPython/Extensions/ipipe.py (isort): Make isort usable without
1147 * IPython/Extensions/ipipe.py (isort): Make isort usable without
1142 argument. This sorts the items themselves.
1148 argument. This sorts the items themselves.
1143
1149
1144 2006-07-12 Walter Doerwald <walter@livinglogic.de>
1150 2006-07-12 Walter Doerwald <walter@livinglogic.de>
1145
1151
1146 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
1152 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
1147 Compile expression strings into code objects. This should speed
1153 Compile expression strings into code objects. This should speed
1148 up ifilter and friends somewhat.
1154 up ifilter and friends somewhat.
1149
1155
1150 2006-07-08 Ville Vainio <vivainio@gmail.com>
1156 2006-07-08 Ville Vainio <vivainio@gmail.com>
1151
1157
1152 * Magic.py: %cpaste now strips > from the beginning of lines
1158 * Magic.py: %cpaste now strips > from the beginning of lines
1153 to ease pasting quoted code from emails. Contributed by
1159 to ease pasting quoted code from emails. Contributed by
1154 Stefan van der Walt.
1160 Stefan van der Walt.
1155
1161
1156 2006-06-29 Ville Vainio <vivainio@gmail.com>
1162 2006-06-29 Ville Vainio <vivainio@gmail.com>
1157
1163
1158 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
1164 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
1159 mode, patch contributed by Darren Dale. NEEDS TESTING!
1165 mode, patch contributed by Darren Dale. NEEDS TESTING!
1160
1166
1161 2006-06-28 Walter Doerwald <walter@livinglogic.de>
1167 2006-06-28 Walter Doerwald <walter@livinglogic.de>
1162
1168
1163 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
1169 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
1164 a blue background. Fix fetching new display rows when the browser
1170 a blue background. Fix fetching new display rows when the browser
1165 scrolls more than a screenful (e.g. by using the goto command).
1171 scrolls more than a screenful (e.g. by using the goto command).
1166
1172
1167 2006-06-27 Ville Vainio <vivainio@gmail.com>
1173 2006-06-27 Ville Vainio <vivainio@gmail.com>
1168
1174
1169 * Magic.py (_inspect, _ofind) Apply David Huard's
1175 * Magic.py (_inspect, _ofind) Apply David Huard's
1170 patch for displaying the correct docstring for 'property'
1176 patch for displaying the correct docstring for 'property'
1171 attributes.
1177 attributes.
1172
1178
1173 2006-06-23 Walter Doerwald <walter@livinglogic.de>
1179 2006-06-23 Walter Doerwald <walter@livinglogic.de>
1174
1180
1175 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
1181 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
1176 commands into the methods implementing them.
1182 commands into the methods implementing them.
1177
1183
1178 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
1184 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
1179
1185
1180 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
1186 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
1181 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
1187 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
1182 autoindent support was authored by Jin Liu.
1188 autoindent support was authored by Jin Liu.
1183
1189
1184 2006-06-22 Walter Doerwald <walter@livinglogic.de>
1190 2006-06-22 Walter Doerwald <walter@livinglogic.de>
1185
1191
1186 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
1192 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
1187 for keymaps with a custom class that simplifies handling.
1193 for keymaps with a custom class that simplifies handling.
1188
1194
1189 2006-06-19 Walter Doerwald <walter@livinglogic.de>
1195 2006-06-19 Walter Doerwald <walter@livinglogic.de>
1190
1196
1191 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
1197 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
1192 resizing. This requires Python 2.5 to work.
1198 resizing. This requires Python 2.5 to work.
1193
1199
1194 2006-06-16 Walter Doerwald <walter@livinglogic.de>
1200 2006-06-16 Walter Doerwald <walter@livinglogic.de>
1195
1201
1196 * IPython/Extensions/ibrowse.py: Add two new commands to
1202 * IPython/Extensions/ibrowse.py: Add two new commands to
1197 ibrowse: "hideattr" (mapped to "h") hides the attribute under
1203 ibrowse: "hideattr" (mapped to "h") hides the attribute under
1198 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
1204 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
1199 attributes again. Remapped the help command to "?". Display
1205 attributes again. Remapped the help command to "?". Display
1200 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
1206 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
1201 as keys for the "home" and "end" commands. Add three new commands
1207 as keys for the "home" and "end" commands. Add three new commands
1202 to the input mode for "find" and friends: "delend" (CTRL-K)
1208 to the input mode for "find" and friends: "delend" (CTRL-K)
1203 deletes to the end of line. "incsearchup" searches upwards in the
1209 deletes to the end of line. "incsearchup" searches upwards in the
1204 command history for an input that starts with the text before the cursor.
1210 command history for an input that starts with the text before the cursor.
1205 "incsearchdown" does the same downwards. Removed a bogus mapping of
1211 "incsearchdown" does the same downwards. Removed a bogus mapping of
1206 the x key to "delete".
1212 the x key to "delete".
1207
1213
1208 2006-06-15 Ville Vainio <vivainio@gmail.com>
1214 2006-06-15 Ville Vainio <vivainio@gmail.com>
1209
1215
1210 * iplib.py, hooks.py: Added new generate_prompt hook that can be
1216 * iplib.py, hooks.py: Added new generate_prompt hook that can be
1211 used to create prompts dynamically, instead of the "old" way of
1217 used to create prompts dynamically, instead of the "old" way of
1212 assigning "magic" strings to prompt_in1 and prompt_in2. The old
1218 assigning "magic" strings to prompt_in1 and prompt_in2. The old
1213 way still works (it's invoked by the default hook), of course.
1219 way still works (it's invoked by the default hook), of course.
1214
1220
1215 * Prompts.py: added generate_output_prompt hook for altering output
1221 * Prompts.py: added generate_output_prompt hook for altering output
1216 prompt
1222 prompt
1217
1223
1218 * Release.py: Changed version string to 0.7.3.svn.
1224 * Release.py: Changed version string to 0.7.3.svn.
1219
1225
1220 2006-06-15 Walter Doerwald <walter@livinglogic.de>
1226 2006-06-15 Walter Doerwald <walter@livinglogic.de>
1221
1227
1222 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
1228 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
1223 the call to fetch() always tries to fetch enough data for at least one
1229 the call to fetch() always tries to fetch enough data for at least one
1224 full screen. This makes it possible to simply call moveto(0,0,True) in
1230 full screen. This makes it possible to simply call moveto(0,0,True) in
1225 the constructor. Fix typos and removed the obsolete goto attribute.
1231 the constructor. Fix typos and removed the obsolete goto attribute.
1226
1232
1227 2006-06-12 Ville Vainio <vivainio@gmail.com>
1233 2006-06-12 Ville Vainio <vivainio@gmail.com>
1228
1234
1229 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
1235 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
1230 allowing $variable interpolation within multiline statements,
1236 allowing $variable interpolation within multiline statements,
1231 though so far only with "sh" profile for a testing period.
1237 though so far only with "sh" profile for a testing period.
1232 The patch also enables splitting long commands with \ but it
1238 The patch also enables splitting long commands with \ but it
1233 doesn't work properly yet.
1239 doesn't work properly yet.
1234
1240
1235 2006-06-12 Walter Doerwald <walter@livinglogic.de>
1241 2006-06-12 Walter Doerwald <walter@livinglogic.de>
1236
1242
1237 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
1243 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
1238 input history and the position of the cursor in the input history for
1244 input history and the position of the cursor in the input history for
1239 the find, findbackwards and goto command.
1245 the find, findbackwards and goto command.
1240
1246
1241 2006-06-10 Walter Doerwald <walter@livinglogic.de>
1247 2006-06-10 Walter Doerwald <walter@livinglogic.de>
1242
1248
1243 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
1249 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
1244 implements the basic functionality of browser commands that require
1250 implements the basic functionality of browser commands that require
1245 input. Reimplement the goto, find and findbackwards commands as
1251 input. Reimplement the goto, find and findbackwards commands as
1246 subclasses of _CommandInput. Add an input history and keymaps to those
1252 subclasses of _CommandInput. Add an input history and keymaps to those
1247 commands. Add "\r" as a keyboard shortcut for the enterdefault and
1253 commands. Add "\r" as a keyboard shortcut for the enterdefault and
1248 execute commands.
1254 execute commands.
1249
1255
1250 2006-06-07 Ville Vainio <vivainio@gmail.com>
1256 2006-06-07 Ville Vainio <vivainio@gmail.com>
1251
1257
1252 * iplib.py: ipython mybatch.ipy exits ipython immediately after
1258 * iplib.py: ipython mybatch.ipy exits ipython immediately after
1253 running the batch files instead of leaving the session open.
1259 running the batch files instead of leaving the session open.
1254
1260
1255 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
1261 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
1256
1262
1257 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
1263 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
1258 the original fix was incomplete. Patch submitted by W. Maier.
1264 the original fix was incomplete. Patch submitted by W. Maier.
1259
1265
1260 2006-06-07 Ville Vainio <vivainio@gmail.com>
1266 2006-06-07 Ville Vainio <vivainio@gmail.com>
1261
1267
1262 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
1268 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
1263 Confirmation prompts can be supressed by 'quiet' option.
1269 Confirmation prompts can be supressed by 'quiet' option.
1264 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
1270 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
1265
1271
1266 2006-06-06 *** Released version 0.7.2
1272 2006-06-06 *** Released version 0.7.2
1267
1273
1268 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
1274 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
1269
1275
1270 * IPython/Release.py (version): Made 0.7.2 final for release.
1276 * IPython/Release.py (version): Made 0.7.2 final for release.
1271 Repo tagged and release cut.
1277 Repo tagged and release cut.
1272
1278
1273 2006-06-05 Ville Vainio <vivainio@gmail.com>
1279 2006-06-05 Ville Vainio <vivainio@gmail.com>
1274
1280
1275 * Magic.py (magic_rehashx): Honor no_alias list earlier in
1281 * Magic.py (magic_rehashx): Honor no_alias list earlier in
1276 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
1282 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
1277
1283
1278 * upgrade_dir.py: try import 'path' module a bit harder
1284 * upgrade_dir.py: try import 'path' module a bit harder
1279 (for %upgrade)
1285 (for %upgrade)
1280
1286
1281 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
1287 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
1282
1288
1283 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
1289 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
1284 instead of looping 20 times.
1290 instead of looping 20 times.
1285
1291
1286 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
1292 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
1287 correctly at initialization time. Bug reported by Krishna Mohan
1293 correctly at initialization time. Bug reported by Krishna Mohan
1288 Gundu <gkmohan-AT-gmail.com> on the user list.
1294 Gundu <gkmohan-AT-gmail.com> on the user list.
1289
1295
1290 * IPython/Release.py (version): Mark 0.7.2 version to start
1296 * IPython/Release.py (version): Mark 0.7.2 version to start
1291 testing for release on 06/06.
1297 testing for release on 06/06.
1292
1298
1293 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
1299 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
1294
1300
1295 * scripts/irunner: thin script interface so users don't have to
1301 * scripts/irunner: thin script interface so users don't have to
1296 find the module and call it as an executable, since modules rarely
1302 find the module and call it as an executable, since modules rarely
1297 live in people's PATH.
1303 live in people's PATH.
1298
1304
1299 * IPython/irunner.py (InteractiveRunner.__init__): added
1305 * IPython/irunner.py (InteractiveRunner.__init__): added
1300 delaybeforesend attribute to control delays with newer versions of
1306 delaybeforesend attribute to control delays with newer versions of
1301 pexpect. Thanks to detailed help from pexpect's author, Noah
1307 pexpect. Thanks to detailed help from pexpect's author, Noah
1302 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
1308 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
1303 correctly (it works in NoColor mode).
1309 correctly (it works in NoColor mode).
1304
1310
1305 * IPython/iplib.py (handle_normal): fix nasty crash reported on
1311 * IPython/iplib.py (handle_normal): fix nasty crash reported on
1306 SAGE list, from improper log() calls.
1312 SAGE list, from improper log() calls.
1307
1313
1308 2006-05-31 Ville Vainio <vivainio@gmail.com>
1314 2006-05-31 Ville Vainio <vivainio@gmail.com>
1309
1315
1310 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
1316 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
1311 with args in parens to work correctly with dirs that have spaces.
1317 with args in parens to work correctly with dirs that have spaces.
1312
1318
1313 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
1319 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
1314
1320
1315 * IPython/Logger.py (Logger.logstart): add option to log raw input
1321 * IPython/Logger.py (Logger.logstart): add option to log raw input
1316 instead of the processed one. A -r flag was added to the
1322 instead of the processed one. A -r flag was added to the
1317 %logstart magic used for controlling logging.
1323 %logstart magic used for controlling logging.
1318
1324
1319 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
1325 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
1320
1326
1321 * IPython/iplib.py (InteractiveShell.__init__): add check for the
1327 * IPython/iplib.py (InteractiveShell.__init__): add check for the
1322 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
1328 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
1323 recognize the option. After a bug report by Will Maier. This
1329 recognize the option. After a bug report by Will Maier. This
1324 closes #64 (will do it after confirmation from W. Maier).
1330 closes #64 (will do it after confirmation from W. Maier).
1325
1331
1326 * IPython/irunner.py: New module to run scripts as if manually
1332 * IPython/irunner.py: New module to run scripts as if manually
1327 typed into an interactive environment, based on pexpect. After a
1333 typed into an interactive environment, based on pexpect. After a
1328 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
1334 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
1329 ipython-user list. Simple unittests in the tests/ directory.
1335 ipython-user list. Simple unittests in the tests/ directory.
1330
1336
1331 * tools/release: add Will Maier, OpenBSD port maintainer, to
1337 * tools/release: add Will Maier, OpenBSD port maintainer, to
1332 recepients list. We are now officially part of the OpenBSD ports:
1338 recepients list. We are now officially part of the OpenBSD ports:
1333 http://www.openbsd.org/ports.html ! Many thanks to Will for the
1339 http://www.openbsd.org/ports.html ! Many thanks to Will for the
1334 work.
1340 work.
1335
1341
1336 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
1342 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
1337
1343
1338 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
1344 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
1339 so that it doesn't break tkinter apps.
1345 so that it doesn't break tkinter apps.
1340
1346
1341 * IPython/iplib.py (_prefilter): fix bug where aliases would
1347 * IPython/iplib.py (_prefilter): fix bug where aliases would
1342 shadow variables when autocall was fully off. Reported by SAGE
1348 shadow variables when autocall was fully off. Reported by SAGE
1343 author William Stein.
1349 author William Stein.
1344
1350
1345 * IPython/OInspect.py (Inspector.__init__): add a flag to control
1351 * IPython/OInspect.py (Inspector.__init__): add a flag to control
1346 at what detail level strings are computed when foo? is requested.
1352 at what detail level strings are computed when foo? is requested.
1347 This allows users to ask for example that the string form of an
1353 This allows users to ask for example that the string form of an
1348 object is only computed when foo?? is called, or even never, by
1354 object is only computed when foo?? is called, or even never, by
1349 setting the object_info_string_level >= 2 in the configuration
1355 setting the object_info_string_level >= 2 in the configuration
1350 file. This new option has been added and documented. After a
1356 file. This new option has been added and documented. After a
1351 request by SAGE to be able to control the printing of very large
1357 request by SAGE to be able to control the printing of very large
1352 objects more easily.
1358 objects more easily.
1353
1359
1354 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
1360 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
1355
1361
1356 * IPython/ipmaker.py (make_IPython): remove the ipython call path
1362 * IPython/ipmaker.py (make_IPython): remove the ipython call path
1357 from sys.argv, to be 100% consistent with how Python itself works
1363 from sys.argv, to be 100% consistent with how Python itself works
1358 (as seen for example with python -i file.py). After a bug report
1364 (as seen for example with python -i file.py). After a bug report
1359 by Jeffrey Collins.
1365 by Jeffrey Collins.
1360
1366
1361 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
1367 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
1362 nasty bug which was preventing custom namespaces with -pylab,
1368 nasty bug which was preventing custom namespaces with -pylab,
1363 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
1369 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
1364 compatibility (long gone from mpl).
1370 compatibility (long gone from mpl).
1365
1371
1366 * IPython/ipapi.py (make_session): name change: create->make. We
1372 * IPython/ipapi.py (make_session): name change: create->make. We
1367 use make in other places (ipmaker,...), it's shorter and easier to
1373 use make in other places (ipmaker,...), it's shorter and easier to
1368 type and say, etc. I'm trying to clean things before 0.7.2 so
1374 type and say, etc. I'm trying to clean things before 0.7.2 so
1369 that I can keep things stable wrt to ipapi in the chainsaw branch.
1375 that I can keep things stable wrt to ipapi in the chainsaw branch.
1370
1376
1371 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
1377 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
1372 python-mode recognizes our debugger mode. Add support for
1378 python-mode recognizes our debugger mode. Add support for
1373 autoindent inside (X)emacs. After a patch sent in by Jin Liu
1379 autoindent inside (X)emacs. After a patch sent in by Jin Liu
1374 <m.liu.jin-AT-gmail.com> originally written by
1380 <m.liu.jin-AT-gmail.com> originally written by
1375 doxgen-AT-newsmth.net (with minor modifications for xemacs
1381 doxgen-AT-newsmth.net (with minor modifications for xemacs
1376 compatibility)
1382 compatibility)
1377
1383
1378 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
1384 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
1379 tracebacks when walking the stack so that the stack tracking system
1385 tracebacks when walking the stack so that the stack tracking system
1380 in emacs' python-mode can identify the frames correctly.
1386 in emacs' python-mode can identify the frames correctly.
1381
1387
1382 * IPython/ipmaker.py (make_IPython): make the internal (and
1388 * IPython/ipmaker.py (make_IPython): make the internal (and
1383 default config) autoedit_syntax value false by default. Too many
1389 default config) autoedit_syntax value false by default. Too many
1384 users have complained to me (both on and off-list) about problems
1390 users have complained to me (both on and off-list) about problems
1385 with this option being on by default, so I'm making it default to
1391 with this option being on by default, so I'm making it default to
1386 off. It can still be enabled by anyone via the usual mechanisms.
1392 off. It can still be enabled by anyone via the usual mechanisms.
1387
1393
1388 * IPython/completer.py (Completer.attr_matches): add support for
1394 * IPython/completer.py (Completer.attr_matches): add support for
1389 PyCrust-style _getAttributeNames magic method. Patch contributed
1395 PyCrust-style _getAttributeNames magic method. Patch contributed
1390 by <mscott-AT-goldenspud.com>. Closes #50.
1396 by <mscott-AT-goldenspud.com>. Closes #50.
1391
1397
1392 * IPython/iplib.py (InteractiveShell.__init__): remove the
1398 * IPython/iplib.py (InteractiveShell.__init__): remove the
1393 deletion of exit/quit from __builtin__, which can break
1399 deletion of exit/quit from __builtin__, which can break
1394 third-party tools like the Zope debugging console. The
1400 third-party tools like the Zope debugging console. The
1395 %exit/%quit magics remain. In general, it's probably a good idea
1401 %exit/%quit magics remain. In general, it's probably a good idea
1396 not to delete anything from __builtin__, since we never know what
1402 not to delete anything from __builtin__, since we never know what
1397 that will break. In any case, python now (for 2.5) will support
1403 that will break. In any case, python now (for 2.5) will support
1398 'real' exit/quit, so this issue is moot. Closes #55.
1404 'real' exit/quit, so this issue is moot. Closes #55.
1399
1405
1400 * IPython/genutils.py (with_obj): rename the 'with' function to
1406 * IPython/genutils.py (with_obj): rename the 'with' function to
1401 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
1407 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
1402 becomes a language keyword. Closes #53.
1408 becomes a language keyword. Closes #53.
1403
1409
1404 * IPython/FakeModule.py (FakeModule.__init__): add a proper
1410 * IPython/FakeModule.py (FakeModule.__init__): add a proper
1405 __file__ attribute to this so it fools more things into thinking
1411 __file__ attribute to this so it fools more things into thinking
1406 it is a real module. Closes #59.
1412 it is a real module. Closes #59.
1407
1413
1408 * IPython/Magic.py (magic_edit): add -n option to open the editor
1414 * IPython/Magic.py (magic_edit): add -n option to open the editor
1409 at a specific line number. After a patch by Stefan van der Walt.
1415 at a specific line number. After a patch by Stefan van der Walt.
1410
1416
1411 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
1417 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
1412
1418
1413 * IPython/iplib.py (edit_syntax_error): fix crash when for some
1419 * IPython/iplib.py (edit_syntax_error): fix crash when for some
1414 reason the file could not be opened. After automatic crash
1420 reason the file could not be opened. After automatic crash
1415 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
1421 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
1416 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
1422 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
1417 (_should_recompile): Don't fire editor if using %bg, since there
1423 (_should_recompile): Don't fire editor if using %bg, since there
1418 is no file in the first place. From the same report as above.
1424 is no file in the first place. From the same report as above.
1419 (raw_input): protect against faulty third-party prefilters. After
1425 (raw_input): protect against faulty third-party prefilters. After
1420 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
1426 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
1421 while running under SAGE.
1427 while running under SAGE.
1422
1428
1423 2006-05-23 Ville Vainio <vivainio@gmail.com>
1429 2006-05-23 Ville Vainio <vivainio@gmail.com>
1424
1430
1425 * ipapi.py: Stripped down ip.to_user_ns() to work only as
1431 * ipapi.py: Stripped down ip.to_user_ns() to work only as
1426 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
1432 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
1427 now returns None (again), unless dummy is specifically allowed by
1433 now returns None (again), unless dummy is specifically allowed by
1428 ipapi.get(allow_dummy=True).
1434 ipapi.get(allow_dummy=True).
1429
1435
1430 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
1436 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
1431
1437
1432 * IPython: remove all 2.2-compatibility objects and hacks from
1438 * IPython: remove all 2.2-compatibility objects and hacks from
1433 everywhere, since we only support 2.3 at this point. Docs
1439 everywhere, since we only support 2.3 at this point. Docs
1434 updated.
1440 updated.
1435
1441
1436 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
1442 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
1437 Anything requiring extra validation can be turned into a Python
1443 Anything requiring extra validation can be turned into a Python
1438 property in the future. I used a property for the db one b/c
1444 property in the future. I used a property for the db one b/c
1439 there was a nasty circularity problem with the initialization
1445 there was a nasty circularity problem with the initialization
1440 order, which right now I don't have time to clean up.
1446 order, which right now I don't have time to clean up.
1441
1447
1442 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
1448 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
1443 another locking bug reported by Jorgen. I'm not 100% sure though,
1449 another locking bug reported by Jorgen. I'm not 100% sure though,
1444 so more testing is needed...
1450 so more testing is needed...
1445
1451
1446 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
1452 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
1447
1453
1448 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
1454 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
1449 local variables from any routine in user code (typically executed
1455 local variables from any routine in user code (typically executed
1450 with %run) directly into the interactive namespace. Very useful
1456 with %run) directly into the interactive namespace. Very useful
1451 when doing complex debugging.
1457 when doing complex debugging.
1452 (IPythonNotRunning): Changed the default None object to a dummy
1458 (IPythonNotRunning): Changed the default None object to a dummy
1453 whose attributes can be queried as well as called without
1459 whose attributes can be queried as well as called without
1454 exploding, to ease writing code which works transparently both in
1460 exploding, to ease writing code which works transparently both in
1455 and out of ipython and uses some of this API.
1461 and out of ipython and uses some of this API.
1456
1462
1457 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
1463 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
1458
1464
1459 * IPython/hooks.py (result_display): Fix the fact that our display
1465 * IPython/hooks.py (result_display): Fix the fact that our display
1460 hook was using str() instead of repr(), as the default python
1466 hook was using str() instead of repr(), as the default python
1461 console does. This had gone unnoticed b/c it only happened if
1467 console does. This had gone unnoticed b/c it only happened if
1462 %Pprint was off, but the inconsistency was there.
1468 %Pprint was off, but the inconsistency was there.
1463
1469
1464 2006-05-15 Ville Vainio <vivainio@gmail.com>
1470 2006-05-15 Ville Vainio <vivainio@gmail.com>
1465
1471
1466 * Oinspect.py: Only show docstring for nonexisting/binary files
1472 * Oinspect.py: Only show docstring for nonexisting/binary files
1467 when doing object??, closing ticket #62
1473 when doing object??, closing ticket #62
1468
1474
1469 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
1475 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
1470
1476
1471 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
1477 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
1472 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
1478 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
1473 was being released in a routine which hadn't checked if it had
1479 was being released in a routine which hadn't checked if it had
1474 been the one to acquire it.
1480 been the one to acquire it.
1475
1481
1476 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
1482 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
1477
1483
1478 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
1484 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
1479
1485
1480 2006-04-11 Ville Vainio <vivainio@gmail.com>
1486 2006-04-11 Ville Vainio <vivainio@gmail.com>
1481
1487
1482 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
1488 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
1483 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
1489 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
1484 prefilters, allowing stuff like magics and aliases in the file.
1490 prefilters, allowing stuff like magics and aliases in the file.
1485
1491
1486 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
1492 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
1487 added. Supported now are "%clear in" and "%clear out" (clear input and
1493 added. Supported now are "%clear in" and "%clear out" (clear input and
1488 output history, respectively). Also fixed CachedOutput.flush to
1494 output history, respectively). Also fixed CachedOutput.flush to
1489 properly flush the output cache.
1495 properly flush the output cache.
1490
1496
1491 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
1497 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
1492 half-success (and fail explicitly).
1498 half-success (and fail explicitly).
1493
1499
1494 2006-03-28 Ville Vainio <vivainio@gmail.com>
1500 2006-03-28 Ville Vainio <vivainio@gmail.com>
1495
1501
1496 * iplib.py: Fix quoting of aliases so that only argless ones
1502 * iplib.py: Fix quoting of aliases so that only argless ones
1497 are quoted
1503 are quoted
1498
1504
1499 2006-03-28 Ville Vainio <vivainio@gmail.com>
1505 2006-03-28 Ville Vainio <vivainio@gmail.com>
1500
1506
1501 * iplib.py: Quote aliases with spaces in the name.
1507 * iplib.py: Quote aliases with spaces in the name.
1502 "c:\program files\blah\bin" is now legal alias target.
1508 "c:\program files\blah\bin" is now legal alias target.
1503
1509
1504 * ext_rehashdir.py: Space no longer allowed as arg
1510 * ext_rehashdir.py: Space no longer allowed as arg
1505 separator, since space is legal in path names.
1511 separator, since space is legal in path names.
1506
1512
1507 2006-03-16 Ville Vainio <vivainio@gmail.com>
1513 2006-03-16 Ville Vainio <vivainio@gmail.com>
1508
1514
1509 * upgrade_dir.py: Take path.py from Extensions, correcting
1515 * upgrade_dir.py: Take path.py from Extensions, correcting
1510 %upgrade magic
1516 %upgrade magic
1511
1517
1512 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
1518 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
1513
1519
1514 * hooks.py: Only enclose editor binary in quotes if legal and
1520 * hooks.py: Only enclose editor binary in quotes if legal and
1515 necessary (space in the name, and is an existing file). Fixes a bug
1521 necessary (space in the name, and is an existing file). Fixes a bug
1516 reported by Zachary Pincus.
1522 reported by Zachary Pincus.
1517
1523
1518 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
1524 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
1519
1525
1520 * Manual: thanks to a tip on proper color handling for Emacs, by
1526 * Manual: thanks to a tip on proper color handling for Emacs, by
1521 Eric J Haywiser <ejh1-AT-MIT.EDU>.
1527 Eric J Haywiser <ejh1-AT-MIT.EDU>.
1522
1528
1523 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
1529 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
1524 by applying the provided patch. Thanks to Liu Jin
1530 by applying the provided patch. Thanks to Liu Jin
1525 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
1531 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
1526 XEmacs/Linux, I'm trusting the submitter that it actually helps
1532 XEmacs/Linux, I'm trusting the submitter that it actually helps
1527 under win32/GNU Emacs. Will revisit if any problems are reported.
1533 under win32/GNU Emacs. Will revisit if any problems are reported.
1528
1534
1529 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1535 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1530
1536
1531 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
1537 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
1532 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
1538 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
1533
1539
1534 2006-03-12 Ville Vainio <vivainio@gmail.com>
1540 2006-03-12 Ville Vainio <vivainio@gmail.com>
1535
1541
1536 * Magic.py (magic_timeit): Added %timeit magic, contributed by
1542 * Magic.py (magic_timeit): Added %timeit magic, contributed by
1537 Torsten Marek.
1543 Torsten Marek.
1538
1544
1539 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1545 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1540
1546
1541 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
1547 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
1542 line ranges works again.
1548 line ranges works again.
1543
1549
1544 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
1550 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
1545
1551
1546 * IPython/iplib.py (showtraceback): add back sys.last_traceback
1552 * IPython/iplib.py (showtraceback): add back sys.last_traceback
1547 and friends, after a discussion with Zach Pincus on ipython-user.
1553 and friends, after a discussion with Zach Pincus on ipython-user.
1548 I'm not 100% sure, but after thinking about it quite a bit, it may
1554 I'm not 100% sure, but after thinking about it quite a bit, it may
1549 be OK. Testing with the multithreaded shells didn't reveal any
1555 be OK. Testing with the multithreaded shells didn't reveal any
1550 problems, but let's keep an eye out.
1556 problems, but let's keep an eye out.
1551
1557
1552 In the process, I fixed a few things which were calling
1558 In the process, I fixed a few things which were calling
1553 self.InteractiveTB() directly (like safe_execfile), which is a
1559 self.InteractiveTB() directly (like safe_execfile), which is a
1554 mistake: ALL exception reporting should be done by calling
1560 mistake: ALL exception reporting should be done by calling
1555 self.showtraceback(), which handles state and tab-completion and
1561 self.showtraceback(), which handles state and tab-completion and
1556 more.
1562 more.
1557
1563
1558 2006-03-01 Ville Vainio <vivainio@gmail.com>
1564 2006-03-01 Ville Vainio <vivainio@gmail.com>
1559
1565
1560 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
1566 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
1561 To use, do "from ipipe import *".
1567 To use, do "from ipipe import *".
1562
1568
1563 2006-02-24 Ville Vainio <vivainio@gmail.com>
1569 2006-02-24 Ville Vainio <vivainio@gmail.com>
1564
1570
1565 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
1571 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
1566 "cleanly" and safely than the older upgrade mechanism.
1572 "cleanly" and safely than the older upgrade mechanism.
1567
1573
1568 2006-02-21 Ville Vainio <vivainio@gmail.com>
1574 2006-02-21 Ville Vainio <vivainio@gmail.com>
1569
1575
1570 * Magic.py: %save works again.
1576 * Magic.py: %save works again.
1571
1577
1572 2006-02-15 Ville Vainio <vivainio@gmail.com>
1578 2006-02-15 Ville Vainio <vivainio@gmail.com>
1573
1579
1574 * Magic.py: %Pprint works again
1580 * Magic.py: %Pprint works again
1575
1581
1576 * Extensions/ipy_sane_defaults.py: Provide everything provided
1582 * Extensions/ipy_sane_defaults.py: Provide everything provided
1577 in default ipythonrc, to make it possible to have a completely empty
1583 in default ipythonrc, to make it possible to have a completely empty
1578 ipythonrc (and thus completely rc-file free configuration)
1584 ipythonrc (and thus completely rc-file free configuration)
1579
1585
1580 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
1586 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
1581
1587
1582 * IPython/hooks.py (editor): quote the call to the editor command,
1588 * IPython/hooks.py (editor): quote the call to the editor command,
1583 to allow commands with spaces in them. Problem noted by watching
1589 to allow commands with spaces in them. Problem noted by watching
1584 Ian Oswald's video about textpad under win32 at
1590 Ian Oswald's video about textpad under win32 at
1585 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
1591 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
1586
1592
1587 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
1593 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
1588 describing magics (we haven't used @ for a loong time).
1594 describing magics (we haven't used @ for a loong time).
1589
1595
1590 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
1596 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
1591 contributed by marienz to close
1597 contributed by marienz to close
1592 http://www.scipy.net/roundup/ipython/issue53.
1598 http://www.scipy.net/roundup/ipython/issue53.
1593
1599
1594 2006-02-10 Ville Vainio <vivainio@gmail.com>
1600 2006-02-10 Ville Vainio <vivainio@gmail.com>
1595
1601
1596 * genutils.py: getoutput now works in win32 too
1602 * genutils.py: getoutput now works in win32 too
1597
1603
1598 * completer.py: alias and magic completion only invoked
1604 * completer.py: alias and magic completion only invoked
1599 at the first "item" in the line, to avoid "cd %store"
1605 at the first "item" in the line, to avoid "cd %store"
1600 nonsense.
1606 nonsense.
1601
1607
1602 2006-02-09 Ville Vainio <vivainio@gmail.com>
1608 2006-02-09 Ville Vainio <vivainio@gmail.com>
1603
1609
1604 * test/*: Added a unit testing framework (finally).
1610 * test/*: Added a unit testing framework (finally).
1605 '%run runtests.py' to run test_*.
1611 '%run runtests.py' to run test_*.
1606
1612
1607 * ipapi.py: Exposed runlines and set_custom_exc
1613 * ipapi.py: Exposed runlines and set_custom_exc
1608
1614
1609 2006-02-07 Ville Vainio <vivainio@gmail.com>
1615 2006-02-07 Ville Vainio <vivainio@gmail.com>
1610
1616
1611 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
1617 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
1612 instead use "f(1 2)" as before.
1618 instead use "f(1 2)" as before.
1613
1619
1614 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
1620 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
1615
1621
1616 * IPython/demo.py (IPythonDemo): Add new classes to the demo
1622 * IPython/demo.py (IPythonDemo): Add new classes to the demo
1617 facilities, for demos processed by the IPython input filter
1623 facilities, for demos processed by the IPython input filter
1618 (IPythonDemo), and for running a script one-line-at-a-time as a
1624 (IPythonDemo), and for running a script one-line-at-a-time as a
1619 demo, both for pure Python (LineDemo) and for IPython-processed
1625 demo, both for pure Python (LineDemo) and for IPython-processed
1620 input (IPythonLineDemo). After a request by Dave Kohel, from the
1626 input (IPythonLineDemo). After a request by Dave Kohel, from the
1621 SAGE team.
1627 SAGE team.
1622 (Demo.edit): added an edit() method to the demo objects, to edit
1628 (Demo.edit): added an edit() method to the demo objects, to edit
1623 the in-memory copy of the last executed block.
1629 the in-memory copy of the last executed block.
1624
1630
1625 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
1631 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
1626 processing to %edit, %macro and %save. These commands can now be
1632 processing to %edit, %macro and %save. These commands can now be
1627 invoked on the unprocessed input as it was typed by the user
1633 invoked on the unprocessed input as it was typed by the user
1628 (without any prefilters applied). After requests by the SAGE team
1634 (without any prefilters applied). After requests by the SAGE team
1629 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
1635 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
1630
1636
1631 2006-02-01 Ville Vainio <vivainio@gmail.com>
1637 2006-02-01 Ville Vainio <vivainio@gmail.com>
1632
1638
1633 * setup.py, eggsetup.py: easy_install ipython==dev works
1639 * setup.py, eggsetup.py: easy_install ipython==dev works
1634 correctly now (on Linux)
1640 correctly now (on Linux)
1635
1641
1636 * ipy_user_conf,ipmaker: user config changes, removed spurious
1642 * ipy_user_conf,ipmaker: user config changes, removed spurious
1637 warnings
1643 warnings
1638
1644
1639 * iplib: if rc.banner is string, use it as is.
1645 * iplib: if rc.banner is string, use it as is.
1640
1646
1641 * Magic: %pycat accepts a string argument and pages it's contents.
1647 * Magic: %pycat accepts a string argument and pages it's contents.
1642
1648
1643
1649
1644 2006-01-30 Ville Vainio <vivainio@gmail.com>
1650 2006-01-30 Ville Vainio <vivainio@gmail.com>
1645
1651
1646 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
1652 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
1647 Now %store and bookmarks work through PickleShare, meaning that
1653 Now %store and bookmarks work through PickleShare, meaning that
1648 concurrent access is possible and all ipython sessions see the
1654 concurrent access is possible and all ipython sessions see the
1649 same database situation all the time, instead of snapshot of
1655 same database situation all the time, instead of snapshot of
1650 the situation when the session was started. Hence, %bookmark
1656 the situation when the session was started. Hence, %bookmark
1651 results are immediately accessible from othes sessions. The database
1657 results are immediately accessible from othes sessions. The database
1652 is also available for use by user extensions. See:
1658 is also available for use by user extensions. See:
1653 http://www.python.org/pypi/pickleshare
1659 http://www.python.org/pypi/pickleshare
1654
1660
1655 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
1661 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
1656
1662
1657 * aliases can now be %store'd
1663 * aliases can now be %store'd
1658
1664
1659 * path.py moved to Extensions so that pickleshare does not need
1665 * path.py moved to Extensions so that pickleshare does not need
1660 IPython-specific import. Extensions added to pythonpath right
1666 IPython-specific import. Extensions added to pythonpath right
1661 at __init__.
1667 at __init__.
1662
1668
1663 * iplib.py: ipalias deprecated/redundant; aliases are converted and
1669 * iplib.py: ipalias deprecated/redundant; aliases are converted and
1664 called with _ip.system and the pre-transformed command string.
1670 called with _ip.system and the pre-transformed command string.
1665
1671
1666 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
1672 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
1667
1673
1668 * IPython/iplib.py (interact): Fix that we were not catching
1674 * IPython/iplib.py (interact): Fix that we were not catching
1669 KeyboardInterrupt exceptions properly. I'm not quite sure why the
1675 KeyboardInterrupt exceptions properly. I'm not quite sure why the
1670 logic here had to change, but it's fixed now.
1676 logic here had to change, but it's fixed now.
1671
1677
1672 2006-01-29 Ville Vainio <vivainio@gmail.com>
1678 2006-01-29 Ville Vainio <vivainio@gmail.com>
1673
1679
1674 * iplib.py: Try to import pyreadline on Windows.
1680 * iplib.py: Try to import pyreadline on Windows.
1675
1681
1676 2006-01-27 Ville Vainio <vivainio@gmail.com>
1682 2006-01-27 Ville Vainio <vivainio@gmail.com>
1677
1683
1678 * iplib.py: Expose ipapi as _ip in builtin namespace.
1684 * iplib.py: Expose ipapi as _ip in builtin namespace.
1679 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
1685 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
1680 and ip_set_hook (-> _ip.set_hook) redundant. % and !
1686 and ip_set_hook (-> _ip.set_hook) redundant. % and !
1681 syntax now produce _ip.* variant of the commands.
1687 syntax now produce _ip.* variant of the commands.
1682
1688
1683 * "_ip.options().autoedit_syntax = 2" automatically throws
1689 * "_ip.options().autoedit_syntax = 2" automatically throws
1684 user to editor for syntax error correction without prompting.
1690 user to editor for syntax error correction without prompting.
1685
1691
1686 2006-01-27 Ville Vainio <vivainio@gmail.com>
1692 2006-01-27 Ville Vainio <vivainio@gmail.com>
1687
1693
1688 * ipmaker.py: Give "realistic" sys.argv for scripts (without
1694 * ipmaker.py: Give "realistic" sys.argv for scripts (without
1689 'ipython' at argv[0]) executed through command line.
1695 'ipython' at argv[0]) executed through command line.
1690 NOTE: this DEPRECATES calling ipython with multiple scripts
1696 NOTE: this DEPRECATES calling ipython with multiple scripts
1691 ("ipython a.py b.py c.py")
1697 ("ipython a.py b.py c.py")
1692
1698
1693 * iplib.py, hooks.py: Added configurable input prefilter,
1699 * iplib.py, hooks.py: Added configurable input prefilter,
1694 named 'input_prefilter'. See ext_rescapture.py for example
1700 named 'input_prefilter'. See ext_rescapture.py for example
1695 usage.
1701 usage.
1696
1702
1697 * ext_rescapture.py, Magic.py: Better system command output capture
1703 * ext_rescapture.py, Magic.py: Better system command output capture
1698 through 'var = !ls' (deprecates user-visible %sc). Same notation
1704 through 'var = !ls' (deprecates user-visible %sc). Same notation
1699 applies for magics, 'var = %alias' assigns alias list to var.
1705 applies for magics, 'var = %alias' assigns alias list to var.
1700
1706
1701 * ipapi.py: added meta() for accessing extension-usable data store.
1707 * ipapi.py: added meta() for accessing extension-usable data store.
1702
1708
1703 * iplib.py: added InteractiveShell.getapi(). New magics should be
1709 * iplib.py: added InteractiveShell.getapi(). New magics should be
1704 written doing self.getapi() instead of using the shell directly.
1710 written doing self.getapi() instead of using the shell directly.
1705
1711
1706 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
1712 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
1707 %store foo >> ~/myfoo.txt to store variables to files (in clean
1713 %store foo >> ~/myfoo.txt to store variables to files (in clean
1708 textual form, not a restorable pickle).
1714 textual form, not a restorable pickle).
1709
1715
1710 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
1716 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
1711
1717
1712 * usage.py, Magic.py: added %quickref
1718 * usage.py, Magic.py: added %quickref
1713
1719
1714 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
1720 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
1715
1721
1716 * GetoptErrors when invoking magics etc. with wrong args
1722 * GetoptErrors when invoking magics etc. with wrong args
1717 are now more helpful:
1723 are now more helpful:
1718 GetoptError: option -l not recognized (allowed: "qb" )
1724 GetoptError: option -l not recognized (allowed: "qb" )
1719
1725
1720 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
1726 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
1721
1727
1722 * IPython/demo.py (Demo.show): Flush stdout after each block, so
1728 * IPython/demo.py (Demo.show): Flush stdout after each block, so
1723 computationally intensive blocks don't appear to stall the demo.
1729 computationally intensive blocks don't appear to stall the demo.
1724
1730
1725 2006-01-24 Ville Vainio <vivainio@gmail.com>
1731 2006-01-24 Ville Vainio <vivainio@gmail.com>
1726
1732
1727 * iplib.py, hooks.py: 'result_display' hook can return a non-None
1733 * iplib.py, hooks.py: 'result_display' hook can return a non-None
1728 value to manipulate resulting history entry.
1734 value to manipulate resulting history entry.
1729
1735
1730 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
1736 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
1731 to instance methods of IPApi class, to make extending an embedded
1737 to instance methods of IPApi class, to make extending an embedded
1732 IPython feasible. See ext_rehashdir.py for example usage.
1738 IPython feasible. See ext_rehashdir.py for example usage.
1733
1739
1734 * Merged 1071-1076 from branches/0.7.1
1740 * Merged 1071-1076 from branches/0.7.1
1735
1741
1736
1742
1737 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
1743 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
1738
1744
1739 * tools/release (daystamp): Fix build tools to use the new
1745 * tools/release (daystamp): Fix build tools to use the new
1740 eggsetup.py script to build lightweight eggs.
1746 eggsetup.py script to build lightweight eggs.
1741
1747
1742 * Applied changesets 1062 and 1064 before 0.7.1 release.
1748 * Applied changesets 1062 and 1064 before 0.7.1 release.
1743
1749
1744 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
1750 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
1745 see the raw input history (without conversions like %ls ->
1751 see the raw input history (without conversions like %ls ->
1746 ipmagic("ls")). After a request from W. Stein, SAGE
1752 ipmagic("ls")). After a request from W. Stein, SAGE
1747 (http://modular.ucsd.edu/sage) developer. This information is
1753 (http://modular.ucsd.edu/sage) developer. This information is
1748 stored in the input_hist_raw attribute of the IPython instance, so
1754 stored in the input_hist_raw attribute of the IPython instance, so
1749 developers can access it if needed (it's an InputList instance).
1755 developers can access it if needed (it's an InputList instance).
1750
1756
1751 * Versionstring = 0.7.2.svn
1757 * Versionstring = 0.7.2.svn
1752
1758
1753 * eggsetup.py: A separate script for constructing eggs, creates
1759 * eggsetup.py: A separate script for constructing eggs, creates
1754 proper launch scripts even on Windows (an .exe file in
1760 proper launch scripts even on Windows (an .exe file in
1755 \python24\scripts).
1761 \python24\scripts).
1756
1762
1757 * ipapi.py: launch_new_instance, launch entry point needed for the
1763 * ipapi.py: launch_new_instance, launch entry point needed for the
1758 egg.
1764 egg.
1759
1765
1760 2006-01-23 Ville Vainio <vivainio@gmail.com>
1766 2006-01-23 Ville Vainio <vivainio@gmail.com>
1761
1767
1762 * Added %cpaste magic for pasting python code
1768 * Added %cpaste magic for pasting python code
1763
1769
1764 2006-01-22 Ville Vainio <vivainio@gmail.com>
1770 2006-01-22 Ville Vainio <vivainio@gmail.com>
1765
1771
1766 * Merge from branches/0.7.1 into trunk, revs 1052-1057
1772 * Merge from branches/0.7.1 into trunk, revs 1052-1057
1767
1773
1768 * Versionstring = 0.7.2.svn
1774 * Versionstring = 0.7.2.svn
1769
1775
1770 * eggsetup.py: A separate script for constructing eggs, creates
1776 * eggsetup.py: A separate script for constructing eggs, creates
1771 proper launch scripts even on Windows (an .exe file in
1777 proper launch scripts even on Windows (an .exe file in
1772 \python24\scripts).
1778 \python24\scripts).
1773
1779
1774 * ipapi.py: launch_new_instance, launch entry point needed for the
1780 * ipapi.py: launch_new_instance, launch entry point needed for the
1775 egg.
1781 egg.
1776
1782
1777 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
1783 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
1778
1784
1779 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
1785 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
1780 %pfile foo would print the file for foo even if it was a binary.
1786 %pfile foo would print the file for foo even if it was a binary.
1781 Now, extensions '.so' and '.dll' are skipped.
1787 Now, extensions '.so' and '.dll' are skipped.
1782
1788
1783 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
1789 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
1784 bug, where macros would fail in all threaded modes. I'm not 100%
1790 bug, where macros would fail in all threaded modes. I'm not 100%
1785 sure, so I'm going to put out an rc instead of making a release
1791 sure, so I'm going to put out an rc instead of making a release
1786 today, and wait for feedback for at least a few days.
1792 today, and wait for feedback for at least a few days.
1787
1793
1788 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
1794 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
1789 it...) the handling of pasting external code with autoindent on.
1795 it...) the handling of pasting external code with autoindent on.
1790 To get out of a multiline input, the rule will appear for most
1796 To get out of a multiline input, the rule will appear for most
1791 users unchanged: two blank lines or change the indent level
1797 users unchanged: two blank lines or change the indent level
1792 proposed by IPython. But there is a twist now: you can
1798 proposed by IPython. But there is a twist now: you can
1793 add/subtract only *one or two spaces*. If you add/subtract three
1799 add/subtract only *one or two spaces*. If you add/subtract three
1794 or more (unless you completely delete the line), IPython will
1800 or more (unless you completely delete the line), IPython will
1795 accept that line, and you'll need to enter a second one of pure
1801 accept that line, and you'll need to enter a second one of pure
1796 whitespace. I know it sounds complicated, but I can't find a
1802 whitespace. I know it sounds complicated, but I can't find a
1797 different solution that covers all the cases, with the right
1803 different solution that covers all the cases, with the right
1798 heuristics. Hopefully in actual use, nobody will really notice
1804 heuristics. Hopefully in actual use, nobody will really notice
1799 all these strange rules and things will 'just work'.
1805 all these strange rules and things will 'just work'.
1800
1806
1801 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
1807 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
1802
1808
1803 * IPython/iplib.py (interact): catch exceptions which can be
1809 * IPython/iplib.py (interact): catch exceptions which can be
1804 triggered asynchronously by signal handlers. Thanks to an
1810 triggered asynchronously by signal handlers. Thanks to an
1805 automatic crash report, submitted by Colin Kingsley
1811 automatic crash report, submitted by Colin Kingsley
1806 <tercel-AT-gentoo.org>.
1812 <tercel-AT-gentoo.org>.
1807
1813
1808 2006-01-20 Ville Vainio <vivainio@gmail.com>
1814 2006-01-20 Ville Vainio <vivainio@gmail.com>
1809
1815
1810 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
1816 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
1811 (%rehashdir, very useful, try it out) of how to extend ipython
1817 (%rehashdir, very useful, try it out) of how to extend ipython
1812 with new magics. Also added Extensions dir to pythonpath to make
1818 with new magics. Also added Extensions dir to pythonpath to make
1813 importing extensions easy.
1819 importing extensions easy.
1814
1820
1815 * %store now complains when trying to store interactively declared
1821 * %store now complains when trying to store interactively declared
1816 classes / instances of those classes.
1822 classes / instances of those classes.
1817
1823
1818 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
1824 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
1819 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
1825 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
1820 if they exist, and ipy_user_conf.py with some defaults is created for
1826 if they exist, and ipy_user_conf.py with some defaults is created for
1821 the user.
1827 the user.
1822
1828
1823 * Startup rehashing done by the config file, not InterpreterExec.
1829 * Startup rehashing done by the config file, not InterpreterExec.
1824 This means system commands are available even without selecting the
1830 This means system commands are available even without selecting the
1825 pysh profile. It's the sensible default after all.
1831 pysh profile. It's the sensible default after all.
1826
1832
1827 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
1833 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
1828
1834
1829 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
1835 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
1830 multiline code with autoindent on working. But I am really not
1836 multiline code with autoindent on working. But I am really not
1831 sure, so this needs more testing. Will commit a debug-enabled
1837 sure, so this needs more testing. Will commit a debug-enabled
1832 version for now, while I test it some more, so that Ville and
1838 version for now, while I test it some more, so that Ville and
1833 others may also catch any problems. Also made
1839 others may also catch any problems. Also made
1834 self.indent_current_str() a method, to ensure that there's no
1840 self.indent_current_str() a method, to ensure that there's no
1835 chance of the indent space count and the corresponding string
1841 chance of the indent space count and the corresponding string
1836 falling out of sync. All code needing the string should just call
1842 falling out of sync. All code needing the string should just call
1837 the method.
1843 the method.
1838
1844
1839 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
1845 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
1840
1846
1841 * IPython/Magic.py (magic_edit): fix check for when users don't
1847 * IPython/Magic.py (magic_edit): fix check for when users don't
1842 save their output files, the try/except was in the wrong section.
1848 save their output files, the try/except was in the wrong section.
1843
1849
1844 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
1850 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
1845
1851
1846 * IPython/Magic.py (magic_run): fix __file__ global missing from
1852 * IPython/Magic.py (magic_run): fix __file__ global missing from
1847 script's namespace when executed via %run. After a report by
1853 script's namespace when executed via %run. After a report by
1848 Vivian.
1854 Vivian.
1849
1855
1850 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
1856 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
1851 when using python 2.4. The parent constructor changed in 2.4, and
1857 when using python 2.4. The parent constructor changed in 2.4, and
1852 we need to track it directly (we can't call it, as it messes up
1858 we need to track it directly (we can't call it, as it messes up
1853 readline and tab-completion inside our pdb would stop working).
1859 readline and tab-completion inside our pdb would stop working).
1854 After a bug report by R. Bernstein <rocky-AT-panix.com>.
1860 After a bug report by R. Bernstein <rocky-AT-panix.com>.
1855
1861
1856 2006-01-16 Ville Vainio <vivainio@gmail.com>
1862 2006-01-16 Ville Vainio <vivainio@gmail.com>
1857
1863
1858 * Ipython/magic.py: Reverted back to old %edit functionality
1864 * Ipython/magic.py: Reverted back to old %edit functionality
1859 that returns file contents on exit.
1865 that returns file contents on exit.
1860
1866
1861 * IPython/path.py: Added Jason Orendorff's "path" module to
1867 * IPython/path.py: Added Jason Orendorff's "path" module to
1862 IPython tree, http://www.jorendorff.com/articles/python/path/.
1868 IPython tree, http://www.jorendorff.com/articles/python/path/.
1863 You can get path objects conveniently through %sc, and !!, e.g.:
1869 You can get path objects conveniently through %sc, and !!, e.g.:
1864 sc files=ls
1870 sc files=ls
1865 for p in files.paths: # or files.p
1871 for p in files.paths: # or files.p
1866 print p,p.mtime
1872 print p,p.mtime
1867
1873
1868 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
1874 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
1869 now work again without considering the exclusion regexp -
1875 now work again without considering the exclusion regexp -
1870 hence, things like ',foo my/path' turn to 'foo("my/path")'
1876 hence, things like ',foo my/path' turn to 'foo("my/path")'
1871 instead of syntax error.
1877 instead of syntax error.
1872
1878
1873
1879
1874 2006-01-14 Ville Vainio <vivainio@gmail.com>
1880 2006-01-14 Ville Vainio <vivainio@gmail.com>
1875
1881
1876 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
1882 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
1877 ipapi decorators for python 2.4 users, options() provides access to rc
1883 ipapi decorators for python 2.4 users, options() provides access to rc
1878 data.
1884 data.
1879
1885
1880 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
1886 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
1881 as path separators (even on Linux ;-). Space character after
1887 as path separators (even on Linux ;-). Space character after
1882 backslash (as yielded by tab completer) is still space;
1888 backslash (as yielded by tab completer) is still space;
1883 "%cd long\ name" works as expected.
1889 "%cd long\ name" works as expected.
1884
1890
1885 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
1891 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
1886 as "chain of command", with priority. API stays the same,
1892 as "chain of command", with priority. API stays the same,
1887 TryNext exception raised by a hook function signals that
1893 TryNext exception raised by a hook function signals that
1888 current hook failed and next hook should try handling it, as
1894 current hook failed and next hook should try handling it, as
1889 suggested by Walter Dörwald <walter@livinglogic.de>. Walter also
1895 suggested by Walter Dörwald <walter@livinglogic.de>. Walter also
1890 requested configurable display hook, which is now implemented.
1896 requested configurable display hook, which is now implemented.
1891
1897
1892 2006-01-13 Ville Vainio <vivainio@gmail.com>
1898 2006-01-13 Ville Vainio <vivainio@gmail.com>
1893
1899
1894 * IPython/platutils*.py: platform specific utility functions,
1900 * IPython/platutils*.py: platform specific utility functions,
1895 so far only set_term_title is implemented (change terminal
1901 so far only set_term_title is implemented (change terminal
1896 label in windowing systems). %cd now changes the title to
1902 label in windowing systems). %cd now changes the title to
1897 current dir.
1903 current dir.
1898
1904
1899 * IPython/Release.py: Added myself to "authors" list,
1905 * IPython/Release.py: Added myself to "authors" list,
1900 had to create new files.
1906 had to create new files.
1901
1907
1902 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
1908 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
1903 shell escape; not a known bug but had potential to be one in the
1909 shell escape; not a known bug but had potential to be one in the
1904 future.
1910 future.
1905
1911
1906 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
1912 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
1907 extension API for IPython! See the module for usage example. Fix
1913 extension API for IPython! See the module for usage example. Fix
1908 OInspect for docstring-less magic functions.
1914 OInspect for docstring-less magic functions.
1909
1915
1910
1916
1911 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
1917 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
1912
1918
1913 * IPython/iplib.py (raw_input): temporarily deactivate all
1919 * IPython/iplib.py (raw_input): temporarily deactivate all
1914 attempts at allowing pasting of code with autoindent on. It
1920 attempts at allowing pasting of code with autoindent on. It
1915 introduced bugs (reported by Prabhu) and I can't seem to find a
1921 introduced bugs (reported by Prabhu) and I can't seem to find a
1916 robust combination which works in all cases. Will have to revisit
1922 robust combination which works in all cases. Will have to revisit
1917 later.
1923 later.
1918
1924
1919 * IPython/genutils.py: remove isspace() function. We've dropped
1925 * IPython/genutils.py: remove isspace() function. We've dropped
1920 2.2 compatibility, so it's OK to use the string method.
1926 2.2 compatibility, so it's OK to use the string method.
1921
1927
1922 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1928 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1923
1929
1924 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
1930 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
1925 matching what NOT to autocall on, to include all python binary
1931 matching what NOT to autocall on, to include all python binary
1926 operators (including things like 'and', 'or', 'is' and 'in').
1932 operators (including things like 'and', 'or', 'is' and 'in').
1927 Prompted by a bug report on 'foo & bar', but I realized we had
1933 Prompted by a bug report on 'foo & bar', but I realized we had
1928 many more potential bug cases with other operators. The regexp is
1934 many more potential bug cases with other operators. The regexp is
1929 self.re_exclude_auto, it's fairly commented.
1935 self.re_exclude_auto, it's fairly commented.
1930
1936
1931 2006-01-12 Ville Vainio <vivainio@gmail.com>
1937 2006-01-12 Ville Vainio <vivainio@gmail.com>
1932
1938
1933 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
1939 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
1934 Prettified and hardened string/backslash quoting with ipsystem(),
1940 Prettified and hardened string/backslash quoting with ipsystem(),
1935 ipalias() and ipmagic(). Now even \ characters are passed to
1941 ipalias() and ipmagic(). Now even \ characters are passed to
1936 %magics, !shell escapes and aliases exactly as they are in the
1942 %magics, !shell escapes and aliases exactly as they are in the
1937 ipython command line. Should improve backslash experience,
1943 ipython command line. Should improve backslash experience,
1938 particularly in Windows (path delimiter for some commands that
1944 particularly in Windows (path delimiter for some commands that
1939 won't understand '/'), but Unix benefits as well (regexps). %cd
1945 won't understand '/'), but Unix benefits as well (regexps). %cd
1940 magic still doesn't support backslash path delimiters, though. Also
1946 magic still doesn't support backslash path delimiters, though. Also
1941 deleted all pretense of supporting multiline command strings in
1947 deleted all pretense of supporting multiline command strings in
1942 !system or %magic commands. Thanks to Jerry McRae for suggestions.
1948 !system or %magic commands. Thanks to Jerry McRae for suggestions.
1943
1949
1944 * doc/build_doc_instructions.txt added. Documentation on how to
1950 * doc/build_doc_instructions.txt added. Documentation on how to
1945 use doc/update_manual.py, added yesterday. Both files contributed
1951 use doc/update_manual.py, added yesterday. Both files contributed
1946 by Jörgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
1952 by Jörgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
1947 doc/*.sh for deprecation at a later date.
1953 doc/*.sh for deprecation at a later date.
1948
1954
1949 * /ipython.py Added ipython.py to root directory for
1955 * /ipython.py Added ipython.py to root directory for
1950 zero-installation (tar xzvf ipython.tgz; cd ipython; python
1956 zero-installation (tar xzvf ipython.tgz; cd ipython; python
1951 ipython.py) and development convenience (no need to keep doing
1957 ipython.py) and development convenience (no need to keep doing
1952 "setup.py install" between changes).
1958 "setup.py install" between changes).
1953
1959
1954 * Made ! and !! shell escapes work (again) in multiline expressions:
1960 * Made ! and !! shell escapes work (again) in multiline expressions:
1955 if 1:
1961 if 1:
1956 !ls
1962 !ls
1957 !!ls
1963 !!ls
1958
1964
1959 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1965 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1960
1966
1961 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
1967 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
1962 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
1968 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
1963 module in case-insensitive installation. Was causing crashes
1969 module in case-insensitive installation. Was causing crashes
1964 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
1970 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
1965
1971
1966 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
1972 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
1967 <marienz-AT-gentoo.org>, closes
1973 <marienz-AT-gentoo.org>, closes
1968 http://www.scipy.net/roundup/ipython/issue51.
1974 http://www.scipy.net/roundup/ipython/issue51.
1969
1975
1970 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
1976 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
1971
1977
1972 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
1978 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
1973 problem of excessive CPU usage under *nix and keyboard lag under
1979 problem of excessive CPU usage under *nix and keyboard lag under
1974 win32.
1980 win32.
1975
1981
1976 2006-01-10 *** Released version 0.7.0
1982 2006-01-10 *** Released version 0.7.0
1977
1983
1978 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
1984 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
1979
1985
1980 * IPython/Release.py (revision): tag version number to 0.7.0,
1986 * IPython/Release.py (revision): tag version number to 0.7.0,
1981 ready for release.
1987 ready for release.
1982
1988
1983 * IPython/Magic.py (magic_edit): Add print statement to %edit so
1989 * IPython/Magic.py (magic_edit): Add print statement to %edit so
1984 it informs the user of the name of the temp. file used. This can
1990 it informs the user of the name of the temp. file used. This can
1985 help if you decide later to reuse that same file, so you know
1991 help if you decide later to reuse that same file, so you know
1986 where to copy the info from.
1992 where to copy the info from.
1987
1993
1988 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
1994 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
1989
1995
1990 * setup_bdist_egg.py: little script to build an egg. Added
1996 * setup_bdist_egg.py: little script to build an egg. Added
1991 support in the release tools as well.
1997 support in the release tools as well.
1992
1998
1993 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
1999 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
1994
2000
1995 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
2001 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
1996 version selection (new -wxversion command line and ipythonrc
2002 version selection (new -wxversion command line and ipythonrc
1997 parameter). Patch contributed by Arnd Baecker
2003 parameter). Patch contributed by Arnd Baecker
1998 <arnd.baecker-AT-web.de>.
2004 <arnd.baecker-AT-web.de>.
1999
2005
2000 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2006 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2001 embedded instances, for variables defined at the interactive
2007 embedded instances, for variables defined at the interactive
2002 prompt of the embedded ipython. Reported by Arnd.
2008 prompt of the embedded ipython. Reported by Arnd.
2003
2009
2004 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
2010 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
2005 it can be used as a (stateful) toggle, or with a direct parameter.
2011 it can be used as a (stateful) toggle, or with a direct parameter.
2006
2012
2007 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
2013 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
2008 could be triggered in certain cases and cause the traceback
2014 could be triggered in certain cases and cause the traceback
2009 printer not to work.
2015 printer not to work.
2010
2016
2011 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
2017 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
2012
2018
2013 * IPython/iplib.py (_should_recompile): Small fix, closes
2019 * IPython/iplib.py (_should_recompile): Small fix, closes
2014 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
2020 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
2015
2021
2016 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
2022 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
2017
2023
2018 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
2024 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
2019 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
2025 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
2020 Moad for help with tracking it down.
2026 Moad for help with tracking it down.
2021
2027
2022 * IPython/iplib.py (handle_auto): fix autocall handling for
2028 * IPython/iplib.py (handle_auto): fix autocall handling for
2023 objects which support BOTH __getitem__ and __call__ (so that f [x]
2029 objects which support BOTH __getitem__ and __call__ (so that f [x]
2024 is left alone, instead of becoming f([x]) automatically).
2030 is left alone, instead of becoming f([x]) automatically).
2025
2031
2026 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
2032 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
2027 Ville's patch.
2033 Ville's patch.
2028
2034
2029 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
2035 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
2030
2036
2031 * IPython/iplib.py (handle_auto): changed autocall semantics to
2037 * IPython/iplib.py (handle_auto): changed autocall semantics to
2032 include 'smart' mode, where the autocall transformation is NOT
2038 include 'smart' mode, where the autocall transformation is NOT
2033 applied if there are no arguments on the line. This allows you to
2039 applied if there are no arguments on the line. This allows you to
2034 just type 'foo' if foo is a callable to see its internal form,
2040 just type 'foo' if foo is a callable to see its internal form,
2035 instead of having it called with no arguments (typically a
2041 instead of having it called with no arguments (typically a
2036 mistake). The old 'full' autocall still exists: for that, you
2042 mistake). The old 'full' autocall still exists: for that, you
2037 need to set the 'autocall' parameter to 2 in your ipythonrc file.
2043 need to set the 'autocall' parameter to 2 in your ipythonrc file.
2038
2044
2039 * IPython/completer.py (Completer.attr_matches): add
2045 * IPython/completer.py (Completer.attr_matches): add
2040 tab-completion support for Enthoughts' traits. After a report by
2046 tab-completion support for Enthoughts' traits. After a report by
2041 Arnd and a patch by Prabhu.
2047 Arnd and a patch by Prabhu.
2042
2048
2043 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
2049 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
2044
2050
2045 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
2051 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
2046 Schmolck's patch to fix inspect.getinnerframes().
2052 Schmolck's patch to fix inspect.getinnerframes().
2047
2053
2048 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
2054 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
2049 for embedded instances, regarding handling of namespaces and items
2055 for embedded instances, regarding handling of namespaces and items
2050 added to the __builtin__ one. Multiple embedded instances and
2056 added to the __builtin__ one. Multiple embedded instances and
2051 recursive embeddings should work better now (though I'm not sure
2057 recursive embeddings should work better now (though I'm not sure
2052 I've got all the corner cases fixed, that code is a bit of a brain
2058 I've got all the corner cases fixed, that code is a bit of a brain
2053 twister).
2059 twister).
2054
2060
2055 * IPython/Magic.py (magic_edit): added support to edit in-memory
2061 * IPython/Magic.py (magic_edit): added support to edit in-memory
2056 macros (automatically creates the necessary temp files). %edit
2062 macros (automatically creates the necessary temp files). %edit
2057 also doesn't return the file contents anymore, it's just noise.
2063 also doesn't return the file contents anymore, it's just noise.
2058
2064
2059 * IPython/completer.py (Completer.attr_matches): revert change to
2065 * IPython/completer.py (Completer.attr_matches): revert change to
2060 complete only on attributes listed in __all__. I realized it
2066 complete only on attributes listed in __all__. I realized it
2061 cripples the tab-completion system as a tool for exploring the
2067 cripples the tab-completion system as a tool for exploring the
2062 internals of unknown libraries (it renders any non-__all__
2068 internals of unknown libraries (it renders any non-__all__
2063 attribute off-limits). I got bit by this when trying to see
2069 attribute off-limits). I got bit by this when trying to see
2064 something inside the dis module.
2070 something inside the dis module.
2065
2071
2066 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
2072 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
2067
2073
2068 * IPython/iplib.py (InteractiveShell.__init__): add .meta
2074 * IPython/iplib.py (InteractiveShell.__init__): add .meta
2069 namespace for users and extension writers to hold data in. This
2075 namespace for users and extension writers to hold data in. This
2070 follows the discussion in
2076 follows the discussion in
2071 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
2077 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
2072
2078
2073 * IPython/completer.py (IPCompleter.complete): small patch to help
2079 * IPython/completer.py (IPCompleter.complete): small patch to help
2074 tab-completion under Emacs, after a suggestion by John Barnard
2080 tab-completion under Emacs, after a suggestion by John Barnard
2075 <barnarj-AT-ccf.org>.
2081 <barnarj-AT-ccf.org>.
2076
2082
2077 * IPython/Magic.py (Magic.extract_input_slices): added support for
2083 * IPython/Magic.py (Magic.extract_input_slices): added support for
2078 the slice notation in magics to use N-M to represent numbers N...M
2084 the slice notation in magics to use N-M to represent numbers N...M
2079 (closed endpoints). This is used by %macro and %save.
2085 (closed endpoints). This is used by %macro and %save.
2080
2086
2081 * IPython/completer.py (Completer.attr_matches): for modules which
2087 * IPython/completer.py (Completer.attr_matches): for modules which
2082 define __all__, complete only on those. After a patch by Jeffrey
2088 define __all__, complete only on those. After a patch by Jeffrey
2083 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
2089 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
2084 speed up this routine.
2090 speed up this routine.
2085
2091
2086 * IPython/Logger.py (Logger.log): fix a history handling bug. I
2092 * IPython/Logger.py (Logger.log): fix a history handling bug. I
2087 don't know if this is the end of it, but the behavior now is
2093 don't know if this is the end of it, but the behavior now is
2088 certainly much more correct. Note that coupled with macros,
2094 certainly much more correct. Note that coupled with macros,
2089 slightly surprising (at first) behavior may occur: a macro will in
2095 slightly surprising (at first) behavior may occur: a macro will in
2090 general expand to multiple lines of input, so upon exiting, the
2096 general expand to multiple lines of input, so upon exiting, the
2091 in/out counters will both be bumped by the corresponding amount
2097 in/out counters will both be bumped by the corresponding amount
2092 (as if the macro's contents had been typed interactively). Typing
2098 (as if the macro's contents had been typed interactively). Typing
2093 %hist will reveal the intermediate (silently processed) lines.
2099 %hist will reveal the intermediate (silently processed) lines.
2094
2100
2095 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
2101 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
2096 pickle to fail (%run was overwriting __main__ and not restoring
2102 pickle to fail (%run was overwriting __main__ and not restoring
2097 it, but pickle relies on __main__ to operate).
2103 it, but pickle relies on __main__ to operate).
2098
2104
2099 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
2105 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
2100 using properties, but forgot to make the main InteractiveShell
2106 using properties, but forgot to make the main InteractiveShell
2101 class a new-style class. Properties fail silently, and
2107 class a new-style class. Properties fail silently, and
2102 mysteriously, with old-style class (getters work, but
2108 mysteriously, with old-style class (getters work, but
2103 setters don't do anything).
2109 setters don't do anything).
2104
2110
2105 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
2111 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
2106
2112
2107 * IPython/Magic.py (magic_history): fix history reporting bug (I
2113 * IPython/Magic.py (magic_history): fix history reporting bug (I
2108 know some nasties are still there, I just can't seem to find a
2114 know some nasties are still there, I just can't seem to find a
2109 reproducible test case to track them down; the input history is
2115 reproducible test case to track them down; the input history is
2110 falling out of sync...)
2116 falling out of sync...)
2111
2117
2112 * IPython/iplib.py (handle_shell_escape): fix bug where both
2118 * IPython/iplib.py (handle_shell_escape): fix bug where both
2113 aliases and system accesses where broken for indented code (such
2119 aliases and system accesses where broken for indented code (such
2114 as loops).
2120 as loops).
2115
2121
2116 * IPython/genutils.py (shell): fix small but critical bug for
2122 * IPython/genutils.py (shell): fix small but critical bug for
2117 win32 system access.
2123 win32 system access.
2118
2124
2119 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
2125 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
2120
2126
2121 * IPython/iplib.py (showtraceback): remove use of the
2127 * IPython/iplib.py (showtraceback): remove use of the
2122 sys.last_{type/value/traceback} structures, which are non
2128 sys.last_{type/value/traceback} structures, which are non
2123 thread-safe.
2129 thread-safe.
2124 (_prefilter): change control flow to ensure that we NEVER
2130 (_prefilter): change control flow to ensure that we NEVER
2125 introspect objects when autocall is off. This will guarantee that
2131 introspect objects when autocall is off. This will guarantee that
2126 having an input line of the form 'x.y', where access to attribute
2132 having an input line of the form 'x.y', where access to attribute
2127 'y' has side effects, doesn't trigger the side effect TWICE. It
2133 'y' has side effects, doesn't trigger the side effect TWICE. It
2128 is important to note that, with autocall on, these side effects
2134 is important to note that, with autocall on, these side effects
2129 can still happen.
2135 can still happen.
2130 (ipsystem): new builtin, to complete the ip{magic/alias/system}
2136 (ipsystem): new builtin, to complete the ip{magic/alias/system}
2131 trio. IPython offers these three kinds of special calls which are
2137 trio. IPython offers these three kinds of special calls which are
2132 not python code, and it's a good thing to have their call method
2138 not python code, and it's a good thing to have their call method
2133 be accessible as pure python functions (not just special syntax at
2139 be accessible as pure python functions (not just special syntax at
2134 the command line). It gives us a better internal implementation
2140 the command line). It gives us a better internal implementation
2135 structure, as well as exposing these for user scripting more
2141 structure, as well as exposing these for user scripting more
2136 cleanly.
2142 cleanly.
2137
2143
2138 * IPython/macro.py (Macro.__init__): moved macros to a standalone
2144 * IPython/macro.py (Macro.__init__): moved macros to a standalone
2139 file. Now that they'll be more likely to be used with the
2145 file. Now that they'll be more likely to be used with the
2140 persistance system (%store), I want to make sure their module path
2146 persistance system (%store), I want to make sure their module path
2141 doesn't change in the future, so that we don't break things for
2147 doesn't change in the future, so that we don't break things for
2142 users' persisted data.
2148 users' persisted data.
2143
2149
2144 * IPython/iplib.py (autoindent_update): move indentation
2150 * IPython/iplib.py (autoindent_update): move indentation
2145 management into the _text_ processing loop, not the keyboard
2151 management into the _text_ processing loop, not the keyboard
2146 interactive one. This is necessary to correctly process non-typed
2152 interactive one. This is necessary to correctly process non-typed
2147 multiline input (such as macros).
2153 multiline input (such as macros).
2148
2154
2149 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
2155 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
2150 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
2156 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
2151 which was producing problems in the resulting manual.
2157 which was producing problems in the resulting manual.
2152 (magic_whos): improve reporting of instances (show their class,
2158 (magic_whos): improve reporting of instances (show their class,
2153 instead of simply printing 'instance' which isn't terribly
2159 instead of simply printing 'instance' which isn't terribly
2154 informative).
2160 informative).
2155
2161
2156 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
2162 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
2157 (minor mods) to support network shares under win32.
2163 (minor mods) to support network shares under win32.
2158
2164
2159 * IPython/winconsole.py (get_console_size): add new winconsole
2165 * IPython/winconsole.py (get_console_size): add new winconsole
2160 module and fixes to page_dumb() to improve its behavior under
2166 module and fixes to page_dumb() to improve its behavior under
2161 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
2167 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
2162
2168
2163 * IPython/Magic.py (Macro): simplified Macro class to just
2169 * IPython/Magic.py (Macro): simplified Macro class to just
2164 subclass list. We've had only 2.2 compatibility for a very long
2170 subclass list. We've had only 2.2 compatibility for a very long
2165 time, yet I was still avoiding subclassing the builtin types. No
2171 time, yet I was still avoiding subclassing the builtin types. No
2166 more (I'm also starting to use properties, though I won't shift to
2172 more (I'm also starting to use properties, though I won't shift to
2167 2.3-specific features quite yet).
2173 2.3-specific features quite yet).
2168 (magic_store): added Ville's patch for lightweight variable
2174 (magic_store): added Ville's patch for lightweight variable
2169 persistence, after a request on the user list by Matt Wilkie
2175 persistence, after a request on the user list by Matt Wilkie
2170 <maphew-AT-gmail.com>. The new %store magic's docstring has full
2176 <maphew-AT-gmail.com>. The new %store magic's docstring has full
2171 details.
2177 details.
2172
2178
2173 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2179 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2174 changed the default logfile name from 'ipython.log' to
2180 changed the default logfile name from 'ipython.log' to
2175 'ipython_log.py'. These logs are real python files, and now that
2181 'ipython_log.py'. These logs are real python files, and now that
2176 we have much better multiline support, people are more likely to
2182 we have much better multiline support, people are more likely to
2177 want to use them as such. Might as well name them correctly.
2183 want to use them as such. Might as well name them correctly.
2178
2184
2179 * IPython/Magic.py: substantial cleanup. While we can't stop
2185 * IPython/Magic.py: substantial cleanup. While we can't stop
2180 using magics as mixins, due to the existing customizations 'out
2186 using magics as mixins, due to the existing customizations 'out
2181 there' which rely on the mixin naming conventions, at least I
2187 there' which rely on the mixin naming conventions, at least I
2182 cleaned out all cross-class name usage. So once we are OK with
2188 cleaned out all cross-class name usage. So once we are OK with
2183 breaking compatibility, the two systems can be separated.
2189 breaking compatibility, the two systems can be separated.
2184
2190
2185 * IPython/Logger.py: major cleanup. This one is NOT a mixin
2191 * IPython/Logger.py: major cleanup. This one is NOT a mixin
2186 anymore, and the class is a fair bit less hideous as well. New
2192 anymore, and the class is a fair bit less hideous as well. New
2187 features were also introduced: timestamping of input, and logging
2193 features were also introduced: timestamping of input, and logging
2188 of output results. These are user-visible with the -t and -o
2194 of output results. These are user-visible with the -t and -o
2189 options to %logstart. Closes
2195 options to %logstart. Closes
2190 http://www.scipy.net/roundup/ipython/issue11 and a request by
2196 http://www.scipy.net/roundup/ipython/issue11 and a request by
2191 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
2197 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
2192
2198
2193 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
2199 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
2194
2200
2195 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
2201 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
2196 better handle backslashes in paths. See the thread 'More Windows
2202 better handle backslashes in paths. See the thread 'More Windows
2197 questions part 2 - \/ characters revisited' on the iypthon user
2203 questions part 2 - \/ characters revisited' on the iypthon user
2198 list:
2204 list:
2199 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
2205 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
2200
2206
2201 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
2207 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
2202
2208
2203 (InteractiveShell.__init__): change threaded shells to not use the
2209 (InteractiveShell.__init__): change threaded shells to not use the
2204 ipython crash handler. This was causing more problems than not,
2210 ipython crash handler. This was causing more problems than not,
2205 as exceptions in the main thread (GUI code, typically) would
2211 as exceptions in the main thread (GUI code, typically) would
2206 always show up as a 'crash', when they really weren't.
2212 always show up as a 'crash', when they really weren't.
2207
2213
2208 The colors and exception mode commands (%colors/%xmode) have been
2214 The colors and exception mode commands (%colors/%xmode) have been
2209 synchronized to also take this into account, so users can get
2215 synchronized to also take this into account, so users can get
2210 verbose exceptions for their threaded code as well. I also added
2216 verbose exceptions for their threaded code as well. I also added
2211 support for activating pdb inside this exception handler as well,
2217 support for activating pdb inside this exception handler as well,
2212 so now GUI authors can use IPython's enhanced pdb at runtime.
2218 so now GUI authors can use IPython's enhanced pdb at runtime.
2213
2219
2214 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
2220 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
2215 true by default, and add it to the shipped ipythonrc file. Since
2221 true by default, and add it to the shipped ipythonrc file. Since
2216 this asks the user before proceeding, I think it's OK to make it
2222 this asks the user before proceeding, I think it's OK to make it
2217 true by default.
2223 true by default.
2218
2224
2219 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
2225 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
2220 of the previous special-casing of input in the eval loop. I think
2226 of the previous special-casing of input in the eval loop. I think
2221 this is cleaner, as they really are commands and shouldn't have
2227 this is cleaner, as they really are commands and shouldn't have
2222 a special role in the middle of the core code.
2228 a special role in the middle of the core code.
2223
2229
2224 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
2230 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
2225
2231
2226 * IPython/iplib.py (edit_syntax_error): added support for
2232 * IPython/iplib.py (edit_syntax_error): added support for
2227 automatically reopening the editor if the file had a syntax error
2233 automatically reopening the editor if the file had a syntax error
2228 in it. Thanks to scottt who provided the patch at:
2234 in it. Thanks to scottt who provided the patch at:
2229 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
2235 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
2230 version committed).
2236 version committed).
2231
2237
2232 * IPython/iplib.py (handle_normal): add suport for multi-line
2238 * IPython/iplib.py (handle_normal): add suport for multi-line
2233 input with emtpy lines. This fixes
2239 input with emtpy lines. This fixes
2234 http://www.scipy.net/roundup/ipython/issue43 and a similar
2240 http://www.scipy.net/roundup/ipython/issue43 and a similar
2235 discussion on the user list.
2241 discussion on the user list.
2236
2242
2237 WARNING: a behavior change is necessarily introduced to support
2243 WARNING: a behavior change is necessarily introduced to support
2238 blank lines: now a single blank line with whitespace does NOT
2244 blank lines: now a single blank line with whitespace does NOT
2239 break the input loop, which means that when autoindent is on, by
2245 break the input loop, which means that when autoindent is on, by
2240 default hitting return on the next (indented) line does NOT exit.
2246 default hitting return on the next (indented) line does NOT exit.
2241
2247
2242 Instead, to exit a multiline input you can either have:
2248 Instead, to exit a multiline input you can either have:
2243
2249
2244 - TWO whitespace lines (just hit return again), or
2250 - TWO whitespace lines (just hit return again), or
2245 - a single whitespace line of a different length than provided
2251 - a single whitespace line of a different length than provided
2246 by the autoindent (add or remove a space).
2252 by the autoindent (add or remove a space).
2247
2253
2248 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
2254 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
2249 module to better organize all readline-related functionality.
2255 module to better organize all readline-related functionality.
2250 I've deleted FlexCompleter and put all completion clases here.
2256 I've deleted FlexCompleter and put all completion clases here.
2251
2257
2252 * IPython/iplib.py (raw_input): improve indentation management.
2258 * IPython/iplib.py (raw_input): improve indentation management.
2253 It is now possible to paste indented code with autoindent on, and
2259 It is now possible to paste indented code with autoindent on, and
2254 the code is interpreted correctly (though it still looks bad on
2260 the code is interpreted correctly (though it still looks bad on
2255 screen, due to the line-oriented nature of ipython).
2261 screen, due to the line-oriented nature of ipython).
2256 (MagicCompleter.complete): change behavior so that a TAB key on an
2262 (MagicCompleter.complete): change behavior so that a TAB key on an
2257 otherwise empty line actually inserts a tab, instead of completing
2263 otherwise empty line actually inserts a tab, instead of completing
2258 on the entire global namespace. This makes it easier to use the
2264 on the entire global namespace. This makes it easier to use the
2259 TAB key for indentation. After a request by Hans Meine
2265 TAB key for indentation. After a request by Hans Meine
2260 <hans_meine-AT-gmx.net>
2266 <hans_meine-AT-gmx.net>
2261 (_prefilter): add support so that typing plain 'exit' or 'quit'
2267 (_prefilter): add support so that typing plain 'exit' or 'quit'
2262 does a sensible thing. Originally I tried to deviate as little as
2268 does a sensible thing. Originally I tried to deviate as little as
2263 possible from the default python behavior, but even that one may
2269 possible from the default python behavior, but even that one may
2264 change in this direction (thread on python-dev to that effect).
2270 change in this direction (thread on python-dev to that effect).
2265 Regardless, ipython should do the right thing even if CPython's
2271 Regardless, ipython should do the right thing even if CPython's
2266 '>>>' prompt doesn't.
2272 '>>>' prompt doesn't.
2267 (InteractiveShell): removed subclassing code.InteractiveConsole
2273 (InteractiveShell): removed subclassing code.InteractiveConsole
2268 class. By now we'd overridden just about all of its methods: I've
2274 class. By now we'd overridden just about all of its methods: I've
2269 copied the remaining two over, and now ipython is a standalone
2275 copied the remaining two over, and now ipython is a standalone
2270 class. This will provide a clearer picture for the chainsaw
2276 class. This will provide a clearer picture for the chainsaw
2271 branch refactoring.
2277 branch refactoring.
2272
2278
2273 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
2279 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
2274
2280
2275 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
2281 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
2276 failures for objects which break when dir() is called on them.
2282 failures for objects which break when dir() is called on them.
2277
2283
2278 * IPython/FlexCompleter.py (Completer.__init__): Added support for
2284 * IPython/FlexCompleter.py (Completer.__init__): Added support for
2279 distinct local and global namespaces in the completer API. This
2285 distinct local and global namespaces in the completer API. This
2280 change allows us to properly handle completion with distinct
2286 change allows us to properly handle completion with distinct
2281 scopes, including in embedded instances (this had never really
2287 scopes, including in embedded instances (this had never really
2282 worked correctly).
2288 worked correctly).
2283
2289
2284 Note: this introduces a change in the constructor for
2290 Note: this introduces a change in the constructor for
2285 MagicCompleter, as a new global_namespace parameter is now the
2291 MagicCompleter, as a new global_namespace parameter is now the
2286 second argument (the others were bumped one position).
2292 second argument (the others were bumped one position).
2287
2293
2288 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
2294 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
2289
2295
2290 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2296 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2291 embedded instances (which can be done now thanks to Vivian's
2297 embedded instances (which can be done now thanks to Vivian's
2292 frame-handling fixes for pdb).
2298 frame-handling fixes for pdb).
2293 (InteractiveShell.__init__): Fix namespace handling problem in
2299 (InteractiveShell.__init__): Fix namespace handling problem in
2294 embedded instances. We were overwriting __main__ unconditionally,
2300 embedded instances. We were overwriting __main__ unconditionally,
2295 and this should only be done for 'full' (non-embedded) IPython;
2301 and this should only be done for 'full' (non-embedded) IPython;
2296 embedded instances must respect the caller's __main__. Thanks to
2302 embedded instances must respect the caller's __main__. Thanks to
2297 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
2303 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
2298
2304
2299 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
2305 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
2300
2306
2301 * setup.py: added download_url to setup(). This registers the
2307 * setup.py: added download_url to setup(). This registers the
2302 download address at PyPI, which is not only useful to humans
2308 download address at PyPI, which is not only useful to humans
2303 browsing the site, but is also picked up by setuptools (the Eggs
2309 browsing the site, but is also picked up by setuptools (the Eggs
2304 machinery). Thanks to Ville and R. Kern for the info/discussion
2310 machinery). Thanks to Ville and R. Kern for the info/discussion
2305 on this.
2311 on this.
2306
2312
2307 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
2313 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
2308
2314
2309 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
2315 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
2310 This brings a lot of nice functionality to the pdb mode, which now
2316 This brings a lot of nice functionality to the pdb mode, which now
2311 has tab-completion, syntax highlighting, and better stack handling
2317 has tab-completion, syntax highlighting, and better stack handling
2312 than before. Many thanks to Vivian De Smedt
2318 than before. Many thanks to Vivian De Smedt
2313 <vivian-AT-vdesmedt.com> for the original patches.
2319 <vivian-AT-vdesmedt.com> for the original patches.
2314
2320
2315 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
2321 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
2316
2322
2317 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
2323 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
2318 sequence to consistently accept the banner argument. The
2324 sequence to consistently accept the banner argument. The
2319 inconsistency was tripping SAGE, thanks to Gary Zablackis
2325 inconsistency was tripping SAGE, thanks to Gary Zablackis
2320 <gzabl-AT-yahoo.com> for the report.
2326 <gzabl-AT-yahoo.com> for the report.
2321
2327
2322 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2328 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2323
2329
2324 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2330 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2325 Fix bug where a naked 'alias' call in the ipythonrc file would
2331 Fix bug where a naked 'alias' call in the ipythonrc file would
2326 cause a crash. Bug reported by Jorgen Stenarson.
2332 cause a crash. Bug reported by Jorgen Stenarson.
2327
2333
2328 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2334 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2329
2335
2330 * IPython/ipmaker.py (make_IPython): cleanups which should improve
2336 * IPython/ipmaker.py (make_IPython): cleanups which should improve
2331 startup time.
2337 startup time.
2332
2338
2333 * IPython/iplib.py (runcode): my globals 'fix' for embedded
2339 * IPython/iplib.py (runcode): my globals 'fix' for embedded
2334 instances had introduced a bug with globals in normal code. Now
2340 instances had introduced a bug with globals in normal code. Now
2335 it's working in all cases.
2341 it's working in all cases.
2336
2342
2337 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
2343 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
2338 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
2344 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
2339 has been introduced to set the default case sensitivity of the
2345 has been introduced to set the default case sensitivity of the
2340 searches. Users can still select either mode at runtime on a
2346 searches. Users can still select either mode at runtime on a
2341 per-search basis.
2347 per-search basis.
2342
2348
2343 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
2349 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
2344
2350
2345 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
2351 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
2346 attributes in wildcard searches for subclasses. Modified version
2352 attributes in wildcard searches for subclasses. Modified version
2347 of a patch by Jorgen.
2353 of a patch by Jorgen.
2348
2354
2349 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
2355 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
2350
2356
2351 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
2357 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
2352 embedded instances. I added a user_global_ns attribute to the
2358 embedded instances. I added a user_global_ns attribute to the
2353 InteractiveShell class to handle this.
2359 InteractiveShell class to handle this.
2354
2360
2355 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
2361 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
2356
2362
2357 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
2363 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
2358 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
2364 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
2359 (reported under win32, but may happen also in other platforms).
2365 (reported under win32, but may happen also in other platforms).
2360 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
2366 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
2361
2367
2362 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
2368 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
2363
2369
2364 * IPython/Magic.py (magic_psearch): new support for wildcard
2370 * IPython/Magic.py (magic_psearch): new support for wildcard
2365 patterns. Now, typing ?a*b will list all names which begin with a
2371 patterns. Now, typing ?a*b will list all names which begin with a
2366 and end in b, for example. The %psearch magic has full
2372 and end in b, for example. The %psearch magic has full
2367 docstrings. Many thanks to Jörgen Stenarson
2373 docstrings. Many thanks to Jörgen Stenarson
2368 <jorgen.stenarson-AT-bostream.nu>, author of the patches
2374 <jorgen.stenarson-AT-bostream.nu>, author of the patches
2369 implementing this functionality.
2375 implementing this functionality.
2370
2376
2371 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2377 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2372
2378
2373 * Manual: fixed long-standing annoyance of double-dashes (as in
2379 * Manual: fixed long-standing annoyance of double-dashes (as in
2374 --prefix=~, for example) being stripped in the HTML version. This
2380 --prefix=~, for example) being stripped in the HTML version. This
2375 is a latex2html bug, but a workaround was provided. Many thanks
2381 is a latex2html bug, but a workaround was provided. Many thanks
2376 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
2382 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
2377 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
2383 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
2378 rolling. This seemingly small issue had tripped a number of users
2384 rolling. This seemingly small issue had tripped a number of users
2379 when first installing, so I'm glad to see it gone.
2385 when first installing, so I'm glad to see it gone.
2380
2386
2381 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2387 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2382
2388
2383 * IPython/Extensions/numeric_formats.py: fix missing import,
2389 * IPython/Extensions/numeric_formats.py: fix missing import,
2384 reported by Stephen Walton.
2390 reported by Stephen Walton.
2385
2391
2386 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
2392 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
2387
2393
2388 * IPython/demo.py: finish demo module, fully documented now.
2394 * IPython/demo.py: finish demo module, fully documented now.
2389
2395
2390 * IPython/genutils.py (file_read): simple little utility to read a
2396 * IPython/genutils.py (file_read): simple little utility to read a
2391 file and ensure it's closed afterwards.
2397 file and ensure it's closed afterwards.
2392
2398
2393 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
2399 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
2394
2400
2395 * IPython/demo.py (Demo.__init__): added support for individually
2401 * IPython/demo.py (Demo.__init__): added support for individually
2396 tagging blocks for automatic execution.
2402 tagging blocks for automatic execution.
2397
2403
2398 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
2404 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
2399 syntax-highlighted python sources, requested by John.
2405 syntax-highlighted python sources, requested by John.
2400
2406
2401 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
2407 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
2402
2408
2403 * IPython/demo.py (Demo.again): fix bug where again() blocks after
2409 * IPython/demo.py (Demo.again): fix bug where again() blocks after
2404 finishing.
2410 finishing.
2405
2411
2406 * IPython/genutils.py (shlex_split): moved from Magic to here,
2412 * IPython/genutils.py (shlex_split): moved from Magic to here,
2407 where all 2.2 compatibility stuff lives. I needed it for demo.py.
2413 where all 2.2 compatibility stuff lives. I needed it for demo.py.
2408
2414
2409 * IPython/demo.py (Demo.__init__): added support for silent
2415 * IPython/demo.py (Demo.__init__): added support for silent
2410 blocks, improved marks as regexps, docstrings written.
2416 blocks, improved marks as regexps, docstrings written.
2411 (Demo.__init__): better docstring, added support for sys.argv.
2417 (Demo.__init__): better docstring, added support for sys.argv.
2412
2418
2413 * IPython/genutils.py (marquee): little utility used by the demo
2419 * IPython/genutils.py (marquee): little utility used by the demo
2414 code, handy in general.
2420 code, handy in general.
2415
2421
2416 * IPython/demo.py (Demo.__init__): new class for interactive
2422 * IPython/demo.py (Demo.__init__): new class for interactive
2417 demos. Not documented yet, I just wrote it in a hurry for
2423 demos. Not documented yet, I just wrote it in a hurry for
2418 scipy'05. Will docstring later.
2424 scipy'05. Will docstring later.
2419
2425
2420 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
2426 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
2421
2427
2422 * IPython/Shell.py (sigint_handler): Drastic simplification which
2428 * IPython/Shell.py (sigint_handler): Drastic simplification which
2423 also seems to make Ctrl-C work correctly across threads! This is
2429 also seems to make Ctrl-C work correctly across threads! This is
2424 so simple, that I can't beleive I'd missed it before. Needs more
2430 so simple, that I can't beleive I'd missed it before. Needs more
2425 testing, though.
2431 testing, though.
2426 (KBINT): Never mind, revert changes. I'm sure I'd tried something
2432 (KBINT): Never mind, revert changes. I'm sure I'd tried something
2427 like this before...
2433 like this before...
2428
2434
2429 * IPython/genutils.py (get_home_dir): add protection against
2435 * IPython/genutils.py (get_home_dir): add protection against
2430 non-dirs in win32 registry.
2436 non-dirs in win32 registry.
2431
2437
2432 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
2438 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
2433 bug where dict was mutated while iterating (pysh crash).
2439 bug where dict was mutated while iterating (pysh crash).
2434
2440
2435 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
2441 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
2436
2442
2437 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
2443 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
2438 spurious newlines added by this routine. After a report by
2444 spurious newlines added by this routine. After a report by
2439 F. Mantegazza.
2445 F. Mantegazza.
2440
2446
2441 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
2447 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
2442
2448
2443 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
2449 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
2444 calls. These were a leftover from the GTK 1.x days, and can cause
2450 calls. These were a leftover from the GTK 1.x days, and can cause
2445 problems in certain cases (after a report by John Hunter).
2451 problems in certain cases (after a report by John Hunter).
2446
2452
2447 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
2453 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
2448 os.getcwd() fails at init time. Thanks to patch from David Remahl
2454 os.getcwd() fails at init time. Thanks to patch from David Remahl
2449 <chmod007-AT-mac.com>.
2455 <chmod007-AT-mac.com>.
2450 (InteractiveShell.__init__): prevent certain special magics from
2456 (InteractiveShell.__init__): prevent certain special magics from
2451 being shadowed by aliases. Closes
2457 being shadowed by aliases. Closes
2452 http://www.scipy.net/roundup/ipython/issue41.
2458 http://www.scipy.net/roundup/ipython/issue41.
2453
2459
2454 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
2460 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
2455
2461
2456 * IPython/iplib.py (InteractiveShell.complete): Added new
2462 * IPython/iplib.py (InteractiveShell.complete): Added new
2457 top-level completion method to expose the completion mechanism
2463 top-level completion method to expose the completion mechanism
2458 beyond readline-based environments.
2464 beyond readline-based environments.
2459
2465
2460 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
2466 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
2461
2467
2462 * tools/ipsvnc (svnversion): fix svnversion capture.
2468 * tools/ipsvnc (svnversion): fix svnversion capture.
2463
2469
2464 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
2470 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
2465 attribute to self, which was missing. Before, it was set by a
2471 attribute to self, which was missing. Before, it was set by a
2466 routine which in certain cases wasn't being called, so the
2472 routine which in certain cases wasn't being called, so the
2467 instance could end up missing the attribute. This caused a crash.
2473 instance could end up missing the attribute. This caused a crash.
2468 Closes http://www.scipy.net/roundup/ipython/issue40.
2474 Closes http://www.scipy.net/roundup/ipython/issue40.
2469
2475
2470 2005-08-16 Fernando Perez <fperez@colorado.edu>
2476 2005-08-16 Fernando Perez <fperez@colorado.edu>
2471
2477
2472 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
2478 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
2473 contains non-string attribute. Closes
2479 contains non-string attribute. Closes
2474 http://www.scipy.net/roundup/ipython/issue38.
2480 http://www.scipy.net/roundup/ipython/issue38.
2475
2481
2476 2005-08-14 Fernando Perez <fperez@colorado.edu>
2482 2005-08-14 Fernando Perez <fperez@colorado.edu>
2477
2483
2478 * tools/ipsvnc: Minor improvements, to add changeset info.
2484 * tools/ipsvnc: Minor improvements, to add changeset info.
2479
2485
2480 2005-08-12 Fernando Perez <fperez@colorado.edu>
2486 2005-08-12 Fernando Perez <fperez@colorado.edu>
2481
2487
2482 * IPython/iplib.py (runsource): remove self.code_to_run_src
2488 * IPython/iplib.py (runsource): remove self.code_to_run_src
2483 attribute. I realized this is nothing more than
2489 attribute. I realized this is nothing more than
2484 '\n'.join(self.buffer), and having the same data in two different
2490 '\n'.join(self.buffer), and having the same data in two different
2485 places is just asking for synchronization bugs. This may impact
2491 places is just asking for synchronization bugs. This may impact
2486 people who have custom exception handlers, so I need to warn
2492 people who have custom exception handlers, so I need to warn
2487 ipython-dev about it (F. Mantegazza may use them).
2493 ipython-dev about it (F. Mantegazza may use them).
2488
2494
2489 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
2495 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
2490
2496
2491 * IPython/genutils.py: fix 2.2 compatibility (generators)
2497 * IPython/genutils.py: fix 2.2 compatibility (generators)
2492
2498
2493 2005-07-18 Fernando Perez <fperez@colorado.edu>
2499 2005-07-18 Fernando Perez <fperez@colorado.edu>
2494
2500
2495 * IPython/genutils.py (get_home_dir): fix to help users with
2501 * IPython/genutils.py (get_home_dir): fix to help users with
2496 invalid $HOME under win32.
2502 invalid $HOME under win32.
2497
2503
2498 2005-07-17 Fernando Perez <fperez@colorado.edu>
2504 2005-07-17 Fernando Perez <fperez@colorado.edu>
2499
2505
2500 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
2506 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
2501 some old hacks and clean up a bit other routines; code should be
2507 some old hacks and clean up a bit other routines; code should be
2502 simpler and a bit faster.
2508 simpler and a bit faster.
2503
2509
2504 * IPython/iplib.py (interact): removed some last-resort attempts
2510 * IPython/iplib.py (interact): removed some last-resort attempts
2505 to survive broken stdout/stderr. That code was only making it
2511 to survive broken stdout/stderr. That code was only making it
2506 harder to abstract out the i/o (necessary for gui integration),
2512 harder to abstract out the i/o (necessary for gui integration),
2507 and the crashes it could prevent were extremely rare in practice
2513 and the crashes it could prevent were extremely rare in practice
2508 (besides being fully user-induced in a pretty violent manner).
2514 (besides being fully user-induced in a pretty violent manner).
2509
2515
2510 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
2516 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
2511 Nothing major yet, but the code is simpler to read; this should
2517 Nothing major yet, but the code is simpler to read; this should
2512 make it easier to do more serious modifications in the future.
2518 make it easier to do more serious modifications in the future.
2513
2519
2514 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
2520 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
2515 which broke in .15 (thanks to a report by Ville).
2521 which broke in .15 (thanks to a report by Ville).
2516
2522
2517 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
2523 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
2518 be quite correct, I know next to nothing about unicode). This
2524 be quite correct, I know next to nothing about unicode). This
2519 will allow unicode strings to be used in prompts, amongst other
2525 will allow unicode strings to be used in prompts, amongst other
2520 cases. It also will prevent ipython from crashing when unicode
2526 cases. It also will prevent ipython from crashing when unicode
2521 shows up unexpectedly in many places. If ascii encoding fails, we
2527 shows up unexpectedly in many places. If ascii encoding fails, we
2522 assume utf_8. Currently the encoding is not a user-visible
2528 assume utf_8. Currently the encoding is not a user-visible
2523 setting, though it could be made so if there is demand for it.
2529 setting, though it could be made so if there is demand for it.
2524
2530
2525 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
2531 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
2526
2532
2527 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
2533 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
2528
2534
2529 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
2535 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
2530
2536
2531 * IPython/genutils.py: Add 2.2 compatibility here, so all other
2537 * IPython/genutils.py: Add 2.2 compatibility here, so all other
2532 code can work transparently for 2.2/2.3.
2538 code can work transparently for 2.2/2.3.
2533
2539
2534 2005-07-16 Fernando Perez <fperez@colorado.edu>
2540 2005-07-16 Fernando Perez <fperez@colorado.edu>
2535
2541
2536 * IPython/ultraTB.py (ExceptionColors): Make a global variable
2542 * IPython/ultraTB.py (ExceptionColors): Make a global variable
2537 out of the color scheme table used for coloring exception
2543 out of the color scheme table used for coloring exception
2538 tracebacks. This allows user code to add new schemes at runtime.
2544 tracebacks. This allows user code to add new schemes at runtime.
2539 This is a minimally modified version of the patch at
2545 This is a minimally modified version of the patch at
2540 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
2546 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
2541 for the contribution.
2547 for the contribution.
2542
2548
2543 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
2549 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
2544 slightly modified version of the patch in
2550 slightly modified version of the patch in
2545 http://www.scipy.net/roundup/ipython/issue34, which also allows me
2551 http://www.scipy.net/roundup/ipython/issue34, which also allows me
2546 to remove the previous try/except solution (which was costlier).
2552 to remove the previous try/except solution (which was costlier).
2547 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
2553 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
2548
2554
2549 2005-06-08 Fernando Perez <fperez@colorado.edu>
2555 2005-06-08 Fernando Perez <fperez@colorado.edu>
2550
2556
2551 * IPython/iplib.py (write/write_err): Add methods to abstract all
2557 * IPython/iplib.py (write/write_err): Add methods to abstract all
2552 I/O a bit more.
2558 I/O a bit more.
2553
2559
2554 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
2560 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
2555 warning, reported by Aric Hagberg, fix by JD Hunter.
2561 warning, reported by Aric Hagberg, fix by JD Hunter.
2556
2562
2557 2005-06-02 *** Released version 0.6.15
2563 2005-06-02 *** Released version 0.6.15
2558
2564
2559 2005-06-01 Fernando Perez <fperez@colorado.edu>
2565 2005-06-01 Fernando Perez <fperez@colorado.edu>
2560
2566
2561 * IPython/iplib.py (MagicCompleter.file_matches): Fix
2567 * IPython/iplib.py (MagicCompleter.file_matches): Fix
2562 tab-completion of filenames within open-quoted strings. Note that
2568 tab-completion of filenames within open-quoted strings. Note that
2563 this requires that in ~/.ipython/ipythonrc, users change the
2569 this requires that in ~/.ipython/ipythonrc, users change the
2564 readline delimiters configuration to read:
2570 readline delimiters configuration to read:
2565
2571
2566 readline_remove_delims -/~
2572 readline_remove_delims -/~
2567
2573
2568
2574
2569 2005-05-31 *** Released version 0.6.14
2575 2005-05-31 *** Released version 0.6.14
2570
2576
2571 2005-05-29 Fernando Perez <fperez@colorado.edu>
2577 2005-05-29 Fernando Perez <fperez@colorado.edu>
2572
2578
2573 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
2579 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
2574 with files not on the filesystem. Reported by Eliyahu Sandler
2580 with files not on the filesystem. Reported by Eliyahu Sandler
2575 <eli@gondolin.net>
2581 <eli@gondolin.net>
2576
2582
2577 2005-05-22 Fernando Perez <fperez@colorado.edu>
2583 2005-05-22 Fernando Perez <fperez@colorado.edu>
2578
2584
2579 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
2585 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
2580 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
2586 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
2581
2587
2582 2005-05-19 Fernando Perez <fperez@colorado.edu>
2588 2005-05-19 Fernando Perez <fperez@colorado.edu>
2583
2589
2584 * IPython/iplib.py (safe_execfile): close a file which could be
2590 * IPython/iplib.py (safe_execfile): close a file which could be
2585 left open (causing problems in win32, which locks open files).
2591 left open (causing problems in win32, which locks open files).
2586 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
2592 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
2587
2593
2588 2005-05-18 Fernando Perez <fperez@colorado.edu>
2594 2005-05-18 Fernando Perez <fperez@colorado.edu>
2589
2595
2590 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
2596 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
2591 keyword arguments correctly to safe_execfile().
2597 keyword arguments correctly to safe_execfile().
2592
2598
2593 2005-05-13 Fernando Perez <fperez@colorado.edu>
2599 2005-05-13 Fernando Perez <fperez@colorado.edu>
2594
2600
2595 * ipython.1: Added info about Qt to manpage, and threads warning
2601 * ipython.1: Added info about Qt to manpage, and threads warning
2596 to usage page (invoked with --help).
2602 to usage page (invoked with --help).
2597
2603
2598 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
2604 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
2599 new matcher (it goes at the end of the priority list) to do
2605 new matcher (it goes at the end of the priority list) to do
2600 tab-completion on named function arguments. Submitted by George
2606 tab-completion on named function arguments. Submitted by George
2601 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
2607 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
2602 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
2608 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
2603 for more details.
2609 for more details.
2604
2610
2605 * IPython/Magic.py (magic_run): Added new -e flag to ignore
2611 * IPython/Magic.py (magic_run): Added new -e flag to ignore
2606 SystemExit exceptions in the script being run. Thanks to a report
2612 SystemExit exceptions in the script being run. Thanks to a report
2607 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
2613 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
2608 producing very annoying behavior when running unit tests.
2614 producing very annoying behavior when running unit tests.
2609
2615
2610 2005-05-12 Fernando Perez <fperez@colorado.edu>
2616 2005-05-12 Fernando Perez <fperez@colorado.edu>
2611
2617
2612 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
2618 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
2613 which I'd broken (again) due to a changed regexp. In the process,
2619 which I'd broken (again) due to a changed regexp. In the process,
2614 added ';' as an escape to auto-quote the whole line without
2620 added ';' as an escape to auto-quote the whole line without
2615 splitting its arguments. Thanks to a report by Jerry McRae
2621 splitting its arguments. Thanks to a report by Jerry McRae
2616 <qrs0xyc02-AT-sneakemail.com>.
2622 <qrs0xyc02-AT-sneakemail.com>.
2617
2623
2618 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
2624 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
2619 possible crashes caused by a TokenError. Reported by Ed Schofield
2625 possible crashes caused by a TokenError. Reported by Ed Schofield
2620 <schofield-AT-ftw.at>.
2626 <schofield-AT-ftw.at>.
2621
2627
2622 2005-05-06 Fernando Perez <fperez@colorado.edu>
2628 2005-05-06 Fernando Perez <fperez@colorado.edu>
2623
2629
2624 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
2630 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
2625
2631
2626 2005-04-29 Fernando Perez <fperez@colorado.edu>
2632 2005-04-29 Fernando Perez <fperez@colorado.edu>
2627
2633
2628 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
2634 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
2629 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
2635 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
2630 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
2636 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
2631 which provides support for Qt interactive usage (similar to the
2637 which provides support for Qt interactive usage (similar to the
2632 existing one for WX and GTK). This had been often requested.
2638 existing one for WX and GTK). This had been often requested.
2633
2639
2634 2005-04-14 *** Released version 0.6.13
2640 2005-04-14 *** Released version 0.6.13
2635
2641
2636 2005-04-08 Fernando Perez <fperez@colorado.edu>
2642 2005-04-08 Fernando Perez <fperez@colorado.edu>
2637
2643
2638 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
2644 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
2639 from _ofind, which gets called on almost every input line. Now,
2645 from _ofind, which gets called on almost every input line. Now,
2640 we only try to get docstrings if they are actually going to be
2646 we only try to get docstrings if they are actually going to be
2641 used (the overhead of fetching unnecessary docstrings can be
2647 used (the overhead of fetching unnecessary docstrings can be
2642 noticeable for certain objects, such as Pyro proxies).
2648 noticeable for certain objects, such as Pyro proxies).
2643
2649
2644 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
2650 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
2645 for completers. For some reason I had been passing them the state
2651 for completers. For some reason I had been passing them the state
2646 variable, which completers never actually need, and was in
2652 variable, which completers never actually need, and was in
2647 conflict with the rlcompleter API. Custom completers ONLY need to
2653 conflict with the rlcompleter API. Custom completers ONLY need to
2648 take the text parameter.
2654 take the text parameter.
2649
2655
2650 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
2656 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
2651 work correctly in pysh. I've also moved all the logic which used
2657 work correctly in pysh. I've also moved all the logic which used
2652 to be in pysh.py here, which will prevent problems with future
2658 to be in pysh.py here, which will prevent problems with future
2653 upgrades. However, this time I must warn users to update their
2659 upgrades. However, this time I must warn users to update their
2654 pysh profile to include the line
2660 pysh profile to include the line
2655
2661
2656 import_all IPython.Extensions.InterpreterExec
2662 import_all IPython.Extensions.InterpreterExec
2657
2663
2658 because otherwise things won't work for them. They MUST also
2664 because otherwise things won't work for them. They MUST also
2659 delete pysh.py and the line
2665 delete pysh.py and the line
2660
2666
2661 execfile pysh.py
2667 execfile pysh.py
2662
2668
2663 from their ipythonrc-pysh.
2669 from their ipythonrc-pysh.
2664
2670
2665 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
2671 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
2666 robust in the face of objects whose dir() returns non-strings
2672 robust in the face of objects whose dir() returns non-strings
2667 (which it shouldn't, but some broken libs like ITK do). Thanks to
2673 (which it shouldn't, but some broken libs like ITK do). Thanks to
2668 a patch by John Hunter (implemented differently, though). Also
2674 a patch by John Hunter (implemented differently, though). Also
2669 minor improvements by using .extend instead of + on lists.
2675 minor improvements by using .extend instead of + on lists.
2670
2676
2671 * pysh.py:
2677 * pysh.py:
2672
2678
2673 2005-04-06 Fernando Perez <fperez@colorado.edu>
2679 2005-04-06 Fernando Perez <fperez@colorado.edu>
2674
2680
2675 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
2681 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
2676 by default, so that all users benefit from it. Those who don't
2682 by default, so that all users benefit from it. Those who don't
2677 want it can still turn it off.
2683 want it can still turn it off.
2678
2684
2679 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
2685 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
2680 config file, I'd forgotten about this, so users were getting it
2686 config file, I'd forgotten about this, so users were getting it
2681 off by default.
2687 off by default.
2682
2688
2683 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
2689 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
2684 consistency. Now magics can be called in multiline statements,
2690 consistency. Now magics can be called in multiline statements,
2685 and python variables can be expanded in magic calls via $var.
2691 and python variables can be expanded in magic calls via $var.
2686 This makes the magic system behave just like aliases or !system
2692 This makes the magic system behave just like aliases or !system
2687 calls.
2693 calls.
2688
2694
2689 2005-03-28 Fernando Perez <fperez@colorado.edu>
2695 2005-03-28 Fernando Perez <fperez@colorado.edu>
2690
2696
2691 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
2697 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
2692 expensive string additions for building command. Add support for
2698 expensive string additions for building command. Add support for
2693 trailing ';' when autocall is used.
2699 trailing ';' when autocall is used.
2694
2700
2695 2005-03-26 Fernando Perez <fperez@colorado.edu>
2701 2005-03-26 Fernando Perez <fperez@colorado.edu>
2696
2702
2697 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
2703 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
2698 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
2704 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
2699 ipython.el robust against prompts with any number of spaces
2705 ipython.el robust against prompts with any number of spaces
2700 (including 0) after the ':' character.
2706 (including 0) after the ':' character.
2701
2707
2702 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
2708 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
2703 continuation prompt, which misled users to think the line was
2709 continuation prompt, which misled users to think the line was
2704 already indented. Closes debian Bug#300847, reported to me by
2710 already indented. Closes debian Bug#300847, reported to me by
2705 Norbert Tretkowski <tretkowski-AT-inittab.de>.
2711 Norbert Tretkowski <tretkowski-AT-inittab.de>.
2706
2712
2707 2005-03-23 Fernando Perez <fperez@colorado.edu>
2713 2005-03-23 Fernando Perez <fperez@colorado.edu>
2708
2714
2709 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
2715 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
2710 properly aligned if they have embedded newlines.
2716 properly aligned if they have embedded newlines.
2711
2717
2712 * IPython/iplib.py (runlines): Add a public method to expose
2718 * IPython/iplib.py (runlines): Add a public method to expose
2713 IPython's code execution machinery, so that users can run strings
2719 IPython's code execution machinery, so that users can run strings
2714 as if they had been typed at the prompt interactively.
2720 as if they had been typed at the prompt interactively.
2715 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
2721 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
2716 methods which can call the system shell, but with python variable
2722 methods which can call the system shell, but with python variable
2717 expansion. The three such methods are: __IPYTHON__.system,
2723 expansion. The three such methods are: __IPYTHON__.system,
2718 .getoutput and .getoutputerror. These need to be documented in a
2724 .getoutput and .getoutputerror. These need to be documented in a
2719 'public API' section (to be written) of the manual.
2725 'public API' section (to be written) of the manual.
2720
2726
2721 2005-03-20 Fernando Perez <fperez@colorado.edu>
2727 2005-03-20 Fernando Perez <fperez@colorado.edu>
2722
2728
2723 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
2729 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
2724 for custom exception handling. This is quite powerful, and it
2730 for custom exception handling. This is quite powerful, and it
2725 allows for user-installable exception handlers which can trap
2731 allows for user-installable exception handlers which can trap
2726 custom exceptions at runtime and treat them separately from
2732 custom exceptions at runtime and treat them separately from
2727 IPython's default mechanisms. At the request of Frédéric
2733 IPython's default mechanisms. At the request of Frédéric
2728 Mantegazza <mantegazza-AT-ill.fr>.
2734 Mantegazza <mantegazza-AT-ill.fr>.
2729 (InteractiveShell.set_custom_completer): public API function to
2735 (InteractiveShell.set_custom_completer): public API function to
2730 add new completers at runtime.
2736 add new completers at runtime.
2731
2737
2732 2005-03-19 Fernando Perez <fperez@colorado.edu>
2738 2005-03-19 Fernando Perez <fperez@colorado.edu>
2733
2739
2734 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
2740 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
2735 allow objects which provide their docstrings via non-standard
2741 allow objects which provide their docstrings via non-standard
2736 mechanisms (like Pyro proxies) to still be inspected by ipython's
2742 mechanisms (like Pyro proxies) to still be inspected by ipython's
2737 ? system.
2743 ? system.
2738
2744
2739 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
2745 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
2740 automatic capture system. I tried quite hard to make it work
2746 automatic capture system. I tried quite hard to make it work
2741 reliably, and simply failed. I tried many combinations with the
2747 reliably, and simply failed. I tried many combinations with the
2742 subprocess module, but eventually nothing worked in all needed
2748 subprocess module, but eventually nothing worked in all needed
2743 cases (not blocking stdin for the child, duplicating stdout
2749 cases (not blocking stdin for the child, duplicating stdout
2744 without blocking, etc). The new %sc/%sx still do capture to these
2750 without blocking, etc). The new %sc/%sx still do capture to these
2745 magical list/string objects which make shell use much more
2751 magical list/string objects which make shell use much more
2746 conveninent, so not all is lost.
2752 conveninent, so not all is lost.
2747
2753
2748 XXX - FIX MANUAL for the change above!
2754 XXX - FIX MANUAL for the change above!
2749
2755
2750 (runsource): I copied code.py's runsource() into ipython to modify
2756 (runsource): I copied code.py's runsource() into ipython to modify
2751 it a bit. Now the code object and source to be executed are
2757 it a bit. Now the code object and source to be executed are
2752 stored in ipython. This makes this info accessible to third-party
2758 stored in ipython. This makes this info accessible to third-party
2753 tools, like custom exception handlers. After a request by Frédéric
2759 tools, like custom exception handlers. After a request by Frédéric
2754 Mantegazza <mantegazza-AT-ill.fr>.
2760 Mantegazza <mantegazza-AT-ill.fr>.
2755
2761
2756 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
2762 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
2757 history-search via readline (like C-p/C-n). I'd wanted this for a
2763 history-search via readline (like C-p/C-n). I'd wanted this for a
2758 long time, but only recently found out how to do it. For users
2764 long time, but only recently found out how to do it. For users
2759 who already have their ipythonrc files made and want this, just
2765 who already have their ipythonrc files made and want this, just
2760 add:
2766 add:
2761
2767
2762 readline_parse_and_bind "\e[A": history-search-backward
2768 readline_parse_and_bind "\e[A": history-search-backward
2763 readline_parse_and_bind "\e[B": history-search-forward
2769 readline_parse_and_bind "\e[B": history-search-forward
2764
2770
2765 2005-03-18 Fernando Perez <fperez@colorado.edu>
2771 2005-03-18 Fernando Perez <fperez@colorado.edu>
2766
2772
2767 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
2773 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
2768 LSString and SList classes which allow transparent conversions
2774 LSString and SList classes which allow transparent conversions
2769 between list mode and whitespace-separated string.
2775 between list mode and whitespace-separated string.
2770 (magic_r): Fix recursion problem in %r.
2776 (magic_r): Fix recursion problem in %r.
2771
2777
2772 * IPython/genutils.py (LSString): New class to be used for
2778 * IPython/genutils.py (LSString): New class to be used for
2773 automatic storage of the results of all alias/system calls in _o
2779 automatic storage of the results of all alias/system calls in _o
2774 and _e (stdout/err). These provide a .l/.list attribute which
2780 and _e (stdout/err). These provide a .l/.list attribute which
2775 does automatic splitting on newlines. This means that for most
2781 does automatic splitting on newlines. This means that for most
2776 uses, you'll never need to do capturing of output with %sc/%sx
2782 uses, you'll never need to do capturing of output with %sc/%sx
2777 anymore, since ipython keeps this always done for you. Note that
2783 anymore, since ipython keeps this always done for you. Note that
2778 only the LAST results are stored, the _o/e variables are
2784 only the LAST results are stored, the _o/e variables are
2779 overwritten on each call. If you need to save their contents
2785 overwritten on each call. If you need to save their contents
2780 further, simply bind them to any other name.
2786 further, simply bind them to any other name.
2781
2787
2782 2005-03-17 Fernando Perez <fperez@colorado.edu>
2788 2005-03-17 Fernando Perez <fperez@colorado.edu>
2783
2789
2784 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
2790 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
2785 prompt namespace handling.
2791 prompt namespace handling.
2786
2792
2787 2005-03-16 Fernando Perez <fperez@colorado.edu>
2793 2005-03-16 Fernando Perez <fperez@colorado.edu>
2788
2794
2789 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
2795 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
2790 classic prompts to be '>>> ' (final space was missing, and it
2796 classic prompts to be '>>> ' (final space was missing, and it
2791 trips the emacs python mode).
2797 trips the emacs python mode).
2792 (BasePrompt.__str__): Added safe support for dynamic prompt
2798 (BasePrompt.__str__): Added safe support for dynamic prompt
2793 strings. Now you can set your prompt string to be '$x', and the
2799 strings. Now you can set your prompt string to be '$x', and the
2794 value of x will be printed from your interactive namespace. The
2800 value of x will be printed from your interactive namespace. The
2795 interpolation syntax includes the full Itpl support, so
2801 interpolation syntax includes the full Itpl support, so
2796 ${foo()+x+bar()} is a valid prompt string now, and the function
2802 ${foo()+x+bar()} is a valid prompt string now, and the function
2797 calls will be made at runtime.
2803 calls will be made at runtime.
2798
2804
2799 2005-03-15 Fernando Perez <fperez@colorado.edu>
2805 2005-03-15 Fernando Perez <fperez@colorado.edu>
2800
2806
2801 * IPython/Magic.py (magic_history): renamed %hist to %history, to
2807 * IPython/Magic.py (magic_history): renamed %hist to %history, to
2802 avoid name clashes in pylab. %hist still works, it just forwards
2808 avoid name clashes in pylab. %hist still works, it just forwards
2803 the call to %history.
2809 the call to %history.
2804
2810
2805 2005-03-02 *** Released version 0.6.12
2811 2005-03-02 *** Released version 0.6.12
2806
2812
2807 2005-03-02 Fernando Perez <fperez@colorado.edu>
2813 2005-03-02 Fernando Perez <fperez@colorado.edu>
2808
2814
2809 * IPython/iplib.py (handle_magic): log magic calls properly as
2815 * IPython/iplib.py (handle_magic): log magic calls properly as
2810 ipmagic() function calls.
2816 ipmagic() function calls.
2811
2817
2812 * IPython/Magic.py (magic_time): Improved %time to support
2818 * IPython/Magic.py (magic_time): Improved %time to support
2813 statements and provide wall-clock as well as CPU time.
2819 statements and provide wall-clock as well as CPU time.
2814
2820
2815 2005-02-27 Fernando Perez <fperez@colorado.edu>
2821 2005-02-27 Fernando Perez <fperez@colorado.edu>
2816
2822
2817 * IPython/hooks.py: New hooks module, to expose user-modifiable
2823 * IPython/hooks.py: New hooks module, to expose user-modifiable
2818 IPython functionality in a clean manner. For now only the editor
2824 IPython functionality in a clean manner. For now only the editor
2819 hook is actually written, and other thigns which I intend to turn
2825 hook is actually written, and other thigns which I intend to turn
2820 into proper hooks aren't yet there. The display and prefilter
2826 into proper hooks aren't yet there. The display and prefilter
2821 stuff, for example, should be hooks. But at least now the
2827 stuff, for example, should be hooks. But at least now the
2822 framework is in place, and the rest can be moved here with more
2828 framework is in place, and the rest can be moved here with more
2823 time later. IPython had had a .hooks variable for a long time for
2829 time later. IPython had had a .hooks variable for a long time for
2824 this purpose, but I'd never actually used it for anything.
2830 this purpose, but I'd never actually used it for anything.
2825
2831
2826 2005-02-26 Fernando Perez <fperez@colorado.edu>
2832 2005-02-26 Fernando Perez <fperez@colorado.edu>
2827
2833
2828 * IPython/ipmaker.py (make_IPython): make the default ipython
2834 * IPython/ipmaker.py (make_IPython): make the default ipython
2829 directory be called _ipython under win32, to follow more the
2835 directory be called _ipython under win32, to follow more the
2830 naming peculiarities of that platform (where buggy software like
2836 naming peculiarities of that platform (where buggy software like
2831 Visual Sourcesafe breaks with .named directories). Reported by
2837 Visual Sourcesafe breaks with .named directories). Reported by
2832 Ville Vainio.
2838 Ville Vainio.
2833
2839
2834 2005-02-23 Fernando Perez <fperez@colorado.edu>
2840 2005-02-23 Fernando Perez <fperez@colorado.edu>
2835
2841
2836 * IPython/iplib.py (InteractiveShell.__init__): removed a few
2842 * IPython/iplib.py (InteractiveShell.__init__): removed a few
2837 auto_aliases for win32 which were causing problems. Users can
2843 auto_aliases for win32 which were causing problems. Users can
2838 define the ones they personally like.
2844 define the ones they personally like.
2839
2845
2840 2005-02-21 Fernando Perez <fperez@colorado.edu>
2846 2005-02-21 Fernando Perez <fperez@colorado.edu>
2841
2847
2842 * IPython/Magic.py (magic_time): new magic to time execution of
2848 * IPython/Magic.py (magic_time): new magic to time execution of
2843 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
2849 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
2844
2850
2845 2005-02-19 Fernando Perez <fperez@colorado.edu>
2851 2005-02-19 Fernando Perez <fperez@colorado.edu>
2846
2852
2847 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
2853 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
2848 into keys (for prompts, for example).
2854 into keys (for prompts, for example).
2849
2855
2850 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
2856 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
2851 prompts in case users want them. This introduces a small behavior
2857 prompts in case users want them. This introduces a small behavior
2852 change: ipython does not automatically add a space to all prompts
2858 change: ipython does not automatically add a space to all prompts
2853 anymore. To get the old prompts with a space, users should add it
2859 anymore. To get the old prompts with a space, users should add it
2854 manually to their ipythonrc file, so for example prompt_in1 should
2860 manually to their ipythonrc file, so for example prompt_in1 should
2855 now read 'In [\#]: ' instead of 'In [\#]:'.
2861 now read 'In [\#]: ' instead of 'In [\#]:'.
2856 (BasePrompt.__init__): New option prompts_pad_left (only in rc
2862 (BasePrompt.__init__): New option prompts_pad_left (only in rc
2857 file) to control left-padding of secondary prompts.
2863 file) to control left-padding of secondary prompts.
2858
2864
2859 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
2865 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
2860 the profiler can't be imported. Fix for Debian, which removed
2866 the profiler can't be imported. Fix for Debian, which removed
2861 profile.py because of License issues. I applied a slightly
2867 profile.py because of License issues. I applied a slightly
2862 modified version of the original Debian patch at
2868 modified version of the original Debian patch at
2863 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
2869 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
2864
2870
2865 2005-02-17 Fernando Perez <fperez@colorado.edu>
2871 2005-02-17 Fernando Perez <fperez@colorado.edu>
2866
2872
2867 * IPython/genutils.py (native_line_ends): Fix bug which would
2873 * IPython/genutils.py (native_line_ends): Fix bug which would
2868 cause improper line-ends under win32 b/c I was not opening files
2874 cause improper line-ends under win32 b/c I was not opening files
2869 in binary mode. Bug report and fix thanks to Ville.
2875 in binary mode. Bug report and fix thanks to Ville.
2870
2876
2871 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
2877 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
2872 trying to catch spurious foo[1] autocalls. My fix actually broke
2878 trying to catch spurious foo[1] autocalls. My fix actually broke
2873 ',/' autoquote/call with explicit escape (bad regexp).
2879 ',/' autoquote/call with explicit escape (bad regexp).
2874
2880
2875 2005-02-15 *** Released version 0.6.11
2881 2005-02-15 *** Released version 0.6.11
2876
2882
2877 2005-02-14 Fernando Perez <fperez@colorado.edu>
2883 2005-02-14 Fernando Perez <fperez@colorado.edu>
2878
2884
2879 * IPython/background_jobs.py: New background job management
2885 * IPython/background_jobs.py: New background job management
2880 subsystem. This is implemented via a new set of classes, and
2886 subsystem. This is implemented via a new set of classes, and
2881 IPython now provides a builtin 'jobs' object for background job
2887 IPython now provides a builtin 'jobs' object for background job
2882 execution. A convenience %bg magic serves as a lightweight
2888 execution. A convenience %bg magic serves as a lightweight
2883 frontend for starting the more common type of calls. This was
2889 frontend for starting the more common type of calls. This was
2884 inspired by discussions with B. Granger and the BackgroundCommand
2890 inspired by discussions with B. Granger and the BackgroundCommand
2885 class described in the book Python Scripting for Computational
2891 class described in the book Python Scripting for Computational
2886 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
2892 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
2887 (although ultimately no code from this text was used, as IPython's
2893 (although ultimately no code from this text was used, as IPython's
2888 system is a separate implementation).
2894 system is a separate implementation).
2889
2895
2890 * IPython/iplib.py (MagicCompleter.python_matches): add new option
2896 * IPython/iplib.py (MagicCompleter.python_matches): add new option
2891 to control the completion of single/double underscore names
2897 to control the completion of single/double underscore names
2892 separately. As documented in the example ipytonrc file, the
2898 separately. As documented in the example ipytonrc file, the
2893 readline_omit__names variable can now be set to 2, to omit even
2899 readline_omit__names variable can now be set to 2, to omit even
2894 single underscore names. Thanks to a patch by Brian Wong
2900 single underscore names. Thanks to a patch by Brian Wong
2895 <BrianWong-AT-AirgoNetworks.Com>.
2901 <BrianWong-AT-AirgoNetworks.Com>.
2896 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
2902 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
2897 be autocalled as foo([1]) if foo were callable. A problem for
2903 be autocalled as foo([1]) if foo were callable. A problem for
2898 things which are both callable and implement __getitem__.
2904 things which are both callable and implement __getitem__.
2899 (init_readline): Fix autoindentation for win32. Thanks to a patch
2905 (init_readline): Fix autoindentation for win32. Thanks to a patch
2900 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
2906 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
2901
2907
2902 2005-02-12 Fernando Perez <fperez@colorado.edu>
2908 2005-02-12 Fernando Perez <fperez@colorado.edu>
2903
2909
2904 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
2910 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
2905 which I had written long ago to sort out user error messages which
2911 which I had written long ago to sort out user error messages which
2906 may occur during startup. This seemed like a good idea initially,
2912 may occur during startup. This seemed like a good idea initially,
2907 but it has proven a disaster in retrospect. I don't want to
2913 but it has proven a disaster in retrospect. I don't want to
2908 change much code for now, so my fix is to set the internal 'debug'
2914 change much code for now, so my fix is to set the internal 'debug'
2909 flag to true everywhere, whose only job was precisely to control
2915 flag to true everywhere, whose only job was precisely to control
2910 this subsystem. This closes issue 28 (as well as avoiding all
2916 this subsystem. This closes issue 28 (as well as avoiding all
2911 sorts of strange hangups which occur from time to time).
2917 sorts of strange hangups which occur from time to time).
2912
2918
2913 2005-02-07 Fernando Perez <fperez@colorado.edu>
2919 2005-02-07 Fernando Perez <fperez@colorado.edu>
2914
2920
2915 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
2921 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
2916 previous call produced a syntax error.
2922 previous call produced a syntax error.
2917
2923
2918 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
2924 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
2919 classes without constructor.
2925 classes without constructor.
2920
2926
2921 2005-02-06 Fernando Perez <fperez@colorado.edu>
2927 2005-02-06 Fernando Perez <fperez@colorado.edu>
2922
2928
2923 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
2929 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
2924 completions with the results of each matcher, so we return results
2930 completions with the results of each matcher, so we return results
2925 to the user from all namespaces. This breaks with ipython
2931 to the user from all namespaces. This breaks with ipython
2926 tradition, but I think it's a nicer behavior. Now you get all
2932 tradition, but I think it's a nicer behavior. Now you get all
2927 possible completions listed, from all possible namespaces (python,
2933 possible completions listed, from all possible namespaces (python,
2928 filesystem, magics...) After a request by John Hunter
2934 filesystem, magics...) After a request by John Hunter
2929 <jdhunter-AT-nitace.bsd.uchicago.edu>.
2935 <jdhunter-AT-nitace.bsd.uchicago.edu>.
2930
2936
2931 2005-02-05 Fernando Perez <fperez@colorado.edu>
2937 2005-02-05 Fernando Perez <fperez@colorado.edu>
2932
2938
2933 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
2939 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
2934 the call had quote characters in it (the quotes were stripped).
2940 the call had quote characters in it (the quotes were stripped).
2935
2941
2936 2005-01-31 Fernando Perez <fperez@colorado.edu>
2942 2005-01-31 Fernando Perez <fperez@colorado.edu>
2937
2943
2938 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
2944 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
2939 Itpl.itpl() to make the code more robust against psyco
2945 Itpl.itpl() to make the code more robust against psyco
2940 optimizations.
2946 optimizations.
2941
2947
2942 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
2948 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
2943 of causing an exception. Quicker, cleaner.
2949 of causing an exception. Quicker, cleaner.
2944
2950
2945 2005-01-28 Fernando Perez <fperez@colorado.edu>
2951 2005-01-28 Fernando Perez <fperez@colorado.edu>
2946
2952
2947 * scripts/ipython_win_post_install.py (install): hardcode
2953 * scripts/ipython_win_post_install.py (install): hardcode
2948 sys.prefix+'python.exe' as the executable path. It turns out that
2954 sys.prefix+'python.exe' as the executable path. It turns out that
2949 during the post-installation run, sys.executable resolves to the
2955 during the post-installation run, sys.executable resolves to the
2950 name of the binary installer! I should report this as a distutils
2956 name of the binary installer! I should report this as a distutils
2951 bug, I think. I updated the .10 release with this tiny fix, to
2957 bug, I think. I updated the .10 release with this tiny fix, to
2952 avoid annoying the lists further.
2958 avoid annoying the lists further.
2953
2959
2954 2005-01-27 *** Released version 0.6.10
2960 2005-01-27 *** Released version 0.6.10
2955
2961
2956 2005-01-27 Fernando Perez <fperez@colorado.edu>
2962 2005-01-27 Fernando Perez <fperez@colorado.edu>
2957
2963
2958 * IPython/numutils.py (norm): Added 'inf' as optional name for
2964 * IPython/numutils.py (norm): Added 'inf' as optional name for
2959 L-infinity norm, included references to mathworld.com for vector
2965 L-infinity norm, included references to mathworld.com for vector
2960 norm definitions.
2966 norm definitions.
2961 (amin/amax): added amin/amax for array min/max. Similar to what
2967 (amin/amax): added amin/amax for array min/max. Similar to what
2962 pylab ships with after the recent reorganization of names.
2968 pylab ships with after the recent reorganization of names.
2963 (spike/spike_odd): removed deprecated spike/spike_odd functions.
2969 (spike/spike_odd): removed deprecated spike/spike_odd functions.
2964
2970
2965 * ipython.el: committed Alex's recent fixes and improvements.
2971 * ipython.el: committed Alex's recent fixes and improvements.
2966 Tested with python-mode from CVS, and it looks excellent. Since
2972 Tested with python-mode from CVS, and it looks excellent. Since
2967 python-mode hasn't released anything in a while, I'm temporarily
2973 python-mode hasn't released anything in a while, I'm temporarily
2968 putting a copy of today's CVS (v 4.70) of python-mode in:
2974 putting a copy of today's CVS (v 4.70) of python-mode in:
2969 http://ipython.scipy.org/tmp/python-mode.el
2975 http://ipython.scipy.org/tmp/python-mode.el
2970
2976
2971 * scripts/ipython_win_post_install.py (install): Win32 fix to use
2977 * scripts/ipython_win_post_install.py (install): Win32 fix to use
2972 sys.executable for the executable name, instead of assuming it's
2978 sys.executable for the executable name, instead of assuming it's
2973 called 'python.exe' (the post-installer would have produced broken
2979 called 'python.exe' (the post-installer would have produced broken
2974 setups on systems with a differently named python binary).
2980 setups on systems with a differently named python binary).
2975
2981
2976 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
2982 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
2977 references to os.linesep, to make the code more
2983 references to os.linesep, to make the code more
2978 platform-independent. This is also part of the win32 coloring
2984 platform-independent. This is also part of the win32 coloring
2979 fixes.
2985 fixes.
2980
2986
2981 * IPython/genutils.py (page_dumb): Remove attempts to chop long
2987 * IPython/genutils.py (page_dumb): Remove attempts to chop long
2982 lines, which actually cause coloring bugs because the length of
2988 lines, which actually cause coloring bugs because the length of
2983 the line is very difficult to correctly compute with embedded
2989 the line is very difficult to correctly compute with embedded
2984 escapes. This was the source of all the coloring problems under
2990 escapes. This was the source of all the coloring problems under
2985 Win32. I think that _finally_, Win32 users have a properly
2991 Win32. I think that _finally_, Win32 users have a properly
2986 working ipython in all respects. This would never have happened
2992 working ipython in all respects. This would never have happened
2987 if not for Gary Bishop and Viktor Ransmayr's great help and work.
2993 if not for Gary Bishop and Viktor Ransmayr's great help and work.
2988
2994
2989 2005-01-26 *** Released version 0.6.9
2995 2005-01-26 *** Released version 0.6.9
2990
2996
2991 2005-01-25 Fernando Perez <fperez@colorado.edu>
2997 2005-01-25 Fernando Perez <fperez@colorado.edu>
2992
2998
2993 * setup.py: finally, we have a true Windows installer, thanks to
2999 * setup.py: finally, we have a true Windows installer, thanks to
2994 the excellent work of Viktor Ransmayr
3000 the excellent work of Viktor Ransmayr
2995 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
3001 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
2996 Windows users. The setup routine is quite a bit cleaner thanks to
3002 Windows users. The setup routine is quite a bit cleaner thanks to
2997 this, and the post-install script uses the proper functions to
3003 this, and the post-install script uses the proper functions to
2998 allow a clean de-installation using the standard Windows Control
3004 allow a clean de-installation using the standard Windows Control
2999 Panel.
3005 Panel.
3000
3006
3001 * IPython/genutils.py (get_home_dir): changed to use the $HOME
3007 * IPython/genutils.py (get_home_dir): changed to use the $HOME
3002 environment variable under all OSes (including win32) if
3008 environment variable under all OSes (including win32) if
3003 available. This will give consistency to win32 users who have set
3009 available. This will give consistency to win32 users who have set
3004 this variable for any reason. If os.environ['HOME'] fails, the
3010 this variable for any reason. If os.environ['HOME'] fails, the
3005 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
3011 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
3006
3012
3007 2005-01-24 Fernando Perez <fperez@colorado.edu>
3013 2005-01-24 Fernando Perez <fperez@colorado.edu>
3008
3014
3009 * IPython/numutils.py (empty_like): add empty_like(), similar to
3015 * IPython/numutils.py (empty_like): add empty_like(), similar to
3010 zeros_like() but taking advantage of the new empty() Numeric routine.
3016 zeros_like() but taking advantage of the new empty() Numeric routine.
3011
3017
3012 2005-01-23 *** Released version 0.6.8
3018 2005-01-23 *** Released version 0.6.8
3013
3019
3014 2005-01-22 Fernando Perez <fperez@colorado.edu>
3020 2005-01-22 Fernando Perez <fperez@colorado.edu>
3015
3021
3016 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
3022 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
3017 automatic show() calls. After discussing things with JDH, it
3023 automatic show() calls. After discussing things with JDH, it
3018 turns out there are too many corner cases where this can go wrong.
3024 turns out there are too many corner cases where this can go wrong.
3019 It's best not to try to be 'too smart', and simply have ipython
3025 It's best not to try to be 'too smart', and simply have ipython
3020 reproduce as much as possible the default behavior of a normal
3026 reproduce as much as possible the default behavior of a normal
3021 python shell.
3027 python shell.
3022
3028
3023 * IPython/iplib.py (InteractiveShell.__init__): Modified the
3029 * IPython/iplib.py (InteractiveShell.__init__): Modified the
3024 line-splitting regexp and _prefilter() to avoid calling getattr()
3030 line-splitting regexp and _prefilter() to avoid calling getattr()
3025 on assignments. This closes
3031 on assignments. This closes
3026 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
3032 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
3027 readline uses getattr(), so a simple <TAB> keypress is still
3033 readline uses getattr(), so a simple <TAB> keypress is still
3028 enough to trigger getattr() calls on an object.
3034 enough to trigger getattr() calls on an object.
3029
3035
3030 2005-01-21 Fernando Perez <fperez@colorado.edu>
3036 2005-01-21 Fernando Perez <fperez@colorado.edu>
3031
3037
3032 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
3038 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
3033 docstring under pylab so it doesn't mask the original.
3039 docstring under pylab so it doesn't mask the original.
3034
3040
3035 2005-01-21 *** Released version 0.6.7
3041 2005-01-21 *** Released version 0.6.7
3036
3042
3037 2005-01-21 Fernando Perez <fperez@colorado.edu>
3043 2005-01-21 Fernando Perez <fperez@colorado.edu>
3038
3044
3039 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
3045 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
3040 signal handling for win32 users in multithreaded mode.
3046 signal handling for win32 users in multithreaded mode.
3041
3047
3042 2005-01-17 Fernando Perez <fperez@colorado.edu>
3048 2005-01-17 Fernando Perez <fperez@colorado.edu>
3043
3049
3044 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3050 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3045 instances with no __init__. After a crash report by Norbert Nemec
3051 instances with no __init__. After a crash report by Norbert Nemec
3046 <Norbert-AT-nemec-online.de>.
3052 <Norbert-AT-nemec-online.de>.
3047
3053
3048 2005-01-14 Fernando Perez <fperez@colorado.edu>
3054 2005-01-14 Fernando Perez <fperez@colorado.edu>
3049
3055
3050 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
3056 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
3051 names for verbose exceptions, when multiple dotted names and the
3057 names for verbose exceptions, when multiple dotted names and the
3052 'parent' object were present on the same line.
3058 'parent' object were present on the same line.
3053
3059
3054 2005-01-11 Fernando Perez <fperez@colorado.edu>
3060 2005-01-11 Fernando Perez <fperez@colorado.edu>
3055
3061
3056 * IPython/genutils.py (flag_calls): new utility to trap and flag
3062 * IPython/genutils.py (flag_calls): new utility to trap and flag
3057 calls in functions. I need it to clean up matplotlib support.
3063 calls in functions. I need it to clean up matplotlib support.
3058 Also removed some deprecated code in genutils.
3064 Also removed some deprecated code in genutils.
3059
3065
3060 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
3066 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
3061 that matplotlib scripts called with %run, which don't call show()
3067 that matplotlib scripts called with %run, which don't call show()
3062 themselves, still have their plotting windows open.
3068 themselves, still have their plotting windows open.
3063
3069
3064 2005-01-05 Fernando Perez <fperez@colorado.edu>
3070 2005-01-05 Fernando Perez <fperez@colorado.edu>
3065
3071
3066 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
3072 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
3067 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
3073 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
3068
3074
3069 2004-12-19 Fernando Perez <fperez@colorado.edu>
3075 2004-12-19 Fernando Perez <fperez@colorado.edu>
3070
3076
3071 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
3077 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
3072 parent_runcode, which was an eyesore. The same result can be
3078 parent_runcode, which was an eyesore. The same result can be
3073 obtained with Python's regular superclass mechanisms.
3079 obtained with Python's regular superclass mechanisms.
3074
3080
3075 2004-12-17 Fernando Perez <fperez@colorado.edu>
3081 2004-12-17 Fernando Perez <fperez@colorado.edu>
3076
3082
3077 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
3083 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
3078 reported by Prabhu.
3084 reported by Prabhu.
3079 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
3085 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
3080 sys.stderr) instead of explicitly calling sys.stderr. This helps
3086 sys.stderr) instead of explicitly calling sys.stderr. This helps
3081 maintain our I/O abstractions clean, for future GUI embeddings.
3087 maintain our I/O abstractions clean, for future GUI embeddings.
3082
3088
3083 * IPython/genutils.py (info): added new utility for sys.stderr
3089 * IPython/genutils.py (info): added new utility for sys.stderr
3084 unified info message handling (thin wrapper around warn()).
3090 unified info message handling (thin wrapper around warn()).
3085
3091
3086 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
3092 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
3087 composite (dotted) names on verbose exceptions.
3093 composite (dotted) names on verbose exceptions.
3088 (VerboseTB.nullrepr): harden against another kind of errors which
3094 (VerboseTB.nullrepr): harden against another kind of errors which
3089 Python's inspect module can trigger, and which were crashing
3095 Python's inspect module can trigger, and which were crashing
3090 IPython. Thanks to a report by Marco Lombardi
3096 IPython. Thanks to a report by Marco Lombardi
3091 <mlombard-AT-ma010192.hq.eso.org>.
3097 <mlombard-AT-ma010192.hq.eso.org>.
3092
3098
3093 2004-12-13 *** Released version 0.6.6
3099 2004-12-13 *** Released version 0.6.6
3094
3100
3095 2004-12-12 Fernando Perez <fperez@colorado.edu>
3101 2004-12-12 Fernando Perez <fperez@colorado.edu>
3096
3102
3097 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
3103 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
3098 generated by pygtk upon initialization if it was built without
3104 generated by pygtk upon initialization if it was built without
3099 threads (for matplotlib users). After a crash reported by
3105 threads (for matplotlib users). After a crash reported by
3100 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
3106 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
3101
3107
3102 * IPython/ipmaker.py (make_IPython): fix small bug in the
3108 * IPython/ipmaker.py (make_IPython): fix small bug in the
3103 import_some parameter for multiple imports.
3109 import_some parameter for multiple imports.
3104
3110
3105 * IPython/iplib.py (ipmagic): simplified the interface of
3111 * IPython/iplib.py (ipmagic): simplified the interface of
3106 ipmagic() to take a single string argument, just as it would be
3112 ipmagic() to take a single string argument, just as it would be
3107 typed at the IPython cmd line.
3113 typed at the IPython cmd line.
3108 (ipalias): Added new ipalias() with an interface identical to
3114 (ipalias): Added new ipalias() with an interface identical to
3109 ipmagic(). This completes exposing a pure python interface to the
3115 ipmagic(). This completes exposing a pure python interface to the
3110 alias and magic system, which can be used in loops or more complex
3116 alias and magic system, which can be used in loops or more complex
3111 code where IPython's automatic line mangling is not active.
3117 code where IPython's automatic line mangling is not active.
3112
3118
3113 * IPython/genutils.py (timing): changed interface of timing to
3119 * IPython/genutils.py (timing): changed interface of timing to
3114 simply run code once, which is the most common case. timings()
3120 simply run code once, which is the most common case. timings()
3115 remains unchanged, for the cases where you want multiple runs.
3121 remains unchanged, for the cases where you want multiple runs.
3116
3122
3117 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
3123 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
3118 bug where Python2.2 crashes with exec'ing code which does not end
3124 bug where Python2.2 crashes with exec'ing code which does not end
3119 in a single newline. Python 2.3 is OK, so I hadn't noticed this
3125 in a single newline. Python 2.3 is OK, so I hadn't noticed this
3120 before.
3126 before.
3121
3127
3122 2004-12-10 Fernando Perez <fperez@colorado.edu>
3128 2004-12-10 Fernando Perez <fperez@colorado.edu>
3123
3129
3124 * IPython/Magic.py (Magic.magic_prun): changed name of option from
3130 * IPython/Magic.py (Magic.magic_prun): changed name of option from
3125 -t to -T, to accomodate the new -t flag in %run (the %run and
3131 -t to -T, to accomodate the new -t flag in %run (the %run and
3126 %prun options are kind of intermixed, and it's not easy to change
3132 %prun options are kind of intermixed, and it's not easy to change
3127 this with the limitations of python's getopt).
3133 this with the limitations of python's getopt).
3128
3134
3129 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
3135 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
3130 the execution of scripts. It's not as fine-tuned as timeit.py,
3136 the execution of scripts. It's not as fine-tuned as timeit.py,
3131 but it works from inside ipython (and under 2.2, which lacks
3137 but it works from inside ipython (and under 2.2, which lacks
3132 timeit.py). Optionally a number of runs > 1 can be given for
3138 timeit.py). Optionally a number of runs > 1 can be given for
3133 timing very short-running code.
3139 timing very short-running code.
3134
3140
3135 * IPython/genutils.py (uniq_stable): new routine which returns a
3141 * IPython/genutils.py (uniq_stable): new routine which returns a
3136 list of unique elements in any iterable, but in stable order of
3142 list of unique elements in any iterable, but in stable order of
3137 appearance. I needed this for the ultraTB fixes, and it's a handy
3143 appearance. I needed this for the ultraTB fixes, and it's a handy
3138 utility.
3144 utility.
3139
3145
3140 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
3146 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
3141 dotted names in Verbose exceptions. This had been broken since
3147 dotted names in Verbose exceptions. This had been broken since
3142 the very start, now x.y will properly be printed in a Verbose
3148 the very start, now x.y will properly be printed in a Verbose
3143 traceback, instead of x being shown and y appearing always as an
3149 traceback, instead of x being shown and y appearing always as an
3144 'undefined global'. Getting this to work was a bit tricky,
3150 'undefined global'. Getting this to work was a bit tricky,
3145 because by default python tokenizers are stateless. Saved by
3151 because by default python tokenizers are stateless. Saved by
3146 python's ability to easily add a bit of state to an arbitrary
3152 python's ability to easily add a bit of state to an arbitrary
3147 function (without needing to build a full-blown callable object).
3153 function (without needing to build a full-blown callable object).
3148
3154
3149 Also big cleanup of this code, which had horrendous runtime
3155 Also big cleanup of this code, which had horrendous runtime
3150 lookups of zillions of attributes for colorization. Moved all
3156 lookups of zillions of attributes for colorization. Moved all
3151 this code into a few templates, which make it cleaner and quicker.
3157 this code into a few templates, which make it cleaner and quicker.
3152
3158
3153 Printout quality was also improved for Verbose exceptions: one
3159 Printout quality was also improved for Verbose exceptions: one
3154 variable per line, and memory addresses are printed (this can be
3160 variable per line, and memory addresses are printed (this can be
3155 quite handy in nasty debugging situations, which is what Verbose
3161 quite handy in nasty debugging situations, which is what Verbose
3156 is for).
3162 is for).
3157
3163
3158 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
3164 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
3159 the command line as scripts to be loaded by embedded instances.
3165 the command line as scripts to be loaded by embedded instances.
3160 Doing so has the potential for an infinite recursion if there are
3166 Doing so has the potential for an infinite recursion if there are
3161 exceptions thrown in the process. This fixes a strange crash
3167 exceptions thrown in the process. This fixes a strange crash
3162 reported by Philippe MULLER <muller-AT-irit.fr>.
3168 reported by Philippe MULLER <muller-AT-irit.fr>.
3163
3169
3164 2004-12-09 Fernando Perez <fperez@colorado.edu>
3170 2004-12-09 Fernando Perez <fperez@colorado.edu>
3165
3171
3166 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
3172 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
3167 to reflect new names in matplotlib, which now expose the
3173 to reflect new names in matplotlib, which now expose the
3168 matlab-compatible interface via a pylab module instead of the
3174 matlab-compatible interface via a pylab module instead of the
3169 'matlab' name. The new code is backwards compatible, so users of
3175 'matlab' name. The new code is backwards compatible, so users of
3170 all matplotlib versions are OK. Patch by J. Hunter.
3176 all matplotlib versions are OK. Patch by J. Hunter.
3171
3177
3172 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
3178 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
3173 of __init__ docstrings for instances (class docstrings are already
3179 of __init__ docstrings for instances (class docstrings are already
3174 automatically printed). Instances with customized docstrings
3180 automatically printed). Instances with customized docstrings
3175 (indep. of the class) are also recognized and all 3 separate
3181 (indep. of the class) are also recognized and all 3 separate
3176 docstrings are printed (instance, class, constructor). After some
3182 docstrings are printed (instance, class, constructor). After some
3177 comments/suggestions by J. Hunter.
3183 comments/suggestions by J. Hunter.
3178
3184
3179 2004-12-05 Fernando Perez <fperez@colorado.edu>
3185 2004-12-05 Fernando Perez <fperez@colorado.edu>
3180
3186
3181 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
3187 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
3182 warnings when tab-completion fails and triggers an exception.
3188 warnings when tab-completion fails and triggers an exception.
3183
3189
3184 2004-12-03 Fernando Perez <fperez@colorado.edu>
3190 2004-12-03 Fernando Perez <fperez@colorado.edu>
3185
3191
3186 * IPython/Magic.py (magic_prun): Fix bug where an exception would
3192 * IPython/Magic.py (magic_prun): Fix bug where an exception would
3187 be triggered when using 'run -p'. An incorrect option flag was
3193 be triggered when using 'run -p'. An incorrect option flag was
3188 being set ('d' instead of 'D').
3194 being set ('d' instead of 'D').
3189 (manpage): fix missing escaped \- sign.
3195 (manpage): fix missing escaped \- sign.
3190
3196
3191 2004-11-30 *** Released version 0.6.5
3197 2004-11-30 *** Released version 0.6.5
3192
3198
3193 2004-11-30 Fernando Perez <fperez@colorado.edu>
3199 2004-11-30 Fernando Perez <fperez@colorado.edu>
3194
3200
3195 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
3201 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
3196 setting with -d option.
3202 setting with -d option.
3197
3203
3198 * setup.py (docfiles): Fix problem where the doc glob I was using
3204 * setup.py (docfiles): Fix problem where the doc glob I was using
3199 was COMPLETELY BROKEN. It was giving the right files by pure
3205 was COMPLETELY BROKEN. It was giving the right files by pure
3200 accident, but failed once I tried to include ipython.el. Note:
3206 accident, but failed once I tried to include ipython.el. Note:
3201 glob() does NOT allow you to do exclusion on multiple endings!
3207 glob() does NOT allow you to do exclusion on multiple endings!
3202
3208
3203 2004-11-29 Fernando Perez <fperez@colorado.edu>
3209 2004-11-29 Fernando Perez <fperez@colorado.edu>
3204
3210
3205 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
3211 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
3206 the manpage as the source. Better formatting & consistency.
3212 the manpage as the source. Better formatting & consistency.
3207
3213
3208 * IPython/Magic.py (magic_run): Added new -d option, to run
3214 * IPython/Magic.py (magic_run): Added new -d option, to run
3209 scripts under the control of the python pdb debugger. Note that
3215 scripts under the control of the python pdb debugger. Note that
3210 this required changing the %prun option -d to -D, to avoid a clash
3216 this required changing the %prun option -d to -D, to avoid a clash
3211 (since %run must pass options to %prun, and getopt is too dumb to
3217 (since %run must pass options to %prun, and getopt is too dumb to
3212 handle options with string values with embedded spaces). Thanks
3218 handle options with string values with embedded spaces). Thanks
3213 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
3219 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
3214 (magic_who_ls): added type matching to %who and %whos, so that one
3220 (magic_who_ls): added type matching to %who and %whos, so that one
3215 can filter their output to only include variables of certain
3221 can filter their output to only include variables of certain
3216 types. Another suggestion by Matthew.
3222 types. Another suggestion by Matthew.
3217 (magic_whos): Added memory summaries in kb and Mb for arrays.
3223 (magic_whos): Added memory summaries in kb and Mb for arrays.
3218 (magic_who): Improve formatting (break lines every 9 vars).
3224 (magic_who): Improve formatting (break lines every 9 vars).
3219
3225
3220 2004-11-28 Fernando Perez <fperez@colorado.edu>
3226 2004-11-28 Fernando Perez <fperez@colorado.edu>
3221
3227
3222 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
3228 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
3223 cache when empty lines were present.
3229 cache when empty lines were present.
3224
3230
3225 2004-11-24 Fernando Perez <fperez@colorado.edu>
3231 2004-11-24 Fernando Perez <fperez@colorado.edu>
3226
3232
3227 * IPython/usage.py (__doc__): document the re-activated threading
3233 * IPython/usage.py (__doc__): document the re-activated threading
3228 options for WX and GTK.
3234 options for WX and GTK.
3229
3235
3230 2004-11-23 Fernando Perez <fperez@colorado.edu>
3236 2004-11-23 Fernando Perez <fperez@colorado.edu>
3231
3237
3232 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
3238 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
3233 the -wthread and -gthread options, along with a new -tk one to try
3239 the -wthread and -gthread options, along with a new -tk one to try
3234 and coordinate Tk threading with wx/gtk. The tk support is very
3240 and coordinate Tk threading with wx/gtk. The tk support is very
3235 platform dependent, since it seems to require Tcl and Tk to be
3241 platform dependent, since it seems to require Tcl and Tk to be
3236 built with threads (Fedora1/2 appears NOT to have it, but in
3242 built with threads (Fedora1/2 appears NOT to have it, but in
3237 Prabhu's Debian boxes it works OK). But even with some Tk
3243 Prabhu's Debian boxes it works OK). But even with some Tk
3238 limitations, this is a great improvement.
3244 limitations, this is a great improvement.
3239
3245
3240 * IPython/Prompts.py (prompt_specials_color): Added \t for time
3246 * IPython/Prompts.py (prompt_specials_color): Added \t for time
3241 info in user prompts. Patch by Prabhu.
3247 info in user prompts. Patch by Prabhu.
3242
3248
3243 2004-11-18 Fernando Perez <fperez@colorado.edu>
3249 2004-11-18 Fernando Perez <fperez@colorado.edu>
3244
3250
3245 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
3251 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
3246 EOFErrors and bail, to avoid infinite loops if a non-terminating
3252 EOFErrors and bail, to avoid infinite loops if a non-terminating
3247 file is fed into ipython. Patch submitted in issue 19 by user,
3253 file is fed into ipython. Patch submitted in issue 19 by user,
3248 many thanks.
3254 many thanks.
3249
3255
3250 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
3256 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
3251 autoquote/parens in continuation prompts, which can cause lots of
3257 autoquote/parens in continuation prompts, which can cause lots of
3252 problems. Closes roundup issue 20.
3258 problems. Closes roundup issue 20.
3253
3259
3254 2004-11-17 Fernando Perez <fperez@colorado.edu>
3260 2004-11-17 Fernando Perez <fperez@colorado.edu>
3255
3261
3256 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
3262 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
3257 reported as debian bug #280505. I'm not sure my local changelog
3263 reported as debian bug #280505. I'm not sure my local changelog
3258 entry has the proper debian format (Jack?).
3264 entry has the proper debian format (Jack?).
3259
3265
3260 2004-11-08 *** Released version 0.6.4
3266 2004-11-08 *** Released version 0.6.4
3261
3267
3262 2004-11-08 Fernando Perez <fperez@colorado.edu>
3268 2004-11-08 Fernando Perez <fperez@colorado.edu>
3263
3269
3264 * IPython/iplib.py (init_readline): Fix exit message for Windows
3270 * IPython/iplib.py (init_readline): Fix exit message for Windows
3265 when readline is active. Thanks to a report by Eric Jones
3271 when readline is active. Thanks to a report by Eric Jones
3266 <eric-AT-enthought.com>.
3272 <eric-AT-enthought.com>.
3267
3273
3268 2004-11-07 Fernando Perez <fperez@colorado.edu>
3274 2004-11-07 Fernando Perez <fperez@colorado.edu>
3269
3275
3270 * IPython/genutils.py (page): Add a trap for OSError exceptions,
3276 * IPython/genutils.py (page): Add a trap for OSError exceptions,
3271 sometimes seen by win2k/cygwin users.
3277 sometimes seen by win2k/cygwin users.
3272
3278
3273 2004-11-06 Fernando Perez <fperez@colorado.edu>
3279 2004-11-06 Fernando Perez <fperez@colorado.edu>
3274
3280
3275 * IPython/iplib.py (interact): Change the handling of %Exit from
3281 * IPython/iplib.py (interact): Change the handling of %Exit from
3276 trying to propagate a SystemExit to an internal ipython flag.
3282 trying to propagate a SystemExit to an internal ipython flag.
3277 This is less elegant than using Python's exception mechanism, but
3283 This is less elegant than using Python's exception mechanism, but
3278 I can't get that to work reliably with threads, so under -pylab
3284 I can't get that to work reliably with threads, so under -pylab
3279 %Exit was hanging IPython. Cross-thread exception handling is
3285 %Exit was hanging IPython. Cross-thread exception handling is
3280 really a bitch. Thaks to a bug report by Stephen Walton
3286 really a bitch. Thaks to a bug report by Stephen Walton
3281 <stephen.walton-AT-csun.edu>.
3287 <stephen.walton-AT-csun.edu>.
3282
3288
3283 2004-11-04 Fernando Perez <fperez@colorado.edu>
3289 2004-11-04 Fernando Perez <fperez@colorado.edu>
3284
3290
3285 * IPython/iplib.py (raw_input_original): store a pointer to the
3291 * IPython/iplib.py (raw_input_original): store a pointer to the
3286 true raw_input to harden against code which can modify it
3292 true raw_input to harden against code which can modify it
3287 (wx.py.PyShell does this and would otherwise crash ipython).
3293 (wx.py.PyShell does this and would otherwise crash ipython).
3288 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
3294 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
3289
3295
3290 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
3296 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
3291 Ctrl-C problem, which does not mess up the input line.
3297 Ctrl-C problem, which does not mess up the input line.
3292
3298
3293 2004-11-03 Fernando Perez <fperez@colorado.edu>
3299 2004-11-03 Fernando Perez <fperez@colorado.edu>
3294
3300
3295 * IPython/Release.py: Changed licensing to BSD, in all files.
3301 * IPython/Release.py: Changed licensing to BSD, in all files.
3296 (name): lowercase name for tarball/RPM release.
3302 (name): lowercase name for tarball/RPM release.
3297
3303
3298 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
3304 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
3299 use throughout ipython.
3305 use throughout ipython.
3300
3306
3301 * IPython/Magic.py (Magic._ofind): Switch to using the new
3307 * IPython/Magic.py (Magic._ofind): Switch to using the new
3302 OInspect.getdoc() function.
3308 OInspect.getdoc() function.
3303
3309
3304 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
3310 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
3305 of the line currently being canceled via Ctrl-C. It's extremely
3311 of the line currently being canceled via Ctrl-C. It's extremely
3306 ugly, but I don't know how to do it better (the problem is one of
3312 ugly, but I don't know how to do it better (the problem is one of
3307 handling cross-thread exceptions).
3313 handling cross-thread exceptions).
3308
3314
3309 2004-10-28 Fernando Perez <fperez@colorado.edu>
3315 2004-10-28 Fernando Perez <fperez@colorado.edu>
3310
3316
3311 * IPython/Shell.py (signal_handler): add signal handlers to trap
3317 * IPython/Shell.py (signal_handler): add signal handlers to trap
3312 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
3318 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
3313 report by Francesc Alted.
3319 report by Francesc Alted.
3314
3320
3315 2004-10-21 Fernando Perez <fperez@colorado.edu>
3321 2004-10-21 Fernando Perez <fperez@colorado.edu>
3316
3322
3317 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
3323 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
3318 to % for pysh syntax extensions.
3324 to % for pysh syntax extensions.
3319
3325
3320 2004-10-09 Fernando Perez <fperez@colorado.edu>
3326 2004-10-09 Fernando Perez <fperez@colorado.edu>
3321
3327
3322 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
3328 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
3323 arrays to print a more useful summary, without calling str(arr).
3329 arrays to print a more useful summary, without calling str(arr).
3324 This avoids the problem of extremely lengthy computations which
3330 This avoids the problem of extremely lengthy computations which
3325 occur if arr is large, and appear to the user as a system lockup
3331 occur if arr is large, and appear to the user as a system lockup
3326 with 100% cpu activity. After a suggestion by Kristian Sandberg
3332 with 100% cpu activity. After a suggestion by Kristian Sandberg
3327 <Kristian.Sandberg@colorado.edu>.
3333 <Kristian.Sandberg@colorado.edu>.
3328 (Magic.__init__): fix bug in global magic escapes not being
3334 (Magic.__init__): fix bug in global magic escapes not being
3329 correctly set.
3335 correctly set.
3330
3336
3331 2004-10-08 Fernando Perez <fperez@colorado.edu>
3337 2004-10-08 Fernando Perez <fperez@colorado.edu>
3332
3338
3333 * IPython/Magic.py (__license__): change to absolute imports of
3339 * IPython/Magic.py (__license__): change to absolute imports of
3334 ipython's own internal packages, to start adapting to the absolute
3340 ipython's own internal packages, to start adapting to the absolute
3335 import requirement of PEP-328.
3341 import requirement of PEP-328.
3336
3342
3337 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
3343 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
3338 files, and standardize author/license marks through the Release
3344 files, and standardize author/license marks through the Release
3339 module instead of having per/file stuff (except for files with
3345 module instead of having per/file stuff (except for files with
3340 particular licenses, like the MIT/PSF-licensed codes).
3346 particular licenses, like the MIT/PSF-licensed codes).
3341
3347
3342 * IPython/Debugger.py: remove dead code for python 2.1
3348 * IPython/Debugger.py: remove dead code for python 2.1
3343
3349
3344 2004-10-04 Fernando Perez <fperez@colorado.edu>
3350 2004-10-04 Fernando Perez <fperez@colorado.edu>
3345
3351
3346 * IPython/iplib.py (ipmagic): New function for accessing magics
3352 * IPython/iplib.py (ipmagic): New function for accessing magics
3347 via a normal python function call.
3353 via a normal python function call.
3348
3354
3349 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
3355 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
3350 from '@' to '%', to accomodate the new @decorator syntax of python
3356 from '@' to '%', to accomodate the new @decorator syntax of python
3351 2.4.
3357 2.4.
3352
3358
3353 2004-09-29 Fernando Perez <fperez@colorado.edu>
3359 2004-09-29 Fernando Perez <fperez@colorado.edu>
3354
3360
3355 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
3361 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
3356 matplotlib.use to prevent running scripts which try to switch
3362 matplotlib.use to prevent running scripts which try to switch
3357 interactive backends from within ipython. This will just crash
3363 interactive backends from within ipython. This will just crash
3358 the python interpreter, so we can't allow it (but a detailed error
3364 the python interpreter, so we can't allow it (but a detailed error
3359 is given to the user).
3365 is given to the user).
3360
3366
3361 2004-09-28 Fernando Perez <fperez@colorado.edu>
3367 2004-09-28 Fernando Perez <fperez@colorado.edu>
3362
3368
3363 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
3369 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
3364 matplotlib-related fixes so that using @run with non-matplotlib
3370 matplotlib-related fixes so that using @run with non-matplotlib
3365 scripts doesn't pop up spurious plot windows. This requires
3371 scripts doesn't pop up spurious plot windows. This requires
3366 matplotlib >= 0.63, where I had to make some changes as well.
3372 matplotlib >= 0.63, where I had to make some changes as well.
3367
3373
3368 * IPython/ipmaker.py (make_IPython): update version requirement to
3374 * IPython/ipmaker.py (make_IPython): update version requirement to
3369 python 2.2.
3375 python 2.2.
3370
3376
3371 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
3377 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
3372 banner arg for embedded customization.
3378 banner arg for embedded customization.
3373
3379
3374 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
3380 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
3375 explicit uses of __IP as the IPython's instance name. Now things
3381 explicit uses of __IP as the IPython's instance name. Now things
3376 are properly handled via the shell.name value. The actual code
3382 are properly handled via the shell.name value. The actual code
3377 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
3383 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
3378 is much better than before. I'll clean things completely when the
3384 is much better than before. I'll clean things completely when the
3379 magic stuff gets a real overhaul.
3385 magic stuff gets a real overhaul.
3380
3386
3381 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
3387 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
3382 minor changes to debian dir.
3388 minor changes to debian dir.
3383
3389
3384 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
3390 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
3385 pointer to the shell itself in the interactive namespace even when
3391 pointer to the shell itself in the interactive namespace even when
3386 a user-supplied dict is provided. This is needed for embedding
3392 a user-supplied dict is provided. This is needed for embedding
3387 purposes (found by tests with Michel Sanner).
3393 purposes (found by tests with Michel Sanner).
3388
3394
3389 2004-09-27 Fernando Perez <fperez@colorado.edu>
3395 2004-09-27 Fernando Perez <fperez@colorado.edu>
3390
3396
3391 * IPython/UserConfig/ipythonrc: remove []{} from
3397 * IPython/UserConfig/ipythonrc: remove []{} from
3392 readline_remove_delims, so that things like [modname.<TAB> do
3398 readline_remove_delims, so that things like [modname.<TAB> do
3393 proper completion. This disables [].TAB, but that's a less common
3399 proper completion. This disables [].TAB, but that's a less common
3394 case than module names in list comprehensions, for example.
3400 case than module names in list comprehensions, for example.
3395 Thanks to a report by Andrea Riciputi.
3401 Thanks to a report by Andrea Riciputi.
3396
3402
3397 2004-09-09 Fernando Perez <fperez@colorado.edu>
3403 2004-09-09 Fernando Perez <fperez@colorado.edu>
3398
3404
3399 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
3405 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
3400 blocking problems in win32 and osx. Fix by John.
3406 blocking problems in win32 and osx. Fix by John.
3401
3407
3402 2004-09-08 Fernando Perez <fperez@colorado.edu>
3408 2004-09-08 Fernando Perez <fperez@colorado.edu>
3403
3409
3404 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
3410 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
3405 for Win32 and OSX. Fix by John Hunter.
3411 for Win32 and OSX. Fix by John Hunter.
3406
3412
3407 2004-08-30 *** Released version 0.6.3
3413 2004-08-30 *** Released version 0.6.3
3408
3414
3409 2004-08-30 Fernando Perez <fperez@colorado.edu>
3415 2004-08-30 Fernando Perez <fperez@colorado.edu>
3410
3416
3411 * setup.py (isfile): Add manpages to list of dependent files to be
3417 * setup.py (isfile): Add manpages to list of dependent files to be
3412 updated.
3418 updated.
3413
3419
3414 2004-08-27 Fernando Perez <fperez@colorado.edu>
3420 2004-08-27 Fernando Perez <fperez@colorado.edu>
3415
3421
3416 * IPython/Shell.py (start): I've disabled -wthread and -gthread
3422 * IPython/Shell.py (start): I've disabled -wthread and -gthread
3417 for now. They don't really work with standalone WX/GTK code
3423 for now. They don't really work with standalone WX/GTK code
3418 (though matplotlib IS working fine with both of those backends).
3424 (though matplotlib IS working fine with both of those backends).
3419 This will neeed much more testing. I disabled most things with
3425 This will neeed much more testing. I disabled most things with
3420 comments, so turning it back on later should be pretty easy.
3426 comments, so turning it back on later should be pretty easy.
3421
3427
3422 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
3428 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
3423 autocalling of expressions like r'foo', by modifying the line
3429 autocalling of expressions like r'foo', by modifying the line
3424 split regexp. Closes
3430 split regexp. Closes
3425 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
3431 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
3426 Riley <ipythonbugs-AT-sabi.net>.
3432 Riley <ipythonbugs-AT-sabi.net>.
3427 (InteractiveShell.mainloop): honor --nobanner with banner
3433 (InteractiveShell.mainloop): honor --nobanner with banner
3428 extensions.
3434 extensions.
3429
3435
3430 * IPython/Shell.py: Significant refactoring of all classes, so
3436 * IPython/Shell.py: Significant refactoring of all classes, so
3431 that we can really support ALL matplotlib backends and threading
3437 that we can really support ALL matplotlib backends and threading
3432 models (John spotted a bug with Tk which required this). Now we
3438 models (John spotted a bug with Tk which required this). Now we
3433 should support single-threaded, WX-threads and GTK-threads, both
3439 should support single-threaded, WX-threads and GTK-threads, both
3434 for generic code and for matplotlib.
3440 for generic code and for matplotlib.
3435
3441
3436 * IPython/ipmaker.py (__call__): Changed -mpthread option to
3442 * IPython/ipmaker.py (__call__): Changed -mpthread option to
3437 -pylab, to simplify things for users. Will also remove the pylab
3443 -pylab, to simplify things for users. Will also remove the pylab
3438 profile, since now all of matplotlib configuration is directly
3444 profile, since now all of matplotlib configuration is directly
3439 handled here. This also reduces startup time.
3445 handled here. This also reduces startup time.
3440
3446
3441 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
3447 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
3442 shell wasn't being correctly called. Also in IPShellWX.
3448 shell wasn't being correctly called. Also in IPShellWX.
3443
3449
3444 * IPython/iplib.py (InteractiveShell.__init__): Added option to
3450 * IPython/iplib.py (InteractiveShell.__init__): Added option to
3445 fine-tune banner.
3451 fine-tune banner.
3446
3452
3447 * IPython/numutils.py (spike): Deprecate these spike functions,
3453 * IPython/numutils.py (spike): Deprecate these spike functions,
3448 delete (long deprecated) gnuplot_exec handler.
3454 delete (long deprecated) gnuplot_exec handler.
3449
3455
3450 2004-08-26 Fernando Perez <fperez@colorado.edu>
3456 2004-08-26 Fernando Perez <fperez@colorado.edu>
3451
3457
3452 * ipython.1: Update for threading options, plus some others which
3458 * ipython.1: Update for threading options, plus some others which
3453 were missing.
3459 were missing.
3454
3460
3455 * IPython/ipmaker.py (__call__): Added -wthread option for
3461 * IPython/ipmaker.py (__call__): Added -wthread option for
3456 wxpython thread handling. Make sure threading options are only
3462 wxpython thread handling. Make sure threading options are only
3457 valid at the command line.
3463 valid at the command line.
3458
3464
3459 * scripts/ipython: moved shell selection into a factory function
3465 * scripts/ipython: moved shell selection into a factory function
3460 in Shell.py, to keep the starter script to a minimum.
3466 in Shell.py, to keep the starter script to a minimum.
3461
3467
3462 2004-08-25 Fernando Perez <fperez@colorado.edu>
3468 2004-08-25 Fernando Perez <fperez@colorado.edu>
3463
3469
3464 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
3470 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
3465 John. Along with some recent changes he made to matplotlib, the
3471 John. Along with some recent changes he made to matplotlib, the
3466 next versions of both systems should work very well together.
3472 next versions of both systems should work very well together.
3467
3473
3468 2004-08-24 Fernando Perez <fperez@colorado.edu>
3474 2004-08-24 Fernando Perez <fperez@colorado.edu>
3469
3475
3470 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
3476 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
3471 tried to switch the profiling to using hotshot, but I'm getting
3477 tried to switch the profiling to using hotshot, but I'm getting
3472 strange errors from prof.runctx() there. I may be misreading the
3478 strange errors from prof.runctx() there. I may be misreading the
3473 docs, but it looks weird. For now the profiling code will
3479 docs, but it looks weird. For now the profiling code will
3474 continue to use the standard profiler.
3480 continue to use the standard profiler.
3475
3481
3476 2004-08-23 Fernando Perez <fperez@colorado.edu>
3482 2004-08-23 Fernando Perez <fperez@colorado.edu>
3477
3483
3478 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
3484 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
3479 threaded shell, by John Hunter. It's not quite ready yet, but
3485 threaded shell, by John Hunter. It's not quite ready yet, but
3480 close.
3486 close.
3481
3487
3482 2004-08-22 Fernando Perez <fperez@colorado.edu>
3488 2004-08-22 Fernando Perez <fperez@colorado.edu>
3483
3489
3484 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
3490 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
3485 in Magic and ultraTB.
3491 in Magic and ultraTB.
3486
3492
3487 * ipython.1: document threading options in manpage.
3493 * ipython.1: document threading options in manpage.
3488
3494
3489 * scripts/ipython: Changed name of -thread option to -gthread,
3495 * scripts/ipython: Changed name of -thread option to -gthread,
3490 since this is GTK specific. I want to leave the door open for a
3496 since this is GTK specific. I want to leave the door open for a
3491 -wthread option for WX, which will most likely be necessary. This
3497 -wthread option for WX, which will most likely be necessary. This
3492 change affects usage and ipmaker as well.
3498 change affects usage and ipmaker as well.
3493
3499
3494 * IPython/Shell.py (matplotlib_shell): Add a factory function to
3500 * IPython/Shell.py (matplotlib_shell): Add a factory function to
3495 handle the matplotlib shell issues. Code by John Hunter
3501 handle the matplotlib shell issues. Code by John Hunter
3496 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3502 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3497 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
3503 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
3498 broken (and disabled for end users) for now, but it puts the
3504 broken (and disabled for end users) for now, but it puts the
3499 infrastructure in place.
3505 infrastructure in place.
3500
3506
3501 2004-08-21 Fernando Perez <fperez@colorado.edu>
3507 2004-08-21 Fernando Perez <fperez@colorado.edu>
3502
3508
3503 * ipythonrc-pylab: Add matplotlib support.
3509 * ipythonrc-pylab: Add matplotlib support.
3504
3510
3505 * matplotlib_config.py: new files for matplotlib support, part of
3511 * matplotlib_config.py: new files for matplotlib support, part of
3506 the pylab profile.
3512 the pylab profile.
3507
3513
3508 * IPython/usage.py (__doc__): documented the threading options.
3514 * IPython/usage.py (__doc__): documented the threading options.
3509
3515
3510 2004-08-20 Fernando Perez <fperez@colorado.edu>
3516 2004-08-20 Fernando Perez <fperez@colorado.edu>
3511
3517
3512 * ipython: Modified the main calling routine to handle the -thread
3518 * ipython: Modified the main calling routine to handle the -thread
3513 and -mpthread options. This needs to be done as a top-level hack,
3519 and -mpthread options. This needs to be done as a top-level hack,
3514 because it determines which class to instantiate for IPython
3520 because it determines which class to instantiate for IPython
3515 itself.
3521 itself.
3516
3522
3517 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
3523 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
3518 classes to support multithreaded GTK operation without blocking,
3524 classes to support multithreaded GTK operation without blocking,
3519 and matplotlib with all backends. This is a lot of still very
3525 and matplotlib with all backends. This is a lot of still very
3520 experimental code, and threads are tricky. So it may still have a
3526 experimental code, and threads are tricky. So it may still have a
3521 few rough edges... This code owes a lot to
3527 few rough edges... This code owes a lot to
3522 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
3528 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
3523 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
3529 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
3524 to John Hunter for all the matplotlib work.
3530 to John Hunter for all the matplotlib work.
3525
3531
3526 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
3532 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
3527 options for gtk thread and matplotlib support.
3533 options for gtk thread and matplotlib support.
3528
3534
3529 2004-08-16 Fernando Perez <fperez@colorado.edu>
3535 2004-08-16 Fernando Perez <fperez@colorado.edu>
3530
3536
3531 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
3537 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
3532 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
3538 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
3533 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
3539 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
3534
3540
3535 2004-08-11 Fernando Perez <fperez@colorado.edu>
3541 2004-08-11 Fernando Perez <fperez@colorado.edu>
3536
3542
3537 * setup.py (isfile): Fix build so documentation gets updated for
3543 * setup.py (isfile): Fix build so documentation gets updated for
3538 rpms (it was only done for .tgz builds).
3544 rpms (it was only done for .tgz builds).
3539
3545
3540 2004-08-10 Fernando Perez <fperez@colorado.edu>
3546 2004-08-10 Fernando Perez <fperez@colorado.edu>
3541
3547
3542 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
3548 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
3543
3549
3544 * iplib.py : Silence syntax error exceptions in tab-completion.
3550 * iplib.py : Silence syntax error exceptions in tab-completion.
3545
3551
3546 2004-08-05 Fernando Perez <fperez@colorado.edu>
3552 2004-08-05 Fernando Perez <fperez@colorado.edu>
3547
3553
3548 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
3554 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
3549 'color off' mark for continuation prompts. This was causing long
3555 'color off' mark for continuation prompts. This was causing long
3550 continuation lines to mis-wrap.
3556 continuation lines to mis-wrap.
3551
3557
3552 2004-08-01 Fernando Perez <fperez@colorado.edu>
3558 2004-08-01 Fernando Perez <fperez@colorado.edu>
3553
3559
3554 * IPython/ipmaker.py (make_IPython): Allow the shell class used
3560 * IPython/ipmaker.py (make_IPython): Allow the shell class used
3555 for building ipython to be a parameter. All this is necessary
3561 for building ipython to be a parameter. All this is necessary
3556 right now to have a multithreaded version, but this insane
3562 right now to have a multithreaded version, but this insane
3557 non-design will be cleaned up soon. For now, it's a hack that
3563 non-design will be cleaned up soon. For now, it's a hack that
3558 works.
3564 works.
3559
3565
3560 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
3566 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
3561 args in various places. No bugs so far, but it's a dangerous
3567 args in various places. No bugs so far, but it's a dangerous
3562 practice.
3568 practice.
3563
3569
3564 2004-07-31 Fernando Perez <fperez@colorado.edu>
3570 2004-07-31 Fernando Perez <fperez@colorado.edu>
3565
3571
3566 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
3572 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
3567 fix completion of files with dots in their names under most
3573 fix completion of files with dots in their names under most
3568 profiles (pysh was OK because the completion order is different).
3574 profiles (pysh was OK because the completion order is different).
3569
3575
3570 2004-07-27 Fernando Perez <fperez@colorado.edu>
3576 2004-07-27 Fernando Perez <fperez@colorado.edu>
3571
3577
3572 * IPython/iplib.py (InteractiveShell.__init__): build dict of
3578 * IPython/iplib.py (InteractiveShell.__init__): build dict of
3573 keywords manually, b/c the one in keyword.py was removed in python
3579 keywords manually, b/c the one in keyword.py was removed in python
3574 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
3580 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
3575 This is NOT a bug under python 2.3 and earlier.
3581 This is NOT a bug under python 2.3 and earlier.
3576
3582
3577 2004-07-26 Fernando Perez <fperez@colorado.edu>
3583 2004-07-26 Fernando Perez <fperez@colorado.edu>
3578
3584
3579 * IPython/ultraTB.py (VerboseTB.text): Add another
3585 * IPython/ultraTB.py (VerboseTB.text): Add another
3580 linecache.checkcache() call to try to prevent inspect.py from
3586 linecache.checkcache() call to try to prevent inspect.py from
3581 crashing under python 2.3. I think this fixes
3587 crashing under python 2.3. I think this fixes
3582 http://www.scipy.net/roundup/ipython/issue17.
3588 http://www.scipy.net/roundup/ipython/issue17.
3583
3589
3584 2004-07-26 *** Released version 0.6.2
3590 2004-07-26 *** Released version 0.6.2
3585
3591
3586 2004-07-26 Fernando Perez <fperez@colorado.edu>
3592 2004-07-26 Fernando Perez <fperez@colorado.edu>
3587
3593
3588 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
3594 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
3589 fail for any number.
3595 fail for any number.
3590 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
3596 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
3591 empty bookmarks.
3597 empty bookmarks.
3592
3598
3593 2004-07-26 *** Released version 0.6.1
3599 2004-07-26 *** Released version 0.6.1
3594
3600
3595 2004-07-26 Fernando Perez <fperez@colorado.edu>
3601 2004-07-26 Fernando Perez <fperez@colorado.edu>
3596
3602
3597 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
3603 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
3598
3604
3599 * IPython/iplib.py (protect_filename): Applied Ville's patch for
3605 * IPython/iplib.py (protect_filename): Applied Ville's patch for
3600 escaping '()[]{}' in filenames.
3606 escaping '()[]{}' in filenames.
3601
3607
3602 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
3608 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
3603 Python 2.2 users who lack a proper shlex.split.
3609 Python 2.2 users who lack a proper shlex.split.
3604
3610
3605 2004-07-19 Fernando Perez <fperez@colorado.edu>
3611 2004-07-19 Fernando Perez <fperez@colorado.edu>
3606
3612
3607 * IPython/iplib.py (InteractiveShell.init_readline): Add support
3613 * IPython/iplib.py (InteractiveShell.init_readline): Add support
3608 for reading readline's init file. I follow the normal chain:
3614 for reading readline's init file. I follow the normal chain:
3609 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
3615 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
3610 report by Mike Heeter. This closes
3616 report by Mike Heeter. This closes
3611 http://www.scipy.net/roundup/ipython/issue16.
3617 http://www.scipy.net/roundup/ipython/issue16.
3612
3618
3613 2004-07-18 Fernando Perez <fperez@colorado.edu>
3619 2004-07-18 Fernando Perez <fperez@colorado.edu>
3614
3620
3615 * IPython/iplib.py (__init__): Add better handling of '\' under
3621 * IPython/iplib.py (__init__): Add better handling of '\' under
3616 Win32 for filenames. After a patch by Ville.
3622 Win32 for filenames. After a patch by Ville.
3617
3623
3618 2004-07-17 Fernando Perez <fperez@colorado.edu>
3624 2004-07-17 Fernando Perez <fperez@colorado.edu>
3619
3625
3620 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3626 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3621 autocalling would be triggered for 'foo is bar' if foo is
3627 autocalling would be triggered for 'foo is bar' if foo is
3622 callable. I also cleaned up the autocall detection code to use a
3628 callable. I also cleaned up the autocall detection code to use a
3623 regexp, which is faster. Bug reported by Alexander Schmolck.
3629 regexp, which is faster. Bug reported by Alexander Schmolck.
3624
3630
3625 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
3631 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
3626 '?' in them would confuse the help system. Reported by Alex
3632 '?' in them would confuse the help system. Reported by Alex
3627 Schmolck.
3633 Schmolck.
3628
3634
3629 2004-07-16 Fernando Perez <fperez@colorado.edu>
3635 2004-07-16 Fernando Perez <fperez@colorado.edu>
3630
3636
3631 * IPython/GnuplotInteractive.py (__all__): added plot2.
3637 * IPython/GnuplotInteractive.py (__all__): added plot2.
3632
3638
3633 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
3639 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
3634 plotting dictionaries, lists or tuples of 1d arrays.
3640 plotting dictionaries, lists or tuples of 1d arrays.
3635
3641
3636 * IPython/Magic.py (Magic.magic_hist): small clenaups and
3642 * IPython/Magic.py (Magic.magic_hist): small clenaups and
3637 optimizations.
3643 optimizations.
3638
3644
3639 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
3645 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
3640 the information which was there from Janko's original IPP code:
3646 the information which was there from Janko's original IPP code:
3641
3647
3642 03.05.99 20:53 porto.ifm.uni-kiel.de
3648 03.05.99 20:53 porto.ifm.uni-kiel.de
3643 --Started changelog.
3649 --Started changelog.
3644 --make clear do what it say it does
3650 --make clear do what it say it does
3645 --added pretty output of lines from inputcache
3651 --added pretty output of lines from inputcache
3646 --Made Logger a mixin class, simplifies handling of switches
3652 --Made Logger a mixin class, simplifies handling of switches
3647 --Added own completer class. .string<TAB> expands to last history
3653 --Added own completer class. .string<TAB> expands to last history
3648 line which starts with string. The new expansion is also present
3654 line which starts with string. The new expansion is also present
3649 with Ctrl-r from the readline library. But this shows, who this
3655 with Ctrl-r from the readline library. But this shows, who this
3650 can be done for other cases.
3656 can be done for other cases.
3651 --Added convention that all shell functions should accept a
3657 --Added convention that all shell functions should accept a
3652 parameter_string This opens the door for different behaviour for
3658 parameter_string This opens the door for different behaviour for
3653 each function. @cd is a good example of this.
3659 each function. @cd is a good example of this.
3654
3660
3655 04.05.99 12:12 porto.ifm.uni-kiel.de
3661 04.05.99 12:12 porto.ifm.uni-kiel.de
3656 --added logfile rotation
3662 --added logfile rotation
3657 --added new mainloop method which freezes first the namespace
3663 --added new mainloop method which freezes first the namespace
3658
3664
3659 07.05.99 21:24 porto.ifm.uni-kiel.de
3665 07.05.99 21:24 porto.ifm.uni-kiel.de
3660 --added the docreader classes. Now there is a help system.
3666 --added the docreader classes. Now there is a help system.
3661 -This is only a first try. Currently it's not easy to put new
3667 -This is only a first try. Currently it's not easy to put new
3662 stuff in the indices. But this is the way to go. Info would be
3668 stuff in the indices. But this is the way to go. Info would be
3663 better, but HTML is every where and not everybody has an info
3669 better, but HTML is every where and not everybody has an info
3664 system installed and it's not so easy to change html-docs to info.
3670 system installed and it's not so easy to change html-docs to info.
3665 --added global logfile option
3671 --added global logfile option
3666 --there is now a hook for object inspection method pinfo needs to
3672 --there is now a hook for object inspection method pinfo needs to
3667 be provided for this. Can be reached by two '??'.
3673 be provided for this. Can be reached by two '??'.
3668
3674
3669 08.05.99 20:51 porto.ifm.uni-kiel.de
3675 08.05.99 20:51 porto.ifm.uni-kiel.de
3670 --added a README
3676 --added a README
3671 --bug in rc file. Something has changed so functions in the rc
3677 --bug in rc file. Something has changed so functions in the rc
3672 file need to reference the shell and not self. Not clear if it's a
3678 file need to reference the shell and not self. Not clear if it's a
3673 bug or feature.
3679 bug or feature.
3674 --changed rc file for new behavior
3680 --changed rc file for new behavior
3675
3681
3676 2004-07-15 Fernando Perez <fperez@colorado.edu>
3682 2004-07-15 Fernando Perez <fperez@colorado.edu>
3677
3683
3678 * IPython/Logger.py (Logger.log): fixed recent bug where the input
3684 * IPython/Logger.py (Logger.log): fixed recent bug where the input
3679 cache was falling out of sync in bizarre manners when multi-line
3685 cache was falling out of sync in bizarre manners when multi-line
3680 input was present. Minor optimizations and cleanup.
3686 input was present. Minor optimizations and cleanup.
3681
3687
3682 (Logger): Remove old Changelog info for cleanup. This is the
3688 (Logger): Remove old Changelog info for cleanup. This is the
3683 information which was there from Janko's original code:
3689 information which was there from Janko's original code:
3684
3690
3685 Changes to Logger: - made the default log filename a parameter
3691 Changes to Logger: - made the default log filename a parameter
3686
3692
3687 - put a check for lines beginning with !@? in log(). Needed
3693 - put a check for lines beginning with !@? in log(). Needed
3688 (even if the handlers properly log their lines) for mid-session
3694 (even if the handlers properly log their lines) for mid-session
3689 logging activation to work properly. Without this, lines logged
3695 logging activation to work properly. Without this, lines logged
3690 in mid session, which get read from the cache, would end up
3696 in mid session, which get read from the cache, would end up
3691 'bare' (with !@? in the open) in the log. Now they are caught
3697 'bare' (with !@? in the open) in the log. Now they are caught
3692 and prepended with a #.
3698 and prepended with a #.
3693
3699
3694 * IPython/iplib.py (InteractiveShell.init_readline): added check
3700 * IPython/iplib.py (InteractiveShell.init_readline): added check
3695 in case MagicCompleter fails to be defined, so we don't crash.
3701 in case MagicCompleter fails to be defined, so we don't crash.
3696
3702
3697 2004-07-13 Fernando Perez <fperez@colorado.edu>
3703 2004-07-13 Fernando Perez <fperez@colorado.edu>
3698
3704
3699 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
3705 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
3700 of EPS if the requested filename ends in '.eps'.
3706 of EPS if the requested filename ends in '.eps'.
3701
3707
3702 2004-07-04 Fernando Perez <fperez@colorado.edu>
3708 2004-07-04 Fernando Perez <fperez@colorado.edu>
3703
3709
3704 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
3710 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
3705 escaping of quotes when calling the shell.
3711 escaping of quotes when calling the shell.
3706
3712
3707 2004-07-02 Fernando Perez <fperez@colorado.edu>
3713 2004-07-02 Fernando Perez <fperez@colorado.edu>
3708
3714
3709 * IPython/Prompts.py (CachedOutput.update): Fix problem with
3715 * IPython/Prompts.py (CachedOutput.update): Fix problem with
3710 gettext not working because we were clobbering '_'. Fixes
3716 gettext not working because we were clobbering '_'. Fixes
3711 http://www.scipy.net/roundup/ipython/issue6.
3717 http://www.scipy.net/roundup/ipython/issue6.
3712
3718
3713 2004-07-01 Fernando Perez <fperez@colorado.edu>
3719 2004-07-01 Fernando Perez <fperez@colorado.edu>
3714
3720
3715 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
3721 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
3716 into @cd. Patch by Ville.
3722 into @cd. Patch by Ville.
3717
3723
3718 * IPython/iplib.py (InteractiveShell.post_config_initialization):
3724 * IPython/iplib.py (InteractiveShell.post_config_initialization):
3719 new function to store things after ipmaker runs. Patch by Ville.
3725 new function to store things after ipmaker runs. Patch by Ville.
3720 Eventually this will go away once ipmaker is removed and the class
3726 Eventually this will go away once ipmaker is removed and the class
3721 gets cleaned up, but for now it's ok. Key functionality here is
3727 gets cleaned up, but for now it's ok. Key functionality here is
3722 the addition of the persistent storage mechanism, a dict for
3728 the addition of the persistent storage mechanism, a dict for
3723 keeping data across sessions (for now just bookmarks, but more can
3729 keeping data across sessions (for now just bookmarks, but more can
3724 be implemented later).
3730 be implemented later).
3725
3731
3726 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
3732 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
3727 persistent across sections. Patch by Ville, I modified it
3733 persistent across sections. Patch by Ville, I modified it
3728 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
3734 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
3729 added a '-l' option to list all bookmarks.
3735 added a '-l' option to list all bookmarks.
3730
3736
3731 * IPython/iplib.py (InteractiveShell.atexit_operations): new
3737 * IPython/iplib.py (InteractiveShell.atexit_operations): new
3732 center for cleanup. Registered with atexit.register(). I moved
3738 center for cleanup. Registered with atexit.register(). I moved
3733 here the old exit_cleanup(). After a patch by Ville.
3739 here the old exit_cleanup(). After a patch by Ville.
3734
3740
3735 * IPython/Magic.py (get_py_filename): added '~' to the accepted
3741 * IPython/Magic.py (get_py_filename): added '~' to the accepted
3736 characters in the hacked shlex_split for python 2.2.
3742 characters in the hacked shlex_split for python 2.2.
3737
3743
3738 * IPython/iplib.py (file_matches): more fixes to filenames with
3744 * IPython/iplib.py (file_matches): more fixes to filenames with
3739 whitespace in them. It's not perfect, but limitations in python's
3745 whitespace in them. It's not perfect, but limitations in python's
3740 readline make it impossible to go further.
3746 readline make it impossible to go further.
3741
3747
3742 2004-06-29 Fernando Perez <fperez@colorado.edu>
3748 2004-06-29 Fernando Perez <fperez@colorado.edu>
3743
3749
3744 * IPython/iplib.py (file_matches): escape whitespace correctly in
3750 * IPython/iplib.py (file_matches): escape whitespace correctly in
3745 filename completions. Bug reported by Ville.
3751 filename completions. Bug reported by Ville.
3746
3752
3747 2004-06-28 Fernando Perez <fperez@colorado.edu>
3753 2004-06-28 Fernando Perez <fperez@colorado.edu>
3748
3754
3749 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
3755 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
3750 the history file will be called 'history-PROFNAME' (or just
3756 the history file will be called 'history-PROFNAME' (or just
3751 'history' if no profile is loaded). I was getting annoyed at
3757 'history' if no profile is loaded). I was getting annoyed at
3752 getting my Numerical work history clobbered by pysh sessions.
3758 getting my Numerical work history clobbered by pysh sessions.
3753
3759
3754 * IPython/iplib.py (InteractiveShell.__init__): Internal
3760 * IPython/iplib.py (InteractiveShell.__init__): Internal
3755 getoutputerror() function so that we can honor the system_verbose
3761 getoutputerror() function so that we can honor the system_verbose
3756 flag for _all_ system calls. I also added escaping of #
3762 flag for _all_ system calls. I also added escaping of #
3757 characters here to avoid confusing Itpl.
3763 characters here to avoid confusing Itpl.
3758
3764
3759 * IPython/Magic.py (shlex_split): removed call to shell in
3765 * IPython/Magic.py (shlex_split): removed call to shell in
3760 parse_options and replaced it with shlex.split(). The annoying
3766 parse_options and replaced it with shlex.split(). The annoying
3761 part was that in Python 2.2, shlex.split() doesn't exist, so I had
3767 part was that in Python 2.2, shlex.split() doesn't exist, so I had
3762 to backport it from 2.3, with several frail hacks (the shlex
3768 to backport it from 2.3, with several frail hacks (the shlex
3763 module is rather limited in 2.2). Thanks to a suggestion by Ville
3769 module is rather limited in 2.2). Thanks to a suggestion by Ville
3764 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
3770 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
3765 problem.
3771 problem.
3766
3772
3767 (Magic.magic_system_verbose): new toggle to print the actual
3773 (Magic.magic_system_verbose): new toggle to print the actual
3768 system calls made by ipython. Mainly for debugging purposes.
3774 system calls made by ipython. Mainly for debugging purposes.
3769
3775
3770 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
3776 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
3771 doesn't support persistence. Reported (and fix suggested) by
3777 doesn't support persistence. Reported (and fix suggested) by
3772 Travis Caldwell <travis_caldwell2000@yahoo.com>.
3778 Travis Caldwell <travis_caldwell2000@yahoo.com>.
3773
3779
3774 2004-06-26 Fernando Perez <fperez@colorado.edu>
3780 2004-06-26 Fernando Perez <fperez@colorado.edu>
3775
3781
3776 * IPython/Logger.py (Logger.log): fix to handle correctly empty
3782 * IPython/Logger.py (Logger.log): fix to handle correctly empty
3777 continue prompts.
3783 continue prompts.
3778
3784
3779 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
3785 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
3780 function (basically a big docstring) and a few more things here to
3786 function (basically a big docstring) and a few more things here to
3781 speedup startup. pysh.py is now very lightweight. We want because
3787 speedup startup. pysh.py is now very lightweight. We want because
3782 it gets execfile'd, while InterpreterExec gets imported, so
3788 it gets execfile'd, while InterpreterExec gets imported, so
3783 byte-compilation saves time.
3789 byte-compilation saves time.
3784
3790
3785 2004-06-25 Fernando Perez <fperez@colorado.edu>
3791 2004-06-25 Fernando Perez <fperez@colorado.edu>
3786
3792
3787 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
3793 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
3788 -NUM', which was recently broken.
3794 -NUM', which was recently broken.
3789
3795
3790 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
3796 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
3791 in multi-line input (but not !!, which doesn't make sense there).
3797 in multi-line input (but not !!, which doesn't make sense there).
3792
3798
3793 * IPython/UserConfig/ipythonrc: made autoindent on by default.
3799 * IPython/UserConfig/ipythonrc: made autoindent on by default.
3794 It's just too useful, and people can turn it off in the less
3800 It's just too useful, and people can turn it off in the less
3795 common cases where it's a problem.
3801 common cases where it's a problem.
3796
3802
3797 2004-06-24 Fernando Perez <fperez@colorado.edu>
3803 2004-06-24 Fernando Perez <fperez@colorado.edu>
3798
3804
3799 * IPython/iplib.py (InteractiveShell._prefilter): big change -
3805 * IPython/iplib.py (InteractiveShell._prefilter): big change -
3800 special syntaxes (like alias calling) is now allied in multi-line
3806 special syntaxes (like alias calling) is now allied in multi-line
3801 input. This is still _very_ experimental, but it's necessary for
3807 input. This is still _very_ experimental, but it's necessary for
3802 efficient shell usage combining python looping syntax with system
3808 efficient shell usage combining python looping syntax with system
3803 calls. For now it's restricted to aliases, I don't think it
3809 calls. For now it's restricted to aliases, I don't think it
3804 really even makes sense to have this for magics.
3810 really even makes sense to have this for magics.
3805
3811
3806 2004-06-23 Fernando Perez <fperez@colorado.edu>
3812 2004-06-23 Fernando Perez <fperez@colorado.edu>
3807
3813
3808 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
3814 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
3809 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
3815 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
3810
3816
3811 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
3817 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
3812 extensions under Windows (after code sent by Gary Bishop). The
3818 extensions under Windows (after code sent by Gary Bishop). The
3813 extensions considered 'executable' are stored in IPython's rc
3819 extensions considered 'executable' are stored in IPython's rc
3814 structure as win_exec_ext.
3820 structure as win_exec_ext.
3815
3821
3816 * IPython/genutils.py (shell): new function, like system() but
3822 * IPython/genutils.py (shell): new function, like system() but
3817 without return value. Very useful for interactive shell work.
3823 without return value. Very useful for interactive shell work.
3818
3824
3819 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
3825 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
3820 delete aliases.
3826 delete aliases.
3821
3827
3822 * IPython/iplib.py (InteractiveShell.alias_table_update): make
3828 * IPython/iplib.py (InteractiveShell.alias_table_update): make
3823 sure that the alias table doesn't contain python keywords.
3829 sure that the alias table doesn't contain python keywords.
3824
3830
3825 2004-06-21 Fernando Perez <fperez@colorado.edu>
3831 2004-06-21 Fernando Perez <fperez@colorado.edu>
3826
3832
3827 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
3833 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
3828 non-existent items are found in $PATH. Reported by Thorsten.
3834 non-existent items are found in $PATH. Reported by Thorsten.
3829
3835
3830 2004-06-20 Fernando Perez <fperez@colorado.edu>
3836 2004-06-20 Fernando Perez <fperez@colorado.edu>
3831
3837
3832 * IPython/iplib.py (complete): modified the completer so that the
3838 * IPython/iplib.py (complete): modified the completer so that the
3833 order of priorities can be easily changed at runtime.
3839 order of priorities can be easily changed at runtime.
3834
3840
3835 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
3841 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
3836 Modified to auto-execute all lines beginning with '~', '/' or '.'.
3842 Modified to auto-execute all lines beginning with '~', '/' or '.'.
3837
3843
3838 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
3844 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
3839 expand Python variables prepended with $ in all system calls. The
3845 expand Python variables prepended with $ in all system calls. The
3840 same was done to InteractiveShell.handle_shell_escape. Now all
3846 same was done to InteractiveShell.handle_shell_escape. Now all
3841 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
3847 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
3842 expansion of python variables and expressions according to the
3848 expansion of python variables and expressions according to the
3843 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
3849 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
3844
3850
3845 Though PEP-215 has been rejected, a similar (but simpler) one
3851 Though PEP-215 has been rejected, a similar (but simpler) one
3846 seems like it will go into Python 2.4, PEP-292 -
3852 seems like it will go into Python 2.4, PEP-292 -
3847 http://www.python.org/peps/pep-0292.html.
3853 http://www.python.org/peps/pep-0292.html.
3848
3854
3849 I'll keep the full syntax of PEP-215, since IPython has since the
3855 I'll keep the full syntax of PEP-215, since IPython has since the
3850 start used Ka-Ping Yee's reference implementation discussed there
3856 start used Ka-Ping Yee's reference implementation discussed there
3851 (Itpl), and I actually like the powerful semantics it offers.
3857 (Itpl), and I actually like the powerful semantics it offers.
3852
3858
3853 In order to access normal shell variables, the $ has to be escaped
3859 In order to access normal shell variables, the $ has to be escaped
3854 via an extra $. For example:
3860 via an extra $. For example:
3855
3861
3856 In [7]: PATH='a python variable'
3862 In [7]: PATH='a python variable'
3857
3863
3858 In [8]: !echo $PATH
3864 In [8]: !echo $PATH
3859 a python variable
3865 a python variable
3860
3866
3861 In [9]: !echo $$PATH
3867 In [9]: !echo $$PATH
3862 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
3868 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
3863
3869
3864 (Magic.parse_options): escape $ so the shell doesn't evaluate
3870 (Magic.parse_options): escape $ so the shell doesn't evaluate
3865 things prematurely.
3871 things prematurely.
3866
3872
3867 * IPython/iplib.py (InteractiveShell.call_alias): added the
3873 * IPython/iplib.py (InteractiveShell.call_alias): added the
3868 ability for aliases to expand python variables via $.
3874 ability for aliases to expand python variables via $.
3869
3875
3870 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
3876 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
3871 system, now there's a @rehash/@rehashx pair of magics. These work
3877 system, now there's a @rehash/@rehashx pair of magics. These work
3872 like the csh rehash command, and can be invoked at any time. They
3878 like the csh rehash command, and can be invoked at any time. They
3873 build a table of aliases to everything in the user's $PATH
3879 build a table of aliases to everything in the user's $PATH
3874 (@rehash uses everything, @rehashx is slower but only adds
3880 (@rehash uses everything, @rehashx is slower but only adds
3875 executable files). With this, the pysh.py-based shell profile can
3881 executable files). With this, the pysh.py-based shell profile can
3876 now simply call rehash upon startup, and full access to all
3882 now simply call rehash upon startup, and full access to all
3877 programs in the user's path is obtained.
3883 programs in the user's path is obtained.
3878
3884
3879 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
3885 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
3880 functionality is now fully in place. I removed the old dynamic
3886 functionality is now fully in place. I removed the old dynamic
3881 code generation based approach, in favor of a much lighter one
3887 code generation based approach, in favor of a much lighter one
3882 based on a simple dict. The advantage is that this allows me to
3888 based on a simple dict. The advantage is that this allows me to
3883 now have thousands of aliases with negligible cost (unthinkable
3889 now have thousands of aliases with negligible cost (unthinkable
3884 with the old system).
3890 with the old system).
3885
3891
3886 2004-06-19 Fernando Perez <fperez@colorado.edu>
3892 2004-06-19 Fernando Perez <fperez@colorado.edu>
3887
3893
3888 * IPython/iplib.py (__init__): extended MagicCompleter class to
3894 * IPython/iplib.py (__init__): extended MagicCompleter class to
3889 also complete (last in priority) on user aliases.
3895 also complete (last in priority) on user aliases.
3890
3896
3891 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
3897 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
3892 call to eval.
3898 call to eval.
3893 (ItplNS.__init__): Added a new class which functions like Itpl,
3899 (ItplNS.__init__): Added a new class which functions like Itpl,
3894 but allows configuring the namespace for the evaluation to occur
3900 but allows configuring the namespace for the evaluation to occur
3895 in.
3901 in.
3896
3902
3897 2004-06-18 Fernando Perez <fperez@colorado.edu>
3903 2004-06-18 Fernando Perez <fperez@colorado.edu>
3898
3904
3899 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
3905 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
3900 better message when 'exit' or 'quit' are typed (a common newbie
3906 better message when 'exit' or 'quit' are typed (a common newbie
3901 confusion).
3907 confusion).
3902
3908
3903 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
3909 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
3904 check for Windows users.
3910 check for Windows users.
3905
3911
3906 * IPython/iplib.py (InteractiveShell.user_setup): removed
3912 * IPython/iplib.py (InteractiveShell.user_setup): removed
3907 disabling of colors for Windows. I'll test at runtime and issue a
3913 disabling of colors for Windows. I'll test at runtime and issue a
3908 warning if Gary's readline isn't found, as to nudge users to
3914 warning if Gary's readline isn't found, as to nudge users to
3909 download it.
3915 download it.
3910
3916
3911 2004-06-16 Fernando Perez <fperez@colorado.edu>
3917 2004-06-16 Fernando Perez <fperez@colorado.edu>
3912
3918
3913 * IPython/genutils.py (Stream.__init__): changed to print errors
3919 * IPython/genutils.py (Stream.__init__): changed to print errors
3914 to sys.stderr. I had a circular dependency here. Now it's
3920 to sys.stderr. I had a circular dependency here. Now it's
3915 possible to run ipython as IDLE's shell (consider this pre-alpha,
3921 possible to run ipython as IDLE's shell (consider this pre-alpha,
3916 since true stdout things end up in the starting terminal instead
3922 since true stdout things end up in the starting terminal instead
3917 of IDLE's out).
3923 of IDLE's out).
3918
3924
3919 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
3925 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
3920 users who haven't # updated their prompt_in2 definitions. Remove
3926 users who haven't # updated their prompt_in2 definitions. Remove
3921 eventually.
3927 eventually.
3922 (multiple_replace): added credit to original ASPN recipe.
3928 (multiple_replace): added credit to original ASPN recipe.
3923
3929
3924 2004-06-15 Fernando Perez <fperez@colorado.edu>
3930 2004-06-15 Fernando Perez <fperez@colorado.edu>
3925
3931
3926 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
3932 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
3927 list of auto-defined aliases.
3933 list of auto-defined aliases.
3928
3934
3929 2004-06-13 Fernando Perez <fperez@colorado.edu>
3935 2004-06-13 Fernando Perez <fperez@colorado.edu>
3930
3936
3931 * setup.py (scriptfiles): Don't trigger win_post_install unless an
3937 * setup.py (scriptfiles): Don't trigger win_post_install unless an
3932 install was really requested (so setup.py can be used for other
3938 install was really requested (so setup.py can be used for other
3933 things under Windows).
3939 things under Windows).
3934
3940
3935 2004-06-10 Fernando Perez <fperez@colorado.edu>
3941 2004-06-10 Fernando Perez <fperez@colorado.edu>
3936
3942
3937 * IPython/Logger.py (Logger.create_log): Manually remove any old
3943 * IPython/Logger.py (Logger.create_log): Manually remove any old
3938 backup, since os.remove may fail under Windows. Fixes bug
3944 backup, since os.remove may fail under Windows. Fixes bug
3939 reported by Thorsten.
3945 reported by Thorsten.
3940
3946
3941 2004-06-09 Fernando Perez <fperez@colorado.edu>
3947 2004-06-09 Fernando Perez <fperez@colorado.edu>
3942
3948
3943 * examples/example-embed.py: fixed all references to %n (replaced
3949 * examples/example-embed.py: fixed all references to %n (replaced
3944 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
3950 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
3945 for all examples and the manual as well.
3951 for all examples and the manual as well.
3946
3952
3947 2004-06-08 Fernando Perez <fperez@colorado.edu>
3953 2004-06-08 Fernando Perez <fperez@colorado.edu>
3948
3954
3949 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
3955 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
3950 alignment and color management. All 3 prompt subsystems now
3956 alignment and color management. All 3 prompt subsystems now
3951 inherit from BasePrompt.
3957 inherit from BasePrompt.
3952
3958
3953 * tools/release: updates for windows installer build and tag rpms
3959 * tools/release: updates for windows installer build and tag rpms
3954 with python version (since paths are fixed).
3960 with python version (since paths are fixed).
3955
3961
3956 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
3962 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
3957 which will become eventually obsolete. Also fixed the default
3963 which will become eventually obsolete. Also fixed the default
3958 prompt_in2 to use \D, so at least new users start with the correct
3964 prompt_in2 to use \D, so at least new users start with the correct
3959 defaults.
3965 defaults.
3960 WARNING: Users with existing ipythonrc files will need to apply
3966 WARNING: Users with existing ipythonrc files will need to apply
3961 this fix manually!
3967 this fix manually!
3962
3968
3963 * setup.py: make windows installer (.exe). This is finally the
3969 * setup.py: make windows installer (.exe). This is finally the
3964 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
3970 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
3965 which I hadn't included because it required Python 2.3 (or recent
3971 which I hadn't included because it required Python 2.3 (or recent
3966 distutils).
3972 distutils).
3967
3973
3968 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
3974 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
3969 usage of new '\D' escape.
3975 usage of new '\D' escape.
3970
3976
3971 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
3977 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
3972 lacks os.getuid())
3978 lacks os.getuid())
3973 (CachedOutput.set_colors): Added the ability to turn coloring
3979 (CachedOutput.set_colors): Added the ability to turn coloring
3974 on/off with @colors even for manually defined prompt colors. It
3980 on/off with @colors even for manually defined prompt colors. It
3975 uses a nasty global, but it works safely and via the generic color
3981 uses a nasty global, but it works safely and via the generic color
3976 handling mechanism.
3982 handling mechanism.
3977 (Prompt2.__init__): Introduced new escape '\D' for continuation
3983 (Prompt2.__init__): Introduced new escape '\D' for continuation
3978 prompts. It represents the counter ('\#') as dots.
3984 prompts. It represents the counter ('\#') as dots.
3979 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
3985 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
3980 need to update their ipythonrc files and replace '%n' with '\D' in
3986 need to update their ipythonrc files and replace '%n' with '\D' in
3981 their prompt_in2 settings everywhere. Sorry, but there's
3987 their prompt_in2 settings everywhere. Sorry, but there's
3982 otherwise no clean way to get all prompts to properly align. The
3988 otherwise no clean way to get all prompts to properly align. The
3983 ipythonrc shipped with IPython has been updated.
3989 ipythonrc shipped with IPython has been updated.
3984
3990
3985 2004-06-07 Fernando Perez <fperez@colorado.edu>
3991 2004-06-07 Fernando Perez <fperez@colorado.edu>
3986
3992
3987 * setup.py (isfile): Pass local_icons option to latex2html, so the
3993 * setup.py (isfile): Pass local_icons option to latex2html, so the
3988 resulting HTML file is self-contained. Thanks to
3994 resulting HTML file is self-contained. Thanks to
3989 dryice-AT-liu.com.cn for the tip.
3995 dryice-AT-liu.com.cn for the tip.
3990
3996
3991 * pysh.py: I created a new profile 'shell', which implements a
3997 * pysh.py: I created a new profile 'shell', which implements a
3992 _rudimentary_ IPython-based shell. This is in NO WAY a realy
3998 _rudimentary_ IPython-based shell. This is in NO WAY a realy
3993 system shell, nor will it become one anytime soon. It's mainly
3999 system shell, nor will it become one anytime soon. It's mainly
3994 meant to illustrate the use of the new flexible bash-like prompts.
4000 meant to illustrate the use of the new flexible bash-like prompts.
3995 I guess it could be used by hardy souls for true shell management,
4001 I guess it could be used by hardy souls for true shell management,
3996 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
4002 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
3997 profile. This uses the InterpreterExec extension provided by
4003 profile. This uses the InterpreterExec extension provided by
3998 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
4004 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
3999
4005
4000 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
4006 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
4001 auto-align itself with the length of the previous input prompt
4007 auto-align itself with the length of the previous input prompt
4002 (taking into account the invisible color escapes).
4008 (taking into account the invisible color escapes).
4003 (CachedOutput.__init__): Large restructuring of this class. Now
4009 (CachedOutput.__init__): Large restructuring of this class. Now
4004 all three prompts (primary1, primary2, output) are proper objects,
4010 all three prompts (primary1, primary2, output) are proper objects,
4005 managed by the 'parent' CachedOutput class. The code is still a
4011 managed by the 'parent' CachedOutput class. The code is still a
4006 bit hackish (all prompts share state via a pointer to the cache),
4012 bit hackish (all prompts share state via a pointer to the cache),
4007 but it's overall far cleaner than before.
4013 but it's overall far cleaner than before.
4008
4014
4009 * IPython/genutils.py (getoutputerror): modified to add verbose,
4015 * IPython/genutils.py (getoutputerror): modified to add verbose,
4010 debug and header options. This makes the interface of all getout*
4016 debug and header options. This makes the interface of all getout*
4011 functions uniform.
4017 functions uniform.
4012 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
4018 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
4013
4019
4014 * IPython/Magic.py (Magic.default_option): added a function to
4020 * IPython/Magic.py (Magic.default_option): added a function to
4015 allow registering default options for any magic command. This
4021 allow registering default options for any magic command. This
4016 makes it easy to have profiles which customize the magics globally
4022 makes it easy to have profiles which customize the magics globally
4017 for a certain use. The values set through this function are
4023 for a certain use. The values set through this function are
4018 picked up by the parse_options() method, which all magics should
4024 picked up by the parse_options() method, which all magics should
4019 use to parse their options.
4025 use to parse their options.
4020
4026
4021 * IPython/genutils.py (warn): modified the warnings framework to
4027 * IPython/genutils.py (warn): modified the warnings framework to
4022 use the Term I/O class. I'm trying to slowly unify all of
4028 use the Term I/O class. I'm trying to slowly unify all of
4023 IPython's I/O operations to pass through Term.
4029 IPython's I/O operations to pass through Term.
4024
4030
4025 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
4031 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
4026 the secondary prompt to correctly match the length of the primary
4032 the secondary prompt to correctly match the length of the primary
4027 one for any prompt. Now multi-line code will properly line up
4033 one for any prompt. Now multi-line code will properly line up
4028 even for path dependent prompts, such as the new ones available
4034 even for path dependent prompts, such as the new ones available
4029 via the prompt_specials.
4035 via the prompt_specials.
4030
4036
4031 2004-06-06 Fernando Perez <fperez@colorado.edu>
4037 2004-06-06 Fernando Perez <fperez@colorado.edu>
4032
4038
4033 * IPython/Prompts.py (prompt_specials): Added the ability to have
4039 * IPython/Prompts.py (prompt_specials): Added the ability to have
4034 bash-like special sequences in the prompts, which get
4040 bash-like special sequences in the prompts, which get
4035 automatically expanded. Things like hostname, current working
4041 automatically expanded. Things like hostname, current working
4036 directory and username are implemented already, but it's easy to
4042 directory and username are implemented already, but it's easy to
4037 add more in the future. Thanks to a patch by W.J. van der Laan
4043 add more in the future. Thanks to a patch by W.J. van der Laan
4038 <gnufnork-AT-hetdigitalegat.nl>
4044 <gnufnork-AT-hetdigitalegat.nl>
4039 (prompt_specials): Added color support for prompt strings, so
4045 (prompt_specials): Added color support for prompt strings, so
4040 users can define arbitrary color setups for their prompts.
4046 users can define arbitrary color setups for their prompts.
4041
4047
4042 2004-06-05 Fernando Perez <fperez@colorado.edu>
4048 2004-06-05 Fernando Perez <fperez@colorado.edu>
4043
4049
4044 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
4050 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
4045 code to load Gary Bishop's readline and configure it
4051 code to load Gary Bishop's readline and configure it
4046 automatically. Thanks to Gary for help on this.
4052 automatically. Thanks to Gary for help on this.
4047
4053
4048 2004-06-01 Fernando Perez <fperez@colorado.edu>
4054 2004-06-01 Fernando Perez <fperez@colorado.edu>
4049
4055
4050 * IPython/Logger.py (Logger.create_log): fix bug for logging
4056 * IPython/Logger.py (Logger.create_log): fix bug for logging
4051 with no filename (previous fix was incomplete).
4057 with no filename (previous fix was incomplete).
4052
4058
4053 2004-05-25 Fernando Perez <fperez@colorado.edu>
4059 2004-05-25 Fernando Perez <fperez@colorado.edu>
4054
4060
4055 * IPython/Magic.py (Magic.parse_options): fix bug where naked
4061 * IPython/Magic.py (Magic.parse_options): fix bug where naked
4056 parens would get passed to the shell.
4062 parens would get passed to the shell.
4057
4063
4058 2004-05-20 Fernando Perez <fperez@colorado.edu>
4064 2004-05-20 Fernando Perez <fperez@colorado.edu>
4059
4065
4060 * IPython/Magic.py (Magic.magic_prun): changed default profile
4066 * IPython/Magic.py (Magic.magic_prun): changed default profile
4061 sort order to 'time' (the more common profiling need).
4067 sort order to 'time' (the more common profiling need).
4062
4068
4063 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
4069 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
4064 so that source code shown is guaranteed in sync with the file on
4070 so that source code shown is guaranteed in sync with the file on
4065 disk (also changed in psource). Similar fix to the one for
4071 disk (also changed in psource). Similar fix to the one for
4066 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
4072 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
4067 <yann.ledu-AT-noos.fr>.
4073 <yann.ledu-AT-noos.fr>.
4068
4074
4069 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
4075 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
4070 with a single option would not be correctly parsed. Closes
4076 with a single option would not be correctly parsed. Closes
4071 http://www.scipy.net/roundup/ipython/issue14. This bug had been
4077 http://www.scipy.net/roundup/ipython/issue14. This bug had been
4072 introduced in 0.6.0 (on 2004-05-06).
4078 introduced in 0.6.0 (on 2004-05-06).
4073
4079
4074 2004-05-13 *** Released version 0.6.0
4080 2004-05-13 *** Released version 0.6.0
4075
4081
4076 2004-05-13 Fernando Perez <fperez@colorado.edu>
4082 2004-05-13 Fernando Perez <fperez@colorado.edu>
4077
4083
4078 * debian/: Added debian/ directory to CVS, so that debian support
4084 * debian/: Added debian/ directory to CVS, so that debian support
4079 is publicly accessible. The debian package is maintained by Jack
4085 is publicly accessible. The debian package is maintained by Jack
4080 Moffit <jack-AT-xiph.org>.
4086 Moffit <jack-AT-xiph.org>.
4081
4087
4082 * Documentation: included the notes about an ipython-based system
4088 * Documentation: included the notes about an ipython-based system
4083 shell (the hypothetical 'pysh') into the new_design.pdf document,
4089 shell (the hypothetical 'pysh') into the new_design.pdf document,
4084 so that these ideas get distributed to users along with the
4090 so that these ideas get distributed to users along with the
4085 official documentation.
4091 official documentation.
4086
4092
4087 2004-05-10 Fernando Perez <fperez@colorado.edu>
4093 2004-05-10 Fernando Perez <fperez@colorado.edu>
4088
4094
4089 * IPython/Logger.py (Logger.create_log): fix recently introduced
4095 * IPython/Logger.py (Logger.create_log): fix recently introduced
4090 bug (misindented line) where logstart would fail when not given an
4096 bug (misindented line) where logstart would fail when not given an
4091 explicit filename.
4097 explicit filename.
4092
4098
4093 2004-05-09 Fernando Perez <fperez@colorado.edu>
4099 2004-05-09 Fernando Perez <fperez@colorado.edu>
4094
4100
4095 * IPython/Magic.py (Magic.parse_options): skip system call when
4101 * IPython/Magic.py (Magic.parse_options): skip system call when
4096 there are no options to look for. Faster, cleaner for the common
4102 there are no options to look for. Faster, cleaner for the common
4097 case.
4103 case.
4098
4104
4099 * Documentation: many updates to the manual: describing Windows
4105 * Documentation: many updates to the manual: describing Windows
4100 support better, Gnuplot updates, credits, misc small stuff. Also
4106 support better, Gnuplot updates, credits, misc small stuff. Also
4101 updated the new_design doc a bit.
4107 updated the new_design doc a bit.
4102
4108
4103 2004-05-06 *** Released version 0.6.0.rc1
4109 2004-05-06 *** Released version 0.6.0.rc1
4104
4110
4105 2004-05-06 Fernando Perez <fperez@colorado.edu>
4111 2004-05-06 Fernando Perez <fperez@colorado.edu>
4106
4112
4107 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
4113 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
4108 operations to use the vastly more efficient list/''.join() method.
4114 operations to use the vastly more efficient list/''.join() method.
4109 (FormattedTB.text): Fix
4115 (FormattedTB.text): Fix
4110 http://www.scipy.net/roundup/ipython/issue12 - exception source
4116 http://www.scipy.net/roundup/ipython/issue12 - exception source
4111 extract not updated after reload. Thanks to Mike Salib
4117 extract not updated after reload. Thanks to Mike Salib
4112 <msalib-AT-mit.edu> for pinning the source of the problem.
4118 <msalib-AT-mit.edu> for pinning the source of the problem.
4113 Fortunately, the solution works inside ipython and doesn't require
4119 Fortunately, the solution works inside ipython and doesn't require
4114 any changes to python proper.
4120 any changes to python proper.
4115
4121
4116 * IPython/Magic.py (Magic.parse_options): Improved to process the
4122 * IPython/Magic.py (Magic.parse_options): Improved to process the
4117 argument list as a true shell would (by actually using the
4123 argument list as a true shell would (by actually using the
4118 underlying system shell). This way, all @magics automatically get
4124 underlying system shell). This way, all @magics automatically get
4119 shell expansion for variables. Thanks to a comment by Alex
4125 shell expansion for variables. Thanks to a comment by Alex
4120 Schmolck.
4126 Schmolck.
4121
4127
4122 2004-04-04 Fernando Perez <fperez@colorado.edu>
4128 2004-04-04 Fernando Perez <fperez@colorado.edu>
4123
4129
4124 * IPython/iplib.py (InteractiveShell.interact): Added a special
4130 * IPython/iplib.py (InteractiveShell.interact): Added a special
4125 trap for a debugger quit exception, which is basically impossible
4131 trap for a debugger quit exception, which is basically impossible
4126 to handle by normal mechanisms, given what pdb does to the stack.
4132 to handle by normal mechanisms, given what pdb does to the stack.
4127 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
4133 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
4128
4134
4129 2004-04-03 Fernando Perez <fperez@colorado.edu>
4135 2004-04-03 Fernando Perez <fperez@colorado.edu>
4130
4136
4131 * IPython/genutils.py (Term): Standardized the names of the Term
4137 * IPython/genutils.py (Term): Standardized the names of the Term
4132 class streams to cin/cout/cerr, following C++ naming conventions
4138 class streams to cin/cout/cerr, following C++ naming conventions
4133 (I can't use in/out/err because 'in' is not a valid attribute
4139 (I can't use in/out/err because 'in' is not a valid attribute
4134 name).
4140 name).
4135
4141
4136 * IPython/iplib.py (InteractiveShell.interact): don't increment
4142 * IPython/iplib.py (InteractiveShell.interact): don't increment
4137 the prompt if there's no user input. By Daniel 'Dang' Griffith
4143 the prompt if there's no user input. By Daniel 'Dang' Griffith
4138 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
4144 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
4139 Francois Pinard.
4145 Francois Pinard.
4140
4146
4141 2004-04-02 Fernando Perez <fperez@colorado.edu>
4147 2004-04-02 Fernando Perez <fperez@colorado.edu>
4142
4148
4143 * IPython/genutils.py (Stream.__init__): Modified to survive at
4149 * IPython/genutils.py (Stream.__init__): Modified to survive at
4144 least importing in contexts where stdin/out/err aren't true file
4150 least importing in contexts where stdin/out/err aren't true file
4145 objects, such as PyCrust (they lack fileno() and mode). However,
4151 objects, such as PyCrust (they lack fileno() and mode). However,
4146 the recovery facilities which rely on these things existing will
4152 the recovery facilities which rely on these things existing will
4147 not work.
4153 not work.
4148
4154
4149 2004-04-01 Fernando Perez <fperez@colorado.edu>
4155 2004-04-01 Fernando Perez <fperez@colorado.edu>
4150
4156
4151 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
4157 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
4152 use the new getoutputerror() function, so it properly
4158 use the new getoutputerror() function, so it properly
4153 distinguishes stdout/err.
4159 distinguishes stdout/err.
4154
4160
4155 * IPython/genutils.py (getoutputerror): added a function to
4161 * IPython/genutils.py (getoutputerror): added a function to
4156 capture separately the standard output and error of a command.
4162 capture separately the standard output and error of a command.
4157 After a comment from dang on the mailing lists. This code is
4163 After a comment from dang on the mailing lists. This code is
4158 basically a modified version of commands.getstatusoutput(), from
4164 basically a modified version of commands.getstatusoutput(), from
4159 the standard library.
4165 the standard library.
4160
4166
4161 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
4167 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
4162 '!!' as a special syntax (shorthand) to access @sx.
4168 '!!' as a special syntax (shorthand) to access @sx.
4163
4169
4164 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
4170 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
4165 command and return its output as a list split on '\n'.
4171 command and return its output as a list split on '\n'.
4166
4172
4167 2004-03-31 Fernando Perez <fperez@colorado.edu>
4173 2004-03-31 Fernando Perez <fperez@colorado.edu>
4168
4174
4169 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
4175 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
4170 method to dictionaries used as FakeModule instances if they lack
4176 method to dictionaries used as FakeModule instances if they lack
4171 it. At least pydoc in python2.3 breaks for runtime-defined
4177 it. At least pydoc in python2.3 breaks for runtime-defined
4172 functions without this hack. At some point I need to _really_
4178 functions without this hack. At some point I need to _really_
4173 understand what FakeModule is doing, because it's a gross hack.
4179 understand what FakeModule is doing, because it's a gross hack.
4174 But it solves Arnd's problem for now...
4180 But it solves Arnd's problem for now...
4175
4181
4176 2004-02-27 Fernando Perez <fperez@colorado.edu>
4182 2004-02-27 Fernando Perez <fperez@colorado.edu>
4177
4183
4178 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
4184 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
4179 mode would behave erratically. Also increased the number of
4185 mode would behave erratically. Also increased the number of
4180 possible logs in rotate mod to 999. Thanks to Rod Holland
4186 possible logs in rotate mod to 999. Thanks to Rod Holland
4181 <rhh@StructureLABS.com> for the report and fixes.
4187 <rhh@StructureLABS.com> for the report and fixes.
4182
4188
4183 2004-02-26 Fernando Perez <fperez@colorado.edu>
4189 2004-02-26 Fernando Perez <fperez@colorado.edu>
4184
4190
4185 * IPython/genutils.py (page): Check that the curses module really
4191 * IPython/genutils.py (page): Check that the curses module really
4186 has the initscr attribute before trying to use it. For some
4192 has the initscr attribute before trying to use it. For some
4187 reason, the Solaris curses module is missing this. I think this
4193 reason, the Solaris curses module is missing this. I think this
4188 should be considered a Solaris python bug, but I'm not sure.
4194 should be considered a Solaris python bug, but I'm not sure.
4189
4195
4190 2004-01-17 Fernando Perez <fperez@colorado.edu>
4196 2004-01-17 Fernando Perez <fperez@colorado.edu>
4191
4197
4192 * IPython/genutils.py (Stream.__init__): Changes to try to make
4198 * IPython/genutils.py (Stream.__init__): Changes to try to make
4193 ipython robust against stdin/out/err being closed by the user.
4199 ipython robust against stdin/out/err being closed by the user.
4194 This is 'user error' (and blocks a normal python session, at least
4200 This is 'user error' (and blocks a normal python session, at least
4195 the stdout case). However, Ipython should be able to survive such
4201 the stdout case). However, Ipython should be able to survive such
4196 instances of abuse as gracefully as possible. To simplify the
4202 instances of abuse as gracefully as possible. To simplify the
4197 coding and maintain compatibility with Gary Bishop's Term
4203 coding and maintain compatibility with Gary Bishop's Term
4198 contributions, I've made use of classmethods for this. I think
4204 contributions, I've made use of classmethods for this. I think
4199 this introduces a dependency on python 2.2.
4205 this introduces a dependency on python 2.2.
4200
4206
4201 2004-01-13 Fernando Perez <fperez@colorado.edu>
4207 2004-01-13 Fernando Perez <fperez@colorado.edu>
4202
4208
4203 * IPython/numutils.py (exp_safe): simplified the code a bit and
4209 * IPython/numutils.py (exp_safe): simplified the code a bit and
4204 removed the need for importing the kinds module altogether.
4210 removed the need for importing the kinds module altogether.
4205
4211
4206 2004-01-06 Fernando Perez <fperez@colorado.edu>
4212 2004-01-06 Fernando Perez <fperez@colorado.edu>
4207
4213
4208 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
4214 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
4209 a magic function instead, after some community feedback. No
4215 a magic function instead, after some community feedback. No
4210 special syntax will exist for it, but its name is deliberately
4216 special syntax will exist for it, but its name is deliberately
4211 very short.
4217 very short.
4212
4218
4213 2003-12-20 Fernando Perez <fperez@colorado.edu>
4219 2003-12-20 Fernando Perez <fperez@colorado.edu>
4214
4220
4215 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
4221 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
4216 new functionality, to automagically assign the result of a shell
4222 new functionality, to automagically assign the result of a shell
4217 command to a variable. I'll solicit some community feedback on
4223 command to a variable. I'll solicit some community feedback on
4218 this before making it permanent.
4224 this before making it permanent.
4219
4225
4220 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
4226 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
4221 requested about callables for which inspect couldn't obtain a
4227 requested about callables for which inspect couldn't obtain a
4222 proper argspec. Thanks to a crash report sent by Etienne
4228 proper argspec. Thanks to a crash report sent by Etienne
4223 Posthumus <etienne-AT-apple01.cs.vu.nl>.
4229 Posthumus <etienne-AT-apple01.cs.vu.nl>.
4224
4230
4225 2003-12-09 Fernando Perez <fperez@colorado.edu>
4231 2003-12-09 Fernando Perez <fperez@colorado.edu>
4226
4232
4227 * IPython/genutils.py (page): patch for the pager to work across
4233 * IPython/genutils.py (page): patch for the pager to work across
4228 various versions of Windows. By Gary Bishop.
4234 various versions of Windows. By Gary Bishop.
4229
4235
4230 2003-12-04 Fernando Perez <fperez@colorado.edu>
4236 2003-12-04 Fernando Perez <fperez@colorado.edu>
4231
4237
4232 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
4238 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
4233 Gnuplot.py version 1.7, whose internal names changed quite a bit.
4239 Gnuplot.py version 1.7, whose internal names changed quite a bit.
4234 While I tested this and it looks ok, there may still be corner
4240 While I tested this and it looks ok, there may still be corner
4235 cases I've missed.
4241 cases I've missed.
4236
4242
4237 2003-12-01 Fernando Perez <fperez@colorado.edu>
4243 2003-12-01 Fernando Perez <fperez@colorado.edu>
4238
4244
4239 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
4245 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
4240 where a line like 'p,q=1,2' would fail because the automagic
4246 where a line like 'p,q=1,2' would fail because the automagic
4241 system would be triggered for @p.
4247 system would be triggered for @p.
4242
4248
4243 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
4249 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
4244 cleanups, code unmodified.
4250 cleanups, code unmodified.
4245
4251
4246 * IPython/genutils.py (Term): added a class for IPython to handle
4252 * IPython/genutils.py (Term): added a class for IPython to handle
4247 output. In most cases it will just be a proxy for stdout/err, but
4253 output. In most cases it will just be a proxy for stdout/err, but
4248 having this allows modifications to be made for some platforms,
4254 having this allows modifications to be made for some platforms,
4249 such as handling color escapes under Windows. All of this code
4255 such as handling color escapes under Windows. All of this code
4250 was contributed by Gary Bishop, with minor modifications by me.
4256 was contributed by Gary Bishop, with minor modifications by me.
4251 The actual changes affect many files.
4257 The actual changes affect many files.
4252
4258
4253 2003-11-30 Fernando Perez <fperez@colorado.edu>
4259 2003-11-30 Fernando Perez <fperez@colorado.edu>
4254
4260
4255 * IPython/iplib.py (file_matches): new completion code, courtesy
4261 * IPython/iplib.py (file_matches): new completion code, courtesy
4256 of Jeff Collins. This enables filename completion again under
4262 of Jeff Collins. This enables filename completion again under
4257 python 2.3, which disabled it at the C level.
4263 python 2.3, which disabled it at the C level.
4258
4264
4259 2003-11-11 Fernando Perez <fperez@colorado.edu>
4265 2003-11-11 Fernando Perez <fperez@colorado.edu>
4260
4266
4261 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
4267 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
4262 for Numeric.array(map(...)), but often convenient.
4268 for Numeric.array(map(...)), but often convenient.
4263
4269
4264 2003-11-05 Fernando Perez <fperez@colorado.edu>
4270 2003-11-05 Fernando Perez <fperez@colorado.edu>
4265
4271
4266 * IPython/numutils.py (frange): Changed a call from int() to
4272 * IPython/numutils.py (frange): Changed a call from int() to
4267 int(round()) to prevent a problem reported with arange() in the
4273 int(round()) to prevent a problem reported with arange() in the
4268 numpy list.
4274 numpy list.
4269
4275
4270 2003-10-06 Fernando Perez <fperez@colorado.edu>
4276 2003-10-06 Fernando Perez <fperez@colorado.edu>
4271
4277
4272 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
4278 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
4273 prevent crashes if sys lacks an argv attribute (it happens with
4279 prevent crashes if sys lacks an argv attribute (it happens with
4274 embedded interpreters which build a bare-bones sys module).
4280 embedded interpreters which build a bare-bones sys module).
4275 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
4281 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
4276
4282
4277 2003-09-24 Fernando Perez <fperez@colorado.edu>
4283 2003-09-24 Fernando Perez <fperez@colorado.edu>
4278
4284
4279 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
4285 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
4280 to protect against poorly written user objects where __getattr__
4286 to protect against poorly written user objects where __getattr__
4281 raises exceptions other than AttributeError. Thanks to a bug
4287 raises exceptions other than AttributeError. Thanks to a bug
4282 report by Oliver Sander <osander-AT-gmx.de>.
4288 report by Oliver Sander <osander-AT-gmx.de>.
4283
4289
4284 * IPython/FakeModule.py (FakeModule.__repr__): this method was
4290 * IPython/FakeModule.py (FakeModule.__repr__): this method was
4285 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
4291 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
4286
4292
4287 2003-09-09 Fernando Perez <fperez@colorado.edu>
4293 2003-09-09 Fernando Perez <fperez@colorado.edu>
4288
4294
4289 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
4295 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
4290 unpacking a list whith a callable as first element would
4296 unpacking a list whith a callable as first element would
4291 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
4297 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
4292 Collins.
4298 Collins.
4293
4299
4294 2003-08-25 *** Released version 0.5.0
4300 2003-08-25 *** Released version 0.5.0
4295
4301
4296 2003-08-22 Fernando Perez <fperez@colorado.edu>
4302 2003-08-22 Fernando Perez <fperez@colorado.edu>
4297
4303
4298 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
4304 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
4299 improperly defined user exceptions. Thanks to feedback from Mark
4305 improperly defined user exceptions. Thanks to feedback from Mark
4300 Russell <mrussell-AT-verio.net>.
4306 Russell <mrussell-AT-verio.net>.
4301
4307
4302 2003-08-20 Fernando Perez <fperez@colorado.edu>
4308 2003-08-20 Fernando Perez <fperez@colorado.edu>
4303
4309
4304 * IPython/OInspect.py (Inspector.pinfo): changed String Form
4310 * IPython/OInspect.py (Inspector.pinfo): changed String Form
4305 printing so that it would print multi-line string forms starting
4311 printing so that it would print multi-line string forms starting
4306 with a new line. This way the formatting is better respected for
4312 with a new line. This way the formatting is better respected for
4307 objects which work hard to make nice string forms.
4313 objects which work hard to make nice string forms.
4308
4314
4309 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
4315 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
4310 autocall would overtake data access for objects with both
4316 autocall would overtake data access for objects with both
4311 __getitem__ and __call__.
4317 __getitem__ and __call__.
4312
4318
4313 2003-08-19 *** Released version 0.5.0-rc1
4319 2003-08-19 *** Released version 0.5.0-rc1
4314
4320
4315 2003-08-19 Fernando Perez <fperez@colorado.edu>
4321 2003-08-19 Fernando Perez <fperez@colorado.edu>
4316
4322
4317 * IPython/deep_reload.py (load_tail): single tiny change here
4323 * IPython/deep_reload.py (load_tail): single tiny change here
4318 seems to fix the long-standing bug of dreload() failing to work
4324 seems to fix the long-standing bug of dreload() failing to work
4319 for dotted names. But this module is pretty tricky, so I may have
4325 for dotted names. But this module is pretty tricky, so I may have
4320 missed some subtlety. Needs more testing!.
4326 missed some subtlety. Needs more testing!.
4321
4327
4322 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
4328 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
4323 exceptions which have badly implemented __str__ methods.
4329 exceptions which have badly implemented __str__ methods.
4324 (VerboseTB.text): harden against inspect.getinnerframes crashing,
4330 (VerboseTB.text): harden against inspect.getinnerframes crashing,
4325 which I've been getting reports about from Python 2.3 users. I
4331 which I've been getting reports about from Python 2.3 users. I
4326 wish I had a simple test case to reproduce the problem, so I could
4332 wish I had a simple test case to reproduce the problem, so I could
4327 either write a cleaner workaround or file a bug report if
4333 either write a cleaner workaround or file a bug report if
4328 necessary.
4334 necessary.
4329
4335
4330 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
4336 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
4331 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
4337 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
4332 a bug report by Tjabo Kloppenburg.
4338 a bug report by Tjabo Kloppenburg.
4333
4339
4334 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
4340 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
4335 crashes. Wrapped the pdb call in a blanket try/except, since pdb
4341 crashes. Wrapped the pdb call in a blanket try/except, since pdb
4336 seems rather unstable. Thanks to a bug report by Tjabo
4342 seems rather unstable. Thanks to a bug report by Tjabo
4337 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
4343 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
4338
4344
4339 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
4345 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
4340 this out soon because of the critical fixes in the inner loop for
4346 this out soon because of the critical fixes in the inner loop for
4341 generators.
4347 generators.
4342
4348
4343 * IPython/Magic.py (Magic.getargspec): removed. This (and
4349 * IPython/Magic.py (Magic.getargspec): removed. This (and
4344 _get_def) have been obsoleted by OInspect for a long time, I
4350 _get_def) have been obsoleted by OInspect for a long time, I
4345 hadn't noticed that they were dead code.
4351 hadn't noticed that they were dead code.
4346 (Magic._ofind): restored _ofind functionality for a few literals
4352 (Magic._ofind): restored _ofind functionality for a few literals
4347 (those in ["''",'""','[]','{}','()']). But it won't work anymore
4353 (those in ["''",'""','[]','{}','()']). But it won't work anymore
4348 for things like "hello".capitalize?, since that would require a
4354 for things like "hello".capitalize?, since that would require a
4349 potentially dangerous eval() again.
4355 potentially dangerous eval() again.
4350
4356
4351 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
4357 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
4352 logic a bit more to clean up the escapes handling and minimize the
4358 logic a bit more to clean up the escapes handling and minimize the
4353 use of _ofind to only necessary cases. The interactive 'feel' of
4359 use of _ofind to only necessary cases. The interactive 'feel' of
4354 IPython should have improved quite a bit with the changes in
4360 IPython should have improved quite a bit with the changes in
4355 _prefilter and _ofind (besides being far safer than before).
4361 _prefilter and _ofind (besides being far safer than before).
4356
4362
4357 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
4363 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
4358 obscure, never reported). Edit would fail to find the object to
4364 obscure, never reported). Edit would fail to find the object to
4359 edit under some circumstances.
4365 edit under some circumstances.
4360 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
4366 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
4361 which were causing double-calling of generators. Those eval calls
4367 which were causing double-calling of generators. Those eval calls
4362 were _very_ dangerous, since code with side effects could be
4368 were _very_ dangerous, since code with side effects could be
4363 triggered. As they say, 'eval is evil'... These were the
4369 triggered. As they say, 'eval is evil'... These were the
4364 nastiest evals in IPython. Besides, _ofind is now far simpler,
4370 nastiest evals in IPython. Besides, _ofind is now far simpler,
4365 and it should also be quite a bit faster. Its use of inspect is
4371 and it should also be quite a bit faster. Its use of inspect is
4366 also safer, so perhaps some of the inspect-related crashes I've
4372 also safer, so perhaps some of the inspect-related crashes I've
4367 seen lately with Python 2.3 might be taken care of. That will
4373 seen lately with Python 2.3 might be taken care of. That will
4368 need more testing.
4374 need more testing.
4369
4375
4370 2003-08-17 Fernando Perez <fperez@colorado.edu>
4376 2003-08-17 Fernando Perez <fperez@colorado.edu>
4371
4377
4372 * IPython/iplib.py (InteractiveShell._prefilter): significant
4378 * IPython/iplib.py (InteractiveShell._prefilter): significant
4373 simplifications to the logic for handling user escapes. Faster
4379 simplifications to the logic for handling user escapes. Faster
4374 and simpler code.
4380 and simpler code.
4375
4381
4376 2003-08-14 Fernando Perez <fperez@colorado.edu>
4382 2003-08-14 Fernando Perez <fperez@colorado.edu>
4377
4383
4378 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
4384 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
4379 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
4385 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
4380 but it should be quite a bit faster. And the recursive version
4386 but it should be quite a bit faster. And the recursive version
4381 generated O(log N) intermediate storage for all rank>1 arrays,
4387 generated O(log N) intermediate storage for all rank>1 arrays,
4382 even if they were contiguous.
4388 even if they were contiguous.
4383 (l1norm): Added this function.
4389 (l1norm): Added this function.
4384 (norm): Added this function for arbitrary norms (including
4390 (norm): Added this function for arbitrary norms (including
4385 l-infinity). l1 and l2 are still special cases for convenience
4391 l-infinity). l1 and l2 are still special cases for convenience
4386 and speed.
4392 and speed.
4387
4393
4388 2003-08-03 Fernando Perez <fperez@colorado.edu>
4394 2003-08-03 Fernando Perez <fperez@colorado.edu>
4389
4395
4390 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
4396 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
4391 exceptions, which now raise PendingDeprecationWarnings in Python
4397 exceptions, which now raise PendingDeprecationWarnings in Python
4392 2.3. There were some in Magic and some in Gnuplot2.
4398 2.3. There were some in Magic and some in Gnuplot2.
4393
4399
4394 2003-06-30 Fernando Perez <fperez@colorado.edu>
4400 2003-06-30 Fernando Perez <fperez@colorado.edu>
4395
4401
4396 * IPython/genutils.py (page): modified to call curses only for
4402 * IPython/genutils.py (page): modified to call curses only for
4397 terminals where TERM=='xterm'. After problems under many other
4403 terminals where TERM=='xterm'. After problems under many other
4398 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
4404 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
4399
4405
4400 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
4406 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
4401 would be triggered when readline was absent. This was just an old
4407 would be triggered when readline was absent. This was just an old
4402 debugging statement I'd forgotten to take out.
4408 debugging statement I'd forgotten to take out.
4403
4409
4404 2003-06-20 Fernando Perez <fperez@colorado.edu>
4410 2003-06-20 Fernando Perez <fperez@colorado.edu>
4405
4411
4406 * IPython/genutils.py (clock): modified to return only user time
4412 * IPython/genutils.py (clock): modified to return only user time
4407 (not counting system time), after a discussion on scipy. While
4413 (not counting system time), after a discussion on scipy. While
4408 system time may be a useful quantity occasionally, it may much
4414 system time may be a useful quantity occasionally, it may much
4409 more easily be skewed by occasional swapping or other similar
4415 more easily be skewed by occasional swapping or other similar
4410 activity.
4416 activity.
4411
4417
4412 2003-06-05 Fernando Perez <fperez@colorado.edu>
4418 2003-06-05 Fernando Perez <fperez@colorado.edu>
4413
4419
4414 * IPython/numutils.py (identity): new function, for building
4420 * IPython/numutils.py (identity): new function, for building
4415 arbitrary rank Kronecker deltas (mostly backwards compatible with
4421 arbitrary rank Kronecker deltas (mostly backwards compatible with
4416 Numeric.identity)
4422 Numeric.identity)
4417
4423
4418 2003-06-03 Fernando Perez <fperez@colorado.edu>
4424 2003-06-03 Fernando Perez <fperez@colorado.edu>
4419
4425
4420 * IPython/iplib.py (InteractiveShell.handle_magic): protect
4426 * IPython/iplib.py (InteractiveShell.handle_magic): protect
4421 arguments passed to magics with spaces, to allow trailing '\' to
4427 arguments passed to magics with spaces, to allow trailing '\' to
4422 work normally (mainly for Windows users).
4428 work normally (mainly for Windows users).
4423
4429
4424 2003-05-29 Fernando Perez <fperez@colorado.edu>
4430 2003-05-29 Fernando Perez <fperez@colorado.edu>
4425
4431
4426 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
4432 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
4427 instead of pydoc.help. This fixes a bizarre behavior where
4433 instead of pydoc.help. This fixes a bizarre behavior where
4428 printing '%s' % locals() would trigger the help system. Now
4434 printing '%s' % locals() would trigger the help system. Now
4429 ipython behaves like normal python does.
4435 ipython behaves like normal python does.
4430
4436
4431 Note that if one does 'from pydoc import help', the bizarre
4437 Note that if one does 'from pydoc import help', the bizarre
4432 behavior returns, but this will also happen in normal python, so
4438 behavior returns, but this will also happen in normal python, so
4433 it's not an ipython bug anymore (it has to do with how pydoc.help
4439 it's not an ipython bug anymore (it has to do with how pydoc.help
4434 is implemented).
4440 is implemented).
4435
4441
4436 2003-05-22 Fernando Perez <fperez@colorado.edu>
4442 2003-05-22 Fernando Perez <fperez@colorado.edu>
4437
4443
4438 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
4444 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
4439 return [] instead of None when nothing matches, also match to end
4445 return [] instead of None when nothing matches, also match to end
4440 of line. Patch by Gary Bishop.
4446 of line. Patch by Gary Bishop.
4441
4447
4442 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
4448 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
4443 protection as before, for files passed on the command line. This
4449 protection as before, for files passed on the command line. This
4444 prevents the CrashHandler from kicking in if user files call into
4450 prevents the CrashHandler from kicking in if user files call into
4445 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
4451 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
4446 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
4452 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
4447
4453
4448 2003-05-20 *** Released version 0.4.0
4454 2003-05-20 *** Released version 0.4.0
4449
4455
4450 2003-05-20 Fernando Perez <fperez@colorado.edu>
4456 2003-05-20 Fernando Perez <fperez@colorado.edu>
4451
4457
4452 * setup.py: added support for manpages. It's a bit hackish b/c of
4458 * setup.py: added support for manpages. It's a bit hackish b/c of
4453 a bug in the way the bdist_rpm distutils target handles gzipped
4459 a bug in the way the bdist_rpm distutils target handles gzipped
4454 manpages, but it works. After a patch by Jack.
4460 manpages, but it works. After a patch by Jack.
4455
4461
4456 2003-05-19 Fernando Perez <fperez@colorado.edu>
4462 2003-05-19 Fernando Perez <fperez@colorado.edu>
4457
4463
4458 * IPython/numutils.py: added a mockup of the kinds module, since
4464 * IPython/numutils.py: added a mockup of the kinds module, since
4459 it was recently removed from Numeric. This way, numutils will
4465 it was recently removed from Numeric. This way, numutils will
4460 work for all users even if they are missing kinds.
4466 work for all users even if they are missing kinds.
4461
4467
4462 * IPython/Magic.py (Magic._ofind): Harden against an inspect
4468 * IPython/Magic.py (Magic._ofind): Harden against an inspect
4463 failure, which can occur with SWIG-wrapped extensions. After a
4469 failure, which can occur with SWIG-wrapped extensions. After a
4464 crash report from Prabhu.
4470 crash report from Prabhu.
4465
4471
4466 2003-05-16 Fernando Perez <fperez@colorado.edu>
4472 2003-05-16 Fernando Perez <fperez@colorado.edu>
4467
4473
4468 * IPython/iplib.py (InteractiveShell.excepthook): New method to
4474 * IPython/iplib.py (InteractiveShell.excepthook): New method to
4469 protect ipython from user code which may call directly
4475 protect ipython from user code which may call directly
4470 sys.excepthook (this looks like an ipython crash to the user, even
4476 sys.excepthook (this looks like an ipython crash to the user, even
4471 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4477 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4472 This is especially important to help users of WxWindows, but may
4478 This is especially important to help users of WxWindows, but may
4473 also be useful in other cases.
4479 also be useful in other cases.
4474
4480
4475 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
4481 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
4476 an optional tb_offset to be specified, and to preserve exception
4482 an optional tb_offset to be specified, and to preserve exception
4477 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4483 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4478
4484
4479 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
4485 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
4480
4486
4481 2003-05-15 Fernando Perez <fperez@colorado.edu>
4487 2003-05-15 Fernando Perez <fperez@colorado.edu>
4482
4488
4483 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
4489 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
4484 installing for a new user under Windows.
4490 installing for a new user under Windows.
4485
4491
4486 2003-05-12 Fernando Perez <fperez@colorado.edu>
4492 2003-05-12 Fernando Perez <fperez@colorado.edu>
4487
4493
4488 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
4494 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
4489 handler for Emacs comint-based lines. Currently it doesn't do
4495 handler for Emacs comint-based lines. Currently it doesn't do
4490 much (but importantly, it doesn't update the history cache). In
4496 much (but importantly, it doesn't update the history cache). In
4491 the future it may be expanded if Alex needs more functionality
4497 the future it may be expanded if Alex needs more functionality
4492 there.
4498 there.
4493
4499
4494 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
4500 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
4495 info to crash reports.
4501 info to crash reports.
4496
4502
4497 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
4503 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
4498 just like Python's -c. Also fixed crash with invalid -color
4504 just like Python's -c. Also fixed crash with invalid -color
4499 option value at startup. Thanks to Will French
4505 option value at startup. Thanks to Will French
4500 <wfrench-AT-bestweb.net> for the bug report.
4506 <wfrench-AT-bestweb.net> for the bug report.
4501
4507
4502 2003-05-09 Fernando Perez <fperez@colorado.edu>
4508 2003-05-09 Fernando Perez <fperez@colorado.edu>
4503
4509
4504 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
4510 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
4505 to EvalDict (it's a mapping, after all) and simplified its code
4511 to EvalDict (it's a mapping, after all) and simplified its code
4506 quite a bit, after a nice discussion on c.l.py where Gustavo
4512 quite a bit, after a nice discussion on c.l.py where Gustavo
4507 Córdova <gcordova-AT-sismex.com> suggested the new version.
4513 Córdova <gcordova-AT-sismex.com> suggested the new version.
4508
4514
4509 2003-04-30 Fernando Perez <fperez@colorado.edu>
4515 2003-04-30 Fernando Perez <fperez@colorado.edu>
4510
4516
4511 * IPython/genutils.py (timings_out): modified it to reduce its
4517 * IPython/genutils.py (timings_out): modified it to reduce its
4512 overhead in the common reps==1 case.
4518 overhead in the common reps==1 case.
4513
4519
4514 2003-04-29 Fernando Perez <fperez@colorado.edu>
4520 2003-04-29 Fernando Perez <fperez@colorado.edu>
4515
4521
4516 * IPython/genutils.py (timings_out): Modified to use the resource
4522 * IPython/genutils.py (timings_out): Modified to use the resource
4517 module, which avoids the wraparound problems of time.clock().
4523 module, which avoids the wraparound problems of time.clock().
4518
4524
4519 2003-04-17 *** Released version 0.2.15pre4
4525 2003-04-17 *** Released version 0.2.15pre4
4520
4526
4521 2003-04-17 Fernando Perez <fperez@colorado.edu>
4527 2003-04-17 Fernando Perez <fperez@colorado.edu>
4522
4528
4523 * setup.py (scriptfiles): Split windows-specific stuff over to a
4529 * setup.py (scriptfiles): Split windows-specific stuff over to a
4524 separate file, in an attempt to have a Windows GUI installer.
4530 separate file, in an attempt to have a Windows GUI installer.
4525 That didn't work, but part of the groundwork is done.
4531 That didn't work, but part of the groundwork is done.
4526
4532
4527 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
4533 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
4528 indent/unindent with 4 spaces. Particularly useful in combination
4534 indent/unindent with 4 spaces. Particularly useful in combination
4529 with the new auto-indent option.
4535 with the new auto-indent option.
4530
4536
4531 2003-04-16 Fernando Perez <fperez@colorado.edu>
4537 2003-04-16 Fernando Perez <fperez@colorado.edu>
4532
4538
4533 * IPython/Magic.py: various replacements of self.rc for
4539 * IPython/Magic.py: various replacements of self.rc for
4534 self.shell.rc. A lot more remains to be done to fully disentangle
4540 self.shell.rc. A lot more remains to be done to fully disentangle
4535 this class from the main Shell class.
4541 this class from the main Shell class.
4536
4542
4537 * IPython/GnuplotRuntime.py: added checks for mouse support so
4543 * IPython/GnuplotRuntime.py: added checks for mouse support so
4538 that we don't try to enable it if the current gnuplot doesn't
4544 that we don't try to enable it if the current gnuplot doesn't
4539 really support it. Also added checks so that we don't try to
4545 really support it. Also added checks so that we don't try to
4540 enable persist under Windows (where Gnuplot doesn't recognize the
4546 enable persist under Windows (where Gnuplot doesn't recognize the
4541 option).
4547 option).
4542
4548
4543 * IPython/iplib.py (InteractiveShell.interact): Added optional
4549 * IPython/iplib.py (InteractiveShell.interact): Added optional
4544 auto-indenting code, after a patch by King C. Shu
4550 auto-indenting code, after a patch by King C. Shu
4545 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
4551 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
4546 get along well with pasting indented code. If I ever figure out
4552 get along well with pasting indented code. If I ever figure out
4547 how to make that part go well, it will become on by default.
4553 how to make that part go well, it will become on by default.
4548
4554
4549 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
4555 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
4550 crash ipython if there was an unmatched '%' in the user's prompt
4556 crash ipython if there was an unmatched '%' in the user's prompt
4551 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4557 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4552
4558
4553 * IPython/iplib.py (InteractiveShell.interact): removed the
4559 * IPython/iplib.py (InteractiveShell.interact): removed the
4554 ability to ask the user whether he wants to crash or not at the
4560 ability to ask the user whether he wants to crash or not at the
4555 'last line' exception handler. Calling functions at that point
4561 'last line' exception handler. Calling functions at that point
4556 changes the stack, and the error reports would have incorrect
4562 changes the stack, and the error reports would have incorrect
4557 tracebacks.
4563 tracebacks.
4558
4564
4559 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
4565 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
4560 pass through a peger a pretty-printed form of any object. After a
4566 pass through a peger a pretty-printed form of any object. After a
4561 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
4567 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
4562
4568
4563 2003-04-14 Fernando Perez <fperez@colorado.edu>
4569 2003-04-14 Fernando Perez <fperez@colorado.edu>
4564
4570
4565 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
4571 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
4566 all files in ~ would be modified at first install (instead of
4572 all files in ~ would be modified at first install (instead of
4567 ~/.ipython). This could be potentially disastrous, as the
4573 ~/.ipython). This could be potentially disastrous, as the
4568 modification (make line-endings native) could damage binary files.
4574 modification (make line-endings native) could damage binary files.
4569
4575
4570 2003-04-10 Fernando Perez <fperez@colorado.edu>
4576 2003-04-10 Fernando Perez <fperez@colorado.edu>
4571
4577
4572 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
4578 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
4573 handle only lines which are invalid python. This now means that
4579 handle only lines which are invalid python. This now means that
4574 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
4580 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
4575 for the bug report.
4581 for the bug report.
4576
4582
4577 2003-04-01 Fernando Perez <fperez@colorado.edu>
4583 2003-04-01 Fernando Perez <fperez@colorado.edu>
4578
4584
4579 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
4585 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
4580 where failing to set sys.last_traceback would crash pdb.pm().
4586 where failing to set sys.last_traceback would crash pdb.pm().
4581 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
4587 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
4582 report.
4588 report.
4583
4589
4584 2003-03-25 Fernando Perez <fperez@colorado.edu>
4590 2003-03-25 Fernando Perez <fperez@colorado.edu>
4585
4591
4586 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
4592 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
4587 before printing it (it had a lot of spurious blank lines at the
4593 before printing it (it had a lot of spurious blank lines at the
4588 end).
4594 end).
4589
4595
4590 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
4596 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
4591 output would be sent 21 times! Obviously people don't use this
4597 output would be sent 21 times! Obviously people don't use this
4592 too often, or I would have heard about it.
4598 too often, or I would have heard about it.
4593
4599
4594 2003-03-24 Fernando Perez <fperez@colorado.edu>
4600 2003-03-24 Fernando Perez <fperez@colorado.edu>
4595
4601
4596 * setup.py (scriptfiles): renamed the data_files parameter from
4602 * setup.py (scriptfiles): renamed the data_files parameter from
4597 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
4603 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
4598 for the patch.
4604 for the patch.
4599
4605
4600 2003-03-20 Fernando Perez <fperez@colorado.edu>
4606 2003-03-20 Fernando Perez <fperez@colorado.edu>
4601
4607
4602 * IPython/genutils.py (error): added error() and fatal()
4608 * IPython/genutils.py (error): added error() and fatal()
4603 functions.
4609 functions.
4604
4610
4605 2003-03-18 *** Released version 0.2.15pre3
4611 2003-03-18 *** Released version 0.2.15pre3
4606
4612
4607 2003-03-18 Fernando Perez <fperez@colorado.edu>
4613 2003-03-18 Fernando Perez <fperez@colorado.edu>
4608
4614
4609 * setupext/install_data_ext.py
4615 * setupext/install_data_ext.py
4610 (install_data_ext.initialize_options): Class contributed by Jack
4616 (install_data_ext.initialize_options): Class contributed by Jack
4611 Moffit for fixing the old distutils hack. He is sending this to
4617 Moffit for fixing the old distutils hack. He is sending this to
4612 the distutils folks so in the future we may not need it as a
4618 the distutils folks so in the future we may not need it as a
4613 private fix.
4619 private fix.
4614
4620
4615 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
4621 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
4616 changes for Debian packaging. See his patch for full details.
4622 changes for Debian packaging. See his patch for full details.
4617 The old distutils hack of making the ipythonrc* files carry a
4623 The old distutils hack of making the ipythonrc* files carry a
4618 bogus .py extension is gone, at last. Examples were moved to a
4624 bogus .py extension is gone, at last. Examples were moved to a
4619 separate subdir under doc/, and the separate executable scripts
4625 separate subdir under doc/, and the separate executable scripts
4620 now live in their own directory. Overall a great cleanup. The
4626 now live in their own directory. Overall a great cleanup. The
4621 manual was updated to use the new files, and setup.py has been
4627 manual was updated to use the new files, and setup.py has been
4622 fixed for this setup.
4628 fixed for this setup.
4623
4629
4624 * IPython/PyColorize.py (Parser.usage): made non-executable and
4630 * IPython/PyColorize.py (Parser.usage): made non-executable and
4625 created a pycolor wrapper around it to be included as a script.
4631 created a pycolor wrapper around it to be included as a script.
4626
4632
4627 2003-03-12 *** Released version 0.2.15pre2
4633 2003-03-12 *** Released version 0.2.15pre2
4628
4634
4629 2003-03-12 Fernando Perez <fperez@colorado.edu>
4635 2003-03-12 Fernando Perez <fperez@colorado.edu>
4630
4636
4631 * IPython/ColorANSI.py (make_color_table): Finally fixed the
4637 * IPython/ColorANSI.py (make_color_table): Finally fixed the
4632 long-standing problem with garbage characters in some terminals.
4638 long-standing problem with garbage characters in some terminals.
4633 The issue was really that the \001 and \002 escapes must _only_ be
4639 The issue was really that the \001 and \002 escapes must _only_ be
4634 passed to input prompts (which call readline), but _never_ to
4640 passed to input prompts (which call readline), but _never_ to
4635 normal text to be printed on screen. I changed ColorANSI to have
4641 normal text to be printed on screen. I changed ColorANSI to have
4636 two classes: TermColors and InputTermColors, each with the
4642 two classes: TermColors and InputTermColors, each with the
4637 appropriate escapes for input prompts or normal text. The code in
4643 appropriate escapes for input prompts or normal text. The code in
4638 Prompts.py got slightly more complicated, but this very old and
4644 Prompts.py got slightly more complicated, but this very old and
4639 annoying bug is finally fixed.
4645 annoying bug is finally fixed.
4640
4646
4641 All the credit for nailing down the real origin of this problem
4647 All the credit for nailing down the real origin of this problem
4642 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
4648 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
4643 *Many* thanks to him for spending quite a bit of effort on this.
4649 *Many* thanks to him for spending quite a bit of effort on this.
4644
4650
4645 2003-03-05 *** Released version 0.2.15pre1
4651 2003-03-05 *** Released version 0.2.15pre1
4646
4652
4647 2003-03-03 Fernando Perez <fperez@colorado.edu>
4653 2003-03-03 Fernando Perez <fperez@colorado.edu>
4648
4654
4649 * IPython/FakeModule.py: Moved the former _FakeModule to a
4655 * IPython/FakeModule.py: Moved the former _FakeModule to a
4650 separate file, because it's also needed by Magic (to fix a similar
4656 separate file, because it's also needed by Magic (to fix a similar
4651 pickle-related issue in @run).
4657 pickle-related issue in @run).
4652
4658
4653 2003-03-02 Fernando Perez <fperez@colorado.edu>
4659 2003-03-02 Fernando Perez <fperez@colorado.edu>
4654
4660
4655 * IPython/Magic.py (Magic.magic_autocall): new magic to control
4661 * IPython/Magic.py (Magic.magic_autocall): new magic to control
4656 the autocall option at runtime.
4662 the autocall option at runtime.
4657 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
4663 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
4658 across Magic.py to start separating Magic from InteractiveShell.
4664 across Magic.py to start separating Magic from InteractiveShell.
4659 (Magic._ofind): Fixed to return proper namespace for dotted
4665 (Magic._ofind): Fixed to return proper namespace for dotted
4660 names. Before, a dotted name would always return 'not currently
4666 names. Before, a dotted name would always return 'not currently
4661 defined', because it would find the 'parent'. s.x would be found,
4667 defined', because it would find the 'parent'. s.x would be found,
4662 but since 'x' isn't defined by itself, it would get confused.
4668 but since 'x' isn't defined by itself, it would get confused.
4663 (Magic.magic_run): Fixed pickling problems reported by Ralf
4669 (Magic.magic_run): Fixed pickling problems reported by Ralf
4664 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
4670 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
4665 that I'd used when Mike Heeter reported similar issues at the
4671 that I'd used when Mike Heeter reported similar issues at the
4666 top-level, but now for @run. It boils down to injecting the
4672 top-level, but now for @run. It boils down to injecting the
4667 namespace where code is being executed with something that looks
4673 namespace where code is being executed with something that looks
4668 enough like a module to fool pickle.dump(). Since a pickle stores
4674 enough like a module to fool pickle.dump(). Since a pickle stores
4669 a named reference to the importing module, we need this for
4675 a named reference to the importing module, we need this for
4670 pickles to save something sensible.
4676 pickles to save something sensible.
4671
4677
4672 * IPython/ipmaker.py (make_IPython): added an autocall option.
4678 * IPython/ipmaker.py (make_IPython): added an autocall option.
4673
4679
4674 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
4680 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
4675 the auto-eval code. Now autocalling is an option, and the code is
4681 the auto-eval code. Now autocalling is an option, and the code is
4676 also vastly safer. There is no more eval() involved at all.
4682 also vastly safer. There is no more eval() involved at all.
4677
4683
4678 2003-03-01 Fernando Perez <fperez@colorado.edu>
4684 2003-03-01 Fernando Perez <fperez@colorado.edu>
4679
4685
4680 * IPython/Magic.py (Magic._ofind): Changed interface to return a
4686 * IPython/Magic.py (Magic._ofind): Changed interface to return a
4681 dict with named keys instead of a tuple.
4687 dict with named keys instead of a tuple.
4682
4688
4683 * IPython: Started using CVS for IPython as of 0.2.15pre1.
4689 * IPython: Started using CVS for IPython as of 0.2.15pre1.
4684
4690
4685 * setup.py (make_shortcut): Fixed message about directories
4691 * setup.py (make_shortcut): Fixed message about directories
4686 created during Windows installation (the directories were ok, just
4692 created during Windows installation (the directories were ok, just
4687 the printed message was misleading). Thanks to Chris Liechti
4693 the printed message was misleading). Thanks to Chris Liechti
4688 <cliechti-AT-gmx.net> for the heads up.
4694 <cliechti-AT-gmx.net> for the heads up.
4689
4695
4690 2003-02-21 Fernando Perez <fperez@colorado.edu>
4696 2003-02-21 Fernando Perez <fperez@colorado.edu>
4691
4697
4692 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
4698 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
4693 of ValueError exception when checking for auto-execution. This
4699 of ValueError exception when checking for auto-execution. This
4694 one is raised by things like Numeric arrays arr.flat when the
4700 one is raised by things like Numeric arrays arr.flat when the
4695 array is non-contiguous.
4701 array is non-contiguous.
4696
4702
4697 2003-01-31 Fernando Perez <fperez@colorado.edu>
4703 2003-01-31 Fernando Perez <fperez@colorado.edu>
4698
4704
4699 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
4705 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
4700 not return any value at all (even though the command would get
4706 not return any value at all (even though the command would get
4701 executed).
4707 executed).
4702 (xsys): Flush stdout right after printing the command to ensure
4708 (xsys): Flush stdout right after printing the command to ensure
4703 proper ordering of commands and command output in the total
4709 proper ordering of commands and command output in the total
4704 output.
4710 output.
4705 (SystemExec/xsys/bq): Switched the names of xsys/bq and
4711 (SystemExec/xsys/bq): Switched the names of xsys/bq and
4706 system/getoutput as defaults. The old ones are kept for
4712 system/getoutput as defaults. The old ones are kept for
4707 compatibility reasons, so no code which uses this library needs
4713 compatibility reasons, so no code which uses this library needs
4708 changing.
4714 changing.
4709
4715
4710 2003-01-27 *** Released version 0.2.14
4716 2003-01-27 *** Released version 0.2.14
4711
4717
4712 2003-01-25 Fernando Perez <fperez@colorado.edu>
4718 2003-01-25 Fernando Perez <fperez@colorado.edu>
4713
4719
4714 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
4720 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
4715 functions defined in previous edit sessions could not be re-edited
4721 functions defined in previous edit sessions could not be re-edited
4716 (because the temp files were immediately removed). Now temp files
4722 (because the temp files were immediately removed). Now temp files
4717 are removed only at IPython's exit.
4723 are removed only at IPython's exit.
4718 (Magic.magic_run): Improved @run to perform shell-like expansions
4724 (Magic.magic_run): Improved @run to perform shell-like expansions
4719 on its arguments (~users and $VARS). With this, @run becomes more
4725 on its arguments (~users and $VARS). With this, @run becomes more
4720 like a normal command-line.
4726 like a normal command-line.
4721
4727
4722 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
4728 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
4723 bugs related to embedding and cleaned up that code. A fairly
4729 bugs related to embedding and cleaned up that code. A fairly
4724 important one was the impossibility to access the global namespace
4730 important one was the impossibility to access the global namespace
4725 through the embedded IPython (only local variables were visible).
4731 through the embedded IPython (only local variables were visible).
4726
4732
4727 2003-01-14 Fernando Perez <fperez@colorado.edu>
4733 2003-01-14 Fernando Perez <fperez@colorado.edu>
4728
4734
4729 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
4735 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
4730 auto-calling to be a bit more conservative. Now it doesn't get
4736 auto-calling to be a bit more conservative. Now it doesn't get
4731 triggered if any of '!=()<>' are in the rest of the input line, to
4737 triggered if any of '!=()<>' are in the rest of the input line, to
4732 allow comparing callables. Thanks to Alex for the heads up.
4738 allow comparing callables. Thanks to Alex for the heads up.
4733
4739
4734 2003-01-07 Fernando Perez <fperez@colorado.edu>
4740 2003-01-07 Fernando Perez <fperez@colorado.edu>
4735
4741
4736 * IPython/genutils.py (page): fixed estimation of the number of
4742 * IPython/genutils.py (page): fixed estimation of the number of
4737 lines in a string to be paged to simply count newlines. This
4743 lines in a string to be paged to simply count newlines. This
4738 prevents over-guessing due to embedded escape sequences. A better
4744 prevents over-guessing due to embedded escape sequences. A better
4739 long-term solution would involve stripping out the control chars
4745 long-term solution would involve stripping out the control chars
4740 for the count, but it's potentially so expensive I just don't
4746 for the count, but it's potentially so expensive I just don't
4741 think it's worth doing.
4747 think it's worth doing.
4742
4748
4743 2002-12-19 *** Released version 0.2.14pre50
4749 2002-12-19 *** Released version 0.2.14pre50
4744
4750
4745 2002-12-19 Fernando Perez <fperez@colorado.edu>
4751 2002-12-19 Fernando Perez <fperez@colorado.edu>
4746
4752
4747 * tools/release (version): Changed release scripts to inform
4753 * tools/release (version): Changed release scripts to inform
4748 Andrea and build a NEWS file with a list of recent changes.
4754 Andrea and build a NEWS file with a list of recent changes.
4749
4755
4750 * IPython/ColorANSI.py (__all__): changed terminal detection
4756 * IPython/ColorANSI.py (__all__): changed terminal detection
4751 code. Seems to work better for xterms without breaking
4757 code. Seems to work better for xterms without breaking
4752 konsole. Will need more testing to determine if WinXP and Mac OSX
4758 konsole. Will need more testing to determine if WinXP and Mac OSX
4753 also work ok.
4759 also work ok.
4754
4760
4755 2002-12-18 *** Released version 0.2.14pre49
4761 2002-12-18 *** Released version 0.2.14pre49
4756
4762
4757 2002-12-18 Fernando Perez <fperez@colorado.edu>
4763 2002-12-18 Fernando Perez <fperez@colorado.edu>
4758
4764
4759 * Docs: added new info about Mac OSX, from Andrea.
4765 * Docs: added new info about Mac OSX, from Andrea.
4760
4766
4761 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
4767 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
4762 allow direct plotting of python strings whose format is the same
4768 allow direct plotting of python strings whose format is the same
4763 of gnuplot data files.
4769 of gnuplot data files.
4764
4770
4765 2002-12-16 Fernando Perez <fperez@colorado.edu>
4771 2002-12-16 Fernando Perez <fperez@colorado.edu>
4766
4772
4767 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
4773 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
4768 value of exit question to be acknowledged.
4774 value of exit question to be acknowledged.
4769
4775
4770 2002-12-03 Fernando Perez <fperez@colorado.edu>
4776 2002-12-03 Fernando Perez <fperez@colorado.edu>
4771
4777
4772 * IPython/ipmaker.py: removed generators, which had been added
4778 * IPython/ipmaker.py: removed generators, which had been added
4773 by mistake in an earlier debugging run. This was causing trouble
4779 by mistake in an earlier debugging run. This was causing trouble
4774 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
4780 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
4775 for pointing this out.
4781 for pointing this out.
4776
4782
4777 2002-11-17 Fernando Perez <fperez@colorado.edu>
4783 2002-11-17 Fernando Perez <fperez@colorado.edu>
4778
4784
4779 * Manual: updated the Gnuplot section.
4785 * Manual: updated the Gnuplot section.
4780
4786
4781 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
4787 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
4782 a much better split of what goes in Runtime and what goes in
4788 a much better split of what goes in Runtime and what goes in
4783 Interactive.
4789 Interactive.
4784
4790
4785 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
4791 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
4786 being imported from iplib.
4792 being imported from iplib.
4787
4793
4788 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
4794 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
4789 for command-passing. Now the global Gnuplot instance is called
4795 for command-passing. Now the global Gnuplot instance is called
4790 'gp' instead of 'g', which was really a far too fragile and
4796 'gp' instead of 'g', which was really a far too fragile and
4791 common name.
4797 common name.
4792
4798
4793 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
4799 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
4794 bounding boxes generated by Gnuplot for square plots.
4800 bounding boxes generated by Gnuplot for square plots.
4795
4801
4796 * IPython/genutils.py (popkey): new function added. I should
4802 * IPython/genutils.py (popkey): new function added. I should
4797 suggest this on c.l.py as a dict method, it seems useful.
4803 suggest this on c.l.py as a dict method, it seems useful.
4798
4804
4799 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
4805 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
4800 to transparently handle PostScript generation. MUCH better than
4806 to transparently handle PostScript generation. MUCH better than
4801 the previous plot_eps/replot_eps (which I removed now). The code
4807 the previous plot_eps/replot_eps (which I removed now). The code
4802 is also fairly clean and well documented now (including
4808 is also fairly clean and well documented now (including
4803 docstrings).
4809 docstrings).
4804
4810
4805 2002-11-13 Fernando Perez <fperez@colorado.edu>
4811 2002-11-13 Fernando Perez <fperez@colorado.edu>
4806
4812
4807 * IPython/Magic.py (Magic.magic_edit): fixed docstring
4813 * IPython/Magic.py (Magic.magic_edit): fixed docstring
4808 (inconsistent with options).
4814 (inconsistent with options).
4809
4815
4810 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
4816 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
4811 manually disabled, I don't know why. Fixed it.
4817 manually disabled, I don't know why. Fixed it.
4812 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
4818 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
4813 eps output.
4819 eps output.
4814
4820
4815 2002-11-12 Fernando Perez <fperez@colorado.edu>
4821 2002-11-12 Fernando Perez <fperez@colorado.edu>
4816
4822
4817 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
4823 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
4818 don't propagate up to caller. Fixes crash reported by François
4824 don't propagate up to caller. Fixes crash reported by François
4819 Pinard.
4825 Pinard.
4820
4826
4821 2002-11-09 Fernando Perez <fperez@colorado.edu>
4827 2002-11-09 Fernando Perez <fperez@colorado.edu>
4822
4828
4823 * IPython/ipmaker.py (make_IPython): fixed problem with writing
4829 * IPython/ipmaker.py (make_IPython): fixed problem with writing
4824 history file for new users.
4830 history file for new users.
4825 (make_IPython): fixed bug where initial install would leave the
4831 (make_IPython): fixed bug where initial install would leave the
4826 user running in the .ipython dir.
4832 user running in the .ipython dir.
4827 (make_IPython): fixed bug where config dir .ipython would be
4833 (make_IPython): fixed bug where config dir .ipython would be
4828 created regardless of the given -ipythondir option. Thanks to Cory
4834 created regardless of the given -ipythondir option. Thanks to Cory
4829 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
4835 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
4830
4836
4831 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
4837 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
4832 type confirmations. Will need to use it in all of IPython's code
4838 type confirmations. Will need to use it in all of IPython's code
4833 consistently.
4839 consistently.
4834
4840
4835 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
4841 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
4836 context to print 31 lines instead of the default 5. This will make
4842 context to print 31 lines instead of the default 5. This will make
4837 the crash reports extremely detailed in case the problem is in
4843 the crash reports extremely detailed in case the problem is in
4838 libraries I don't have access to.
4844 libraries I don't have access to.
4839
4845
4840 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
4846 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
4841 line of defense' code to still crash, but giving users fair
4847 line of defense' code to still crash, but giving users fair
4842 warning. I don't want internal errors to go unreported: if there's
4848 warning. I don't want internal errors to go unreported: if there's
4843 an internal problem, IPython should crash and generate a full
4849 an internal problem, IPython should crash and generate a full
4844 report.
4850 report.
4845
4851
4846 2002-11-08 Fernando Perez <fperez@colorado.edu>
4852 2002-11-08 Fernando Perez <fperez@colorado.edu>
4847
4853
4848 * IPython/iplib.py (InteractiveShell.interact): added code to trap
4854 * IPython/iplib.py (InteractiveShell.interact): added code to trap
4849 otherwise uncaught exceptions which can appear if people set
4855 otherwise uncaught exceptions which can appear if people set
4850 sys.stdout to something badly broken. Thanks to a crash report
4856 sys.stdout to something badly broken. Thanks to a crash report
4851 from henni-AT-mail.brainbot.com.
4857 from henni-AT-mail.brainbot.com.
4852
4858
4853 2002-11-04 Fernando Perez <fperez@colorado.edu>
4859 2002-11-04 Fernando Perez <fperez@colorado.edu>
4854
4860
4855 * IPython/iplib.py (InteractiveShell.interact): added
4861 * IPython/iplib.py (InteractiveShell.interact): added
4856 __IPYTHON__active to the builtins. It's a flag which goes on when
4862 __IPYTHON__active to the builtins. It's a flag which goes on when
4857 the interaction starts and goes off again when it stops. This
4863 the interaction starts and goes off again when it stops. This
4858 allows embedding code to detect being inside IPython. Before this
4864 allows embedding code to detect being inside IPython. Before this
4859 was done via __IPYTHON__, but that only shows that an IPython
4865 was done via __IPYTHON__, but that only shows that an IPython
4860 instance has been created.
4866 instance has been created.
4861
4867
4862 * IPython/Magic.py (Magic.magic_env): I realized that in a
4868 * IPython/Magic.py (Magic.magic_env): I realized that in a
4863 UserDict, instance.data holds the data as a normal dict. So I
4869 UserDict, instance.data holds the data as a normal dict. So I
4864 modified @env to return os.environ.data instead of rebuilding a
4870 modified @env to return os.environ.data instead of rebuilding a
4865 dict by hand.
4871 dict by hand.
4866
4872
4867 2002-11-02 Fernando Perez <fperez@colorado.edu>
4873 2002-11-02 Fernando Perez <fperez@colorado.edu>
4868
4874
4869 * IPython/genutils.py (warn): changed so that level 1 prints no
4875 * IPython/genutils.py (warn): changed so that level 1 prints no
4870 header. Level 2 is now the default (with 'WARNING' header, as
4876 header. Level 2 is now the default (with 'WARNING' header, as
4871 before). I think I tracked all places where changes were needed in
4877 before). I think I tracked all places where changes were needed in
4872 IPython, but outside code using the old level numbering may have
4878 IPython, but outside code using the old level numbering may have
4873 broken.
4879 broken.
4874
4880
4875 * IPython/iplib.py (InteractiveShell.runcode): added this to
4881 * IPython/iplib.py (InteractiveShell.runcode): added this to
4876 handle the tracebacks in SystemExit traps correctly. The previous
4882 handle the tracebacks in SystemExit traps correctly. The previous
4877 code (through interact) was printing more of the stack than
4883 code (through interact) was printing more of the stack than
4878 necessary, showing IPython internal code to the user.
4884 necessary, showing IPython internal code to the user.
4879
4885
4880 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
4886 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
4881 default. Now that the default at the confirmation prompt is yes,
4887 default. Now that the default at the confirmation prompt is yes,
4882 it's not so intrusive. François' argument that ipython sessions
4888 it's not so intrusive. François' argument that ipython sessions
4883 tend to be complex enough not to lose them from an accidental C-d,
4889 tend to be complex enough not to lose them from an accidental C-d,
4884 is a valid one.
4890 is a valid one.
4885
4891
4886 * IPython/iplib.py (InteractiveShell.interact): added a
4892 * IPython/iplib.py (InteractiveShell.interact): added a
4887 showtraceback() call to the SystemExit trap, and modified the exit
4893 showtraceback() call to the SystemExit trap, and modified the exit
4888 confirmation to have yes as the default.
4894 confirmation to have yes as the default.
4889
4895
4890 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
4896 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
4891 this file. It's been gone from the code for a long time, this was
4897 this file. It's been gone from the code for a long time, this was
4892 simply leftover junk.
4898 simply leftover junk.
4893
4899
4894 2002-11-01 Fernando Perez <fperez@colorado.edu>
4900 2002-11-01 Fernando Perez <fperez@colorado.edu>
4895
4901
4896 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
4902 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
4897 added. If set, IPython now traps EOF and asks for
4903 added. If set, IPython now traps EOF and asks for
4898 confirmation. After a request by François Pinard.
4904 confirmation. After a request by François Pinard.
4899
4905
4900 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
4906 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
4901 of @abort, and with a new (better) mechanism for handling the
4907 of @abort, and with a new (better) mechanism for handling the
4902 exceptions.
4908 exceptions.
4903
4909
4904 2002-10-27 Fernando Perez <fperez@colorado.edu>
4910 2002-10-27 Fernando Perez <fperez@colorado.edu>
4905
4911
4906 * IPython/usage.py (__doc__): updated the --help information and
4912 * IPython/usage.py (__doc__): updated the --help information and
4907 the ipythonrc file to indicate that -log generates
4913 the ipythonrc file to indicate that -log generates
4908 ./ipython.log. Also fixed the corresponding info in @logstart.
4914 ./ipython.log. Also fixed the corresponding info in @logstart.
4909 This and several other fixes in the manuals thanks to reports by
4915 This and several other fixes in the manuals thanks to reports by
4910 François Pinard <pinard-AT-iro.umontreal.ca>.
4916 François Pinard <pinard-AT-iro.umontreal.ca>.
4911
4917
4912 * IPython/Logger.py (Logger.switch_log): Fixed error message to
4918 * IPython/Logger.py (Logger.switch_log): Fixed error message to
4913 refer to @logstart (instead of @log, which doesn't exist).
4919 refer to @logstart (instead of @log, which doesn't exist).
4914
4920
4915 * IPython/iplib.py (InteractiveShell._prefilter): fixed
4921 * IPython/iplib.py (InteractiveShell._prefilter): fixed
4916 AttributeError crash. Thanks to Christopher Armstrong
4922 AttributeError crash. Thanks to Christopher Armstrong
4917 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
4923 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
4918 introduced recently (in 0.2.14pre37) with the fix to the eval
4924 introduced recently (in 0.2.14pre37) with the fix to the eval
4919 problem mentioned below.
4925 problem mentioned below.
4920
4926
4921 2002-10-17 Fernando Perez <fperez@colorado.edu>
4927 2002-10-17 Fernando Perez <fperez@colorado.edu>
4922
4928
4923 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
4929 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
4924 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
4930 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
4925
4931
4926 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
4932 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
4927 this function to fix a problem reported by Alex Schmolck. He saw
4933 this function to fix a problem reported by Alex Schmolck. He saw
4928 it with list comprehensions and generators, which were getting
4934 it with list comprehensions and generators, which were getting
4929 called twice. The real problem was an 'eval' call in testing for
4935 called twice. The real problem was an 'eval' call in testing for
4930 automagic which was evaluating the input line silently.
4936 automagic which was evaluating the input line silently.
4931
4937
4932 This is a potentially very nasty bug, if the input has side
4938 This is a potentially very nasty bug, if the input has side
4933 effects which must not be repeated. The code is much cleaner now,
4939 effects which must not be repeated. The code is much cleaner now,
4934 without any blanket 'except' left and with a regexp test for
4940 without any blanket 'except' left and with a regexp test for
4935 actual function names.
4941 actual function names.
4936
4942
4937 But an eval remains, which I'm not fully comfortable with. I just
4943 But an eval remains, which I'm not fully comfortable with. I just
4938 don't know how to find out if an expression could be a callable in
4944 don't know how to find out if an expression could be a callable in
4939 the user's namespace without doing an eval on the string. However
4945 the user's namespace without doing an eval on the string. However
4940 that string is now much more strictly checked so that no code
4946 that string is now much more strictly checked so that no code
4941 slips by, so the eval should only happen for things that can
4947 slips by, so the eval should only happen for things that can
4942 really be only function/method names.
4948 really be only function/method names.
4943
4949
4944 2002-10-15 Fernando Perez <fperez@colorado.edu>
4950 2002-10-15 Fernando Perez <fperez@colorado.edu>
4945
4951
4946 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
4952 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
4947 OSX information to main manual, removed README_Mac_OSX file from
4953 OSX information to main manual, removed README_Mac_OSX file from
4948 distribution. Also updated credits for recent additions.
4954 distribution. Also updated credits for recent additions.
4949
4955
4950 2002-10-10 Fernando Perez <fperez@colorado.edu>
4956 2002-10-10 Fernando Perez <fperez@colorado.edu>
4951
4957
4952 * README_Mac_OSX: Added a README for Mac OSX users for fixing
4958 * README_Mac_OSX: Added a README for Mac OSX users for fixing
4953 terminal-related issues. Many thanks to Andrea Riciputi
4959 terminal-related issues. Many thanks to Andrea Riciputi
4954 <andrea.riciputi-AT-libero.it> for writing it.
4960 <andrea.riciputi-AT-libero.it> for writing it.
4955
4961
4956 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
4962 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
4957 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4963 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4958
4964
4959 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
4965 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
4960 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
4966 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
4961 <syver-en-AT-online.no> who both submitted patches for this problem.
4967 <syver-en-AT-online.no> who both submitted patches for this problem.
4962
4968
4963 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
4969 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
4964 global embedding to make sure that things don't overwrite user
4970 global embedding to make sure that things don't overwrite user
4965 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
4971 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
4966
4972
4967 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
4973 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
4968 compatibility. Thanks to Hayden Callow
4974 compatibility. Thanks to Hayden Callow
4969 <h.callow-AT-elec.canterbury.ac.nz>
4975 <h.callow-AT-elec.canterbury.ac.nz>
4970
4976
4971 2002-10-04 Fernando Perez <fperez@colorado.edu>
4977 2002-10-04 Fernando Perez <fperez@colorado.edu>
4972
4978
4973 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
4979 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
4974 Gnuplot.File objects.
4980 Gnuplot.File objects.
4975
4981
4976 2002-07-23 Fernando Perez <fperez@colorado.edu>
4982 2002-07-23 Fernando Perez <fperez@colorado.edu>
4977
4983
4978 * IPython/genutils.py (timing): Added timings() and timing() for
4984 * IPython/genutils.py (timing): Added timings() and timing() for
4979 quick access to the most commonly needed data, the execution
4985 quick access to the most commonly needed data, the execution
4980 times. Old timing() renamed to timings_out().
4986 times. Old timing() renamed to timings_out().
4981
4987
4982 2002-07-18 Fernando Perez <fperez@colorado.edu>
4988 2002-07-18 Fernando Perez <fperez@colorado.edu>
4983
4989
4984 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
4990 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
4985 bug with nested instances disrupting the parent's tab completion.
4991 bug with nested instances disrupting the parent's tab completion.
4986
4992
4987 * IPython/iplib.py (all_completions): Added Alex Schmolck's
4993 * IPython/iplib.py (all_completions): Added Alex Schmolck's
4988 all_completions code to begin the emacs integration.
4994 all_completions code to begin the emacs integration.
4989
4995
4990 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
4996 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
4991 argument to allow titling individual arrays when plotting.
4997 argument to allow titling individual arrays when plotting.
4992
4998
4993 2002-07-15 Fernando Perez <fperez@colorado.edu>
4999 2002-07-15 Fernando Perez <fperez@colorado.edu>
4994
5000
4995 * setup.py (make_shortcut): changed to retrieve the value of
5001 * setup.py (make_shortcut): changed to retrieve the value of
4996 'Program Files' directory from the registry (this value changes in
5002 'Program Files' directory from the registry (this value changes in
4997 non-english versions of Windows). Thanks to Thomas Fanslau
5003 non-english versions of Windows). Thanks to Thomas Fanslau
4998 <tfanslau-AT-gmx.de> for the report.
5004 <tfanslau-AT-gmx.de> for the report.
4999
5005
5000 2002-07-10 Fernando Perez <fperez@colorado.edu>
5006 2002-07-10 Fernando Perez <fperez@colorado.edu>
5001
5007
5002 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
5008 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
5003 a bug in pdb, which crashes if a line with only whitespace is
5009 a bug in pdb, which crashes if a line with only whitespace is
5004 entered. Bug report submitted to sourceforge.
5010 entered. Bug report submitted to sourceforge.
5005
5011
5006 2002-07-09 Fernando Perez <fperez@colorado.edu>
5012 2002-07-09 Fernando Perez <fperez@colorado.edu>
5007
5013
5008 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
5014 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
5009 reporting exceptions (it's a bug in inspect.py, I just set a
5015 reporting exceptions (it's a bug in inspect.py, I just set a
5010 workaround).
5016 workaround).
5011
5017
5012 2002-07-08 Fernando Perez <fperez@colorado.edu>
5018 2002-07-08 Fernando Perez <fperez@colorado.edu>
5013
5019
5014 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
5020 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
5015 __IPYTHON__ in __builtins__ to show up in user_ns.
5021 __IPYTHON__ in __builtins__ to show up in user_ns.
5016
5022
5017 2002-07-03 Fernando Perez <fperez@colorado.edu>
5023 2002-07-03 Fernando Perez <fperez@colorado.edu>
5018
5024
5019 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
5025 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
5020 name from @gp_set_instance to @gp_set_default.
5026 name from @gp_set_instance to @gp_set_default.
5021
5027
5022 * IPython/ipmaker.py (make_IPython): default editor value set to
5028 * IPython/ipmaker.py (make_IPython): default editor value set to
5023 '0' (a string), to match the rc file. Otherwise will crash when
5029 '0' (a string), to match the rc file. Otherwise will crash when
5024 .strip() is called on it.
5030 .strip() is called on it.
5025
5031
5026
5032
5027 2002-06-28 Fernando Perez <fperez@colorado.edu>
5033 2002-06-28 Fernando Perez <fperez@colorado.edu>
5028
5034
5029 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
5035 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
5030 of files in current directory when a file is executed via
5036 of files in current directory when a file is executed via
5031 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
5037 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
5032
5038
5033 * setup.py (manfiles): fix for rpm builds, submitted by RA
5039 * setup.py (manfiles): fix for rpm builds, submitted by RA
5034 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
5040 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
5035
5041
5036 * IPython/ipmaker.py (make_IPython): fixed lookup of default
5042 * IPython/ipmaker.py (make_IPython): fixed lookup of default
5037 editor when set to '0'. Problem was, '0' evaluates to True (it's a
5043 editor when set to '0'. Problem was, '0' evaluates to True (it's a
5038 string!). A. Schmolck caught this one.
5044 string!). A. Schmolck caught this one.
5039
5045
5040 2002-06-27 Fernando Perez <fperez@colorado.edu>
5046 2002-06-27 Fernando Perez <fperez@colorado.edu>
5041
5047
5042 * IPython/ipmaker.py (make_IPython): fixed bug when running user
5048 * IPython/ipmaker.py (make_IPython): fixed bug when running user
5043 defined files at the cmd line. __name__ wasn't being set to
5049 defined files at the cmd line. __name__ wasn't being set to
5044 __main__.
5050 __main__.
5045
5051
5046 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
5052 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
5047 regular lists and tuples besides Numeric arrays.
5053 regular lists and tuples besides Numeric arrays.
5048
5054
5049 * IPython/Prompts.py (CachedOutput.__call__): Added output
5055 * IPython/Prompts.py (CachedOutput.__call__): Added output
5050 supression for input ending with ';'. Similar to Mathematica and
5056 supression for input ending with ';'. Similar to Mathematica and
5051 Matlab. The _* vars and Out[] list are still updated, just like
5057 Matlab. The _* vars and Out[] list are still updated, just like
5052 Mathematica behaves.
5058 Mathematica behaves.
5053
5059
5054 2002-06-25 Fernando Perez <fperez@colorado.edu>
5060 2002-06-25 Fernando Perez <fperez@colorado.edu>
5055
5061
5056 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
5062 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
5057 .ini extensions for profiels under Windows.
5063 .ini extensions for profiels under Windows.
5058
5064
5059 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
5065 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
5060 string form. Fix contributed by Alexander Schmolck
5066 string form. Fix contributed by Alexander Schmolck
5061 <a.schmolck-AT-gmx.net>
5067 <a.schmolck-AT-gmx.net>
5062
5068
5063 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
5069 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
5064 pre-configured Gnuplot instance.
5070 pre-configured Gnuplot instance.
5065
5071
5066 2002-06-21 Fernando Perez <fperez@colorado.edu>
5072 2002-06-21 Fernando Perez <fperez@colorado.edu>
5067
5073
5068 * IPython/numutils.py (exp_safe): new function, works around the
5074 * IPython/numutils.py (exp_safe): new function, works around the
5069 underflow problems in Numeric.
5075 underflow problems in Numeric.
5070 (log2): New fn. Safe log in base 2: returns exact integer answer
5076 (log2): New fn. Safe log in base 2: returns exact integer answer
5071 for exact integer powers of 2.
5077 for exact integer powers of 2.
5072
5078
5073 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
5079 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
5074 properly.
5080 properly.
5075
5081
5076 2002-06-20 Fernando Perez <fperez@colorado.edu>
5082 2002-06-20 Fernando Perez <fperez@colorado.edu>
5077
5083
5078 * IPython/genutils.py (timing): new function like
5084 * IPython/genutils.py (timing): new function like
5079 Mathematica's. Similar to time_test, but returns more info.
5085 Mathematica's. Similar to time_test, but returns more info.
5080
5086
5081 2002-06-18 Fernando Perez <fperez@colorado.edu>
5087 2002-06-18 Fernando Perez <fperez@colorado.edu>
5082
5088
5083 * IPython/Magic.py (Magic.magic_save): modified @save and @r
5089 * IPython/Magic.py (Magic.magic_save): modified @save and @r
5084 according to Mike Heeter's suggestions.
5090 according to Mike Heeter's suggestions.
5085
5091
5086 2002-06-16 Fernando Perez <fperez@colorado.edu>
5092 2002-06-16 Fernando Perez <fperez@colorado.edu>
5087
5093
5088 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
5094 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
5089 system. GnuplotMagic is gone as a user-directory option. New files
5095 system. GnuplotMagic is gone as a user-directory option. New files
5090 make it easier to use all the gnuplot stuff both from external
5096 make it easier to use all the gnuplot stuff both from external
5091 programs as well as from IPython. Had to rewrite part of
5097 programs as well as from IPython. Had to rewrite part of
5092 hardcopy() b/c of a strange bug: often the ps files simply don't
5098 hardcopy() b/c of a strange bug: often the ps files simply don't
5093 get created, and require a repeat of the command (often several
5099 get created, and require a repeat of the command (often several
5094 times).
5100 times).
5095
5101
5096 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
5102 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
5097 resolve output channel at call time, so that if sys.stderr has
5103 resolve output channel at call time, so that if sys.stderr has
5098 been redirected by user this gets honored.
5104 been redirected by user this gets honored.
5099
5105
5100 2002-06-13 Fernando Perez <fperez@colorado.edu>
5106 2002-06-13 Fernando Perez <fperez@colorado.edu>
5101
5107
5102 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
5108 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
5103 IPShell. Kept a copy with the old names to avoid breaking people's
5109 IPShell. Kept a copy with the old names to avoid breaking people's
5104 embedded code.
5110 embedded code.
5105
5111
5106 * IPython/ipython: simplified it to the bare minimum after
5112 * IPython/ipython: simplified it to the bare minimum after
5107 Holger's suggestions. Added info about how to use it in
5113 Holger's suggestions. Added info about how to use it in
5108 PYTHONSTARTUP.
5114 PYTHONSTARTUP.
5109
5115
5110 * IPython/Shell.py (IPythonShell): changed the options passing
5116 * IPython/Shell.py (IPythonShell): changed the options passing
5111 from a string with funky %s replacements to a straight list. Maybe
5117 from a string with funky %s replacements to a straight list. Maybe
5112 a bit more typing, but it follows sys.argv conventions, so there's
5118 a bit more typing, but it follows sys.argv conventions, so there's
5113 less special-casing to remember.
5119 less special-casing to remember.
5114
5120
5115 2002-06-12 Fernando Perez <fperez@colorado.edu>
5121 2002-06-12 Fernando Perez <fperez@colorado.edu>
5116
5122
5117 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
5123 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
5118 command. Thanks to a suggestion by Mike Heeter.
5124 command. Thanks to a suggestion by Mike Heeter.
5119 (Magic.magic_pfile): added behavior to look at filenames if given
5125 (Magic.magic_pfile): added behavior to look at filenames if given
5120 arg is not a defined object.
5126 arg is not a defined object.
5121 (Magic.magic_save): New @save function to save code snippets. Also
5127 (Magic.magic_save): New @save function to save code snippets. Also
5122 a Mike Heeter idea.
5128 a Mike Heeter idea.
5123
5129
5124 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
5130 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
5125 plot() and replot(). Much more convenient now, especially for
5131 plot() and replot(). Much more convenient now, especially for
5126 interactive use.
5132 interactive use.
5127
5133
5128 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
5134 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
5129 filenames.
5135 filenames.
5130
5136
5131 2002-06-02 Fernando Perez <fperez@colorado.edu>
5137 2002-06-02 Fernando Perez <fperez@colorado.edu>
5132
5138
5133 * IPython/Struct.py (Struct.__init__): modified to admit
5139 * IPython/Struct.py (Struct.__init__): modified to admit
5134 initialization via another struct.
5140 initialization via another struct.
5135
5141
5136 * IPython/genutils.py (SystemExec.__init__): New stateful
5142 * IPython/genutils.py (SystemExec.__init__): New stateful
5137 interface to xsys and bq. Useful for writing system scripts.
5143 interface to xsys and bq. Useful for writing system scripts.
5138
5144
5139 2002-05-30 Fernando Perez <fperez@colorado.edu>
5145 2002-05-30 Fernando Perez <fperez@colorado.edu>
5140
5146
5141 * MANIFEST.in: Changed docfile selection to exclude all the lyx
5147 * MANIFEST.in: Changed docfile selection to exclude all the lyx
5142 documents. This will make the user download smaller (it's getting
5148 documents. This will make the user download smaller (it's getting
5143 too big).
5149 too big).
5144
5150
5145 2002-05-29 Fernando Perez <fperez@colorado.edu>
5151 2002-05-29 Fernando Perez <fperez@colorado.edu>
5146
5152
5147 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
5153 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
5148 fix problems with shelve and pickle. Seems to work, but I don't
5154 fix problems with shelve and pickle. Seems to work, but I don't
5149 know if corner cases break it. Thanks to Mike Heeter
5155 know if corner cases break it. Thanks to Mike Heeter
5150 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
5156 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
5151
5157
5152 2002-05-24 Fernando Perez <fperez@colorado.edu>
5158 2002-05-24 Fernando Perez <fperez@colorado.edu>
5153
5159
5154 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
5160 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
5155 macros having broken.
5161 macros having broken.
5156
5162
5157 2002-05-21 Fernando Perez <fperez@colorado.edu>
5163 2002-05-21 Fernando Perez <fperez@colorado.edu>
5158
5164
5159 * IPython/Magic.py (Magic.magic_logstart): fixed recently
5165 * IPython/Magic.py (Magic.magic_logstart): fixed recently
5160 introduced logging bug: all history before logging started was
5166 introduced logging bug: all history before logging started was
5161 being written one character per line! This came from the redesign
5167 being written one character per line! This came from the redesign
5162 of the input history as a special list which slices to strings,
5168 of the input history as a special list which slices to strings,
5163 not to lists.
5169 not to lists.
5164
5170
5165 2002-05-20 Fernando Perez <fperez@colorado.edu>
5171 2002-05-20 Fernando Perez <fperez@colorado.edu>
5166
5172
5167 * IPython/Prompts.py (CachedOutput.__init__): made the color table
5173 * IPython/Prompts.py (CachedOutput.__init__): made the color table
5168 be an attribute of all classes in this module. The design of these
5174 be an attribute of all classes in this module. The design of these
5169 classes needs some serious overhauling.
5175 classes needs some serious overhauling.
5170
5176
5171 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
5177 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
5172 which was ignoring '_' in option names.
5178 which was ignoring '_' in option names.
5173
5179
5174 * IPython/ultraTB.py (FormattedTB.__init__): Changed
5180 * IPython/ultraTB.py (FormattedTB.__init__): Changed
5175 'Verbose_novars' to 'Context' and made it the new default. It's a
5181 'Verbose_novars' to 'Context' and made it the new default. It's a
5176 bit more readable and also safer than verbose.
5182 bit more readable and also safer than verbose.
5177
5183
5178 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
5184 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
5179 triple-quoted strings.
5185 triple-quoted strings.
5180
5186
5181 * IPython/OInspect.py (__all__): new module exposing the object
5187 * IPython/OInspect.py (__all__): new module exposing the object
5182 introspection facilities. Now the corresponding magics are dummy
5188 introspection facilities. Now the corresponding magics are dummy
5183 wrappers around this. Having this module will make it much easier
5189 wrappers around this. Having this module will make it much easier
5184 to put these functions into our modified pdb.
5190 to put these functions into our modified pdb.
5185 This new object inspector system uses the new colorizing module,
5191 This new object inspector system uses the new colorizing module,
5186 so source code and other things are nicely syntax highlighted.
5192 so source code and other things are nicely syntax highlighted.
5187
5193
5188 2002-05-18 Fernando Perez <fperez@colorado.edu>
5194 2002-05-18 Fernando Perez <fperez@colorado.edu>
5189
5195
5190 * IPython/ColorANSI.py: Split the coloring tools into a separate
5196 * IPython/ColorANSI.py: Split the coloring tools into a separate
5191 module so I can use them in other code easier (they were part of
5197 module so I can use them in other code easier (they were part of
5192 ultraTB).
5198 ultraTB).
5193
5199
5194 2002-05-17 Fernando Perez <fperez@colorado.edu>
5200 2002-05-17 Fernando Perez <fperez@colorado.edu>
5195
5201
5196 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5202 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5197 fixed it to set the global 'g' also to the called instance, as
5203 fixed it to set the global 'g' also to the called instance, as
5198 long as 'g' was still a gnuplot instance (so it doesn't overwrite
5204 long as 'g' was still a gnuplot instance (so it doesn't overwrite
5199 user's 'g' variables).
5205 user's 'g' variables).
5200
5206
5201 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
5207 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
5202 global variables (aliases to _ih,_oh) so that users which expect
5208 global variables (aliases to _ih,_oh) so that users which expect
5203 In[5] or Out[7] to work aren't unpleasantly surprised.
5209 In[5] or Out[7] to work aren't unpleasantly surprised.
5204 (InputList.__getslice__): new class to allow executing slices of
5210 (InputList.__getslice__): new class to allow executing slices of
5205 input history directly. Very simple class, complements the use of
5211 input history directly. Very simple class, complements the use of
5206 macros.
5212 macros.
5207
5213
5208 2002-05-16 Fernando Perez <fperez@colorado.edu>
5214 2002-05-16 Fernando Perez <fperez@colorado.edu>
5209
5215
5210 * setup.py (docdirbase): make doc directory be just doc/IPython
5216 * setup.py (docdirbase): make doc directory be just doc/IPython
5211 without version numbers, it will reduce clutter for users.
5217 without version numbers, it will reduce clutter for users.
5212
5218
5213 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
5219 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
5214 execfile call to prevent possible memory leak. See for details:
5220 execfile call to prevent possible memory leak. See for details:
5215 http://mail.python.org/pipermail/python-list/2002-February/088476.html
5221 http://mail.python.org/pipermail/python-list/2002-February/088476.html
5216
5222
5217 2002-05-15 Fernando Perez <fperez@colorado.edu>
5223 2002-05-15 Fernando Perez <fperez@colorado.edu>
5218
5224
5219 * IPython/Magic.py (Magic.magic_psource): made the object
5225 * IPython/Magic.py (Magic.magic_psource): made the object
5220 introspection names be more standard: pdoc, pdef, pfile and
5226 introspection names be more standard: pdoc, pdef, pfile and
5221 psource. They all print/page their output, and it makes
5227 psource. They all print/page their output, and it makes
5222 remembering them easier. Kept old names for compatibility as
5228 remembering them easier. Kept old names for compatibility as
5223 aliases.
5229 aliases.
5224
5230
5225 2002-05-14 Fernando Perez <fperez@colorado.edu>
5231 2002-05-14 Fernando Perez <fperez@colorado.edu>
5226
5232
5227 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
5233 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
5228 what the mouse problem was. The trick is to use gnuplot with temp
5234 what the mouse problem was. The trick is to use gnuplot with temp
5229 files and NOT with pipes (for data communication), because having
5235 files and NOT with pipes (for data communication), because having
5230 both pipes and the mouse on is bad news.
5236 both pipes and the mouse on is bad news.
5231
5237
5232 2002-05-13 Fernando Perez <fperez@colorado.edu>
5238 2002-05-13 Fernando Perez <fperez@colorado.edu>
5233
5239
5234 * IPython/Magic.py (Magic._ofind): fixed namespace order search
5240 * IPython/Magic.py (Magic._ofind): fixed namespace order search
5235 bug. Information would be reported about builtins even when
5241 bug. Information would be reported about builtins even when
5236 user-defined functions overrode them.
5242 user-defined functions overrode them.
5237
5243
5238 2002-05-11 Fernando Perez <fperez@colorado.edu>
5244 2002-05-11 Fernando Perez <fperez@colorado.edu>
5239
5245
5240 * IPython/__init__.py (__all__): removed FlexCompleter from
5246 * IPython/__init__.py (__all__): removed FlexCompleter from
5241 __all__ so that things don't fail in platforms without readline.
5247 __all__ so that things don't fail in platforms without readline.
5242
5248
5243 2002-05-10 Fernando Perez <fperez@colorado.edu>
5249 2002-05-10 Fernando Perez <fperez@colorado.edu>
5244
5250
5245 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
5251 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
5246 it requires Numeric, effectively making Numeric a dependency for
5252 it requires Numeric, effectively making Numeric a dependency for
5247 IPython.
5253 IPython.
5248
5254
5249 * Released 0.2.13
5255 * Released 0.2.13
5250
5256
5251 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
5257 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
5252 profiler interface. Now all the major options from the profiler
5258 profiler interface. Now all the major options from the profiler
5253 module are directly supported in IPython, both for single
5259 module are directly supported in IPython, both for single
5254 expressions (@prun) and for full programs (@run -p).
5260 expressions (@prun) and for full programs (@run -p).
5255
5261
5256 2002-05-09 Fernando Perez <fperez@colorado.edu>
5262 2002-05-09 Fernando Perez <fperez@colorado.edu>
5257
5263
5258 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
5264 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
5259 magic properly formatted for screen.
5265 magic properly formatted for screen.
5260
5266
5261 * setup.py (make_shortcut): Changed things to put pdf version in
5267 * setup.py (make_shortcut): Changed things to put pdf version in
5262 doc/ instead of doc/manual (had to change lyxport a bit).
5268 doc/ instead of doc/manual (had to change lyxport a bit).
5263
5269
5264 * IPython/Magic.py (Profile.string_stats): made profile runs go
5270 * IPython/Magic.py (Profile.string_stats): made profile runs go
5265 through pager (they are long and a pager allows searching, saving,
5271 through pager (they are long and a pager allows searching, saving,
5266 etc.)
5272 etc.)
5267
5273
5268 2002-05-08 Fernando Perez <fperez@colorado.edu>
5274 2002-05-08 Fernando Perez <fperez@colorado.edu>
5269
5275
5270 * Released 0.2.12
5276 * Released 0.2.12
5271
5277
5272 2002-05-06 Fernando Perez <fperez@colorado.edu>
5278 2002-05-06 Fernando Perez <fperez@colorado.edu>
5273
5279
5274 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
5280 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
5275 introduced); 'hist n1 n2' was broken.
5281 introduced); 'hist n1 n2' was broken.
5276 (Magic.magic_pdb): added optional on/off arguments to @pdb
5282 (Magic.magic_pdb): added optional on/off arguments to @pdb
5277 (Magic.magic_run): added option -i to @run, which executes code in
5283 (Magic.magic_run): added option -i to @run, which executes code in
5278 the IPython namespace instead of a clean one. Also added @irun as
5284 the IPython namespace instead of a clean one. Also added @irun as
5279 an alias to @run -i.
5285 an alias to @run -i.
5280
5286
5281 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5287 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5282 fixed (it didn't really do anything, the namespaces were wrong).
5288 fixed (it didn't really do anything, the namespaces were wrong).
5283
5289
5284 * IPython/Debugger.py (__init__): Added workaround for python 2.1
5290 * IPython/Debugger.py (__init__): Added workaround for python 2.1
5285
5291
5286 * IPython/__init__.py (__all__): Fixed package namespace, now
5292 * IPython/__init__.py (__all__): Fixed package namespace, now
5287 'import IPython' does give access to IPython.<all> as
5293 'import IPython' does give access to IPython.<all> as
5288 expected. Also renamed __release__ to Release.
5294 expected. Also renamed __release__ to Release.
5289
5295
5290 * IPython/Debugger.py (__license__): created new Pdb class which
5296 * IPython/Debugger.py (__license__): created new Pdb class which
5291 functions like a drop-in for the normal pdb.Pdb but does NOT
5297 functions like a drop-in for the normal pdb.Pdb but does NOT
5292 import readline by default. This way it doesn't muck up IPython's
5298 import readline by default. This way it doesn't muck up IPython's
5293 readline handling, and now tab-completion finally works in the
5299 readline handling, and now tab-completion finally works in the
5294 debugger -- sort of. It completes things globally visible, but the
5300 debugger -- sort of. It completes things globally visible, but the
5295 completer doesn't track the stack as pdb walks it. That's a bit
5301 completer doesn't track the stack as pdb walks it. That's a bit
5296 tricky, and I'll have to implement it later.
5302 tricky, and I'll have to implement it later.
5297
5303
5298 2002-05-05 Fernando Perez <fperez@colorado.edu>
5304 2002-05-05 Fernando Perez <fperez@colorado.edu>
5299
5305
5300 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
5306 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
5301 magic docstrings when printed via ? (explicit \'s were being
5307 magic docstrings when printed via ? (explicit \'s were being
5302 printed).
5308 printed).
5303
5309
5304 * IPython/ipmaker.py (make_IPython): fixed namespace
5310 * IPython/ipmaker.py (make_IPython): fixed namespace
5305 identification bug. Now variables loaded via logs or command-line
5311 identification bug. Now variables loaded via logs or command-line
5306 files are recognized in the interactive namespace by @who.
5312 files are recognized in the interactive namespace by @who.
5307
5313
5308 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
5314 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
5309 log replay system stemming from the string form of Structs.
5315 log replay system stemming from the string form of Structs.
5310
5316
5311 * IPython/Magic.py (Macro.__init__): improved macros to properly
5317 * IPython/Magic.py (Macro.__init__): improved macros to properly
5312 handle magic commands in them.
5318 handle magic commands in them.
5313 (Magic.magic_logstart): usernames are now expanded so 'logstart
5319 (Magic.magic_logstart): usernames are now expanded so 'logstart
5314 ~/mylog' now works.
5320 ~/mylog' now works.
5315
5321
5316 * IPython/iplib.py (complete): fixed bug where paths starting with
5322 * IPython/iplib.py (complete): fixed bug where paths starting with
5317 '/' would be completed as magic names.
5323 '/' would be completed as magic names.
5318
5324
5319 2002-05-04 Fernando Perez <fperez@colorado.edu>
5325 2002-05-04 Fernando Perez <fperez@colorado.edu>
5320
5326
5321 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
5327 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
5322 allow running full programs under the profiler's control.
5328 allow running full programs under the profiler's control.
5323
5329
5324 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
5330 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
5325 mode to report exceptions verbosely but without formatting
5331 mode to report exceptions verbosely but without formatting
5326 variables. This addresses the issue of ipython 'freezing' (it's
5332 variables. This addresses the issue of ipython 'freezing' (it's
5327 not frozen, but caught in an expensive formatting loop) when huge
5333 not frozen, but caught in an expensive formatting loop) when huge
5328 variables are in the context of an exception.
5334 variables are in the context of an exception.
5329 (VerboseTB.text): Added '--->' markers at line where exception was
5335 (VerboseTB.text): Added '--->' markers at line where exception was
5330 triggered. Much clearer to read, especially in NoColor modes.
5336 triggered. Much clearer to read, especially in NoColor modes.
5331
5337
5332 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
5338 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
5333 implemented in reverse when changing to the new parse_options().
5339 implemented in reverse when changing to the new parse_options().
5334
5340
5335 2002-05-03 Fernando Perez <fperez@colorado.edu>
5341 2002-05-03 Fernando Perez <fperez@colorado.edu>
5336
5342
5337 * IPython/Magic.py (Magic.parse_options): new function so that
5343 * IPython/Magic.py (Magic.parse_options): new function so that
5338 magics can parse options easier.
5344 magics can parse options easier.
5339 (Magic.magic_prun): new function similar to profile.run(),
5345 (Magic.magic_prun): new function similar to profile.run(),
5340 suggested by Chris Hart.
5346 suggested by Chris Hart.
5341 (Magic.magic_cd): fixed behavior so that it only changes if
5347 (Magic.magic_cd): fixed behavior so that it only changes if
5342 directory actually is in history.
5348 directory actually is in history.
5343
5349
5344 * IPython/usage.py (__doc__): added information about potential
5350 * IPython/usage.py (__doc__): added information about potential
5345 slowness of Verbose exception mode when there are huge data
5351 slowness of Verbose exception mode when there are huge data
5346 structures to be formatted (thanks to Archie Paulson).
5352 structures to be formatted (thanks to Archie Paulson).
5347
5353
5348 * IPython/ipmaker.py (make_IPython): Changed default logging
5354 * IPython/ipmaker.py (make_IPython): Changed default logging
5349 (when simply called with -log) to use curr_dir/ipython.log in
5355 (when simply called with -log) to use curr_dir/ipython.log in
5350 rotate mode. Fixed crash which was occuring with -log before
5356 rotate mode. Fixed crash which was occuring with -log before
5351 (thanks to Jim Boyle).
5357 (thanks to Jim Boyle).
5352
5358
5353 2002-05-01 Fernando Perez <fperez@colorado.edu>
5359 2002-05-01 Fernando Perez <fperez@colorado.edu>
5354
5360
5355 * Released 0.2.11 for these fixes (mainly the ultraTB one which
5361 * Released 0.2.11 for these fixes (mainly the ultraTB one which
5356 was nasty -- though somewhat of a corner case).
5362 was nasty -- though somewhat of a corner case).
5357
5363
5358 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
5364 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
5359 text (was a bug).
5365 text (was a bug).
5360
5366
5361 2002-04-30 Fernando Perez <fperez@colorado.edu>
5367 2002-04-30 Fernando Perez <fperez@colorado.edu>
5362
5368
5363 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
5369 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
5364 a print after ^D or ^C from the user so that the In[] prompt
5370 a print after ^D or ^C from the user so that the In[] prompt
5365 doesn't over-run the gnuplot one.
5371 doesn't over-run the gnuplot one.
5366
5372
5367 2002-04-29 Fernando Perez <fperez@colorado.edu>
5373 2002-04-29 Fernando Perez <fperez@colorado.edu>
5368
5374
5369 * Released 0.2.10
5375 * Released 0.2.10
5370
5376
5371 * IPython/__release__.py (version): get date dynamically.
5377 * IPython/__release__.py (version): get date dynamically.
5372
5378
5373 * Misc. documentation updates thanks to Arnd's comments. Also ran
5379 * Misc. documentation updates thanks to Arnd's comments. Also ran
5374 a full spellcheck on the manual (hadn't been done in a while).
5380 a full spellcheck on the manual (hadn't been done in a while).
5375
5381
5376 2002-04-27 Fernando Perez <fperez@colorado.edu>
5382 2002-04-27 Fernando Perez <fperez@colorado.edu>
5377
5383
5378 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
5384 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
5379 starting a log in mid-session would reset the input history list.
5385 starting a log in mid-session would reset the input history list.
5380
5386
5381 2002-04-26 Fernando Perez <fperez@colorado.edu>
5387 2002-04-26 Fernando Perez <fperez@colorado.edu>
5382
5388
5383 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
5389 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
5384 all files were being included in an update. Now anything in
5390 all files were being included in an update. Now anything in
5385 UserConfig that matches [A-Za-z]*.py will go (this excludes
5391 UserConfig that matches [A-Za-z]*.py will go (this excludes
5386 __init__.py)
5392 __init__.py)
5387
5393
5388 2002-04-25 Fernando Perez <fperez@colorado.edu>
5394 2002-04-25 Fernando Perez <fperez@colorado.edu>
5389
5395
5390 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
5396 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
5391 to __builtins__ so that any form of embedded or imported code can
5397 to __builtins__ so that any form of embedded or imported code can
5392 test for being inside IPython.
5398 test for being inside IPython.
5393
5399
5394 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
5400 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
5395 changed to GnuplotMagic because it's now an importable module,
5401 changed to GnuplotMagic because it's now an importable module,
5396 this makes the name follow that of the standard Gnuplot module.
5402 this makes the name follow that of the standard Gnuplot module.
5397 GnuplotMagic can now be loaded at any time in mid-session.
5403 GnuplotMagic can now be loaded at any time in mid-session.
5398
5404
5399 2002-04-24 Fernando Perez <fperez@colorado.edu>
5405 2002-04-24 Fernando Perez <fperez@colorado.edu>
5400
5406
5401 * IPython/numutils.py: removed SIUnits. It doesn't properly set
5407 * IPython/numutils.py: removed SIUnits. It doesn't properly set
5402 the globals (IPython has its own namespace) and the
5408 the globals (IPython has its own namespace) and the
5403 PhysicalQuantity stuff is much better anyway.
5409 PhysicalQuantity stuff is much better anyway.
5404
5410
5405 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
5411 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
5406 embedding example to standard user directory for
5412 embedding example to standard user directory for
5407 distribution. Also put it in the manual.
5413 distribution. Also put it in the manual.
5408
5414
5409 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
5415 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
5410 instance as first argument (so it doesn't rely on some obscure
5416 instance as first argument (so it doesn't rely on some obscure
5411 hidden global).
5417 hidden global).
5412
5418
5413 * IPython/UserConfig/ipythonrc.py: put () back in accepted
5419 * IPython/UserConfig/ipythonrc.py: put () back in accepted
5414 delimiters. While it prevents ().TAB from working, it allows
5420 delimiters. While it prevents ().TAB from working, it allows
5415 completions in open (... expressions. This is by far a more common
5421 completions in open (... expressions. This is by far a more common
5416 case.
5422 case.
5417
5423
5418 2002-04-23 Fernando Perez <fperez@colorado.edu>
5424 2002-04-23 Fernando Perez <fperez@colorado.edu>
5419
5425
5420 * IPython/Extensions/InterpreterPasteInput.py: new
5426 * IPython/Extensions/InterpreterPasteInput.py: new
5421 syntax-processing module for pasting lines with >>> or ... at the
5427 syntax-processing module for pasting lines with >>> or ... at the
5422 start.
5428 start.
5423
5429
5424 * IPython/Extensions/PhysicalQ_Interactive.py
5430 * IPython/Extensions/PhysicalQ_Interactive.py
5425 (PhysicalQuantityInteractive.__int__): fixed to work with either
5431 (PhysicalQuantityInteractive.__int__): fixed to work with either
5426 Numeric or math.
5432 Numeric or math.
5427
5433
5428 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
5434 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
5429 provided profiles. Now we have:
5435 provided profiles. Now we have:
5430 -math -> math module as * and cmath with its own namespace.
5436 -math -> math module as * and cmath with its own namespace.
5431 -numeric -> Numeric as *, plus gnuplot & grace
5437 -numeric -> Numeric as *, plus gnuplot & grace
5432 -physics -> same as before
5438 -physics -> same as before
5433
5439
5434 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
5440 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
5435 user-defined magics wouldn't be found by @magic if they were
5441 user-defined magics wouldn't be found by @magic if they were
5436 defined as class methods. Also cleaned up the namespace search
5442 defined as class methods. Also cleaned up the namespace search
5437 logic and the string building (to use %s instead of many repeated
5443 logic and the string building (to use %s instead of many repeated
5438 string adds).
5444 string adds).
5439
5445
5440 * IPython/UserConfig/example-magic.py (magic_foo): updated example
5446 * IPython/UserConfig/example-magic.py (magic_foo): updated example
5441 of user-defined magics to operate with class methods (cleaner, in
5447 of user-defined magics to operate with class methods (cleaner, in
5442 line with the gnuplot code).
5448 line with the gnuplot code).
5443
5449
5444 2002-04-22 Fernando Perez <fperez@colorado.edu>
5450 2002-04-22 Fernando Perez <fperez@colorado.edu>
5445
5451
5446 * setup.py: updated dependency list so that manual is updated when
5452 * setup.py: updated dependency list so that manual is updated when
5447 all included files change.
5453 all included files change.
5448
5454
5449 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
5455 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
5450 the delimiter removal option (the fix is ugly right now).
5456 the delimiter removal option (the fix is ugly right now).
5451
5457
5452 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
5458 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
5453 all of the math profile (quicker loading, no conflict between
5459 all of the math profile (quicker loading, no conflict between
5454 g-9.8 and g-gnuplot).
5460 g-9.8 and g-gnuplot).
5455
5461
5456 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
5462 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
5457 name of post-mortem files to IPython_crash_report.txt.
5463 name of post-mortem files to IPython_crash_report.txt.
5458
5464
5459 * Cleanup/update of the docs. Added all the new readline info and
5465 * Cleanup/update of the docs. Added all the new readline info and
5460 formatted all lists as 'real lists'.
5466 formatted all lists as 'real lists'.
5461
5467
5462 * IPython/ipmaker.py (make_IPython): removed now-obsolete
5468 * IPython/ipmaker.py (make_IPython): removed now-obsolete
5463 tab-completion options, since the full readline parse_and_bind is
5469 tab-completion options, since the full readline parse_and_bind is
5464 now accessible.
5470 now accessible.
5465
5471
5466 * IPython/iplib.py (InteractiveShell.init_readline): Changed
5472 * IPython/iplib.py (InteractiveShell.init_readline): Changed
5467 handling of readline options. Now users can specify any string to
5473 handling of readline options. Now users can specify any string to
5468 be passed to parse_and_bind(), as well as the delimiters to be
5474 be passed to parse_and_bind(), as well as the delimiters to be
5469 removed.
5475 removed.
5470 (InteractiveShell.__init__): Added __name__ to the global
5476 (InteractiveShell.__init__): Added __name__ to the global
5471 namespace so that things like Itpl which rely on its existence
5477 namespace so that things like Itpl which rely on its existence
5472 don't crash.
5478 don't crash.
5473 (InteractiveShell._prefilter): Defined the default with a _ so
5479 (InteractiveShell._prefilter): Defined the default with a _ so
5474 that prefilter() is easier to override, while the default one
5480 that prefilter() is easier to override, while the default one
5475 remains available.
5481 remains available.
5476
5482
5477 2002-04-18 Fernando Perez <fperez@colorado.edu>
5483 2002-04-18 Fernando Perez <fperez@colorado.edu>
5478
5484
5479 * Added information about pdb in the docs.
5485 * Added information about pdb in the docs.
5480
5486
5481 2002-04-17 Fernando Perez <fperez@colorado.edu>
5487 2002-04-17 Fernando Perez <fperez@colorado.edu>
5482
5488
5483 * IPython/ipmaker.py (make_IPython): added rc_override option to
5489 * IPython/ipmaker.py (make_IPython): added rc_override option to
5484 allow passing config options at creation time which may override
5490 allow passing config options at creation time which may override
5485 anything set in the config files or command line. This is
5491 anything set in the config files or command line. This is
5486 particularly useful for configuring embedded instances.
5492 particularly useful for configuring embedded instances.
5487
5493
5488 2002-04-15 Fernando Perez <fperez@colorado.edu>
5494 2002-04-15 Fernando Perez <fperez@colorado.edu>
5489
5495
5490 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
5496 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
5491 crash embedded instances because of the input cache falling out of
5497 crash embedded instances because of the input cache falling out of
5492 sync with the output counter.
5498 sync with the output counter.
5493
5499
5494 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
5500 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
5495 mode which calls pdb after an uncaught exception in IPython itself.
5501 mode which calls pdb after an uncaught exception in IPython itself.
5496
5502
5497 2002-04-14 Fernando Perez <fperez@colorado.edu>
5503 2002-04-14 Fernando Perez <fperez@colorado.edu>
5498
5504
5499 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
5505 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
5500 readline, fix it back after each call.
5506 readline, fix it back after each call.
5501
5507
5502 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
5508 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
5503 method to force all access via __call__(), which guarantees that
5509 method to force all access via __call__(), which guarantees that
5504 traceback references are properly deleted.
5510 traceback references are properly deleted.
5505
5511
5506 * IPython/Prompts.py (CachedOutput._display): minor fixes to
5512 * IPython/Prompts.py (CachedOutput._display): minor fixes to
5507 improve printing when pprint is in use.
5513 improve printing when pprint is in use.
5508
5514
5509 2002-04-13 Fernando Perez <fperez@colorado.edu>
5515 2002-04-13 Fernando Perez <fperez@colorado.edu>
5510
5516
5511 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
5517 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
5512 exceptions aren't caught anymore. If the user triggers one, he
5518 exceptions aren't caught anymore. If the user triggers one, he
5513 should know why he's doing it and it should go all the way up,
5519 should know why he's doing it and it should go all the way up,
5514 just like any other exception. So now @abort will fully kill the
5520 just like any other exception. So now @abort will fully kill the
5515 embedded interpreter and the embedding code (unless that happens
5521 embedded interpreter and the embedding code (unless that happens
5516 to catch SystemExit).
5522 to catch SystemExit).
5517
5523
5518 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
5524 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
5519 and a debugger() method to invoke the interactive pdb debugger
5525 and a debugger() method to invoke the interactive pdb debugger
5520 after printing exception information. Also added the corresponding
5526 after printing exception information. Also added the corresponding
5521 -pdb option and @pdb magic to control this feature, and updated
5527 -pdb option and @pdb magic to control this feature, and updated
5522 the docs. After a suggestion from Christopher Hart
5528 the docs. After a suggestion from Christopher Hart
5523 (hart-AT-caltech.edu).
5529 (hart-AT-caltech.edu).
5524
5530
5525 2002-04-12 Fernando Perez <fperez@colorado.edu>
5531 2002-04-12 Fernando Perez <fperez@colorado.edu>
5526
5532
5527 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
5533 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
5528 the exception handlers defined by the user (not the CrashHandler)
5534 the exception handlers defined by the user (not the CrashHandler)
5529 so that user exceptions don't trigger an ipython bug report.
5535 so that user exceptions don't trigger an ipython bug report.
5530
5536
5531 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
5537 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
5532 configurable (it should have always been so).
5538 configurable (it should have always been so).
5533
5539
5534 2002-03-26 Fernando Perez <fperez@colorado.edu>
5540 2002-03-26 Fernando Perez <fperez@colorado.edu>
5535
5541
5536 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
5542 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
5537 and there to fix embedding namespace issues. This should all be
5543 and there to fix embedding namespace issues. This should all be
5538 done in a more elegant way.
5544 done in a more elegant way.
5539
5545
5540 2002-03-25 Fernando Perez <fperez@colorado.edu>
5546 2002-03-25 Fernando Perez <fperez@colorado.edu>
5541
5547
5542 * IPython/genutils.py (get_home_dir): Try to make it work under
5548 * IPython/genutils.py (get_home_dir): Try to make it work under
5543 win9x also.
5549 win9x also.
5544
5550
5545 2002-03-20 Fernando Perez <fperez@colorado.edu>
5551 2002-03-20 Fernando Perez <fperez@colorado.edu>
5546
5552
5547 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
5553 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
5548 sys.displayhook untouched upon __init__.
5554 sys.displayhook untouched upon __init__.
5549
5555
5550 2002-03-19 Fernando Perez <fperez@colorado.edu>
5556 2002-03-19 Fernando Perez <fperez@colorado.edu>
5551
5557
5552 * Released 0.2.9 (for embedding bug, basically).
5558 * Released 0.2.9 (for embedding bug, basically).
5553
5559
5554 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
5560 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
5555 exceptions so that enclosing shell's state can be restored.
5561 exceptions so that enclosing shell's state can be restored.
5556
5562
5557 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
5563 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
5558 naming conventions in the .ipython/ dir.
5564 naming conventions in the .ipython/ dir.
5559
5565
5560 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
5566 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
5561 from delimiters list so filenames with - in them get expanded.
5567 from delimiters list so filenames with - in them get expanded.
5562
5568
5563 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
5569 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
5564 sys.displayhook not being properly restored after an embedded call.
5570 sys.displayhook not being properly restored after an embedded call.
5565
5571
5566 2002-03-18 Fernando Perez <fperez@colorado.edu>
5572 2002-03-18 Fernando Perez <fperez@colorado.edu>
5567
5573
5568 * Released 0.2.8
5574 * Released 0.2.8
5569
5575
5570 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
5576 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
5571 some files weren't being included in a -upgrade.
5577 some files weren't being included in a -upgrade.
5572 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
5578 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
5573 on' so that the first tab completes.
5579 on' so that the first tab completes.
5574 (InteractiveShell.handle_magic): fixed bug with spaces around
5580 (InteractiveShell.handle_magic): fixed bug with spaces around
5575 quotes breaking many magic commands.
5581 quotes breaking many magic commands.
5576
5582
5577 * setup.py: added note about ignoring the syntax error messages at
5583 * setup.py: added note about ignoring the syntax error messages at
5578 installation.
5584 installation.
5579
5585
5580 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
5586 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
5581 streamlining the gnuplot interface, now there's only one magic @gp.
5587 streamlining the gnuplot interface, now there's only one magic @gp.
5582
5588
5583 2002-03-17 Fernando Perez <fperez@colorado.edu>
5589 2002-03-17 Fernando Perez <fperez@colorado.edu>
5584
5590
5585 * IPython/UserConfig/magic_gnuplot.py: new name for the
5591 * IPython/UserConfig/magic_gnuplot.py: new name for the
5586 example-magic_pm.py file. Much enhanced system, now with a shell
5592 example-magic_pm.py file. Much enhanced system, now with a shell
5587 for communicating directly with gnuplot, one command at a time.
5593 for communicating directly with gnuplot, one command at a time.
5588
5594
5589 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
5595 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
5590 setting __name__=='__main__'.
5596 setting __name__=='__main__'.
5591
5597
5592 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
5598 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
5593 mini-shell for accessing gnuplot from inside ipython. Should
5599 mini-shell for accessing gnuplot from inside ipython. Should
5594 extend it later for grace access too. Inspired by Arnd's
5600 extend it later for grace access too. Inspired by Arnd's
5595 suggestion.
5601 suggestion.
5596
5602
5597 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
5603 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
5598 calling magic functions with () in their arguments. Thanks to Arnd
5604 calling magic functions with () in their arguments. Thanks to Arnd
5599 Baecker for pointing this to me.
5605 Baecker for pointing this to me.
5600
5606
5601 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
5607 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
5602 infinitely for integer or complex arrays (only worked with floats).
5608 infinitely for integer or complex arrays (only worked with floats).
5603
5609
5604 2002-03-16 Fernando Perez <fperez@colorado.edu>
5610 2002-03-16 Fernando Perez <fperez@colorado.edu>
5605
5611
5606 * setup.py: Merged setup and setup_windows into a single script
5612 * setup.py: Merged setup and setup_windows into a single script
5607 which properly handles things for windows users.
5613 which properly handles things for windows users.
5608
5614
5609 2002-03-15 Fernando Perez <fperez@colorado.edu>
5615 2002-03-15 Fernando Perez <fperez@colorado.edu>
5610
5616
5611 * Big change to the manual: now the magics are all automatically
5617 * Big change to the manual: now the magics are all automatically
5612 documented. This information is generated from their docstrings
5618 documented. This information is generated from their docstrings
5613 and put in a latex file included by the manual lyx file. This way
5619 and put in a latex file included by the manual lyx file. This way
5614 we get always up to date information for the magics. The manual
5620 we get always up to date information for the magics. The manual
5615 now also has proper version information, also auto-synced.
5621 now also has proper version information, also auto-synced.
5616
5622
5617 For this to work, an undocumented --magic_docstrings option was added.
5623 For this to work, an undocumented --magic_docstrings option was added.
5618
5624
5619 2002-03-13 Fernando Perez <fperez@colorado.edu>
5625 2002-03-13 Fernando Perez <fperez@colorado.edu>
5620
5626
5621 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
5627 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
5622 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
5628 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
5623
5629
5624 2002-03-12 Fernando Perez <fperez@colorado.edu>
5630 2002-03-12 Fernando Perez <fperez@colorado.edu>
5625
5631
5626 * IPython/ultraTB.py (TermColors): changed color escapes again to
5632 * IPython/ultraTB.py (TermColors): changed color escapes again to
5627 fix the (old, reintroduced) line-wrapping bug. Basically, if
5633 fix the (old, reintroduced) line-wrapping bug. Basically, if
5628 \001..\002 aren't given in the color escapes, lines get wrapped
5634 \001..\002 aren't given in the color escapes, lines get wrapped
5629 weirdly. But giving those screws up old xterms and emacs terms. So
5635 weirdly. But giving those screws up old xterms and emacs terms. So
5630 I added some logic for emacs terms to be ok, but I can't identify old
5636 I added some logic for emacs terms to be ok, but I can't identify old
5631 xterms separately ($TERM=='xterm' for many terminals, like konsole).
5637 xterms separately ($TERM=='xterm' for many terminals, like konsole).
5632
5638
5633 2002-03-10 Fernando Perez <fperez@colorado.edu>
5639 2002-03-10 Fernando Perez <fperez@colorado.edu>
5634
5640
5635 * IPython/usage.py (__doc__): Various documentation cleanups and
5641 * IPython/usage.py (__doc__): Various documentation cleanups and
5636 updates, both in usage docstrings and in the manual.
5642 updates, both in usage docstrings and in the manual.
5637
5643
5638 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
5644 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
5639 handling of caching. Set minimum acceptabe value for having a
5645 handling of caching. Set minimum acceptabe value for having a
5640 cache at 20 values.
5646 cache at 20 values.
5641
5647
5642 * IPython/iplib.py (InteractiveShell.user_setup): moved the
5648 * IPython/iplib.py (InteractiveShell.user_setup): moved the
5643 install_first_time function to a method, renamed it and added an
5649 install_first_time function to a method, renamed it and added an
5644 'upgrade' mode. Now people can update their config directory with
5650 'upgrade' mode. Now people can update their config directory with
5645 a simple command line switch (-upgrade, also new).
5651 a simple command line switch (-upgrade, also new).
5646
5652
5647 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
5653 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
5648 @file (convenient for automagic users under Python >= 2.2).
5654 @file (convenient for automagic users under Python >= 2.2).
5649 Removed @files (it seemed more like a plural than an abbrev. of
5655 Removed @files (it seemed more like a plural than an abbrev. of
5650 'file show').
5656 'file show').
5651
5657
5652 * IPython/iplib.py (install_first_time): Fixed crash if there were
5658 * IPython/iplib.py (install_first_time): Fixed crash if there were
5653 backup files ('~') in .ipython/ install directory.
5659 backup files ('~') in .ipython/ install directory.
5654
5660
5655 * IPython/ipmaker.py (make_IPython): fixes for new prompt
5661 * IPython/ipmaker.py (make_IPython): fixes for new prompt
5656 system. Things look fine, but these changes are fairly
5662 system. Things look fine, but these changes are fairly
5657 intrusive. Test them for a few days.
5663 intrusive. Test them for a few days.
5658
5664
5659 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
5665 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
5660 the prompts system. Now all in/out prompt strings are user
5666 the prompts system. Now all in/out prompt strings are user
5661 controllable. This is particularly useful for embedding, as one
5667 controllable. This is particularly useful for embedding, as one
5662 can tag embedded instances with particular prompts.
5668 can tag embedded instances with particular prompts.
5663
5669
5664 Also removed global use of sys.ps1/2, which now allows nested
5670 Also removed global use of sys.ps1/2, which now allows nested
5665 embeddings without any problems. Added command-line options for
5671 embeddings without any problems. Added command-line options for
5666 the prompt strings.
5672 the prompt strings.
5667
5673
5668 2002-03-08 Fernando Perez <fperez@colorado.edu>
5674 2002-03-08 Fernando Perez <fperez@colorado.edu>
5669
5675
5670 * IPython/UserConfig/example-embed-short.py (ipshell): added
5676 * IPython/UserConfig/example-embed-short.py (ipshell): added
5671 example file with the bare minimum code for embedding.
5677 example file with the bare minimum code for embedding.
5672
5678
5673 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
5679 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
5674 functionality for the embeddable shell to be activated/deactivated
5680 functionality for the embeddable shell to be activated/deactivated
5675 either globally or at each call.
5681 either globally or at each call.
5676
5682
5677 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
5683 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
5678 rewriting the prompt with '--->' for auto-inputs with proper
5684 rewriting the prompt with '--->' for auto-inputs with proper
5679 coloring. Now the previous UGLY hack in handle_auto() is gone, and
5685 coloring. Now the previous UGLY hack in handle_auto() is gone, and
5680 this is handled by the prompts class itself, as it should.
5686 this is handled by the prompts class itself, as it should.
5681
5687
5682 2002-03-05 Fernando Perez <fperez@colorado.edu>
5688 2002-03-05 Fernando Perez <fperez@colorado.edu>
5683
5689
5684 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
5690 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
5685 @logstart to avoid name clashes with the math log function.
5691 @logstart to avoid name clashes with the math log function.
5686
5692
5687 * Big updates to X/Emacs section of the manual.
5693 * Big updates to X/Emacs section of the manual.
5688
5694
5689 * Removed ipython_emacs. Milan explained to me how to pass
5695 * Removed ipython_emacs. Milan explained to me how to pass
5690 arguments to ipython through Emacs. Some day I'm going to end up
5696 arguments to ipython through Emacs. Some day I'm going to end up
5691 learning some lisp...
5697 learning some lisp...
5692
5698
5693 2002-03-04 Fernando Perez <fperez@colorado.edu>
5699 2002-03-04 Fernando Perez <fperez@colorado.edu>
5694
5700
5695 * IPython/ipython_emacs: Created script to be used as the
5701 * IPython/ipython_emacs: Created script to be used as the
5696 py-python-command Emacs variable so we can pass IPython
5702 py-python-command Emacs variable so we can pass IPython
5697 parameters. I can't figure out how to tell Emacs directly to pass
5703 parameters. I can't figure out how to tell Emacs directly to pass
5698 parameters to IPython, so a dummy shell script will do it.
5704 parameters to IPython, so a dummy shell script will do it.
5699
5705
5700 Other enhancements made for things to work better under Emacs'
5706 Other enhancements made for things to work better under Emacs'
5701 various types of terminals. Many thanks to Milan Zamazal
5707 various types of terminals. Many thanks to Milan Zamazal
5702 <pdm-AT-zamazal.org> for all the suggestions and pointers.
5708 <pdm-AT-zamazal.org> for all the suggestions and pointers.
5703
5709
5704 2002-03-01 Fernando Perez <fperez@colorado.edu>
5710 2002-03-01 Fernando Perez <fperez@colorado.edu>
5705
5711
5706 * IPython/ipmaker.py (make_IPython): added a --readline! option so
5712 * IPython/ipmaker.py (make_IPython): added a --readline! option so
5707 that loading of readline is now optional. This gives better
5713 that loading of readline is now optional. This gives better
5708 control to emacs users.
5714 control to emacs users.
5709
5715
5710 * IPython/ultraTB.py (__date__): Modified color escape sequences
5716 * IPython/ultraTB.py (__date__): Modified color escape sequences
5711 and now things work fine under xterm and in Emacs' term buffers
5717 and now things work fine under xterm and in Emacs' term buffers
5712 (though not shell ones). Well, in emacs you get colors, but all
5718 (though not shell ones). Well, in emacs you get colors, but all
5713 seem to be 'light' colors (no difference between dark and light
5719 seem to be 'light' colors (no difference between dark and light
5714 ones). But the garbage chars are gone, and also in xterms. It
5720 ones). But the garbage chars are gone, and also in xterms. It
5715 seems that now I'm using 'cleaner' ansi sequences.
5721 seems that now I'm using 'cleaner' ansi sequences.
5716
5722
5717 2002-02-21 Fernando Perez <fperez@colorado.edu>
5723 2002-02-21 Fernando Perez <fperez@colorado.edu>
5718
5724
5719 * Released 0.2.7 (mainly to publish the scoping fix).
5725 * Released 0.2.7 (mainly to publish the scoping fix).
5720
5726
5721 * IPython/Logger.py (Logger.logstate): added. A corresponding
5727 * IPython/Logger.py (Logger.logstate): added. A corresponding
5722 @logstate magic was created.
5728 @logstate magic was created.
5723
5729
5724 * IPython/Magic.py: fixed nested scoping problem under Python
5730 * IPython/Magic.py: fixed nested scoping problem under Python
5725 2.1.x (automagic wasn't working).
5731 2.1.x (automagic wasn't working).
5726
5732
5727 2002-02-20 Fernando Perez <fperez@colorado.edu>
5733 2002-02-20 Fernando Perez <fperez@colorado.edu>
5728
5734
5729 * Released 0.2.6.
5735 * Released 0.2.6.
5730
5736
5731 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
5737 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
5732 option so that logs can come out without any headers at all.
5738 option so that logs can come out without any headers at all.
5733
5739
5734 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
5740 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
5735 SciPy.
5741 SciPy.
5736
5742
5737 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
5743 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
5738 that embedded IPython calls don't require vars() to be explicitly
5744 that embedded IPython calls don't require vars() to be explicitly
5739 passed. Now they are extracted from the caller's frame (code
5745 passed. Now they are extracted from the caller's frame (code
5740 snatched from Eric Jones' weave). Added better documentation to
5746 snatched from Eric Jones' weave). Added better documentation to
5741 the section on embedding and the example file.
5747 the section on embedding and the example file.
5742
5748
5743 * IPython/genutils.py (page): Changed so that under emacs, it just
5749 * IPython/genutils.py (page): Changed so that under emacs, it just
5744 prints the string. You can then page up and down in the emacs
5750 prints the string. You can then page up and down in the emacs
5745 buffer itself. This is how the builtin help() works.
5751 buffer itself. This is how the builtin help() works.
5746
5752
5747 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
5753 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
5748 macro scoping: macros need to be executed in the user's namespace
5754 macro scoping: macros need to be executed in the user's namespace
5749 to work as if they had been typed by the user.
5755 to work as if they had been typed by the user.
5750
5756
5751 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
5757 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
5752 execute automatically (no need to type 'exec...'). They then
5758 execute automatically (no need to type 'exec...'). They then
5753 behave like 'true macros'. The printing system was also modified
5759 behave like 'true macros'. The printing system was also modified
5754 for this to work.
5760 for this to work.
5755
5761
5756 2002-02-19 Fernando Perez <fperez@colorado.edu>
5762 2002-02-19 Fernando Perez <fperez@colorado.edu>
5757
5763
5758 * IPython/genutils.py (page_file): new function for paging files
5764 * IPython/genutils.py (page_file): new function for paging files
5759 in an OS-independent way. Also necessary for file viewing to work
5765 in an OS-independent way. Also necessary for file viewing to work
5760 well inside Emacs buffers.
5766 well inside Emacs buffers.
5761 (page): Added checks for being in an emacs buffer.
5767 (page): Added checks for being in an emacs buffer.
5762 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
5768 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
5763 same bug in iplib.
5769 same bug in iplib.
5764
5770
5765 2002-02-18 Fernando Perez <fperez@colorado.edu>
5771 2002-02-18 Fernando Perez <fperez@colorado.edu>
5766
5772
5767 * IPython/iplib.py (InteractiveShell.init_readline): modified use
5773 * IPython/iplib.py (InteractiveShell.init_readline): modified use
5768 of readline so that IPython can work inside an Emacs buffer.
5774 of readline so that IPython can work inside an Emacs buffer.
5769
5775
5770 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
5776 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
5771 method signatures (they weren't really bugs, but it looks cleaner
5777 method signatures (they weren't really bugs, but it looks cleaner
5772 and keeps PyChecker happy).
5778 and keeps PyChecker happy).
5773
5779
5774 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
5780 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
5775 for implementing various user-defined hooks. Currently only
5781 for implementing various user-defined hooks. Currently only
5776 display is done.
5782 display is done.
5777
5783
5778 * IPython/Prompts.py (CachedOutput._display): changed display
5784 * IPython/Prompts.py (CachedOutput._display): changed display
5779 functions so that they can be dynamically changed by users easily.
5785 functions so that they can be dynamically changed by users easily.
5780
5786
5781 * IPython/Extensions/numeric_formats.py (num_display): added an
5787 * IPython/Extensions/numeric_formats.py (num_display): added an
5782 extension for printing NumPy arrays in flexible manners. It
5788 extension for printing NumPy arrays in flexible manners. It
5783 doesn't do anything yet, but all the structure is in
5789 doesn't do anything yet, but all the structure is in
5784 place. Ultimately the plan is to implement output format control
5790 place. Ultimately the plan is to implement output format control
5785 like in Octave.
5791 like in Octave.
5786
5792
5787 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
5793 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
5788 methods are found at run-time by all the automatic machinery.
5794 methods are found at run-time by all the automatic machinery.
5789
5795
5790 2002-02-17 Fernando Perez <fperez@colorado.edu>
5796 2002-02-17 Fernando Perez <fperez@colorado.edu>
5791
5797
5792 * setup_Windows.py (make_shortcut): documented. Cleaned up the
5798 * setup_Windows.py (make_shortcut): documented. Cleaned up the
5793 whole file a little.
5799 whole file a little.
5794
5800
5795 * ToDo: closed this document. Now there's a new_design.lyx
5801 * ToDo: closed this document. Now there's a new_design.lyx
5796 document for all new ideas. Added making a pdf of it for the
5802 document for all new ideas. Added making a pdf of it for the
5797 end-user distro.
5803 end-user distro.
5798
5804
5799 * IPython/Logger.py (Logger.switch_log): Created this to replace
5805 * IPython/Logger.py (Logger.switch_log): Created this to replace
5800 logon() and logoff(). It also fixes a nasty crash reported by
5806 logon() and logoff(). It also fixes a nasty crash reported by
5801 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
5807 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
5802
5808
5803 * IPython/iplib.py (complete): got auto-completion to work with
5809 * IPython/iplib.py (complete): got auto-completion to work with
5804 automagic (I had wanted this for a long time).
5810 automagic (I had wanted this for a long time).
5805
5811
5806 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
5812 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
5807 to @file, since file() is now a builtin and clashes with automagic
5813 to @file, since file() is now a builtin and clashes with automagic
5808 for @file.
5814 for @file.
5809
5815
5810 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
5816 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
5811 of this was previously in iplib, which had grown to more than 2000
5817 of this was previously in iplib, which had grown to more than 2000
5812 lines, way too long. No new functionality, but it makes managing
5818 lines, way too long. No new functionality, but it makes managing
5813 the code a bit easier.
5819 the code a bit easier.
5814
5820
5815 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
5821 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
5816 information to crash reports.
5822 information to crash reports.
5817
5823
5818 2002-02-12 Fernando Perez <fperez@colorado.edu>
5824 2002-02-12 Fernando Perez <fperez@colorado.edu>
5819
5825
5820 * Released 0.2.5.
5826 * Released 0.2.5.
5821
5827
5822 2002-02-11 Fernando Perez <fperez@colorado.edu>
5828 2002-02-11 Fernando Perez <fperez@colorado.edu>
5823
5829
5824 * Wrote a relatively complete Windows installer. It puts
5830 * Wrote a relatively complete Windows installer. It puts
5825 everything in place, creates Start Menu entries and fixes the
5831 everything in place, creates Start Menu entries and fixes the
5826 color issues. Nothing fancy, but it works.
5832 color issues. Nothing fancy, but it works.
5827
5833
5828 2002-02-10 Fernando Perez <fperez@colorado.edu>
5834 2002-02-10 Fernando Perez <fperez@colorado.edu>
5829
5835
5830 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
5836 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
5831 os.path.expanduser() call so that we can type @run ~/myfile.py and
5837 os.path.expanduser() call so that we can type @run ~/myfile.py and
5832 have thigs work as expected.
5838 have thigs work as expected.
5833
5839
5834 * IPython/genutils.py (page): fixed exception handling so things
5840 * IPython/genutils.py (page): fixed exception handling so things
5835 work both in Unix and Windows correctly. Quitting a pager triggers
5841 work both in Unix and Windows correctly. Quitting a pager triggers
5836 an IOError/broken pipe in Unix, and in windows not finding a pager
5842 an IOError/broken pipe in Unix, and in windows not finding a pager
5837 is also an IOError, so I had to actually look at the return value
5843 is also an IOError, so I had to actually look at the return value
5838 of the exception, not just the exception itself. Should be ok now.
5844 of the exception, not just the exception itself. Should be ok now.
5839
5845
5840 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
5846 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
5841 modified to allow case-insensitive color scheme changes.
5847 modified to allow case-insensitive color scheme changes.
5842
5848
5843 2002-02-09 Fernando Perez <fperez@colorado.edu>
5849 2002-02-09 Fernando Perez <fperez@colorado.edu>
5844
5850
5845 * IPython/genutils.py (native_line_ends): new function to leave
5851 * IPython/genutils.py (native_line_ends): new function to leave
5846 user config files with os-native line-endings.
5852 user config files with os-native line-endings.
5847
5853
5848 * README and manual updates.
5854 * README and manual updates.
5849
5855
5850 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
5856 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
5851 instead of StringType to catch Unicode strings.
5857 instead of StringType to catch Unicode strings.
5852
5858
5853 * IPython/genutils.py (filefind): fixed bug for paths with
5859 * IPython/genutils.py (filefind): fixed bug for paths with
5854 embedded spaces (very common in Windows).
5860 embedded spaces (very common in Windows).
5855
5861
5856 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
5862 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
5857 files under Windows, so that they get automatically associated
5863 files under Windows, so that they get automatically associated
5858 with a text editor. Windows makes it a pain to handle
5864 with a text editor. Windows makes it a pain to handle
5859 extension-less files.
5865 extension-less files.
5860
5866
5861 * IPython/iplib.py (InteractiveShell.init_readline): Made the
5867 * IPython/iplib.py (InteractiveShell.init_readline): Made the
5862 warning about readline only occur for Posix. In Windows there's no
5868 warning about readline only occur for Posix. In Windows there's no
5863 way to get readline, so why bother with the warning.
5869 way to get readline, so why bother with the warning.
5864
5870
5865 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
5871 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
5866 for __str__ instead of dir(self), since dir() changed in 2.2.
5872 for __str__ instead of dir(self), since dir() changed in 2.2.
5867
5873
5868 * Ported to Windows! Tested on XP, I suspect it should work fine
5874 * Ported to Windows! Tested on XP, I suspect it should work fine
5869 on NT/2000, but I don't think it will work on 98 et al. That
5875 on NT/2000, but I don't think it will work on 98 et al. That
5870 series of Windows is such a piece of junk anyway that I won't try
5876 series of Windows is such a piece of junk anyway that I won't try
5871 porting it there. The XP port was straightforward, showed a few
5877 porting it there. The XP port was straightforward, showed a few
5872 bugs here and there (fixed all), in particular some string
5878 bugs here and there (fixed all), in particular some string
5873 handling stuff which required considering Unicode strings (which
5879 handling stuff which required considering Unicode strings (which
5874 Windows uses). This is good, but hasn't been too tested :) No
5880 Windows uses). This is good, but hasn't been too tested :) No
5875 fancy installer yet, I'll put a note in the manual so people at
5881 fancy installer yet, I'll put a note in the manual so people at
5876 least make manually a shortcut.
5882 least make manually a shortcut.
5877
5883
5878 * IPython/iplib.py (Magic.magic_colors): Unified the color options
5884 * IPython/iplib.py (Magic.magic_colors): Unified the color options
5879 into a single one, "colors". This now controls both prompt and
5885 into a single one, "colors". This now controls both prompt and
5880 exception color schemes, and can be changed both at startup
5886 exception color schemes, and can be changed both at startup
5881 (either via command-line switches or via ipythonrc files) and at
5887 (either via command-line switches or via ipythonrc files) and at
5882 runtime, with @colors.
5888 runtime, with @colors.
5883 (Magic.magic_run): renamed @prun to @run and removed the old
5889 (Magic.magic_run): renamed @prun to @run and removed the old
5884 @run. The two were too similar to warrant keeping both.
5890 @run. The two were too similar to warrant keeping both.
5885
5891
5886 2002-02-03 Fernando Perez <fperez@colorado.edu>
5892 2002-02-03 Fernando Perez <fperez@colorado.edu>
5887
5893
5888 * IPython/iplib.py (install_first_time): Added comment on how to
5894 * IPython/iplib.py (install_first_time): Added comment on how to
5889 configure the color options for first-time users. Put a <return>
5895 configure the color options for first-time users. Put a <return>
5890 request at the end so that small-terminal users get a chance to
5896 request at the end so that small-terminal users get a chance to
5891 read the startup info.
5897 read the startup info.
5892
5898
5893 2002-01-23 Fernando Perez <fperez@colorado.edu>
5899 2002-01-23 Fernando Perez <fperez@colorado.edu>
5894
5900
5895 * IPython/iplib.py (CachedOutput.update): Changed output memory
5901 * IPython/iplib.py (CachedOutput.update): Changed output memory
5896 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
5902 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
5897 input history we still use _i. Did this b/c these variable are
5903 input history we still use _i. Did this b/c these variable are
5898 very commonly used in interactive work, so the less we need to
5904 very commonly used in interactive work, so the less we need to
5899 type the better off we are.
5905 type the better off we are.
5900 (Magic.magic_prun): updated @prun to better handle the namespaces
5906 (Magic.magic_prun): updated @prun to better handle the namespaces
5901 the file will run in, including a fix for __name__ not being set
5907 the file will run in, including a fix for __name__ not being set
5902 before.
5908 before.
5903
5909
5904 2002-01-20 Fernando Perez <fperez@colorado.edu>
5910 2002-01-20 Fernando Perez <fperez@colorado.edu>
5905
5911
5906 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
5912 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
5907 extra garbage for Python 2.2. Need to look more carefully into
5913 extra garbage for Python 2.2. Need to look more carefully into
5908 this later.
5914 this later.
5909
5915
5910 2002-01-19 Fernando Perez <fperez@colorado.edu>
5916 2002-01-19 Fernando Perez <fperez@colorado.edu>
5911
5917
5912 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
5918 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
5913 display SyntaxError exceptions properly formatted when they occur
5919 display SyntaxError exceptions properly formatted when they occur
5914 (they can be triggered by imported code).
5920 (they can be triggered by imported code).
5915
5921
5916 2002-01-18 Fernando Perez <fperez@colorado.edu>
5922 2002-01-18 Fernando Perez <fperez@colorado.edu>
5917
5923
5918 * IPython/iplib.py (InteractiveShell.safe_execfile): now
5924 * IPython/iplib.py (InteractiveShell.safe_execfile): now
5919 SyntaxError exceptions are reported nicely formatted, instead of
5925 SyntaxError exceptions are reported nicely formatted, instead of
5920 spitting out only offset information as before.
5926 spitting out only offset information as before.
5921 (Magic.magic_prun): Added the @prun function for executing
5927 (Magic.magic_prun): Added the @prun function for executing
5922 programs with command line args inside IPython.
5928 programs with command line args inside IPython.
5923
5929
5924 2002-01-16 Fernando Perez <fperez@colorado.edu>
5930 2002-01-16 Fernando Perez <fperez@colorado.edu>
5925
5931
5926 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
5932 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
5927 to *not* include the last item given in a range. This brings their
5933 to *not* include the last item given in a range. This brings their
5928 behavior in line with Python's slicing:
5934 behavior in line with Python's slicing:
5929 a[n1:n2] -> a[n1]...a[n2-1]
5935 a[n1:n2] -> a[n1]...a[n2-1]
5930 It may be a bit less convenient, but I prefer to stick to Python's
5936 It may be a bit less convenient, but I prefer to stick to Python's
5931 conventions *everywhere*, so users never have to wonder.
5937 conventions *everywhere*, so users never have to wonder.
5932 (Magic.magic_macro): Added @macro function to ease the creation of
5938 (Magic.magic_macro): Added @macro function to ease the creation of
5933 macros.
5939 macros.
5934
5940
5935 2002-01-05 Fernando Perez <fperez@colorado.edu>
5941 2002-01-05 Fernando Perez <fperez@colorado.edu>
5936
5942
5937 * Released 0.2.4.
5943 * Released 0.2.4.
5938
5944
5939 * IPython/iplib.py (Magic.magic_pdef):
5945 * IPython/iplib.py (Magic.magic_pdef):
5940 (InteractiveShell.safe_execfile): report magic lines and error
5946 (InteractiveShell.safe_execfile): report magic lines and error
5941 lines without line numbers so one can easily copy/paste them for
5947 lines without line numbers so one can easily copy/paste them for
5942 re-execution.
5948 re-execution.
5943
5949
5944 * Updated manual with recent changes.
5950 * Updated manual with recent changes.
5945
5951
5946 * IPython/iplib.py (Magic.magic_oinfo): added constructor
5952 * IPython/iplib.py (Magic.magic_oinfo): added constructor
5947 docstring printing when class? is called. Very handy for knowing
5953 docstring printing when class? is called. Very handy for knowing
5948 how to create class instances (as long as __init__ is well
5954 how to create class instances (as long as __init__ is well
5949 documented, of course :)
5955 documented, of course :)
5950 (Magic.magic_doc): print both class and constructor docstrings.
5956 (Magic.magic_doc): print both class and constructor docstrings.
5951 (Magic.magic_pdef): give constructor info if passed a class and
5957 (Magic.magic_pdef): give constructor info if passed a class and
5952 __call__ info for callable object instances.
5958 __call__ info for callable object instances.
5953
5959
5954 2002-01-04 Fernando Perez <fperez@colorado.edu>
5960 2002-01-04 Fernando Perez <fperez@colorado.edu>
5955
5961
5956 * Made deep_reload() off by default. It doesn't always work
5962 * Made deep_reload() off by default. It doesn't always work
5957 exactly as intended, so it's probably safer to have it off. It's
5963 exactly as intended, so it's probably safer to have it off. It's
5958 still available as dreload() anyway, so nothing is lost.
5964 still available as dreload() anyway, so nothing is lost.
5959
5965
5960 2002-01-02 Fernando Perez <fperez@colorado.edu>
5966 2002-01-02 Fernando Perez <fperez@colorado.edu>
5961
5967
5962 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
5968 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
5963 so I wanted an updated release).
5969 so I wanted an updated release).
5964
5970
5965 2001-12-27 Fernando Perez <fperez@colorado.edu>
5971 2001-12-27 Fernando Perez <fperez@colorado.edu>
5966
5972
5967 * IPython/iplib.py (InteractiveShell.interact): Added the original
5973 * IPython/iplib.py (InteractiveShell.interact): Added the original
5968 code from 'code.py' for this module in order to change the
5974 code from 'code.py' for this module in order to change the
5969 handling of a KeyboardInterrupt. This was necessary b/c otherwise
5975 handling of a KeyboardInterrupt. This was necessary b/c otherwise
5970 the history cache would break when the user hit Ctrl-C, and
5976 the history cache would break when the user hit Ctrl-C, and
5971 interact() offers no way to add any hooks to it.
5977 interact() offers no way to add any hooks to it.
5972
5978
5973 2001-12-23 Fernando Perez <fperez@colorado.edu>
5979 2001-12-23 Fernando Perez <fperez@colorado.edu>
5974
5980
5975 * setup.py: added check for 'MANIFEST' before trying to remove
5981 * setup.py: added check for 'MANIFEST' before trying to remove
5976 it. Thanks to Sean Reifschneider.
5982 it. Thanks to Sean Reifschneider.
5977
5983
5978 2001-12-22 Fernando Perez <fperez@colorado.edu>
5984 2001-12-22 Fernando Perez <fperez@colorado.edu>
5979
5985
5980 * Released 0.2.2.
5986 * Released 0.2.2.
5981
5987
5982 * Finished (reasonably) writing the manual. Later will add the
5988 * Finished (reasonably) writing the manual. Later will add the
5983 python-standard navigation stylesheets, but for the time being
5989 python-standard navigation stylesheets, but for the time being
5984 it's fairly complete. Distribution will include html and pdf
5990 it's fairly complete. Distribution will include html and pdf
5985 versions.
5991 versions.
5986
5992
5987 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
5993 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
5988 (MayaVi author).
5994 (MayaVi author).
5989
5995
5990 2001-12-21 Fernando Perez <fperez@colorado.edu>
5996 2001-12-21 Fernando Perez <fperez@colorado.edu>
5991
5997
5992 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
5998 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
5993 good public release, I think (with the manual and the distutils
5999 good public release, I think (with the manual and the distutils
5994 installer). The manual can use some work, but that can go
6000 installer). The manual can use some work, but that can go
5995 slowly. Otherwise I think it's quite nice for end users. Next
6001 slowly. Otherwise I think it's quite nice for end users. Next
5996 summer, rewrite the guts of it...
6002 summer, rewrite the guts of it...
5997
6003
5998 * Changed format of ipythonrc files to use whitespace as the
6004 * Changed format of ipythonrc files to use whitespace as the
5999 separator instead of an explicit '='. Cleaner.
6005 separator instead of an explicit '='. Cleaner.
6000
6006
6001 2001-12-20 Fernando Perez <fperez@colorado.edu>
6007 2001-12-20 Fernando Perez <fperez@colorado.edu>
6002
6008
6003 * Started a manual in LyX. For now it's just a quick merge of the
6009 * Started a manual in LyX. For now it's just a quick merge of the
6004 various internal docstrings and READMEs. Later it may grow into a
6010 various internal docstrings and READMEs. Later it may grow into a
6005 nice, full-blown manual.
6011 nice, full-blown manual.
6006
6012
6007 * Set up a distutils based installer. Installation should now be
6013 * Set up a distutils based installer. Installation should now be
6008 trivially simple for end-users.
6014 trivially simple for end-users.
6009
6015
6010 2001-12-11 Fernando Perez <fperez@colorado.edu>
6016 2001-12-11 Fernando Perez <fperez@colorado.edu>
6011
6017
6012 * Released 0.2.0. First public release, announced it at
6018 * Released 0.2.0. First public release, announced it at
6013 comp.lang.python. From now on, just bugfixes...
6019 comp.lang.python. From now on, just bugfixes...
6014
6020
6015 * Went through all the files, set copyright/license notices and
6021 * Went through all the files, set copyright/license notices and
6016 cleaned up things. Ready for release.
6022 cleaned up things. Ready for release.
6017
6023
6018 2001-12-10 Fernando Perez <fperez@colorado.edu>
6024 2001-12-10 Fernando Perez <fperez@colorado.edu>
6019
6025
6020 * Changed the first-time installer not to use tarfiles. It's more
6026 * Changed the first-time installer not to use tarfiles. It's more
6021 robust now and less unix-dependent. Also makes it easier for
6027 robust now and less unix-dependent. Also makes it easier for
6022 people to later upgrade versions.
6028 people to later upgrade versions.
6023
6029
6024 * Changed @exit to @abort to reflect the fact that it's pretty
6030 * Changed @exit to @abort to reflect the fact that it's pretty
6025 brutal (a sys.exit()). The difference between @abort and Ctrl-D
6031 brutal (a sys.exit()). The difference between @abort and Ctrl-D
6026 becomes significant only when IPyhton is embedded: in that case,
6032 becomes significant only when IPyhton is embedded: in that case,
6027 C-D closes IPython only, but @abort kills the enclosing program
6033 C-D closes IPython only, but @abort kills the enclosing program
6028 too (unless it had called IPython inside a try catching
6034 too (unless it had called IPython inside a try catching
6029 SystemExit).
6035 SystemExit).
6030
6036
6031 * Created Shell module which exposes the actuall IPython Shell
6037 * Created Shell module which exposes the actuall IPython Shell
6032 classes, currently the normal and the embeddable one. This at
6038 classes, currently the normal and the embeddable one. This at
6033 least offers a stable interface we won't need to change when
6039 least offers a stable interface we won't need to change when
6034 (later) the internals are rewritten. That rewrite will be confined
6040 (later) the internals are rewritten. That rewrite will be confined
6035 to iplib and ipmaker, but the Shell interface should remain as is.
6041 to iplib and ipmaker, but the Shell interface should remain as is.
6036
6042
6037 * Added embed module which offers an embeddable IPShell object,
6043 * Added embed module which offers an embeddable IPShell object,
6038 useful to fire up IPython *inside* a running program. Great for
6044 useful to fire up IPython *inside* a running program. Great for
6039 debugging or dynamical data analysis.
6045 debugging or dynamical data analysis.
6040
6046
6041 2001-12-08 Fernando Perez <fperez@colorado.edu>
6047 2001-12-08 Fernando Perez <fperez@colorado.edu>
6042
6048
6043 * Fixed small bug preventing seeing info from methods of defined
6049 * Fixed small bug preventing seeing info from methods of defined
6044 objects (incorrect namespace in _ofind()).
6050 objects (incorrect namespace in _ofind()).
6045
6051
6046 * Documentation cleanup. Moved the main usage docstrings to a
6052 * Documentation cleanup. Moved the main usage docstrings to a
6047 separate file, usage.py (cleaner to maintain, and hopefully in the
6053 separate file, usage.py (cleaner to maintain, and hopefully in the
6048 future some perlpod-like way of producing interactive, man and
6054 future some perlpod-like way of producing interactive, man and
6049 html docs out of it will be found).
6055 html docs out of it will be found).
6050
6056
6051 * Added @profile to see your profile at any time.
6057 * Added @profile to see your profile at any time.
6052
6058
6053 * Added @p as an alias for 'print'. It's especially convenient if
6059 * Added @p as an alias for 'print'. It's especially convenient if
6054 using automagic ('p x' prints x).
6060 using automagic ('p x' prints x).
6055
6061
6056 * Small cleanups and fixes after a pychecker run.
6062 * Small cleanups and fixes after a pychecker run.
6057
6063
6058 * Changed the @cd command to handle @cd - and @cd -<n> for
6064 * Changed the @cd command to handle @cd - and @cd -<n> for
6059 visiting any directory in _dh.
6065 visiting any directory in _dh.
6060
6066
6061 * Introduced _dh, a history of visited directories. @dhist prints
6067 * Introduced _dh, a history of visited directories. @dhist prints
6062 it out with numbers.
6068 it out with numbers.
6063
6069
6064 2001-12-07 Fernando Perez <fperez@colorado.edu>
6070 2001-12-07 Fernando Perez <fperez@colorado.edu>
6065
6071
6066 * Released 0.1.22
6072 * Released 0.1.22
6067
6073
6068 * Made initialization a bit more robust against invalid color
6074 * Made initialization a bit more robust against invalid color
6069 options in user input (exit, not traceback-crash).
6075 options in user input (exit, not traceback-crash).
6070
6076
6071 * Changed the bug crash reporter to write the report only in the
6077 * Changed the bug crash reporter to write the report only in the
6072 user's .ipython directory. That way IPython won't litter people's
6078 user's .ipython directory. That way IPython won't litter people's
6073 hard disks with crash files all over the place. Also print on
6079 hard disks with crash files all over the place. Also print on
6074 screen the necessary mail command.
6080 screen the necessary mail command.
6075
6081
6076 * With the new ultraTB, implemented LightBG color scheme for light
6082 * With the new ultraTB, implemented LightBG color scheme for light
6077 background terminals. A lot of people like white backgrounds, so I
6083 background terminals. A lot of people like white backgrounds, so I
6078 guess we should at least give them something readable.
6084 guess we should at least give them something readable.
6079
6085
6080 2001-12-06 Fernando Perez <fperez@colorado.edu>
6086 2001-12-06 Fernando Perez <fperez@colorado.edu>
6081
6087
6082 * Modified the structure of ultraTB. Now there's a proper class
6088 * Modified the structure of ultraTB. Now there's a proper class
6083 for tables of color schemes which allow adding schemes easily and
6089 for tables of color schemes which allow adding schemes easily and
6084 switching the active scheme without creating a new instance every
6090 switching the active scheme without creating a new instance every
6085 time (which was ridiculous). The syntax for creating new schemes
6091 time (which was ridiculous). The syntax for creating new schemes
6086 is also cleaner. I think ultraTB is finally done, with a clean
6092 is also cleaner. I think ultraTB is finally done, with a clean
6087 class structure. Names are also much cleaner (now there's proper
6093 class structure. Names are also much cleaner (now there's proper
6088 color tables, no need for every variable to also have 'color' in
6094 color tables, no need for every variable to also have 'color' in
6089 its name).
6095 its name).
6090
6096
6091 * Broke down genutils into separate files. Now genutils only
6097 * Broke down genutils into separate files. Now genutils only
6092 contains utility functions, and classes have been moved to their
6098 contains utility functions, and classes have been moved to their
6093 own files (they had enough independent functionality to warrant
6099 own files (they had enough independent functionality to warrant
6094 it): ConfigLoader, OutputTrap, Struct.
6100 it): ConfigLoader, OutputTrap, Struct.
6095
6101
6096 2001-12-05 Fernando Perez <fperez@colorado.edu>
6102 2001-12-05 Fernando Perez <fperez@colorado.edu>
6097
6103
6098 * IPython turns 21! Released version 0.1.21, as a candidate for
6104 * IPython turns 21! Released version 0.1.21, as a candidate for
6099 public consumption. If all goes well, release in a few days.
6105 public consumption. If all goes well, release in a few days.
6100
6106
6101 * Fixed path bug (files in Extensions/ directory wouldn't be found
6107 * Fixed path bug (files in Extensions/ directory wouldn't be found
6102 unless IPython/ was explicitly in sys.path).
6108 unless IPython/ was explicitly in sys.path).
6103
6109
6104 * Extended the FlexCompleter class as MagicCompleter to allow
6110 * Extended the FlexCompleter class as MagicCompleter to allow
6105 completion of @-starting lines.
6111 completion of @-starting lines.
6106
6112
6107 * Created __release__.py file as a central repository for release
6113 * Created __release__.py file as a central repository for release
6108 info that other files can read from.
6114 info that other files can read from.
6109
6115
6110 * Fixed small bug in logging: when logging was turned on in
6116 * Fixed small bug in logging: when logging was turned on in
6111 mid-session, old lines with special meanings (!@?) were being
6117 mid-session, old lines with special meanings (!@?) were being
6112 logged without the prepended comment, which is necessary since
6118 logged without the prepended comment, which is necessary since
6113 they are not truly valid python syntax. This should make session
6119 they are not truly valid python syntax. This should make session
6114 restores produce less errors.
6120 restores produce less errors.
6115
6121
6116 * The namespace cleanup forced me to make a FlexCompleter class
6122 * The namespace cleanup forced me to make a FlexCompleter class
6117 which is nothing but a ripoff of rlcompleter, but with selectable
6123 which is nothing but a ripoff of rlcompleter, but with selectable
6118 namespace (rlcompleter only works in __main__.__dict__). I'll try
6124 namespace (rlcompleter only works in __main__.__dict__). I'll try
6119 to submit a note to the authors to see if this change can be
6125 to submit a note to the authors to see if this change can be
6120 incorporated in future rlcompleter releases (Dec.6: done)
6126 incorporated in future rlcompleter releases (Dec.6: done)
6121
6127
6122 * More fixes to namespace handling. It was a mess! Now all
6128 * More fixes to namespace handling. It was a mess! Now all
6123 explicit references to __main__.__dict__ are gone (except when
6129 explicit references to __main__.__dict__ are gone (except when
6124 really needed) and everything is handled through the namespace
6130 really needed) and everything is handled through the namespace
6125 dicts in the IPython instance. We seem to be getting somewhere
6131 dicts in the IPython instance. We seem to be getting somewhere
6126 with this, finally...
6132 with this, finally...
6127
6133
6128 * Small documentation updates.
6134 * Small documentation updates.
6129
6135
6130 * Created the Extensions directory under IPython (with an
6136 * Created the Extensions directory under IPython (with an
6131 __init__.py). Put the PhysicalQ stuff there. This directory should
6137 __init__.py). Put the PhysicalQ stuff there. This directory should
6132 be used for all special-purpose extensions.
6138 be used for all special-purpose extensions.
6133
6139
6134 * File renaming:
6140 * File renaming:
6135 ipythonlib --> ipmaker
6141 ipythonlib --> ipmaker
6136 ipplib --> iplib
6142 ipplib --> iplib
6137 This makes a bit more sense in terms of what these files actually do.
6143 This makes a bit more sense in terms of what these files actually do.
6138
6144
6139 * Moved all the classes and functions in ipythonlib to ipplib, so
6145 * Moved all the classes and functions in ipythonlib to ipplib, so
6140 now ipythonlib only has make_IPython(). This will ease up its
6146 now ipythonlib only has make_IPython(). This will ease up its
6141 splitting in smaller functional chunks later.
6147 splitting in smaller functional chunks later.
6142
6148
6143 * Cleaned up (done, I think) output of @whos. Better column
6149 * Cleaned up (done, I think) output of @whos. Better column
6144 formatting, and now shows str(var) for as much as it can, which is
6150 formatting, and now shows str(var) for as much as it can, which is
6145 typically what one gets with a 'print var'.
6151 typically what one gets with a 'print var'.
6146
6152
6147 2001-12-04 Fernando Perez <fperez@colorado.edu>
6153 2001-12-04 Fernando Perez <fperez@colorado.edu>
6148
6154
6149 * Fixed namespace problems. Now builtin/IPyhton/user names get
6155 * Fixed namespace problems. Now builtin/IPyhton/user names get
6150 properly reported in their namespace. Internal namespace handling
6156 properly reported in their namespace. Internal namespace handling
6151 is finally getting decent (not perfect yet, but much better than
6157 is finally getting decent (not perfect yet, but much better than
6152 the ad-hoc mess we had).
6158 the ad-hoc mess we had).
6153
6159
6154 * Removed -exit option. If people just want to run a python
6160 * Removed -exit option. If people just want to run a python
6155 script, that's what the normal interpreter is for. Less
6161 script, that's what the normal interpreter is for. Less
6156 unnecessary options, less chances for bugs.
6162 unnecessary options, less chances for bugs.
6157
6163
6158 * Added a crash handler which generates a complete post-mortem if
6164 * Added a crash handler which generates a complete post-mortem if
6159 IPython crashes. This will help a lot in tracking bugs down the
6165 IPython crashes. This will help a lot in tracking bugs down the
6160 road.
6166 road.
6161
6167
6162 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
6168 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
6163 which were boud to functions being reassigned would bypass the
6169 which were boud to functions being reassigned would bypass the
6164 logger, breaking the sync of _il with the prompt counter. This
6170 logger, breaking the sync of _il with the prompt counter. This
6165 would then crash IPython later when a new line was logged.
6171 would then crash IPython later when a new line was logged.
6166
6172
6167 2001-12-02 Fernando Perez <fperez@colorado.edu>
6173 2001-12-02 Fernando Perez <fperez@colorado.edu>
6168
6174
6169 * Made IPython a package. This means people don't have to clutter
6175 * Made IPython a package. This means people don't have to clutter
6170 their sys.path with yet another directory. Changed the INSTALL
6176 their sys.path with yet another directory. Changed the INSTALL
6171 file accordingly.
6177 file accordingly.
6172
6178
6173 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
6179 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
6174 sorts its output (so @who shows it sorted) and @whos formats the
6180 sorts its output (so @who shows it sorted) and @whos formats the
6175 table according to the width of the first column. Nicer, easier to
6181 table according to the width of the first column. Nicer, easier to
6176 read. Todo: write a generic table_format() which takes a list of
6182 read. Todo: write a generic table_format() which takes a list of
6177 lists and prints it nicely formatted, with optional row/column
6183 lists and prints it nicely formatted, with optional row/column
6178 separators and proper padding and justification.
6184 separators and proper padding and justification.
6179
6185
6180 * Released 0.1.20
6186 * Released 0.1.20
6181
6187
6182 * Fixed bug in @log which would reverse the inputcache list (a
6188 * Fixed bug in @log which would reverse the inputcache list (a
6183 copy operation was missing).
6189 copy operation was missing).
6184
6190
6185 * Code cleanup. @config was changed to use page(). Better, since
6191 * Code cleanup. @config was changed to use page(). Better, since
6186 its output is always quite long.
6192 its output is always quite long.
6187
6193
6188 * Itpl is back as a dependency. I was having too many problems
6194 * Itpl is back as a dependency. I was having too many problems
6189 getting the parametric aliases to work reliably, and it's just
6195 getting the parametric aliases to work reliably, and it's just
6190 easier to code weird string operations with it than playing %()s
6196 easier to code weird string operations with it than playing %()s
6191 games. It's only ~6k, so I don't think it's too big a deal.
6197 games. It's only ~6k, so I don't think it's too big a deal.
6192
6198
6193 * Found (and fixed) a very nasty bug with history. !lines weren't
6199 * Found (and fixed) a very nasty bug with history. !lines weren't
6194 getting cached, and the out of sync caches would crash
6200 getting cached, and the out of sync caches would crash
6195 IPython. Fixed it by reorganizing the prefilter/handlers/logger
6201 IPython. Fixed it by reorganizing the prefilter/handlers/logger
6196 division of labor a bit better. Bug fixed, cleaner structure.
6202 division of labor a bit better. Bug fixed, cleaner structure.
6197
6203
6198 2001-12-01 Fernando Perez <fperez@colorado.edu>
6204 2001-12-01 Fernando Perez <fperez@colorado.edu>
6199
6205
6200 * Released 0.1.19
6206 * Released 0.1.19
6201
6207
6202 * Added option -n to @hist to prevent line number printing. Much
6208 * Added option -n to @hist to prevent line number printing. Much
6203 easier to copy/paste code this way.
6209 easier to copy/paste code this way.
6204
6210
6205 * Created global _il to hold the input list. Allows easy
6211 * Created global _il to hold the input list. Allows easy
6206 re-execution of blocks of code by slicing it (inspired by Janko's
6212 re-execution of blocks of code by slicing it (inspired by Janko's
6207 comment on 'macros').
6213 comment on 'macros').
6208
6214
6209 * Small fixes and doc updates.
6215 * Small fixes and doc updates.
6210
6216
6211 * Rewrote @history function (was @h). Renamed it to @hist, @h is
6217 * Rewrote @history function (was @h). Renamed it to @hist, @h is
6212 much too fragile with automagic. Handles properly multi-line
6218 much too fragile with automagic. Handles properly multi-line
6213 statements and takes parameters.
6219 statements and takes parameters.
6214
6220
6215 2001-11-30 Fernando Perez <fperez@colorado.edu>
6221 2001-11-30 Fernando Perez <fperez@colorado.edu>
6216
6222
6217 * Version 0.1.18 released.
6223 * Version 0.1.18 released.
6218
6224
6219 * Fixed nasty namespace bug in initial module imports.
6225 * Fixed nasty namespace bug in initial module imports.
6220
6226
6221 * Added copyright/license notes to all code files (except
6227 * Added copyright/license notes to all code files (except
6222 DPyGetOpt). For the time being, LGPL. That could change.
6228 DPyGetOpt). For the time being, LGPL. That could change.
6223
6229
6224 * Rewrote a much nicer README, updated INSTALL, cleaned up
6230 * Rewrote a much nicer README, updated INSTALL, cleaned up
6225 ipythonrc-* samples.
6231 ipythonrc-* samples.
6226
6232
6227 * Overall code/documentation cleanup. Basically ready for
6233 * Overall code/documentation cleanup. Basically ready for
6228 release. Only remaining thing: licence decision (LGPL?).
6234 release. Only remaining thing: licence decision (LGPL?).
6229
6235
6230 * Converted load_config to a class, ConfigLoader. Now recursion
6236 * Converted load_config to a class, ConfigLoader. Now recursion
6231 control is better organized. Doesn't include the same file twice.
6237 control is better organized. Doesn't include the same file twice.
6232
6238
6233 2001-11-29 Fernando Perez <fperez@colorado.edu>
6239 2001-11-29 Fernando Perez <fperez@colorado.edu>
6234
6240
6235 * Got input history working. Changed output history variables from
6241 * Got input history working. Changed output history variables from
6236 _p to _o so that _i is for input and _o for output. Just cleaner
6242 _p to _o so that _i is for input and _o for output. Just cleaner
6237 convention.
6243 convention.
6238
6244
6239 * Implemented parametric aliases. This pretty much allows the
6245 * Implemented parametric aliases. This pretty much allows the
6240 alias system to offer full-blown shell convenience, I think.
6246 alias system to offer full-blown shell convenience, I think.
6241
6247
6242 * Version 0.1.17 released, 0.1.18 opened.
6248 * Version 0.1.17 released, 0.1.18 opened.
6243
6249
6244 * dot_ipython/ipythonrc (alias): added documentation.
6250 * dot_ipython/ipythonrc (alias): added documentation.
6245 (xcolor): Fixed small bug (xcolors -> xcolor)
6251 (xcolor): Fixed small bug (xcolors -> xcolor)
6246
6252
6247 * Changed the alias system. Now alias is a magic command to define
6253 * Changed the alias system. Now alias is a magic command to define
6248 aliases just like the shell. Rationale: the builtin magics should
6254 aliases just like the shell. Rationale: the builtin magics should
6249 be there for things deeply connected to IPython's
6255 be there for things deeply connected to IPython's
6250 architecture. And this is a much lighter system for what I think
6256 architecture. And this is a much lighter system for what I think
6251 is the really important feature: allowing users to define quickly
6257 is the really important feature: allowing users to define quickly
6252 magics that will do shell things for them, so they can customize
6258 magics that will do shell things for them, so they can customize
6253 IPython easily to match their work habits. If someone is really
6259 IPython easily to match their work habits. If someone is really
6254 desperate to have another name for a builtin alias, they can
6260 desperate to have another name for a builtin alias, they can
6255 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
6261 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
6256 works.
6262 works.
6257
6263
6258 2001-11-28 Fernando Perez <fperez@colorado.edu>
6264 2001-11-28 Fernando Perez <fperez@colorado.edu>
6259
6265
6260 * Changed @file so that it opens the source file at the proper
6266 * Changed @file so that it opens the source file at the proper
6261 line. Since it uses less, if your EDITOR environment is
6267 line. Since it uses less, if your EDITOR environment is
6262 configured, typing v will immediately open your editor of choice
6268 configured, typing v will immediately open your editor of choice
6263 right at the line where the object is defined. Not as quick as
6269 right at the line where the object is defined. Not as quick as
6264 having a direct @edit command, but for all intents and purposes it
6270 having a direct @edit command, but for all intents and purposes it
6265 works. And I don't have to worry about writing @edit to deal with
6271 works. And I don't have to worry about writing @edit to deal with
6266 all the editors, less does that.
6272 all the editors, less does that.
6267
6273
6268 * Version 0.1.16 released, 0.1.17 opened.
6274 * Version 0.1.16 released, 0.1.17 opened.
6269
6275
6270 * Fixed some nasty bugs in the page/page_dumb combo that could
6276 * Fixed some nasty bugs in the page/page_dumb combo that could
6271 crash IPython.
6277 crash IPython.
6272
6278
6273 2001-11-27 Fernando Perez <fperez@colorado.edu>
6279 2001-11-27 Fernando Perez <fperez@colorado.edu>
6274
6280
6275 * Version 0.1.15 released, 0.1.16 opened.
6281 * Version 0.1.15 released, 0.1.16 opened.
6276
6282
6277 * Finally got ? and ?? to work for undefined things: now it's
6283 * Finally got ? and ?? to work for undefined things: now it's
6278 possible to type {}.get? and get information about the get method
6284 possible to type {}.get? and get information about the get method
6279 of dicts, or os.path? even if only os is defined (so technically
6285 of dicts, or os.path? even if only os is defined (so technically
6280 os.path isn't). Works at any level. For example, after import os,
6286 os.path isn't). Works at any level. For example, after import os,
6281 os?, os.path?, os.path.abspath? all work. This is great, took some
6287 os?, os.path?, os.path.abspath? all work. This is great, took some
6282 work in _ofind.
6288 work in _ofind.
6283
6289
6284 * Fixed more bugs with logging. The sanest way to do it was to add
6290 * Fixed more bugs with logging. The sanest way to do it was to add
6285 to @log a 'mode' parameter. Killed two in one shot (this mode
6291 to @log a 'mode' parameter. Killed two in one shot (this mode
6286 option was a request of Janko's). I think it's finally clean
6292 option was a request of Janko's). I think it's finally clean
6287 (famous last words).
6293 (famous last words).
6288
6294
6289 * Added a page_dumb() pager which does a decent job of paging on
6295 * Added a page_dumb() pager which does a decent job of paging on
6290 screen, if better things (like less) aren't available. One less
6296 screen, if better things (like less) aren't available. One less
6291 unix dependency (someday maybe somebody will port this to
6297 unix dependency (someday maybe somebody will port this to
6292 windows).
6298 windows).
6293
6299
6294 * Fixed problem in magic_log: would lock of logging out if log
6300 * Fixed problem in magic_log: would lock of logging out if log
6295 creation failed (because it would still think it had succeeded).
6301 creation failed (because it would still think it had succeeded).
6296
6302
6297 * Improved the page() function using curses to auto-detect screen
6303 * Improved the page() function using curses to auto-detect screen
6298 size. Now it can make a much better decision on whether to print
6304 size. Now it can make a much better decision on whether to print
6299 or page a string. Option screen_length was modified: a value 0
6305 or page a string. Option screen_length was modified: a value 0
6300 means auto-detect, and that's the default now.
6306 means auto-detect, and that's the default now.
6301
6307
6302 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
6308 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
6303 go out. I'll test it for a few days, then talk to Janko about
6309 go out. I'll test it for a few days, then talk to Janko about
6304 licences and announce it.
6310 licences and announce it.
6305
6311
6306 * Fixed the length of the auto-generated ---> prompt which appears
6312 * Fixed the length of the auto-generated ---> prompt which appears
6307 for auto-parens and auto-quotes. Getting this right isn't trivial,
6313 for auto-parens and auto-quotes. Getting this right isn't trivial,
6308 with all the color escapes, different prompt types and optional
6314 with all the color escapes, different prompt types and optional
6309 separators. But it seems to be working in all the combinations.
6315 separators. But it seems to be working in all the combinations.
6310
6316
6311 2001-11-26 Fernando Perez <fperez@colorado.edu>
6317 2001-11-26 Fernando Perez <fperez@colorado.edu>
6312
6318
6313 * Wrote a regexp filter to get option types from the option names
6319 * Wrote a regexp filter to get option types from the option names
6314 string. This eliminates the need to manually keep two duplicate
6320 string. This eliminates the need to manually keep two duplicate
6315 lists.
6321 lists.
6316
6322
6317 * Removed the unneeded check_option_names. Now options are handled
6323 * Removed the unneeded check_option_names. Now options are handled
6318 in a much saner manner and it's easy to visually check that things
6324 in a much saner manner and it's easy to visually check that things
6319 are ok.
6325 are ok.
6320
6326
6321 * Updated version numbers on all files I modified to carry a
6327 * Updated version numbers on all files I modified to carry a
6322 notice so Janko and Nathan have clear version markers.
6328 notice so Janko and Nathan have clear version markers.
6323
6329
6324 * Updated docstring for ultraTB with my changes. I should send
6330 * Updated docstring for ultraTB with my changes. I should send
6325 this to Nathan.
6331 this to Nathan.
6326
6332
6327 * Lots of small fixes. Ran everything through pychecker again.
6333 * Lots of small fixes. Ran everything through pychecker again.
6328
6334
6329 * Made loading of deep_reload an cmd line option. If it's not too
6335 * Made loading of deep_reload an cmd line option. If it's not too
6330 kosher, now people can just disable it. With -nodeep_reload it's
6336 kosher, now people can just disable it. With -nodeep_reload it's
6331 still available as dreload(), it just won't overwrite reload().
6337 still available as dreload(), it just won't overwrite reload().
6332
6338
6333 * Moved many options to the no| form (-opt and -noopt
6339 * Moved many options to the no| form (-opt and -noopt
6334 accepted). Cleaner.
6340 accepted). Cleaner.
6335
6341
6336 * Changed magic_log so that if called with no parameters, it uses
6342 * Changed magic_log so that if called with no parameters, it uses
6337 'rotate' mode. That way auto-generated logs aren't automatically
6343 'rotate' mode. That way auto-generated logs aren't automatically
6338 over-written. For normal logs, now a backup is made if it exists
6344 over-written. For normal logs, now a backup is made if it exists
6339 (only 1 level of backups). A new 'backup' mode was added to the
6345 (only 1 level of backups). A new 'backup' mode was added to the
6340 Logger class to support this. This was a request by Janko.
6346 Logger class to support this. This was a request by Janko.
6341
6347
6342 * Added @logoff/@logon to stop/restart an active log.
6348 * Added @logoff/@logon to stop/restart an active log.
6343
6349
6344 * Fixed a lot of bugs in log saving/replay. It was pretty
6350 * Fixed a lot of bugs in log saving/replay. It was pretty
6345 broken. Now special lines (!@,/) appear properly in the command
6351 broken. Now special lines (!@,/) appear properly in the command
6346 history after a log replay.
6352 history after a log replay.
6347
6353
6348 * Tried and failed to implement full session saving via pickle. My
6354 * Tried and failed to implement full session saving via pickle. My
6349 idea was to pickle __main__.__dict__, but modules can't be
6355 idea was to pickle __main__.__dict__, but modules can't be
6350 pickled. This would be a better alternative to replaying logs, but
6356 pickled. This would be a better alternative to replaying logs, but
6351 seems quite tricky to get to work. Changed -session to be called
6357 seems quite tricky to get to work. Changed -session to be called
6352 -logplay, which more accurately reflects what it does. And if we
6358 -logplay, which more accurately reflects what it does. And if we
6353 ever get real session saving working, -session is now available.
6359 ever get real session saving working, -session is now available.
6354
6360
6355 * Implemented color schemes for prompts also. As for tracebacks,
6361 * Implemented color schemes for prompts also. As for tracebacks,
6356 currently only NoColor and Linux are supported. But now the
6362 currently only NoColor and Linux are supported. But now the
6357 infrastructure is in place, based on a generic ColorScheme
6363 infrastructure is in place, based on a generic ColorScheme
6358 class. So writing and activating new schemes both for the prompts
6364 class. So writing and activating new schemes both for the prompts
6359 and the tracebacks should be straightforward.
6365 and the tracebacks should be straightforward.
6360
6366
6361 * Version 0.1.13 released, 0.1.14 opened.
6367 * Version 0.1.13 released, 0.1.14 opened.
6362
6368
6363 * Changed handling of options for output cache. Now counter is
6369 * Changed handling of options for output cache. Now counter is
6364 hardwired starting at 1 and one specifies the maximum number of
6370 hardwired starting at 1 and one specifies the maximum number of
6365 entries *in the outcache* (not the max prompt counter). This is
6371 entries *in the outcache* (not the max prompt counter). This is
6366 much better, since many statements won't increase the cache
6372 much better, since many statements won't increase the cache
6367 count. It also eliminated some confusing options, now there's only
6373 count. It also eliminated some confusing options, now there's only
6368 one: cache_size.
6374 one: cache_size.
6369
6375
6370 * Added 'alias' magic function and magic_alias option in the
6376 * Added 'alias' magic function and magic_alias option in the
6371 ipythonrc file. Now the user can easily define whatever names he
6377 ipythonrc file. Now the user can easily define whatever names he
6372 wants for the magic functions without having to play weird
6378 wants for the magic functions without having to play weird
6373 namespace games. This gives IPython a real shell-like feel.
6379 namespace games. This gives IPython a real shell-like feel.
6374
6380
6375 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
6381 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
6376 @ or not).
6382 @ or not).
6377
6383
6378 This was one of the last remaining 'visible' bugs (that I know
6384 This was one of the last remaining 'visible' bugs (that I know
6379 of). I think if I can clean up the session loading so it works
6385 of). I think if I can clean up the session loading so it works
6380 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
6386 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
6381 about licensing).
6387 about licensing).
6382
6388
6383 2001-11-25 Fernando Perez <fperez@colorado.edu>
6389 2001-11-25 Fernando Perez <fperez@colorado.edu>
6384
6390
6385 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
6391 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
6386 there's a cleaner distinction between what ? and ?? show.
6392 there's a cleaner distinction between what ? and ?? show.
6387
6393
6388 * Added screen_length option. Now the user can define his own
6394 * Added screen_length option. Now the user can define his own
6389 screen size for page() operations.
6395 screen size for page() operations.
6390
6396
6391 * Implemented magic shell-like functions with automatic code
6397 * Implemented magic shell-like functions with automatic code
6392 generation. Now adding another function is just a matter of adding
6398 generation. Now adding another function is just a matter of adding
6393 an entry to a dict, and the function is dynamically generated at
6399 an entry to a dict, and the function is dynamically generated at
6394 run-time. Python has some really cool features!
6400 run-time. Python has some really cool features!
6395
6401
6396 * Renamed many options to cleanup conventions a little. Now all
6402 * Renamed many options to cleanup conventions a little. Now all
6397 are lowercase, and only underscores where needed. Also in the code
6403 are lowercase, and only underscores where needed. Also in the code
6398 option name tables are clearer.
6404 option name tables are clearer.
6399
6405
6400 * Changed prompts a little. Now input is 'In [n]:' instead of
6406 * Changed prompts a little. Now input is 'In [n]:' instead of
6401 'In[n]:='. This allows it the numbers to be aligned with the
6407 'In[n]:='. This allows it the numbers to be aligned with the
6402 Out[n] numbers, and removes usage of ':=' which doesn't exist in
6408 Out[n] numbers, and removes usage of ':=' which doesn't exist in
6403 Python (it was a Mathematica thing). The '...' continuation prompt
6409 Python (it was a Mathematica thing). The '...' continuation prompt
6404 was also changed a little to align better.
6410 was also changed a little to align better.
6405
6411
6406 * Fixed bug when flushing output cache. Not all _p<n> variables
6412 * Fixed bug when flushing output cache. Not all _p<n> variables
6407 exist, so their deletion needs to be wrapped in a try:
6413 exist, so their deletion needs to be wrapped in a try:
6408
6414
6409 * Figured out how to properly use inspect.formatargspec() (it
6415 * Figured out how to properly use inspect.formatargspec() (it
6410 requires the args preceded by *). So I removed all the code from
6416 requires the args preceded by *). So I removed all the code from
6411 _get_pdef in Magic, which was just replicating that.
6417 _get_pdef in Magic, which was just replicating that.
6412
6418
6413 * Added test to prefilter to allow redefining magic function names
6419 * Added test to prefilter to allow redefining magic function names
6414 as variables. This is ok, since the @ form is always available,
6420 as variables. This is ok, since the @ form is always available,
6415 but whe should allow the user to define a variable called 'ls' if
6421 but whe should allow the user to define a variable called 'ls' if
6416 he needs it.
6422 he needs it.
6417
6423
6418 * Moved the ToDo information from README into a separate ToDo.
6424 * Moved the ToDo information from README into a separate ToDo.
6419
6425
6420 * General code cleanup and small bugfixes. I think it's close to a
6426 * General code cleanup and small bugfixes. I think it's close to a
6421 state where it can be released, obviously with a big 'beta'
6427 state where it can be released, obviously with a big 'beta'
6422 warning on it.
6428 warning on it.
6423
6429
6424 * Got the magic function split to work. Now all magics are defined
6430 * Got the magic function split to work. Now all magics are defined
6425 in a separate class. It just organizes things a bit, and now
6431 in a separate class. It just organizes things a bit, and now
6426 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
6432 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
6427 was too long).
6433 was too long).
6428
6434
6429 * Changed @clear to @reset to avoid potential confusions with
6435 * Changed @clear to @reset to avoid potential confusions with
6430 the shell command clear. Also renamed @cl to @clear, which does
6436 the shell command clear. Also renamed @cl to @clear, which does
6431 exactly what people expect it to from their shell experience.
6437 exactly what people expect it to from their shell experience.
6432
6438
6433 Added a check to the @reset command (since it's so
6439 Added a check to the @reset command (since it's so
6434 destructive, it's probably a good idea to ask for confirmation).
6440 destructive, it's probably a good idea to ask for confirmation).
6435 But now reset only works for full namespace resetting. Since the
6441 But now reset only works for full namespace resetting. Since the
6436 del keyword is already there for deleting a few specific
6442 del keyword is already there for deleting a few specific
6437 variables, I don't see the point of having a redundant magic
6443 variables, I don't see the point of having a redundant magic
6438 function for the same task.
6444 function for the same task.
6439
6445
6440 2001-11-24 Fernando Perez <fperez@colorado.edu>
6446 2001-11-24 Fernando Perez <fperez@colorado.edu>
6441
6447
6442 * Updated the builtin docs (esp. the ? ones).
6448 * Updated the builtin docs (esp. the ? ones).
6443
6449
6444 * Ran all the code through pychecker. Not terribly impressed with
6450 * Ran all the code through pychecker. Not terribly impressed with
6445 it: lots of spurious warnings and didn't really find anything of
6451 it: lots of spurious warnings and didn't really find anything of
6446 substance (just a few modules being imported and not used).
6452 substance (just a few modules being imported and not used).
6447
6453
6448 * Implemented the new ultraTB functionality into IPython. New
6454 * Implemented the new ultraTB functionality into IPython. New
6449 option: xcolors. This chooses color scheme. xmode now only selects
6455 option: xcolors. This chooses color scheme. xmode now only selects
6450 between Plain and Verbose. Better orthogonality.
6456 between Plain and Verbose. Better orthogonality.
6451
6457
6452 * Large rewrite of ultraTB. Much cleaner now, with a separation of
6458 * Large rewrite of ultraTB. Much cleaner now, with a separation of
6453 mode and color scheme for the exception handlers. Now it's
6459 mode and color scheme for the exception handlers. Now it's
6454 possible to have the verbose traceback with no coloring.
6460 possible to have the verbose traceback with no coloring.
6455
6461
6456 2001-11-23 Fernando Perez <fperez@colorado.edu>
6462 2001-11-23 Fernando Perez <fperez@colorado.edu>
6457
6463
6458 * Version 0.1.12 released, 0.1.13 opened.
6464 * Version 0.1.12 released, 0.1.13 opened.
6459
6465
6460 * Removed option to set auto-quote and auto-paren escapes by
6466 * Removed option to set auto-quote and auto-paren escapes by
6461 user. The chances of breaking valid syntax are just too high. If
6467 user. The chances of breaking valid syntax are just too high. If
6462 someone *really* wants, they can always dig into the code.
6468 someone *really* wants, they can always dig into the code.
6463
6469
6464 * Made prompt separators configurable.
6470 * Made prompt separators configurable.
6465
6471
6466 2001-11-22 Fernando Perez <fperez@colorado.edu>
6472 2001-11-22 Fernando Perez <fperez@colorado.edu>
6467
6473
6468 * Small bugfixes in many places.
6474 * Small bugfixes in many places.
6469
6475
6470 * Removed the MyCompleter class from ipplib. It seemed redundant
6476 * Removed the MyCompleter class from ipplib. It seemed redundant
6471 with the C-p,C-n history search functionality. Less code to
6477 with the C-p,C-n history search functionality. Less code to
6472 maintain.
6478 maintain.
6473
6479
6474 * Moved all the original ipython.py code into ipythonlib.py. Right
6480 * Moved all the original ipython.py code into ipythonlib.py. Right
6475 now it's just one big dump into a function called make_IPython, so
6481 now it's just one big dump into a function called make_IPython, so
6476 no real modularity has been gained. But at least it makes the
6482 no real modularity has been gained. But at least it makes the
6477 wrapper script tiny, and since ipythonlib is a module, it gets
6483 wrapper script tiny, and since ipythonlib is a module, it gets
6478 compiled and startup is much faster.
6484 compiled and startup is much faster.
6479
6485
6480 This is a reasobably 'deep' change, so we should test it for a
6486 This is a reasobably 'deep' change, so we should test it for a
6481 while without messing too much more with the code.
6487 while without messing too much more with the code.
6482
6488
6483 2001-11-21 Fernando Perez <fperez@colorado.edu>
6489 2001-11-21 Fernando Perez <fperez@colorado.edu>
6484
6490
6485 * Version 0.1.11 released, 0.1.12 opened for further work.
6491 * Version 0.1.11 released, 0.1.12 opened for further work.
6486
6492
6487 * Removed dependency on Itpl. It was only needed in one place. It
6493 * Removed dependency on Itpl. It was only needed in one place. It
6488 would be nice if this became part of python, though. It makes life
6494 would be nice if this became part of python, though. It makes life
6489 *a lot* easier in some cases.
6495 *a lot* easier in some cases.
6490
6496
6491 * Simplified the prefilter code a bit. Now all handlers are
6497 * Simplified the prefilter code a bit. Now all handlers are
6492 expected to explicitly return a value (at least a blank string).
6498 expected to explicitly return a value (at least a blank string).
6493
6499
6494 * Heavy edits in ipplib. Removed the help system altogether. Now
6500 * Heavy edits in ipplib. Removed the help system altogether. Now
6495 obj?/?? is used for inspecting objects, a magic @doc prints
6501 obj?/?? is used for inspecting objects, a magic @doc prints
6496 docstrings, and full-blown Python help is accessed via the 'help'
6502 docstrings, and full-blown Python help is accessed via the 'help'
6497 keyword. This cleans up a lot of code (less to maintain) and does
6503 keyword. This cleans up a lot of code (less to maintain) and does
6498 the job. Since 'help' is now a standard Python component, might as
6504 the job. Since 'help' is now a standard Python component, might as
6499 well use it and remove duplicate functionality.
6505 well use it and remove duplicate functionality.
6500
6506
6501 Also removed the option to use ipplib as a standalone program. By
6507 Also removed the option to use ipplib as a standalone program. By
6502 now it's too dependent on other parts of IPython to function alone.
6508 now it's too dependent on other parts of IPython to function alone.
6503
6509
6504 * Fixed bug in genutils.pager. It would crash if the pager was
6510 * Fixed bug in genutils.pager. It would crash if the pager was
6505 exited immediately after opening (broken pipe).
6511 exited immediately after opening (broken pipe).
6506
6512
6507 * Trimmed down the VerboseTB reporting a little. The header is
6513 * Trimmed down the VerboseTB reporting a little. The header is
6508 much shorter now and the repeated exception arguments at the end
6514 much shorter now and the repeated exception arguments at the end
6509 have been removed. For interactive use the old header seemed a bit
6515 have been removed. For interactive use the old header seemed a bit
6510 excessive.
6516 excessive.
6511
6517
6512 * Fixed small bug in output of @whos for variables with multi-word
6518 * Fixed small bug in output of @whos for variables with multi-word
6513 types (only first word was displayed).
6519 types (only first word was displayed).
6514
6520
6515 2001-11-17 Fernando Perez <fperez@colorado.edu>
6521 2001-11-17 Fernando Perez <fperez@colorado.edu>
6516
6522
6517 * Version 0.1.10 released, 0.1.11 opened for further work.
6523 * Version 0.1.10 released, 0.1.11 opened for further work.
6518
6524
6519 * Modified dirs and friends. dirs now *returns* the stack (not
6525 * Modified dirs and friends. dirs now *returns* the stack (not
6520 prints), so one can manipulate it as a variable. Convenient to
6526 prints), so one can manipulate it as a variable. Convenient to
6521 travel along many directories.
6527 travel along many directories.
6522
6528
6523 * Fixed bug in magic_pdef: would only work with functions with
6529 * Fixed bug in magic_pdef: would only work with functions with
6524 arguments with default values.
6530 arguments with default values.
6525
6531
6526 2001-11-14 Fernando Perez <fperez@colorado.edu>
6532 2001-11-14 Fernando Perez <fperez@colorado.edu>
6527
6533
6528 * Added the PhysicsInput stuff to dot_ipython so it ships as an
6534 * Added the PhysicsInput stuff to dot_ipython so it ships as an
6529 example with IPython. Various other minor fixes and cleanups.
6535 example with IPython. Various other minor fixes and cleanups.
6530
6536
6531 * Version 0.1.9 released, 0.1.10 opened for further work.
6537 * Version 0.1.9 released, 0.1.10 opened for further work.
6532
6538
6533 * Added sys.path to the list of directories searched in the
6539 * Added sys.path to the list of directories searched in the
6534 execfile= option. It used to be the current directory and the
6540 execfile= option. It used to be the current directory and the
6535 user's IPYTHONDIR only.
6541 user's IPYTHONDIR only.
6536
6542
6537 2001-11-13 Fernando Perez <fperez@colorado.edu>
6543 2001-11-13 Fernando Perez <fperez@colorado.edu>
6538
6544
6539 * Reinstated the raw_input/prefilter separation that Janko had
6545 * Reinstated the raw_input/prefilter separation that Janko had
6540 initially. This gives a more convenient setup for extending the
6546 initially. This gives a more convenient setup for extending the
6541 pre-processor from the outside: raw_input always gets a string,
6547 pre-processor from the outside: raw_input always gets a string,
6542 and prefilter has to process it. We can then redefine prefilter
6548 and prefilter has to process it. We can then redefine prefilter
6543 from the outside and implement extensions for special
6549 from the outside and implement extensions for special
6544 purposes.
6550 purposes.
6545
6551
6546 Today I got one for inputting PhysicalQuantity objects
6552 Today I got one for inputting PhysicalQuantity objects
6547 (from Scientific) without needing any function calls at
6553 (from Scientific) without needing any function calls at
6548 all. Extremely convenient, and it's all done as a user-level
6554 all. Extremely convenient, and it's all done as a user-level
6549 extension (no IPython code was touched). Now instead of:
6555 extension (no IPython code was touched). Now instead of:
6550 a = PhysicalQuantity(4.2,'m/s**2')
6556 a = PhysicalQuantity(4.2,'m/s**2')
6551 one can simply say
6557 one can simply say
6552 a = 4.2 m/s**2
6558 a = 4.2 m/s**2
6553 or even
6559 or even
6554 a = 4.2 m/s^2
6560 a = 4.2 m/s^2
6555
6561
6556 I use this, but it's also a proof of concept: IPython really is
6562 I use this, but it's also a proof of concept: IPython really is
6557 fully user-extensible, even at the level of the parsing of the
6563 fully user-extensible, even at the level of the parsing of the
6558 command line. It's not trivial, but it's perfectly doable.
6564 command line. It's not trivial, but it's perfectly doable.
6559
6565
6560 * Added 'add_flip' method to inclusion conflict resolver. Fixes
6566 * Added 'add_flip' method to inclusion conflict resolver. Fixes
6561 the problem of modules being loaded in the inverse order in which
6567 the problem of modules being loaded in the inverse order in which
6562 they were defined in
6568 they were defined in
6563
6569
6564 * Version 0.1.8 released, 0.1.9 opened for further work.
6570 * Version 0.1.8 released, 0.1.9 opened for further work.
6565
6571
6566 * Added magics pdef, source and file. They respectively show the
6572 * Added magics pdef, source and file. They respectively show the
6567 definition line ('prototype' in C), source code and full python
6573 definition line ('prototype' in C), source code and full python
6568 file for any callable object. The object inspector oinfo uses
6574 file for any callable object. The object inspector oinfo uses
6569 these to show the same information.
6575 these to show the same information.
6570
6576
6571 * Version 0.1.7 released, 0.1.8 opened for further work.
6577 * Version 0.1.7 released, 0.1.8 opened for further work.
6572
6578
6573 * Separated all the magic functions into a class called Magic. The
6579 * Separated all the magic functions into a class called Magic. The
6574 InteractiveShell class was becoming too big for Xemacs to handle
6580 InteractiveShell class was becoming too big for Xemacs to handle
6575 (de-indenting a line would lock it up for 10 seconds while it
6581 (de-indenting a line would lock it up for 10 seconds while it
6576 backtracked on the whole class!)
6582 backtracked on the whole class!)
6577
6583
6578 FIXME: didn't work. It can be done, but right now namespaces are
6584 FIXME: didn't work. It can be done, but right now namespaces are
6579 all messed up. Do it later (reverted it for now, so at least
6585 all messed up. Do it later (reverted it for now, so at least
6580 everything works as before).
6586 everything works as before).
6581
6587
6582 * Got the object introspection system (magic_oinfo) working! I
6588 * Got the object introspection system (magic_oinfo) working! I
6583 think this is pretty much ready for release to Janko, so he can
6589 think this is pretty much ready for release to Janko, so he can
6584 test it for a while and then announce it. Pretty much 100% of what
6590 test it for a while and then announce it. Pretty much 100% of what
6585 I wanted for the 'phase 1' release is ready. Happy, tired.
6591 I wanted for the 'phase 1' release is ready. Happy, tired.
6586
6592
6587 2001-11-12 Fernando Perez <fperez@colorado.edu>
6593 2001-11-12 Fernando Perez <fperez@colorado.edu>
6588
6594
6589 * Version 0.1.6 released, 0.1.7 opened for further work.
6595 * Version 0.1.6 released, 0.1.7 opened for further work.
6590
6596
6591 * Fixed bug in printing: it used to test for truth before
6597 * Fixed bug in printing: it used to test for truth before
6592 printing, so 0 wouldn't print. Now checks for None.
6598 printing, so 0 wouldn't print. Now checks for None.
6593
6599
6594 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
6600 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
6595 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
6601 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
6596 reaches by hand into the outputcache. Think of a better way to do
6602 reaches by hand into the outputcache. Think of a better way to do
6597 this later.
6603 this later.
6598
6604
6599 * Various small fixes thanks to Nathan's comments.
6605 * Various small fixes thanks to Nathan's comments.
6600
6606
6601 * Changed magic_pprint to magic_Pprint. This way it doesn't
6607 * Changed magic_pprint to magic_Pprint. This way it doesn't
6602 collide with pprint() and the name is consistent with the command
6608 collide with pprint() and the name is consistent with the command
6603 line option.
6609 line option.
6604
6610
6605 * Changed prompt counter behavior to be fully like
6611 * Changed prompt counter behavior to be fully like
6606 Mathematica's. That is, even input that doesn't return a result
6612 Mathematica's. That is, even input that doesn't return a result
6607 raises the prompt counter. The old behavior was kind of confusing
6613 raises the prompt counter. The old behavior was kind of confusing
6608 (getting the same prompt number several times if the operation
6614 (getting the same prompt number several times if the operation
6609 didn't return a result).
6615 didn't return a result).
6610
6616
6611 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
6617 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
6612
6618
6613 * Fixed -Classic mode (wasn't working anymore).
6619 * Fixed -Classic mode (wasn't working anymore).
6614
6620
6615 * Added colored prompts using Nathan's new code. Colors are
6621 * Added colored prompts using Nathan's new code. Colors are
6616 currently hardwired, they can be user-configurable. For
6622 currently hardwired, they can be user-configurable. For
6617 developers, they can be chosen in file ipythonlib.py, at the
6623 developers, they can be chosen in file ipythonlib.py, at the
6618 beginning of the CachedOutput class def.
6624 beginning of the CachedOutput class def.
6619
6625
6620 2001-11-11 Fernando Perez <fperez@colorado.edu>
6626 2001-11-11 Fernando Perez <fperez@colorado.edu>
6621
6627
6622 * Version 0.1.5 released, 0.1.6 opened for further work.
6628 * Version 0.1.5 released, 0.1.6 opened for further work.
6623
6629
6624 * Changed magic_env to *return* the environment as a dict (not to
6630 * Changed magic_env to *return* the environment as a dict (not to
6625 print it). This way it prints, but it can also be processed.
6631 print it). This way it prints, but it can also be processed.
6626
6632
6627 * Added Verbose exception reporting to interactive
6633 * Added Verbose exception reporting to interactive
6628 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
6634 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
6629 traceback. Had to make some changes to the ultraTB file. This is
6635 traceback. Had to make some changes to the ultraTB file. This is
6630 probably the last 'big' thing in my mental todo list. This ties
6636 probably the last 'big' thing in my mental todo list. This ties
6631 in with the next entry:
6637 in with the next entry:
6632
6638
6633 * Changed -Xi and -Xf to a single -xmode option. Now all the user
6639 * Changed -Xi and -Xf to a single -xmode option. Now all the user
6634 has to specify is Plain, Color or Verbose for all exception
6640 has to specify is Plain, Color or Verbose for all exception
6635 handling.
6641 handling.
6636
6642
6637 * Removed ShellServices option. All this can really be done via
6643 * Removed ShellServices option. All this can really be done via
6638 the magic system. It's easier to extend, cleaner and has automatic
6644 the magic system. It's easier to extend, cleaner and has automatic
6639 namespace protection and documentation.
6645 namespace protection and documentation.
6640
6646
6641 2001-11-09 Fernando Perez <fperez@colorado.edu>
6647 2001-11-09 Fernando Perez <fperez@colorado.edu>
6642
6648
6643 * Fixed bug in output cache flushing (missing parameter to
6649 * Fixed bug in output cache flushing (missing parameter to
6644 __init__). Other small bugs fixed (found using pychecker).
6650 __init__). Other small bugs fixed (found using pychecker).
6645
6651
6646 * Version 0.1.4 opened for bugfixing.
6652 * Version 0.1.4 opened for bugfixing.
6647
6653
6648 2001-11-07 Fernando Perez <fperez@colorado.edu>
6654 2001-11-07 Fernando Perez <fperez@colorado.edu>
6649
6655
6650 * Version 0.1.3 released, mainly because of the raw_input bug.
6656 * Version 0.1.3 released, mainly because of the raw_input bug.
6651
6657
6652 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
6658 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
6653 and when testing for whether things were callable, a call could
6659 and when testing for whether things were callable, a call could
6654 actually be made to certain functions. They would get called again
6660 actually be made to certain functions. They would get called again
6655 once 'really' executed, with a resulting double call. A disaster
6661 once 'really' executed, with a resulting double call. A disaster
6656 in many cases (list.reverse() would never work!).
6662 in many cases (list.reverse() would never work!).
6657
6663
6658 * Removed prefilter() function, moved its code to raw_input (which
6664 * Removed prefilter() function, moved its code to raw_input (which
6659 after all was just a near-empty caller for prefilter). This saves
6665 after all was just a near-empty caller for prefilter). This saves
6660 a function call on every prompt, and simplifies the class a tiny bit.
6666 a function call on every prompt, and simplifies the class a tiny bit.
6661
6667
6662 * Fix _ip to __ip name in magic example file.
6668 * Fix _ip to __ip name in magic example file.
6663
6669
6664 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
6670 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
6665 work with non-gnu versions of tar.
6671 work with non-gnu versions of tar.
6666
6672
6667 2001-11-06 Fernando Perez <fperez@colorado.edu>
6673 2001-11-06 Fernando Perez <fperez@colorado.edu>
6668
6674
6669 * Version 0.1.2. Just to keep track of the recent changes.
6675 * Version 0.1.2. Just to keep track of the recent changes.
6670
6676
6671 * Fixed nasty bug in output prompt routine. It used to check 'if
6677 * Fixed nasty bug in output prompt routine. It used to check 'if
6672 arg != None...'. Problem is, this fails if arg implements a
6678 arg != None...'. Problem is, this fails if arg implements a
6673 special comparison (__cmp__) which disallows comparing to
6679 special comparison (__cmp__) which disallows comparing to
6674 None. Found it when trying to use the PhysicalQuantity module from
6680 None. Found it when trying to use the PhysicalQuantity module from
6675 ScientificPython.
6681 ScientificPython.
6676
6682
6677 2001-11-05 Fernando Perez <fperez@colorado.edu>
6683 2001-11-05 Fernando Perez <fperez@colorado.edu>
6678
6684
6679 * Also added dirs. Now the pushd/popd/dirs family functions
6685 * Also added dirs. Now the pushd/popd/dirs family functions
6680 basically like the shell, with the added convenience of going home
6686 basically like the shell, with the added convenience of going home
6681 when called with no args.
6687 when called with no args.
6682
6688
6683 * pushd/popd slightly modified to mimic shell behavior more
6689 * pushd/popd slightly modified to mimic shell behavior more
6684 closely.
6690 closely.
6685
6691
6686 * Added env,pushd,popd from ShellServices as magic functions. I
6692 * Added env,pushd,popd from ShellServices as magic functions. I
6687 think the cleanest will be to port all desired functions from
6693 think the cleanest will be to port all desired functions from
6688 ShellServices as magics and remove ShellServices altogether. This
6694 ShellServices as magics and remove ShellServices altogether. This
6689 will provide a single, clean way of adding functionality
6695 will provide a single, clean way of adding functionality
6690 (shell-type or otherwise) to IP.
6696 (shell-type or otherwise) to IP.
6691
6697
6692 2001-11-04 Fernando Perez <fperez@colorado.edu>
6698 2001-11-04 Fernando Perez <fperez@colorado.edu>
6693
6699
6694 * Added .ipython/ directory to sys.path. This way users can keep
6700 * Added .ipython/ directory to sys.path. This way users can keep
6695 customizations there and access them via import.
6701 customizations there and access them via import.
6696
6702
6697 2001-11-03 Fernando Perez <fperez@colorado.edu>
6703 2001-11-03 Fernando Perez <fperez@colorado.edu>
6698
6704
6699 * Opened version 0.1.1 for new changes.
6705 * Opened version 0.1.1 for new changes.
6700
6706
6701 * Changed version number to 0.1.0: first 'public' release, sent to
6707 * Changed version number to 0.1.0: first 'public' release, sent to
6702 Nathan and Janko.
6708 Nathan and Janko.
6703
6709
6704 * Lots of small fixes and tweaks.
6710 * Lots of small fixes and tweaks.
6705
6711
6706 * Minor changes to whos format. Now strings are shown, snipped if
6712 * Minor changes to whos format. Now strings are shown, snipped if
6707 too long.
6713 too long.
6708
6714
6709 * Changed ShellServices to work on __main__ so they show up in @who
6715 * Changed ShellServices to work on __main__ so they show up in @who
6710
6716
6711 * Help also works with ? at the end of a line:
6717 * Help also works with ? at the end of a line:
6712 ?sin and sin?
6718 ?sin and sin?
6713 both produce the same effect. This is nice, as often I use the
6719 both produce the same effect. This is nice, as often I use the
6714 tab-complete to find the name of a method, but I used to then have
6720 tab-complete to find the name of a method, but I used to then have
6715 to go to the beginning of the line to put a ? if I wanted more
6721 to go to the beginning of the line to put a ? if I wanted more
6716 info. Now I can just add the ? and hit return. Convenient.
6722 info. Now I can just add the ? and hit return. Convenient.
6717
6723
6718 2001-11-02 Fernando Perez <fperez@colorado.edu>
6724 2001-11-02 Fernando Perez <fperez@colorado.edu>
6719
6725
6720 * Python version check (>=2.1) added.
6726 * Python version check (>=2.1) added.
6721
6727
6722 * Added LazyPython documentation. At this point the docs are quite
6728 * Added LazyPython documentation. At this point the docs are quite
6723 a mess. A cleanup is in order.
6729 a mess. A cleanup is in order.
6724
6730
6725 * Auto-installer created. For some bizarre reason, the zipfiles
6731 * Auto-installer created. For some bizarre reason, the zipfiles
6726 module isn't working on my system. So I made a tar version
6732 module isn't working on my system. So I made a tar version
6727 (hopefully the command line options in various systems won't kill
6733 (hopefully the command line options in various systems won't kill
6728 me).
6734 me).
6729
6735
6730 * Fixes to Struct in genutils. Now all dictionary-like methods are
6736 * Fixes to Struct in genutils. Now all dictionary-like methods are
6731 protected (reasonably).
6737 protected (reasonably).
6732
6738
6733 * Added pager function to genutils and changed ? to print usage
6739 * Added pager function to genutils and changed ? to print usage
6734 note through it (it was too long).
6740 note through it (it was too long).
6735
6741
6736 * Added the LazyPython functionality. Works great! I changed the
6742 * Added the LazyPython functionality. Works great! I changed the
6737 auto-quote escape to ';', it's on home row and next to '. But
6743 auto-quote escape to ';', it's on home row and next to '. But
6738 both auto-quote and auto-paren (still /) escapes are command-line
6744 both auto-quote and auto-paren (still /) escapes are command-line
6739 parameters.
6745 parameters.
6740
6746
6741
6747
6742 2001-11-01 Fernando Perez <fperez@colorado.edu>
6748 2001-11-01 Fernando Perez <fperez@colorado.edu>
6743
6749
6744 * Version changed to 0.0.7. Fairly large change: configuration now
6750 * Version changed to 0.0.7. Fairly large change: configuration now
6745 is all stored in a directory, by default .ipython. There, all
6751 is all stored in a directory, by default .ipython. There, all
6746 config files have normal looking names (not .names)
6752 config files have normal looking names (not .names)
6747
6753
6748 * Version 0.0.6 Released first to Lucas and Archie as a test
6754 * Version 0.0.6 Released first to Lucas and Archie as a test
6749 run. Since it's the first 'semi-public' release, change version to
6755 run. Since it's the first 'semi-public' release, change version to
6750 > 0.0.6 for any changes now.
6756 > 0.0.6 for any changes now.
6751
6757
6752 * Stuff I had put in the ipplib.py changelog:
6758 * Stuff I had put in the ipplib.py changelog:
6753
6759
6754 Changes to InteractiveShell:
6760 Changes to InteractiveShell:
6755
6761
6756 - Made the usage message a parameter.
6762 - Made the usage message a parameter.
6757
6763
6758 - Require the name of the shell variable to be given. It's a bit
6764 - Require the name of the shell variable to be given. It's a bit
6759 of a hack, but allows the name 'shell' not to be hardwired in the
6765 of a hack, but allows the name 'shell' not to be hardwired in the
6760 magic (@) handler, which is problematic b/c it requires
6766 magic (@) handler, which is problematic b/c it requires
6761 polluting the global namespace with 'shell'. This in turn is
6767 polluting the global namespace with 'shell'. This in turn is
6762 fragile: if a user redefines a variable called shell, things
6768 fragile: if a user redefines a variable called shell, things
6763 break.
6769 break.
6764
6770
6765 - magic @: all functions available through @ need to be defined
6771 - magic @: all functions available through @ need to be defined
6766 as magic_<name>, even though they can be called simply as
6772 as magic_<name>, even though they can be called simply as
6767 @<name>. This allows the special command @magic to gather
6773 @<name>. This allows the special command @magic to gather
6768 information automatically about all existing magic functions,
6774 information automatically about all existing magic functions,
6769 even if they are run-time user extensions, by parsing the shell
6775 even if they are run-time user extensions, by parsing the shell
6770 instance __dict__ looking for special magic_ names.
6776 instance __dict__ looking for special magic_ names.
6771
6777
6772 - mainloop: added *two* local namespace parameters. This allows
6778 - mainloop: added *two* local namespace parameters. This allows
6773 the class to differentiate between parameters which were there
6779 the class to differentiate between parameters which were there
6774 before and after command line initialization was processed. This
6780 before and after command line initialization was processed. This
6775 way, later @who can show things loaded at startup by the
6781 way, later @who can show things loaded at startup by the
6776 user. This trick was necessary to make session saving/reloading
6782 user. This trick was necessary to make session saving/reloading
6777 really work: ideally after saving/exiting/reloading a session,
6783 really work: ideally after saving/exiting/reloading a session,
6778 *everything* should look the same, including the output of @who. I
6784 *everything* should look the same, including the output of @who. I
6779 was only able to make this work with this double namespace
6785 was only able to make this work with this double namespace
6780 trick.
6786 trick.
6781
6787
6782 - added a header to the logfile which allows (almost) full
6788 - added a header to the logfile which allows (almost) full
6783 session restoring.
6789 session restoring.
6784
6790
6785 - prepend lines beginning with @ or !, with a and log
6791 - prepend lines beginning with @ or !, with a and log
6786 them. Why? !lines: may be useful to know what you did @lines:
6792 them. Why? !lines: may be useful to know what you did @lines:
6787 they may affect session state. So when restoring a session, at
6793 they may affect session state. So when restoring a session, at
6788 least inform the user of their presence. I couldn't quite get
6794 least inform the user of their presence. I couldn't quite get
6789 them to properly re-execute, but at least the user is warned.
6795 them to properly re-execute, but at least the user is warned.
6790
6796
6791 * Started ChangeLog.
6797 * Started ChangeLog.
General Comments 0
You need to be logged in to leave comments. Login now