##// END OF EJS Templates
Make isort usable without a key argument....
walter.doerwald -
Show More
@@ -1,1845 +1,1851 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 ``ls`` (listing the
18 * ``Table``s: These objects produce items. Examples are ``ls`` (listing the
19 current directory, ``ienv`` (listing environment variables), ``ipwd`` (listing
19 current directory, ``ienv`` (listing environment variables), ``ipwd`` (listing
20 user account) and ``igrp`` (listing user groups). A ``Table`` must be the
20 user account) 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 ``browse`` which is a ``curses``
32 display objects will be used. One example is ``browse`` 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)``. This method must return a
40 implement the method ``__xattrs__(self, mode)``. This method must return a
41 sequence of attribute names. This sequence may also contain integers, which
41 sequence of attribute names. This sequence may also contain integers, which
42 will be treated as sequence indizes. Also supported is ``None``, which uses
42 will be treated as sequence indizes. Also supported is ``None``, which uses
43 the object itself and callables which will be called with the object as the
43 the object itself and callables which will be called with the object as the
44 an argument. If ``__xattrs__()`` isn't implemented ``(None,)`` will be used as
44 an argument. If ``__xattrs__()`` isn't implemented ``(None,)`` will be used as
45 the attribute sequence (i.e. the object itself (it's ``repr()`` format) will
45 the attribute sequence (i.e. the object itself (it's ``repr()`` format) will
46 be being displayed. The global function ``xattrs()`` implements this
46 be being displayed. The global function ``xattrs()`` implements this
47 functionality.
47 functionality.
48
48
49 * When an object ``foo`` is displayed in the header, footer or table cell of the
49 * When an object ``foo`` is displayed in the header, footer or table cell of the
50 browser ``foo.__xrepr__(mode)`` is called. Mode can be ``"header"`` or
50 browser ``foo.__xrepr__(mode)`` is called. Mode can be ``"header"`` or
51 ``"footer"`` for the header or footer line and ``"cell"`` for a table cell.
51 ``"footer"`` for the header or footer line and ``"cell"`` for a table cell.
52 ``__xrepr__()```must return an iterable (e.g. by being a generator) which
52 ``__xrepr__()```must return an iterable (e.g. by being a generator) which
53 produces the following items: The first item should be a tuple containing
53 produces the following items: The first item should be a tuple containing
54 the alignment (-1 left aligned, 0 centered and 1 right aligned) and whether
54 the alignment (-1 left aligned, 0 centered and 1 right aligned) and whether
55 the complete output must be displayed or if the browser is allowed to stop
55 the complete output must be displayed or if the browser is allowed to stop
56 output after enough text has been produced (e.g. a syntax highlighted text
56 output after enough text has been produced (e.g. a syntax highlighted text
57 line would use ``True``, but for a large data structure (i.e. a nested list,
57 line would use ``True``, but for a large data structure (i.e. a nested list,
58 tuple or dictionary) ``False`` would be used). The other output ``__xrepr__()``
58 tuple or dictionary) ``False`` would be used). The other output ``__xrepr__()``
59 may produce is tuples of ``Style```objects and text (which contain the text
59 may produce is tuples of ``Style```objects and text (which contain the text
60 representation of the object; see the ``astyle`` module). If ``__xrepr__()``
60 representation of the object; see the ``astyle`` module). If ``__xrepr__()``
61 recursively outputs a data structure the function ``xrepr(object, mode)`` can
61 recursively outputs a data structure the function ``xrepr(object, mode)`` can
62 be used and ``"default"`` must be passed as the mode in these calls. This in
62 be used and ``"default"`` must be passed as the mode in these calls. This in
63 turn calls the ``__xrepr__()`` method on ``object`` (or uses ``repr(object)``
63 turn calls the ``__xrepr__()`` method on ``object`` (or uses ``repr(object)``
64 as the string representation if ``__xrepr__()`` doesn't exist).
64 as the string representation if ``__xrepr__()`` doesn't exist).
65
65
66 * Objects that can be iterated by ``Pipe``s must implement the method
66 * Objects that can be iterated by ``Pipe``s must implement the method
67 ``__xiter__(self, mode)``. ``mode`` can take the following values:
67 ``__xiter__(self, mode)``. ``mode`` can take the following values:
68
68
69 - ``"default"``: This is the default value and ist always used by pipeline
69 - ``"default"``: This is the default value and ist always used by pipeline
70 expressions. Other values are only used in the browser.
70 expressions. Other values are only used in the browser.
71 - ``None``: This value is passed by the browser. The object must return an
71 - ``None``: This value is passed by the browser. The object must return an
72 iterable of ``XMode`` objects describing all modes supported by the object.
72 iterable of ``XMode`` objects describing all modes supported by the object.
73 (This should never include ``"default"`` or ``None``).
73 (This should never include ``"default"`` or ``None``).
74 - Any other value that the object supports.
74 - Any other value that the object supports.
75
75
76 The global function ``xiter()`` can be called to get such an iterator. If
76 The global function ``xiter()`` can be called to get such an iterator. If
77 the method ``_xiter__`` isn't implemented, ``xiter()`` falls back to
77 the method ``_xiter__`` isn't implemented, ``xiter()`` falls back to
78 ``__iter__``. In addition to that, dictionaries and modules receive special
78 ``__iter__``. In addition to that, dictionaries and modules receive special
79 treatment (returning an iterator over ``(key, value)`` pairs). This makes it
79 treatment (returning an iterator over ``(key, value)`` pairs). This makes it
80 possible to use dictionaries and modules in pipeline expressions, for example:
80 possible to use dictionaries and modules in pipeline expressions, for example:
81
81
82 >>> import sys
82 >>> import sys
83 >>> sys | ifilter("isinstance(value, int)") | idump
83 >>> sys | ifilter("isinstance(value, int)") | idump
84 key |value
84 key |value
85 api_version| 1012
85 api_version| 1012
86 dllhandle | 503316480
86 dllhandle | 503316480
87 hexversion | 33817328
87 hexversion | 33817328
88 maxint |2147483647
88 maxint |2147483647
89 maxunicode | 65535
89 maxunicode | 65535
90 >>> sys.modules | ifilter("_.value is not None") | isort("_.key.lower()")
90 >>> sys.modules | ifilter("_.value is not None") | isort("_.key.lower()")
91 ...
91 ...
92
92
93 Note: The expression strings passed to ``ifilter()`` and ``isort()`` can
93 Note: The expression strings passed to ``ifilter()`` and ``isort()`` can
94 refer to the object to be filtered or sorted via the variable ``_`` and to any
94 refer to the object to be filtered or sorted via the variable ``_`` and to any
95 of the attributes of the object, i.e.:
95 of the attributes of the object, i.e.:
96
96
97 >>> sys.modules | ifilter("_.value is not None") | isort("_.key.lower()")
97 >>> sys.modules | ifilter("_.value is not None") | isort("_.key.lower()")
98
98
99 does the same as
99 does the same as
100
100
101 >>> sys.modules | ifilter("value is not None") | isort("key.lower()")
101 >>> sys.modules | ifilter("value is not None") | isort("key.lower()")
102
102
103 In addition to expression strings, it's possible to pass callables (taking
103 In addition to expression strings, it's possible to pass callables (taking
104 the object as an argument) to ``ifilter()``, ``isort()`` and ``ieval()``:
104 the object as an argument) to ``ifilter()``, ``isort()`` and ``ieval()``:
105
105
106 >>> sys | ifilter(lambda _:isinstance(_.value, int)) \
106 >>> sys | ifilter(lambda _:isinstance(_.value, int)) \
107 ... | ieval(lambda _: (_.key, hex(_.value))) | idump
107 ... | ieval(lambda _: (_.key, hex(_.value))) | idump
108 0 |1
108 0 |1
109 api_version|0x3f4
109 api_version|0x3f4
110 dllhandle |0x1e000000
110 dllhandle |0x1e000000
111 hexversion |0x20402f0
111 hexversion |0x20402f0
112 maxint |0x7fffffff
112 maxint |0x7fffffff
113 maxunicode |0xffff
113 maxunicode |0xffff
114 """
114 """
115
115
116 import sys, os, os.path, stat, glob, new, csv, datetime, types
116 import sys, os, os.path, stat, glob, new, csv, datetime, types
117 import itertools, mimetypes
117 import itertools, mimetypes
118
118
119 try: # Python 2.3 compatibility
119 try: # Python 2.3 compatibility
120 import collections
120 import collections
121 except ImportError:
121 except ImportError:
122 deque = list
122 deque = list
123 else:
123 else:
124 deque = collections.deque
124 deque = collections.deque
125
125
126 try: # Python 2.3 compatibility
126 try: # Python 2.3 compatibility
127 set
127 set
128 except NameError:
128 except NameError:
129 import sets
129 import sets
130 set = sets.Set
130 set = sets.Set
131
131
132 try: # Python 2.3 compatibility
132 try: # Python 2.3 compatibility
133 sorted
133 sorted
134 except NameError:
134 except NameError:
135 def sorted(iterator, key=None, reverse=False):
135 def sorted(iterator, key=None, reverse=False):
136 items = list(iterator)
136 items = list(iterator)
137 if key is not None:
137 if key is not None:
138 items.sort(lambda i1, i2: cmp(key(i1), key(i2)))
138 items.sort(lambda i1, i2: cmp(key(i1), key(i2)))
139 else:
139 else:
140 items.sort()
140 items.sort()
141 if reverse:
141 if reverse:
142 items.reverse()
142 items.reverse()
143 return items
143 return items
144
144
145 try:
145 try:
146 import pwd
146 import pwd
147 except ImportError:
147 except ImportError:
148 pwd = None
148 pwd = None
149
149
150 try:
150 try:
151 import grp
151 import grp
152 except ImportError:
152 except ImportError:
153 grp = None
153 grp = None
154
154
155 import path
155 import path
156 try:
156 try:
157 from IPython import genutils, ipapi
157 from IPython import genutils, ipapi
158 except ImportError:
158 except ImportError:
159 genutils = None
159 genutils = None
160 ipapi = None
160 ipapi = None
161
161
162 import astyle
162 import astyle
163
163
164
164
165 __all__ = [
165 __all__ = [
166 "ifile", "ils", "iglob", "iwalk", "ipwdentry", "ipwd", "igrpentry", "igrp",
166 "ifile", "ils", "iglob", "iwalk", "ipwdentry", "ipwd", "igrpentry", "igrp",
167 "icsv", "ix", "ichain", "isort", "ifilter", "ieval", "ienum", "ienv",
167 "icsv", "ix", "ichain", "isort", "ifilter", "ieval", "ienum", "ienv",
168 "idump", "iless"
168 "idump", "iless"
169 ]
169 ]
170
170
171
171
172 os.stat_float_times(True) # enable microseconds
172 os.stat_float_times(True) # enable microseconds
173
173
174
174
175 class AttrNamespace(object):
175 class AttrNamespace(object):
176 """
176 """
177 Helper class that is used for providing a namespace for evaluating
177 Helper class that is used for providing a namespace for evaluating
178 expressions containing attribute names of an object.
178 expressions containing attribute names of an object.
179 """
179 """
180 def __init__(self, wrapped):
180 def __init__(self, wrapped):
181 self.wrapped = wrapped
181 self.wrapped = wrapped
182
182
183 def __getitem__(self, name):
183 def __getitem__(self, name):
184 if name == "_":
184 if name == "_":
185 return self.wrapped
185 return self.wrapped
186 try:
186 try:
187 return getattr(self.wrapped, name)
187 return getattr(self.wrapped, name)
188 except AttributeError:
188 except AttributeError:
189 raise KeyError(name)
189 raise KeyError(name)
190
190
191 # Python 2.3 compatibility
191 # Python 2.3 compatibility
192 # use eval workaround to find out which names are used in the
192 # use eval workaround to find out which names are used in the
193 # eval string and put them into the locals. This works for most
193 # eval string and put them into the locals. This works for most
194 # normal uses case, bizarre ones like accessing the locals()
194 # normal uses case, bizarre ones like accessing the locals()
195 # will fail
195 # will fail
196 try:
196 try:
197 eval("_", None, AttrNamespace(None))
197 eval("_", None, AttrNamespace(None))
198 except TypeError:
198 except TypeError:
199 real_eval = eval
199 real_eval = eval
200 def eval(codestring, _globals, _locals):
200 def eval(codestring, _globals, _locals):
201 """
201 """
202 eval(source[, globals[, locals]]) -> value
202 eval(source[, globals[, locals]]) -> value
203
203
204 Evaluate the source in the context of globals and locals.
204 Evaluate the source in the context of globals and locals.
205 The source may be a string representing a Python expression
205 The source may be a string representing a Python expression
206 or a code object as returned by compile().
206 or a code object as returned by compile().
207 The globals must be a dictionary and locals can be any mappping.
207 The globals must be a dictionary and locals can be any mappping.
208
208
209 This function is a workaround for the shortcomings of
209 This function is a workaround for the shortcomings of
210 Python 2.3's eval.
210 Python 2.3's eval.
211 """
211 """
212
212
213 if isinstance(codestring, basestring):
213 if isinstance(codestring, basestring):
214 code = compile(codestring, "_eval", "eval")
214 code = compile(codestring, "_eval", "eval")
215 else:
215 else:
216 code = codestring
216 code = codestring
217 newlocals = {}
217 newlocals = {}
218 for name in code.co_names:
218 for name in code.co_names:
219 try:
219 try:
220 newlocals[name] = _locals[name]
220 newlocals[name] = _locals[name]
221 except KeyError:
221 except KeyError:
222 pass
222 pass
223 return real_eval(code, _globals, newlocals)
223 return real_eval(code, _globals, newlocals)
224
224
225
225
226 noitem = object()
226 noitem = object()
227
227
228 def item(iterator, index, default=noitem):
228 def item(iterator, index, default=noitem):
229 """
229 """
230 Return the ``index``th item from the iterator ``iterator``.
230 Return the ``index``th item from the iterator ``iterator``.
231 ``index`` must be an integer (negative integers are relative to the
231 ``index`` must be an integer (negative integers are relative to the
232 end (i.e. the last item produced by the iterator)).
232 end (i.e. the last item produced by the iterator)).
233
233
234 If ``default`` is given, this will be the default value when
234 If ``default`` is given, this will be the default value when
235 the iterator doesn't contain an item at this position. Otherwise an
235 the iterator doesn't contain an item at this position. Otherwise an
236 ``IndexError`` will be raised.
236 ``IndexError`` will be raised.
237
237
238 Note that using this function will partially or totally exhaust the
238 Note that using this function will partially or totally exhaust the
239 iterator.
239 iterator.
240 """
240 """
241 i = index
241 i = index
242 if i>=0:
242 if i>=0:
243 for item in iterator:
243 for item in iterator:
244 if not i:
244 if not i:
245 return item
245 return item
246 i -= 1
246 i -= 1
247 else:
247 else:
248 i = -index
248 i = -index
249 cache = deque()
249 cache = deque()
250 for item in iterator:
250 for item in iterator:
251 cache.append(item)
251 cache.append(item)
252 if len(cache)>i:
252 if len(cache)>i:
253 cache.popleft()
253 cache.popleft()
254 if len(cache)==i:
254 if len(cache)==i:
255 return cache.popleft()
255 return cache.popleft()
256 if default is noitem:
256 if default is noitem:
257 raise IndexError(index)
257 raise IndexError(index)
258 else:
258 else:
259 return default
259 return default
260
260
261
261
262 def getglobals(g):
262 def getglobals(g):
263 if g is None:
263 if g is None:
264 if ipapi is not None:
264 if ipapi is not None:
265 return ipapi.get().user_ns
265 return ipapi.get().user_ns
266 else:
266 else:
267 return globals()
267 return globals()
268 return g
268 return g
269
269
270
270
271 class Table(object):
271 class Table(object):
272 """
272 """
273 A ``Table`` is an object that produces items (just like a normal Python
273 A ``Table`` is an object that produces items (just like a normal Python
274 iterator/generator does) and can be used as the first object in a pipeline
274 iterator/generator does) and can be used as the first object in a pipeline
275 expression. The displayhook will open the default browser for such an object
275 expression. The displayhook will open the default browser for such an object
276 (instead of simply printing the ``repr()`` result).
276 (instead of simply printing the ``repr()`` result).
277 """
277 """
278
278
279 # We want to support ``foo`` and ``foo()`` in pipeline expression:
279 # We want to support ``foo`` and ``foo()`` in pipeline expression:
280 # So we implement the required operators (``|`` and ``+``) in the metaclass,
280 # So we implement the required operators (``|`` and ``+``) in the metaclass,
281 # instantiate the class and forward the operator to the instance
281 # instantiate the class and forward the operator to the instance
282 class __metaclass__(type):
282 class __metaclass__(type):
283 def __iter__(self):
283 def __iter__(self):
284 return iter(self())
284 return iter(self())
285
285
286 def __or__(self, other):
286 def __or__(self, other):
287 return self() | other
287 return self() | other
288
288
289 def __add__(self, other):
289 def __add__(self, other):
290 return self() + other
290 return self() + other
291
291
292 def __radd__(self, other):
292 def __radd__(self, other):
293 return other + self()
293 return other + self()
294
294
295 def __getitem__(self, index):
295 def __getitem__(self, index):
296 return self()[index]
296 return self()[index]
297
297
298 def __getitem__(self, index):
298 def __getitem__(self, index):
299 return item(self, index)
299 return item(self, index)
300
300
301 def __contains__(self, item):
301 def __contains__(self, item):
302 for haveitem in self:
302 for haveitem in self:
303 if item == haveitem:
303 if item == haveitem:
304 return True
304 return True
305 return False
305 return False
306
306
307 def __or__(self, other):
307 def __or__(self, other):
308 # autoinstantiate right hand side
308 # autoinstantiate right hand side
309 if isinstance(other, type) and issubclass(other, (Table, Display)):
309 if isinstance(other, type) and issubclass(other, (Table, Display)):
310 other = other()
310 other = other()
311 # treat simple strings and functions as ``ieval`` instances
311 # treat simple strings and functions as ``ieval`` instances
312 elif not isinstance(other, Display) and not isinstance(other, Table):
312 elif not isinstance(other, Display) and not isinstance(other, Table):
313 other = ieval(other)
313 other = ieval(other)
314 # forward operations to the right hand side
314 # forward operations to the right hand side
315 return other.__ror__(self)
315 return other.__ror__(self)
316
316
317 def __add__(self, other):
317 def __add__(self, other):
318 # autoinstantiate right hand side
318 # autoinstantiate right hand side
319 if isinstance(other, type) and issubclass(other, Table):
319 if isinstance(other, type) and issubclass(other, Table):
320 other = other()
320 other = other()
321 return ichain(self, other)
321 return ichain(self, other)
322
322
323 def __radd__(self, other):
323 def __radd__(self, other):
324 # autoinstantiate left hand side
324 # autoinstantiate left hand side
325 if isinstance(other, type) and issubclass(other, Table):
325 if isinstance(other, type) and issubclass(other, Table):
326 other = other()
326 other = other()
327 return ichain(other, self)
327 return ichain(other, self)
328
328
329 def __iter__(self):
329 def __iter__(self):
330 return xiter(self, "default")
330 return xiter(self, "default")
331
331
332
332
333 class Pipe(Table):
333 class Pipe(Table):
334 """
334 """
335 A ``Pipe`` is an object that can be used in a pipeline expression. It
335 A ``Pipe`` is an object that can be used in a pipeline expression. It
336 processes the objects it gets from its input ``Table``/``Pipe``. Note that
336 processes the objects it gets from its input ``Table``/``Pipe``. Note that
337 a ``Pipe`` object can't be used as the first object in a pipeline
337 a ``Pipe`` object can't be used as the first object in a pipeline
338 expression, as it doesn't produces items itself.
338 expression, as it doesn't produces items itself.
339 """
339 """
340 class __metaclass__(Table.__metaclass__):
340 class __metaclass__(Table.__metaclass__):
341 def __ror__(self, input):
341 def __ror__(self, input):
342 return input | self()
342 return input | self()
343
343
344 def __ror__(self, input):
344 def __ror__(self, input):
345 # autoinstantiate left hand side
345 # autoinstantiate left hand side
346 if isinstance(input, type) and issubclass(input, Table):
346 if isinstance(input, type) and issubclass(input, Table):
347 input = input()
347 input = input()
348 self.input = input
348 self.input = input
349 return self
349 return self
350
350
351
351
352 def _getattr(obj, name, default=noitem):
352 def _getattr(obj, name, default=noitem):
353 """
353 """
354 Internal helper for getting an attribute of an item. If ``name`` is ``None``
354 Internal helper for getting an attribute of an item. If ``name`` is ``None``
355 return the object itself. If ``name`` is an integer, use ``__getitem__``
355 return the object itself. If ``name`` is an integer, use ``__getitem__``
356 instead. If the attribute or item does not exist, return ``default``.
356 instead. If the attribute or item does not exist, return ``default``.
357 """
357 """
358 if name is None:
358 if name is None:
359 return obj
359 return obj
360 elif isinstance(name, basestring):
360 elif isinstance(name, basestring):
361 if name.endswith("()"):
361 if name.endswith("()"):
362 return getattr(obj, name[:-2], default)()
362 return getattr(obj, name[:-2], default)()
363 else:
363 else:
364 return getattr(obj, name, default)
364 return getattr(obj, name, default)
365 elif callable(name):
365 elif callable(name):
366 try:
366 try:
367 return name(obj)
367 return name(obj)
368 except AttributeError:
368 except AttributeError:
369 return default
369 return default
370 else:
370 else:
371 try:
371 try:
372 return obj[name]
372 return obj[name]
373 except IndexError:
373 except IndexError:
374 return default
374 return default
375
375
376
376
377 def _attrname(name):
377 def _attrname(name):
378 """
378 """
379 Internal helper that gives a proper name for the attribute ``name``
379 Internal helper that gives a proper name for the attribute ``name``
380 (which might be ``None`` or an ``int``).
380 (which might be ``None`` or an ``int``).
381 """
381 """
382 if name is None:
382 if name is None:
383 return "_"
383 return "_"
384 elif isinstance(name, basestring):
384 elif isinstance(name, basestring):
385 return name
385 return name
386 elif callable(name):
386 elif callable(name):
387 return getattr(name, "__xname__", name.__name__)
387 return getattr(name, "__xname__", name.__name__)
388 else:
388 else:
389 return str(name)
389 return str(name)
390
390
391
391
392 def xrepr(item, mode):
392 def xrepr(item, mode):
393 try:
393 try:
394 func = item.__xrepr__
394 func = item.__xrepr__
395 except AttributeError:
395 except AttributeError:
396 pass
396 pass
397 else:
397 else:
398 try:
398 try:
399 for x in func(mode):
399 for x in func(mode):
400 yield x
400 yield x
401 except (KeyboardInterrupt, SystemExit):
401 except (KeyboardInterrupt, SystemExit):
402 raise
402 raise
403 except Exception:
403 except Exception:
404 yield (astyle.style_default, repr(item))
404 yield (astyle.style_default, repr(item))
405 return
405 return
406 if item is None:
406 if item is None:
407 yield (astyle.style_type_none, repr(item))
407 yield (astyle.style_type_none, repr(item))
408 elif isinstance(item, bool):
408 elif isinstance(item, bool):
409 yield (astyle.style_type_bool, repr(item))
409 yield (astyle.style_type_bool, repr(item))
410 elif isinstance(item, str):
410 elif isinstance(item, str):
411 if mode == "cell":
411 if mode == "cell":
412 yield (astyle.style_default, repr(item.expandtabs(tab))[1:-1])
412 yield (astyle.style_default, repr(item.expandtabs(tab))[1:-1])
413 else:
413 else:
414 yield (astyle.style_default, repr(item))
414 yield (astyle.style_default, repr(item))
415 elif isinstance(item, unicode):
415 elif isinstance(item, unicode):
416 if mode == "cell":
416 if mode == "cell":
417 yield (astyle.style_default, repr(item.expandtabs(tab))[2:-1])
417 yield (astyle.style_default, repr(item.expandtabs(tab))[2:-1])
418 else:
418 else:
419 yield (astyle.style_default, repr(item))
419 yield (astyle.style_default, repr(item))
420 elif isinstance(item, (int, long, float)):
420 elif isinstance(item, (int, long, float)):
421 yield (1, True)
421 yield (1, True)
422 yield (astyle.style_type_number, repr(item))
422 yield (astyle.style_type_number, repr(item))
423 elif isinstance(item, complex):
423 elif isinstance(item, complex):
424 yield (astyle.style_type_number, repr(item))
424 yield (astyle.style_type_number, repr(item))
425 elif isinstance(item, datetime.datetime):
425 elif isinstance(item, datetime.datetime):
426 if mode == "cell":
426 if mode == "cell":
427 # Don't use strftime() here, as this requires year >= 1900
427 # Don't use strftime() here, as this requires year >= 1900
428 yield (astyle.style_type_datetime,
428 yield (astyle.style_type_datetime,
429 "%04d-%02d-%02d %02d:%02d:%02d.%06d" % \
429 "%04d-%02d-%02d %02d:%02d:%02d.%06d" % \
430 (item.year, item.month, item.day,
430 (item.year, item.month, item.day,
431 item.hour, item.minute, item.second,
431 item.hour, item.minute, item.second,
432 item.microsecond),
432 item.microsecond),
433 )
433 )
434 else:
434 else:
435 yield (astyle.style_type_datetime, repr(item))
435 yield (astyle.style_type_datetime, repr(item))
436 elif isinstance(item, datetime.date):
436 elif isinstance(item, datetime.date):
437 if mode == "cell":
437 if mode == "cell":
438 yield (astyle.style_type_datetime,
438 yield (astyle.style_type_datetime,
439 "%04d-%02d-%02d" % (item.year, item.month, item.day))
439 "%04d-%02d-%02d" % (item.year, item.month, item.day))
440 else:
440 else:
441 yield (astyle.style_type_datetime, repr(item))
441 yield (astyle.style_type_datetime, repr(item))
442 elif isinstance(item, datetime.time):
442 elif isinstance(item, datetime.time):
443 if mode == "cell":
443 if mode == "cell":
444 yield (astyle.style_type_datetime,
444 yield (astyle.style_type_datetime,
445 "%02d:%02d:%02d.%06d" % \
445 "%02d:%02d:%02d.%06d" % \
446 (item.hour, item.minute, item.second, item.microsecond))
446 (item.hour, item.minute, item.second, item.microsecond))
447 else:
447 else:
448 yield (astyle.style_type_datetime, repr(item))
448 yield (astyle.style_type_datetime, repr(item))
449 elif isinstance(item, datetime.timedelta):
449 elif isinstance(item, datetime.timedelta):
450 yield (astyle.style_type_datetime, repr(item))
450 yield (astyle.style_type_datetime, repr(item))
451 elif isinstance(item, Exception):
451 elif isinstance(item, Exception):
452 if item.__class__.__module__ == "exceptions":
452 if item.__class__.__module__ == "exceptions":
453 classname = item.__class__.__name__
453 classname = item.__class__.__name__
454 else:
454 else:
455 classname = "%s.%s" % \
455 classname = "%s.%s" % \
456 (item.__class__.__module__, item.__class__.__name__)
456 (item.__class__.__module__, item.__class__.__name__)
457 if mode == "header" or mode == "footer":
457 if mode == "header" or mode == "footer":
458 yield (astyle.style_error, "%s: %s" % (classname, item))
458 yield (astyle.style_error, "%s: %s" % (classname, item))
459 else:
459 else:
460 yield (astyle.style_error, classname)
460 yield (astyle.style_error, classname)
461 elif isinstance(item, (list, tuple)):
461 elif isinstance(item, (list, tuple)):
462 if mode == "header" or mode == "footer":
462 if mode == "header" or mode == "footer":
463 if item.__class__.__module__ == "__builtin__":
463 if item.__class__.__module__ == "__builtin__":
464 classname = item.__class__.__name__
464 classname = item.__class__.__name__
465 else:
465 else:
466 classname = "%s.%s" % \
466 classname = "%s.%s" % \
467 (item.__class__.__module__,item.__class__.__name__)
467 (item.__class__.__module__,item.__class__.__name__)
468 yield (astyle.style_default,
468 yield (astyle.style_default,
469 "<%s object with %d items at 0x%x>" % \
469 "<%s object with %d items at 0x%x>" % \
470 (classname, len(item), id(item)))
470 (classname, len(item), id(item)))
471 else:
471 else:
472 yield (-1, False)
472 yield (-1, False)
473 if isinstance(item, list):
473 if isinstance(item, list):
474 yield (astyle.style_default, "[")
474 yield (astyle.style_default, "[")
475 end = "]"
475 end = "]"
476 else:
476 else:
477 yield (astyle.style_default, "(")
477 yield (astyle.style_default, "(")
478 end = ")"
478 end = ")"
479 for (i, subitem) in enumerate(item):
479 for (i, subitem) in enumerate(item):
480 if i:
480 if i:
481 yield (astyle.style_default, ", ")
481 yield (astyle.style_default, ", ")
482 for part in xrepr(subitem, "default"):
482 for part in xrepr(subitem, "default"):
483 yield part
483 yield part
484 yield (astyle.style_default, end)
484 yield (astyle.style_default, end)
485 elif isinstance(item, (dict, types.DictProxyType)):
485 elif isinstance(item, (dict, types.DictProxyType)):
486 if mode == "header" or mode == "footer":
486 if mode == "header" or mode == "footer":
487 if item.__class__.__module__ == "__builtin__":
487 if item.__class__.__module__ == "__builtin__":
488 classname = item.__class__.__name__
488 classname = item.__class__.__name__
489 else:
489 else:
490 classname = "%s.%s" % \
490 classname = "%s.%s" % \
491 (item.__class__.__module__,item.__class__.__name__)
491 (item.__class__.__module__,item.__class__.__name__)
492 yield (astyle.style_default,
492 yield (astyle.style_default,
493 "<%s object with %d items at 0x%x>" % \
493 "<%s object with %d items at 0x%x>" % \
494 (classname, len(item), id(item)))
494 (classname, len(item), id(item)))
495 else:
495 else:
496 yield (-1, False)
496 yield (-1, False)
497 if isinstance(item, dict):
497 if isinstance(item, dict):
498 yield (astyle.style_default, "{")
498 yield (astyle.style_default, "{")
499 end = "}"
499 end = "}"
500 else:
500 else:
501 yield (astyle.style_default, "dictproxy((")
501 yield (astyle.style_default, "dictproxy((")
502 end = "})"
502 end = "})"
503 for (i, (key, value)) in enumerate(item.iteritems()):
503 for (i, (key, value)) in enumerate(item.iteritems()):
504 if i:
504 if i:
505 yield (astyle.style_default, ", ")
505 yield (astyle.style_default, ", ")
506 for part in xrepr(key, "default"):
506 for part in xrepr(key, "default"):
507 yield part
507 yield part
508 yield (astyle.style_default, ": ")
508 yield (astyle.style_default, ": ")
509 for part in xrepr(value, "default"):
509 for part in xrepr(value, "default"):
510 yield part
510 yield part
511 yield (astyle.style_default, end)
511 yield (astyle.style_default, end)
512 else:
512 else:
513 yield (astyle.style_default, repr(item))
513 yield (astyle.style_default, repr(item))
514
514
515
515
516 def xattrs(item, mode):
516 def xattrs(item, mode):
517 try:
517 try:
518 func = item.__xattrs__
518 func = item.__xattrs__
519 except AttributeError:
519 except AttributeError:
520 if mode == "detail":
520 if mode == "detail":
521 return dir(item)
521 return dir(item)
522 else:
522 else:
523 return (None,)
523 return (None,)
524 else:
524 else:
525 try:
525 try:
526 return func(mode)
526 return func(mode)
527 except (KeyboardInterrupt, SystemExit):
527 except (KeyboardInterrupt, SystemExit):
528 raise
528 raise
529 except Exception:
529 except Exception:
530 return (None,)
530 return (None,)
531
531
532
532
533 def xiter(item, mode):
533 def xiter(item, mode):
534 if mode == "detail":
534 if mode == "detail":
535 def items():
535 def items():
536 for name in xattrs(item, mode):
536 for name in xattrs(item, mode):
537 yield XAttr(item, name)
537 yield XAttr(item, name)
538 return items()
538 return items()
539 try:
539 try:
540 func = item.__xiter__
540 func = item.__xiter__
541 except AttributeError:
541 except AttributeError:
542 if isinstance(item, (dict, types.DictProxyType)):
542 if isinstance(item, (dict, types.DictProxyType)):
543 def items(item):
543 def items(item):
544 fields = ("key", "value")
544 fields = ("key", "value")
545 for (key, value) in item.iteritems():
545 for (key, value) in item.iteritems():
546 yield Fields(fields, key=key, value=value)
546 yield Fields(fields, key=key, value=value)
547 return items(item)
547 return items(item)
548 elif isinstance(item, new.module):
548 elif isinstance(item, new.module):
549 def items(item):
549 def items(item):
550 fields = ("key", "value")
550 fields = ("key", "value")
551 for key in sorted(item.__dict__):
551 for key in sorted(item.__dict__):
552 yield Fields(fields, key=key, value=getattr(item, key))
552 yield Fields(fields, key=key, value=getattr(item, key))
553 return items(item)
553 return items(item)
554 elif isinstance(item, basestring):
554 elif isinstance(item, basestring):
555 if not len(item):
555 if not len(item):
556 raise ValueError("can't enter empty string")
556 raise ValueError("can't enter empty string")
557 lines = item.splitlines()
557 lines = item.splitlines()
558 if len(lines) <= 1:
558 if len(lines) <= 1:
559 raise ValueError("can't enter one line string")
559 raise ValueError("can't enter one line string")
560 return iter(lines)
560 return iter(lines)
561 return iter(item)
561 return iter(item)
562 else:
562 else:
563 return iter(func(mode)) # iter() just to be safe
563 return iter(func(mode)) # iter() just to be safe
564
564
565
565
566 class ichain(Pipe):
566 class ichain(Pipe):
567 """
567 """
568 Chains multiple ``Table``s into one.
568 Chains multiple ``Table``s into one.
569 """
569 """
570
570
571 def __init__(self, *iters):
571 def __init__(self, *iters):
572 self.iters = iters
572 self.iters = iters
573
573
574 def __xiter__(self, mode):
574 def __xiter__(self, mode):
575 return itertools.chain(*self.iters)
575 return itertools.chain(*self.iters)
576
576
577 def __xrepr__(self, mode):
577 def __xrepr__(self, mode):
578 if mode == "header" or mode == "footer":
578 if mode == "header" or mode == "footer":
579 for (i, item) in enumerate(self.iters):
579 for (i, item) in enumerate(self.iters):
580 if i:
580 if i:
581 yield (astyle.style_default, "+")
581 yield (astyle.style_default, "+")
582 if isinstance(item, Pipe):
582 if isinstance(item, Pipe):
583 yield (astyle.style_default, "(")
583 yield (astyle.style_default, "(")
584 for part in xrepr(item, mode):
584 for part in xrepr(item, mode):
585 yield part
585 yield part
586 if isinstance(item, Pipe):
586 if isinstance(item, Pipe):
587 yield (astyle.style_default, ")")
587 yield (astyle.style_default, ")")
588 else:
588 else:
589 yield (astyle.style_default, repr(self))
589 yield (astyle.style_default, repr(self))
590
590
591 def __repr__(self):
591 def __repr__(self):
592 args = ", ".join([repr(it) for it in self.iters])
592 args = ", ".join([repr(it) for it in self.iters])
593 return "%s.%s(%s)" % \
593 return "%s.%s(%s)" % \
594 (self.__class__.__module__, self.__class__.__name__, args)
594 (self.__class__.__module__, self.__class__.__name__, args)
595
595
596
596
597 class ifile(path.path):
597 class ifile(path.path):
598 """
598 """
599 file (or directory) object.
599 file (or directory) object.
600 """
600 """
601
601
602 def __add_(self, other):
602 def __add_(self, other):
603 return ifile(path._base(self) + other)
603 return ifile(path._base(self) + other)
604
604
605 def __radd_(self, other):
605 def __radd_(self, other):
606 return ifile(other + path._base(self))
606 return ifile(other + path._base(self))
607
607
608 def __div_(self, other):
608 def __div_(self, other):
609 return ifile(path.__div__(self, other))
609 return ifile(path.__div__(self, other))
610
610
611 def getcwd():
611 def getcwd():
612 return ifile(path.path.getcwd())
612 return ifile(path.path.getcwd())
613 getcwd.__doc__ = path.path.getcwd.__doc__
613 getcwd.__doc__ = path.path.getcwd.__doc__
614 getcwd = staticmethod(getcwd)
614 getcwd = staticmethod(getcwd)
615
615
616 def abspath(self):
616 def abspath(self):
617 return ifile(path.path.abspath(self))
617 return ifile(path.path.abspath(self))
618 abspath.__doc__ = path.path.abspath.__doc__
618 abspath.__doc__ = path.path.abspath.__doc__
619
619
620 def normcase(self):
620 def normcase(self):
621 return ifile(path.path.normcase(self))
621 return ifile(path.path.normcase(self))
622 normcase.__doc__ = path.path.normcase.__doc__
622 normcase.__doc__ = path.path.normcase.__doc__
623
623
624 def normpath(self):
624 def normpath(self):
625 return ifile(path.path.normpath(self))
625 return ifile(path.path.normpath(self))
626 normpath.__doc__ = path.path.normpath.__doc__
626 normpath.__doc__ = path.path.normpath.__doc__
627
627
628 def realpath(self):
628 def realpath(self):
629 return ifile(path.path.realpath(self))
629 return ifile(path.path.realpath(self))
630 realpath.__doc__ = path.path.realpath.__doc__
630 realpath.__doc__ = path.path.realpath.__doc__
631
631
632 def expanduser(self):
632 def expanduser(self):
633 return ifile(path.path.expanduser(self))
633 return ifile(path.path.expanduser(self))
634 expanduser.__doc__ = path.path.expanduser.__doc__
634 expanduser.__doc__ = path.path.expanduser.__doc__
635
635
636 def expandvars(self):
636 def expandvars(self):
637 return ifile(path.path.expandvars(self))
637 return ifile(path.path.expandvars(self))
638 expandvars.__doc__ = path.path.expandvars.__doc__
638 expandvars.__doc__ = path.path.expandvars.__doc__
639
639
640 def dirname(self):
640 def dirname(self):
641 return ifile(path.path.dirname(self))
641 return ifile(path.path.dirname(self))
642 dirname.__doc__ = path.path.dirname.__doc__
642 dirname.__doc__ = path.path.dirname.__doc__
643
643
644 parent = property(dirname, None, None, path.path.parent.__doc__)
644 parent = property(dirname, None, None, path.path.parent.__doc__)
645
645
646 def splitpath(self):
646 def splitpath(self):
647 (parent, child) = path.path.splitpath(self)
647 (parent, child) = path.path.splitpath(self)
648 return (ifile(parent), child)
648 return (ifile(parent), child)
649 splitpath.__doc__ = path.path.splitpath.__doc__
649 splitpath.__doc__ = path.path.splitpath.__doc__
650
650
651 def splitdrive(self):
651 def splitdrive(self):
652 (drive, rel) = path.path.splitdrive(self)
652 (drive, rel) = path.path.splitdrive(self)
653 return (ifile(drive), rel)
653 return (ifile(drive), rel)
654 splitdrive.__doc__ = path.path.splitdrive.__doc__
654 splitdrive.__doc__ = path.path.splitdrive.__doc__
655
655
656 def splitext(self):
656 def splitext(self):
657 (filename, ext) = path.path.splitext(self)
657 (filename, ext) = path.path.splitext(self)
658 return (ifile(filename), ext)
658 return (ifile(filename), ext)
659 splitext.__doc__ = path.path.splitext.__doc__
659 splitext.__doc__ = path.path.splitext.__doc__
660
660
661 if hasattr(path.path, "splitunc"):
661 if hasattr(path.path, "splitunc"):
662 def splitunc(self):
662 def splitunc(self):
663 (unc, rest) = path.path.splitunc(self)
663 (unc, rest) = path.path.splitunc(self)
664 return (ifile(unc), rest)
664 return (ifile(unc), rest)
665 splitunc.__doc__ = path.path.splitunc.__doc__
665 splitunc.__doc__ = path.path.splitunc.__doc__
666
666
667 def _get_uncshare(self):
667 def _get_uncshare(self):
668 unc, r = os.path.splitunc(self)
668 unc, r = os.path.splitunc(self)
669 return ifile(unc)
669 return ifile(unc)
670
670
671 uncshare = property(
671 uncshare = property(
672 _get_uncshare, None, None,
672 _get_uncshare, None, None,
673 """ The UNC mount point for this path.
673 """ The UNC mount point for this path.
674 This is empty for paths on local drives. """)
674 This is empty for paths on local drives. """)
675
675
676 def joinpath(self, *args):
676 def joinpath(self, *args):
677 return ifile(path.path.joinpath(self, *args))
677 return ifile(path.path.joinpath(self, *args))
678 joinpath.__doc__ = path.path.joinpath.__doc__
678 joinpath.__doc__ = path.path.joinpath.__doc__
679
679
680 def splitall(self):
680 def splitall(self):
681 return map(ifile, path.path.splitall(self))
681 return map(ifile, path.path.splitall(self))
682 splitall.__doc__ = path.path.splitall.__doc__
682 splitall.__doc__ = path.path.splitall.__doc__
683
683
684 def relpath(self):
684 def relpath(self):
685 return ifile(path.path.relpath(self))
685 return ifile(path.path.relpath(self))
686 relpath.__doc__ = path.path.relpath.__doc__
686 relpath.__doc__ = path.path.relpath.__doc__
687
687
688 def relpathto(self, dest):
688 def relpathto(self, dest):
689 return ifile(path.path.relpathto(self, dest))
689 return ifile(path.path.relpathto(self, dest))
690 relpathto.__doc__ = path.path.relpathto.__doc__
690 relpathto.__doc__ = path.path.relpathto.__doc__
691
691
692 def listdir(self, pattern=None):
692 def listdir(self, pattern=None):
693 return [ifile(child) for child in path.path.listdir(self, pattern)]
693 return [ifile(child) for child in path.path.listdir(self, pattern)]
694 listdir.__doc__ = path.path.listdir.__doc__
694 listdir.__doc__ = path.path.listdir.__doc__
695
695
696 def dirs(self, pattern=None):
696 def dirs(self, pattern=None):
697 return [ifile(child) for child in path.path.dirs(self, pattern)]
697 return [ifile(child) for child in path.path.dirs(self, pattern)]
698 dirs.__doc__ = path.path.dirs.__doc__
698 dirs.__doc__ = path.path.dirs.__doc__
699
699
700 def files(self, pattern=None):
700 def files(self, pattern=None):
701 return [ifile(child) for child in path.path.files(self, pattern)]
701 return [ifile(child) for child in path.path.files(self, pattern)]
702 files.__doc__ = path.path.files.__doc__
702 files.__doc__ = path.path.files.__doc__
703
703
704 def walk(self, pattern=None):
704 def walk(self, pattern=None):
705 for child in path.path.walk(self, pattern):
705 for child in path.path.walk(self, pattern):
706 yield ifile(child)
706 yield ifile(child)
707 walk.__doc__ = path.path.walk.__doc__
707 walk.__doc__ = path.path.walk.__doc__
708
708
709 def walkdirs(self, pattern=None):
709 def walkdirs(self, pattern=None):
710 for child in path.path.walkdirs(self, pattern):
710 for child in path.path.walkdirs(self, pattern):
711 yield ifile(child)
711 yield ifile(child)
712 walkdirs.__doc__ = path.path.walkdirs.__doc__
712 walkdirs.__doc__ = path.path.walkdirs.__doc__
713
713
714 def walkfiles(self, pattern=None):
714 def walkfiles(self, pattern=None):
715 for child in path.path.walkfiles(self, pattern):
715 for child in path.path.walkfiles(self, pattern):
716 yield ifile(child)
716 yield ifile(child)
717 walkfiles.__doc__ = path.path.walkfiles.__doc__
717 walkfiles.__doc__ = path.path.walkfiles.__doc__
718
718
719 def glob(self, pattern):
719 def glob(self, pattern):
720 return map(ifile, path.path.glob(self, pattern))
720 return map(ifile, path.path.glob(self, pattern))
721 glob.__doc__ = path.path.glob.__doc__
721 glob.__doc__ = path.path.glob.__doc__
722
722
723 if hasattr(os, 'readlink'):
723 if hasattr(os, 'readlink'):
724 def readlink(self):
724 def readlink(self):
725 return ifile(path.path.readlink(self))
725 return ifile(path.path.readlink(self))
726 readlink.__doc__ = path.path.readlink.__doc__
726 readlink.__doc__ = path.path.readlink.__doc__
727
727
728 def readlinkabs(self):
728 def readlinkabs(self):
729 return ifile(path.path.readlinkabs(self))
729 return ifile(path.path.readlinkabs(self))
730 readlinkabs.__doc__ = path.path.readlinkabs.__doc__
730 readlinkabs.__doc__ = path.path.readlinkabs.__doc__
731
731
732 def getmode(self):
732 def getmode(self):
733 return self.stat().st_mode
733 return self.stat().st_mode
734 mode = property(getmode, None, None, "Access mode")
734 mode = property(getmode, None, None, "Access mode")
735
735
736 def gettype(self):
736 def gettype(self):
737 data = [
737 data = [
738 (stat.S_ISREG, "file"),
738 (stat.S_ISREG, "file"),
739 (stat.S_ISDIR, "dir"),
739 (stat.S_ISDIR, "dir"),
740 (stat.S_ISCHR, "chardev"),
740 (stat.S_ISCHR, "chardev"),
741 (stat.S_ISBLK, "blockdev"),
741 (stat.S_ISBLK, "blockdev"),
742 (stat.S_ISFIFO, "fifo"),
742 (stat.S_ISFIFO, "fifo"),
743 (stat.S_ISLNK, "symlink"),
743 (stat.S_ISLNK, "symlink"),
744 (stat.S_ISSOCK,"socket"),
744 (stat.S_ISSOCK,"socket"),
745 ]
745 ]
746 lstat = self.lstat()
746 lstat = self.lstat()
747 if lstat is not None:
747 if lstat is not None:
748 types = set([text for (func, text) in data if func(lstat.st_mode)])
748 types = set([text for (func, text) in data if func(lstat.st_mode)])
749 else:
749 else:
750 types = set()
750 types = set()
751 m = self.mode
751 m = self.mode
752 types.update([text for (func, text) in data if func(m)])
752 types.update([text for (func, text) in data if func(m)])
753 return ", ".join(types)
753 return ", ".join(types)
754 type = property(gettype, None, None, "file type (file, directory, link, etc.)")
754 type = property(gettype, None, None, "file type (file, directory, link, etc.)")
755
755
756 def getmodestr(self):
756 def getmodestr(self):
757 m = self.mode
757 m = self.mode
758 data = [
758 data = [
759 (stat.S_IRUSR, "-r"),
759 (stat.S_IRUSR, "-r"),
760 (stat.S_IWUSR, "-w"),
760 (stat.S_IWUSR, "-w"),
761 (stat.S_IXUSR, "-x"),
761 (stat.S_IXUSR, "-x"),
762 (stat.S_IRGRP, "-r"),
762 (stat.S_IRGRP, "-r"),
763 (stat.S_IWGRP, "-w"),
763 (stat.S_IWGRP, "-w"),
764 (stat.S_IXGRP, "-x"),
764 (stat.S_IXGRP, "-x"),
765 (stat.S_IROTH, "-r"),
765 (stat.S_IROTH, "-r"),
766 (stat.S_IWOTH, "-w"),
766 (stat.S_IWOTH, "-w"),
767 (stat.S_IXOTH, "-x"),
767 (stat.S_IXOTH, "-x"),
768 ]
768 ]
769 return "".join([text[bool(m&bit)] for (bit, text) in data])
769 return "".join([text[bool(m&bit)] for (bit, text) in data])
770
770
771 modestr = property(getmodestr, None, None, "Access mode as string")
771 modestr = property(getmodestr, None, None, "Access mode as string")
772
772
773 def getblocks(self):
773 def getblocks(self):
774 return self.stat().st_blocks
774 return self.stat().st_blocks
775 blocks = property(getblocks, None, None, "File size in blocks")
775 blocks = property(getblocks, None, None, "File size in blocks")
776
776
777 def getblksize(self):
777 def getblksize(self):
778 return self.stat().st_blksize
778 return self.stat().st_blksize
779 blksize = property(getblksize, None, None, "Filesystem block size")
779 blksize = property(getblksize, None, None, "Filesystem block size")
780
780
781 def getdev(self):
781 def getdev(self):
782 return self.stat().st_dev
782 return self.stat().st_dev
783 dev = property(getdev)
783 dev = property(getdev)
784
784
785 def getnlink(self):
785 def getnlink(self):
786 return self.stat().st_nlink
786 return self.stat().st_nlink
787 nlink = property(getnlink, None, None, "Number of links")
787 nlink = property(getnlink, None, None, "Number of links")
788
788
789 def getuid(self):
789 def getuid(self):
790 return self.stat().st_uid
790 return self.stat().st_uid
791 uid = property(getuid, None, None, "User id of file owner")
791 uid = property(getuid, None, None, "User id of file owner")
792
792
793 def getgid(self):
793 def getgid(self):
794 return self.stat().st_gid
794 return self.stat().st_gid
795 gid = property(getgid, None, None, "Group id of file owner")
795 gid = property(getgid, None, None, "Group id of file owner")
796
796
797 def getowner(self):
797 def getowner(self):
798 stat = self.stat()
798 stat = self.stat()
799 try:
799 try:
800 return pwd.getpwuid(stat.st_uid).pw_name
800 return pwd.getpwuid(stat.st_uid).pw_name
801 except KeyError:
801 except KeyError:
802 return stat.st_uid
802 return stat.st_uid
803 owner = property(getowner, None, None, "Owner name (or id)")
803 owner = property(getowner, None, None, "Owner name (or id)")
804
804
805 def getgroup(self):
805 def getgroup(self):
806 stat = self.stat()
806 stat = self.stat()
807 try:
807 try:
808 return grp.getgrgid(stat.st_gid).gr_name
808 return grp.getgrgid(stat.st_gid).gr_name
809 except KeyError:
809 except KeyError:
810 return stat.st_gid
810 return stat.st_gid
811 group = property(getgroup, None, None, "Group name (or id)")
811 group = property(getgroup, None, None, "Group name (or id)")
812
812
813 def getadate(self):
813 def getadate(self):
814 return datetime.datetime.utcfromtimestamp(self.atime)
814 return datetime.datetime.utcfromtimestamp(self.atime)
815 adate = property(getadate, None, None, "Access date")
815 adate = property(getadate, None, None, "Access date")
816
816
817 def getcdate(self):
817 def getcdate(self):
818 return datetime.datetime.utcfromtimestamp(self.ctime)
818 return datetime.datetime.utcfromtimestamp(self.ctime)
819 cdate = property(getcdate, None, None, "Creation date")
819 cdate = property(getcdate, None, None, "Creation date")
820
820
821 def getmdate(self):
821 def getmdate(self):
822 return datetime.datetime.utcfromtimestamp(self.mtime)
822 return datetime.datetime.utcfromtimestamp(self.mtime)
823 mdate = property(getmdate, None, None, "Modification date")
823 mdate = property(getmdate, None, None, "Modification date")
824
824
825 def getmimetype(self):
825 def getmimetype(self):
826 return mimetypes.guess_type(self.basename())[0]
826 return mimetypes.guess_type(self.basename())[0]
827 mimetype = property(getmimetype, None, None, "MIME type")
827 mimetype = property(getmimetype, None, None, "MIME type")
828
828
829 def getencoding(self):
829 def getencoding(self):
830 return mimetypes.guess_type(self.basename())[1]
830 return mimetypes.guess_type(self.basename())[1]
831 encoding = property(getencoding, None, None, "Compression")
831 encoding = property(getencoding, None, None, "Compression")
832
832
833 def __repr__(self):
833 def __repr__(self):
834 return "ifile(%s)" % path._base.__repr__(self)
834 return "ifile(%s)" % path._base.__repr__(self)
835
835
836 defaultattrs = (None, "type", "size", "modestr", "owner", "group", "mdate")
836 defaultattrs = (None, "type", "size", "modestr", "owner", "group", "mdate")
837
837
838 def __xattrs__(self, mode):
838 def __xattrs__(self, mode):
839 if mode == "detail":
839 if mode == "detail":
840 return (
840 return (
841 "name", "basename()", "abspath()", "realpath()",
841 "name", "basename()", "abspath()", "realpath()",
842 "type", "mode", "modestr", "stat()", "lstat()",
842 "type", "mode", "modestr", "stat()", "lstat()",
843 "uid", "gid", "owner", "group", "dev", "nlink",
843 "uid", "gid", "owner", "group", "dev", "nlink",
844 "ctime", "mtime", "atime", "cdate", "mdate", "adate",
844 "ctime", "mtime", "atime", "cdate", "mdate", "adate",
845 "size", "blocks", "blksize", "isdir()", "islink()",
845 "size", "blocks", "blksize", "isdir()", "islink()",
846 "mimetype", "encoding"
846 "mimetype", "encoding"
847 )
847 )
848 return self.defaultattrs
848 return self.defaultattrs
849
849
850 def __xrepr__(self, mode):
850 def __xrepr__(self, mode):
851 try:
851 try:
852 if self.isdir():
852 if self.isdir():
853 name = "idir"
853 name = "idir"
854 style = astyle.style_dir
854 style = astyle.style_dir
855 else:
855 else:
856 name = "ifile"
856 name = "ifile"
857 style = astyle.style_file
857 style = astyle.style_file
858 except IOError:
858 except IOError:
859 name = "ifile"
859 name = "ifile"
860 style = astyle.style_default
860 style = astyle.style_default
861 if mode == "cell" or mode in "header" or mode == "footer":
861 if mode == "cell" or mode in "header" or mode == "footer":
862 abspath = repr(path._base(self.normpath()))
862 abspath = repr(path._base(self.normpath()))
863 if abspath.startswith("u"):
863 if abspath.startswith("u"):
864 abspath = abspath[2:-1]
864 abspath = abspath[2:-1]
865 else:
865 else:
866 abspath = abspath[1:-1]
866 abspath = abspath[1:-1]
867 if mode == "cell":
867 if mode == "cell":
868 yield (style, abspath)
868 yield (style, abspath)
869 else:
869 else:
870 yield (style, "%s(%s)" % (name, abspath))
870 yield (style, "%s(%s)" % (name, abspath))
871 else:
871 else:
872 yield (style, repr(self))
872 yield (style, repr(self))
873
873
874 def __xiter__(self, mode):
874 def __xiter__(self, mode):
875 if self.isdir():
875 if self.isdir():
876 yield iparentdir(self / os.pardir)
876 yield iparentdir(self / os.pardir)
877 for child in sorted(self.listdir()):
877 for child in sorted(self.listdir()):
878 yield child
878 yield child
879 else:
879 else:
880 f = self.open("rb")
880 f = self.open("rb")
881 for line in f:
881 for line in f:
882 yield line
882 yield line
883 f.close()
883 f.close()
884
884
885
885
886 class iparentdir(ifile):
886 class iparentdir(ifile):
887 def __xrepr__(self, mode):
887 def __xrepr__(self, mode):
888 if mode == "cell":
888 if mode == "cell":
889 yield (astyle.style_dir, os.pardir)
889 yield (astyle.style_dir, os.pardir)
890 else:
890 else:
891 for part in ifile.__xrepr__(self, mode):
891 for part in ifile.__xrepr__(self, mode):
892 yield part
892 yield part
893
893
894
894
895 class ils(Table):
895 class ils(Table):
896 """
896 """
897 List the current (or a specific) directory.
897 List the current (or a specific) directory.
898
898
899 Examples:
899 Examples:
900
900
901 >>> ils
901 >>> ils
902 >>> ils("/usr/local/lib/python2.4")
902 >>> ils("/usr/local/lib/python2.4")
903 >>> ils("~")
903 >>> ils("~")
904 """
904 """
905 def __init__(self, base=os.curdir):
905 def __init__(self, base=os.curdir):
906 self.base = os.path.expanduser(base)
906 self.base = os.path.expanduser(base)
907
907
908 def __xiter__(self, mode):
908 def __xiter__(self, mode):
909 return xiter(ifile(self.base), mode)
909 return xiter(ifile(self.base), mode)
910
910
911 def __xrepr__(self, mode):
911 def __xrepr__(self, mode):
912 return ifile(self.base).__xrepr__(mode)
912 return ifile(self.base).__xrepr__(mode)
913
913
914 def __repr__(self):
914 def __repr__(self):
915 return "%s.%s(%r)" % \
915 return "%s.%s(%r)" % \
916 (self.__class__.__module__, self.__class__.__name__, self.base)
916 (self.__class__.__module__, self.__class__.__name__, self.base)
917
917
918
918
919 class iglob(Table):
919 class iglob(Table):
920 """
920 """
921 List all files and directories matching a specified pattern.
921 List all files and directories matching a specified pattern.
922 (See ``glob.glob()`` for more info.).
922 (See ``glob.glob()`` for more info.).
923
923
924 Examples:
924 Examples:
925
925
926 >>> iglob("*.py")
926 >>> iglob("*.py")
927 """
927 """
928 def __init__(self, glob):
928 def __init__(self, glob):
929 self.glob = glob
929 self.glob = glob
930
930
931 def __xiter__(self, mode):
931 def __xiter__(self, mode):
932 for name in glob.glob(self.glob):
932 for name in glob.glob(self.glob):
933 yield ifile(name)
933 yield ifile(name)
934
934
935 def __xrepr__(self, mode):
935 def __xrepr__(self, mode):
936 if mode == "header" or mode == "footer" or mode == "cell":
936 if mode == "header" or mode == "footer" or mode == "cell":
937 yield (astyle.style_default,
937 yield (astyle.style_default,
938 "%s(%r)" % (self.__class__.__name__, self.glob))
938 "%s(%r)" % (self.__class__.__name__, self.glob))
939 else:
939 else:
940 yield (astyle.style_default, repr(self))
940 yield (astyle.style_default, repr(self))
941
941
942 def __repr__(self):
942 def __repr__(self):
943 return "%s.%s(%r)" % \
943 return "%s.%s(%r)" % \
944 (self.__class__.__module__, self.__class__.__name__, self.glob)
944 (self.__class__.__module__, self.__class__.__name__, self.glob)
945
945
946
946
947 class iwalk(Table):
947 class iwalk(Table):
948 """
948 """
949 List all files and directories in a directory and it's subdirectory.
949 List all files and directories in a directory and it's subdirectory.
950
950
951 >>> iwalk
951 >>> iwalk
952 >>> iwalk("/usr/local/lib/python2.4")
952 >>> iwalk("/usr/local/lib/python2.4")
953 >>> iwalk("~")
953 >>> iwalk("~")
954 """
954 """
955 def __init__(self, base=os.curdir, dirs=True, files=True):
955 def __init__(self, base=os.curdir, dirs=True, files=True):
956 self.base = os.path.expanduser(base)
956 self.base = os.path.expanduser(base)
957 self.dirs = dirs
957 self.dirs = dirs
958 self.files = files
958 self.files = files
959
959
960 def __xiter__(self, mode):
960 def __xiter__(self, mode):
961 for (dirpath, dirnames, filenames) in os.walk(self.base):
961 for (dirpath, dirnames, filenames) in os.walk(self.base):
962 if self.dirs:
962 if self.dirs:
963 for name in sorted(dirnames):
963 for name in sorted(dirnames):
964 yield ifile(os.path.join(dirpath, name))
964 yield ifile(os.path.join(dirpath, name))
965 if self.files:
965 if self.files:
966 for name in sorted(filenames):
966 for name in sorted(filenames):
967 yield ifile(os.path.join(dirpath, name))
967 yield ifile(os.path.join(dirpath, name))
968
968
969 def __xrepr__(self, mode):
969 def __xrepr__(self, mode):
970 if mode == "header" or mode == "footer" or mode == "cell":
970 if mode == "header" or mode == "footer" or mode == "cell":
971 yield (astyle.style_default,
971 yield (astyle.style_default,
972 "%s(%r)" % (self.__class__.__name__, self.base))
972 "%s(%r)" % (self.__class__.__name__, self.base))
973 else:
973 else:
974 yield (astyle.style_default, repr(self))
974 yield (astyle.style_default, repr(self))
975
975
976 def __repr__(self):
976 def __repr__(self):
977 return "%s.%s(%r)" % \
977 return "%s.%s(%r)" % \
978 (self.__class__.__module__, self.__class__.__name__, self.base)
978 (self.__class__.__module__, self.__class__.__name__, self.base)
979
979
980
980
981 class ipwdentry(object):
981 class ipwdentry(object):
982 """
982 """
983 ``ipwdentry`` objects encapsulate entries in the Unix user account and
983 ``ipwdentry`` objects encapsulate entries in the Unix user account and
984 password database.
984 password database.
985 """
985 """
986 def __init__(self, id):
986 def __init__(self, id):
987 self._id = id
987 self._id = id
988 self._entry = None
988 self._entry = None
989
989
990 def _getentry(self):
990 def _getentry(self):
991 if self._entry is None:
991 if self._entry is None:
992 if isinstance(self._id, basestring):
992 if isinstance(self._id, basestring):
993 self._entry = pwd.getpwnam(self._id)
993 self._entry = pwd.getpwnam(self._id)
994 else:
994 else:
995 self._entry = pwd.getpwuid(self._id)
995 self._entry = pwd.getpwuid(self._id)
996 return self._entry
996 return self._entry
997
997
998 def getname(self):
998 def getname(self):
999 if isinstance(self._id, basestring):
999 if isinstance(self._id, basestring):
1000 return self._id
1000 return self._id
1001 else:
1001 else:
1002 return self._getentry().pw_name
1002 return self._getentry().pw_name
1003 name = property(getname, None, None, "User name")
1003 name = property(getname, None, None, "User name")
1004
1004
1005 def getpasswd(self):
1005 def getpasswd(self):
1006 return self._getentry().pw_passwd
1006 return self._getentry().pw_passwd
1007 passwd = property(getpasswd, None, None, "Password")
1007 passwd = property(getpasswd, None, None, "Password")
1008
1008
1009 def getuid(self):
1009 def getuid(self):
1010 if isinstance(self._id, basestring):
1010 if isinstance(self._id, basestring):
1011 return self._getentry().pw_uid
1011 return self._getentry().pw_uid
1012 else:
1012 else:
1013 return self._id
1013 return self._id
1014 uid = property(getuid, None, None, "User id")
1014 uid = property(getuid, None, None, "User id")
1015
1015
1016 def getgid(self):
1016 def getgid(self):
1017 return self._getentry().pw_gid
1017 return self._getentry().pw_gid
1018 gid = property(getgid, None, None, "Primary group id")
1018 gid = property(getgid, None, None, "Primary group id")
1019
1019
1020 def getgroup(self):
1020 def getgroup(self):
1021 return igrpentry(self.gid)
1021 return igrpentry(self.gid)
1022 group = property(getgroup, None, None, "Group")
1022 group = property(getgroup, None, None, "Group")
1023
1023
1024 def getgecos(self):
1024 def getgecos(self):
1025 return self._getentry().pw_gecos
1025 return self._getentry().pw_gecos
1026 gecos = property(getgecos, None, None, "Information (e.g. full user name)")
1026 gecos = property(getgecos, None, None, "Information (e.g. full user name)")
1027
1027
1028 def getdir(self):
1028 def getdir(self):
1029 return self._getentry().pw_dir
1029 return self._getentry().pw_dir
1030 dir = property(getdir, None, None, "$HOME directory")
1030 dir = property(getdir, None, None, "$HOME directory")
1031
1031
1032 def getshell(self):
1032 def getshell(self):
1033 return self._getentry().pw_shell
1033 return self._getentry().pw_shell
1034 shell = property(getshell, None, None, "Login shell")
1034 shell = property(getshell, None, None, "Login shell")
1035
1035
1036 def __xattrs__(self, mode):
1036 def __xattrs__(self, mode):
1037 return ("name", "passwd", "uid", "gid", "gecos", "dir", "shell")
1037 return ("name", "passwd", "uid", "gid", "gecos", "dir", "shell")
1038
1038
1039 def __repr__(self):
1039 def __repr__(self):
1040 return "%s.%s(%r)" % \
1040 return "%s.%s(%r)" % \
1041 (self.__class__.__module__, self.__class__.__name__, self._id)
1041 (self.__class__.__module__, self.__class__.__name__, self._id)
1042
1042
1043
1043
1044 class ipwd(Table):
1044 class ipwd(Table):
1045 """
1045 """
1046 List all entries in the Unix user account and password database.
1046 List all entries in the Unix user account and password database.
1047
1047
1048 Example:
1048 Example:
1049
1049
1050 >>> ipwd | isort("uid")
1050 >>> ipwd | isort("uid")
1051 """
1051 """
1052 def __iter__(self):
1052 def __iter__(self):
1053 for entry in pwd.getpwall():
1053 for entry in pwd.getpwall():
1054 yield ipwdentry(entry.pw_name)
1054 yield ipwdentry(entry.pw_name)
1055
1055
1056 def __xrepr__(self, mode):
1056 def __xrepr__(self, mode):
1057 if mode == "header" or mode == "footer" or mode == "cell":
1057 if mode == "header" or mode == "footer" or mode == "cell":
1058 yield (astyle.style_default, "%s()" % self.__class__.__name__)
1058 yield (astyle.style_default, "%s()" % self.__class__.__name__)
1059 else:
1059 else:
1060 yield (astyle.style_default, repr(self))
1060 yield (astyle.style_default, repr(self))
1061
1061
1062
1062
1063 class igrpentry(object):
1063 class igrpentry(object):
1064 """
1064 """
1065 ``igrpentry`` objects encapsulate entries in the Unix group database.
1065 ``igrpentry`` objects encapsulate entries in the Unix group database.
1066 """
1066 """
1067 def __init__(self, id):
1067 def __init__(self, id):
1068 self._id = id
1068 self._id = id
1069 self._entry = None
1069 self._entry = None
1070
1070
1071 def _getentry(self):
1071 def _getentry(self):
1072 if self._entry is None:
1072 if self._entry is None:
1073 if isinstance(self._id, basestring):
1073 if isinstance(self._id, basestring):
1074 self._entry = grp.getgrnam(self._id)
1074 self._entry = grp.getgrnam(self._id)
1075 else:
1075 else:
1076 self._entry = grp.getgrgid(self._id)
1076 self._entry = grp.getgrgid(self._id)
1077 return self._entry
1077 return self._entry
1078
1078
1079 def getname(self):
1079 def getname(self):
1080 if isinstance(self._id, basestring):
1080 if isinstance(self._id, basestring):
1081 return self._id
1081 return self._id
1082 else:
1082 else:
1083 return self._getentry().gr_name
1083 return self._getentry().gr_name
1084 name = property(getname, None, None, "Group name")
1084 name = property(getname, None, None, "Group name")
1085
1085
1086 def getpasswd(self):
1086 def getpasswd(self):
1087 return self._getentry().gr_passwd
1087 return self._getentry().gr_passwd
1088 passwd = property(getpasswd, None, None, "Password")
1088 passwd = property(getpasswd, None, None, "Password")
1089
1089
1090 def getgid(self):
1090 def getgid(self):
1091 if isinstance(self._id, basestring):
1091 if isinstance(self._id, basestring):
1092 return self._getentry().gr_gid
1092 return self._getentry().gr_gid
1093 else:
1093 else:
1094 return self._id
1094 return self._id
1095 gid = property(getgid, None, None, "Group id")
1095 gid = property(getgid, None, None, "Group id")
1096
1096
1097 def getmem(self):
1097 def getmem(self):
1098 return self._getentry().gr_mem
1098 return self._getentry().gr_mem
1099 mem = property(getmem, None, None, "Members")
1099 mem = property(getmem, None, None, "Members")
1100
1100
1101 def __xattrs__(self, mode):
1101 def __xattrs__(self, mode):
1102 return ("name", "passwd", "gid", "mem")
1102 return ("name", "passwd", "gid", "mem")
1103
1103
1104 def __xrepr__(self, mode):
1104 def __xrepr__(self, mode):
1105 if mode == "header" or mode == "footer" or mode == "cell":
1105 if mode == "header" or mode == "footer" or mode == "cell":
1106 yield (astyle.style_default, "group ")
1106 yield (astyle.style_default, "group ")
1107 try:
1107 try:
1108 yield (astyle.style_default, self.name)
1108 yield (astyle.style_default, self.name)
1109 except KeyError:
1109 except KeyError:
1110 if isinstance(self._id, basestring):
1110 if isinstance(self._id, basestring):
1111 yield (astyle.style_default, self.name_id)
1111 yield (astyle.style_default, self.name_id)
1112 else:
1112 else:
1113 yield (astyle.style_type_number, str(self._id))
1113 yield (astyle.style_type_number, str(self._id))
1114 else:
1114 else:
1115 yield (astyle.style_default, repr(self))
1115 yield (astyle.style_default, repr(self))
1116
1116
1117 def __xiter__(self, mode):
1117 def __xiter__(self, mode):
1118 for member in self.mem:
1118 for member in self.mem:
1119 yield ipwdentry(member)
1119 yield ipwdentry(member)
1120
1120
1121 def __repr__(self):
1121 def __repr__(self):
1122 return "%s.%s(%r)" % \
1122 return "%s.%s(%r)" % \
1123 (self.__class__.__module__, self.__class__.__name__, self._id)
1123 (self.__class__.__module__, self.__class__.__name__, self._id)
1124
1124
1125
1125
1126 class igrp(Table):
1126 class igrp(Table):
1127 """
1127 """
1128 This ``Table`` lists all entries in the Unix group database.
1128 This ``Table`` lists all entries in the Unix group database.
1129 """
1129 """
1130 def __xiter__(self, mode):
1130 def __xiter__(self, mode):
1131 for entry in grp.getgrall():
1131 for entry in grp.getgrall():
1132 yield igrpentry(entry.gr_name)
1132 yield igrpentry(entry.gr_name)
1133
1133
1134 def __xrepr__(self, mode):
1134 def __xrepr__(self, mode):
1135 if mode == "header" or mode == "footer":
1135 if mode == "header" or mode == "footer":
1136 yield (astyle.style_default, "%s()" % self.__class__.__name__)
1136 yield (astyle.style_default, "%s()" % self.__class__.__name__)
1137 else:
1137 else:
1138 yield (astyle.style_default, repr(self))
1138 yield (astyle.style_default, repr(self))
1139
1139
1140
1140
1141 class Fields(object):
1141 class Fields(object):
1142 def __init__(self, fieldnames, **fields):
1142 def __init__(self, fieldnames, **fields):
1143 self.__fieldnames = fieldnames
1143 self.__fieldnames = fieldnames
1144 for (key, value) in fields.iteritems():
1144 for (key, value) in fields.iteritems():
1145 setattr(self, key, value)
1145 setattr(self, key, value)
1146
1146
1147 def __xattrs__(self, mode):
1147 def __xattrs__(self, mode):
1148 return self.__fieldnames
1148 return self.__fieldnames
1149
1149
1150 def __xrepr__(self, mode):
1150 def __xrepr__(self, mode):
1151 yield (-1, False)
1151 yield (-1, False)
1152 if mode == "header" or mode == "cell":
1152 if mode == "header" or mode == "cell":
1153 yield (astyle.style_default, self.__class__.__name__)
1153 yield (astyle.style_default, self.__class__.__name__)
1154 yield (astyle.style_default, "(")
1154 yield (astyle.style_default, "(")
1155 for (i, f) in enumerate(self.__fieldnames):
1155 for (i, f) in enumerate(self.__fieldnames):
1156 if i:
1156 if i:
1157 yield (astyle.style_default, ", ")
1157 yield (astyle.style_default, ", ")
1158 yield (astyle.style_default, f)
1158 yield (astyle.style_default, f)
1159 yield (astyle.style_default, "=")
1159 yield (astyle.style_default, "=")
1160 for part in xrepr(getattr(self, f), "default"):
1160 for part in xrepr(getattr(self, f), "default"):
1161 yield part
1161 yield part
1162 yield (astyle.style_default, ")")
1162 yield (astyle.style_default, ")")
1163 elif mode == "footer":
1163 elif mode == "footer":
1164 yield (astyle.style_default, self.__class__.__name__)
1164 yield (astyle.style_default, self.__class__.__name__)
1165 yield (astyle.style_default, "(")
1165 yield (astyle.style_default, "(")
1166 for (i, f) in enumerate(self.__fieldnames):
1166 for (i, f) in enumerate(self.__fieldnames):
1167 if i:
1167 if i:
1168 yield (astyle.style_default, ", ")
1168 yield (astyle.style_default, ", ")
1169 yield (astyle.style_default, f)
1169 yield (astyle.style_default, f)
1170 yield (astyle.style_default, ")")
1170 yield (astyle.style_default, ")")
1171 else:
1171 else:
1172 yield (astyle.style_default, repr(self))
1172 yield (astyle.style_default, repr(self))
1173
1173
1174
1174
1175 class FieldTable(Table, list):
1175 class FieldTable(Table, list):
1176 def __init__(self, *fields):
1176 def __init__(self, *fields):
1177 Table.__init__(self)
1177 Table.__init__(self)
1178 list.__init__(self)
1178 list.__init__(self)
1179 self.fields = fields
1179 self.fields = fields
1180
1180
1181 def add(self, **fields):
1181 def add(self, **fields):
1182 self.append(Fields(self.fields, **fields))
1182 self.append(Fields(self.fields, **fields))
1183
1183
1184 def __xiter__(self, mode):
1184 def __xiter__(self, mode):
1185 return list.__iter__(self)
1185 return list.__iter__(self)
1186
1186
1187 def __xrepr__(self, mode):
1187 def __xrepr__(self, mode):
1188 yield (-1, False)
1188 yield (-1, False)
1189 if mode == "header" or mode == "footer":
1189 if mode == "header" or mode == "footer":
1190 yield (astyle.style_default, self.__class__.__name__)
1190 yield (astyle.style_default, self.__class__.__name__)
1191 yield (astyle.style_default, "(")
1191 yield (astyle.style_default, "(")
1192 for (i, f) in enumerate(self.__fieldnames):
1192 for (i, f) in enumerate(self.__fieldnames):
1193 if i:
1193 if i:
1194 yield (astyle.style_default, ", ")
1194 yield (astyle.style_default, ", ")
1195 yield (astyle.style_default, f)
1195 yield (astyle.style_default, f)
1196 yield (astyle.style_default, ")")
1196 yield (astyle.style_default, ")")
1197 else:
1197 else:
1198 yield (astyle.style_default, repr(self))
1198 yield (astyle.style_default, repr(self))
1199
1199
1200 def __repr__(self):
1200 def __repr__(self):
1201 return "<%s.%s object with fields=%r at 0x%x>" % \
1201 return "<%s.%s object with fields=%r at 0x%x>" % \
1202 (self.__class__.__module__, self.__class__.__name__,
1202 (self.__class__.__module__, self.__class__.__name__,
1203 ", ".join(map(repr, self.fields)), id(self))
1203 ", ".join(map(repr, self.fields)), id(self))
1204
1204
1205
1205
1206 class List(list):
1206 class List(list):
1207 def __xattrs__(self, mode):
1207 def __xattrs__(self, mode):
1208 return xrange(len(self))
1208 return xrange(len(self))
1209
1209
1210 def __xrepr__(self, mode):
1210 def __xrepr__(self, mode):
1211 yield (-1, False)
1211 yield (-1, False)
1212 if mode == "header" or mode == "cell" or mode == "footer" or mode == "default":
1212 if mode == "header" or mode == "cell" or mode == "footer" or mode == "default":
1213 yield (astyle.style_default, self.__class__.__name__)
1213 yield (astyle.style_default, self.__class__.__name__)
1214 yield (astyle.style_default, "(")
1214 yield (astyle.style_default, "(")
1215 for (i, item) in enumerate(self):
1215 for (i, item) in enumerate(self):
1216 if i:
1216 if i:
1217 yield (astyle.style_default, ", ")
1217 yield (astyle.style_default, ", ")
1218 for part in xrepr(item, "default"):
1218 for part in xrepr(item, "default"):
1219 yield part
1219 yield part
1220 yield (astyle.style_default, ")")
1220 yield (astyle.style_default, ")")
1221 else:
1221 else:
1222 yield (astyle.style_default, repr(self))
1222 yield (astyle.style_default, repr(self))
1223
1223
1224
1224
1225 class ienv(Table):
1225 class ienv(Table):
1226 """
1226 """
1227 List environment variables.
1227 List environment variables.
1228
1228
1229 Example:
1229 Example:
1230
1230
1231 >>> ienv
1231 >>> ienv
1232 """
1232 """
1233
1233
1234 def __xiter__(self, mode):
1234 def __xiter__(self, mode):
1235 fields = ("key", "value")
1235 fields = ("key", "value")
1236 for (key, value) in os.environ.iteritems():
1236 for (key, value) in os.environ.iteritems():
1237 yield Fields(fields, key=key, value=value)
1237 yield Fields(fields, key=key, value=value)
1238
1238
1239 def __xrepr__(self, mode):
1239 def __xrepr__(self, mode):
1240 if mode == "header" or mode == "cell":
1240 if mode == "header" or mode == "cell":
1241 yield (astyle.style_default, "%s()" % self.__class__.__name__)
1241 yield (astyle.style_default, "%s()" % self.__class__.__name__)
1242 else:
1242 else:
1243 yield (astyle.style_default, repr(self))
1243 yield (astyle.style_default, repr(self))
1244
1244
1245
1245
1246 class icsv(Pipe):
1246 class icsv(Pipe):
1247 """
1247 """
1248 This ``Pipe`` lists turn the input (with must be a pipe outputting lines
1248 This ``Pipe`` lists turn the input (with must be a pipe outputting lines
1249 or an ``ifile``) into lines of CVS columns.
1249 or an ``ifile``) into lines of CVS columns.
1250 """
1250 """
1251 def __init__(self, **csvargs):
1251 def __init__(self, **csvargs):
1252 """
1252 """
1253 Create an ``icsv`` object. ``cvsargs`` will be passed through as
1253 Create an ``icsv`` object. ``cvsargs`` will be passed through as
1254 keyword arguments to ``cvs.reader()``.
1254 keyword arguments to ``cvs.reader()``.
1255 """
1255 """
1256 self.csvargs = csvargs
1256 self.csvargs = csvargs
1257
1257
1258 def __xiter__(self, mode):
1258 def __xiter__(self, mode):
1259 input = self.input
1259 input = self.input
1260 if isinstance(input, ifile):
1260 if isinstance(input, ifile):
1261 input = input.open("rb")
1261 input = input.open("rb")
1262 reader = csv.reader(input, **self.csvargs)
1262 reader = csv.reader(input, **self.csvargs)
1263 for line in reader:
1263 for line in reader:
1264 yield List(line)
1264 yield List(line)
1265
1265
1266 def __xrepr__(self, mode):
1266 def __xrepr__(self, mode):
1267 yield (-1, False)
1267 yield (-1, False)
1268 if mode == "header" or mode == "footer":
1268 if mode == "header" or mode == "footer":
1269 input = getattr(self, "input", None)
1269 input = getattr(self, "input", None)
1270 if input is not None:
1270 if input is not None:
1271 for part in xrepr(input, mode):
1271 for part in xrepr(input, mode):
1272 yield part
1272 yield part
1273 yield (astyle.style_default, " | ")
1273 yield (astyle.style_default, " | ")
1274 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1274 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1275 for (i, (name, value)) in enumerate(self.csvargs.iteritems()):
1275 for (i, (name, value)) in enumerate(self.csvargs.iteritems()):
1276 if i:
1276 if i:
1277 yield (astyle.style_default, ", ")
1277 yield (astyle.style_default, ", ")
1278 yield (astyle.style_default, name)
1278 yield (astyle.style_default, name)
1279 yield (astyle.style_default, "=")
1279 yield (astyle.style_default, "=")
1280 for part in xrepr(value, "default"):
1280 for part in xrepr(value, "default"):
1281 yield part
1281 yield part
1282 yield (astyle.style_default, ")")
1282 yield (astyle.style_default, ")")
1283 else:
1283 else:
1284 yield (astyle.style_default, repr(self))
1284 yield (astyle.style_default, repr(self))
1285
1285
1286 def __repr__(self):
1286 def __repr__(self):
1287 args = ", ".join(["%s=%r" % item for item in self.csvargs.iteritems()])
1287 args = ", ".join(["%s=%r" % item for item in self.csvargs.iteritems()])
1288 return "<%s.%s %s at 0x%x>" % \
1288 return "<%s.%s %s at 0x%x>" % \
1289 (self.__class__.__module__, self.__class__.__name__, args, id(self))
1289 (self.__class__.__module__, self.__class__.__name__, args, id(self))
1290
1290
1291
1291
1292 class ix(Table):
1292 class ix(Table):
1293 """
1293 """
1294 Execute a system command and list its output as lines
1294 Execute a system command and list its output as lines
1295 (similar to ``os.popen()``).
1295 (similar to ``os.popen()``).
1296
1296
1297 Examples:
1297 Examples:
1298
1298
1299 >>> ix("ps x")
1299 >>> ix("ps x")
1300 >>> ix("find .") | ifile
1300 >>> ix("find .") | ifile
1301 """
1301 """
1302 def __init__(self, cmd):
1302 def __init__(self, cmd):
1303 self.cmd = cmd
1303 self.cmd = cmd
1304 self._pipe = None
1304 self._pipe = None
1305
1305
1306 def __xiter__(self, mode):
1306 def __xiter__(self, mode):
1307 self._pipe = os.popen(self.cmd)
1307 self._pipe = os.popen(self.cmd)
1308 for l in self._pipe:
1308 for l in self._pipe:
1309 yield l.rstrip("\r\n")
1309 yield l.rstrip("\r\n")
1310 self._pipe.close()
1310 self._pipe.close()
1311 self._pipe = None
1311 self._pipe = None
1312
1312
1313 def __del__(self):
1313 def __del__(self):
1314 if self._pipe is not None and not self._pipe.closed:
1314 if self._pipe is not None and not self._pipe.closed:
1315 self._pipe.close()
1315 self._pipe.close()
1316 self._pipe = None
1316 self._pipe = None
1317
1317
1318 def __xrepr__(self, mode):
1318 def __xrepr__(self, mode):
1319 if mode == "header" or mode == "footer":
1319 if mode == "header" or mode == "footer":
1320 yield (astyle.style_default,
1320 yield (astyle.style_default,
1321 "%s(%r)" % (self.__class__.__name__, self.cmd))
1321 "%s(%r)" % (self.__class__.__name__, self.cmd))
1322 else:
1322 else:
1323 yield (astyle.style_default, repr(self))
1323 yield (astyle.style_default, repr(self))
1324
1324
1325 def __repr__(self):
1325 def __repr__(self):
1326 return "%s.%s(%r)" % \
1326 return "%s.%s(%r)" % \
1327 (self.__class__.__module__, self.__class__.__name__, self.cmd)
1327 (self.__class__.__module__, self.__class__.__name__, self.cmd)
1328
1328
1329
1329
1330 class ifilter(Pipe):
1330 class ifilter(Pipe):
1331 """
1331 """
1332 Filter an input pipe. Only objects where an expression evaluates to true
1332 Filter an input pipe. Only objects where an expression evaluates to true
1333 (and doesn't raise an exception) are listed.
1333 (and doesn't raise an exception) are listed.
1334
1334
1335 Examples:
1335 Examples:
1336
1336
1337 >>> ils | ifilter("_.isfile() and size>1000")
1337 >>> ils | ifilter("_.isfile() and size>1000")
1338 >>> igrp | ifilter("len(mem)")
1338 >>> igrp | ifilter("len(mem)")
1339 >>> sys.modules | ifilter(lambda _:_.value is not None)
1339 >>> sys.modules | ifilter(lambda _:_.value is not None)
1340 """
1340 """
1341
1341
1342 def __init__(self, expr, globals=None, errors="raiseifallfail"):
1342 def __init__(self, expr, globals=None, errors="raiseifallfail"):
1343 """
1343 """
1344 Create an ``ifilter`` object. ``expr`` can be a callable or a string
1344 Create an ``ifilter`` object. ``expr`` can be a callable or a string
1345 containing an expression. ``globals`` will be used as the global
1345 containing an expression. ``globals`` will be used as the global
1346 namespace for calling string expressions (defaulting to IPython's
1346 namespace for calling string expressions (defaulting to IPython's
1347 user namespace). ``errors`` specifies how exception during evaluation
1347 user namespace). ``errors`` specifies how exception during evaluation
1348 of ``expr`` are handled:
1348 of ``expr`` are handled:
1349
1349
1350 * ``drop``: drop all items that have errors;
1350 * ``drop``: drop all items that have errors;
1351
1351
1352 * ``keep``: keep all items that have errors;
1352 * ``keep``: keep all items that have errors;
1353
1353
1354 * ``keeperror``: keep the exception of all items that have errors;
1354 * ``keeperror``: keep the exception of all items that have errors;
1355
1355
1356 * ``raise``: raise the exception;
1356 * ``raise``: raise the exception;
1357
1357
1358 * ``raiseifallfail``: raise the first exception if all items have errors;
1358 * ``raiseifallfail``: raise the first exception if all items have errors;
1359 otherwise drop those with errors (this is the default).
1359 otherwise drop those with errors (this is the default).
1360 """
1360 """
1361 self.expr = expr
1361 self.expr = expr
1362 self.globals = globals
1362 self.globals = globals
1363 self.errors = errors
1363 self.errors = errors
1364
1364
1365 def __xiter__(self, mode):
1365 def __xiter__(self, mode):
1366 if callable(self.expr):
1366 if callable(self.expr):
1367 test = self.expr
1367 test = self.expr
1368 else:
1368 else:
1369 g = getglobals(self.globals)
1369 g = getglobals(self.globals)
1370 expr = compile(self.expr, "ipipe-expression", "eval")
1370 expr = compile(self.expr, "ipipe-expression", "eval")
1371 def test(item):
1371 def test(item):
1372 return eval(expr, g, AttrNamespace(item))
1372 return eval(expr, g, AttrNamespace(item))
1373
1373
1374 ok = 0
1374 ok = 0
1375 exc_info = None
1375 exc_info = None
1376 for item in xiter(self.input, mode):
1376 for item in xiter(self.input, mode):
1377 try:
1377 try:
1378 if test(item):
1378 if test(item):
1379 yield item
1379 yield item
1380 ok += 1
1380 ok += 1
1381 except (KeyboardInterrupt, SystemExit):
1381 except (KeyboardInterrupt, SystemExit):
1382 raise
1382 raise
1383 except Exception, exc:
1383 except Exception, exc:
1384 if self.errors == "drop":
1384 if self.errors == "drop":
1385 pass # Ignore errors
1385 pass # Ignore errors
1386 elif self.errors == "keep":
1386 elif self.errors == "keep":
1387 yield item
1387 yield item
1388 elif self.errors == "keeperror":
1388 elif self.errors == "keeperror":
1389 yield exc
1389 yield exc
1390 elif self.errors == "raise":
1390 elif self.errors == "raise":
1391 raise
1391 raise
1392 elif self.errors == "raiseifallfail":
1392 elif self.errors == "raiseifallfail":
1393 if exc_info is None:
1393 if exc_info is None:
1394 exc_info = sys.exc_info()
1394 exc_info = sys.exc_info()
1395 if not ok and exc_info is not None:
1395 if not ok and exc_info is not None:
1396 raise exc_info[0], exc_info[1], exc_info[2]
1396 raise exc_info[0], exc_info[1], exc_info[2]
1397
1397
1398 def __xrepr__(self, mode):
1398 def __xrepr__(self, mode):
1399 if mode == "header" or mode == "footer":
1399 if mode == "header" or mode == "footer":
1400 input = getattr(self, "input", None)
1400 input = getattr(self, "input", None)
1401 if input is not None:
1401 if input is not None:
1402 for part in xrepr(input, mode):
1402 for part in xrepr(input, mode):
1403 yield part
1403 yield part
1404 yield (astyle.style_default, " | ")
1404 yield (astyle.style_default, " | ")
1405 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1405 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1406 for part in xrepr(self.expr, "default"):
1406 for part in xrepr(self.expr, "default"):
1407 yield part
1407 yield part
1408 yield (astyle.style_default, ")")
1408 yield (astyle.style_default, ")")
1409 else:
1409 else:
1410 yield (astyle.style_default, repr(self))
1410 yield (astyle.style_default, repr(self))
1411
1411
1412 def __repr__(self):
1412 def __repr__(self):
1413 return "<%s.%s expr=%r at 0x%x>" % \
1413 return "<%s.%s expr=%r at 0x%x>" % \
1414 (self.__class__.__module__, self.__class__.__name__,
1414 (self.__class__.__module__, self.__class__.__name__,
1415 self.expr, id(self))
1415 self.expr, id(self))
1416
1416
1417
1417
1418 class ieval(Pipe):
1418 class ieval(Pipe):
1419 """
1419 """
1420 Evaluate an expression for each object in the input pipe.
1420 Evaluate an expression for each object in the input pipe.
1421
1421
1422 Examples:
1422 Examples:
1423
1423
1424 >>> ils | ieval("_.abspath()")
1424 >>> ils | ieval("_.abspath()")
1425 >>> sys.path | ieval(ifile)
1425 >>> sys.path | ieval(ifile)
1426 """
1426 """
1427
1427
1428 def __init__(self, expr, globals=None, errors="raiseifallfail"):
1428 def __init__(self, expr, globals=None, errors="raiseifallfail"):
1429 """
1429 """
1430 Create an ``ieval`` object. ``expr`` can be a callable or a string
1430 Create an ``ieval`` object. ``expr`` can be a callable or a string
1431 containing an expression. For the meaning of ``globals`` and
1431 containing an expression. For the meaning of ``globals`` and
1432 ``errors`` see ``ifilter``.
1432 ``errors`` see ``ifilter``.
1433 """
1433 """
1434 self.expr = expr
1434 self.expr = expr
1435 self.globals = globals
1435 self.globals = globals
1436 self.errors = errors
1436 self.errors = errors
1437
1437
1438 def __xiter__(self, mode):
1438 def __xiter__(self, mode):
1439 if callable(self.expr):
1439 if callable(self.expr):
1440 do = self.expr
1440 do = self.expr
1441 else:
1441 else:
1442 g = getglobals(self.globals)
1442 g = getglobals(self.globals)
1443 expr = compile(self.expr, "ipipe-expression", "eval")
1443 expr = compile(self.expr, "ipipe-expression", "eval")
1444 def do(item):
1444 def do(item):
1445 return eval(expr, g, AttrNamespace(item))
1445 return eval(expr, g, AttrNamespace(item))
1446
1446
1447 ok = 0
1447 ok = 0
1448 exc_info = None
1448 exc_info = None
1449 for item in xiter(self.input, mode):
1449 for item in xiter(self.input, mode):
1450 try:
1450 try:
1451 yield do(item)
1451 yield do(item)
1452 except (KeyboardInterrupt, SystemExit):
1452 except (KeyboardInterrupt, SystemExit):
1453 raise
1453 raise
1454 except Exception, exc:
1454 except Exception, exc:
1455 if self.errors == "drop":
1455 if self.errors == "drop":
1456 pass # Ignore errors
1456 pass # Ignore errors
1457 elif self.errors == "keep":
1457 elif self.errors == "keep":
1458 yield item
1458 yield item
1459 elif self.errors == "keeperror":
1459 elif self.errors == "keeperror":
1460 yield exc
1460 yield exc
1461 elif self.errors == "raise":
1461 elif self.errors == "raise":
1462 raise
1462 raise
1463 elif self.errors == "raiseifallfail":
1463 elif self.errors == "raiseifallfail":
1464 if exc_info is None:
1464 if exc_info is None:
1465 exc_info = sys.exc_info()
1465 exc_info = sys.exc_info()
1466 if not ok and exc_info is not None:
1466 if not ok and exc_info is not None:
1467 raise exc_info[0], exc_info[1], exc_info[2]
1467 raise exc_info[0], exc_info[1], exc_info[2]
1468
1468
1469 def __xrepr__(self, mode):
1469 def __xrepr__(self, mode):
1470 if mode == "header" or mode == "footer":
1470 if mode == "header" or mode == "footer":
1471 input = getattr(self, "input", None)
1471 input = getattr(self, "input", None)
1472 if input is not None:
1472 if input is not None:
1473 for part in xrepr(input, mode):
1473 for part in xrepr(input, mode):
1474 yield part
1474 yield part
1475 yield (astyle.style_default, " | ")
1475 yield (astyle.style_default, " | ")
1476 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1476 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1477 for part in xrepr(self.expr, "default"):
1477 for part in xrepr(self.expr, "default"):
1478 yield part
1478 yield part
1479 yield (astyle.style_default, ")")
1479 yield (astyle.style_default, ")")
1480 else:
1480 else:
1481 yield (astyle.style_default, repr(self))
1481 yield (astyle.style_default, repr(self))
1482
1482
1483 def __repr__(self):
1483 def __repr__(self):
1484 return "<%s.%s expr=%r at 0x%x>" % \
1484 return "<%s.%s expr=%r at 0x%x>" % \
1485 (self.__class__.__module__, self.__class__.__name__,
1485 (self.__class__.__module__, self.__class__.__name__,
1486 self.expr, id(self))
1486 self.expr, id(self))
1487
1487
1488
1488
1489 class ienum(Pipe):
1489 class ienum(Pipe):
1490 """
1490 """
1491 Enumerate the input pipe (i.e. wrap each input object in an object
1491 Enumerate the input pipe (i.e. wrap each input object in an object
1492 with ``index`` and ``object`` attributes).
1492 with ``index`` and ``object`` attributes).
1493
1493
1494 Examples:
1494 Examples:
1495
1495
1496 >>> xrange(20) | ieval("_,_*_") | ienum | ifilter("index % 2 == 0") | ieval("object")
1496 >>> xrange(20) | ieval("_,_*_") | ienum | ifilter("index % 2 == 0") | ieval("object")
1497 """
1497 """
1498 def __xiter__(self, mode):
1498 def __xiter__(self, mode):
1499 fields = ("index", "object")
1499 fields = ("index", "object")
1500 for (index, object) in enumerate(xiter(self.input, mode)):
1500 for (index, object) in enumerate(xiter(self.input, mode)):
1501 yield Fields(fields, index=index, object=object)
1501 yield Fields(fields, index=index, object=object)
1502
1502
1503
1503
1504 class isort(Pipe):
1504 class isort(Pipe):
1505 """
1505 """
1506 Sorts the input pipe.
1506 Sorts the input pipe.
1507
1507
1508 Examples:
1508 Examples:
1509
1509
1510 >>> ils | isort("size")
1510 >>> ils | isort("size")
1511 >>> ils | isort("_.isdir(), _.lower()", reverse=True)
1511 >>> ils | isort("_.isdir(), _.lower()", reverse=True)
1512 """
1512 """
1513
1513
1514 def __init__(self, key, globals=None, reverse=False):
1514 def __init__(self, key=None, globals=None, reverse=False):
1515 """
1515 """
1516 Create an ``isort`` object. ``key`` can be a callable or a string
1516 Create an ``isort`` object. ``key`` can be a callable or a string
1517 containing an expression. If ``reverse`` is true the sort order will
1517 containing an expression (or ``None`` in which case the items
1518 be reversed. For the meaning of ``globals`` see ``ifilter``.
1518 themselves will be sorted). If ``reverse`` is true the sort order
1519 will be reversed. For the meaning of ``globals`` see ``ifilter``.
1519 """
1520 """
1520 self.key = key
1521 self.key = key
1521 self.globals = globals
1522 self.globals = globals
1522 self.reverse = reverse
1523 self.reverse = reverse
1523
1524
1524 def __xiter__(self, mode):
1525 def __xiter__(self, mode):
1525 if callable(self.key):
1526 if self.key is None:
1527 items = sorted(
1528 xiter(self.input, mode),
1529 reverse=self.reverse
1530 )
1531 elif callable(self.key):
1526 items = sorted(
1532 items = sorted(
1527 xiter(self.input, mode),
1533 xiter(self.input, mode),
1528 key=self.key,
1534 key=self.key,
1529 reverse=self.reverse
1535 reverse=self.reverse
1530 )
1536 )
1531 else:
1537 else:
1532 g = getglobals(self.globals)
1538 g = getglobals(self.globals)
1533 key = compile(self.key, "ipipe-expression", "eval")
1539 key = compile(self.key, "ipipe-expression", "eval")
1534 def realkey(item):
1540 def realkey(item):
1535 return eval(key, g, AttrNamespace(item))
1541 return eval(key, g, AttrNamespace(item))
1536 items = sorted(
1542 items = sorted(
1537 xiter(self.input, mode),
1543 xiter(self.input, mode),
1538 key=realkey,
1544 key=realkey,
1539 reverse=self.reverse
1545 reverse=self.reverse
1540 )
1546 )
1541 for item in items:
1547 for item in items:
1542 yield item
1548 yield item
1543
1549
1544 def __xrepr__(self, mode):
1550 def __xrepr__(self, mode):
1545 if mode == "header" or mode == "footer":
1551 if mode == "header" or mode == "footer":
1546 input = getattr(self, "input", None)
1552 input = getattr(self, "input", None)
1547 if input is not None:
1553 if input is not None:
1548 for part in xrepr(input, mode):
1554 for part in xrepr(input, mode):
1549 yield part
1555 yield part
1550 yield (astyle.style_default, " | ")
1556 yield (astyle.style_default, " | ")
1551 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1557 yield (astyle.style_default, "%s(" % self.__class__.__name__)
1552 for part in xrepr(self.key, "default"):
1558 for part in xrepr(self.key, "default"):
1553 yield part
1559 yield part
1554 if self.reverse:
1560 if self.reverse:
1555 yield (astyle.style_default, ", ")
1561 yield (astyle.style_default, ", ")
1556 for part in xrepr(True, "default"):
1562 for part in xrepr(True, "default"):
1557 yield part
1563 yield part
1558 yield (astyle.style_default, ")")
1564 yield (astyle.style_default, ")")
1559 else:
1565 else:
1560 yield (astyle.style_default, repr(self))
1566 yield (astyle.style_default, repr(self))
1561
1567
1562 def __repr__(self):
1568 def __repr__(self):
1563 return "<%s.%s key=%r reverse=%r at 0x%x>" % \
1569 return "<%s.%s key=%r reverse=%r at 0x%x>" % \
1564 (self.__class__.__module__, self.__class__.__name__,
1570 (self.__class__.__module__, self.__class__.__name__,
1565 self.key, self.reverse, id(self))
1571 self.key, self.reverse, id(self))
1566
1572
1567
1573
1568 tab = 3 # for expandtabs()
1574 tab = 3 # for expandtabs()
1569
1575
1570 def _format(field):
1576 def _format(field):
1571 if isinstance(field, str):
1577 if isinstance(field, str):
1572 text = repr(field.expandtabs(tab))[1:-1]
1578 text = repr(field.expandtabs(tab))[1:-1]
1573 elif isinstance(field, unicode):
1579 elif isinstance(field, unicode):
1574 text = repr(field.expandtabs(tab))[2:-1]
1580 text = repr(field.expandtabs(tab))[2:-1]
1575 elif isinstance(field, datetime.datetime):
1581 elif isinstance(field, datetime.datetime):
1576 # Don't use strftime() here, as this requires year >= 1900
1582 # Don't use strftime() here, as this requires year >= 1900
1577 text = "%04d-%02d-%02d %02d:%02d:%02d.%06d" % \
1583 text = "%04d-%02d-%02d %02d:%02d:%02d.%06d" % \
1578 (field.year, field.month, field.day,
1584 (field.year, field.month, field.day,
1579 field.hour, field.minute, field.second, field.microsecond)
1585 field.hour, field.minute, field.second, field.microsecond)
1580 elif isinstance(field, datetime.date):
1586 elif isinstance(field, datetime.date):
1581 text = "%04d-%02d-%02d" % (field.year, field.month, field.day)
1587 text = "%04d-%02d-%02d" % (field.year, field.month, field.day)
1582 else:
1588 else:
1583 text = repr(field)
1589 text = repr(field)
1584 return text
1590 return text
1585
1591
1586
1592
1587 class Display(object):
1593 class Display(object):
1588 class __metaclass__(type):
1594 class __metaclass__(type):
1589 def __ror__(self, input):
1595 def __ror__(self, input):
1590 return input | self()
1596 return input | self()
1591
1597
1592 def __ror__(self, input):
1598 def __ror__(self, input):
1593 self.input = input
1599 self.input = input
1594 return self
1600 return self
1595
1601
1596 def display(self):
1602 def display(self):
1597 pass
1603 pass
1598
1604
1599
1605
1600 class iless(Display):
1606 class iless(Display):
1601 cmd = "less --quit-if-one-screen --LONG-PROMPT --LINE-NUMBERS --chop-long-lines --shift=8 --RAW-CONTROL-CHARS"
1607 cmd = "less --quit-if-one-screen --LONG-PROMPT --LINE-NUMBERS --chop-long-lines --shift=8 --RAW-CONTROL-CHARS"
1602
1608
1603 def display(self):
1609 def display(self):
1604 try:
1610 try:
1605 pager = os.popen(self.cmd, "w")
1611 pager = os.popen(self.cmd, "w")
1606 try:
1612 try:
1607 for item in xiter(self.input, "default"):
1613 for item in xiter(self.input, "default"):
1608 attrs = xattrs(item, "default")
1614 attrs = xattrs(item, "default")
1609 attrs = ["%s=%s" % (a, _format(_getattr(item, a))) for a in attrs]
1615 attrs = ["%s=%s" % (a, _format(_getattr(item, a))) for a in attrs]
1610 pager.write(" ".join(attrs))
1616 pager.write(" ".join(attrs))
1611 pager.write("\n")
1617 pager.write("\n")
1612 finally:
1618 finally:
1613 pager.close()
1619 pager.close()
1614 except Exception, exc:
1620 except Exception, exc:
1615 print "%s: %s" % (exc.__class__.__name__, str(exc))
1621 print "%s: %s" % (exc.__class__.__name__, str(exc))
1616
1622
1617
1623
1618 def xformat(value, mode, maxlength):
1624 def xformat(value, mode, maxlength):
1619 align = None
1625 align = None
1620 full = True
1626 full = True
1621 width = 0
1627 width = 0
1622 text = astyle.Text()
1628 text = astyle.Text()
1623 for (style, part) in xrepr(value, mode):
1629 for (style, part) in xrepr(value, mode):
1624 # only consider the first result
1630 # only consider the first result
1625 if align is None:
1631 if align is None:
1626 if isinstance(style, int):
1632 if isinstance(style, int):
1627 # (style, text) really is (alignment, stop)
1633 # (style, text) really is (alignment, stop)
1628 align = style
1634 align = style
1629 full = part
1635 full = part
1630 continue
1636 continue
1631 else:
1637 else:
1632 align = -1
1638 align = -1
1633 full = True
1639 full = True
1634 if not isinstance(style, int):
1640 if not isinstance(style, int):
1635 text.append((style, part))
1641 text.append((style, part))
1636 width += len(part)
1642 width += len(part)
1637 if width >= maxlength and not full:
1643 if width >= maxlength and not full:
1638 text.append((astyle.style_ellisis, "..."))
1644 text.append((astyle.style_ellisis, "..."))
1639 width += 3
1645 width += 3
1640 break
1646 break
1641 if align is None: # default to left alignment
1647 if align is None: # default to left alignment
1642 align = -1
1648 align = -1
1643 return (align, width, text)
1649 return (align, width, text)
1644
1650
1645
1651
1646 class idump(Display):
1652 class idump(Display):
1647 # The approximate maximum length of a column entry
1653 # The approximate maximum length of a column entry
1648 maxattrlength = 200
1654 maxattrlength = 200
1649
1655
1650 # Style for column names
1656 # Style for column names
1651 style_header = astyle.Style.fromstr("white:black:bold")
1657 style_header = astyle.Style.fromstr("white:black:bold")
1652
1658
1653 def __init__(self, *attrs):
1659 def __init__(self, *attrs):
1654 self.attrs = attrs
1660 self.attrs = attrs
1655 self.headerpadchar = " "
1661 self.headerpadchar = " "
1656 self.headersepchar = "|"
1662 self.headersepchar = "|"
1657 self.datapadchar = " "
1663 self.datapadchar = " "
1658 self.datasepchar = "|"
1664 self.datasepchar = "|"
1659
1665
1660 def display(self):
1666 def display(self):
1661 stream = genutils.Term.cout
1667 stream = genutils.Term.cout
1662 allattrs = []
1668 allattrs = []
1663 allattrset = set()
1669 allattrset = set()
1664 colwidths = {}
1670 colwidths = {}
1665 rows = []
1671 rows = []
1666 for item in xiter(self.input, "default"):
1672 for item in xiter(self.input, "default"):
1667 row = {}
1673 row = {}
1668 attrs = self.attrs
1674 attrs = self.attrs
1669 if not attrs:
1675 if not attrs:
1670 attrs = xattrs(item, "default")
1676 attrs = xattrs(item, "default")
1671 for attrname in attrs:
1677 for attrname in attrs:
1672 if attrname not in allattrset:
1678 if attrname not in allattrset:
1673 allattrs.append(attrname)
1679 allattrs.append(attrname)
1674 allattrset.add(attrname)
1680 allattrset.add(attrname)
1675 colwidths[attrname] = len(_attrname(attrname))
1681 colwidths[attrname] = len(_attrname(attrname))
1676 try:
1682 try:
1677 value = _getattr(item, attrname, None)
1683 value = _getattr(item, attrname, None)
1678 except (KeyboardInterrupt, SystemExit):
1684 except (KeyboardInterrupt, SystemExit):
1679 raise
1685 raise
1680 except Exception, exc:
1686 except Exception, exc:
1681 value = exc
1687 value = exc
1682 (align, width, text) = xformat(value, "cell", self.maxattrlength)
1688 (align, width, text) = xformat(value, "cell", self.maxattrlength)
1683 colwidths[attrname] = max(colwidths[attrname], width)
1689 colwidths[attrname] = max(colwidths[attrname], width)
1684 # remember alignment, length and colored parts
1690 # remember alignment, length and colored parts
1685 row[attrname] = (align, width, text)
1691 row[attrname] = (align, width, text)
1686 rows.append(row)
1692 rows.append(row)
1687
1693
1688 stream.write("\n")
1694 stream.write("\n")
1689 for (i, attrname) in enumerate(allattrs):
1695 for (i, attrname) in enumerate(allattrs):
1690 self.style_header(_attrname(attrname)).write(stream)
1696 self.style_header(_attrname(attrname)).write(stream)
1691 spc = colwidths[attrname] - len(_attrname(attrname))
1697 spc = colwidths[attrname] - len(_attrname(attrname))
1692 if i < len(colwidths)-1:
1698 if i < len(colwidths)-1:
1693 stream.write(self.headerpadchar*spc)
1699 stream.write(self.headerpadchar*spc)
1694 stream.write(self.headersepchar)
1700 stream.write(self.headersepchar)
1695 stream.write("\n")
1701 stream.write("\n")
1696
1702
1697 for row in rows:
1703 for row in rows:
1698 for (i, attrname) in enumerate(allattrs):
1704 for (i, attrname) in enumerate(allattrs):
1699 (align, width, text) = row[attrname]
1705 (align, width, text) = row[attrname]
1700 spc = colwidths[attrname] - width
1706 spc = colwidths[attrname] - width
1701 if align == -1:
1707 if align == -1:
1702 text.write(stream)
1708 text.write(stream)
1703 if i < len(colwidths)-1:
1709 if i < len(colwidths)-1:
1704 stream.write(self.datapadchar*spc)
1710 stream.write(self.datapadchar*spc)
1705 elif align == 0:
1711 elif align == 0:
1706 spc = colwidths[attrname] - width
1712 spc = colwidths[attrname] - width
1707 spc1 = spc//2
1713 spc1 = spc//2
1708 spc2 = spc-spc1
1714 spc2 = spc-spc1
1709 stream.write(self.datapadchar*spc1)
1715 stream.write(self.datapadchar*spc1)
1710 text.write(stream)
1716 text.write(stream)
1711 if i < len(colwidths)-1:
1717 if i < len(colwidths)-1:
1712 stream.write(self.datapadchar*spc2)
1718 stream.write(self.datapadchar*spc2)
1713 else:
1719 else:
1714 stream.write(self.datapadchar*spc)
1720 stream.write(self.datapadchar*spc)
1715 text.write(stream)
1721 text.write(stream)
1716 if i < len(colwidths)-1:
1722 if i < len(colwidths)-1:
1717 stream.write(self.datasepchar)
1723 stream.write(self.datasepchar)
1718 stream.write("\n")
1724 stream.write("\n")
1719
1725
1720
1726
1721 class XMode(object):
1727 class XMode(object):
1722 """
1728 """
1723 An ``XMode`` object describes one enter mode available for an object
1729 An ``XMode`` object describes one enter mode available for an object
1724 """
1730 """
1725 def __init__(self, object, mode, title=None, description=None):
1731 def __init__(self, object, mode, title=None, description=None):
1726 """
1732 """
1727 Create a new ``XMode`` object for the object ``object``. This object
1733 Create a new ``XMode`` object for the object ``object``. This object
1728 must support the enter mode ``mode`` (i.e. ``object.__xiter__(mode)``
1734 must support the enter mode ``mode`` (i.e. ``object.__xiter__(mode)``
1729 must return an iterable). ``title`` and ``description`` will be
1735 must return an iterable). ``title`` and ``description`` will be
1730 displayed in the browser when selecting among the available modes.
1736 displayed in the browser when selecting among the available modes.
1731 """
1737 """
1732 self.object = object
1738 self.object = object
1733 self.mode = mode
1739 self.mode = mode
1734 self.title = title
1740 self.title = title
1735 self.description = description
1741 self.description = description
1736
1742
1737 def __repr__(self):
1743 def __repr__(self):
1738 return "<%s.%s object mode=%r at 0x%x>" % \
1744 return "<%s.%s object mode=%r at 0x%x>" % \
1739 (self.__class__.__module__, self.__class__.__name__,
1745 (self.__class__.__module__, self.__class__.__name__,
1740 self.mode, id(self))
1746 self.mode, id(self))
1741
1747
1742 def __xrepr__(self, mode):
1748 def __xrepr__(self, mode):
1743 if mode == "header" or mode == "footer":
1749 if mode == "header" or mode == "footer":
1744 yield (astyle.style_default, self.title)
1750 yield (astyle.style_default, self.title)
1745 else:
1751 else:
1746 yield (astyle.style_default, repr(self))
1752 yield (astyle.style_default, repr(self))
1747
1753
1748 def __xattrs__(self, mode):
1754 def __xattrs__(self, mode):
1749 if mode == "detail":
1755 if mode == "detail":
1750 return ("object", "mode", "title", "description")
1756 return ("object", "mode", "title", "description")
1751 return ("title", "description")
1757 return ("title", "description")
1752
1758
1753 def __xiter__(self, mode):
1759 def __xiter__(self, mode):
1754 return xiter(self.object, self.mode)
1760 return xiter(self.object, self.mode)
1755
1761
1756
1762
1757 class XAttr(object):
1763 class XAttr(object):
1758 def __init__(self, object, name):
1764 def __init__(self, object, name):
1759 self.name = _attrname(name)
1765 self.name = _attrname(name)
1760
1766
1761 try:
1767 try:
1762 self.value = _getattr(object, name)
1768 self.value = _getattr(object, name)
1763 except (KeyboardInterrupt, SystemExit):
1769 except (KeyboardInterrupt, SystemExit):
1764 raise
1770 raise
1765 except Exception, exc:
1771 except Exception, exc:
1766 if exc.__class__.__module__ == "exceptions":
1772 if exc.__class__.__module__ == "exceptions":
1767 self.value = exc.__class__.__name__
1773 self.value = exc.__class__.__name__
1768 else:
1774 else:
1769 self.value = "%s.%s" % \
1775 self.value = "%s.%s" % \
1770 (exc.__class__.__module__, exc.__class__.__name__)
1776 (exc.__class__.__module__, exc.__class__.__name__)
1771 self.type = self.value
1777 self.type = self.value
1772 else:
1778 else:
1773 t = type(self.value)
1779 t = type(self.value)
1774 if t.__module__ == "__builtin__":
1780 if t.__module__ == "__builtin__":
1775 self.type = t.__name__
1781 self.type = t.__name__
1776 else:
1782 else:
1777 self.type = "%s.%s" % (t.__module__, t.__name__)
1783 self.type = "%s.%s" % (t.__module__, t.__name__)
1778
1784
1779 doc = None
1785 doc = None
1780 if isinstance(name, basestring):
1786 if isinstance(name, basestring):
1781 if name.endswith("()"):
1787 if name.endswith("()"):
1782 doc = getattr(getattr(object, name[:-2]), "__doc__", None)
1788 doc = getattr(getattr(object, name[:-2]), "__doc__", None)
1783 else:
1789 else:
1784 try:
1790 try:
1785 meta = getattr(type(object), name)
1791 meta = getattr(type(object), name)
1786 except AttributeError:
1792 except AttributeError:
1787 pass
1793 pass
1788 else:
1794 else:
1789 if isinstance(meta, property):
1795 if isinstance(meta, property):
1790 doc = getattr(meta, "__doc__", None)
1796 doc = getattr(meta, "__doc__", None)
1791 elif callable(name):
1797 elif callable(name):
1792 doc = getattr(name, "__doc__", None)
1798 doc = getattr(name, "__doc__", None)
1793 if isinstance(doc, basestring):
1799 if isinstance(doc, basestring):
1794 doc = doc.strip()
1800 doc = doc.strip()
1795 self.doc = doc
1801 self.doc = doc
1796
1802
1797 def __xattrs__(self, mode):
1803 def __xattrs__(self, mode):
1798 return ("name", "type", "doc", "value")
1804 return ("name", "type", "doc", "value")
1799
1805
1800
1806
1801 try:
1807 try:
1802 from ibrowse import ibrowse
1808 from ibrowse import ibrowse
1803 except ImportError:
1809 except ImportError:
1804 # No curses (probably Windows) => use ``idump`` as the default display.
1810 # No curses (probably Windows) => use ``idump`` as the default display.
1805 defaultdisplay = idump
1811 defaultdisplay = idump
1806 else:
1812 else:
1807 defaultdisplay = ibrowse
1813 defaultdisplay = ibrowse
1808 __all__.append("ibrowse")
1814 __all__.append("ibrowse")
1809
1815
1810
1816
1811 # If we're running under IPython, install an IPython displayhook that
1817 # If we're running under IPython, install an IPython displayhook that
1812 # returns the object from Display.display(), else install a displayhook
1818 # returns the object from Display.display(), else install a displayhook
1813 # directly as sys.displayhook
1819 # directly as sys.displayhook
1814 api = None
1820 api = None
1815 if ipapi is not None:
1821 if ipapi is not None:
1816 try:
1822 try:
1817 api = ipapi.get()
1823 api = ipapi.get()
1818 except AttributeError:
1824 except AttributeError:
1819 pass
1825 pass
1820
1826
1821 if api is not None:
1827 if api is not None:
1822 def displayhook(self, obj):
1828 def displayhook(self, obj):
1823 if isinstance(obj, type) and issubclass(obj, Table):
1829 if isinstance(obj, type) and issubclass(obj, Table):
1824 obj = obj()
1830 obj = obj()
1825 if isinstance(obj, Table):
1831 if isinstance(obj, Table):
1826 obj = obj | defaultdisplay
1832 obj = obj | defaultdisplay
1827 if isinstance(obj, Display):
1833 if isinstance(obj, Display):
1828 return obj.display()
1834 return obj.display()
1829 else:
1835 else:
1830 raise ipapi.TryNext
1836 raise ipapi.TryNext
1831 api.set_hook("result_display", displayhook)
1837 api.set_hook("result_display", displayhook)
1832 else:
1838 else:
1833 def installdisplayhook():
1839 def installdisplayhook():
1834 _originalhook = sys.displayhook
1840 _originalhook = sys.displayhook
1835 def displayhook(obj):
1841 def displayhook(obj):
1836 if isinstance(obj, type) and issubclass(obj, Table):
1842 if isinstance(obj, type) and issubclass(obj, Table):
1837 obj = obj()
1843 obj = obj()
1838 if isinstance(obj, Table):
1844 if isinstance(obj, Table):
1839 obj = obj | defaultdisplay
1845 obj = obj | defaultdisplay
1840 if isinstance(obj, Display):
1846 if isinstance(obj, Display):
1841 return obj.display()
1847 return obj.display()
1842 else:
1848 else:
1843 _originalhook(obj)
1849 _originalhook(obj)
1844 sys.displayhook = displayhook
1850 sys.displayhook = displayhook
1845 installdisplayhook()
1851 installdisplayhook()
@@ -1,5648 +1,5653 b''
1 2006-07-13 Walter Doerwald <walter@livinglogic.de>
2
3 * IPython/Extensions/ipipe.py (isort): Make isort usable without
4 argument. This sorts the items themselves.
5
1 2006-07-12 Walter Doerwald <walter@livinglogic.de>
6 2006-07-12 Walter Doerwald <walter@livinglogic.de>
2
7
3 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
8 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
4 Compile expression strings into code objects. This should speed
9 Compile expression strings into code objects. This should speed
5 up ifilter and friends somewhat.
10 up ifilter and friends somewhat.
6
11
7 2006-07-08 Ville Vainio <vivainio@gmail.com>
12 2006-07-08 Ville Vainio <vivainio@gmail.com>
8
13
9 * Magic.py: %cpaste now strips > from the beginning of lines
14 * Magic.py: %cpaste now strips > from the beginning of lines
10 to ease pasting quoted code from emails. Contributed by
15 to ease pasting quoted code from emails. Contributed by
11 Stefan van der Walt.
16 Stefan van der Walt.
12
17
13 2006-06-29 Ville Vainio <vivainio@gmail.com>
18 2006-06-29 Ville Vainio <vivainio@gmail.com>
14
19
15 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
20 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
16 mode, patch contributed by Darren Dale. NEEDS TESTING!
21 mode, patch contributed by Darren Dale. NEEDS TESTING!
17
22
18 2006-06-28 Walter Doerwald <walter@livinglogic.de>
23 2006-06-28 Walter Doerwald <walter@livinglogic.de>
19
24
20 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
25 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
21 a blue background. Fix fetching new display rows when the browser
26 a blue background. Fix fetching new display rows when the browser
22 scrolls more than a screenful (e.g. by using the goto command).
27 scrolls more than a screenful (e.g. by using the goto command).
23
28
24 2006-06-27 Ville Vainio <vivainio@gmail.com>
29 2006-06-27 Ville Vainio <vivainio@gmail.com>
25
30
26 * Magic.py (_inspect, _ofind) Apply David Huard's
31 * Magic.py (_inspect, _ofind) Apply David Huard's
27 patch for displaying the correct docstring for 'property'
32 patch for displaying the correct docstring for 'property'
28 attributes.
33 attributes.
29
34
30 2006-06-23 Walter Doerwald <walter@livinglogic.de>
35 2006-06-23 Walter Doerwald <walter@livinglogic.de>
31
36
32 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
37 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
33 commands into the methods implementing them.
38 commands into the methods implementing them.
34
39
35 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
40 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
36
41
37 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
42 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
38 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
43 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
39 autoindent support was authored by Jin Liu.
44 autoindent support was authored by Jin Liu.
40
45
41 2006-06-22 Walter Doerwald <walter@livinglogic.de>
46 2006-06-22 Walter Doerwald <walter@livinglogic.de>
42
47
43 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
48 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
44 for keymaps with a custom class that simplifies handling.
49 for keymaps with a custom class that simplifies handling.
45
50
46 2006-06-19 Walter Doerwald <walter@livinglogic.de>
51 2006-06-19 Walter Doerwald <walter@livinglogic.de>
47
52
48 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
53 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
49 resizing. This requires Python 2.5 to work.
54 resizing. This requires Python 2.5 to work.
50
55
51 2006-06-16 Walter Doerwald <walter@livinglogic.de>
56 2006-06-16 Walter Doerwald <walter@livinglogic.de>
52
57
53 * IPython/Extensions/ibrowse.py: Add two new commands to
58 * IPython/Extensions/ibrowse.py: Add two new commands to
54 ibrowse: "hideattr" (mapped to "h") hides the attribute under
59 ibrowse: "hideattr" (mapped to "h") hides the attribute under
55 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
60 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
56 attributes again. Remapped the help command to "?". Display
61 attributes again. Remapped the help command to "?". Display
57 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
62 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
58 as keys for the "home" and "end" commands. Add three new commands
63 as keys for the "home" and "end" commands. Add three new commands
59 to the input mode for "find" and friends: "delend" (CTRL-K)
64 to the input mode for "find" and friends: "delend" (CTRL-K)
60 deletes to the end of line. "incsearchup" searches upwards in the
65 deletes to the end of line. "incsearchup" searches upwards in the
61 command history for an input that starts with the text before the cursor.
66 command history for an input that starts with the text before the cursor.
62 "incsearchdown" does the same downwards. Removed a bogus mapping of
67 "incsearchdown" does the same downwards. Removed a bogus mapping of
63 the x key to "delete".
68 the x key to "delete".
64
69
65 2006-06-15 Ville Vainio <vivainio@gmail.com>
70 2006-06-15 Ville Vainio <vivainio@gmail.com>
66
71
67 * iplib.py, hooks.py: Added new generate_prompt hook that can be
72 * iplib.py, hooks.py: Added new generate_prompt hook that can be
68 used to create prompts dynamically, instead of the "old" way of
73 used to create prompts dynamically, instead of the "old" way of
69 assigning "magic" strings to prompt_in1 and prompt_in2. The old
74 assigning "magic" strings to prompt_in1 and prompt_in2. The old
70 way still works (it's invoked by the default hook), of course.
75 way still works (it's invoked by the default hook), of course.
71
76
72 * Prompts.py: added generate_output_prompt hook for altering output
77 * Prompts.py: added generate_output_prompt hook for altering output
73 prompt
78 prompt
74
79
75 * Release.py: Changed version string to 0.7.3.svn.
80 * Release.py: Changed version string to 0.7.3.svn.
76
81
77 2006-06-15 Walter Doerwald <walter@livinglogic.de>
82 2006-06-15 Walter Doerwald <walter@livinglogic.de>
78
83
79 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
84 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
80 the call to fetch() always tries to fetch enough data for at least one
85 the call to fetch() always tries to fetch enough data for at least one
81 full screen. This makes it possible to simply call moveto(0,0,True) in
86 full screen. This makes it possible to simply call moveto(0,0,True) in
82 the constructor. Fix typos and removed the obsolete goto attribute.
87 the constructor. Fix typos and removed the obsolete goto attribute.
83
88
84 2006-06-12 Ville Vainio <vivainio@gmail.com>
89 2006-06-12 Ville Vainio <vivainio@gmail.com>
85
90
86 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
91 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
87 allowing $variable interpolation within multiline statements,
92 allowing $variable interpolation within multiline statements,
88 though so far only with "sh" profile for a testing period.
93 though so far only with "sh" profile for a testing period.
89 The patch also enables splitting long commands with \ but it
94 The patch also enables splitting long commands with \ but it
90 doesn't work properly yet.
95 doesn't work properly yet.
91
96
92 2006-06-12 Walter Doerwald <walter@livinglogic.de>
97 2006-06-12 Walter Doerwald <walter@livinglogic.de>
93
98
94 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
99 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
95 input history and the position of the cursor in the input history for
100 input history and the position of the cursor in the input history for
96 the find, findbackwards and goto command.
101 the find, findbackwards and goto command.
97
102
98 2006-06-10 Walter Doerwald <walter@livinglogic.de>
103 2006-06-10 Walter Doerwald <walter@livinglogic.de>
99
104
100 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
105 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
101 implements the basic functionality of browser commands that require
106 implements the basic functionality of browser commands that require
102 input. Reimplement the goto, find and findbackwards commands as
107 input. Reimplement the goto, find and findbackwards commands as
103 subclasses of _CommandInput. Add an input history and keymaps to those
108 subclasses of _CommandInput. Add an input history and keymaps to those
104 commands. Add "\r" as a keyboard shortcut for the enterdefault and
109 commands. Add "\r" as a keyboard shortcut for the enterdefault and
105 execute commands.
110 execute commands.
106
111
107 2006-06-07 Ville Vainio <vivainio@gmail.com>
112 2006-06-07 Ville Vainio <vivainio@gmail.com>
108
113
109 * iplib.py: ipython mybatch.ipy exits ipython immediately after
114 * iplib.py: ipython mybatch.ipy exits ipython immediately after
110 running the batch files instead of leaving the session open.
115 running the batch files instead of leaving the session open.
111
116
112 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
117 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
113
118
114 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
119 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
115 the original fix was incomplete. Patch submitted by W. Maier.
120 the original fix was incomplete. Patch submitted by W. Maier.
116
121
117 2006-06-07 Ville Vainio <vivainio@gmail.com>
122 2006-06-07 Ville Vainio <vivainio@gmail.com>
118
123
119 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
124 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
120 Confirmation prompts can be supressed by 'quiet' option.
125 Confirmation prompts can be supressed by 'quiet' option.
121 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
126 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
122
127
123 2006-06-06 *** Released version 0.7.2
128 2006-06-06 *** Released version 0.7.2
124
129
125 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
130 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
126
131
127 * IPython/Release.py (version): Made 0.7.2 final for release.
132 * IPython/Release.py (version): Made 0.7.2 final for release.
128 Repo tagged and release cut.
133 Repo tagged and release cut.
129
134
130 2006-06-05 Ville Vainio <vivainio@gmail.com>
135 2006-06-05 Ville Vainio <vivainio@gmail.com>
131
136
132 * Magic.py (magic_rehashx): Honor no_alias list earlier in
137 * Magic.py (magic_rehashx): Honor no_alias list earlier in
133 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
138 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
134
139
135 * upgrade_dir.py: try import 'path' module a bit harder
140 * upgrade_dir.py: try import 'path' module a bit harder
136 (for %upgrade)
141 (for %upgrade)
137
142
138 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
143 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
139
144
140 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
145 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
141 instead of looping 20 times.
146 instead of looping 20 times.
142
147
143 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
148 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
144 correctly at initialization time. Bug reported by Krishna Mohan
149 correctly at initialization time. Bug reported by Krishna Mohan
145 Gundu <gkmohan-AT-gmail.com> on the user list.
150 Gundu <gkmohan-AT-gmail.com> on the user list.
146
151
147 * IPython/Release.py (version): Mark 0.7.2 version to start
152 * IPython/Release.py (version): Mark 0.7.2 version to start
148 testing for release on 06/06.
153 testing for release on 06/06.
149
154
150 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
155 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
151
156
152 * scripts/irunner: thin script interface so users don't have to
157 * scripts/irunner: thin script interface so users don't have to
153 find the module and call it as an executable, since modules rarely
158 find the module and call it as an executable, since modules rarely
154 live in people's PATH.
159 live in people's PATH.
155
160
156 * IPython/irunner.py (InteractiveRunner.__init__): added
161 * IPython/irunner.py (InteractiveRunner.__init__): added
157 delaybeforesend attribute to control delays with newer versions of
162 delaybeforesend attribute to control delays with newer versions of
158 pexpect. Thanks to detailed help from pexpect's author, Noah
163 pexpect. Thanks to detailed help from pexpect's author, Noah
159 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
164 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
160 correctly (it works in NoColor mode).
165 correctly (it works in NoColor mode).
161
166
162 * IPython/iplib.py (handle_normal): fix nasty crash reported on
167 * IPython/iplib.py (handle_normal): fix nasty crash reported on
163 SAGE list, from improper log() calls.
168 SAGE list, from improper log() calls.
164
169
165 2006-05-31 Ville Vainio <vivainio@gmail.com>
170 2006-05-31 Ville Vainio <vivainio@gmail.com>
166
171
167 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
172 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
168 with args in parens to work correctly with dirs that have spaces.
173 with args in parens to work correctly with dirs that have spaces.
169
174
170 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
175 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
171
176
172 * IPython/Logger.py (Logger.logstart): add option to log raw input
177 * IPython/Logger.py (Logger.logstart): add option to log raw input
173 instead of the processed one. A -r flag was added to the
178 instead of the processed one. A -r flag was added to the
174 %logstart magic used for controlling logging.
179 %logstart magic used for controlling logging.
175
180
176 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
181 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
177
182
178 * IPython/iplib.py (InteractiveShell.__init__): add check for the
183 * IPython/iplib.py (InteractiveShell.__init__): add check for the
179 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
184 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
180 recognize the option. After a bug report by Will Maier. This
185 recognize the option. After a bug report by Will Maier. This
181 closes #64 (will do it after confirmation from W. Maier).
186 closes #64 (will do it after confirmation from W. Maier).
182
187
183 * IPython/irunner.py: New module to run scripts as if manually
188 * IPython/irunner.py: New module to run scripts as if manually
184 typed into an interactive environment, based on pexpect. After a
189 typed into an interactive environment, based on pexpect. After a
185 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
190 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
186 ipython-user list. Simple unittests in the tests/ directory.
191 ipython-user list. Simple unittests in the tests/ directory.
187
192
188 * tools/release: add Will Maier, OpenBSD port maintainer, to
193 * tools/release: add Will Maier, OpenBSD port maintainer, to
189 recepients list. We are now officially part of the OpenBSD ports:
194 recepients list. We are now officially part of the OpenBSD ports:
190 http://www.openbsd.org/ports.html ! Many thanks to Will for the
195 http://www.openbsd.org/ports.html ! Many thanks to Will for the
191 work.
196 work.
192
197
193 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
198 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
194
199
195 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
200 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
196 so that it doesn't break tkinter apps.
201 so that it doesn't break tkinter apps.
197
202
198 * IPython/iplib.py (_prefilter): fix bug where aliases would
203 * IPython/iplib.py (_prefilter): fix bug where aliases would
199 shadow variables when autocall was fully off. Reported by SAGE
204 shadow variables when autocall was fully off. Reported by SAGE
200 author William Stein.
205 author William Stein.
201
206
202 * IPython/OInspect.py (Inspector.__init__): add a flag to control
207 * IPython/OInspect.py (Inspector.__init__): add a flag to control
203 at what detail level strings are computed when foo? is requested.
208 at what detail level strings are computed when foo? is requested.
204 This allows users to ask for example that the string form of an
209 This allows users to ask for example that the string form of an
205 object is only computed when foo?? is called, or even never, by
210 object is only computed when foo?? is called, or even never, by
206 setting the object_info_string_level >= 2 in the configuration
211 setting the object_info_string_level >= 2 in the configuration
207 file. This new option has been added and documented. After a
212 file. This new option has been added and documented. After a
208 request by SAGE to be able to control the printing of very large
213 request by SAGE to be able to control the printing of very large
209 objects more easily.
214 objects more easily.
210
215
211 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
216 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
212
217
213 * IPython/ipmaker.py (make_IPython): remove the ipython call path
218 * IPython/ipmaker.py (make_IPython): remove the ipython call path
214 from sys.argv, to be 100% consistent with how Python itself works
219 from sys.argv, to be 100% consistent with how Python itself works
215 (as seen for example with python -i file.py). After a bug report
220 (as seen for example with python -i file.py). After a bug report
216 by Jeffrey Collins.
221 by Jeffrey Collins.
217
222
218 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
223 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
219 nasty bug which was preventing custom namespaces with -pylab,
224 nasty bug which was preventing custom namespaces with -pylab,
220 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
225 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
221 compatibility (long gone from mpl).
226 compatibility (long gone from mpl).
222
227
223 * IPython/ipapi.py (make_session): name change: create->make. We
228 * IPython/ipapi.py (make_session): name change: create->make. We
224 use make in other places (ipmaker,...), it's shorter and easier to
229 use make in other places (ipmaker,...), it's shorter and easier to
225 type and say, etc. I'm trying to clean things before 0.7.2 so
230 type and say, etc. I'm trying to clean things before 0.7.2 so
226 that I can keep things stable wrt to ipapi in the chainsaw branch.
231 that I can keep things stable wrt to ipapi in the chainsaw branch.
227
232
228 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
233 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
229 python-mode recognizes our debugger mode. Add support for
234 python-mode recognizes our debugger mode. Add support for
230 autoindent inside (X)emacs. After a patch sent in by Jin Liu
235 autoindent inside (X)emacs. After a patch sent in by Jin Liu
231 <m.liu.jin-AT-gmail.com> originally written by
236 <m.liu.jin-AT-gmail.com> originally written by
232 doxgen-AT-newsmth.net (with minor modifications for xemacs
237 doxgen-AT-newsmth.net (with minor modifications for xemacs
233 compatibility)
238 compatibility)
234
239
235 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
240 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
236 tracebacks when walking the stack so that the stack tracking system
241 tracebacks when walking the stack so that the stack tracking system
237 in emacs' python-mode can identify the frames correctly.
242 in emacs' python-mode can identify the frames correctly.
238
243
239 * IPython/ipmaker.py (make_IPython): make the internal (and
244 * IPython/ipmaker.py (make_IPython): make the internal (and
240 default config) autoedit_syntax value false by default. Too many
245 default config) autoedit_syntax value false by default. Too many
241 users have complained to me (both on and off-list) about problems
246 users have complained to me (both on and off-list) about problems
242 with this option being on by default, so I'm making it default to
247 with this option being on by default, so I'm making it default to
243 off. It can still be enabled by anyone via the usual mechanisms.
248 off. It can still be enabled by anyone via the usual mechanisms.
244
249
245 * IPython/completer.py (Completer.attr_matches): add support for
250 * IPython/completer.py (Completer.attr_matches): add support for
246 PyCrust-style _getAttributeNames magic method. Patch contributed
251 PyCrust-style _getAttributeNames magic method. Patch contributed
247 by <mscott-AT-goldenspud.com>. Closes #50.
252 by <mscott-AT-goldenspud.com>. Closes #50.
248
253
249 * IPython/iplib.py (InteractiveShell.__init__): remove the
254 * IPython/iplib.py (InteractiveShell.__init__): remove the
250 deletion of exit/quit from __builtin__, which can break
255 deletion of exit/quit from __builtin__, which can break
251 third-party tools like the Zope debugging console. The
256 third-party tools like the Zope debugging console. The
252 %exit/%quit magics remain. In general, it's probably a good idea
257 %exit/%quit magics remain. In general, it's probably a good idea
253 not to delete anything from __builtin__, since we never know what
258 not to delete anything from __builtin__, since we never know what
254 that will break. In any case, python now (for 2.5) will support
259 that will break. In any case, python now (for 2.5) will support
255 'real' exit/quit, so this issue is moot. Closes #55.
260 'real' exit/quit, so this issue is moot. Closes #55.
256
261
257 * IPython/genutils.py (with_obj): rename the 'with' function to
262 * IPython/genutils.py (with_obj): rename the 'with' function to
258 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
263 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
259 becomes a language keyword. Closes #53.
264 becomes a language keyword. Closes #53.
260
265
261 * IPython/FakeModule.py (FakeModule.__init__): add a proper
266 * IPython/FakeModule.py (FakeModule.__init__): add a proper
262 __file__ attribute to this so it fools more things into thinking
267 __file__ attribute to this so it fools more things into thinking
263 it is a real module. Closes #59.
268 it is a real module. Closes #59.
264
269
265 * IPython/Magic.py (magic_edit): add -n option to open the editor
270 * IPython/Magic.py (magic_edit): add -n option to open the editor
266 at a specific line number. After a patch by Stefan van der Walt.
271 at a specific line number. After a patch by Stefan van der Walt.
267
272
268 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
273 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
269
274
270 * IPython/iplib.py (edit_syntax_error): fix crash when for some
275 * IPython/iplib.py (edit_syntax_error): fix crash when for some
271 reason the file could not be opened. After automatic crash
276 reason the file could not be opened. After automatic crash
272 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
277 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
273 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
278 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
274 (_should_recompile): Don't fire editor if using %bg, since there
279 (_should_recompile): Don't fire editor if using %bg, since there
275 is no file in the first place. From the same report as above.
280 is no file in the first place. From the same report as above.
276 (raw_input): protect against faulty third-party prefilters. After
281 (raw_input): protect against faulty third-party prefilters. After
277 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
282 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
278 while running under SAGE.
283 while running under SAGE.
279
284
280 2006-05-23 Ville Vainio <vivainio@gmail.com>
285 2006-05-23 Ville Vainio <vivainio@gmail.com>
281
286
282 * ipapi.py: Stripped down ip.to_user_ns() to work only as
287 * ipapi.py: Stripped down ip.to_user_ns() to work only as
283 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
288 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
284 now returns None (again), unless dummy is specifically allowed by
289 now returns None (again), unless dummy is specifically allowed by
285 ipapi.get(allow_dummy=True).
290 ipapi.get(allow_dummy=True).
286
291
287 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
292 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
288
293
289 * IPython: remove all 2.2-compatibility objects and hacks from
294 * IPython: remove all 2.2-compatibility objects and hacks from
290 everywhere, since we only support 2.3 at this point. Docs
295 everywhere, since we only support 2.3 at this point. Docs
291 updated.
296 updated.
292
297
293 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
298 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
294 Anything requiring extra validation can be turned into a Python
299 Anything requiring extra validation can be turned into a Python
295 property in the future. I used a property for the db one b/c
300 property in the future. I used a property for the db one b/c
296 there was a nasty circularity problem with the initialization
301 there was a nasty circularity problem with the initialization
297 order, which right now I don't have time to clean up.
302 order, which right now I don't have time to clean up.
298
303
299 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
304 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
300 another locking bug reported by Jorgen. I'm not 100% sure though,
305 another locking bug reported by Jorgen. I'm not 100% sure though,
301 so more testing is needed...
306 so more testing is needed...
302
307
303 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
308 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
304
309
305 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
310 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
306 local variables from any routine in user code (typically executed
311 local variables from any routine in user code (typically executed
307 with %run) directly into the interactive namespace. Very useful
312 with %run) directly into the interactive namespace. Very useful
308 when doing complex debugging.
313 when doing complex debugging.
309 (IPythonNotRunning): Changed the default None object to a dummy
314 (IPythonNotRunning): Changed the default None object to a dummy
310 whose attributes can be queried as well as called without
315 whose attributes can be queried as well as called without
311 exploding, to ease writing code which works transparently both in
316 exploding, to ease writing code which works transparently both in
312 and out of ipython and uses some of this API.
317 and out of ipython and uses some of this API.
313
318
314 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
319 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
315
320
316 * IPython/hooks.py (result_display): Fix the fact that our display
321 * IPython/hooks.py (result_display): Fix the fact that our display
317 hook was using str() instead of repr(), as the default python
322 hook was using str() instead of repr(), as the default python
318 console does. This had gone unnoticed b/c it only happened if
323 console does. This had gone unnoticed b/c it only happened if
319 %Pprint was off, but the inconsistency was there.
324 %Pprint was off, but the inconsistency was there.
320
325
321 2006-05-15 Ville Vainio <vivainio@gmail.com>
326 2006-05-15 Ville Vainio <vivainio@gmail.com>
322
327
323 * Oinspect.py: Only show docstring for nonexisting/binary files
328 * Oinspect.py: Only show docstring for nonexisting/binary files
324 when doing object??, closing ticket #62
329 when doing object??, closing ticket #62
325
330
326 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
331 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
327
332
328 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
333 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
329 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
334 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
330 was being released in a routine which hadn't checked if it had
335 was being released in a routine which hadn't checked if it had
331 been the one to acquire it.
336 been the one to acquire it.
332
337
333 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
338 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
334
339
335 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
340 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
336
341
337 2006-04-11 Ville Vainio <vivainio@gmail.com>
342 2006-04-11 Ville Vainio <vivainio@gmail.com>
338
343
339 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
344 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
340 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
345 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
341 prefilters, allowing stuff like magics and aliases in the file.
346 prefilters, allowing stuff like magics and aliases in the file.
342
347
343 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
348 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
344 added. Supported now are "%clear in" and "%clear out" (clear input and
349 added. Supported now are "%clear in" and "%clear out" (clear input and
345 output history, respectively). Also fixed CachedOutput.flush to
350 output history, respectively). Also fixed CachedOutput.flush to
346 properly flush the output cache.
351 properly flush the output cache.
347
352
348 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
353 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
349 half-success (and fail explicitly).
354 half-success (and fail explicitly).
350
355
351 2006-03-28 Ville Vainio <vivainio@gmail.com>
356 2006-03-28 Ville Vainio <vivainio@gmail.com>
352
357
353 * iplib.py: Fix quoting of aliases so that only argless ones
358 * iplib.py: Fix quoting of aliases so that only argless ones
354 are quoted
359 are quoted
355
360
356 2006-03-28 Ville Vainio <vivainio@gmail.com>
361 2006-03-28 Ville Vainio <vivainio@gmail.com>
357
362
358 * iplib.py: Quote aliases with spaces in the name.
363 * iplib.py: Quote aliases with spaces in the name.
359 "c:\program files\blah\bin" is now legal alias target.
364 "c:\program files\blah\bin" is now legal alias target.
360
365
361 * ext_rehashdir.py: Space no longer allowed as arg
366 * ext_rehashdir.py: Space no longer allowed as arg
362 separator, since space is legal in path names.
367 separator, since space is legal in path names.
363
368
364 2006-03-16 Ville Vainio <vivainio@gmail.com>
369 2006-03-16 Ville Vainio <vivainio@gmail.com>
365
370
366 * upgrade_dir.py: Take path.py from Extensions, correcting
371 * upgrade_dir.py: Take path.py from Extensions, correcting
367 %upgrade magic
372 %upgrade magic
368
373
369 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
374 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
370
375
371 * hooks.py: Only enclose editor binary in quotes if legal and
376 * hooks.py: Only enclose editor binary in quotes if legal and
372 necessary (space in the name, and is an existing file). Fixes a bug
377 necessary (space in the name, and is an existing file). Fixes a bug
373 reported by Zachary Pincus.
378 reported by Zachary Pincus.
374
379
375 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
380 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
376
381
377 * Manual: thanks to a tip on proper color handling for Emacs, by
382 * Manual: thanks to a tip on proper color handling for Emacs, by
378 Eric J Haywiser <ejh1-AT-MIT.EDU>.
383 Eric J Haywiser <ejh1-AT-MIT.EDU>.
379
384
380 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
385 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
381 by applying the provided patch. Thanks to Liu Jin
386 by applying the provided patch. Thanks to Liu Jin
382 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
387 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
383 XEmacs/Linux, I'm trusting the submitter that it actually helps
388 XEmacs/Linux, I'm trusting the submitter that it actually helps
384 under win32/GNU Emacs. Will revisit if any problems are reported.
389 under win32/GNU Emacs. Will revisit if any problems are reported.
385
390
386 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
391 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
387
392
388 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
393 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
389 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
394 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
390
395
391 2006-03-12 Ville Vainio <vivainio@gmail.com>
396 2006-03-12 Ville Vainio <vivainio@gmail.com>
392
397
393 * Magic.py (magic_timeit): Added %timeit magic, contributed by
398 * Magic.py (magic_timeit): Added %timeit magic, contributed by
394 Torsten Marek.
399 Torsten Marek.
395
400
396 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
401 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
397
402
398 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
403 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
399 line ranges works again.
404 line ranges works again.
400
405
401 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
406 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
402
407
403 * IPython/iplib.py (showtraceback): add back sys.last_traceback
408 * IPython/iplib.py (showtraceback): add back sys.last_traceback
404 and friends, after a discussion with Zach Pincus on ipython-user.
409 and friends, after a discussion with Zach Pincus on ipython-user.
405 I'm not 100% sure, but after thinking about it quite a bit, it may
410 I'm not 100% sure, but after thinking about it quite a bit, it may
406 be OK. Testing with the multithreaded shells didn't reveal any
411 be OK. Testing with the multithreaded shells didn't reveal any
407 problems, but let's keep an eye out.
412 problems, but let's keep an eye out.
408
413
409 In the process, I fixed a few things which were calling
414 In the process, I fixed a few things which were calling
410 self.InteractiveTB() directly (like safe_execfile), which is a
415 self.InteractiveTB() directly (like safe_execfile), which is a
411 mistake: ALL exception reporting should be done by calling
416 mistake: ALL exception reporting should be done by calling
412 self.showtraceback(), which handles state and tab-completion and
417 self.showtraceback(), which handles state and tab-completion and
413 more.
418 more.
414
419
415 2006-03-01 Ville Vainio <vivainio@gmail.com>
420 2006-03-01 Ville Vainio <vivainio@gmail.com>
416
421
417 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
422 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
418 To use, do "from ipipe import *".
423 To use, do "from ipipe import *".
419
424
420 2006-02-24 Ville Vainio <vivainio@gmail.com>
425 2006-02-24 Ville Vainio <vivainio@gmail.com>
421
426
422 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
427 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
423 "cleanly" and safely than the older upgrade mechanism.
428 "cleanly" and safely than the older upgrade mechanism.
424
429
425 2006-02-21 Ville Vainio <vivainio@gmail.com>
430 2006-02-21 Ville Vainio <vivainio@gmail.com>
426
431
427 * Magic.py: %save works again.
432 * Magic.py: %save works again.
428
433
429 2006-02-15 Ville Vainio <vivainio@gmail.com>
434 2006-02-15 Ville Vainio <vivainio@gmail.com>
430
435
431 * Magic.py: %Pprint works again
436 * Magic.py: %Pprint works again
432
437
433 * Extensions/ipy_sane_defaults.py: Provide everything provided
438 * Extensions/ipy_sane_defaults.py: Provide everything provided
434 in default ipythonrc, to make it possible to have a completely empty
439 in default ipythonrc, to make it possible to have a completely empty
435 ipythonrc (and thus completely rc-file free configuration)
440 ipythonrc (and thus completely rc-file free configuration)
436
441
437 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
442 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
438
443
439 * IPython/hooks.py (editor): quote the call to the editor command,
444 * IPython/hooks.py (editor): quote the call to the editor command,
440 to allow commands with spaces in them. Problem noted by watching
445 to allow commands with spaces in them. Problem noted by watching
441 Ian Oswald's video about textpad under win32 at
446 Ian Oswald's video about textpad under win32 at
442 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
447 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
443
448
444 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
449 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
445 describing magics (we haven't used @ for a loong time).
450 describing magics (we haven't used @ for a loong time).
446
451
447 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
452 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
448 contributed by marienz to close
453 contributed by marienz to close
449 http://www.scipy.net/roundup/ipython/issue53.
454 http://www.scipy.net/roundup/ipython/issue53.
450
455
451 2006-02-10 Ville Vainio <vivainio@gmail.com>
456 2006-02-10 Ville Vainio <vivainio@gmail.com>
452
457
453 * genutils.py: getoutput now works in win32 too
458 * genutils.py: getoutput now works in win32 too
454
459
455 * completer.py: alias and magic completion only invoked
460 * completer.py: alias and magic completion only invoked
456 at the first "item" in the line, to avoid "cd %store"
461 at the first "item" in the line, to avoid "cd %store"
457 nonsense.
462 nonsense.
458
463
459 2006-02-09 Ville Vainio <vivainio@gmail.com>
464 2006-02-09 Ville Vainio <vivainio@gmail.com>
460
465
461 * test/*: Added a unit testing framework (finally).
466 * test/*: Added a unit testing framework (finally).
462 '%run runtests.py' to run test_*.
467 '%run runtests.py' to run test_*.
463
468
464 * ipapi.py: Exposed runlines and set_custom_exc
469 * ipapi.py: Exposed runlines and set_custom_exc
465
470
466 2006-02-07 Ville Vainio <vivainio@gmail.com>
471 2006-02-07 Ville Vainio <vivainio@gmail.com>
467
472
468 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
473 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
469 instead use "f(1 2)" as before.
474 instead use "f(1 2)" as before.
470
475
471 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
476 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
472
477
473 * IPython/demo.py (IPythonDemo): Add new classes to the demo
478 * IPython/demo.py (IPythonDemo): Add new classes to the demo
474 facilities, for demos processed by the IPython input filter
479 facilities, for demos processed by the IPython input filter
475 (IPythonDemo), and for running a script one-line-at-a-time as a
480 (IPythonDemo), and for running a script one-line-at-a-time as a
476 demo, both for pure Python (LineDemo) and for IPython-processed
481 demo, both for pure Python (LineDemo) and for IPython-processed
477 input (IPythonLineDemo). After a request by Dave Kohel, from the
482 input (IPythonLineDemo). After a request by Dave Kohel, from the
478 SAGE team.
483 SAGE team.
479 (Demo.edit): added an edit() method to the demo objects, to edit
484 (Demo.edit): added an edit() method to the demo objects, to edit
480 the in-memory copy of the last executed block.
485 the in-memory copy of the last executed block.
481
486
482 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
487 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
483 processing to %edit, %macro and %save. These commands can now be
488 processing to %edit, %macro and %save. These commands can now be
484 invoked on the unprocessed input as it was typed by the user
489 invoked on the unprocessed input as it was typed by the user
485 (without any prefilters applied). After requests by the SAGE team
490 (without any prefilters applied). After requests by the SAGE team
486 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
491 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
487
492
488 2006-02-01 Ville Vainio <vivainio@gmail.com>
493 2006-02-01 Ville Vainio <vivainio@gmail.com>
489
494
490 * setup.py, eggsetup.py: easy_install ipython==dev works
495 * setup.py, eggsetup.py: easy_install ipython==dev works
491 correctly now (on Linux)
496 correctly now (on Linux)
492
497
493 * ipy_user_conf,ipmaker: user config changes, removed spurious
498 * ipy_user_conf,ipmaker: user config changes, removed spurious
494 warnings
499 warnings
495
500
496 * iplib: if rc.banner is string, use it as is.
501 * iplib: if rc.banner is string, use it as is.
497
502
498 * Magic: %pycat accepts a string argument and pages it's contents.
503 * Magic: %pycat accepts a string argument and pages it's contents.
499
504
500
505
501 2006-01-30 Ville Vainio <vivainio@gmail.com>
506 2006-01-30 Ville Vainio <vivainio@gmail.com>
502
507
503 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
508 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
504 Now %store and bookmarks work through PickleShare, meaning that
509 Now %store and bookmarks work through PickleShare, meaning that
505 concurrent access is possible and all ipython sessions see the
510 concurrent access is possible and all ipython sessions see the
506 same database situation all the time, instead of snapshot of
511 same database situation all the time, instead of snapshot of
507 the situation when the session was started. Hence, %bookmark
512 the situation when the session was started. Hence, %bookmark
508 results are immediately accessible from othes sessions. The database
513 results are immediately accessible from othes sessions. The database
509 is also available for use by user extensions. See:
514 is also available for use by user extensions. See:
510 http://www.python.org/pypi/pickleshare
515 http://www.python.org/pypi/pickleshare
511
516
512 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
517 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
513
518
514 * aliases can now be %store'd
519 * aliases can now be %store'd
515
520
516 * path.py moved to Extensions so that pickleshare does not need
521 * path.py moved to Extensions so that pickleshare does not need
517 IPython-specific import. Extensions added to pythonpath right
522 IPython-specific import. Extensions added to pythonpath right
518 at __init__.
523 at __init__.
519
524
520 * iplib.py: ipalias deprecated/redundant; aliases are converted and
525 * iplib.py: ipalias deprecated/redundant; aliases are converted and
521 called with _ip.system and the pre-transformed command string.
526 called with _ip.system and the pre-transformed command string.
522
527
523 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
528 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
524
529
525 * IPython/iplib.py (interact): Fix that we were not catching
530 * IPython/iplib.py (interact): Fix that we were not catching
526 KeyboardInterrupt exceptions properly. I'm not quite sure why the
531 KeyboardInterrupt exceptions properly. I'm not quite sure why the
527 logic here had to change, but it's fixed now.
532 logic here had to change, but it's fixed now.
528
533
529 2006-01-29 Ville Vainio <vivainio@gmail.com>
534 2006-01-29 Ville Vainio <vivainio@gmail.com>
530
535
531 * iplib.py: Try to import pyreadline on Windows.
536 * iplib.py: Try to import pyreadline on Windows.
532
537
533 2006-01-27 Ville Vainio <vivainio@gmail.com>
538 2006-01-27 Ville Vainio <vivainio@gmail.com>
534
539
535 * iplib.py: Expose ipapi as _ip in builtin namespace.
540 * iplib.py: Expose ipapi as _ip in builtin namespace.
536 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
541 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
537 and ip_set_hook (-> _ip.set_hook) redundant. % and !
542 and ip_set_hook (-> _ip.set_hook) redundant. % and !
538 syntax now produce _ip.* variant of the commands.
543 syntax now produce _ip.* variant of the commands.
539
544
540 * "_ip.options().autoedit_syntax = 2" automatically throws
545 * "_ip.options().autoedit_syntax = 2" automatically throws
541 user to editor for syntax error correction without prompting.
546 user to editor for syntax error correction without prompting.
542
547
543 2006-01-27 Ville Vainio <vivainio@gmail.com>
548 2006-01-27 Ville Vainio <vivainio@gmail.com>
544
549
545 * ipmaker.py: Give "realistic" sys.argv for scripts (without
550 * ipmaker.py: Give "realistic" sys.argv for scripts (without
546 'ipython' at argv[0]) executed through command line.
551 'ipython' at argv[0]) executed through command line.
547 NOTE: this DEPRECATES calling ipython with multiple scripts
552 NOTE: this DEPRECATES calling ipython with multiple scripts
548 ("ipython a.py b.py c.py")
553 ("ipython a.py b.py c.py")
549
554
550 * iplib.py, hooks.py: Added configurable input prefilter,
555 * iplib.py, hooks.py: Added configurable input prefilter,
551 named 'input_prefilter'. See ext_rescapture.py for example
556 named 'input_prefilter'. See ext_rescapture.py for example
552 usage.
557 usage.
553
558
554 * ext_rescapture.py, Magic.py: Better system command output capture
559 * ext_rescapture.py, Magic.py: Better system command output capture
555 through 'var = !ls' (deprecates user-visible %sc). Same notation
560 through 'var = !ls' (deprecates user-visible %sc). Same notation
556 applies for magics, 'var = %alias' assigns alias list to var.
561 applies for magics, 'var = %alias' assigns alias list to var.
557
562
558 * ipapi.py: added meta() for accessing extension-usable data store.
563 * ipapi.py: added meta() for accessing extension-usable data store.
559
564
560 * iplib.py: added InteractiveShell.getapi(). New magics should be
565 * iplib.py: added InteractiveShell.getapi(). New magics should be
561 written doing self.getapi() instead of using the shell directly.
566 written doing self.getapi() instead of using the shell directly.
562
567
563 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
568 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
564 %store foo >> ~/myfoo.txt to store variables to files (in clean
569 %store foo >> ~/myfoo.txt to store variables to files (in clean
565 textual form, not a restorable pickle).
570 textual form, not a restorable pickle).
566
571
567 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
572 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
568
573
569 * usage.py, Magic.py: added %quickref
574 * usage.py, Magic.py: added %quickref
570
575
571 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
576 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
572
577
573 * GetoptErrors when invoking magics etc. with wrong args
578 * GetoptErrors when invoking magics etc. with wrong args
574 are now more helpful:
579 are now more helpful:
575 GetoptError: option -l not recognized (allowed: "qb" )
580 GetoptError: option -l not recognized (allowed: "qb" )
576
581
577 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
582 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
578
583
579 * IPython/demo.py (Demo.show): Flush stdout after each block, so
584 * IPython/demo.py (Demo.show): Flush stdout after each block, so
580 computationally intensive blocks don't appear to stall the demo.
585 computationally intensive blocks don't appear to stall the demo.
581
586
582 2006-01-24 Ville Vainio <vivainio@gmail.com>
587 2006-01-24 Ville Vainio <vivainio@gmail.com>
583
588
584 * iplib.py, hooks.py: 'result_display' hook can return a non-None
589 * iplib.py, hooks.py: 'result_display' hook can return a non-None
585 value to manipulate resulting history entry.
590 value to manipulate resulting history entry.
586
591
587 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
592 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
588 to instance methods of IPApi class, to make extending an embedded
593 to instance methods of IPApi class, to make extending an embedded
589 IPython feasible. See ext_rehashdir.py for example usage.
594 IPython feasible. See ext_rehashdir.py for example usage.
590
595
591 * Merged 1071-1076 from branches/0.7.1
596 * Merged 1071-1076 from branches/0.7.1
592
597
593
598
594 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
599 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
595
600
596 * tools/release (daystamp): Fix build tools to use the new
601 * tools/release (daystamp): Fix build tools to use the new
597 eggsetup.py script to build lightweight eggs.
602 eggsetup.py script to build lightweight eggs.
598
603
599 * Applied changesets 1062 and 1064 before 0.7.1 release.
604 * Applied changesets 1062 and 1064 before 0.7.1 release.
600
605
601 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
606 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
602 see the raw input history (without conversions like %ls ->
607 see the raw input history (without conversions like %ls ->
603 ipmagic("ls")). After a request from W. Stein, SAGE
608 ipmagic("ls")). After a request from W. Stein, SAGE
604 (http://modular.ucsd.edu/sage) developer. This information is
609 (http://modular.ucsd.edu/sage) developer. This information is
605 stored in the input_hist_raw attribute of the IPython instance, so
610 stored in the input_hist_raw attribute of the IPython instance, so
606 developers can access it if needed (it's an InputList instance).
611 developers can access it if needed (it's an InputList instance).
607
612
608 * Versionstring = 0.7.2.svn
613 * Versionstring = 0.7.2.svn
609
614
610 * eggsetup.py: A separate script for constructing eggs, creates
615 * eggsetup.py: A separate script for constructing eggs, creates
611 proper launch scripts even on Windows (an .exe file in
616 proper launch scripts even on Windows (an .exe file in
612 \python24\scripts).
617 \python24\scripts).
613
618
614 * ipapi.py: launch_new_instance, launch entry point needed for the
619 * ipapi.py: launch_new_instance, launch entry point needed for the
615 egg.
620 egg.
616
621
617 2006-01-23 Ville Vainio <vivainio@gmail.com>
622 2006-01-23 Ville Vainio <vivainio@gmail.com>
618
623
619 * Added %cpaste magic for pasting python code
624 * Added %cpaste magic for pasting python code
620
625
621 2006-01-22 Ville Vainio <vivainio@gmail.com>
626 2006-01-22 Ville Vainio <vivainio@gmail.com>
622
627
623 * Merge from branches/0.7.1 into trunk, revs 1052-1057
628 * Merge from branches/0.7.1 into trunk, revs 1052-1057
624
629
625 * Versionstring = 0.7.2.svn
630 * Versionstring = 0.7.2.svn
626
631
627 * eggsetup.py: A separate script for constructing eggs, creates
632 * eggsetup.py: A separate script for constructing eggs, creates
628 proper launch scripts even on Windows (an .exe file in
633 proper launch scripts even on Windows (an .exe file in
629 \python24\scripts).
634 \python24\scripts).
630
635
631 * ipapi.py: launch_new_instance, launch entry point needed for the
636 * ipapi.py: launch_new_instance, launch entry point needed for the
632 egg.
637 egg.
633
638
634 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
639 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
635
640
636 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
641 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
637 %pfile foo would print the file for foo even if it was a binary.
642 %pfile foo would print the file for foo even if it was a binary.
638 Now, extensions '.so' and '.dll' are skipped.
643 Now, extensions '.so' and '.dll' are skipped.
639
644
640 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
645 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
641 bug, where macros would fail in all threaded modes. I'm not 100%
646 bug, where macros would fail in all threaded modes. I'm not 100%
642 sure, so I'm going to put out an rc instead of making a release
647 sure, so I'm going to put out an rc instead of making a release
643 today, and wait for feedback for at least a few days.
648 today, and wait for feedback for at least a few days.
644
649
645 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
650 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
646 it...) the handling of pasting external code with autoindent on.
651 it...) the handling of pasting external code with autoindent on.
647 To get out of a multiline input, the rule will appear for most
652 To get out of a multiline input, the rule will appear for most
648 users unchanged: two blank lines or change the indent level
653 users unchanged: two blank lines or change the indent level
649 proposed by IPython. But there is a twist now: you can
654 proposed by IPython. But there is a twist now: you can
650 add/subtract only *one or two spaces*. If you add/subtract three
655 add/subtract only *one or two spaces*. If you add/subtract three
651 or more (unless you completely delete the line), IPython will
656 or more (unless you completely delete the line), IPython will
652 accept that line, and you'll need to enter a second one of pure
657 accept that line, and you'll need to enter a second one of pure
653 whitespace. I know it sounds complicated, but I can't find a
658 whitespace. I know it sounds complicated, but I can't find a
654 different solution that covers all the cases, with the right
659 different solution that covers all the cases, with the right
655 heuristics. Hopefully in actual use, nobody will really notice
660 heuristics. Hopefully in actual use, nobody will really notice
656 all these strange rules and things will 'just work'.
661 all these strange rules and things will 'just work'.
657
662
658 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
663 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
659
664
660 * IPython/iplib.py (interact): catch exceptions which can be
665 * IPython/iplib.py (interact): catch exceptions which can be
661 triggered asynchronously by signal handlers. Thanks to an
666 triggered asynchronously by signal handlers. Thanks to an
662 automatic crash report, submitted by Colin Kingsley
667 automatic crash report, submitted by Colin Kingsley
663 <tercel-AT-gentoo.org>.
668 <tercel-AT-gentoo.org>.
664
669
665 2006-01-20 Ville Vainio <vivainio@gmail.com>
670 2006-01-20 Ville Vainio <vivainio@gmail.com>
666
671
667 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
672 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
668 (%rehashdir, very useful, try it out) of how to extend ipython
673 (%rehashdir, very useful, try it out) of how to extend ipython
669 with new magics. Also added Extensions dir to pythonpath to make
674 with new magics. Also added Extensions dir to pythonpath to make
670 importing extensions easy.
675 importing extensions easy.
671
676
672 * %store now complains when trying to store interactively declared
677 * %store now complains when trying to store interactively declared
673 classes / instances of those classes.
678 classes / instances of those classes.
674
679
675 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
680 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
676 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
681 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
677 if they exist, and ipy_user_conf.py with some defaults is created for
682 if they exist, and ipy_user_conf.py with some defaults is created for
678 the user.
683 the user.
679
684
680 * Startup rehashing done by the config file, not InterpreterExec.
685 * Startup rehashing done by the config file, not InterpreterExec.
681 This means system commands are available even without selecting the
686 This means system commands are available even without selecting the
682 pysh profile. It's the sensible default after all.
687 pysh profile. It's the sensible default after all.
683
688
684 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
689 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
685
690
686 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
691 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
687 multiline code with autoindent on working. But I am really not
692 multiline code with autoindent on working. But I am really not
688 sure, so this needs more testing. Will commit a debug-enabled
693 sure, so this needs more testing. Will commit a debug-enabled
689 version for now, while I test it some more, so that Ville and
694 version for now, while I test it some more, so that Ville and
690 others may also catch any problems. Also made
695 others may also catch any problems. Also made
691 self.indent_current_str() a method, to ensure that there's no
696 self.indent_current_str() a method, to ensure that there's no
692 chance of the indent space count and the corresponding string
697 chance of the indent space count and the corresponding string
693 falling out of sync. All code needing the string should just call
698 falling out of sync. All code needing the string should just call
694 the method.
699 the method.
695
700
696 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
701 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
697
702
698 * IPython/Magic.py (magic_edit): fix check for when users don't
703 * IPython/Magic.py (magic_edit): fix check for when users don't
699 save their output files, the try/except was in the wrong section.
704 save their output files, the try/except was in the wrong section.
700
705
701 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
706 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
702
707
703 * IPython/Magic.py (magic_run): fix __file__ global missing from
708 * IPython/Magic.py (magic_run): fix __file__ global missing from
704 script's namespace when executed via %run. After a report by
709 script's namespace when executed via %run. After a report by
705 Vivian.
710 Vivian.
706
711
707 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
712 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
708 when using python 2.4. The parent constructor changed in 2.4, and
713 when using python 2.4. The parent constructor changed in 2.4, and
709 we need to track it directly (we can't call it, as it messes up
714 we need to track it directly (we can't call it, as it messes up
710 readline and tab-completion inside our pdb would stop working).
715 readline and tab-completion inside our pdb would stop working).
711 After a bug report by R. Bernstein <rocky-AT-panix.com>.
716 After a bug report by R. Bernstein <rocky-AT-panix.com>.
712
717
713 2006-01-16 Ville Vainio <vivainio@gmail.com>
718 2006-01-16 Ville Vainio <vivainio@gmail.com>
714
719
715 * Ipython/magic.py: Reverted back to old %edit functionality
720 * Ipython/magic.py: Reverted back to old %edit functionality
716 that returns file contents on exit.
721 that returns file contents on exit.
717
722
718 * IPython/path.py: Added Jason Orendorff's "path" module to
723 * IPython/path.py: Added Jason Orendorff's "path" module to
719 IPython tree, http://www.jorendorff.com/articles/python/path/.
724 IPython tree, http://www.jorendorff.com/articles/python/path/.
720 You can get path objects conveniently through %sc, and !!, e.g.:
725 You can get path objects conveniently through %sc, and !!, e.g.:
721 sc files=ls
726 sc files=ls
722 for p in files.paths: # or files.p
727 for p in files.paths: # or files.p
723 print p,p.mtime
728 print p,p.mtime
724
729
725 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
730 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
726 now work again without considering the exclusion regexp -
731 now work again without considering the exclusion regexp -
727 hence, things like ',foo my/path' turn to 'foo("my/path")'
732 hence, things like ',foo my/path' turn to 'foo("my/path")'
728 instead of syntax error.
733 instead of syntax error.
729
734
730
735
731 2006-01-14 Ville Vainio <vivainio@gmail.com>
736 2006-01-14 Ville Vainio <vivainio@gmail.com>
732
737
733 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
738 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
734 ipapi decorators for python 2.4 users, options() provides access to rc
739 ipapi decorators for python 2.4 users, options() provides access to rc
735 data.
740 data.
736
741
737 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
742 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
738 as path separators (even on Linux ;-). Space character after
743 as path separators (even on Linux ;-). Space character after
739 backslash (as yielded by tab completer) is still space;
744 backslash (as yielded by tab completer) is still space;
740 "%cd long\ name" works as expected.
745 "%cd long\ name" works as expected.
741
746
742 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
747 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
743 as "chain of command", with priority. API stays the same,
748 as "chain of command", with priority. API stays the same,
744 TryNext exception raised by a hook function signals that
749 TryNext exception raised by a hook function signals that
745 current hook failed and next hook should try handling it, as
750 current hook failed and next hook should try handling it, as
746 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
751 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
747 requested configurable display hook, which is now implemented.
752 requested configurable display hook, which is now implemented.
748
753
749 2006-01-13 Ville Vainio <vivainio@gmail.com>
754 2006-01-13 Ville Vainio <vivainio@gmail.com>
750
755
751 * IPython/platutils*.py: platform specific utility functions,
756 * IPython/platutils*.py: platform specific utility functions,
752 so far only set_term_title is implemented (change terminal
757 so far only set_term_title is implemented (change terminal
753 label in windowing systems). %cd now changes the title to
758 label in windowing systems). %cd now changes the title to
754 current dir.
759 current dir.
755
760
756 * IPython/Release.py: Added myself to "authors" list,
761 * IPython/Release.py: Added myself to "authors" list,
757 had to create new files.
762 had to create new files.
758
763
759 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
764 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
760 shell escape; not a known bug but had potential to be one in the
765 shell escape; not a known bug but had potential to be one in the
761 future.
766 future.
762
767
763 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
768 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
764 extension API for IPython! See the module for usage example. Fix
769 extension API for IPython! See the module for usage example. Fix
765 OInspect for docstring-less magic functions.
770 OInspect for docstring-less magic functions.
766
771
767
772
768 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
773 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
769
774
770 * IPython/iplib.py (raw_input): temporarily deactivate all
775 * IPython/iplib.py (raw_input): temporarily deactivate all
771 attempts at allowing pasting of code with autoindent on. It
776 attempts at allowing pasting of code with autoindent on. It
772 introduced bugs (reported by Prabhu) and I can't seem to find a
777 introduced bugs (reported by Prabhu) and I can't seem to find a
773 robust combination which works in all cases. Will have to revisit
778 robust combination which works in all cases. Will have to revisit
774 later.
779 later.
775
780
776 * IPython/genutils.py: remove isspace() function. We've dropped
781 * IPython/genutils.py: remove isspace() function. We've dropped
777 2.2 compatibility, so it's OK to use the string method.
782 2.2 compatibility, so it's OK to use the string method.
778
783
779 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
784 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
780
785
781 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
786 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
782 matching what NOT to autocall on, to include all python binary
787 matching what NOT to autocall on, to include all python binary
783 operators (including things like 'and', 'or', 'is' and 'in').
788 operators (including things like 'and', 'or', 'is' and 'in').
784 Prompted by a bug report on 'foo & bar', but I realized we had
789 Prompted by a bug report on 'foo & bar', but I realized we had
785 many more potential bug cases with other operators. The regexp is
790 many more potential bug cases with other operators. The regexp is
786 self.re_exclude_auto, it's fairly commented.
791 self.re_exclude_auto, it's fairly commented.
787
792
788 2006-01-12 Ville Vainio <vivainio@gmail.com>
793 2006-01-12 Ville Vainio <vivainio@gmail.com>
789
794
790 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
795 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
791 Prettified and hardened string/backslash quoting with ipsystem(),
796 Prettified and hardened string/backslash quoting with ipsystem(),
792 ipalias() and ipmagic(). Now even \ characters are passed to
797 ipalias() and ipmagic(). Now even \ characters are passed to
793 %magics, !shell escapes and aliases exactly as they are in the
798 %magics, !shell escapes and aliases exactly as they are in the
794 ipython command line. Should improve backslash experience,
799 ipython command line. Should improve backslash experience,
795 particularly in Windows (path delimiter for some commands that
800 particularly in Windows (path delimiter for some commands that
796 won't understand '/'), but Unix benefits as well (regexps). %cd
801 won't understand '/'), but Unix benefits as well (regexps). %cd
797 magic still doesn't support backslash path delimiters, though. Also
802 magic still doesn't support backslash path delimiters, though. Also
798 deleted all pretense of supporting multiline command strings in
803 deleted all pretense of supporting multiline command strings in
799 !system or %magic commands. Thanks to Jerry McRae for suggestions.
804 !system or %magic commands. Thanks to Jerry McRae for suggestions.
800
805
801 * doc/build_doc_instructions.txt added. Documentation on how to
806 * doc/build_doc_instructions.txt added. Documentation on how to
802 use doc/update_manual.py, added yesterday. Both files contributed
807 use doc/update_manual.py, added yesterday. Both files contributed
803 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
808 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
804 doc/*.sh for deprecation at a later date.
809 doc/*.sh for deprecation at a later date.
805
810
806 * /ipython.py Added ipython.py to root directory for
811 * /ipython.py Added ipython.py to root directory for
807 zero-installation (tar xzvf ipython.tgz; cd ipython; python
812 zero-installation (tar xzvf ipython.tgz; cd ipython; python
808 ipython.py) and development convenience (no need to keep doing
813 ipython.py) and development convenience (no need to keep doing
809 "setup.py install" between changes).
814 "setup.py install" between changes).
810
815
811 * Made ! and !! shell escapes work (again) in multiline expressions:
816 * Made ! and !! shell escapes work (again) in multiline expressions:
812 if 1:
817 if 1:
813 !ls
818 !ls
814 !!ls
819 !!ls
815
820
816 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
821 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
817
822
818 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
823 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
819 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
824 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
820 module in case-insensitive installation. Was causing crashes
825 module in case-insensitive installation. Was causing crashes
821 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
826 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
822
827
823 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
828 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
824 <marienz-AT-gentoo.org>, closes
829 <marienz-AT-gentoo.org>, closes
825 http://www.scipy.net/roundup/ipython/issue51.
830 http://www.scipy.net/roundup/ipython/issue51.
826
831
827 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
832 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
828
833
829 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
834 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
830 problem of excessive CPU usage under *nix and keyboard lag under
835 problem of excessive CPU usage under *nix and keyboard lag under
831 win32.
836 win32.
832
837
833 2006-01-10 *** Released version 0.7.0
838 2006-01-10 *** Released version 0.7.0
834
839
835 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
840 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
836
841
837 * IPython/Release.py (revision): tag version number to 0.7.0,
842 * IPython/Release.py (revision): tag version number to 0.7.0,
838 ready for release.
843 ready for release.
839
844
840 * IPython/Magic.py (magic_edit): Add print statement to %edit so
845 * IPython/Magic.py (magic_edit): Add print statement to %edit so
841 it informs the user of the name of the temp. file used. This can
846 it informs the user of the name of the temp. file used. This can
842 help if you decide later to reuse that same file, so you know
847 help if you decide later to reuse that same file, so you know
843 where to copy the info from.
848 where to copy the info from.
844
849
845 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
850 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
846
851
847 * setup_bdist_egg.py: little script to build an egg. Added
852 * setup_bdist_egg.py: little script to build an egg. Added
848 support in the release tools as well.
853 support in the release tools as well.
849
854
850 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
855 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
851
856
852 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
857 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
853 version selection (new -wxversion command line and ipythonrc
858 version selection (new -wxversion command line and ipythonrc
854 parameter). Patch contributed by Arnd Baecker
859 parameter). Patch contributed by Arnd Baecker
855 <arnd.baecker-AT-web.de>.
860 <arnd.baecker-AT-web.de>.
856
861
857 * IPython/iplib.py (embed_mainloop): fix tab-completion in
862 * IPython/iplib.py (embed_mainloop): fix tab-completion in
858 embedded instances, for variables defined at the interactive
863 embedded instances, for variables defined at the interactive
859 prompt of the embedded ipython. Reported by Arnd.
864 prompt of the embedded ipython. Reported by Arnd.
860
865
861 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
866 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
862 it can be used as a (stateful) toggle, or with a direct parameter.
867 it can be used as a (stateful) toggle, or with a direct parameter.
863
868
864 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
869 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
865 could be triggered in certain cases and cause the traceback
870 could be triggered in certain cases and cause the traceback
866 printer not to work.
871 printer not to work.
867
872
868 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
873 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
869
874
870 * IPython/iplib.py (_should_recompile): Small fix, closes
875 * IPython/iplib.py (_should_recompile): Small fix, closes
871 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
876 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
872
877
873 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
878 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
874
879
875 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
880 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
876 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
881 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
877 Moad for help with tracking it down.
882 Moad for help with tracking it down.
878
883
879 * IPython/iplib.py (handle_auto): fix autocall handling for
884 * IPython/iplib.py (handle_auto): fix autocall handling for
880 objects which support BOTH __getitem__ and __call__ (so that f [x]
885 objects which support BOTH __getitem__ and __call__ (so that f [x]
881 is left alone, instead of becoming f([x]) automatically).
886 is left alone, instead of becoming f([x]) automatically).
882
887
883 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
888 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
884 Ville's patch.
889 Ville's patch.
885
890
886 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
891 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
887
892
888 * IPython/iplib.py (handle_auto): changed autocall semantics to
893 * IPython/iplib.py (handle_auto): changed autocall semantics to
889 include 'smart' mode, where the autocall transformation is NOT
894 include 'smart' mode, where the autocall transformation is NOT
890 applied if there are no arguments on the line. This allows you to
895 applied if there are no arguments on the line. This allows you to
891 just type 'foo' if foo is a callable to see its internal form,
896 just type 'foo' if foo is a callable to see its internal form,
892 instead of having it called with no arguments (typically a
897 instead of having it called with no arguments (typically a
893 mistake). The old 'full' autocall still exists: for that, you
898 mistake). The old 'full' autocall still exists: for that, you
894 need to set the 'autocall' parameter to 2 in your ipythonrc file.
899 need to set the 'autocall' parameter to 2 in your ipythonrc file.
895
900
896 * IPython/completer.py (Completer.attr_matches): add
901 * IPython/completer.py (Completer.attr_matches): add
897 tab-completion support for Enthoughts' traits. After a report by
902 tab-completion support for Enthoughts' traits. After a report by
898 Arnd and a patch by Prabhu.
903 Arnd and a patch by Prabhu.
899
904
900 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
905 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
901
906
902 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
907 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
903 Schmolck's patch to fix inspect.getinnerframes().
908 Schmolck's patch to fix inspect.getinnerframes().
904
909
905 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
910 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
906 for embedded instances, regarding handling of namespaces and items
911 for embedded instances, regarding handling of namespaces and items
907 added to the __builtin__ one. Multiple embedded instances and
912 added to the __builtin__ one. Multiple embedded instances and
908 recursive embeddings should work better now (though I'm not sure
913 recursive embeddings should work better now (though I'm not sure
909 I've got all the corner cases fixed, that code is a bit of a brain
914 I've got all the corner cases fixed, that code is a bit of a brain
910 twister).
915 twister).
911
916
912 * IPython/Magic.py (magic_edit): added support to edit in-memory
917 * IPython/Magic.py (magic_edit): added support to edit in-memory
913 macros (automatically creates the necessary temp files). %edit
918 macros (automatically creates the necessary temp files). %edit
914 also doesn't return the file contents anymore, it's just noise.
919 also doesn't return the file contents anymore, it's just noise.
915
920
916 * IPython/completer.py (Completer.attr_matches): revert change to
921 * IPython/completer.py (Completer.attr_matches): revert change to
917 complete only on attributes listed in __all__. I realized it
922 complete only on attributes listed in __all__. I realized it
918 cripples the tab-completion system as a tool for exploring the
923 cripples the tab-completion system as a tool for exploring the
919 internals of unknown libraries (it renders any non-__all__
924 internals of unknown libraries (it renders any non-__all__
920 attribute off-limits). I got bit by this when trying to see
925 attribute off-limits). I got bit by this when trying to see
921 something inside the dis module.
926 something inside the dis module.
922
927
923 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
928 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
924
929
925 * IPython/iplib.py (InteractiveShell.__init__): add .meta
930 * IPython/iplib.py (InteractiveShell.__init__): add .meta
926 namespace for users and extension writers to hold data in. This
931 namespace for users and extension writers to hold data in. This
927 follows the discussion in
932 follows the discussion in
928 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
933 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
929
934
930 * IPython/completer.py (IPCompleter.complete): small patch to help
935 * IPython/completer.py (IPCompleter.complete): small patch to help
931 tab-completion under Emacs, after a suggestion by John Barnard
936 tab-completion under Emacs, after a suggestion by John Barnard
932 <barnarj-AT-ccf.org>.
937 <barnarj-AT-ccf.org>.
933
938
934 * IPython/Magic.py (Magic.extract_input_slices): added support for
939 * IPython/Magic.py (Magic.extract_input_slices): added support for
935 the slice notation in magics to use N-M to represent numbers N...M
940 the slice notation in magics to use N-M to represent numbers N...M
936 (closed endpoints). This is used by %macro and %save.
941 (closed endpoints). This is used by %macro and %save.
937
942
938 * IPython/completer.py (Completer.attr_matches): for modules which
943 * IPython/completer.py (Completer.attr_matches): for modules which
939 define __all__, complete only on those. After a patch by Jeffrey
944 define __all__, complete only on those. After a patch by Jeffrey
940 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
945 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
941 speed up this routine.
946 speed up this routine.
942
947
943 * IPython/Logger.py (Logger.log): fix a history handling bug. I
948 * IPython/Logger.py (Logger.log): fix a history handling bug. I
944 don't know if this is the end of it, but the behavior now is
949 don't know if this is the end of it, but the behavior now is
945 certainly much more correct. Note that coupled with macros,
950 certainly much more correct. Note that coupled with macros,
946 slightly surprising (at first) behavior may occur: a macro will in
951 slightly surprising (at first) behavior may occur: a macro will in
947 general expand to multiple lines of input, so upon exiting, the
952 general expand to multiple lines of input, so upon exiting, the
948 in/out counters will both be bumped by the corresponding amount
953 in/out counters will both be bumped by the corresponding amount
949 (as if the macro's contents had been typed interactively). Typing
954 (as if the macro's contents had been typed interactively). Typing
950 %hist will reveal the intermediate (silently processed) lines.
955 %hist will reveal the intermediate (silently processed) lines.
951
956
952 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
957 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
953 pickle to fail (%run was overwriting __main__ and not restoring
958 pickle to fail (%run was overwriting __main__ and not restoring
954 it, but pickle relies on __main__ to operate).
959 it, but pickle relies on __main__ to operate).
955
960
956 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
961 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
957 using properties, but forgot to make the main InteractiveShell
962 using properties, but forgot to make the main InteractiveShell
958 class a new-style class. Properties fail silently, and
963 class a new-style class. Properties fail silently, and
959 mysteriously, with old-style class (getters work, but
964 mysteriously, with old-style class (getters work, but
960 setters don't do anything).
965 setters don't do anything).
961
966
962 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
967 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
963
968
964 * IPython/Magic.py (magic_history): fix history reporting bug (I
969 * IPython/Magic.py (magic_history): fix history reporting bug (I
965 know some nasties are still there, I just can't seem to find a
970 know some nasties are still there, I just can't seem to find a
966 reproducible test case to track them down; the input history is
971 reproducible test case to track them down; the input history is
967 falling out of sync...)
972 falling out of sync...)
968
973
969 * IPython/iplib.py (handle_shell_escape): fix bug where both
974 * IPython/iplib.py (handle_shell_escape): fix bug where both
970 aliases and system accesses where broken for indented code (such
975 aliases and system accesses where broken for indented code (such
971 as loops).
976 as loops).
972
977
973 * IPython/genutils.py (shell): fix small but critical bug for
978 * IPython/genutils.py (shell): fix small but critical bug for
974 win32 system access.
979 win32 system access.
975
980
976 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
981 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
977
982
978 * IPython/iplib.py (showtraceback): remove use of the
983 * IPython/iplib.py (showtraceback): remove use of the
979 sys.last_{type/value/traceback} structures, which are non
984 sys.last_{type/value/traceback} structures, which are non
980 thread-safe.
985 thread-safe.
981 (_prefilter): change control flow to ensure that we NEVER
986 (_prefilter): change control flow to ensure that we NEVER
982 introspect objects when autocall is off. This will guarantee that
987 introspect objects when autocall is off. This will guarantee that
983 having an input line of the form 'x.y', where access to attribute
988 having an input line of the form 'x.y', where access to attribute
984 'y' has side effects, doesn't trigger the side effect TWICE. It
989 'y' has side effects, doesn't trigger the side effect TWICE. It
985 is important to note that, with autocall on, these side effects
990 is important to note that, with autocall on, these side effects
986 can still happen.
991 can still happen.
987 (ipsystem): new builtin, to complete the ip{magic/alias/system}
992 (ipsystem): new builtin, to complete the ip{magic/alias/system}
988 trio. IPython offers these three kinds of special calls which are
993 trio. IPython offers these three kinds of special calls which are
989 not python code, and it's a good thing to have their call method
994 not python code, and it's a good thing to have their call method
990 be accessible as pure python functions (not just special syntax at
995 be accessible as pure python functions (not just special syntax at
991 the command line). It gives us a better internal implementation
996 the command line). It gives us a better internal implementation
992 structure, as well as exposing these for user scripting more
997 structure, as well as exposing these for user scripting more
993 cleanly.
998 cleanly.
994
999
995 * IPython/macro.py (Macro.__init__): moved macros to a standalone
1000 * IPython/macro.py (Macro.__init__): moved macros to a standalone
996 file. Now that they'll be more likely to be used with the
1001 file. Now that they'll be more likely to be used with the
997 persistance system (%store), I want to make sure their module path
1002 persistance system (%store), I want to make sure their module path
998 doesn't change in the future, so that we don't break things for
1003 doesn't change in the future, so that we don't break things for
999 users' persisted data.
1004 users' persisted data.
1000
1005
1001 * IPython/iplib.py (autoindent_update): move indentation
1006 * IPython/iplib.py (autoindent_update): move indentation
1002 management into the _text_ processing loop, not the keyboard
1007 management into the _text_ processing loop, not the keyboard
1003 interactive one. This is necessary to correctly process non-typed
1008 interactive one. This is necessary to correctly process non-typed
1004 multiline input (such as macros).
1009 multiline input (such as macros).
1005
1010
1006 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
1011 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
1007 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
1012 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
1008 which was producing problems in the resulting manual.
1013 which was producing problems in the resulting manual.
1009 (magic_whos): improve reporting of instances (show their class,
1014 (magic_whos): improve reporting of instances (show their class,
1010 instead of simply printing 'instance' which isn't terribly
1015 instead of simply printing 'instance' which isn't terribly
1011 informative).
1016 informative).
1012
1017
1013 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
1018 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
1014 (minor mods) to support network shares under win32.
1019 (minor mods) to support network shares under win32.
1015
1020
1016 * IPython/winconsole.py (get_console_size): add new winconsole
1021 * IPython/winconsole.py (get_console_size): add new winconsole
1017 module and fixes to page_dumb() to improve its behavior under
1022 module and fixes to page_dumb() to improve its behavior under
1018 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
1023 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
1019
1024
1020 * IPython/Magic.py (Macro): simplified Macro class to just
1025 * IPython/Magic.py (Macro): simplified Macro class to just
1021 subclass list. We've had only 2.2 compatibility for a very long
1026 subclass list. We've had only 2.2 compatibility for a very long
1022 time, yet I was still avoiding subclassing the builtin types. No
1027 time, yet I was still avoiding subclassing the builtin types. No
1023 more (I'm also starting to use properties, though I won't shift to
1028 more (I'm also starting to use properties, though I won't shift to
1024 2.3-specific features quite yet).
1029 2.3-specific features quite yet).
1025 (magic_store): added Ville's patch for lightweight variable
1030 (magic_store): added Ville's patch for lightweight variable
1026 persistence, after a request on the user list by Matt Wilkie
1031 persistence, after a request on the user list by Matt Wilkie
1027 <maphew-AT-gmail.com>. The new %store magic's docstring has full
1032 <maphew-AT-gmail.com>. The new %store magic's docstring has full
1028 details.
1033 details.
1029
1034
1030 * IPython/iplib.py (InteractiveShell.post_config_initialization):
1035 * IPython/iplib.py (InteractiveShell.post_config_initialization):
1031 changed the default logfile name from 'ipython.log' to
1036 changed the default logfile name from 'ipython.log' to
1032 'ipython_log.py'. These logs are real python files, and now that
1037 'ipython_log.py'. These logs are real python files, and now that
1033 we have much better multiline support, people are more likely to
1038 we have much better multiline support, people are more likely to
1034 want to use them as such. Might as well name them correctly.
1039 want to use them as such. Might as well name them correctly.
1035
1040
1036 * IPython/Magic.py: substantial cleanup. While we can't stop
1041 * IPython/Magic.py: substantial cleanup. While we can't stop
1037 using magics as mixins, due to the existing customizations 'out
1042 using magics as mixins, due to the existing customizations 'out
1038 there' which rely on the mixin naming conventions, at least I
1043 there' which rely on the mixin naming conventions, at least I
1039 cleaned out all cross-class name usage. So once we are OK with
1044 cleaned out all cross-class name usage. So once we are OK with
1040 breaking compatibility, the two systems can be separated.
1045 breaking compatibility, the two systems can be separated.
1041
1046
1042 * IPython/Logger.py: major cleanup. This one is NOT a mixin
1047 * IPython/Logger.py: major cleanup. This one is NOT a mixin
1043 anymore, and the class is a fair bit less hideous as well. New
1048 anymore, and the class is a fair bit less hideous as well. New
1044 features were also introduced: timestamping of input, and logging
1049 features were also introduced: timestamping of input, and logging
1045 of output results. These are user-visible with the -t and -o
1050 of output results. These are user-visible with the -t and -o
1046 options to %logstart. Closes
1051 options to %logstart. Closes
1047 http://www.scipy.net/roundup/ipython/issue11 and a request by
1052 http://www.scipy.net/roundup/ipython/issue11 and a request by
1048 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
1053 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
1049
1054
1050 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
1055 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
1051
1056
1052 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
1057 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
1053 better handle backslashes in paths. See the thread 'More Windows
1058 better handle backslashes in paths. See the thread 'More Windows
1054 questions part 2 - \/ characters revisited' on the iypthon user
1059 questions part 2 - \/ characters revisited' on the iypthon user
1055 list:
1060 list:
1056 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
1061 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
1057
1062
1058 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
1063 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
1059
1064
1060 (InteractiveShell.__init__): change threaded shells to not use the
1065 (InteractiveShell.__init__): change threaded shells to not use the
1061 ipython crash handler. This was causing more problems than not,
1066 ipython crash handler. This was causing more problems than not,
1062 as exceptions in the main thread (GUI code, typically) would
1067 as exceptions in the main thread (GUI code, typically) would
1063 always show up as a 'crash', when they really weren't.
1068 always show up as a 'crash', when they really weren't.
1064
1069
1065 The colors and exception mode commands (%colors/%xmode) have been
1070 The colors and exception mode commands (%colors/%xmode) have been
1066 synchronized to also take this into account, so users can get
1071 synchronized to also take this into account, so users can get
1067 verbose exceptions for their threaded code as well. I also added
1072 verbose exceptions for their threaded code as well. I also added
1068 support for activating pdb inside this exception handler as well,
1073 support for activating pdb inside this exception handler as well,
1069 so now GUI authors can use IPython's enhanced pdb at runtime.
1074 so now GUI authors can use IPython's enhanced pdb at runtime.
1070
1075
1071 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
1076 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
1072 true by default, and add it to the shipped ipythonrc file. Since
1077 true by default, and add it to the shipped ipythonrc file. Since
1073 this asks the user before proceeding, I think it's OK to make it
1078 this asks the user before proceeding, I think it's OK to make it
1074 true by default.
1079 true by default.
1075
1080
1076 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
1081 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
1077 of the previous special-casing of input in the eval loop. I think
1082 of the previous special-casing of input in the eval loop. I think
1078 this is cleaner, as they really are commands and shouldn't have
1083 this is cleaner, as they really are commands and shouldn't have
1079 a special role in the middle of the core code.
1084 a special role in the middle of the core code.
1080
1085
1081 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
1086 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
1082
1087
1083 * IPython/iplib.py (edit_syntax_error): added support for
1088 * IPython/iplib.py (edit_syntax_error): added support for
1084 automatically reopening the editor if the file had a syntax error
1089 automatically reopening the editor if the file had a syntax error
1085 in it. Thanks to scottt who provided the patch at:
1090 in it. Thanks to scottt who provided the patch at:
1086 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
1091 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
1087 version committed).
1092 version committed).
1088
1093
1089 * IPython/iplib.py (handle_normal): add suport for multi-line
1094 * IPython/iplib.py (handle_normal): add suport for multi-line
1090 input with emtpy lines. This fixes
1095 input with emtpy lines. This fixes
1091 http://www.scipy.net/roundup/ipython/issue43 and a similar
1096 http://www.scipy.net/roundup/ipython/issue43 and a similar
1092 discussion on the user list.
1097 discussion on the user list.
1093
1098
1094 WARNING: a behavior change is necessarily introduced to support
1099 WARNING: a behavior change is necessarily introduced to support
1095 blank lines: now a single blank line with whitespace does NOT
1100 blank lines: now a single blank line with whitespace does NOT
1096 break the input loop, which means that when autoindent is on, by
1101 break the input loop, which means that when autoindent is on, by
1097 default hitting return on the next (indented) line does NOT exit.
1102 default hitting return on the next (indented) line does NOT exit.
1098
1103
1099 Instead, to exit a multiline input you can either have:
1104 Instead, to exit a multiline input you can either have:
1100
1105
1101 - TWO whitespace lines (just hit return again), or
1106 - TWO whitespace lines (just hit return again), or
1102 - a single whitespace line of a different length than provided
1107 - a single whitespace line of a different length than provided
1103 by the autoindent (add or remove a space).
1108 by the autoindent (add or remove a space).
1104
1109
1105 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
1110 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
1106 module to better organize all readline-related functionality.
1111 module to better organize all readline-related functionality.
1107 I've deleted FlexCompleter and put all completion clases here.
1112 I've deleted FlexCompleter and put all completion clases here.
1108
1113
1109 * IPython/iplib.py (raw_input): improve indentation management.
1114 * IPython/iplib.py (raw_input): improve indentation management.
1110 It is now possible to paste indented code with autoindent on, and
1115 It is now possible to paste indented code with autoindent on, and
1111 the code is interpreted correctly (though it still looks bad on
1116 the code is interpreted correctly (though it still looks bad on
1112 screen, due to the line-oriented nature of ipython).
1117 screen, due to the line-oriented nature of ipython).
1113 (MagicCompleter.complete): change behavior so that a TAB key on an
1118 (MagicCompleter.complete): change behavior so that a TAB key on an
1114 otherwise empty line actually inserts a tab, instead of completing
1119 otherwise empty line actually inserts a tab, instead of completing
1115 on the entire global namespace. This makes it easier to use the
1120 on the entire global namespace. This makes it easier to use the
1116 TAB key for indentation. After a request by Hans Meine
1121 TAB key for indentation. After a request by Hans Meine
1117 <hans_meine-AT-gmx.net>
1122 <hans_meine-AT-gmx.net>
1118 (_prefilter): add support so that typing plain 'exit' or 'quit'
1123 (_prefilter): add support so that typing plain 'exit' or 'quit'
1119 does a sensible thing. Originally I tried to deviate as little as
1124 does a sensible thing. Originally I tried to deviate as little as
1120 possible from the default python behavior, but even that one may
1125 possible from the default python behavior, but even that one may
1121 change in this direction (thread on python-dev to that effect).
1126 change in this direction (thread on python-dev to that effect).
1122 Regardless, ipython should do the right thing even if CPython's
1127 Regardless, ipython should do the right thing even if CPython's
1123 '>>>' prompt doesn't.
1128 '>>>' prompt doesn't.
1124 (InteractiveShell): removed subclassing code.InteractiveConsole
1129 (InteractiveShell): removed subclassing code.InteractiveConsole
1125 class. By now we'd overridden just about all of its methods: I've
1130 class. By now we'd overridden just about all of its methods: I've
1126 copied the remaining two over, and now ipython is a standalone
1131 copied the remaining two over, and now ipython is a standalone
1127 class. This will provide a clearer picture for the chainsaw
1132 class. This will provide a clearer picture for the chainsaw
1128 branch refactoring.
1133 branch refactoring.
1129
1134
1130 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
1135 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
1131
1136
1132 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
1137 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
1133 failures for objects which break when dir() is called on them.
1138 failures for objects which break when dir() is called on them.
1134
1139
1135 * IPython/FlexCompleter.py (Completer.__init__): Added support for
1140 * IPython/FlexCompleter.py (Completer.__init__): Added support for
1136 distinct local and global namespaces in the completer API. This
1141 distinct local and global namespaces in the completer API. This
1137 change allows us to properly handle completion with distinct
1142 change allows us to properly handle completion with distinct
1138 scopes, including in embedded instances (this had never really
1143 scopes, including in embedded instances (this had never really
1139 worked correctly).
1144 worked correctly).
1140
1145
1141 Note: this introduces a change in the constructor for
1146 Note: this introduces a change in the constructor for
1142 MagicCompleter, as a new global_namespace parameter is now the
1147 MagicCompleter, as a new global_namespace parameter is now the
1143 second argument (the others were bumped one position).
1148 second argument (the others were bumped one position).
1144
1149
1145 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
1150 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
1146
1151
1147 * IPython/iplib.py (embed_mainloop): fix tab-completion in
1152 * IPython/iplib.py (embed_mainloop): fix tab-completion in
1148 embedded instances (which can be done now thanks to Vivian's
1153 embedded instances (which can be done now thanks to Vivian's
1149 frame-handling fixes for pdb).
1154 frame-handling fixes for pdb).
1150 (InteractiveShell.__init__): Fix namespace handling problem in
1155 (InteractiveShell.__init__): Fix namespace handling problem in
1151 embedded instances. We were overwriting __main__ unconditionally,
1156 embedded instances. We were overwriting __main__ unconditionally,
1152 and this should only be done for 'full' (non-embedded) IPython;
1157 and this should only be done for 'full' (non-embedded) IPython;
1153 embedded instances must respect the caller's __main__. Thanks to
1158 embedded instances must respect the caller's __main__. Thanks to
1154 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
1159 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
1155
1160
1156 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
1161 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
1157
1162
1158 * setup.py: added download_url to setup(). This registers the
1163 * setup.py: added download_url to setup(). This registers the
1159 download address at PyPI, which is not only useful to humans
1164 download address at PyPI, which is not only useful to humans
1160 browsing the site, but is also picked up by setuptools (the Eggs
1165 browsing the site, but is also picked up by setuptools (the Eggs
1161 machinery). Thanks to Ville and R. Kern for the info/discussion
1166 machinery). Thanks to Ville and R. Kern for the info/discussion
1162 on this.
1167 on this.
1163
1168
1164 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
1169 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
1165
1170
1166 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
1171 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
1167 This brings a lot of nice functionality to the pdb mode, which now
1172 This brings a lot of nice functionality to the pdb mode, which now
1168 has tab-completion, syntax highlighting, and better stack handling
1173 has tab-completion, syntax highlighting, and better stack handling
1169 than before. Many thanks to Vivian De Smedt
1174 than before. Many thanks to Vivian De Smedt
1170 <vivian-AT-vdesmedt.com> for the original patches.
1175 <vivian-AT-vdesmedt.com> for the original patches.
1171
1176
1172 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
1177 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
1173
1178
1174 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
1179 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
1175 sequence to consistently accept the banner argument. The
1180 sequence to consistently accept the banner argument. The
1176 inconsistency was tripping SAGE, thanks to Gary Zablackis
1181 inconsistency was tripping SAGE, thanks to Gary Zablackis
1177 <gzabl-AT-yahoo.com> for the report.
1182 <gzabl-AT-yahoo.com> for the report.
1178
1183
1179 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
1184 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
1180
1185
1181 * IPython/iplib.py (InteractiveShell.post_config_initialization):
1186 * IPython/iplib.py (InteractiveShell.post_config_initialization):
1182 Fix bug where a naked 'alias' call in the ipythonrc file would
1187 Fix bug where a naked 'alias' call in the ipythonrc file would
1183 cause a crash. Bug reported by Jorgen Stenarson.
1188 cause a crash. Bug reported by Jorgen Stenarson.
1184
1189
1185 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
1190 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
1186
1191
1187 * IPython/ipmaker.py (make_IPython): cleanups which should improve
1192 * IPython/ipmaker.py (make_IPython): cleanups which should improve
1188 startup time.
1193 startup time.
1189
1194
1190 * IPython/iplib.py (runcode): my globals 'fix' for embedded
1195 * IPython/iplib.py (runcode): my globals 'fix' for embedded
1191 instances had introduced a bug with globals in normal code. Now
1196 instances had introduced a bug with globals in normal code. Now
1192 it's working in all cases.
1197 it's working in all cases.
1193
1198
1194 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
1199 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
1195 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
1200 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
1196 has been introduced to set the default case sensitivity of the
1201 has been introduced to set the default case sensitivity of the
1197 searches. Users can still select either mode at runtime on a
1202 searches. Users can still select either mode at runtime on a
1198 per-search basis.
1203 per-search basis.
1199
1204
1200 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
1205 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
1201
1206
1202 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
1207 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
1203 attributes in wildcard searches for subclasses. Modified version
1208 attributes in wildcard searches for subclasses. Modified version
1204 of a patch by Jorgen.
1209 of a patch by Jorgen.
1205
1210
1206 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
1211 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
1207
1212
1208 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
1213 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
1209 embedded instances. I added a user_global_ns attribute to the
1214 embedded instances. I added a user_global_ns attribute to the
1210 InteractiveShell class to handle this.
1215 InteractiveShell class to handle this.
1211
1216
1212 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
1217 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
1213
1218
1214 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
1219 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
1215 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
1220 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
1216 (reported under win32, but may happen also in other platforms).
1221 (reported under win32, but may happen also in other platforms).
1217 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
1222 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
1218
1223
1219 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
1224 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
1220
1225
1221 * IPython/Magic.py (magic_psearch): new support for wildcard
1226 * IPython/Magic.py (magic_psearch): new support for wildcard
1222 patterns. Now, typing ?a*b will list all names which begin with a
1227 patterns. Now, typing ?a*b will list all names which begin with a
1223 and end in b, for example. The %psearch magic has full
1228 and end in b, for example. The %psearch magic has full
1224 docstrings. Many thanks to JΓΆrgen Stenarson
1229 docstrings. Many thanks to JΓΆrgen Stenarson
1225 <jorgen.stenarson-AT-bostream.nu>, author of the patches
1230 <jorgen.stenarson-AT-bostream.nu>, author of the patches
1226 implementing this functionality.
1231 implementing this functionality.
1227
1232
1228 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1233 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1229
1234
1230 * Manual: fixed long-standing annoyance of double-dashes (as in
1235 * Manual: fixed long-standing annoyance of double-dashes (as in
1231 --prefix=~, for example) being stripped in the HTML version. This
1236 --prefix=~, for example) being stripped in the HTML version. This
1232 is a latex2html bug, but a workaround was provided. Many thanks
1237 is a latex2html bug, but a workaround was provided. Many thanks
1233 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
1238 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
1234 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
1239 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
1235 rolling. This seemingly small issue had tripped a number of users
1240 rolling. This seemingly small issue had tripped a number of users
1236 when first installing, so I'm glad to see it gone.
1241 when first installing, so I'm glad to see it gone.
1237
1242
1238 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1243 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1239
1244
1240 * IPython/Extensions/numeric_formats.py: fix missing import,
1245 * IPython/Extensions/numeric_formats.py: fix missing import,
1241 reported by Stephen Walton.
1246 reported by Stephen Walton.
1242
1247
1243 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
1248 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
1244
1249
1245 * IPython/demo.py: finish demo module, fully documented now.
1250 * IPython/demo.py: finish demo module, fully documented now.
1246
1251
1247 * IPython/genutils.py (file_read): simple little utility to read a
1252 * IPython/genutils.py (file_read): simple little utility to read a
1248 file and ensure it's closed afterwards.
1253 file and ensure it's closed afterwards.
1249
1254
1250 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
1255 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
1251
1256
1252 * IPython/demo.py (Demo.__init__): added support for individually
1257 * IPython/demo.py (Demo.__init__): added support for individually
1253 tagging blocks for automatic execution.
1258 tagging blocks for automatic execution.
1254
1259
1255 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
1260 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
1256 syntax-highlighted python sources, requested by John.
1261 syntax-highlighted python sources, requested by John.
1257
1262
1258 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
1263 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
1259
1264
1260 * IPython/demo.py (Demo.again): fix bug where again() blocks after
1265 * IPython/demo.py (Demo.again): fix bug where again() blocks after
1261 finishing.
1266 finishing.
1262
1267
1263 * IPython/genutils.py (shlex_split): moved from Magic to here,
1268 * IPython/genutils.py (shlex_split): moved from Magic to here,
1264 where all 2.2 compatibility stuff lives. I needed it for demo.py.
1269 where all 2.2 compatibility stuff lives. I needed it for demo.py.
1265
1270
1266 * IPython/demo.py (Demo.__init__): added support for silent
1271 * IPython/demo.py (Demo.__init__): added support for silent
1267 blocks, improved marks as regexps, docstrings written.
1272 blocks, improved marks as regexps, docstrings written.
1268 (Demo.__init__): better docstring, added support for sys.argv.
1273 (Demo.__init__): better docstring, added support for sys.argv.
1269
1274
1270 * IPython/genutils.py (marquee): little utility used by the demo
1275 * IPython/genutils.py (marquee): little utility used by the demo
1271 code, handy in general.
1276 code, handy in general.
1272
1277
1273 * IPython/demo.py (Demo.__init__): new class for interactive
1278 * IPython/demo.py (Demo.__init__): new class for interactive
1274 demos. Not documented yet, I just wrote it in a hurry for
1279 demos. Not documented yet, I just wrote it in a hurry for
1275 scipy'05. Will docstring later.
1280 scipy'05. Will docstring later.
1276
1281
1277 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
1282 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
1278
1283
1279 * IPython/Shell.py (sigint_handler): Drastic simplification which
1284 * IPython/Shell.py (sigint_handler): Drastic simplification which
1280 also seems to make Ctrl-C work correctly across threads! This is
1285 also seems to make Ctrl-C work correctly across threads! This is
1281 so simple, that I can't beleive I'd missed it before. Needs more
1286 so simple, that I can't beleive I'd missed it before. Needs more
1282 testing, though.
1287 testing, though.
1283 (KBINT): Never mind, revert changes. I'm sure I'd tried something
1288 (KBINT): Never mind, revert changes. I'm sure I'd tried something
1284 like this before...
1289 like this before...
1285
1290
1286 * IPython/genutils.py (get_home_dir): add protection against
1291 * IPython/genutils.py (get_home_dir): add protection against
1287 non-dirs in win32 registry.
1292 non-dirs in win32 registry.
1288
1293
1289 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
1294 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
1290 bug where dict was mutated while iterating (pysh crash).
1295 bug where dict was mutated while iterating (pysh crash).
1291
1296
1292 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
1297 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
1293
1298
1294 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
1299 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
1295 spurious newlines added by this routine. After a report by
1300 spurious newlines added by this routine. After a report by
1296 F. Mantegazza.
1301 F. Mantegazza.
1297
1302
1298 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
1303 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
1299
1304
1300 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
1305 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
1301 calls. These were a leftover from the GTK 1.x days, and can cause
1306 calls. These were a leftover from the GTK 1.x days, and can cause
1302 problems in certain cases (after a report by John Hunter).
1307 problems in certain cases (after a report by John Hunter).
1303
1308
1304 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
1309 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
1305 os.getcwd() fails at init time. Thanks to patch from David Remahl
1310 os.getcwd() fails at init time. Thanks to patch from David Remahl
1306 <chmod007-AT-mac.com>.
1311 <chmod007-AT-mac.com>.
1307 (InteractiveShell.__init__): prevent certain special magics from
1312 (InteractiveShell.__init__): prevent certain special magics from
1308 being shadowed by aliases. Closes
1313 being shadowed by aliases. Closes
1309 http://www.scipy.net/roundup/ipython/issue41.
1314 http://www.scipy.net/roundup/ipython/issue41.
1310
1315
1311 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
1316 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
1312
1317
1313 * IPython/iplib.py (InteractiveShell.complete): Added new
1318 * IPython/iplib.py (InteractiveShell.complete): Added new
1314 top-level completion method to expose the completion mechanism
1319 top-level completion method to expose the completion mechanism
1315 beyond readline-based environments.
1320 beyond readline-based environments.
1316
1321
1317 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
1322 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
1318
1323
1319 * tools/ipsvnc (svnversion): fix svnversion capture.
1324 * tools/ipsvnc (svnversion): fix svnversion capture.
1320
1325
1321 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
1326 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
1322 attribute to self, which was missing. Before, it was set by a
1327 attribute to self, which was missing. Before, it was set by a
1323 routine which in certain cases wasn't being called, so the
1328 routine which in certain cases wasn't being called, so the
1324 instance could end up missing the attribute. This caused a crash.
1329 instance could end up missing the attribute. This caused a crash.
1325 Closes http://www.scipy.net/roundup/ipython/issue40.
1330 Closes http://www.scipy.net/roundup/ipython/issue40.
1326
1331
1327 2005-08-16 Fernando Perez <fperez@colorado.edu>
1332 2005-08-16 Fernando Perez <fperez@colorado.edu>
1328
1333
1329 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
1334 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
1330 contains non-string attribute. Closes
1335 contains non-string attribute. Closes
1331 http://www.scipy.net/roundup/ipython/issue38.
1336 http://www.scipy.net/roundup/ipython/issue38.
1332
1337
1333 2005-08-14 Fernando Perez <fperez@colorado.edu>
1338 2005-08-14 Fernando Perez <fperez@colorado.edu>
1334
1339
1335 * tools/ipsvnc: Minor improvements, to add changeset info.
1340 * tools/ipsvnc: Minor improvements, to add changeset info.
1336
1341
1337 2005-08-12 Fernando Perez <fperez@colorado.edu>
1342 2005-08-12 Fernando Perez <fperez@colorado.edu>
1338
1343
1339 * IPython/iplib.py (runsource): remove self.code_to_run_src
1344 * IPython/iplib.py (runsource): remove self.code_to_run_src
1340 attribute. I realized this is nothing more than
1345 attribute. I realized this is nothing more than
1341 '\n'.join(self.buffer), and having the same data in two different
1346 '\n'.join(self.buffer), and having the same data in two different
1342 places is just asking for synchronization bugs. This may impact
1347 places is just asking for synchronization bugs. This may impact
1343 people who have custom exception handlers, so I need to warn
1348 people who have custom exception handlers, so I need to warn
1344 ipython-dev about it (F. Mantegazza may use them).
1349 ipython-dev about it (F. Mantegazza may use them).
1345
1350
1346 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
1351 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
1347
1352
1348 * IPython/genutils.py: fix 2.2 compatibility (generators)
1353 * IPython/genutils.py: fix 2.2 compatibility (generators)
1349
1354
1350 2005-07-18 Fernando Perez <fperez@colorado.edu>
1355 2005-07-18 Fernando Perez <fperez@colorado.edu>
1351
1356
1352 * IPython/genutils.py (get_home_dir): fix to help users with
1357 * IPython/genutils.py (get_home_dir): fix to help users with
1353 invalid $HOME under win32.
1358 invalid $HOME under win32.
1354
1359
1355 2005-07-17 Fernando Perez <fperez@colorado.edu>
1360 2005-07-17 Fernando Perez <fperez@colorado.edu>
1356
1361
1357 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
1362 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
1358 some old hacks and clean up a bit other routines; code should be
1363 some old hacks and clean up a bit other routines; code should be
1359 simpler and a bit faster.
1364 simpler and a bit faster.
1360
1365
1361 * IPython/iplib.py (interact): removed some last-resort attempts
1366 * IPython/iplib.py (interact): removed some last-resort attempts
1362 to survive broken stdout/stderr. That code was only making it
1367 to survive broken stdout/stderr. That code was only making it
1363 harder to abstract out the i/o (necessary for gui integration),
1368 harder to abstract out the i/o (necessary for gui integration),
1364 and the crashes it could prevent were extremely rare in practice
1369 and the crashes it could prevent were extremely rare in practice
1365 (besides being fully user-induced in a pretty violent manner).
1370 (besides being fully user-induced in a pretty violent manner).
1366
1371
1367 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
1372 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
1368 Nothing major yet, but the code is simpler to read; this should
1373 Nothing major yet, but the code is simpler to read; this should
1369 make it easier to do more serious modifications in the future.
1374 make it easier to do more serious modifications in the future.
1370
1375
1371 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
1376 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
1372 which broke in .15 (thanks to a report by Ville).
1377 which broke in .15 (thanks to a report by Ville).
1373
1378
1374 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
1379 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
1375 be quite correct, I know next to nothing about unicode). This
1380 be quite correct, I know next to nothing about unicode). This
1376 will allow unicode strings to be used in prompts, amongst other
1381 will allow unicode strings to be used in prompts, amongst other
1377 cases. It also will prevent ipython from crashing when unicode
1382 cases. It also will prevent ipython from crashing when unicode
1378 shows up unexpectedly in many places. If ascii encoding fails, we
1383 shows up unexpectedly in many places. If ascii encoding fails, we
1379 assume utf_8. Currently the encoding is not a user-visible
1384 assume utf_8. Currently the encoding is not a user-visible
1380 setting, though it could be made so if there is demand for it.
1385 setting, though it could be made so if there is demand for it.
1381
1386
1382 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
1387 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
1383
1388
1384 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
1389 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
1385
1390
1386 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
1391 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
1387
1392
1388 * IPython/genutils.py: Add 2.2 compatibility here, so all other
1393 * IPython/genutils.py: Add 2.2 compatibility here, so all other
1389 code can work transparently for 2.2/2.3.
1394 code can work transparently for 2.2/2.3.
1390
1395
1391 2005-07-16 Fernando Perez <fperez@colorado.edu>
1396 2005-07-16 Fernando Perez <fperez@colorado.edu>
1392
1397
1393 * IPython/ultraTB.py (ExceptionColors): Make a global variable
1398 * IPython/ultraTB.py (ExceptionColors): Make a global variable
1394 out of the color scheme table used for coloring exception
1399 out of the color scheme table used for coloring exception
1395 tracebacks. This allows user code to add new schemes at runtime.
1400 tracebacks. This allows user code to add new schemes at runtime.
1396 This is a minimally modified version of the patch at
1401 This is a minimally modified version of the patch at
1397 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
1402 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
1398 for the contribution.
1403 for the contribution.
1399
1404
1400 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
1405 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
1401 slightly modified version of the patch in
1406 slightly modified version of the patch in
1402 http://www.scipy.net/roundup/ipython/issue34, which also allows me
1407 http://www.scipy.net/roundup/ipython/issue34, which also allows me
1403 to remove the previous try/except solution (which was costlier).
1408 to remove the previous try/except solution (which was costlier).
1404 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
1409 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
1405
1410
1406 2005-06-08 Fernando Perez <fperez@colorado.edu>
1411 2005-06-08 Fernando Perez <fperez@colorado.edu>
1407
1412
1408 * IPython/iplib.py (write/write_err): Add methods to abstract all
1413 * IPython/iplib.py (write/write_err): Add methods to abstract all
1409 I/O a bit more.
1414 I/O a bit more.
1410
1415
1411 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
1416 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
1412 warning, reported by Aric Hagberg, fix by JD Hunter.
1417 warning, reported by Aric Hagberg, fix by JD Hunter.
1413
1418
1414 2005-06-02 *** Released version 0.6.15
1419 2005-06-02 *** Released version 0.6.15
1415
1420
1416 2005-06-01 Fernando Perez <fperez@colorado.edu>
1421 2005-06-01 Fernando Perez <fperez@colorado.edu>
1417
1422
1418 * IPython/iplib.py (MagicCompleter.file_matches): Fix
1423 * IPython/iplib.py (MagicCompleter.file_matches): Fix
1419 tab-completion of filenames within open-quoted strings. Note that
1424 tab-completion of filenames within open-quoted strings. Note that
1420 this requires that in ~/.ipython/ipythonrc, users change the
1425 this requires that in ~/.ipython/ipythonrc, users change the
1421 readline delimiters configuration to read:
1426 readline delimiters configuration to read:
1422
1427
1423 readline_remove_delims -/~
1428 readline_remove_delims -/~
1424
1429
1425
1430
1426 2005-05-31 *** Released version 0.6.14
1431 2005-05-31 *** Released version 0.6.14
1427
1432
1428 2005-05-29 Fernando Perez <fperez@colorado.edu>
1433 2005-05-29 Fernando Perez <fperez@colorado.edu>
1429
1434
1430 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
1435 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
1431 with files not on the filesystem. Reported by Eliyahu Sandler
1436 with files not on the filesystem. Reported by Eliyahu Sandler
1432 <eli@gondolin.net>
1437 <eli@gondolin.net>
1433
1438
1434 2005-05-22 Fernando Perez <fperez@colorado.edu>
1439 2005-05-22 Fernando Perez <fperez@colorado.edu>
1435
1440
1436 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
1441 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
1437 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
1442 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
1438
1443
1439 2005-05-19 Fernando Perez <fperez@colorado.edu>
1444 2005-05-19 Fernando Perez <fperez@colorado.edu>
1440
1445
1441 * IPython/iplib.py (safe_execfile): close a file which could be
1446 * IPython/iplib.py (safe_execfile): close a file which could be
1442 left open (causing problems in win32, which locks open files).
1447 left open (causing problems in win32, which locks open files).
1443 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
1448 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
1444
1449
1445 2005-05-18 Fernando Perez <fperez@colorado.edu>
1450 2005-05-18 Fernando Perez <fperez@colorado.edu>
1446
1451
1447 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
1452 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
1448 keyword arguments correctly to safe_execfile().
1453 keyword arguments correctly to safe_execfile().
1449
1454
1450 2005-05-13 Fernando Perez <fperez@colorado.edu>
1455 2005-05-13 Fernando Perez <fperez@colorado.edu>
1451
1456
1452 * ipython.1: Added info about Qt to manpage, and threads warning
1457 * ipython.1: Added info about Qt to manpage, and threads warning
1453 to usage page (invoked with --help).
1458 to usage page (invoked with --help).
1454
1459
1455 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
1460 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
1456 new matcher (it goes at the end of the priority list) to do
1461 new matcher (it goes at the end of the priority list) to do
1457 tab-completion on named function arguments. Submitted by George
1462 tab-completion on named function arguments. Submitted by George
1458 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
1463 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
1459 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
1464 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
1460 for more details.
1465 for more details.
1461
1466
1462 * IPython/Magic.py (magic_run): Added new -e flag to ignore
1467 * IPython/Magic.py (magic_run): Added new -e flag to ignore
1463 SystemExit exceptions in the script being run. Thanks to a report
1468 SystemExit exceptions in the script being run. Thanks to a report
1464 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
1469 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
1465 producing very annoying behavior when running unit tests.
1470 producing very annoying behavior when running unit tests.
1466
1471
1467 2005-05-12 Fernando Perez <fperez@colorado.edu>
1472 2005-05-12 Fernando Perez <fperez@colorado.edu>
1468
1473
1469 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
1474 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
1470 which I'd broken (again) due to a changed regexp. In the process,
1475 which I'd broken (again) due to a changed regexp. In the process,
1471 added ';' as an escape to auto-quote the whole line without
1476 added ';' as an escape to auto-quote the whole line without
1472 splitting its arguments. Thanks to a report by Jerry McRae
1477 splitting its arguments. Thanks to a report by Jerry McRae
1473 <qrs0xyc02-AT-sneakemail.com>.
1478 <qrs0xyc02-AT-sneakemail.com>.
1474
1479
1475 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
1480 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
1476 possible crashes caused by a TokenError. Reported by Ed Schofield
1481 possible crashes caused by a TokenError. Reported by Ed Schofield
1477 <schofield-AT-ftw.at>.
1482 <schofield-AT-ftw.at>.
1478
1483
1479 2005-05-06 Fernando Perez <fperez@colorado.edu>
1484 2005-05-06 Fernando Perez <fperez@colorado.edu>
1480
1485
1481 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
1486 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
1482
1487
1483 2005-04-29 Fernando Perez <fperez@colorado.edu>
1488 2005-04-29 Fernando Perez <fperez@colorado.edu>
1484
1489
1485 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
1490 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
1486 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
1491 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
1487 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
1492 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
1488 which provides support for Qt interactive usage (similar to the
1493 which provides support for Qt interactive usage (similar to the
1489 existing one for WX and GTK). This had been often requested.
1494 existing one for WX and GTK). This had been often requested.
1490
1495
1491 2005-04-14 *** Released version 0.6.13
1496 2005-04-14 *** Released version 0.6.13
1492
1497
1493 2005-04-08 Fernando Perez <fperez@colorado.edu>
1498 2005-04-08 Fernando Perez <fperez@colorado.edu>
1494
1499
1495 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
1500 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
1496 from _ofind, which gets called on almost every input line. Now,
1501 from _ofind, which gets called on almost every input line. Now,
1497 we only try to get docstrings if they are actually going to be
1502 we only try to get docstrings if they are actually going to be
1498 used (the overhead of fetching unnecessary docstrings can be
1503 used (the overhead of fetching unnecessary docstrings can be
1499 noticeable for certain objects, such as Pyro proxies).
1504 noticeable for certain objects, such as Pyro proxies).
1500
1505
1501 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
1506 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
1502 for completers. For some reason I had been passing them the state
1507 for completers. For some reason I had been passing them the state
1503 variable, which completers never actually need, and was in
1508 variable, which completers never actually need, and was in
1504 conflict with the rlcompleter API. Custom completers ONLY need to
1509 conflict with the rlcompleter API. Custom completers ONLY need to
1505 take the text parameter.
1510 take the text parameter.
1506
1511
1507 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
1512 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
1508 work correctly in pysh. I've also moved all the logic which used
1513 work correctly in pysh. I've also moved all the logic which used
1509 to be in pysh.py here, which will prevent problems with future
1514 to be in pysh.py here, which will prevent problems with future
1510 upgrades. However, this time I must warn users to update their
1515 upgrades. However, this time I must warn users to update their
1511 pysh profile to include the line
1516 pysh profile to include the line
1512
1517
1513 import_all IPython.Extensions.InterpreterExec
1518 import_all IPython.Extensions.InterpreterExec
1514
1519
1515 because otherwise things won't work for them. They MUST also
1520 because otherwise things won't work for them. They MUST also
1516 delete pysh.py and the line
1521 delete pysh.py and the line
1517
1522
1518 execfile pysh.py
1523 execfile pysh.py
1519
1524
1520 from their ipythonrc-pysh.
1525 from their ipythonrc-pysh.
1521
1526
1522 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
1527 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
1523 robust in the face of objects whose dir() returns non-strings
1528 robust in the face of objects whose dir() returns non-strings
1524 (which it shouldn't, but some broken libs like ITK do). Thanks to
1529 (which it shouldn't, but some broken libs like ITK do). Thanks to
1525 a patch by John Hunter (implemented differently, though). Also
1530 a patch by John Hunter (implemented differently, though). Also
1526 minor improvements by using .extend instead of + on lists.
1531 minor improvements by using .extend instead of + on lists.
1527
1532
1528 * pysh.py:
1533 * pysh.py:
1529
1534
1530 2005-04-06 Fernando Perez <fperez@colorado.edu>
1535 2005-04-06 Fernando Perez <fperez@colorado.edu>
1531
1536
1532 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
1537 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
1533 by default, so that all users benefit from it. Those who don't
1538 by default, so that all users benefit from it. Those who don't
1534 want it can still turn it off.
1539 want it can still turn it off.
1535
1540
1536 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
1541 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
1537 config file, I'd forgotten about this, so users were getting it
1542 config file, I'd forgotten about this, so users were getting it
1538 off by default.
1543 off by default.
1539
1544
1540 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
1545 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
1541 consistency. Now magics can be called in multiline statements,
1546 consistency. Now magics can be called in multiline statements,
1542 and python variables can be expanded in magic calls via $var.
1547 and python variables can be expanded in magic calls via $var.
1543 This makes the magic system behave just like aliases or !system
1548 This makes the magic system behave just like aliases or !system
1544 calls.
1549 calls.
1545
1550
1546 2005-03-28 Fernando Perez <fperez@colorado.edu>
1551 2005-03-28 Fernando Perez <fperez@colorado.edu>
1547
1552
1548 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
1553 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
1549 expensive string additions for building command. Add support for
1554 expensive string additions for building command. Add support for
1550 trailing ';' when autocall is used.
1555 trailing ';' when autocall is used.
1551
1556
1552 2005-03-26 Fernando Perez <fperez@colorado.edu>
1557 2005-03-26 Fernando Perez <fperez@colorado.edu>
1553
1558
1554 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
1559 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
1555 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
1560 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
1556 ipython.el robust against prompts with any number of spaces
1561 ipython.el robust against prompts with any number of spaces
1557 (including 0) after the ':' character.
1562 (including 0) after the ':' character.
1558
1563
1559 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
1564 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
1560 continuation prompt, which misled users to think the line was
1565 continuation prompt, which misled users to think the line was
1561 already indented. Closes debian Bug#300847, reported to me by
1566 already indented. Closes debian Bug#300847, reported to me by
1562 Norbert Tretkowski <tretkowski-AT-inittab.de>.
1567 Norbert Tretkowski <tretkowski-AT-inittab.de>.
1563
1568
1564 2005-03-23 Fernando Perez <fperez@colorado.edu>
1569 2005-03-23 Fernando Perez <fperez@colorado.edu>
1565
1570
1566 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
1571 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
1567 properly aligned if they have embedded newlines.
1572 properly aligned if they have embedded newlines.
1568
1573
1569 * IPython/iplib.py (runlines): Add a public method to expose
1574 * IPython/iplib.py (runlines): Add a public method to expose
1570 IPython's code execution machinery, so that users can run strings
1575 IPython's code execution machinery, so that users can run strings
1571 as if they had been typed at the prompt interactively.
1576 as if they had been typed at the prompt interactively.
1572 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
1577 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
1573 methods which can call the system shell, but with python variable
1578 methods which can call the system shell, but with python variable
1574 expansion. The three such methods are: __IPYTHON__.system,
1579 expansion. The three such methods are: __IPYTHON__.system,
1575 .getoutput and .getoutputerror. These need to be documented in a
1580 .getoutput and .getoutputerror. These need to be documented in a
1576 'public API' section (to be written) of the manual.
1581 'public API' section (to be written) of the manual.
1577
1582
1578 2005-03-20 Fernando Perez <fperez@colorado.edu>
1583 2005-03-20 Fernando Perez <fperez@colorado.edu>
1579
1584
1580 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
1585 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
1581 for custom exception handling. This is quite powerful, and it
1586 for custom exception handling. This is quite powerful, and it
1582 allows for user-installable exception handlers which can trap
1587 allows for user-installable exception handlers which can trap
1583 custom exceptions at runtime and treat them separately from
1588 custom exceptions at runtime and treat them separately from
1584 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
1589 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
1585 Mantegazza <mantegazza-AT-ill.fr>.
1590 Mantegazza <mantegazza-AT-ill.fr>.
1586 (InteractiveShell.set_custom_completer): public API function to
1591 (InteractiveShell.set_custom_completer): public API function to
1587 add new completers at runtime.
1592 add new completers at runtime.
1588
1593
1589 2005-03-19 Fernando Perez <fperez@colorado.edu>
1594 2005-03-19 Fernando Perez <fperez@colorado.edu>
1590
1595
1591 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
1596 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
1592 allow objects which provide their docstrings via non-standard
1597 allow objects which provide their docstrings via non-standard
1593 mechanisms (like Pyro proxies) to still be inspected by ipython's
1598 mechanisms (like Pyro proxies) to still be inspected by ipython's
1594 ? system.
1599 ? system.
1595
1600
1596 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
1601 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
1597 automatic capture system. I tried quite hard to make it work
1602 automatic capture system. I tried quite hard to make it work
1598 reliably, and simply failed. I tried many combinations with the
1603 reliably, and simply failed. I tried many combinations with the
1599 subprocess module, but eventually nothing worked in all needed
1604 subprocess module, but eventually nothing worked in all needed
1600 cases (not blocking stdin for the child, duplicating stdout
1605 cases (not blocking stdin for the child, duplicating stdout
1601 without blocking, etc). The new %sc/%sx still do capture to these
1606 without blocking, etc). The new %sc/%sx still do capture to these
1602 magical list/string objects which make shell use much more
1607 magical list/string objects which make shell use much more
1603 conveninent, so not all is lost.
1608 conveninent, so not all is lost.
1604
1609
1605 XXX - FIX MANUAL for the change above!
1610 XXX - FIX MANUAL for the change above!
1606
1611
1607 (runsource): I copied code.py's runsource() into ipython to modify
1612 (runsource): I copied code.py's runsource() into ipython to modify
1608 it a bit. Now the code object and source to be executed are
1613 it a bit. Now the code object and source to be executed are
1609 stored in ipython. This makes this info accessible to third-party
1614 stored in ipython. This makes this info accessible to third-party
1610 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
1615 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
1611 Mantegazza <mantegazza-AT-ill.fr>.
1616 Mantegazza <mantegazza-AT-ill.fr>.
1612
1617
1613 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
1618 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
1614 history-search via readline (like C-p/C-n). I'd wanted this for a
1619 history-search via readline (like C-p/C-n). I'd wanted this for a
1615 long time, but only recently found out how to do it. For users
1620 long time, but only recently found out how to do it. For users
1616 who already have their ipythonrc files made and want this, just
1621 who already have their ipythonrc files made and want this, just
1617 add:
1622 add:
1618
1623
1619 readline_parse_and_bind "\e[A": history-search-backward
1624 readline_parse_and_bind "\e[A": history-search-backward
1620 readline_parse_and_bind "\e[B": history-search-forward
1625 readline_parse_and_bind "\e[B": history-search-forward
1621
1626
1622 2005-03-18 Fernando Perez <fperez@colorado.edu>
1627 2005-03-18 Fernando Perez <fperez@colorado.edu>
1623
1628
1624 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
1629 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
1625 LSString and SList classes which allow transparent conversions
1630 LSString and SList classes which allow transparent conversions
1626 between list mode and whitespace-separated string.
1631 between list mode and whitespace-separated string.
1627 (magic_r): Fix recursion problem in %r.
1632 (magic_r): Fix recursion problem in %r.
1628
1633
1629 * IPython/genutils.py (LSString): New class to be used for
1634 * IPython/genutils.py (LSString): New class to be used for
1630 automatic storage of the results of all alias/system calls in _o
1635 automatic storage of the results of all alias/system calls in _o
1631 and _e (stdout/err). These provide a .l/.list attribute which
1636 and _e (stdout/err). These provide a .l/.list attribute which
1632 does automatic splitting on newlines. This means that for most
1637 does automatic splitting on newlines. This means that for most
1633 uses, you'll never need to do capturing of output with %sc/%sx
1638 uses, you'll never need to do capturing of output with %sc/%sx
1634 anymore, since ipython keeps this always done for you. Note that
1639 anymore, since ipython keeps this always done for you. Note that
1635 only the LAST results are stored, the _o/e variables are
1640 only the LAST results are stored, the _o/e variables are
1636 overwritten on each call. If you need to save their contents
1641 overwritten on each call. If you need to save their contents
1637 further, simply bind them to any other name.
1642 further, simply bind them to any other name.
1638
1643
1639 2005-03-17 Fernando Perez <fperez@colorado.edu>
1644 2005-03-17 Fernando Perez <fperez@colorado.edu>
1640
1645
1641 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
1646 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
1642 prompt namespace handling.
1647 prompt namespace handling.
1643
1648
1644 2005-03-16 Fernando Perez <fperez@colorado.edu>
1649 2005-03-16 Fernando Perez <fperez@colorado.edu>
1645
1650
1646 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
1651 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
1647 classic prompts to be '>>> ' (final space was missing, and it
1652 classic prompts to be '>>> ' (final space was missing, and it
1648 trips the emacs python mode).
1653 trips the emacs python mode).
1649 (BasePrompt.__str__): Added safe support for dynamic prompt
1654 (BasePrompt.__str__): Added safe support for dynamic prompt
1650 strings. Now you can set your prompt string to be '$x', and the
1655 strings. Now you can set your prompt string to be '$x', and the
1651 value of x will be printed from your interactive namespace. The
1656 value of x will be printed from your interactive namespace. The
1652 interpolation syntax includes the full Itpl support, so
1657 interpolation syntax includes the full Itpl support, so
1653 ${foo()+x+bar()} is a valid prompt string now, and the function
1658 ${foo()+x+bar()} is a valid prompt string now, and the function
1654 calls will be made at runtime.
1659 calls will be made at runtime.
1655
1660
1656 2005-03-15 Fernando Perez <fperez@colorado.edu>
1661 2005-03-15 Fernando Perez <fperez@colorado.edu>
1657
1662
1658 * IPython/Magic.py (magic_history): renamed %hist to %history, to
1663 * IPython/Magic.py (magic_history): renamed %hist to %history, to
1659 avoid name clashes in pylab. %hist still works, it just forwards
1664 avoid name clashes in pylab. %hist still works, it just forwards
1660 the call to %history.
1665 the call to %history.
1661
1666
1662 2005-03-02 *** Released version 0.6.12
1667 2005-03-02 *** Released version 0.6.12
1663
1668
1664 2005-03-02 Fernando Perez <fperez@colorado.edu>
1669 2005-03-02 Fernando Perez <fperez@colorado.edu>
1665
1670
1666 * IPython/iplib.py (handle_magic): log magic calls properly as
1671 * IPython/iplib.py (handle_magic): log magic calls properly as
1667 ipmagic() function calls.
1672 ipmagic() function calls.
1668
1673
1669 * IPython/Magic.py (magic_time): Improved %time to support
1674 * IPython/Magic.py (magic_time): Improved %time to support
1670 statements and provide wall-clock as well as CPU time.
1675 statements and provide wall-clock as well as CPU time.
1671
1676
1672 2005-02-27 Fernando Perez <fperez@colorado.edu>
1677 2005-02-27 Fernando Perez <fperez@colorado.edu>
1673
1678
1674 * IPython/hooks.py: New hooks module, to expose user-modifiable
1679 * IPython/hooks.py: New hooks module, to expose user-modifiable
1675 IPython functionality in a clean manner. For now only the editor
1680 IPython functionality in a clean manner. For now only the editor
1676 hook is actually written, and other thigns which I intend to turn
1681 hook is actually written, and other thigns which I intend to turn
1677 into proper hooks aren't yet there. The display and prefilter
1682 into proper hooks aren't yet there. The display and prefilter
1678 stuff, for example, should be hooks. But at least now the
1683 stuff, for example, should be hooks. But at least now the
1679 framework is in place, and the rest can be moved here with more
1684 framework is in place, and the rest can be moved here with more
1680 time later. IPython had had a .hooks variable for a long time for
1685 time later. IPython had had a .hooks variable for a long time for
1681 this purpose, but I'd never actually used it for anything.
1686 this purpose, but I'd never actually used it for anything.
1682
1687
1683 2005-02-26 Fernando Perez <fperez@colorado.edu>
1688 2005-02-26 Fernando Perez <fperez@colorado.edu>
1684
1689
1685 * IPython/ipmaker.py (make_IPython): make the default ipython
1690 * IPython/ipmaker.py (make_IPython): make the default ipython
1686 directory be called _ipython under win32, to follow more the
1691 directory be called _ipython under win32, to follow more the
1687 naming peculiarities of that platform (where buggy software like
1692 naming peculiarities of that platform (where buggy software like
1688 Visual Sourcesafe breaks with .named directories). Reported by
1693 Visual Sourcesafe breaks with .named directories). Reported by
1689 Ville Vainio.
1694 Ville Vainio.
1690
1695
1691 2005-02-23 Fernando Perez <fperez@colorado.edu>
1696 2005-02-23 Fernando Perez <fperez@colorado.edu>
1692
1697
1693 * IPython/iplib.py (InteractiveShell.__init__): removed a few
1698 * IPython/iplib.py (InteractiveShell.__init__): removed a few
1694 auto_aliases for win32 which were causing problems. Users can
1699 auto_aliases for win32 which were causing problems. Users can
1695 define the ones they personally like.
1700 define the ones they personally like.
1696
1701
1697 2005-02-21 Fernando Perez <fperez@colorado.edu>
1702 2005-02-21 Fernando Perez <fperez@colorado.edu>
1698
1703
1699 * IPython/Magic.py (magic_time): new magic to time execution of
1704 * IPython/Magic.py (magic_time): new magic to time execution of
1700 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
1705 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
1701
1706
1702 2005-02-19 Fernando Perez <fperez@colorado.edu>
1707 2005-02-19 Fernando Perez <fperez@colorado.edu>
1703
1708
1704 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
1709 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
1705 into keys (for prompts, for example).
1710 into keys (for prompts, for example).
1706
1711
1707 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
1712 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
1708 prompts in case users want them. This introduces a small behavior
1713 prompts in case users want them. This introduces a small behavior
1709 change: ipython does not automatically add a space to all prompts
1714 change: ipython does not automatically add a space to all prompts
1710 anymore. To get the old prompts with a space, users should add it
1715 anymore. To get the old prompts with a space, users should add it
1711 manually to their ipythonrc file, so for example prompt_in1 should
1716 manually to their ipythonrc file, so for example prompt_in1 should
1712 now read 'In [\#]: ' instead of 'In [\#]:'.
1717 now read 'In [\#]: ' instead of 'In [\#]:'.
1713 (BasePrompt.__init__): New option prompts_pad_left (only in rc
1718 (BasePrompt.__init__): New option prompts_pad_left (only in rc
1714 file) to control left-padding of secondary prompts.
1719 file) to control left-padding of secondary prompts.
1715
1720
1716 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
1721 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
1717 the profiler can't be imported. Fix for Debian, which removed
1722 the profiler can't be imported. Fix for Debian, which removed
1718 profile.py because of License issues. I applied a slightly
1723 profile.py because of License issues. I applied a slightly
1719 modified version of the original Debian patch at
1724 modified version of the original Debian patch at
1720 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
1725 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
1721
1726
1722 2005-02-17 Fernando Perez <fperez@colorado.edu>
1727 2005-02-17 Fernando Perez <fperez@colorado.edu>
1723
1728
1724 * IPython/genutils.py (native_line_ends): Fix bug which would
1729 * IPython/genutils.py (native_line_ends): Fix bug which would
1725 cause improper line-ends under win32 b/c I was not opening files
1730 cause improper line-ends under win32 b/c I was not opening files
1726 in binary mode. Bug report and fix thanks to Ville.
1731 in binary mode. Bug report and fix thanks to Ville.
1727
1732
1728 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
1733 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
1729 trying to catch spurious foo[1] autocalls. My fix actually broke
1734 trying to catch spurious foo[1] autocalls. My fix actually broke
1730 ',/' autoquote/call with explicit escape (bad regexp).
1735 ',/' autoquote/call with explicit escape (bad regexp).
1731
1736
1732 2005-02-15 *** Released version 0.6.11
1737 2005-02-15 *** Released version 0.6.11
1733
1738
1734 2005-02-14 Fernando Perez <fperez@colorado.edu>
1739 2005-02-14 Fernando Perez <fperez@colorado.edu>
1735
1740
1736 * IPython/background_jobs.py: New background job management
1741 * IPython/background_jobs.py: New background job management
1737 subsystem. This is implemented via a new set of classes, and
1742 subsystem. This is implemented via a new set of classes, and
1738 IPython now provides a builtin 'jobs' object for background job
1743 IPython now provides a builtin 'jobs' object for background job
1739 execution. A convenience %bg magic serves as a lightweight
1744 execution. A convenience %bg magic serves as a lightweight
1740 frontend for starting the more common type of calls. This was
1745 frontend for starting the more common type of calls. This was
1741 inspired by discussions with B. Granger and the BackgroundCommand
1746 inspired by discussions with B. Granger and the BackgroundCommand
1742 class described in the book Python Scripting for Computational
1747 class described in the book Python Scripting for Computational
1743 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
1748 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
1744 (although ultimately no code from this text was used, as IPython's
1749 (although ultimately no code from this text was used, as IPython's
1745 system is a separate implementation).
1750 system is a separate implementation).
1746
1751
1747 * IPython/iplib.py (MagicCompleter.python_matches): add new option
1752 * IPython/iplib.py (MagicCompleter.python_matches): add new option
1748 to control the completion of single/double underscore names
1753 to control the completion of single/double underscore names
1749 separately. As documented in the example ipytonrc file, the
1754 separately. As documented in the example ipytonrc file, the
1750 readline_omit__names variable can now be set to 2, to omit even
1755 readline_omit__names variable can now be set to 2, to omit even
1751 single underscore names. Thanks to a patch by Brian Wong
1756 single underscore names. Thanks to a patch by Brian Wong
1752 <BrianWong-AT-AirgoNetworks.Com>.
1757 <BrianWong-AT-AirgoNetworks.Com>.
1753 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
1758 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
1754 be autocalled as foo([1]) if foo were callable. A problem for
1759 be autocalled as foo([1]) if foo were callable. A problem for
1755 things which are both callable and implement __getitem__.
1760 things which are both callable and implement __getitem__.
1756 (init_readline): Fix autoindentation for win32. Thanks to a patch
1761 (init_readline): Fix autoindentation for win32. Thanks to a patch
1757 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
1762 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
1758
1763
1759 2005-02-12 Fernando Perez <fperez@colorado.edu>
1764 2005-02-12 Fernando Perez <fperez@colorado.edu>
1760
1765
1761 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
1766 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
1762 which I had written long ago to sort out user error messages which
1767 which I had written long ago to sort out user error messages which
1763 may occur during startup. This seemed like a good idea initially,
1768 may occur during startup. This seemed like a good idea initially,
1764 but it has proven a disaster in retrospect. I don't want to
1769 but it has proven a disaster in retrospect. I don't want to
1765 change much code for now, so my fix is to set the internal 'debug'
1770 change much code for now, so my fix is to set the internal 'debug'
1766 flag to true everywhere, whose only job was precisely to control
1771 flag to true everywhere, whose only job was precisely to control
1767 this subsystem. This closes issue 28 (as well as avoiding all
1772 this subsystem. This closes issue 28 (as well as avoiding all
1768 sorts of strange hangups which occur from time to time).
1773 sorts of strange hangups which occur from time to time).
1769
1774
1770 2005-02-07 Fernando Perez <fperez@colorado.edu>
1775 2005-02-07 Fernando Perez <fperez@colorado.edu>
1771
1776
1772 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
1777 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
1773 previous call produced a syntax error.
1778 previous call produced a syntax error.
1774
1779
1775 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
1780 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
1776 classes without constructor.
1781 classes without constructor.
1777
1782
1778 2005-02-06 Fernando Perez <fperez@colorado.edu>
1783 2005-02-06 Fernando Perez <fperez@colorado.edu>
1779
1784
1780 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
1785 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
1781 completions with the results of each matcher, so we return results
1786 completions with the results of each matcher, so we return results
1782 to the user from all namespaces. This breaks with ipython
1787 to the user from all namespaces. This breaks with ipython
1783 tradition, but I think it's a nicer behavior. Now you get all
1788 tradition, but I think it's a nicer behavior. Now you get all
1784 possible completions listed, from all possible namespaces (python,
1789 possible completions listed, from all possible namespaces (python,
1785 filesystem, magics...) After a request by John Hunter
1790 filesystem, magics...) After a request by John Hunter
1786 <jdhunter-AT-nitace.bsd.uchicago.edu>.
1791 <jdhunter-AT-nitace.bsd.uchicago.edu>.
1787
1792
1788 2005-02-05 Fernando Perez <fperez@colorado.edu>
1793 2005-02-05 Fernando Perez <fperez@colorado.edu>
1789
1794
1790 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
1795 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
1791 the call had quote characters in it (the quotes were stripped).
1796 the call had quote characters in it (the quotes were stripped).
1792
1797
1793 2005-01-31 Fernando Perez <fperez@colorado.edu>
1798 2005-01-31 Fernando Perez <fperez@colorado.edu>
1794
1799
1795 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
1800 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
1796 Itpl.itpl() to make the code more robust against psyco
1801 Itpl.itpl() to make the code more robust against psyco
1797 optimizations.
1802 optimizations.
1798
1803
1799 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
1804 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
1800 of causing an exception. Quicker, cleaner.
1805 of causing an exception. Quicker, cleaner.
1801
1806
1802 2005-01-28 Fernando Perez <fperez@colorado.edu>
1807 2005-01-28 Fernando Perez <fperez@colorado.edu>
1803
1808
1804 * scripts/ipython_win_post_install.py (install): hardcode
1809 * scripts/ipython_win_post_install.py (install): hardcode
1805 sys.prefix+'python.exe' as the executable path. It turns out that
1810 sys.prefix+'python.exe' as the executable path. It turns out that
1806 during the post-installation run, sys.executable resolves to the
1811 during the post-installation run, sys.executable resolves to the
1807 name of the binary installer! I should report this as a distutils
1812 name of the binary installer! I should report this as a distutils
1808 bug, I think. I updated the .10 release with this tiny fix, to
1813 bug, I think. I updated the .10 release with this tiny fix, to
1809 avoid annoying the lists further.
1814 avoid annoying the lists further.
1810
1815
1811 2005-01-27 *** Released version 0.6.10
1816 2005-01-27 *** Released version 0.6.10
1812
1817
1813 2005-01-27 Fernando Perez <fperez@colorado.edu>
1818 2005-01-27 Fernando Perez <fperez@colorado.edu>
1814
1819
1815 * IPython/numutils.py (norm): Added 'inf' as optional name for
1820 * IPython/numutils.py (norm): Added 'inf' as optional name for
1816 L-infinity norm, included references to mathworld.com for vector
1821 L-infinity norm, included references to mathworld.com for vector
1817 norm definitions.
1822 norm definitions.
1818 (amin/amax): added amin/amax for array min/max. Similar to what
1823 (amin/amax): added amin/amax for array min/max. Similar to what
1819 pylab ships with after the recent reorganization of names.
1824 pylab ships with after the recent reorganization of names.
1820 (spike/spike_odd): removed deprecated spike/spike_odd functions.
1825 (spike/spike_odd): removed deprecated spike/spike_odd functions.
1821
1826
1822 * ipython.el: committed Alex's recent fixes and improvements.
1827 * ipython.el: committed Alex's recent fixes and improvements.
1823 Tested with python-mode from CVS, and it looks excellent. Since
1828 Tested with python-mode from CVS, and it looks excellent. Since
1824 python-mode hasn't released anything in a while, I'm temporarily
1829 python-mode hasn't released anything in a while, I'm temporarily
1825 putting a copy of today's CVS (v 4.70) of python-mode in:
1830 putting a copy of today's CVS (v 4.70) of python-mode in:
1826 http://ipython.scipy.org/tmp/python-mode.el
1831 http://ipython.scipy.org/tmp/python-mode.el
1827
1832
1828 * scripts/ipython_win_post_install.py (install): Win32 fix to use
1833 * scripts/ipython_win_post_install.py (install): Win32 fix to use
1829 sys.executable for the executable name, instead of assuming it's
1834 sys.executable for the executable name, instead of assuming it's
1830 called 'python.exe' (the post-installer would have produced broken
1835 called 'python.exe' (the post-installer would have produced broken
1831 setups on systems with a differently named python binary).
1836 setups on systems with a differently named python binary).
1832
1837
1833 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
1838 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
1834 references to os.linesep, to make the code more
1839 references to os.linesep, to make the code more
1835 platform-independent. This is also part of the win32 coloring
1840 platform-independent. This is also part of the win32 coloring
1836 fixes.
1841 fixes.
1837
1842
1838 * IPython/genutils.py (page_dumb): Remove attempts to chop long
1843 * IPython/genutils.py (page_dumb): Remove attempts to chop long
1839 lines, which actually cause coloring bugs because the length of
1844 lines, which actually cause coloring bugs because the length of
1840 the line is very difficult to correctly compute with embedded
1845 the line is very difficult to correctly compute with embedded
1841 escapes. This was the source of all the coloring problems under
1846 escapes. This was the source of all the coloring problems under
1842 Win32. I think that _finally_, Win32 users have a properly
1847 Win32. I think that _finally_, Win32 users have a properly
1843 working ipython in all respects. This would never have happened
1848 working ipython in all respects. This would never have happened
1844 if not for Gary Bishop and Viktor Ransmayr's great help and work.
1849 if not for Gary Bishop and Viktor Ransmayr's great help and work.
1845
1850
1846 2005-01-26 *** Released version 0.6.9
1851 2005-01-26 *** Released version 0.6.9
1847
1852
1848 2005-01-25 Fernando Perez <fperez@colorado.edu>
1853 2005-01-25 Fernando Perez <fperez@colorado.edu>
1849
1854
1850 * setup.py: finally, we have a true Windows installer, thanks to
1855 * setup.py: finally, we have a true Windows installer, thanks to
1851 the excellent work of Viktor Ransmayr
1856 the excellent work of Viktor Ransmayr
1852 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
1857 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
1853 Windows users. The setup routine is quite a bit cleaner thanks to
1858 Windows users. The setup routine is quite a bit cleaner thanks to
1854 this, and the post-install script uses the proper functions to
1859 this, and the post-install script uses the proper functions to
1855 allow a clean de-installation using the standard Windows Control
1860 allow a clean de-installation using the standard Windows Control
1856 Panel.
1861 Panel.
1857
1862
1858 * IPython/genutils.py (get_home_dir): changed to use the $HOME
1863 * IPython/genutils.py (get_home_dir): changed to use the $HOME
1859 environment variable under all OSes (including win32) if
1864 environment variable under all OSes (including win32) if
1860 available. This will give consistency to win32 users who have set
1865 available. This will give consistency to win32 users who have set
1861 this variable for any reason. If os.environ['HOME'] fails, the
1866 this variable for any reason. If os.environ['HOME'] fails, the
1862 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
1867 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
1863
1868
1864 2005-01-24 Fernando Perez <fperez@colorado.edu>
1869 2005-01-24 Fernando Perez <fperez@colorado.edu>
1865
1870
1866 * IPython/numutils.py (empty_like): add empty_like(), similar to
1871 * IPython/numutils.py (empty_like): add empty_like(), similar to
1867 zeros_like() but taking advantage of the new empty() Numeric routine.
1872 zeros_like() but taking advantage of the new empty() Numeric routine.
1868
1873
1869 2005-01-23 *** Released version 0.6.8
1874 2005-01-23 *** Released version 0.6.8
1870
1875
1871 2005-01-22 Fernando Perez <fperez@colorado.edu>
1876 2005-01-22 Fernando Perez <fperez@colorado.edu>
1872
1877
1873 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
1878 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
1874 automatic show() calls. After discussing things with JDH, it
1879 automatic show() calls. After discussing things with JDH, it
1875 turns out there are too many corner cases where this can go wrong.
1880 turns out there are too many corner cases where this can go wrong.
1876 It's best not to try to be 'too smart', and simply have ipython
1881 It's best not to try to be 'too smart', and simply have ipython
1877 reproduce as much as possible the default behavior of a normal
1882 reproduce as much as possible the default behavior of a normal
1878 python shell.
1883 python shell.
1879
1884
1880 * IPython/iplib.py (InteractiveShell.__init__): Modified the
1885 * IPython/iplib.py (InteractiveShell.__init__): Modified the
1881 line-splitting regexp and _prefilter() to avoid calling getattr()
1886 line-splitting regexp and _prefilter() to avoid calling getattr()
1882 on assignments. This closes
1887 on assignments. This closes
1883 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
1888 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
1884 readline uses getattr(), so a simple <TAB> keypress is still
1889 readline uses getattr(), so a simple <TAB> keypress is still
1885 enough to trigger getattr() calls on an object.
1890 enough to trigger getattr() calls on an object.
1886
1891
1887 2005-01-21 Fernando Perez <fperez@colorado.edu>
1892 2005-01-21 Fernando Perez <fperez@colorado.edu>
1888
1893
1889 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
1894 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
1890 docstring under pylab so it doesn't mask the original.
1895 docstring under pylab so it doesn't mask the original.
1891
1896
1892 2005-01-21 *** Released version 0.6.7
1897 2005-01-21 *** Released version 0.6.7
1893
1898
1894 2005-01-21 Fernando Perez <fperez@colorado.edu>
1899 2005-01-21 Fernando Perez <fperez@colorado.edu>
1895
1900
1896 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
1901 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
1897 signal handling for win32 users in multithreaded mode.
1902 signal handling for win32 users in multithreaded mode.
1898
1903
1899 2005-01-17 Fernando Perez <fperez@colorado.edu>
1904 2005-01-17 Fernando Perez <fperez@colorado.edu>
1900
1905
1901 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
1906 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
1902 instances with no __init__. After a crash report by Norbert Nemec
1907 instances with no __init__. After a crash report by Norbert Nemec
1903 <Norbert-AT-nemec-online.de>.
1908 <Norbert-AT-nemec-online.de>.
1904
1909
1905 2005-01-14 Fernando Perez <fperez@colorado.edu>
1910 2005-01-14 Fernando Perez <fperez@colorado.edu>
1906
1911
1907 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
1912 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
1908 names for verbose exceptions, when multiple dotted names and the
1913 names for verbose exceptions, when multiple dotted names and the
1909 'parent' object were present on the same line.
1914 'parent' object were present on the same line.
1910
1915
1911 2005-01-11 Fernando Perez <fperez@colorado.edu>
1916 2005-01-11 Fernando Perez <fperez@colorado.edu>
1912
1917
1913 * IPython/genutils.py (flag_calls): new utility to trap and flag
1918 * IPython/genutils.py (flag_calls): new utility to trap and flag
1914 calls in functions. I need it to clean up matplotlib support.
1919 calls in functions. I need it to clean up matplotlib support.
1915 Also removed some deprecated code in genutils.
1920 Also removed some deprecated code in genutils.
1916
1921
1917 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
1922 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
1918 that matplotlib scripts called with %run, which don't call show()
1923 that matplotlib scripts called with %run, which don't call show()
1919 themselves, still have their plotting windows open.
1924 themselves, still have their plotting windows open.
1920
1925
1921 2005-01-05 Fernando Perez <fperez@colorado.edu>
1926 2005-01-05 Fernando Perez <fperez@colorado.edu>
1922
1927
1923 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
1928 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
1924 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
1929 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
1925
1930
1926 2004-12-19 Fernando Perez <fperez@colorado.edu>
1931 2004-12-19 Fernando Perez <fperez@colorado.edu>
1927
1932
1928 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
1933 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
1929 parent_runcode, which was an eyesore. The same result can be
1934 parent_runcode, which was an eyesore. The same result can be
1930 obtained with Python's regular superclass mechanisms.
1935 obtained with Python's regular superclass mechanisms.
1931
1936
1932 2004-12-17 Fernando Perez <fperez@colorado.edu>
1937 2004-12-17 Fernando Perez <fperez@colorado.edu>
1933
1938
1934 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
1939 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
1935 reported by Prabhu.
1940 reported by Prabhu.
1936 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
1941 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
1937 sys.stderr) instead of explicitly calling sys.stderr. This helps
1942 sys.stderr) instead of explicitly calling sys.stderr. This helps
1938 maintain our I/O abstractions clean, for future GUI embeddings.
1943 maintain our I/O abstractions clean, for future GUI embeddings.
1939
1944
1940 * IPython/genutils.py (info): added new utility for sys.stderr
1945 * IPython/genutils.py (info): added new utility for sys.stderr
1941 unified info message handling (thin wrapper around warn()).
1946 unified info message handling (thin wrapper around warn()).
1942
1947
1943 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
1948 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
1944 composite (dotted) names on verbose exceptions.
1949 composite (dotted) names on verbose exceptions.
1945 (VerboseTB.nullrepr): harden against another kind of errors which
1950 (VerboseTB.nullrepr): harden against another kind of errors which
1946 Python's inspect module can trigger, and which were crashing
1951 Python's inspect module can trigger, and which were crashing
1947 IPython. Thanks to a report by Marco Lombardi
1952 IPython. Thanks to a report by Marco Lombardi
1948 <mlombard-AT-ma010192.hq.eso.org>.
1953 <mlombard-AT-ma010192.hq.eso.org>.
1949
1954
1950 2004-12-13 *** Released version 0.6.6
1955 2004-12-13 *** Released version 0.6.6
1951
1956
1952 2004-12-12 Fernando Perez <fperez@colorado.edu>
1957 2004-12-12 Fernando Perez <fperez@colorado.edu>
1953
1958
1954 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
1959 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
1955 generated by pygtk upon initialization if it was built without
1960 generated by pygtk upon initialization if it was built without
1956 threads (for matplotlib users). After a crash reported by
1961 threads (for matplotlib users). After a crash reported by
1957 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
1962 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
1958
1963
1959 * IPython/ipmaker.py (make_IPython): fix small bug in the
1964 * IPython/ipmaker.py (make_IPython): fix small bug in the
1960 import_some parameter for multiple imports.
1965 import_some parameter for multiple imports.
1961
1966
1962 * IPython/iplib.py (ipmagic): simplified the interface of
1967 * IPython/iplib.py (ipmagic): simplified the interface of
1963 ipmagic() to take a single string argument, just as it would be
1968 ipmagic() to take a single string argument, just as it would be
1964 typed at the IPython cmd line.
1969 typed at the IPython cmd line.
1965 (ipalias): Added new ipalias() with an interface identical to
1970 (ipalias): Added new ipalias() with an interface identical to
1966 ipmagic(). This completes exposing a pure python interface to the
1971 ipmagic(). This completes exposing a pure python interface to the
1967 alias and magic system, which can be used in loops or more complex
1972 alias and magic system, which can be used in loops or more complex
1968 code where IPython's automatic line mangling is not active.
1973 code where IPython's automatic line mangling is not active.
1969
1974
1970 * IPython/genutils.py (timing): changed interface of timing to
1975 * IPython/genutils.py (timing): changed interface of timing to
1971 simply run code once, which is the most common case. timings()
1976 simply run code once, which is the most common case. timings()
1972 remains unchanged, for the cases where you want multiple runs.
1977 remains unchanged, for the cases where you want multiple runs.
1973
1978
1974 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
1979 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
1975 bug where Python2.2 crashes with exec'ing code which does not end
1980 bug where Python2.2 crashes with exec'ing code which does not end
1976 in a single newline. Python 2.3 is OK, so I hadn't noticed this
1981 in a single newline. Python 2.3 is OK, so I hadn't noticed this
1977 before.
1982 before.
1978
1983
1979 2004-12-10 Fernando Perez <fperez@colorado.edu>
1984 2004-12-10 Fernando Perez <fperez@colorado.edu>
1980
1985
1981 * IPython/Magic.py (Magic.magic_prun): changed name of option from
1986 * IPython/Magic.py (Magic.magic_prun): changed name of option from
1982 -t to -T, to accomodate the new -t flag in %run (the %run and
1987 -t to -T, to accomodate the new -t flag in %run (the %run and
1983 %prun options are kind of intermixed, and it's not easy to change
1988 %prun options are kind of intermixed, and it's not easy to change
1984 this with the limitations of python's getopt).
1989 this with the limitations of python's getopt).
1985
1990
1986 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
1991 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
1987 the execution of scripts. It's not as fine-tuned as timeit.py,
1992 the execution of scripts. It's not as fine-tuned as timeit.py,
1988 but it works from inside ipython (and under 2.2, which lacks
1993 but it works from inside ipython (and under 2.2, which lacks
1989 timeit.py). Optionally a number of runs > 1 can be given for
1994 timeit.py). Optionally a number of runs > 1 can be given for
1990 timing very short-running code.
1995 timing very short-running code.
1991
1996
1992 * IPython/genutils.py (uniq_stable): new routine which returns a
1997 * IPython/genutils.py (uniq_stable): new routine which returns a
1993 list of unique elements in any iterable, but in stable order of
1998 list of unique elements in any iterable, but in stable order of
1994 appearance. I needed this for the ultraTB fixes, and it's a handy
1999 appearance. I needed this for the ultraTB fixes, and it's a handy
1995 utility.
2000 utility.
1996
2001
1997 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
2002 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
1998 dotted names in Verbose exceptions. This had been broken since
2003 dotted names in Verbose exceptions. This had been broken since
1999 the very start, now x.y will properly be printed in a Verbose
2004 the very start, now x.y will properly be printed in a Verbose
2000 traceback, instead of x being shown and y appearing always as an
2005 traceback, instead of x being shown and y appearing always as an
2001 'undefined global'. Getting this to work was a bit tricky,
2006 'undefined global'. Getting this to work was a bit tricky,
2002 because by default python tokenizers are stateless. Saved by
2007 because by default python tokenizers are stateless. Saved by
2003 python's ability to easily add a bit of state to an arbitrary
2008 python's ability to easily add a bit of state to an arbitrary
2004 function (without needing to build a full-blown callable object).
2009 function (without needing to build a full-blown callable object).
2005
2010
2006 Also big cleanup of this code, which had horrendous runtime
2011 Also big cleanup of this code, which had horrendous runtime
2007 lookups of zillions of attributes for colorization. Moved all
2012 lookups of zillions of attributes for colorization. Moved all
2008 this code into a few templates, which make it cleaner and quicker.
2013 this code into a few templates, which make it cleaner and quicker.
2009
2014
2010 Printout quality was also improved for Verbose exceptions: one
2015 Printout quality was also improved for Verbose exceptions: one
2011 variable per line, and memory addresses are printed (this can be
2016 variable per line, and memory addresses are printed (this can be
2012 quite handy in nasty debugging situations, which is what Verbose
2017 quite handy in nasty debugging situations, which is what Verbose
2013 is for).
2018 is for).
2014
2019
2015 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
2020 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
2016 the command line as scripts to be loaded by embedded instances.
2021 the command line as scripts to be loaded by embedded instances.
2017 Doing so has the potential for an infinite recursion if there are
2022 Doing so has the potential for an infinite recursion if there are
2018 exceptions thrown in the process. This fixes a strange crash
2023 exceptions thrown in the process. This fixes a strange crash
2019 reported by Philippe MULLER <muller-AT-irit.fr>.
2024 reported by Philippe MULLER <muller-AT-irit.fr>.
2020
2025
2021 2004-12-09 Fernando Perez <fperez@colorado.edu>
2026 2004-12-09 Fernando Perez <fperez@colorado.edu>
2022
2027
2023 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
2028 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
2024 to reflect new names in matplotlib, which now expose the
2029 to reflect new names in matplotlib, which now expose the
2025 matlab-compatible interface via a pylab module instead of the
2030 matlab-compatible interface via a pylab module instead of the
2026 'matlab' name. The new code is backwards compatible, so users of
2031 'matlab' name. The new code is backwards compatible, so users of
2027 all matplotlib versions are OK. Patch by J. Hunter.
2032 all matplotlib versions are OK. Patch by J. Hunter.
2028
2033
2029 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
2034 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
2030 of __init__ docstrings for instances (class docstrings are already
2035 of __init__ docstrings for instances (class docstrings are already
2031 automatically printed). Instances with customized docstrings
2036 automatically printed). Instances with customized docstrings
2032 (indep. of the class) are also recognized and all 3 separate
2037 (indep. of the class) are also recognized and all 3 separate
2033 docstrings are printed (instance, class, constructor). After some
2038 docstrings are printed (instance, class, constructor). After some
2034 comments/suggestions by J. Hunter.
2039 comments/suggestions by J. Hunter.
2035
2040
2036 2004-12-05 Fernando Perez <fperez@colorado.edu>
2041 2004-12-05 Fernando Perez <fperez@colorado.edu>
2037
2042
2038 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
2043 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
2039 warnings when tab-completion fails and triggers an exception.
2044 warnings when tab-completion fails and triggers an exception.
2040
2045
2041 2004-12-03 Fernando Perez <fperez@colorado.edu>
2046 2004-12-03 Fernando Perez <fperez@colorado.edu>
2042
2047
2043 * IPython/Magic.py (magic_prun): Fix bug where an exception would
2048 * IPython/Magic.py (magic_prun): Fix bug where an exception would
2044 be triggered when using 'run -p'. An incorrect option flag was
2049 be triggered when using 'run -p'. An incorrect option flag was
2045 being set ('d' instead of 'D').
2050 being set ('d' instead of 'D').
2046 (manpage): fix missing escaped \- sign.
2051 (manpage): fix missing escaped \- sign.
2047
2052
2048 2004-11-30 *** Released version 0.6.5
2053 2004-11-30 *** Released version 0.6.5
2049
2054
2050 2004-11-30 Fernando Perez <fperez@colorado.edu>
2055 2004-11-30 Fernando Perez <fperez@colorado.edu>
2051
2056
2052 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
2057 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
2053 setting with -d option.
2058 setting with -d option.
2054
2059
2055 * setup.py (docfiles): Fix problem where the doc glob I was using
2060 * setup.py (docfiles): Fix problem where the doc glob I was using
2056 was COMPLETELY BROKEN. It was giving the right files by pure
2061 was COMPLETELY BROKEN. It was giving the right files by pure
2057 accident, but failed once I tried to include ipython.el. Note:
2062 accident, but failed once I tried to include ipython.el. Note:
2058 glob() does NOT allow you to do exclusion on multiple endings!
2063 glob() does NOT allow you to do exclusion on multiple endings!
2059
2064
2060 2004-11-29 Fernando Perez <fperez@colorado.edu>
2065 2004-11-29 Fernando Perez <fperez@colorado.edu>
2061
2066
2062 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
2067 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
2063 the manpage as the source. Better formatting & consistency.
2068 the manpage as the source. Better formatting & consistency.
2064
2069
2065 * IPython/Magic.py (magic_run): Added new -d option, to run
2070 * IPython/Magic.py (magic_run): Added new -d option, to run
2066 scripts under the control of the python pdb debugger. Note that
2071 scripts under the control of the python pdb debugger. Note that
2067 this required changing the %prun option -d to -D, to avoid a clash
2072 this required changing the %prun option -d to -D, to avoid a clash
2068 (since %run must pass options to %prun, and getopt is too dumb to
2073 (since %run must pass options to %prun, and getopt is too dumb to
2069 handle options with string values with embedded spaces). Thanks
2074 handle options with string values with embedded spaces). Thanks
2070 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
2075 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
2071 (magic_who_ls): added type matching to %who and %whos, so that one
2076 (magic_who_ls): added type matching to %who and %whos, so that one
2072 can filter their output to only include variables of certain
2077 can filter their output to only include variables of certain
2073 types. Another suggestion by Matthew.
2078 types. Another suggestion by Matthew.
2074 (magic_whos): Added memory summaries in kb and Mb for arrays.
2079 (magic_whos): Added memory summaries in kb and Mb for arrays.
2075 (magic_who): Improve formatting (break lines every 9 vars).
2080 (magic_who): Improve formatting (break lines every 9 vars).
2076
2081
2077 2004-11-28 Fernando Perez <fperez@colorado.edu>
2082 2004-11-28 Fernando Perez <fperez@colorado.edu>
2078
2083
2079 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
2084 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
2080 cache when empty lines were present.
2085 cache when empty lines were present.
2081
2086
2082 2004-11-24 Fernando Perez <fperez@colorado.edu>
2087 2004-11-24 Fernando Perez <fperez@colorado.edu>
2083
2088
2084 * IPython/usage.py (__doc__): document the re-activated threading
2089 * IPython/usage.py (__doc__): document the re-activated threading
2085 options for WX and GTK.
2090 options for WX and GTK.
2086
2091
2087 2004-11-23 Fernando Perez <fperez@colorado.edu>
2092 2004-11-23 Fernando Perez <fperez@colorado.edu>
2088
2093
2089 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
2094 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
2090 the -wthread and -gthread options, along with a new -tk one to try
2095 the -wthread and -gthread options, along with a new -tk one to try
2091 and coordinate Tk threading with wx/gtk. The tk support is very
2096 and coordinate Tk threading with wx/gtk. The tk support is very
2092 platform dependent, since it seems to require Tcl and Tk to be
2097 platform dependent, since it seems to require Tcl and Tk to be
2093 built with threads (Fedora1/2 appears NOT to have it, but in
2098 built with threads (Fedora1/2 appears NOT to have it, but in
2094 Prabhu's Debian boxes it works OK). But even with some Tk
2099 Prabhu's Debian boxes it works OK). But even with some Tk
2095 limitations, this is a great improvement.
2100 limitations, this is a great improvement.
2096
2101
2097 * IPython/Prompts.py (prompt_specials_color): Added \t for time
2102 * IPython/Prompts.py (prompt_specials_color): Added \t for time
2098 info in user prompts. Patch by Prabhu.
2103 info in user prompts. Patch by Prabhu.
2099
2104
2100 2004-11-18 Fernando Perez <fperez@colorado.edu>
2105 2004-11-18 Fernando Perez <fperez@colorado.edu>
2101
2106
2102 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
2107 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
2103 EOFErrors and bail, to avoid infinite loops if a non-terminating
2108 EOFErrors and bail, to avoid infinite loops if a non-terminating
2104 file is fed into ipython. Patch submitted in issue 19 by user,
2109 file is fed into ipython. Patch submitted in issue 19 by user,
2105 many thanks.
2110 many thanks.
2106
2111
2107 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
2112 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
2108 autoquote/parens in continuation prompts, which can cause lots of
2113 autoquote/parens in continuation prompts, which can cause lots of
2109 problems. Closes roundup issue 20.
2114 problems. Closes roundup issue 20.
2110
2115
2111 2004-11-17 Fernando Perez <fperez@colorado.edu>
2116 2004-11-17 Fernando Perez <fperez@colorado.edu>
2112
2117
2113 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
2118 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
2114 reported as debian bug #280505. I'm not sure my local changelog
2119 reported as debian bug #280505. I'm not sure my local changelog
2115 entry has the proper debian format (Jack?).
2120 entry has the proper debian format (Jack?).
2116
2121
2117 2004-11-08 *** Released version 0.6.4
2122 2004-11-08 *** Released version 0.6.4
2118
2123
2119 2004-11-08 Fernando Perez <fperez@colorado.edu>
2124 2004-11-08 Fernando Perez <fperez@colorado.edu>
2120
2125
2121 * IPython/iplib.py (init_readline): Fix exit message for Windows
2126 * IPython/iplib.py (init_readline): Fix exit message for Windows
2122 when readline is active. Thanks to a report by Eric Jones
2127 when readline is active. Thanks to a report by Eric Jones
2123 <eric-AT-enthought.com>.
2128 <eric-AT-enthought.com>.
2124
2129
2125 2004-11-07 Fernando Perez <fperez@colorado.edu>
2130 2004-11-07 Fernando Perez <fperez@colorado.edu>
2126
2131
2127 * IPython/genutils.py (page): Add a trap for OSError exceptions,
2132 * IPython/genutils.py (page): Add a trap for OSError exceptions,
2128 sometimes seen by win2k/cygwin users.
2133 sometimes seen by win2k/cygwin users.
2129
2134
2130 2004-11-06 Fernando Perez <fperez@colorado.edu>
2135 2004-11-06 Fernando Perez <fperez@colorado.edu>
2131
2136
2132 * IPython/iplib.py (interact): Change the handling of %Exit from
2137 * IPython/iplib.py (interact): Change the handling of %Exit from
2133 trying to propagate a SystemExit to an internal ipython flag.
2138 trying to propagate a SystemExit to an internal ipython flag.
2134 This is less elegant than using Python's exception mechanism, but
2139 This is less elegant than using Python's exception mechanism, but
2135 I can't get that to work reliably with threads, so under -pylab
2140 I can't get that to work reliably with threads, so under -pylab
2136 %Exit was hanging IPython. Cross-thread exception handling is
2141 %Exit was hanging IPython. Cross-thread exception handling is
2137 really a bitch. Thaks to a bug report by Stephen Walton
2142 really a bitch. Thaks to a bug report by Stephen Walton
2138 <stephen.walton-AT-csun.edu>.
2143 <stephen.walton-AT-csun.edu>.
2139
2144
2140 2004-11-04 Fernando Perez <fperez@colorado.edu>
2145 2004-11-04 Fernando Perez <fperez@colorado.edu>
2141
2146
2142 * IPython/iplib.py (raw_input_original): store a pointer to the
2147 * IPython/iplib.py (raw_input_original): store a pointer to the
2143 true raw_input to harden against code which can modify it
2148 true raw_input to harden against code which can modify it
2144 (wx.py.PyShell does this and would otherwise crash ipython).
2149 (wx.py.PyShell does this and would otherwise crash ipython).
2145 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
2150 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
2146
2151
2147 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
2152 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
2148 Ctrl-C problem, which does not mess up the input line.
2153 Ctrl-C problem, which does not mess up the input line.
2149
2154
2150 2004-11-03 Fernando Perez <fperez@colorado.edu>
2155 2004-11-03 Fernando Perez <fperez@colorado.edu>
2151
2156
2152 * IPython/Release.py: Changed licensing to BSD, in all files.
2157 * IPython/Release.py: Changed licensing to BSD, in all files.
2153 (name): lowercase name for tarball/RPM release.
2158 (name): lowercase name for tarball/RPM release.
2154
2159
2155 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
2160 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
2156 use throughout ipython.
2161 use throughout ipython.
2157
2162
2158 * IPython/Magic.py (Magic._ofind): Switch to using the new
2163 * IPython/Magic.py (Magic._ofind): Switch to using the new
2159 OInspect.getdoc() function.
2164 OInspect.getdoc() function.
2160
2165
2161 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
2166 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
2162 of the line currently being canceled via Ctrl-C. It's extremely
2167 of the line currently being canceled via Ctrl-C. It's extremely
2163 ugly, but I don't know how to do it better (the problem is one of
2168 ugly, but I don't know how to do it better (the problem is one of
2164 handling cross-thread exceptions).
2169 handling cross-thread exceptions).
2165
2170
2166 2004-10-28 Fernando Perez <fperez@colorado.edu>
2171 2004-10-28 Fernando Perez <fperez@colorado.edu>
2167
2172
2168 * IPython/Shell.py (signal_handler): add signal handlers to trap
2173 * IPython/Shell.py (signal_handler): add signal handlers to trap
2169 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
2174 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
2170 report by Francesc Alted.
2175 report by Francesc Alted.
2171
2176
2172 2004-10-21 Fernando Perez <fperez@colorado.edu>
2177 2004-10-21 Fernando Perez <fperez@colorado.edu>
2173
2178
2174 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
2179 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
2175 to % for pysh syntax extensions.
2180 to % for pysh syntax extensions.
2176
2181
2177 2004-10-09 Fernando Perez <fperez@colorado.edu>
2182 2004-10-09 Fernando Perez <fperez@colorado.edu>
2178
2183
2179 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
2184 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
2180 arrays to print a more useful summary, without calling str(arr).
2185 arrays to print a more useful summary, without calling str(arr).
2181 This avoids the problem of extremely lengthy computations which
2186 This avoids the problem of extremely lengthy computations which
2182 occur if arr is large, and appear to the user as a system lockup
2187 occur if arr is large, and appear to the user as a system lockup
2183 with 100% cpu activity. After a suggestion by Kristian Sandberg
2188 with 100% cpu activity. After a suggestion by Kristian Sandberg
2184 <Kristian.Sandberg@colorado.edu>.
2189 <Kristian.Sandberg@colorado.edu>.
2185 (Magic.__init__): fix bug in global magic escapes not being
2190 (Magic.__init__): fix bug in global magic escapes not being
2186 correctly set.
2191 correctly set.
2187
2192
2188 2004-10-08 Fernando Perez <fperez@colorado.edu>
2193 2004-10-08 Fernando Perez <fperez@colorado.edu>
2189
2194
2190 * IPython/Magic.py (__license__): change to absolute imports of
2195 * IPython/Magic.py (__license__): change to absolute imports of
2191 ipython's own internal packages, to start adapting to the absolute
2196 ipython's own internal packages, to start adapting to the absolute
2192 import requirement of PEP-328.
2197 import requirement of PEP-328.
2193
2198
2194 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
2199 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
2195 files, and standardize author/license marks through the Release
2200 files, and standardize author/license marks through the Release
2196 module instead of having per/file stuff (except for files with
2201 module instead of having per/file stuff (except for files with
2197 particular licenses, like the MIT/PSF-licensed codes).
2202 particular licenses, like the MIT/PSF-licensed codes).
2198
2203
2199 * IPython/Debugger.py: remove dead code for python 2.1
2204 * IPython/Debugger.py: remove dead code for python 2.1
2200
2205
2201 2004-10-04 Fernando Perez <fperez@colorado.edu>
2206 2004-10-04 Fernando Perez <fperez@colorado.edu>
2202
2207
2203 * IPython/iplib.py (ipmagic): New function for accessing magics
2208 * IPython/iplib.py (ipmagic): New function for accessing magics
2204 via a normal python function call.
2209 via a normal python function call.
2205
2210
2206 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
2211 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
2207 from '@' to '%', to accomodate the new @decorator syntax of python
2212 from '@' to '%', to accomodate the new @decorator syntax of python
2208 2.4.
2213 2.4.
2209
2214
2210 2004-09-29 Fernando Perez <fperez@colorado.edu>
2215 2004-09-29 Fernando Perez <fperez@colorado.edu>
2211
2216
2212 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
2217 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
2213 matplotlib.use to prevent running scripts which try to switch
2218 matplotlib.use to prevent running scripts which try to switch
2214 interactive backends from within ipython. This will just crash
2219 interactive backends from within ipython. This will just crash
2215 the python interpreter, so we can't allow it (but a detailed error
2220 the python interpreter, so we can't allow it (but a detailed error
2216 is given to the user).
2221 is given to the user).
2217
2222
2218 2004-09-28 Fernando Perez <fperez@colorado.edu>
2223 2004-09-28 Fernando Perez <fperez@colorado.edu>
2219
2224
2220 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
2225 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
2221 matplotlib-related fixes so that using @run with non-matplotlib
2226 matplotlib-related fixes so that using @run with non-matplotlib
2222 scripts doesn't pop up spurious plot windows. This requires
2227 scripts doesn't pop up spurious plot windows. This requires
2223 matplotlib >= 0.63, where I had to make some changes as well.
2228 matplotlib >= 0.63, where I had to make some changes as well.
2224
2229
2225 * IPython/ipmaker.py (make_IPython): update version requirement to
2230 * IPython/ipmaker.py (make_IPython): update version requirement to
2226 python 2.2.
2231 python 2.2.
2227
2232
2228 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
2233 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
2229 banner arg for embedded customization.
2234 banner arg for embedded customization.
2230
2235
2231 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
2236 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
2232 explicit uses of __IP as the IPython's instance name. Now things
2237 explicit uses of __IP as the IPython's instance name. Now things
2233 are properly handled via the shell.name value. The actual code
2238 are properly handled via the shell.name value. The actual code
2234 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
2239 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
2235 is much better than before. I'll clean things completely when the
2240 is much better than before. I'll clean things completely when the
2236 magic stuff gets a real overhaul.
2241 magic stuff gets a real overhaul.
2237
2242
2238 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
2243 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
2239 minor changes to debian dir.
2244 minor changes to debian dir.
2240
2245
2241 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
2246 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
2242 pointer to the shell itself in the interactive namespace even when
2247 pointer to the shell itself in the interactive namespace even when
2243 a user-supplied dict is provided. This is needed for embedding
2248 a user-supplied dict is provided. This is needed for embedding
2244 purposes (found by tests with Michel Sanner).
2249 purposes (found by tests with Michel Sanner).
2245
2250
2246 2004-09-27 Fernando Perez <fperez@colorado.edu>
2251 2004-09-27 Fernando Perez <fperez@colorado.edu>
2247
2252
2248 * IPython/UserConfig/ipythonrc: remove []{} from
2253 * IPython/UserConfig/ipythonrc: remove []{} from
2249 readline_remove_delims, so that things like [modname.<TAB> do
2254 readline_remove_delims, so that things like [modname.<TAB> do
2250 proper completion. This disables [].TAB, but that's a less common
2255 proper completion. This disables [].TAB, but that's a less common
2251 case than module names in list comprehensions, for example.
2256 case than module names in list comprehensions, for example.
2252 Thanks to a report by Andrea Riciputi.
2257 Thanks to a report by Andrea Riciputi.
2253
2258
2254 2004-09-09 Fernando Perez <fperez@colorado.edu>
2259 2004-09-09 Fernando Perez <fperez@colorado.edu>
2255
2260
2256 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
2261 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
2257 blocking problems in win32 and osx. Fix by John.
2262 blocking problems in win32 and osx. Fix by John.
2258
2263
2259 2004-09-08 Fernando Perez <fperez@colorado.edu>
2264 2004-09-08 Fernando Perez <fperez@colorado.edu>
2260
2265
2261 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
2266 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
2262 for Win32 and OSX. Fix by John Hunter.
2267 for Win32 and OSX. Fix by John Hunter.
2263
2268
2264 2004-08-30 *** Released version 0.6.3
2269 2004-08-30 *** Released version 0.6.3
2265
2270
2266 2004-08-30 Fernando Perez <fperez@colorado.edu>
2271 2004-08-30 Fernando Perez <fperez@colorado.edu>
2267
2272
2268 * setup.py (isfile): Add manpages to list of dependent files to be
2273 * setup.py (isfile): Add manpages to list of dependent files to be
2269 updated.
2274 updated.
2270
2275
2271 2004-08-27 Fernando Perez <fperez@colorado.edu>
2276 2004-08-27 Fernando Perez <fperez@colorado.edu>
2272
2277
2273 * IPython/Shell.py (start): I've disabled -wthread and -gthread
2278 * IPython/Shell.py (start): I've disabled -wthread and -gthread
2274 for now. They don't really work with standalone WX/GTK code
2279 for now. They don't really work with standalone WX/GTK code
2275 (though matplotlib IS working fine with both of those backends).
2280 (though matplotlib IS working fine with both of those backends).
2276 This will neeed much more testing. I disabled most things with
2281 This will neeed much more testing. I disabled most things with
2277 comments, so turning it back on later should be pretty easy.
2282 comments, so turning it back on later should be pretty easy.
2278
2283
2279 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
2284 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
2280 autocalling of expressions like r'foo', by modifying the line
2285 autocalling of expressions like r'foo', by modifying the line
2281 split regexp. Closes
2286 split regexp. Closes
2282 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
2287 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
2283 Riley <ipythonbugs-AT-sabi.net>.
2288 Riley <ipythonbugs-AT-sabi.net>.
2284 (InteractiveShell.mainloop): honor --nobanner with banner
2289 (InteractiveShell.mainloop): honor --nobanner with banner
2285 extensions.
2290 extensions.
2286
2291
2287 * IPython/Shell.py: Significant refactoring of all classes, so
2292 * IPython/Shell.py: Significant refactoring of all classes, so
2288 that we can really support ALL matplotlib backends and threading
2293 that we can really support ALL matplotlib backends and threading
2289 models (John spotted a bug with Tk which required this). Now we
2294 models (John spotted a bug with Tk which required this). Now we
2290 should support single-threaded, WX-threads and GTK-threads, both
2295 should support single-threaded, WX-threads and GTK-threads, both
2291 for generic code and for matplotlib.
2296 for generic code and for matplotlib.
2292
2297
2293 * IPython/ipmaker.py (__call__): Changed -mpthread option to
2298 * IPython/ipmaker.py (__call__): Changed -mpthread option to
2294 -pylab, to simplify things for users. Will also remove the pylab
2299 -pylab, to simplify things for users. Will also remove the pylab
2295 profile, since now all of matplotlib configuration is directly
2300 profile, since now all of matplotlib configuration is directly
2296 handled here. This also reduces startup time.
2301 handled here. This also reduces startup time.
2297
2302
2298 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
2303 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
2299 shell wasn't being correctly called. Also in IPShellWX.
2304 shell wasn't being correctly called. Also in IPShellWX.
2300
2305
2301 * IPython/iplib.py (InteractiveShell.__init__): Added option to
2306 * IPython/iplib.py (InteractiveShell.__init__): Added option to
2302 fine-tune banner.
2307 fine-tune banner.
2303
2308
2304 * IPython/numutils.py (spike): Deprecate these spike functions,
2309 * IPython/numutils.py (spike): Deprecate these spike functions,
2305 delete (long deprecated) gnuplot_exec handler.
2310 delete (long deprecated) gnuplot_exec handler.
2306
2311
2307 2004-08-26 Fernando Perez <fperez@colorado.edu>
2312 2004-08-26 Fernando Perez <fperez@colorado.edu>
2308
2313
2309 * ipython.1: Update for threading options, plus some others which
2314 * ipython.1: Update for threading options, plus some others which
2310 were missing.
2315 were missing.
2311
2316
2312 * IPython/ipmaker.py (__call__): Added -wthread option for
2317 * IPython/ipmaker.py (__call__): Added -wthread option for
2313 wxpython thread handling. Make sure threading options are only
2318 wxpython thread handling. Make sure threading options are only
2314 valid at the command line.
2319 valid at the command line.
2315
2320
2316 * scripts/ipython: moved shell selection into a factory function
2321 * scripts/ipython: moved shell selection into a factory function
2317 in Shell.py, to keep the starter script to a minimum.
2322 in Shell.py, to keep the starter script to a minimum.
2318
2323
2319 2004-08-25 Fernando Perez <fperez@colorado.edu>
2324 2004-08-25 Fernando Perez <fperez@colorado.edu>
2320
2325
2321 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
2326 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
2322 John. Along with some recent changes he made to matplotlib, the
2327 John. Along with some recent changes he made to matplotlib, the
2323 next versions of both systems should work very well together.
2328 next versions of both systems should work very well together.
2324
2329
2325 2004-08-24 Fernando Perez <fperez@colorado.edu>
2330 2004-08-24 Fernando Perez <fperez@colorado.edu>
2326
2331
2327 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
2332 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
2328 tried to switch the profiling to using hotshot, but I'm getting
2333 tried to switch the profiling to using hotshot, but I'm getting
2329 strange errors from prof.runctx() there. I may be misreading the
2334 strange errors from prof.runctx() there. I may be misreading the
2330 docs, but it looks weird. For now the profiling code will
2335 docs, but it looks weird. For now the profiling code will
2331 continue to use the standard profiler.
2336 continue to use the standard profiler.
2332
2337
2333 2004-08-23 Fernando Perez <fperez@colorado.edu>
2338 2004-08-23 Fernando Perez <fperez@colorado.edu>
2334
2339
2335 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
2340 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
2336 threaded shell, by John Hunter. It's not quite ready yet, but
2341 threaded shell, by John Hunter. It's not quite ready yet, but
2337 close.
2342 close.
2338
2343
2339 2004-08-22 Fernando Perez <fperez@colorado.edu>
2344 2004-08-22 Fernando Perez <fperez@colorado.edu>
2340
2345
2341 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
2346 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
2342 in Magic and ultraTB.
2347 in Magic and ultraTB.
2343
2348
2344 * ipython.1: document threading options in manpage.
2349 * ipython.1: document threading options in manpage.
2345
2350
2346 * scripts/ipython: Changed name of -thread option to -gthread,
2351 * scripts/ipython: Changed name of -thread option to -gthread,
2347 since this is GTK specific. I want to leave the door open for a
2352 since this is GTK specific. I want to leave the door open for a
2348 -wthread option for WX, which will most likely be necessary. This
2353 -wthread option for WX, which will most likely be necessary. This
2349 change affects usage and ipmaker as well.
2354 change affects usage and ipmaker as well.
2350
2355
2351 * IPython/Shell.py (matplotlib_shell): Add a factory function to
2356 * IPython/Shell.py (matplotlib_shell): Add a factory function to
2352 handle the matplotlib shell issues. Code by John Hunter
2357 handle the matplotlib shell issues. Code by John Hunter
2353 <jdhunter-AT-nitace.bsd.uchicago.edu>.
2358 <jdhunter-AT-nitace.bsd.uchicago.edu>.
2354 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
2359 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
2355 broken (and disabled for end users) for now, but it puts the
2360 broken (and disabled for end users) for now, but it puts the
2356 infrastructure in place.
2361 infrastructure in place.
2357
2362
2358 2004-08-21 Fernando Perez <fperez@colorado.edu>
2363 2004-08-21 Fernando Perez <fperez@colorado.edu>
2359
2364
2360 * ipythonrc-pylab: Add matplotlib support.
2365 * ipythonrc-pylab: Add matplotlib support.
2361
2366
2362 * matplotlib_config.py: new files for matplotlib support, part of
2367 * matplotlib_config.py: new files for matplotlib support, part of
2363 the pylab profile.
2368 the pylab profile.
2364
2369
2365 * IPython/usage.py (__doc__): documented the threading options.
2370 * IPython/usage.py (__doc__): documented the threading options.
2366
2371
2367 2004-08-20 Fernando Perez <fperez@colorado.edu>
2372 2004-08-20 Fernando Perez <fperez@colorado.edu>
2368
2373
2369 * ipython: Modified the main calling routine to handle the -thread
2374 * ipython: Modified the main calling routine to handle the -thread
2370 and -mpthread options. This needs to be done as a top-level hack,
2375 and -mpthread options. This needs to be done as a top-level hack,
2371 because it determines which class to instantiate for IPython
2376 because it determines which class to instantiate for IPython
2372 itself.
2377 itself.
2373
2378
2374 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
2379 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
2375 classes to support multithreaded GTK operation without blocking,
2380 classes to support multithreaded GTK operation without blocking,
2376 and matplotlib with all backends. This is a lot of still very
2381 and matplotlib with all backends. This is a lot of still very
2377 experimental code, and threads are tricky. So it may still have a
2382 experimental code, and threads are tricky. So it may still have a
2378 few rough edges... This code owes a lot to
2383 few rough edges... This code owes a lot to
2379 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
2384 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
2380 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
2385 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
2381 to John Hunter for all the matplotlib work.
2386 to John Hunter for all the matplotlib work.
2382
2387
2383 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
2388 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
2384 options for gtk thread and matplotlib support.
2389 options for gtk thread and matplotlib support.
2385
2390
2386 2004-08-16 Fernando Perez <fperez@colorado.edu>
2391 2004-08-16 Fernando Perez <fperez@colorado.edu>
2387
2392
2388 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
2393 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
2389 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
2394 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
2390 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
2395 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
2391
2396
2392 2004-08-11 Fernando Perez <fperez@colorado.edu>
2397 2004-08-11 Fernando Perez <fperez@colorado.edu>
2393
2398
2394 * setup.py (isfile): Fix build so documentation gets updated for
2399 * setup.py (isfile): Fix build so documentation gets updated for
2395 rpms (it was only done for .tgz builds).
2400 rpms (it was only done for .tgz builds).
2396
2401
2397 2004-08-10 Fernando Perez <fperez@colorado.edu>
2402 2004-08-10 Fernando Perez <fperez@colorado.edu>
2398
2403
2399 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
2404 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
2400
2405
2401 * iplib.py : Silence syntax error exceptions in tab-completion.
2406 * iplib.py : Silence syntax error exceptions in tab-completion.
2402
2407
2403 2004-08-05 Fernando Perez <fperez@colorado.edu>
2408 2004-08-05 Fernando Perez <fperez@colorado.edu>
2404
2409
2405 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
2410 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
2406 'color off' mark for continuation prompts. This was causing long
2411 'color off' mark for continuation prompts. This was causing long
2407 continuation lines to mis-wrap.
2412 continuation lines to mis-wrap.
2408
2413
2409 2004-08-01 Fernando Perez <fperez@colorado.edu>
2414 2004-08-01 Fernando Perez <fperez@colorado.edu>
2410
2415
2411 * IPython/ipmaker.py (make_IPython): Allow the shell class used
2416 * IPython/ipmaker.py (make_IPython): Allow the shell class used
2412 for building ipython to be a parameter. All this is necessary
2417 for building ipython to be a parameter. All this is necessary
2413 right now to have a multithreaded version, but this insane
2418 right now to have a multithreaded version, but this insane
2414 non-design will be cleaned up soon. For now, it's a hack that
2419 non-design will be cleaned up soon. For now, it's a hack that
2415 works.
2420 works.
2416
2421
2417 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
2422 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
2418 args in various places. No bugs so far, but it's a dangerous
2423 args in various places. No bugs so far, but it's a dangerous
2419 practice.
2424 practice.
2420
2425
2421 2004-07-31 Fernando Perez <fperez@colorado.edu>
2426 2004-07-31 Fernando Perez <fperez@colorado.edu>
2422
2427
2423 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
2428 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
2424 fix completion of files with dots in their names under most
2429 fix completion of files with dots in their names under most
2425 profiles (pysh was OK because the completion order is different).
2430 profiles (pysh was OK because the completion order is different).
2426
2431
2427 2004-07-27 Fernando Perez <fperez@colorado.edu>
2432 2004-07-27 Fernando Perez <fperez@colorado.edu>
2428
2433
2429 * IPython/iplib.py (InteractiveShell.__init__): build dict of
2434 * IPython/iplib.py (InteractiveShell.__init__): build dict of
2430 keywords manually, b/c the one in keyword.py was removed in python
2435 keywords manually, b/c the one in keyword.py was removed in python
2431 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
2436 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
2432 This is NOT a bug under python 2.3 and earlier.
2437 This is NOT a bug under python 2.3 and earlier.
2433
2438
2434 2004-07-26 Fernando Perez <fperez@colorado.edu>
2439 2004-07-26 Fernando Perez <fperez@colorado.edu>
2435
2440
2436 * IPython/ultraTB.py (VerboseTB.text): Add another
2441 * IPython/ultraTB.py (VerboseTB.text): Add another
2437 linecache.checkcache() call to try to prevent inspect.py from
2442 linecache.checkcache() call to try to prevent inspect.py from
2438 crashing under python 2.3. I think this fixes
2443 crashing under python 2.3. I think this fixes
2439 http://www.scipy.net/roundup/ipython/issue17.
2444 http://www.scipy.net/roundup/ipython/issue17.
2440
2445
2441 2004-07-26 *** Released version 0.6.2
2446 2004-07-26 *** Released version 0.6.2
2442
2447
2443 2004-07-26 Fernando Perez <fperez@colorado.edu>
2448 2004-07-26 Fernando Perez <fperez@colorado.edu>
2444
2449
2445 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
2450 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
2446 fail for any number.
2451 fail for any number.
2447 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
2452 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
2448 empty bookmarks.
2453 empty bookmarks.
2449
2454
2450 2004-07-26 *** Released version 0.6.1
2455 2004-07-26 *** Released version 0.6.1
2451
2456
2452 2004-07-26 Fernando Perez <fperez@colorado.edu>
2457 2004-07-26 Fernando Perez <fperez@colorado.edu>
2453
2458
2454 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
2459 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
2455
2460
2456 * IPython/iplib.py (protect_filename): Applied Ville's patch for
2461 * IPython/iplib.py (protect_filename): Applied Ville's patch for
2457 escaping '()[]{}' in filenames.
2462 escaping '()[]{}' in filenames.
2458
2463
2459 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
2464 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
2460 Python 2.2 users who lack a proper shlex.split.
2465 Python 2.2 users who lack a proper shlex.split.
2461
2466
2462 2004-07-19 Fernando Perez <fperez@colorado.edu>
2467 2004-07-19 Fernando Perez <fperez@colorado.edu>
2463
2468
2464 * IPython/iplib.py (InteractiveShell.init_readline): Add support
2469 * IPython/iplib.py (InteractiveShell.init_readline): Add support
2465 for reading readline's init file. I follow the normal chain:
2470 for reading readline's init file. I follow the normal chain:
2466 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
2471 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
2467 report by Mike Heeter. This closes
2472 report by Mike Heeter. This closes
2468 http://www.scipy.net/roundup/ipython/issue16.
2473 http://www.scipy.net/roundup/ipython/issue16.
2469
2474
2470 2004-07-18 Fernando Perez <fperez@colorado.edu>
2475 2004-07-18 Fernando Perez <fperez@colorado.edu>
2471
2476
2472 * IPython/iplib.py (__init__): Add better handling of '\' under
2477 * IPython/iplib.py (__init__): Add better handling of '\' under
2473 Win32 for filenames. After a patch by Ville.
2478 Win32 for filenames. After a patch by Ville.
2474
2479
2475 2004-07-17 Fernando Perez <fperez@colorado.edu>
2480 2004-07-17 Fernando Perez <fperez@colorado.edu>
2476
2481
2477 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
2482 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
2478 autocalling would be triggered for 'foo is bar' if foo is
2483 autocalling would be triggered for 'foo is bar' if foo is
2479 callable. I also cleaned up the autocall detection code to use a
2484 callable. I also cleaned up the autocall detection code to use a
2480 regexp, which is faster. Bug reported by Alexander Schmolck.
2485 regexp, which is faster. Bug reported by Alexander Schmolck.
2481
2486
2482 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
2487 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
2483 '?' in them would confuse the help system. Reported by Alex
2488 '?' in them would confuse the help system. Reported by Alex
2484 Schmolck.
2489 Schmolck.
2485
2490
2486 2004-07-16 Fernando Perez <fperez@colorado.edu>
2491 2004-07-16 Fernando Perez <fperez@colorado.edu>
2487
2492
2488 * IPython/GnuplotInteractive.py (__all__): added plot2.
2493 * IPython/GnuplotInteractive.py (__all__): added plot2.
2489
2494
2490 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
2495 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
2491 plotting dictionaries, lists or tuples of 1d arrays.
2496 plotting dictionaries, lists or tuples of 1d arrays.
2492
2497
2493 * IPython/Magic.py (Magic.magic_hist): small clenaups and
2498 * IPython/Magic.py (Magic.magic_hist): small clenaups and
2494 optimizations.
2499 optimizations.
2495
2500
2496 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
2501 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
2497 the information which was there from Janko's original IPP code:
2502 the information which was there from Janko's original IPP code:
2498
2503
2499 03.05.99 20:53 porto.ifm.uni-kiel.de
2504 03.05.99 20:53 porto.ifm.uni-kiel.de
2500 --Started changelog.
2505 --Started changelog.
2501 --make clear do what it say it does
2506 --make clear do what it say it does
2502 --added pretty output of lines from inputcache
2507 --added pretty output of lines from inputcache
2503 --Made Logger a mixin class, simplifies handling of switches
2508 --Made Logger a mixin class, simplifies handling of switches
2504 --Added own completer class. .string<TAB> expands to last history
2509 --Added own completer class. .string<TAB> expands to last history
2505 line which starts with string. The new expansion is also present
2510 line which starts with string. The new expansion is also present
2506 with Ctrl-r from the readline library. But this shows, who this
2511 with Ctrl-r from the readline library. But this shows, who this
2507 can be done for other cases.
2512 can be done for other cases.
2508 --Added convention that all shell functions should accept a
2513 --Added convention that all shell functions should accept a
2509 parameter_string This opens the door for different behaviour for
2514 parameter_string This opens the door for different behaviour for
2510 each function. @cd is a good example of this.
2515 each function. @cd is a good example of this.
2511
2516
2512 04.05.99 12:12 porto.ifm.uni-kiel.de
2517 04.05.99 12:12 porto.ifm.uni-kiel.de
2513 --added logfile rotation
2518 --added logfile rotation
2514 --added new mainloop method which freezes first the namespace
2519 --added new mainloop method which freezes first the namespace
2515
2520
2516 07.05.99 21:24 porto.ifm.uni-kiel.de
2521 07.05.99 21:24 porto.ifm.uni-kiel.de
2517 --added the docreader classes. Now there is a help system.
2522 --added the docreader classes. Now there is a help system.
2518 -This is only a first try. Currently it's not easy to put new
2523 -This is only a first try. Currently it's not easy to put new
2519 stuff in the indices. But this is the way to go. Info would be
2524 stuff in the indices. But this is the way to go. Info would be
2520 better, but HTML is every where and not everybody has an info
2525 better, but HTML is every where and not everybody has an info
2521 system installed and it's not so easy to change html-docs to info.
2526 system installed and it's not so easy to change html-docs to info.
2522 --added global logfile option
2527 --added global logfile option
2523 --there is now a hook for object inspection method pinfo needs to
2528 --there is now a hook for object inspection method pinfo needs to
2524 be provided for this. Can be reached by two '??'.
2529 be provided for this. Can be reached by two '??'.
2525
2530
2526 08.05.99 20:51 porto.ifm.uni-kiel.de
2531 08.05.99 20:51 porto.ifm.uni-kiel.de
2527 --added a README
2532 --added a README
2528 --bug in rc file. Something has changed so functions in the rc
2533 --bug in rc file. Something has changed so functions in the rc
2529 file need to reference the shell and not self. Not clear if it's a
2534 file need to reference the shell and not self. Not clear if it's a
2530 bug or feature.
2535 bug or feature.
2531 --changed rc file for new behavior
2536 --changed rc file for new behavior
2532
2537
2533 2004-07-15 Fernando Perez <fperez@colorado.edu>
2538 2004-07-15 Fernando Perez <fperez@colorado.edu>
2534
2539
2535 * IPython/Logger.py (Logger.log): fixed recent bug where the input
2540 * IPython/Logger.py (Logger.log): fixed recent bug where the input
2536 cache was falling out of sync in bizarre manners when multi-line
2541 cache was falling out of sync in bizarre manners when multi-line
2537 input was present. Minor optimizations and cleanup.
2542 input was present. Minor optimizations and cleanup.
2538
2543
2539 (Logger): Remove old Changelog info for cleanup. This is the
2544 (Logger): Remove old Changelog info for cleanup. This is the
2540 information which was there from Janko's original code:
2545 information which was there from Janko's original code:
2541
2546
2542 Changes to Logger: - made the default log filename a parameter
2547 Changes to Logger: - made the default log filename a parameter
2543
2548
2544 - put a check for lines beginning with !@? in log(). Needed
2549 - put a check for lines beginning with !@? in log(). Needed
2545 (even if the handlers properly log their lines) for mid-session
2550 (even if the handlers properly log their lines) for mid-session
2546 logging activation to work properly. Without this, lines logged
2551 logging activation to work properly. Without this, lines logged
2547 in mid session, which get read from the cache, would end up
2552 in mid session, which get read from the cache, would end up
2548 'bare' (with !@? in the open) in the log. Now they are caught
2553 'bare' (with !@? in the open) in the log. Now they are caught
2549 and prepended with a #.
2554 and prepended with a #.
2550
2555
2551 * IPython/iplib.py (InteractiveShell.init_readline): added check
2556 * IPython/iplib.py (InteractiveShell.init_readline): added check
2552 in case MagicCompleter fails to be defined, so we don't crash.
2557 in case MagicCompleter fails to be defined, so we don't crash.
2553
2558
2554 2004-07-13 Fernando Perez <fperez@colorado.edu>
2559 2004-07-13 Fernando Perez <fperez@colorado.edu>
2555
2560
2556 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
2561 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
2557 of EPS if the requested filename ends in '.eps'.
2562 of EPS if the requested filename ends in '.eps'.
2558
2563
2559 2004-07-04 Fernando Perez <fperez@colorado.edu>
2564 2004-07-04 Fernando Perez <fperez@colorado.edu>
2560
2565
2561 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
2566 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
2562 escaping of quotes when calling the shell.
2567 escaping of quotes when calling the shell.
2563
2568
2564 2004-07-02 Fernando Perez <fperez@colorado.edu>
2569 2004-07-02 Fernando Perez <fperez@colorado.edu>
2565
2570
2566 * IPython/Prompts.py (CachedOutput.update): Fix problem with
2571 * IPython/Prompts.py (CachedOutput.update): Fix problem with
2567 gettext not working because we were clobbering '_'. Fixes
2572 gettext not working because we were clobbering '_'. Fixes
2568 http://www.scipy.net/roundup/ipython/issue6.
2573 http://www.scipy.net/roundup/ipython/issue6.
2569
2574
2570 2004-07-01 Fernando Perez <fperez@colorado.edu>
2575 2004-07-01 Fernando Perez <fperez@colorado.edu>
2571
2576
2572 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
2577 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
2573 into @cd. Patch by Ville.
2578 into @cd. Patch by Ville.
2574
2579
2575 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2580 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2576 new function to store things after ipmaker runs. Patch by Ville.
2581 new function to store things after ipmaker runs. Patch by Ville.
2577 Eventually this will go away once ipmaker is removed and the class
2582 Eventually this will go away once ipmaker is removed and the class
2578 gets cleaned up, but for now it's ok. Key functionality here is
2583 gets cleaned up, but for now it's ok. Key functionality here is
2579 the addition of the persistent storage mechanism, a dict for
2584 the addition of the persistent storage mechanism, a dict for
2580 keeping data across sessions (for now just bookmarks, but more can
2585 keeping data across sessions (for now just bookmarks, but more can
2581 be implemented later).
2586 be implemented later).
2582
2587
2583 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
2588 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
2584 persistent across sections. Patch by Ville, I modified it
2589 persistent across sections. Patch by Ville, I modified it
2585 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
2590 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
2586 added a '-l' option to list all bookmarks.
2591 added a '-l' option to list all bookmarks.
2587
2592
2588 * IPython/iplib.py (InteractiveShell.atexit_operations): new
2593 * IPython/iplib.py (InteractiveShell.atexit_operations): new
2589 center for cleanup. Registered with atexit.register(). I moved
2594 center for cleanup. Registered with atexit.register(). I moved
2590 here the old exit_cleanup(). After a patch by Ville.
2595 here the old exit_cleanup(). After a patch by Ville.
2591
2596
2592 * IPython/Magic.py (get_py_filename): added '~' to the accepted
2597 * IPython/Magic.py (get_py_filename): added '~' to the accepted
2593 characters in the hacked shlex_split for python 2.2.
2598 characters in the hacked shlex_split for python 2.2.
2594
2599
2595 * IPython/iplib.py (file_matches): more fixes to filenames with
2600 * IPython/iplib.py (file_matches): more fixes to filenames with
2596 whitespace in them. It's not perfect, but limitations in python's
2601 whitespace in them. It's not perfect, but limitations in python's
2597 readline make it impossible to go further.
2602 readline make it impossible to go further.
2598
2603
2599 2004-06-29 Fernando Perez <fperez@colorado.edu>
2604 2004-06-29 Fernando Perez <fperez@colorado.edu>
2600
2605
2601 * IPython/iplib.py (file_matches): escape whitespace correctly in
2606 * IPython/iplib.py (file_matches): escape whitespace correctly in
2602 filename completions. Bug reported by Ville.
2607 filename completions. Bug reported by Ville.
2603
2608
2604 2004-06-28 Fernando Perez <fperez@colorado.edu>
2609 2004-06-28 Fernando Perez <fperez@colorado.edu>
2605
2610
2606 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
2611 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
2607 the history file will be called 'history-PROFNAME' (or just
2612 the history file will be called 'history-PROFNAME' (or just
2608 'history' if no profile is loaded). I was getting annoyed at
2613 'history' if no profile is loaded). I was getting annoyed at
2609 getting my Numerical work history clobbered by pysh sessions.
2614 getting my Numerical work history clobbered by pysh sessions.
2610
2615
2611 * IPython/iplib.py (InteractiveShell.__init__): Internal
2616 * IPython/iplib.py (InteractiveShell.__init__): Internal
2612 getoutputerror() function so that we can honor the system_verbose
2617 getoutputerror() function so that we can honor the system_verbose
2613 flag for _all_ system calls. I also added escaping of #
2618 flag for _all_ system calls. I also added escaping of #
2614 characters here to avoid confusing Itpl.
2619 characters here to avoid confusing Itpl.
2615
2620
2616 * IPython/Magic.py (shlex_split): removed call to shell in
2621 * IPython/Magic.py (shlex_split): removed call to shell in
2617 parse_options and replaced it with shlex.split(). The annoying
2622 parse_options and replaced it with shlex.split(). The annoying
2618 part was that in Python 2.2, shlex.split() doesn't exist, so I had
2623 part was that in Python 2.2, shlex.split() doesn't exist, so I had
2619 to backport it from 2.3, with several frail hacks (the shlex
2624 to backport it from 2.3, with several frail hacks (the shlex
2620 module is rather limited in 2.2). Thanks to a suggestion by Ville
2625 module is rather limited in 2.2). Thanks to a suggestion by Ville
2621 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
2626 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
2622 problem.
2627 problem.
2623
2628
2624 (Magic.magic_system_verbose): new toggle to print the actual
2629 (Magic.magic_system_verbose): new toggle to print the actual
2625 system calls made by ipython. Mainly for debugging purposes.
2630 system calls made by ipython. Mainly for debugging purposes.
2626
2631
2627 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
2632 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
2628 doesn't support persistence. Reported (and fix suggested) by
2633 doesn't support persistence. Reported (and fix suggested) by
2629 Travis Caldwell <travis_caldwell2000@yahoo.com>.
2634 Travis Caldwell <travis_caldwell2000@yahoo.com>.
2630
2635
2631 2004-06-26 Fernando Perez <fperez@colorado.edu>
2636 2004-06-26 Fernando Perez <fperez@colorado.edu>
2632
2637
2633 * IPython/Logger.py (Logger.log): fix to handle correctly empty
2638 * IPython/Logger.py (Logger.log): fix to handle correctly empty
2634 continue prompts.
2639 continue prompts.
2635
2640
2636 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
2641 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
2637 function (basically a big docstring) and a few more things here to
2642 function (basically a big docstring) and a few more things here to
2638 speedup startup. pysh.py is now very lightweight. We want because
2643 speedup startup. pysh.py is now very lightweight. We want because
2639 it gets execfile'd, while InterpreterExec gets imported, so
2644 it gets execfile'd, while InterpreterExec gets imported, so
2640 byte-compilation saves time.
2645 byte-compilation saves time.
2641
2646
2642 2004-06-25 Fernando Perez <fperez@colorado.edu>
2647 2004-06-25 Fernando Perez <fperez@colorado.edu>
2643
2648
2644 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
2649 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
2645 -NUM', which was recently broken.
2650 -NUM', which was recently broken.
2646
2651
2647 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
2652 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
2648 in multi-line input (but not !!, which doesn't make sense there).
2653 in multi-line input (but not !!, which doesn't make sense there).
2649
2654
2650 * IPython/UserConfig/ipythonrc: made autoindent on by default.
2655 * IPython/UserConfig/ipythonrc: made autoindent on by default.
2651 It's just too useful, and people can turn it off in the less
2656 It's just too useful, and people can turn it off in the less
2652 common cases where it's a problem.
2657 common cases where it's a problem.
2653
2658
2654 2004-06-24 Fernando Perez <fperez@colorado.edu>
2659 2004-06-24 Fernando Perez <fperez@colorado.edu>
2655
2660
2656 * IPython/iplib.py (InteractiveShell._prefilter): big change -
2661 * IPython/iplib.py (InteractiveShell._prefilter): big change -
2657 special syntaxes (like alias calling) is now allied in multi-line
2662 special syntaxes (like alias calling) is now allied in multi-line
2658 input. This is still _very_ experimental, but it's necessary for
2663 input. This is still _very_ experimental, but it's necessary for
2659 efficient shell usage combining python looping syntax with system
2664 efficient shell usage combining python looping syntax with system
2660 calls. For now it's restricted to aliases, I don't think it
2665 calls. For now it's restricted to aliases, I don't think it
2661 really even makes sense to have this for magics.
2666 really even makes sense to have this for magics.
2662
2667
2663 2004-06-23 Fernando Perez <fperez@colorado.edu>
2668 2004-06-23 Fernando Perez <fperez@colorado.edu>
2664
2669
2665 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
2670 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
2666 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
2671 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
2667
2672
2668 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
2673 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
2669 extensions under Windows (after code sent by Gary Bishop). The
2674 extensions under Windows (after code sent by Gary Bishop). The
2670 extensions considered 'executable' are stored in IPython's rc
2675 extensions considered 'executable' are stored in IPython's rc
2671 structure as win_exec_ext.
2676 structure as win_exec_ext.
2672
2677
2673 * IPython/genutils.py (shell): new function, like system() but
2678 * IPython/genutils.py (shell): new function, like system() but
2674 without return value. Very useful for interactive shell work.
2679 without return value. Very useful for interactive shell work.
2675
2680
2676 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
2681 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
2677 delete aliases.
2682 delete aliases.
2678
2683
2679 * IPython/iplib.py (InteractiveShell.alias_table_update): make
2684 * IPython/iplib.py (InteractiveShell.alias_table_update): make
2680 sure that the alias table doesn't contain python keywords.
2685 sure that the alias table doesn't contain python keywords.
2681
2686
2682 2004-06-21 Fernando Perez <fperez@colorado.edu>
2687 2004-06-21 Fernando Perez <fperez@colorado.edu>
2683
2688
2684 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
2689 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
2685 non-existent items are found in $PATH. Reported by Thorsten.
2690 non-existent items are found in $PATH. Reported by Thorsten.
2686
2691
2687 2004-06-20 Fernando Perez <fperez@colorado.edu>
2692 2004-06-20 Fernando Perez <fperez@colorado.edu>
2688
2693
2689 * IPython/iplib.py (complete): modified the completer so that the
2694 * IPython/iplib.py (complete): modified the completer so that the
2690 order of priorities can be easily changed at runtime.
2695 order of priorities can be easily changed at runtime.
2691
2696
2692 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
2697 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
2693 Modified to auto-execute all lines beginning with '~', '/' or '.'.
2698 Modified to auto-execute all lines beginning with '~', '/' or '.'.
2694
2699
2695 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
2700 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
2696 expand Python variables prepended with $ in all system calls. The
2701 expand Python variables prepended with $ in all system calls. The
2697 same was done to InteractiveShell.handle_shell_escape. Now all
2702 same was done to InteractiveShell.handle_shell_escape. Now all
2698 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
2703 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
2699 expansion of python variables and expressions according to the
2704 expansion of python variables and expressions according to the
2700 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
2705 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
2701
2706
2702 Though PEP-215 has been rejected, a similar (but simpler) one
2707 Though PEP-215 has been rejected, a similar (but simpler) one
2703 seems like it will go into Python 2.4, PEP-292 -
2708 seems like it will go into Python 2.4, PEP-292 -
2704 http://www.python.org/peps/pep-0292.html.
2709 http://www.python.org/peps/pep-0292.html.
2705
2710
2706 I'll keep the full syntax of PEP-215, since IPython has since the
2711 I'll keep the full syntax of PEP-215, since IPython has since the
2707 start used Ka-Ping Yee's reference implementation discussed there
2712 start used Ka-Ping Yee's reference implementation discussed there
2708 (Itpl), and I actually like the powerful semantics it offers.
2713 (Itpl), and I actually like the powerful semantics it offers.
2709
2714
2710 In order to access normal shell variables, the $ has to be escaped
2715 In order to access normal shell variables, the $ has to be escaped
2711 via an extra $. For example:
2716 via an extra $. For example:
2712
2717
2713 In [7]: PATH='a python variable'
2718 In [7]: PATH='a python variable'
2714
2719
2715 In [8]: !echo $PATH
2720 In [8]: !echo $PATH
2716 a python variable
2721 a python variable
2717
2722
2718 In [9]: !echo $$PATH
2723 In [9]: !echo $$PATH
2719 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
2724 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
2720
2725
2721 (Magic.parse_options): escape $ so the shell doesn't evaluate
2726 (Magic.parse_options): escape $ so the shell doesn't evaluate
2722 things prematurely.
2727 things prematurely.
2723
2728
2724 * IPython/iplib.py (InteractiveShell.call_alias): added the
2729 * IPython/iplib.py (InteractiveShell.call_alias): added the
2725 ability for aliases to expand python variables via $.
2730 ability for aliases to expand python variables via $.
2726
2731
2727 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
2732 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
2728 system, now there's a @rehash/@rehashx pair of magics. These work
2733 system, now there's a @rehash/@rehashx pair of magics. These work
2729 like the csh rehash command, and can be invoked at any time. They
2734 like the csh rehash command, and can be invoked at any time. They
2730 build a table of aliases to everything in the user's $PATH
2735 build a table of aliases to everything in the user's $PATH
2731 (@rehash uses everything, @rehashx is slower but only adds
2736 (@rehash uses everything, @rehashx is slower but only adds
2732 executable files). With this, the pysh.py-based shell profile can
2737 executable files). With this, the pysh.py-based shell profile can
2733 now simply call rehash upon startup, and full access to all
2738 now simply call rehash upon startup, and full access to all
2734 programs in the user's path is obtained.
2739 programs in the user's path is obtained.
2735
2740
2736 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
2741 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
2737 functionality is now fully in place. I removed the old dynamic
2742 functionality is now fully in place. I removed the old dynamic
2738 code generation based approach, in favor of a much lighter one
2743 code generation based approach, in favor of a much lighter one
2739 based on a simple dict. The advantage is that this allows me to
2744 based on a simple dict. The advantage is that this allows me to
2740 now have thousands of aliases with negligible cost (unthinkable
2745 now have thousands of aliases with negligible cost (unthinkable
2741 with the old system).
2746 with the old system).
2742
2747
2743 2004-06-19 Fernando Perez <fperez@colorado.edu>
2748 2004-06-19 Fernando Perez <fperez@colorado.edu>
2744
2749
2745 * IPython/iplib.py (__init__): extended MagicCompleter class to
2750 * IPython/iplib.py (__init__): extended MagicCompleter class to
2746 also complete (last in priority) on user aliases.
2751 also complete (last in priority) on user aliases.
2747
2752
2748 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
2753 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
2749 call to eval.
2754 call to eval.
2750 (ItplNS.__init__): Added a new class which functions like Itpl,
2755 (ItplNS.__init__): Added a new class which functions like Itpl,
2751 but allows configuring the namespace for the evaluation to occur
2756 but allows configuring the namespace for the evaluation to occur
2752 in.
2757 in.
2753
2758
2754 2004-06-18 Fernando Perez <fperez@colorado.edu>
2759 2004-06-18 Fernando Perez <fperez@colorado.edu>
2755
2760
2756 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
2761 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
2757 better message when 'exit' or 'quit' are typed (a common newbie
2762 better message when 'exit' or 'quit' are typed (a common newbie
2758 confusion).
2763 confusion).
2759
2764
2760 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
2765 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
2761 check for Windows users.
2766 check for Windows users.
2762
2767
2763 * IPython/iplib.py (InteractiveShell.user_setup): removed
2768 * IPython/iplib.py (InteractiveShell.user_setup): removed
2764 disabling of colors for Windows. I'll test at runtime and issue a
2769 disabling of colors for Windows. I'll test at runtime and issue a
2765 warning if Gary's readline isn't found, as to nudge users to
2770 warning if Gary's readline isn't found, as to nudge users to
2766 download it.
2771 download it.
2767
2772
2768 2004-06-16 Fernando Perez <fperez@colorado.edu>
2773 2004-06-16 Fernando Perez <fperez@colorado.edu>
2769
2774
2770 * IPython/genutils.py (Stream.__init__): changed to print errors
2775 * IPython/genutils.py (Stream.__init__): changed to print errors
2771 to sys.stderr. I had a circular dependency here. Now it's
2776 to sys.stderr. I had a circular dependency here. Now it's
2772 possible to run ipython as IDLE's shell (consider this pre-alpha,
2777 possible to run ipython as IDLE's shell (consider this pre-alpha,
2773 since true stdout things end up in the starting terminal instead
2778 since true stdout things end up in the starting terminal instead
2774 of IDLE's out).
2779 of IDLE's out).
2775
2780
2776 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
2781 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
2777 users who haven't # updated their prompt_in2 definitions. Remove
2782 users who haven't # updated their prompt_in2 definitions. Remove
2778 eventually.
2783 eventually.
2779 (multiple_replace): added credit to original ASPN recipe.
2784 (multiple_replace): added credit to original ASPN recipe.
2780
2785
2781 2004-06-15 Fernando Perez <fperez@colorado.edu>
2786 2004-06-15 Fernando Perez <fperez@colorado.edu>
2782
2787
2783 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
2788 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
2784 list of auto-defined aliases.
2789 list of auto-defined aliases.
2785
2790
2786 2004-06-13 Fernando Perez <fperez@colorado.edu>
2791 2004-06-13 Fernando Perez <fperez@colorado.edu>
2787
2792
2788 * setup.py (scriptfiles): Don't trigger win_post_install unless an
2793 * setup.py (scriptfiles): Don't trigger win_post_install unless an
2789 install was really requested (so setup.py can be used for other
2794 install was really requested (so setup.py can be used for other
2790 things under Windows).
2795 things under Windows).
2791
2796
2792 2004-06-10 Fernando Perez <fperez@colorado.edu>
2797 2004-06-10 Fernando Perez <fperez@colorado.edu>
2793
2798
2794 * IPython/Logger.py (Logger.create_log): Manually remove any old
2799 * IPython/Logger.py (Logger.create_log): Manually remove any old
2795 backup, since os.remove may fail under Windows. Fixes bug
2800 backup, since os.remove may fail under Windows. Fixes bug
2796 reported by Thorsten.
2801 reported by Thorsten.
2797
2802
2798 2004-06-09 Fernando Perez <fperez@colorado.edu>
2803 2004-06-09 Fernando Perez <fperez@colorado.edu>
2799
2804
2800 * examples/example-embed.py: fixed all references to %n (replaced
2805 * examples/example-embed.py: fixed all references to %n (replaced
2801 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
2806 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
2802 for all examples and the manual as well.
2807 for all examples and the manual as well.
2803
2808
2804 2004-06-08 Fernando Perez <fperez@colorado.edu>
2809 2004-06-08 Fernando Perez <fperez@colorado.edu>
2805
2810
2806 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
2811 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
2807 alignment and color management. All 3 prompt subsystems now
2812 alignment and color management. All 3 prompt subsystems now
2808 inherit from BasePrompt.
2813 inherit from BasePrompt.
2809
2814
2810 * tools/release: updates for windows installer build and tag rpms
2815 * tools/release: updates for windows installer build and tag rpms
2811 with python version (since paths are fixed).
2816 with python version (since paths are fixed).
2812
2817
2813 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
2818 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
2814 which will become eventually obsolete. Also fixed the default
2819 which will become eventually obsolete. Also fixed the default
2815 prompt_in2 to use \D, so at least new users start with the correct
2820 prompt_in2 to use \D, so at least new users start with the correct
2816 defaults.
2821 defaults.
2817 WARNING: Users with existing ipythonrc files will need to apply
2822 WARNING: Users with existing ipythonrc files will need to apply
2818 this fix manually!
2823 this fix manually!
2819
2824
2820 * setup.py: make windows installer (.exe). This is finally the
2825 * setup.py: make windows installer (.exe). This is finally the
2821 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
2826 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
2822 which I hadn't included because it required Python 2.3 (or recent
2827 which I hadn't included because it required Python 2.3 (or recent
2823 distutils).
2828 distutils).
2824
2829
2825 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
2830 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
2826 usage of new '\D' escape.
2831 usage of new '\D' escape.
2827
2832
2828 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
2833 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
2829 lacks os.getuid())
2834 lacks os.getuid())
2830 (CachedOutput.set_colors): Added the ability to turn coloring
2835 (CachedOutput.set_colors): Added the ability to turn coloring
2831 on/off with @colors even for manually defined prompt colors. It
2836 on/off with @colors even for manually defined prompt colors. It
2832 uses a nasty global, but it works safely and via the generic color
2837 uses a nasty global, but it works safely and via the generic color
2833 handling mechanism.
2838 handling mechanism.
2834 (Prompt2.__init__): Introduced new escape '\D' for continuation
2839 (Prompt2.__init__): Introduced new escape '\D' for continuation
2835 prompts. It represents the counter ('\#') as dots.
2840 prompts. It represents the counter ('\#') as dots.
2836 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
2841 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
2837 need to update their ipythonrc files and replace '%n' with '\D' in
2842 need to update their ipythonrc files and replace '%n' with '\D' in
2838 their prompt_in2 settings everywhere. Sorry, but there's
2843 their prompt_in2 settings everywhere. Sorry, but there's
2839 otherwise no clean way to get all prompts to properly align. The
2844 otherwise no clean way to get all prompts to properly align. The
2840 ipythonrc shipped with IPython has been updated.
2845 ipythonrc shipped with IPython has been updated.
2841
2846
2842 2004-06-07 Fernando Perez <fperez@colorado.edu>
2847 2004-06-07 Fernando Perez <fperez@colorado.edu>
2843
2848
2844 * setup.py (isfile): Pass local_icons option to latex2html, so the
2849 * setup.py (isfile): Pass local_icons option to latex2html, so the
2845 resulting HTML file is self-contained. Thanks to
2850 resulting HTML file is self-contained. Thanks to
2846 dryice-AT-liu.com.cn for the tip.
2851 dryice-AT-liu.com.cn for the tip.
2847
2852
2848 * pysh.py: I created a new profile 'shell', which implements a
2853 * pysh.py: I created a new profile 'shell', which implements a
2849 _rudimentary_ IPython-based shell. This is in NO WAY a realy
2854 _rudimentary_ IPython-based shell. This is in NO WAY a realy
2850 system shell, nor will it become one anytime soon. It's mainly
2855 system shell, nor will it become one anytime soon. It's mainly
2851 meant to illustrate the use of the new flexible bash-like prompts.
2856 meant to illustrate the use of the new flexible bash-like prompts.
2852 I guess it could be used by hardy souls for true shell management,
2857 I guess it could be used by hardy souls for true shell management,
2853 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
2858 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
2854 profile. This uses the InterpreterExec extension provided by
2859 profile. This uses the InterpreterExec extension provided by
2855 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
2860 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
2856
2861
2857 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
2862 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
2858 auto-align itself with the length of the previous input prompt
2863 auto-align itself with the length of the previous input prompt
2859 (taking into account the invisible color escapes).
2864 (taking into account the invisible color escapes).
2860 (CachedOutput.__init__): Large restructuring of this class. Now
2865 (CachedOutput.__init__): Large restructuring of this class. Now
2861 all three prompts (primary1, primary2, output) are proper objects,
2866 all three prompts (primary1, primary2, output) are proper objects,
2862 managed by the 'parent' CachedOutput class. The code is still a
2867 managed by the 'parent' CachedOutput class. The code is still a
2863 bit hackish (all prompts share state via a pointer to the cache),
2868 bit hackish (all prompts share state via a pointer to the cache),
2864 but it's overall far cleaner than before.
2869 but it's overall far cleaner than before.
2865
2870
2866 * IPython/genutils.py (getoutputerror): modified to add verbose,
2871 * IPython/genutils.py (getoutputerror): modified to add verbose,
2867 debug and header options. This makes the interface of all getout*
2872 debug and header options. This makes the interface of all getout*
2868 functions uniform.
2873 functions uniform.
2869 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
2874 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
2870
2875
2871 * IPython/Magic.py (Magic.default_option): added a function to
2876 * IPython/Magic.py (Magic.default_option): added a function to
2872 allow registering default options for any magic command. This
2877 allow registering default options for any magic command. This
2873 makes it easy to have profiles which customize the magics globally
2878 makes it easy to have profiles which customize the magics globally
2874 for a certain use. The values set through this function are
2879 for a certain use. The values set through this function are
2875 picked up by the parse_options() method, which all magics should
2880 picked up by the parse_options() method, which all magics should
2876 use to parse their options.
2881 use to parse their options.
2877
2882
2878 * IPython/genutils.py (warn): modified the warnings framework to
2883 * IPython/genutils.py (warn): modified the warnings framework to
2879 use the Term I/O class. I'm trying to slowly unify all of
2884 use the Term I/O class. I'm trying to slowly unify all of
2880 IPython's I/O operations to pass through Term.
2885 IPython's I/O operations to pass through Term.
2881
2886
2882 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
2887 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
2883 the secondary prompt to correctly match the length of the primary
2888 the secondary prompt to correctly match the length of the primary
2884 one for any prompt. Now multi-line code will properly line up
2889 one for any prompt. Now multi-line code will properly line up
2885 even for path dependent prompts, such as the new ones available
2890 even for path dependent prompts, such as the new ones available
2886 via the prompt_specials.
2891 via the prompt_specials.
2887
2892
2888 2004-06-06 Fernando Perez <fperez@colorado.edu>
2893 2004-06-06 Fernando Perez <fperez@colorado.edu>
2889
2894
2890 * IPython/Prompts.py (prompt_specials): Added the ability to have
2895 * IPython/Prompts.py (prompt_specials): Added the ability to have
2891 bash-like special sequences in the prompts, which get
2896 bash-like special sequences in the prompts, which get
2892 automatically expanded. Things like hostname, current working
2897 automatically expanded. Things like hostname, current working
2893 directory and username are implemented already, but it's easy to
2898 directory and username are implemented already, but it's easy to
2894 add more in the future. Thanks to a patch by W.J. van der Laan
2899 add more in the future. Thanks to a patch by W.J. van der Laan
2895 <gnufnork-AT-hetdigitalegat.nl>
2900 <gnufnork-AT-hetdigitalegat.nl>
2896 (prompt_specials): Added color support for prompt strings, so
2901 (prompt_specials): Added color support for prompt strings, so
2897 users can define arbitrary color setups for their prompts.
2902 users can define arbitrary color setups for their prompts.
2898
2903
2899 2004-06-05 Fernando Perez <fperez@colorado.edu>
2904 2004-06-05 Fernando Perez <fperez@colorado.edu>
2900
2905
2901 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
2906 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
2902 code to load Gary Bishop's readline and configure it
2907 code to load Gary Bishop's readline and configure it
2903 automatically. Thanks to Gary for help on this.
2908 automatically. Thanks to Gary for help on this.
2904
2909
2905 2004-06-01 Fernando Perez <fperez@colorado.edu>
2910 2004-06-01 Fernando Perez <fperez@colorado.edu>
2906
2911
2907 * IPython/Logger.py (Logger.create_log): fix bug for logging
2912 * IPython/Logger.py (Logger.create_log): fix bug for logging
2908 with no filename (previous fix was incomplete).
2913 with no filename (previous fix was incomplete).
2909
2914
2910 2004-05-25 Fernando Perez <fperez@colorado.edu>
2915 2004-05-25 Fernando Perez <fperez@colorado.edu>
2911
2916
2912 * IPython/Magic.py (Magic.parse_options): fix bug where naked
2917 * IPython/Magic.py (Magic.parse_options): fix bug where naked
2913 parens would get passed to the shell.
2918 parens would get passed to the shell.
2914
2919
2915 2004-05-20 Fernando Perez <fperez@colorado.edu>
2920 2004-05-20 Fernando Perez <fperez@colorado.edu>
2916
2921
2917 * IPython/Magic.py (Magic.magic_prun): changed default profile
2922 * IPython/Magic.py (Magic.magic_prun): changed default profile
2918 sort order to 'time' (the more common profiling need).
2923 sort order to 'time' (the more common profiling need).
2919
2924
2920 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
2925 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
2921 so that source code shown is guaranteed in sync with the file on
2926 so that source code shown is guaranteed in sync with the file on
2922 disk (also changed in psource). Similar fix to the one for
2927 disk (also changed in psource). Similar fix to the one for
2923 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
2928 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
2924 <yann.ledu-AT-noos.fr>.
2929 <yann.ledu-AT-noos.fr>.
2925
2930
2926 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
2931 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
2927 with a single option would not be correctly parsed. Closes
2932 with a single option would not be correctly parsed. Closes
2928 http://www.scipy.net/roundup/ipython/issue14. This bug had been
2933 http://www.scipy.net/roundup/ipython/issue14. This bug had been
2929 introduced in 0.6.0 (on 2004-05-06).
2934 introduced in 0.6.0 (on 2004-05-06).
2930
2935
2931 2004-05-13 *** Released version 0.6.0
2936 2004-05-13 *** Released version 0.6.0
2932
2937
2933 2004-05-13 Fernando Perez <fperez@colorado.edu>
2938 2004-05-13 Fernando Perez <fperez@colorado.edu>
2934
2939
2935 * debian/: Added debian/ directory to CVS, so that debian support
2940 * debian/: Added debian/ directory to CVS, so that debian support
2936 is publicly accessible. The debian package is maintained by Jack
2941 is publicly accessible. The debian package is maintained by Jack
2937 Moffit <jack-AT-xiph.org>.
2942 Moffit <jack-AT-xiph.org>.
2938
2943
2939 * Documentation: included the notes about an ipython-based system
2944 * Documentation: included the notes about an ipython-based system
2940 shell (the hypothetical 'pysh') into the new_design.pdf document,
2945 shell (the hypothetical 'pysh') into the new_design.pdf document,
2941 so that these ideas get distributed to users along with the
2946 so that these ideas get distributed to users along with the
2942 official documentation.
2947 official documentation.
2943
2948
2944 2004-05-10 Fernando Perez <fperez@colorado.edu>
2949 2004-05-10 Fernando Perez <fperez@colorado.edu>
2945
2950
2946 * IPython/Logger.py (Logger.create_log): fix recently introduced
2951 * IPython/Logger.py (Logger.create_log): fix recently introduced
2947 bug (misindented line) where logstart would fail when not given an
2952 bug (misindented line) where logstart would fail when not given an
2948 explicit filename.
2953 explicit filename.
2949
2954
2950 2004-05-09 Fernando Perez <fperez@colorado.edu>
2955 2004-05-09 Fernando Perez <fperez@colorado.edu>
2951
2956
2952 * IPython/Magic.py (Magic.parse_options): skip system call when
2957 * IPython/Magic.py (Magic.parse_options): skip system call when
2953 there are no options to look for. Faster, cleaner for the common
2958 there are no options to look for. Faster, cleaner for the common
2954 case.
2959 case.
2955
2960
2956 * Documentation: many updates to the manual: describing Windows
2961 * Documentation: many updates to the manual: describing Windows
2957 support better, Gnuplot updates, credits, misc small stuff. Also
2962 support better, Gnuplot updates, credits, misc small stuff. Also
2958 updated the new_design doc a bit.
2963 updated the new_design doc a bit.
2959
2964
2960 2004-05-06 *** Released version 0.6.0.rc1
2965 2004-05-06 *** Released version 0.6.0.rc1
2961
2966
2962 2004-05-06 Fernando Perez <fperez@colorado.edu>
2967 2004-05-06 Fernando Perez <fperez@colorado.edu>
2963
2968
2964 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
2969 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
2965 operations to use the vastly more efficient list/''.join() method.
2970 operations to use the vastly more efficient list/''.join() method.
2966 (FormattedTB.text): Fix
2971 (FormattedTB.text): Fix
2967 http://www.scipy.net/roundup/ipython/issue12 - exception source
2972 http://www.scipy.net/roundup/ipython/issue12 - exception source
2968 extract not updated after reload. Thanks to Mike Salib
2973 extract not updated after reload. Thanks to Mike Salib
2969 <msalib-AT-mit.edu> for pinning the source of the problem.
2974 <msalib-AT-mit.edu> for pinning the source of the problem.
2970 Fortunately, the solution works inside ipython and doesn't require
2975 Fortunately, the solution works inside ipython and doesn't require
2971 any changes to python proper.
2976 any changes to python proper.
2972
2977
2973 * IPython/Magic.py (Magic.parse_options): Improved to process the
2978 * IPython/Magic.py (Magic.parse_options): Improved to process the
2974 argument list as a true shell would (by actually using the
2979 argument list as a true shell would (by actually using the
2975 underlying system shell). This way, all @magics automatically get
2980 underlying system shell). This way, all @magics automatically get
2976 shell expansion for variables. Thanks to a comment by Alex
2981 shell expansion for variables. Thanks to a comment by Alex
2977 Schmolck.
2982 Schmolck.
2978
2983
2979 2004-04-04 Fernando Perez <fperez@colorado.edu>
2984 2004-04-04 Fernando Perez <fperez@colorado.edu>
2980
2985
2981 * IPython/iplib.py (InteractiveShell.interact): Added a special
2986 * IPython/iplib.py (InteractiveShell.interact): Added a special
2982 trap for a debugger quit exception, which is basically impossible
2987 trap for a debugger quit exception, which is basically impossible
2983 to handle by normal mechanisms, given what pdb does to the stack.
2988 to handle by normal mechanisms, given what pdb does to the stack.
2984 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
2989 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
2985
2990
2986 2004-04-03 Fernando Perez <fperez@colorado.edu>
2991 2004-04-03 Fernando Perez <fperez@colorado.edu>
2987
2992
2988 * IPython/genutils.py (Term): Standardized the names of the Term
2993 * IPython/genutils.py (Term): Standardized the names of the Term
2989 class streams to cin/cout/cerr, following C++ naming conventions
2994 class streams to cin/cout/cerr, following C++ naming conventions
2990 (I can't use in/out/err because 'in' is not a valid attribute
2995 (I can't use in/out/err because 'in' is not a valid attribute
2991 name).
2996 name).
2992
2997
2993 * IPython/iplib.py (InteractiveShell.interact): don't increment
2998 * IPython/iplib.py (InteractiveShell.interact): don't increment
2994 the prompt if there's no user input. By Daniel 'Dang' Griffith
2999 the prompt if there's no user input. By Daniel 'Dang' Griffith
2995 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
3000 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
2996 Francois Pinard.
3001 Francois Pinard.
2997
3002
2998 2004-04-02 Fernando Perez <fperez@colorado.edu>
3003 2004-04-02 Fernando Perez <fperez@colorado.edu>
2999
3004
3000 * IPython/genutils.py (Stream.__init__): Modified to survive at
3005 * IPython/genutils.py (Stream.__init__): Modified to survive at
3001 least importing in contexts where stdin/out/err aren't true file
3006 least importing in contexts where stdin/out/err aren't true file
3002 objects, such as PyCrust (they lack fileno() and mode). However,
3007 objects, such as PyCrust (they lack fileno() and mode). However,
3003 the recovery facilities which rely on these things existing will
3008 the recovery facilities which rely on these things existing will
3004 not work.
3009 not work.
3005
3010
3006 2004-04-01 Fernando Perez <fperez@colorado.edu>
3011 2004-04-01 Fernando Perez <fperez@colorado.edu>
3007
3012
3008 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
3013 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
3009 use the new getoutputerror() function, so it properly
3014 use the new getoutputerror() function, so it properly
3010 distinguishes stdout/err.
3015 distinguishes stdout/err.
3011
3016
3012 * IPython/genutils.py (getoutputerror): added a function to
3017 * IPython/genutils.py (getoutputerror): added a function to
3013 capture separately the standard output and error of a command.
3018 capture separately the standard output and error of a command.
3014 After a comment from dang on the mailing lists. This code is
3019 After a comment from dang on the mailing lists. This code is
3015 basically a modified version of commands.getstatusoutput(), from
3020 basically a modified version of commands.getstatusoutput(), from
3016 the standard library.
3021 the standard library.
3017
3022
3018 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
3023 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
3019 '!!' as a special syntax (shorthand) to access @sx.
3024 '!!' as a special syntax (shorthand) to access @sx.
3020
3025
3021 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
3026 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
3022 command and return its output as a list split on '\n'.
3027 command and return its output as a list split on '\n'.
3023
3028
3024 2004-03-31 Fernando Perez <fperez@colorado.edu>
3029 2004-03-31 Fernando Perez <fperez@colorado.edu>
3025
3030
3026 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
3031 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
3027 method to dictionaries used as FakeModule instances if they lack
3032 method to dictionaries used as FakeModule instances if they lack
3028 it. At least pydoc in python2.3 breaks for runtime-defined
3033 it. At least pydoc in python2.3 breaks for runtime-defined
3029 functions without this hack. At some point I need to _really_
3034 functions without this hack. At some point I need to _really_
3030 understand what FakeModule is doing, because it's a gross hack.
3035 understand what FakeModule is doing, because it's a gross hack.
3031 But it solves Arnd's problem for now...
3036 But it solves Arnd's problem for now...
3032
3037
3033 2004-02-27 Fernando Perez <fperez@colorado.edu>
3038 2004-02-27 Fernando Perez <fperez@colorado.edu>
3034
3039
3035 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
3040 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
3036 mode would behave erratically. Also increased the number of
3041 mode would behave erratically. Also increased the number of
3037 possible logs in rotate mod to 999. Thanks to Rod Holland
3042 possible logs in rotate mod to 999. Thanks to Rod Holland
3038 <rhh@StructureLABS.com> for the report and fixes.
3043 <rhh@StructureLABS.com> for the report and fixes.
3039
3044
3040 2004-02-26 Fernando Perez <fperez@colorado.edu>
3045 2004-02-26 Fernando Perez <fperez@colorado.edu>
3041
3046
3042 * IPython/genutils.py (page): Check that the curses module really
3047 * IPython/genutils.py (page): Check that the curses module really
3043 has the initscr attribute before trying to use it. For some
3048 has the initscr attribute before trying to use it. For some
3044 reason, the Solaris curses module is missing this. I think this
3049 reason, the Solaris curses module is missing this. I think this
3045 should be considered a Solaris python bug, but I'm not sure.
3050 should be considered a Solaris python bug, but I'm not sure.
3046
3051
3047 2004-01-17 Fernando Perez <fperez@colorado.edu>
3052 2004-01-17 Fernando Perez <fperez@colorado.edu>
3048
3053
3049 * IPython/genutils.py (Stream.__init__): Changes to try to make
3054 * IPython/genutils.py (Stream.__init__): Changes to try to make
3050 ipython robust against stdin/out/err being closed by the user.
3055 ipython robust against stdin/out/err being closed by the user.
3051 This is 'user error' (and blocks a normal python session, at least
3056 This is 'user error' (and blocks a normal python session, at least
3052 the stdout case). However, Ipython should be able to survive such
3057 the stdout case). However, Ipython should be able to survive such
3053 instances of abuse as gracefully as possible. To simplify the
3058 instances of abuse as gracefully as possible. To simplify the
3054 coding and maintain compatibility with Gary Bishop's Term
3059 coding and maintain compatibility with Gary Bishop's Term
3055 contributions, I've made use of classmethods for this. I think
3060 contributions, I've made use of classmethods for this. I think
3056 this introduces a dependency on python 2.2.
3061 this introduces a dependency on python 2.2.
3057
3062
3058 2004-01-13 Fernando Perez <fperez@colorado.edu>
3063 2004-01-13 Fernando Perez <fperez@colorado.edu>
3059
3064
3060 * IPython/numutils.py (exp_safe): simplified the code a bit and
3065 * IPython/numutils.py (exp_safe): simplified the code a bit and
3061 removed the need for importing the kinds module altogether.
3066 removed the need for importing the kinds module altogether.
3062
3067
3063 2004-01-06 Fernando Perez <fperez@colorado.edu>
3068 2004-01-06 Fernando Perez <fperez@colorado.edu>
3064
3069
3065 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
3070 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
3066 a magic function instead, after some community feedback. No
3071 a magic function instead, after some community feedback. No
3067 special syntax will exist for it, but its name is deliberately
3072 special syntax will exist for it, but its name is deliberately
3068 very short.
3073 very short.
3069
3074
3070 2003-12-20 Fernando Perez <fperez@colorado.edu>
3075 2003-12-20 Fernando Perez <fperez@colorado.edu>
3071
3076
3072 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
3077 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
3073 new functionality, to automagically assign the result of a shell
3078 new functionality, to automagically assign the result of a shell
3074 command to a variable. I'll solicit some community feedback on
3079 command to a variable. I'll solicit some community feedback on
3075 this before making it permanent.
3080 this before making it permanent.
3076
3081
3077 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
3082 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
3078 requested about callables for which inspect couldn't obtain a
3083 requested about callables for which inspect couldn't obtain a
3079 proper argspec. Thanks to a crash report sent by Etienne
3084 proper argspec. Thanks to a crash report sent by Etienne
3080 Posthumus <etienne-AT-apple01.cs.vu.nl>.
3085 Posthumus <etienne-AT-apple01.cs.vu.nl>.
3081
3086
3082 2003-12-09 Fernando Perez <fperez@colorado.edu>
3087 2003-12-09 Fernando Perez <fperez@colorado.edu>
3083
3088
3084 * IPython/genutils.py (page): patch for the pager to work across
3089 * IPython/genutils.py (page): patch for the pager to work across
3085 various versions of Windows. By Gary Bishop.
3090 various versions of Windows. By Gary Bishop.
3086
3091
3087 2003-12-04 Fernando Perez <fperez@colorado.edu>
3092 2003-12-04 Fernando Perez <fperez@colorado.edu>
3088
3093
3089 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
3094 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
3090 Gnuplot.py version 1.7, whose internal names changed quite a bit.
3095 Gnuplot.py version 1.7, whose internal names changed quite a bit.
3091 While I tested this and it looks ok, there may still be corner
3096 While I tested this and it looks ok, there may still be corner
3092 cases I've missed.
3097 cases I've missed.
3093
3098
3094 2003-12-01 Fernando Perez <fperez@colorado.edu>
3099 2003-12-01 Fernando Perez <fperez@colorado.edu>
3095
3100
3096 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
3101 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
3097 where a line like 'p,q=1,2' would fail because the automagic
3102 where a line like 'p,q=1,2' would fail because the automagic
3098 system would be triggered for @p.
3103 system would be triggered for @p.
3099
3104
3100 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
3105 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
3101 cleanups, code unmodified.
3106 cleanups, code unmodified.
3102
3107
3103 * IPython/genutils.py (Term): added a class for IPython to handle
3108 * IPython/genutils.py (Term): added a class for IPython to handle
3104 output. In most cases it will just be a proxy for stdout/err, but
3109 output. In most cases it will just be a proxy for stdout/err, but
3105 having this allows modifications to be made for some platforms,
3110 having this allows modifications to be made for some platforms,
3106 such as handling color escapes under Windows. All of this code
3111 such as handling color escapes under Windows. All of this code
3107 was contributed by Gary Bishop, with minor modifications by me.
3112 was contributed by Gary Bishop, with minor modifications by me.
3108 The actual changes affect many files.
3113 The actual changes affect many files.
3109
3114
3110 2003-11-30 Fernando Perez <fperez@colorado.edu>
3115 2003-11-30 Fernando Perez <fperez@colorado.edu>
3111
3116
3112 * IPython/iplib.py (file_matches): new completion code, courtesy
3117 * IPython/iplib.py (file_matches): new completion code, courtesy
3113 of Jeff Collins. This enables filename completion again under
3118 of Jeff Collins. This enables filename completion again under
3114 python 2.3, which disabled it at the C level.
3119 python 2.3, which disabled it at the C level.
3115
3120
3116 2003-11-11 Fernando Perez <fperez@colorado.edu>
3121 2003-11-11 Fernando Perez <fperez@colorado.edu>
3117
3122
3118 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
3123 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
3119 for Numeric.array(map(...)), but often convenient.
3124 for Numeric.array(map(...)), but often convenient.
3120
3125
3121 2003-11-05 Fernando Perez <fperez@colorado.edu>
3126 2003-11-05 Fernando Perez <fperez@colorado.edu>
3122
3127
3123 * IPython/numutils.py (frange): Changed a call from int() to
3128 * IPython/numutils.py (frange): Changed a call from int() to
3124 int(round()) to prevent a problem reported with arange() in the
3129 int(round()) to prevent a problem reported with arange() in the
3125 numpy list.
3130 numpy list.
3126
3131
3127 2003-10-06 Fernando Perez <fperez@colorado.edu>
3132 2003-10-06 Fernando Perez <fperez@colorado.edu>
3128
3133
3129 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
3134 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
3130 prevent crashes if sys lacks an argv attribute (it happens with
3135 prevent crashes if sys lacks an argv attribute (it happens with
3131 embedded interpreters which build a bare-bones sys module).
3136 embedded interpreters which build a bare-bones sys module).
3132 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
3137 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
3133
3138
3134 2003-09-24 Fernando Perez <fperez@colorado.edu>
3139 2003-09-24 Fernando Perez <fperez@colorado.edu>
3135
3140
3136 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
3141 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
3137 to protect against poorly written user objects where __getattr__
3142 to protect against poorly written user objects where __getattr__
3138 raises exceptions other than AttributeError. Thanks to a bug
3143 raises exceptions other than AttributeError. Thanks to a bug
3139 report by Oliver Sander <osander-AT-gmx.de>.
3144 report by Oliver Sander <osander-AT-gmx.de>.
3140
3145
3141 * IPython/FakeModule.py (FakeModule.__repr__): this method was
3146 * IPython/FakeModule.py (FakeModule.__repr__): this method was
3142 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
3147 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
3143
3148
3144 2003-09-09 Fernando Perez <fperez@colorado.edu>
3149 2003-09-09 Fernando Perez <fperez@colorado.edu>
3145
3150
3146 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3151 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3147 unpacking a list whith a callable as first element would
3152 unpacking a list whith a callable as first element would
3148 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
3153 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
3149 Collins.
3154 Collins.
3150
3155
3151 2003-08-25 *** Released version 0.5.0
3156 2003-08-25 *** Released version 0.5.0
3152
3157
3153 2003-08-22 Fernando Perez <fperez@colorado.edu>
3158 2003-08-22 Fernando Perez <fperez@colorado.edu>
3154
3159
3155 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
3160 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
3156 improperly defined user exceptions. Thanks to feedback from Mark
3161 improperly defined user exceptions. Thanks to feedback from Mark
3157 Russell <mrussell-AT-verio.net>.
3162 Russell <mrussell-AT-verio.net>.
3158
3163
3159 2003-08-20 Fernando Perez <fperez@colorado.edu>
3164 2003-08-20 Fernando Perez <fperez@colorado.edu>
3160
3165
3161 * IPython/OInspect.py (Inspector.pinfo): changed String Form
3166 * IPython/OInspect.py (Inspector.pinfo): changed String Form
3162 printing so that it would print multi-line string forms starting
3167 printing so that it would print multi-line string forms starting
3163 with a new line. This way the formatting is better respected for
3168 with a new line. This way the formatting is better respected for
3164 objects which work hard to make nice string forms.
3169 objects which work hard to make nice string forms.
3165
3170
3166 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
3171 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
3167 autocall would overtake data access for objects with both
3172 autocall would overtake data access for objects with both
3168 __getitem__ and __call__.
3173 __getitem__ and __call__.
3169
3174
3170 2003-08-19 *** Released version 0.5.0-rc1
3175 2003-08-19 *** Released version 0.5.0-rc1
3171
3176
3172 2003-08-19 Fernando Perez <fperez@colorado.edu>
3177 2003-08-19 Fernando Perez <fperez@colorado.edu>
3173
3178
3174 * IPython/deep_reload.py (load_tail): single tiny change here
3179 * IPython/deep_reload.py (load_tail): single tiny change here
3175 seems to fix the long-standing bug of dreload() failing to work
3180 seems to fix the long-standing bug of dreload() failing to work
3176 for dotted names. But this module is pretty tricky, so I may have
3181 for dotted names. But this module is pretty tricky, so I may have
3177 missed some subtlety. Needs more testing!.
3182 missed some subtlety. Needs more testing!.
3178
3183
3179 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
3184 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
3180 exceptions which have badly implemented __str__ methods.
3185 exceptions which have badly implemented __str__ methods.
3181 (VerboseTB.text): harden against inspect.getinnerframes crashing,
3186 (VerboseTB.text): harden against inspect.getinnerframes crashing,
3182 which I've been getting reports about from Python 2.3 users. I
3187 which I've been getting reports about from Python 2.3 users. I
3183 wish I had a simple test case to reproduce the problem, so I could
3188 wish I had a simple test case to reproduce the problem, so I could
3184 either write a cleaner workaround or file a bug report if
3189 either write a cleaner workaround or file a bug report if
3185 necessary.
3190 necessary.
3186
3191
3187 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
3192 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
3188 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
3193 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
3189 a bug report by Tjabo Kloppenburg.
3194 a bug report by Tjabo Kloppenburg.
3190
3195
3191 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
3196 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
3192 crashes. Wrapped the pdb call in a blanket try/except, since pdb
3197 crashes. Wrapped the pdb call in a blanket try/except, since pdb
3193 seems rather unstable. Thanks to a bug report by Tjabo
3198 seems rather unstable. Thanks to a bug report by Tjabo
3194 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
3199 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
3195
3200
3196 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
3201 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
3197 this out soon because of the critical fixes in the inner loop for
3202 this out soon because of the critical fixes in the inner loop for
3198 generators.
3203 generators.
3199
3204
3200 * IPython/Magic.py (Magic.getargspec): removed. This (and
3205 * IPython/Magic.py (Magic.getargspec): removed. This (and
3201 _get_def) have been obsoleted by OInspect for a long time, I
3206 _get_def) have been obsoleted by OInspect for a long time, I
3202 hadn't noticed that they were dead code.
3207 hadn't noticed that they were dead code.
3203 (Magic._ofind): restored _ofind functionality for a few literals
3208 (Magic._ofind): restored _ofind functionality for a few literals
3204 (those in ["''",'""','[]','{}','()']). But it won't work anymore
3209 (those in ["''",'""','[]','{}','()']). But it won't work anymore
3205 for things like "hello".capitalize?, since that would require a
3210 for things like "hello".capitalize?, since that would require a
3206 potentially dangerous eval() again.
3211 potentially dangerous eval() again.
3207
3212
3208 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
3213 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
3209 logic a bit more to clean up the escapes handling and minimize the
3214 logic a bit more to clean up the escapes handling and minimize the
3210 use of _ofind to only necessary cases. The interactive 'feel' of
3215 use of _ofind to only necessary cases. The interactive 'feel' of
3211 IPython should have improved quite a bit with the changes in
3216 IPython should have improved quite a bit with the changes in
3212 _prefilter and _ofind (besides being far safer than before).
3217 _prefilter and _ofind (besides being far safer than before).
3213
3218
3214 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
3219 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
3215 obscure, never reported). Edit would fail to find the object to
3220 obscure, never reported). Edit would fail to find the object to
3216 edit under some circumstances.
3221 edit under some circumstances.
3217 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
3222 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
3218 which were causing double-calling of generators. Those eval calls
3223 which were causing double-calling of generators. Those eval calls
3219 were _very_ dangerous, since code with side effects could be
3224 were _very_ dangerous, since code with side effects could be
3220 triggered. As they say, 'eval is evil'... These were the
3225 triggered. As they say, 'eval is evil'... These were the
3221 nastiest evals in IPython. Besides, _ofind is now far simpler,
3226 nastiest evals in IPython. Besides, _ofind is now far simpler,
3222 and it should also be quite a bit faster. Its use of inspect is
3227 and it should also be quite a bit faster. Its use of inspect is
3223 also safer, so perhaps some of the inspect-related crashes I've
3228 also safer, so perhaps some of the inspect-related crashes I've
3224 seen lately with Python 2.3 might be taken care of. That will
3229 seen lately with Python 2.3 might be taken care of. That will
3225 need more testing.
3230 need more testing.
3226
3231
3227 2003-08-17 Fernando Perez <fperez@colorado.edu>
3232 2003-08-17 Fernando Perez <fperez@colorado.edu>
3228
3233
3229 * IPython/iplib.py (InteractiveShell._prefilter): significant
3234 * IPython/iplib.py (InteractiveShell._prefilter): significant
3230 simplifications to the logic for handling user escapes. Faster
3235 simplifications to the logic for handling user escapes. Faster
3231 and simpler code.
3236 and simpler code.
3232
3237
3233 2003-08-14 Fernando Perez <fperez@colorado.edu>
3238 2003-08-14 Fernando Perez <fperez@colorado.edu>
3234
3239
3235 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
3240 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
3236 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
3241 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
3237 but it should be quite a bit faster. And the recursive version
3242 but it should be quite a bit faster. And the recursive version
3238 generated O(log N) intermediate storage for all rank>1 arrays,
3243 generated O(log N) intermediate storage for all rank>1 arrays,
3239 even if they were contiguous.
3244 even if they were contiguous.
3240 (l1norm): Added this function.
3245 (l1norm): Added this function.
3241 (norm): Added this function for arbitrary norms (including
3246 (norm): Added this function for arbitrary norms (including
3242 l-infinity). l1 and l2 are still special cases for convenience
3247 l-infinity). l1 and l2 are still special cases for convenience
3243 and speed.
3248 and speed.
3244
3249
3245 2003-08-03 Fernando Perez <fperez@colorado.edu>
3250 2003-08-03 Fernando Perez <fperez@colorado.edu>
3246
3251
3247 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
3252 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
3248 exceptions, which now raise PendingDeprecationWarnings in Python
3253 exceptions, which now raise PendingDeprecationWarnings in Python
3249 2.3. There were some in Magic and some in Gnuplot2.
3254 2.3. There were some in Magic and some in Gnuplot2.
3250
3255
3251 2003-06-30 Fernando Perez <fperez@colorado.edu>
3256 2003-06-30 Fernando Perez <fperez@colorado.edu>
3252
3257
3253 * IPython/genutils.py (page): modified to call curses only for
3258 * IPython/genutils.py (page): modified to call curses only for
3254 terminals where TERM=='xterm'. After problems under many other
3259 terminals where TERM=='xterm'. After problems under many other
3255 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
3260 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
3256
3261
3257 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
3262 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
3258 would be triggered when readline was absent. This was just an old
3263 would be triggered when readline was absent. This was just an old
3259 debugging statement I'd forgotten to take out.
3264 debugging statement I'd forgotten to take out.
3260
3265
3261 2003-06-20 Fernando Perez <fperez@colorado.edu>
3266 2003-06-20 Fernando Perez <fperez@colorado.edu>
3262
3267
3263 * IPython/genutils.py (clock): modified to return only user time
3268 * IPython/genutils.py (clock): modified to return only user time
3264 (not counting system time), after a discussion on scipy. While
3269 (not counting system time), after a discussion on scipy. While
3265 system time may be a useful quantity occasionally, it may much
3270 system time may be a useful quantity occasionally, it may much
3266 more easily be skewed by occasional swapping or other similar
3271 more easily be skewed by occasional swapping or other similar
3267 activity.
3272 activity.
3268
3273
3269 2003-06-05 Fernando Perez <fperez@colorado.edu>
3274 2003-06-05 Fernando Perez <fperez@colorado.edu>
3270
3275
3271 * IPython/numutils.py (identity): new function, for building
3276 * IPython/numutils.py (identity): new function, for building
3272 arbitrary rank Kronecker deltas (mostly backwards compatible with
3277 arbitrary rank Kronecker deltas (mostly backwards compatible with
3273 Numeric.identity)
3278 Numeric.identity)
3274
3279
3275 2003-06-03 Fernando Perez <fperez@colorado.edu>
3280 2003-06-03 Fernando Perez <fperez@colorado.edu>
3276
3281
3277 * IPython/iplib.py (InteractiveShell.handle_magic): protect
3282 * IPython/iplib.py (InteractiveShell.handle_magic): protect
3278 arguments passed to magics with spaces, to allow trailing '\' to
3283 arguments passed to magics with spaces, to allow trailing '\' to
3279 work normally (mainly for Windows users).
3284 work normally (mainly for Windows users).
3280
3285
3281 2003-05-29 Fernando Perez <fperez@colorado.edu>
3286 2003-05-29 Fernando Perez <fperez@colorado.edu>
3282
3287
3283 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
3288 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
3284 instead of pydoc.help. This fixes a bizarre behavior where
3289 instead of pydoc.help. This fixes a bizarre behavior where
3285 printing '%s' % locals() would trigger the help system. Now
3290 printing '%s' % locals() would trigger the help system. Now
3286 ipython behaves like normal python does.
3291 ipython behaves like normal python does.
3287
3292
3288 Note that if one does 'from pydoc import help', the bizarre
3293 Note that if one does 'from pydoc import help', the bizarre
3289 behavior returns, but this will also happen in normal python, so
3294 behavior returns, but this will also happen in normal python, so
3290 it's not an ipython bug anymore (it has to do with how pydoc.help
3295 it's not an ipython bug anymore (it has to do with how pydoc.help
3291 is implemented).
3296 is implemented).
3292
3297
3293 2003-05-22 Fernando Perez <fperez@colorado.edu>
3298 2003-05-22 Fernando Perez <fperez@colorado.edu>
3294
3299
3295 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
3300 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
3296 return [] instead of None when nothing matches, also match to end
3301 return [] instead of None when nothing matches, also match to end
3297 of line. Patch by Gary Bishop.
3302 of line. Patch by Gary Bishop.
3298
3303
3299 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
3304 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
3300 protection as before, for files passed on the command line. This
3305 protection as before, for files passed on the command line. This
3301 prevents the CrashHandler from kicking in if user files call into
3306 prevents the CrashHandler from kicking in if user files call into
3302 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
3307 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
3303 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
3308 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
3304
3309
3305 2003-05-20 *** Released version 0.4.0
3310 2003-05-20 *** Released version 0.4.0
3306
3311
3307 2003-05-20 Fernando Perez <fperez@colorado.edu>
3312 2003-05-20 Fernando Perez <fperez@colorado.edu>
3308
3313
3309 * setup.py: added support for manpages. It's a bit hackish b/c of
3314 * setup.py: added support for manpages. It's a bit hackish b/c of
3310 a bug in the way the bdist_rpm distutils target handles gzipped
3315 a bug in the way the bdist_rpm distutils target handles gzipped
3311 manpages, but it works. After a patch by Jack.
3316 manpages, but it works. After a patch by Jack.
3312
3317
3313 2003-05-19 Fernando Perez <fperez@colorado.edu>
3318 2003-05-19 Fernando Perez <fperez@colorado.edu>
3314
3319
3315 * IPython/numutils.py: added a mockup of the kinds module, since
3320 * IPython/numutils.py: added a mockup of the kinds module, since
3316 it was recently removed from Numeric. This way, numutils will
3321 it was recently removed from Numeric. This way, numutils will
3317 work for all users even if they are missing kinds.
3322 work for all users even if they are missing kinds.
3318
3323
3319 * IPython/Magic.py (Magic._ofind): Harden against an inspect
3324 * IPython/Magic.py (Magic._ofind): Harden against an inspect
3320 failure, which can occur with SWIG-wrapped extensions. After a
3325 failure, which can occur with SWIG-wrapped extensions. After a
3321 crash report from Prabhu.
3326 crash report from Prabhu.
3322
3327
3323 2003-05-16 Fernando Perez <fperez@colorado.edu>
3328 2003-05-16 Fernando Perez <fperez@colorado.edu>
3324
3329
3325 * IPython/iplib.py (InteractiveShell.excepthook): New method to
3330 * IPython/iplib.py (InteractiveShell.excepthook): New method to
3326 protect ipython from user code which may call directly
3331 protect ipython from user code which may call directly
3327 sys.excepthook (this looks like an ipython crash to the user, even
3332 sys.excepthook (this looks like an ipython crash to the user, even
3328 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
3333 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
3329 This is especially important to help users of WxWindows, but may
3334 This is especially important to help users of WxWindows, but may
3330 also be useful in other cases.
3335 also be useful in other cases.
3331
3336
3332 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
3337 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
3333 an optional tb_offset to be specified, and to preserve exception
3338 an optional tb_offset to be specified, and to preserve exception
3334 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
3339 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
3335
3340
3336 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
3341 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
3337
3342
3338 2003-05-15 Fernando Perez <fperez@colorado.edu>
3343 2003-05-15 Fernando Perez <fperez@colorado.edu>
3339
3344
3340 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
3345 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
3341 installing for a new user under Windows.
3346 installing for a new user under Windows.
3342
3347
3343 2003-05-12 Fernando Perez <fperez@colorado.edu>
3348 2003-05-12 Fernando Perez <fperez@colorado.edu>
3344
3349
3345 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
3350 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
3346 handler for Emacs comint-based lines. Currently it doesn't do
3351 handler for Emacs comint-based lines. Currently it doesn't do
3347 much (but importantly, it doesn't update the history cache). In
3352 much (but importantly, it doesn't update the history cache). In
3348 the future it may be expanded if Alex needs more functionality
3353 the future it may be expanded if Alex needs more functionality
3349 there.
3354 there.
3350
3355
3351 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
3356 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
3352 info to crash reports.
3357 info to crash reports.
3353
3358
3354 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
3359 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
3355 just like Python's -c. Also fixed crash with invalid -color
3360 just like Python's -c. Also fixed crash with invalid -color
3356 option value at startup. Thanks to Will French
3361 option value at startup. Thanks to Will French
3357 <wfrench-AT-bestweb.net> for the bug report.
3362 <wfrench-AT-bestweb.net> for the bug report.
3358
3363
3359 2003-05-09 Fernando Perez <fperez@colorado.edu>
3364 2003-05-09 Fernando Perez <fperez@colorado.edu>
3360
3365
3361 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
3366 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
3362 to EvalDict (it's a mapping, after all) and simplified its code
3367 to EvalDict (it's a mapping, after all) and simplified its code
3363 quite a bit, after a nice discussion on c.l.py where Gustavo
3368 quite a bit, after a nice discussion on c.l.py where Gustavo
3364 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
3369 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
3365
3370
3366 2003-04-30 Fernando Perez <fperez@colorado.edu>
3371 2003-04-30 Fernando Perez <fperez@colorado.edu>
3367
3372
3368 * IPython/genutils.py (timings_out): modified it to reduce its
3373 * IPython/genutils.py (timings_out): modified it to reduce its
3369 overhead in the common reps==1 case.
3374 overhead in the common reps==1 case.
3370
3375
3371 2003-04-29 Fernando Perez <fperez@colorado.edu>
3376 2003-04-29 Fernando Perez <fperez@colorado.edu>
3372
3377
3373 * IPython/genutils.py (timings_out): Modified to use the resource
3378 * IPython/genutils.py (timings_out): Modified to use the resource
3374 module, which avoids the wraparound problems of time.clock().
3379 module, which avoids the wraparound problems of time.clock().
3375
3380
3376 2003-04-17 *** Released version 0.2.15pre4
3381 2003-04-17 *** Released version 0.2.15pre4
3377
3382
3378 2003-04-17 Fernando Perez <fperez@colorado.edu>
3383 2003-04-17 Fernando Perez <fperez@colorado.edu>
3379
3384
3380 * setup.py (scriptfiles): Split windows-specific stuff over to a
3385 * setup.py (scriptfiles): Split windows-specific stuff over to a
3381 separate file, in an attempt to have a Windows GUI installer.
3386 separate file, in an attempt to have a Windows GUI installer.
3382 That didn't work, but part of the groundwork is done.
3387 That didn't work, but part of the groundwork is done.
3383
3388
3384 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
3389 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
3385 indent/unindent with 4 spaces. Particularly useful in combination
3390 indent/unindent with 4 spaces. Particularly useful in combination
3386 with the new auto-indent option.
3391 with the new auto-indent option.
3387
3392
3388 2003-04-16 Fernando Perez <fperez@colorado.edu>
3393 2003-04-16 Fernando Perez <fperez@colorado.edu>
3389
3394
3390 * IPython/Magic.py: various replacements of self.rc for
3395 * IPython/Magic.py: various replacements of self.rc for
3391 self.shell.rc. A lot more remains to be done to fully disentangle
3396 self.shell.rc. A lot more remains to be done to fully disentangle
3392 this class from the main Shell class.
3397 this class from the main Shell class.
3393
3398
3394 * IPython/GnuplotRuntime.py: added checks for mouse support so
3399 * IPython/GnuplotRuntime.py: added checks for mouse support so
3395 that we don't try to enable it if the current gnuplot doesn't
3400 that we don't try to enable it if the current gnuplot doesn't
3396 really support it. Also added checks so that we don't try to
3401 really support it. Also added checks so that we don't try to
3397 enable persist under Windows (where Gnuplot doesn't recognize the
3402 enable persist under Windows (where Gnuplot doesn't recognize the
3398 option).
3403 option).
3399
3404
3400 * IPython/iplib.py (InteractiveShell.interact): Added optional
3405 * IPython/iplib.py (InteractiveShell.interact): Added optional
3401 auto-indenting code, after a patch by King C. Shu
3406 auto-indenting code, after a patch by King C. Shu
3402 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
3407 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
3403 get along well with pasting indented code. If I ever figure out
3408 get along well with pasting indented code. If I ever figure out
3404 how to make that part go well, it will become on by default.
3409 how to make that part go well, it will become on by default.
3405
3410
3406 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
3411 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
3407 crash ipython if there was an unmatched '%' in the user's prompt
3412 crash ipython if there was an unmatched '%' in the user's prompt
3408 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
3413 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
3409
3414
3410 * IPython/iplib.py (InteractiveShell.interact): removed the
3415 * IPython/iplib.py (InteractiveShell.interact): removed the
3411 ability to ask the user whether he wants to crash or not at the
3416 ability to ask the user whether he wants to crash or not at the
3412 'last line' exception handler. Calling functions at that point
3417 'last line' exception handler. Calling functions at that point
3413 changes the stack, and the error reports would have incorrect
3418 changes the stack, and the error reports would have incorrect
3414 tracebacks.
3419 tracebacks.
3415
3420
3416 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
3421 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
3417 pass through a peger a pretty-printed form of any object. After a
3422 pass through a peger a pretty-printed form of any object. After a
3418 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
3423 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
3419
3424
3420 2003-04-14 Fernando Perez <fperez@colorado.edu>
3425 2003-04-14 Fernando Perez <fperez@colorado.edu>
3421
3426
3422 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
3427 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
3423 all files in ~ would be modified at first install (instead of
3428 all files in ~ would be modified at first install (instead of
3424 ~/.ipython). This could be potentially disastrous, as the
3429 ~/.ipython). This could be potentially disastrous, as the
3425 modification (make line-endings native) could damage binary files.
3430 modification (make line-endings native) could damage binary files.
3426
3431
3427 2003-04-10 Fernando Perez <fperez@colorado.edu>
3432 2003-04-10 Fernando Perez <fperez@colorado.edu>
3428
3433
3429 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
3434 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
3430 handle only lines which are invalid python. This now means that
3435 handle only lines which are invalid python. This now means that
3431 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
3436 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
3432 for the bug report.
3437 for the bug report.
3433
3438
3434 2003-04-01 Fernando Perez <fperez@colorado.edu>
3439 2003-04-01 Fernando Perez <fperez@colorado.edu>
3435
3440
3436 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
3441 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
3437 where failing to set sys.last_traceback would crash pdb.pm().
3442 where failing to set sys.last_traceback would crash pdb.pm().
3438 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
3443 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
3439 report.
3444 report.
3440
3445
3441 2003-03-25 Fernando Perez <fperez@colorado.edu>
3446 2003-03-25 Fernando Perez <fperez@colorado.edu>
3442
3447
3443 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
3448 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
3444 before printing it (it had a lot of spurious blank lines at the
3449 before printing it (it had a lot of spurious blank lines at the
3445 end).
3450 end).
3446
3451
3447 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
3452 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
3448 output would be sent 21 times! Obviously people don't use this
3453 output would be sent 21 times! Obviously people don't use this
3449 too often, or I would have heard about it.
3454 too often, or I would have heard about it.
3450
3455
3451 2003-03-24 Fernando Perez <fperez@colorado.edu>
3456 2003-03-24 Fernando Perez <fperez@colorado.edu>
3452
3457
3453 * setup.py (scriptfiles): renamed the data_files parameter from
3458 * setup.py (scriptfiles): renamed the data_files parameter from
3454 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
3459 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
3455 for the patch.
3460 for the patch.
3456
3461
3457 2003-03-20 Fernando Perez <fperez@colorado.edu>
3462 2003-03-20 Fernando Perez <fperez@colorado.edu>
3458
3463
3459 * IPython/genutils.py (error): added error() and fatal()
3464 * IPython/genutils.py (error): added error() and fatal()
3460 functions.
3465 functions.
3461
3466
3462 2003-03-18 *** Released version 0.2.15pre3
3467 2003-03-18 *** Released version 0.2.15pre3
3463
3468
3464 2003-03-18 Fernando Perez <fperez@colorado.edu>
3469 2003-03-18 Fernando Perez <fperez@colorado.edu>
3465
3470
3466 * setupext/install_data_ext.py
3471 * setupext/install_data_ext.py
3467 (install_data_ext.initialize_options): Class contributed by Jack
3472 (install_data_ext.initialize_options): Class contributed by Jack
3468 Moffit for fixing the old distutils hack. He is sending this to
3473 Moffit for fixing the old distutils hack. He is sending this to
3469 the distutils folks so in the future we may not need it as a
3474 the distutils folks so in the future we may not need it as a
3470 private fix.
3475 private fix.
3471
3476
3472 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
3477 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
3473 changes for Debian packaging. See his patch for full details.
3478 changes for Debian packaging. See his patch for full details.
3474 The old distutils hack of making the ipythonrc* files carry a
3479 The old distutils hack of making the ipythonrc* files carry a
3475 bogus .py extension is gone, at last. Examples were moved to a
3480 bogus .py extension is gone, at last. Examples were moved to a
3476 separate subdir under doc/, and the separate executable scripts
3481 separate subdir under doc/, and the separate executable scripts
3477 now live in their own directory. Overall a great cleanup. The
3482 now live in their own directory. Overall a great cleanup. The
3478 manual was updated to use the new files, and setup.py has been
3483 manual was updated to use the new files, and setup.py has been
3479 fixed for this setup.
3484 fixed for this setup.
3480
3485
3481 * IPython/PyColorize.py (Parser.usage): made non-executable and
3486 * IPython/PyColorize.py (Parser.usage): made non-executable and
3482 created a pycolor wrapper around it to be included as a script.
3487 created a pycolor wrapper around it to be included as a script.
3483
3488
3484 2003-03-12 *** Released version 0.2.15pre2
3489 2003-03-12 *** Released version 0.2.15pre2
3485
3490
3486 2003-03-12 Fernando Perez <fperez@colorado.edu>
3491 2003-03-12 Fernando Perez <fperez@colorado.edu>
3487
3492
3488 * IPython/ColorANSI.py (make_color_table): Finally fixed the
3493 * IPython/ColorANSI.py (make_color_table): Finally fixed the
3489 long-standing problem with garbage characters in some terminals.
3494 long-standing problem with garbage characters in some terminals.
3490 The issue was really that the \001 and \002 escapes must _only_ be
3495 The issue was really that the \001 and \002 escapes must _only_ be
3491 passed to input prompts (which call readline), but _never_ to
3496 passed to input prompts (which call readline), but _never_ to
3492 normal text to be printed on screen. I changed ColorANSI to have
3497 normal text to be printed on screen. I changed ColorANSI to have
3493 two classes: TermColors and InputTermColors, each with the
3498 two classes: TermColors and InputTermColors, each with the
3494 appropriate escapes for input prompts or normal text. The code in
3499 appropriate escapes for input prompts or normal text. The code in
3495 Prompts.py got slightly more complicated, but this very old and
3500 Prompts.py got slightly more complicated, but this very old and
3496 annoying bug is finally fixed.
3501 annoying bug is finally fixed.
3497
3502
3498 All the credit for nailing down the real origin of this problem
3503 All the credit for nailing down the real origin of this problem
3499 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
3504 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
3500 *Many* thanks to him for spending quite a bit of effort on this.
3505 *Many* thanks to him for spending quite a bit of effort on this.
3501
3506
3502 2003-03-05 *** Released version 0.2.15pre1
3507 2003-03-05 *** Released version 0.2.15pre1
3503
3508
3504 2003-03-03 Fernando Perez <fperez@colorado.edu>
3509 2003-03-03 Fernando Perez <fperez@colorado.edu>
3505
3510
3506 * IPython/FakeModule.py: Moved the former _FakeModule to a
3511 * IPython/FakeModule.py: Moved the former _FakeModule to a
3507 separate file, because it's also needed by Magic (to fix a similar
3512 separate file, because it's also needed by Magic (to fix a similar
3508 pickle-related issue in @run).
3513 pickle-related issue in @run).
3509
3514
3510 2003-03-02 Fernando Perez <fperez@colorado.edu>
3515 2003-03-02 Fernando Perez <fperez@colorado.edu>
3511
3516
3512 * IPython/Magic.py (Magic.magic_autocall): new magic to control
3517 * IPython/Magic.py (Magic.magic_autocall): new magic to control
3513 the autocall option at runtime.
3518 the autocall option at runtime.
3514 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
3519 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
3515 across Magic.py to start separating Magic from InteractiveShell.
3520 across Magic.py to start separating Magic from InteractiveShell.
3516 (Magic._ofind): Fixed to return proper namespace for dotted
3521 (Magic._ofind): Fixed to return proper namespace for dotted
3517 names. Before, a dotted name would always return 'not currently
3522 names. Before, a dotted name would always return 'not currently
3518 defined', because it would find the 'parent'. s.x would be found,
3523 defined', because it would find the 'parent'. s.x would be found,
3519 but since 'x' isn't defined by itself, it would get confused.
3524 but since 'x' isn't defined by itself, it would get confused.
3520 (Magic.magic_run): Fixed pickling problems reported by Ralf
3525 (Magic.magic_run): Fixed pickling problems reported by Ralf
3521 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
3526 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
3522 that I'd used when Mike Heeter reported similar issues at the
3527 that I'd used when Mike Heeter reported similar issues at the
3523 top-level, but now for @run. It boils down to injecting the
3528 top-level, but now for @run. It boils down to injecting the
3524 namespace where code is being executed with something that looks
3529 namespace where code is being executed with something that looks
3525 enough like a module to fool pickle.dump(). Since a pickle stores
3530 enough like a module to fool pickle.dump(). Since a pickle stores
3526 a named reference to the importing module, we need this for
3531 a named reference to the importing module, we need this for
3527 pickles to save something sensible.
3532 pickles to save something sensible.
3528
3533
3529 * IPython/ipmaker.py (make_IPython): added an autocall option.
3534 * IPython/ipmaker.py (make_IPython): added an autocall option.
3530
3535
3531 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
3536 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
3532 the auto-eval code. Now autocalling is an option, and the code is
3537 the auto-eval code. Now autocalling is an option, and the code is
3533 also vastly safer. There is no more eval() involved at all.
3538 also vastly safer. There is no more eval() involved at all.
3534
3539
3535 2003-03-01 Fernando Perez <fperez@colorado.edu>
3540 2003-03-01 Fernando Perez <fperez@colorado.edu>
3536
3541
3537 * IPython/Magic.py (Magic._ofind): Changed interface to return a
3542 * IPython/Magic.py (Magic._ofind): Changed interface to return a
3538 dict with named keys instead of a tuple.
3543 dict with named keys instead of a tuple.
3539
3544
3540 * IPython: Started using CVS for IPython as of 0.2.15pre1.
3545 * IPython: Started using CVS for IPython as of 0.2.15pre1.
3541
3546
3542 * setup.py (make_shortcut): Fixed message about directories
3547 * setup.py (make_shortcut): Fixed message about directories
3543 created during Windows installation (the directories were ok, just
3548 created during Windows installation (the directories were ok, just
3544 the printed message was misleading). Thanks to Chris Liechti
3549 the printed message was misleading). Thanks to Chris Liechti
3545 <cliechti-AT-gmx.net> for the heads up.
3550 <cliechti-AT-gmx.net> for the heads up.
3546
3551
3547 2003-02-21 Fernando Perez <fperez@colorado.edu>
3552 2003-02-21 Fernando Perez <fperez@colorado.edu>
3548
3553
3549 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
3554 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
3550 of ValueError exception when checking for auto-execution. This
3555 of ValueError exception when checking for auto-execution. This
3551 one is raised by things like Numeric arrays arr.flat when the
3556 one is raised by things like Numeric arrays arr.flat when the
3552 array is non-contiguous.
3557 array is non-contiguous.
3553
3558
3554 2003-01-31 Fernando Perez <fperez@colorado.edu>
3559 2003-01-31 Fernando Perez <fperez@colorado.edu>
3555
3560
3556 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
3561 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
3557 not return any value at all (even though the command would get
3562 not return any value at all (even though the command would get
3558 executed).
3563 executed).
3559 (xsys): Flush stdout right after printing the command to ensure
3564 (xsys): Flush stdout right after printing the command to ensure
3560 proper ordering of commands and command output in the total
3565 proper ordering of commands and command output in the total
3561 output.
3566 output.
3562 (SystemExec/xsys/bq): Switched the names of xsys/bq and
3567 (SystemExec/xsys/bq): Switched the names of xsys/bq and
3563 system/getoutput as defaults. The old ones are kept for
3568 system/getoutput as defaults. The old ones are kept for
3564 compatibility reasons, so no code which uses this library needs
3569 compatibility reasons, so no code which uses this library needs
3565 changing.
3570 changing.
3566
3571
3567 2003-01-27 *** Released version 0.2.14
3572 2003-01-27 *** Released version 0.2.14
3568
3573
3569 2003-01-25 Fernando Perez <fperez@colorado.edu>
3574 2003-01-25 Fernando Perez <fperez@colorado.edu>
3570
3575
3571 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
3576 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
3572 functions defined in previous edit sessions could not be re-edited
3577 functions defined in previous edit sessions could not be re-edited
3573 (because the temp files were immediately removed). Now temp files
3578 (because the temp files were immediately removed). Now temp files
3574 are removed only at IPython's exit.
3579 are removed only at IPython's exit.
3575 (Magic.magic_run): Improved @run to perform shell-like expansions
3580 (Magic.magic_run): Improved @run to perform shell-like expansions
3576 on its arguments (~users and $VARS). With this, @run becomes more
3581 on its arguments (~users and $VARS). With this, @run becomes more
3577 like a normal command-line.
3582 like a normal command-line.
3578
3583
3579 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
3584 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
3580 bugs related to embedding and cleaned up that code. A fairly
3585 bugs related to embedding and cleaned up that code. A fairly
3581 important one was the impossibility to access the global namespace
3586 important one was the impossibility to access the global namespace
3582 through the embedded IPython (only local variables were visible).
3587 through the embedded IPython (only local variables were visible).
3583
3588
3584 2003-01-14 Fernando Perez <fperez@colorado.edu>
3589 2003-01-14 Fernando Perez <fperez@colorado.edu>
3585
3590
3586 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
3591 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
3587 auto-calling to be a bit more conservative. Now it doesn't get
3592 auto-calling to be a bit more conservative. Now it doesn't get
3588 triggered if any of '!=()<>' are in the rest of the input line, to
3593 triggered if any of '!=()<>' are in the rest of the input line, to
3589 allow comparing callables. Thanks to Alex for the heads up.
3594 allow comparing callables. Thanks to Alex for the heads up.
3590
3595
3591 2003-01-07 Fernando Perez <fperez@colorado.edu>
3596 2003-01-07 Fernando Perez <fperez@colorado.edu>
3592
3597
3593 * IPython/genutils.py (page): fixed estimation of the number of
3598 * IPython/genutils.py (page): fixed estimation of the number of
3594 lines in a string to be paged to simply count newlines. This
3599 lines in a string to be paged to simply count newlines. This
3595 prevents over-guessing due to embedded escape sequences. A better
3600 prevents over-guessing due to embedded escape sequences. A better
3596 long-term solution would involve stripping out the control chars
3601 long-term solution would involve stripping out the control chars
3597 for the count, but it's potentially so expensive I just don't
3602 for the count, but it's potentially so expensive I just don't
3598 think it's worth doing.
3603 think it's worth doing.
3599
3604
3600 2002-12-19 *** Released version 0.2.14pre50
3605 2002-12-19 *** Released version 0.2.14pre50
3601
3606
3602 2002-12-19 Fernando Perez <fperez@colorado.edu>
3607 2002-12-19 Fernando Perez <fperez@colorado.edu>
3603
3608
3604 * tools/release (version): Changed release scripts to inform
3609 * tools/release (version): Changed release scripts to inform
3605 Andrea and build a NEWS file with a list of recent changes.
3610 Andrea and build a NEWS file with a list of recent changes.
3606
3611
3607 * IPython/ColorANSI.py (__all__): changed terminal detection
3612 * IPython/ColorANSI.py (__all__): changed terminal detection
3608 code. Seems to work better for xterms without breaking
3613 code. Seems to work better for xterms without breaking
3609 konsole. Will need more testing to determine if WinXP and Mac OSX
3614 konsole. Will need more testing to determine if WinXP and Mac OSX
3610 also work ok.
3615 also work ok.
3611
3616
3612 2002-12-18 *** Released version 0.2.14pre49
3617 2002-12-18 *** Released version 0.2.14pre49
3613
3618
3614 2002-12-18 Fernando Perez <fperez@colorado.edu>
3619 2002-12-18 Fernando Perez <fperez@colorado.edu>
3615
3620
3616 * Docs: added new info about Mac OSX, from Andrea.
3621 * Docs: added new info about Mac OSX, from Andrea.
3617
3622
3618 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
3623 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
3619 allow direct plotting of python strings whose format is the same
3624 allow direct plotting of python strings whose format is the same
3620 of gnuplot data files.
3625 of gnuplot data files.
3621
3626
3622 2002-12-16 Fernando Perez <fperez@colorado.edu>
3627 2002-12-16 Fernando Perez <fperez@colorado.edu>
3623
3628
3624 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
3629 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
3625 value of exit question to be acknowledged.
3630 value of exit question to be acknowledged.
3626
3631
3627 2002-12-03 Fernando Perez <fperez@colorado.edu>
3632 2002-12-03 Fernando Perez <fperez@colorado.edu>
3628
3633
3629 * IPython/ipmaker.py: removed generators, which had been added
3634 * IPython/ipmaker.py: removed generators, which had been added
3630 by mistake in an earlier debugging run. This was causing trouble
3635 by mistake in an earlier debugging run. This was causing trouble
3631 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
3636 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
3632 for pointing this out.
3637 for pointing this out.
3633
3638
3634 2002-11-17 Fernando Perez <fperez@colorado.edu>
3639 2002-11-17 Fernando Perez <fperez@colorado.edu>
3635
3640
3636 * Manual: updated the Gnuplot section.
3641 * Manual: updated the Gnuplot section.
3637
3642
3638 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
3643 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
3639 a much better split of what goes in Runtime and what goes in
3644 a much better split of what goes in Runtime and what goes in
3640 Interactive.
3645 Interactive.
3641
3646
3642 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
3647 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
3643 being imported from iplib.
3648 being imported from iplib.
3644
3649
3645 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
3650 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
3646 for command-passing. Now the global Gnuplot instance is called
3651 for command-passing. Now the global Gnuplot instance is called
3647 'gp' instead of 'g', which was really a far too fragile and
3652 'gp' instead of 'g', which was really a far too fragile and
3648 common name.
3653 common name.
3649
3654
3650 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
3655 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
3651 bounding boxes generated by Gnuplot for square plots.
3656 bounding boxes generated by Gnuplot for square plots.
3652
3657
3653 * IPython/genutils.py (popkey): new function added. I should
3658 * IPython/genutils.py (popkey): new function added. I should
3654 suggest this on c.l.py as a dict method, it seems useful.
3659 suggest this on c.l.py as a dict method, it seems useful.
3655
3660
3656 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
3661 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
3657 to transparently handle PostScript generation. MUCH better than
3662 to transparently handle PostScript generation. MUCH better than
3658 the previous plot_eps/replot_eps (which I removed now). The code
3663 the previous plot_eps/replot_eps (which I removed now). The code
3659 is also fairly clean and well documented now (including
3664 is also fairly clean and well documented now (including
3660 docstrings).
3665 docstrings).
3661
3666
3662 2002-11-13 Fernando Perez <fperez@colorado.edu>
3667 2002-11-13 Fernando Perez <fperez@colorado.edu>
3663
3668
3664 * IPython/Magic.py (Magic.magic_edit): fixed docstring
3669 * IPython/Magic.py (Magic.magic_edit): fixed docstring
3665 (inconsistent with options).
3670 (inconsistent with options).
3666
3671
3667 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
3672 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
3668 manually disabled, I don't know why. Fixed it.
3673 manually disabled, I don't know why. Fixed it.
3669 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
3674 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
3670 eps output.
3675 eps output.
3671
3676
3672 2002-11-12 Fernando Perez <fperez@colorado.edu>
3677 2002-11-12 Fernando Perez <fperez@colorado.edu>
3673
3678
3674 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
3679 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
3675 don't propagate up to caller. Fixes crash reported by François
3680 don't propagate up to caller. Fixes crash reported by François
3676 Pinard.
3681 Pinard.
3677
3682
3678 2002-11-09 Fernando Perez <fperez@colorado.edu>
3683 2002-11-09 Fernando Perez <fperez@colorado.edu>
3679
3684
3680 * IPython/ipmaker.py (make_IPython): fixed problem with writing
3685 * IPython/ipmaker.py (make_IPython): fixed problem with writing
3681 history file for new users.
3686 history file for new users.
3682 (make_IPython): fixed bug where initial install would leave the
3687 (make_IPython): fixed bug where initial install would leave the
3683 user running in the .ipython dir.
3688 user running in the .ipython dir.
3684 (make_IPython): fixed bug where config dir .ipython would be
3689 (make_IPython): fixed bug where config dir .ipython would be
3685 created regardless of the given -ipythondir option. Thanks to Cory
3690 created regardless of the given -ipythondir option. Thanks to Cory
3686 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
3691 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
3687
3692
3688 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
3693 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
3689 type confirmations. Will need to use it in all of IPython's code
3694 type confirmations. Will need to use it in all of IPython's code
3690 consistently.
3695 consistently.
3691
3696
3692 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
3697 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
3693 context to print 31 lines instead of the default 5. This will make
3698 context to print 31 lines instead of the default 5. This will make
3694 the crash reports extremely detailed in case the problem is in
3699 the crash reports extremely detailed in case the problem is in
3695 libraries I don't have access to.
3700 libraries I don't have access to.
3696
3701
3697 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
3702 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
3698 line of defense' code to still crash, but giving users fair
3703 line of defense' code to still crash, but giving users fair
3699 warning. I don't want internal errors to go unreported: if there's
3704 warning. I don't want internal errors to go unreported: if there's
3700 an internal problem, IPython should crash and generate a full
3705 an internal problem, IPython should crash and generate a full
3701 report.
3706 report.
3702
3707
3703 2002-11-08 Fernando Perez <fperez@colorado.edu>
3708 2002-11-08 Fernando Perez <fperez@colorado.edu>
3704
3709
3705 * IPython/iplib.py (InteractiveShell.interact): added code to trap
3710 * IPython/iplib.py (InteractiveShell.interact): added code to trap
3706 otherwise uncaught exceptions which can appear if people set
3711 otherwise uncaught exceptions which can appear if people set
3707 sys.stdout to something badly broken. Thanks to a crash report
3712 sys.stdout to something badly broken. Thanks to a crash report
3708 from henni-AT-mail.brainbot.com.
3713 from henni-AT-mail.brainbot.com.
3709
3714
3710 2002-11-04 Fernando Perez <fperez@colorado.edu>
3715 2002-11-04 Fernando Perez <fperez@colorado.edu>
3711
3716
3712 * IPython/iplib.py (InteractiveShell.interact): added
3717 * IPython/iplib.py (InteractiveShell.interact): added
3713 __IPYTHON__active to the builtins. It's a flag which goes on when
3718 __IPYTHON__active to the builtins. It's a flag which goes on when
3714 the interaction starts and goes off again when it stops. This
3719 the interaction starts and goes off again when it stops. This
3715 allows embedding code to detect being inside IPython. Before this
3720 allows embedding code to detect being inside IPython. Before this
3716 was done via __IPYTHON__, but that only shows that an IPython
3721 was done via __IPYTHON__, but that only shows that an IPython
3717 instance has been created.
3722 instance has been created.
3718
3723
3719 * IPython/Magic.py (Magic.magic_env): I realized that in a
3724 * IPython/Magic.py (Magic.magic_env): I realized that in a
3720 UserDict, instance.data holds the data as a normal dict. So I
3725 UserDict, instance.data holds the data as a normal dict. So I
3721 modified @env to return os.environ.data instead of rebuilding a
3726 modified @env to return os.environ.data instead of rebuilding a
3722 dict by hand.
3727 dict by hand.
3723
3728
3724 2002-11-02 Fernando Perez <fperez@colorado.edu>
3729 2002-11-02 Fernando Perez <fperez@colorado.edu>
3725
3730
3726 * IPython/genutils.py (warn): changed so that level 1 prints no
3731 * IPython/genutils.py (warn): changed so that level 1 prints no
3727 header. Level 2 is now the default (with 'WARNING' header, as
3732 header. Level 2 is now the default (with 'WARNING' header, as
3728 before). I think I tracked all places where changes were needed in
3733 before). I think I tracked all places where changes were needed in
3729 IPython, but outside code using the old level numbering may have
3734 IPython, but outside code using the old level numbering may have
3730 broken.
3735 broken.
3731
3736
3732 * IPython/iplib.py (InteractiveShell.runcode): added this to
3737 * IPython/iplib.py (InteractiveShell.runcode): added this to
3733 handle the tracebacks in SystemExit traps correctly. The previous
3738 handle the tracebacks in SystemExit traps correctly. The previous
3734 code (through interact) was printing more of the stack than
3739 code (through interact) was printing more of the stack than
3735 necessary, showing IPython internal code to the user.
3740 necessary, showing IPython internal code to the user.
3736
3741
3737 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
3742 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
3738 default. Now that the default at the confirmation prompt is yes,
3743 default. Now that the default at the confirmation prompt is yes,
3739 it's not so intrusive. François' argument that ipython sessions
3744 it's not so intrusive. François' argument that ipython sessions
3740 tend to be complex enough not to lose them from an accidental C-d,
3745 tend to be complex enough not to lose them from an accidental C-d,
3741 is a valid one.
3746 is a valid one.
3742
3747
3743 * IPython/iplib.py (InteractiveShell.interact): added a
3748 * IPython/iplib.py (InteractiveShell.interact): added a
3744 showtraceback() call to the SystemExit trap, and modified the exit
3749 showtraceback() call to the SystemExit trap, and modified the exit
3745 confirmation to have yes as the default.
3750 confirmation to have yes as the default.
3746
3751
3747 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
3752 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
3748 this file. It's been gone from the code for a long time, this was
3753 this file. It's been gone from the code for a long time, this was
3749 simply leftover junk.
3754 simply leftover junk.
3750
3755
3751 2002-11-01 Fernando Perez <fperez@colorado.edu>
3756 2002-11-01 Fernando Perez <fperez@colorado.edu>
3752
3757
3753 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
3758 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
3754 added. If set, IPython now traps EOF and asks for
3759 added. If set, IPython now traps EOF and asks for
3755 confirmation. After a request by François Pinard.
3760 confirmation. After a request by François Pinard.
3756
3761
3757 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
3762 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
3758 of @abort, and with a new (better) mechanism for handling the
3763 of @abort, and with a new (better) mechanism for handling the
3759 exceptions.
3764 exceptions.
3760
3765
3761 2002-10-27 Fernando Perez <fperez@colorado.edu>
3766 2002-10-27 Fernando Perez <fperez@colorado.edu>
3762
3767
3763 * IPython/usage.py (__doc__): updated the --help information and
3768 * IPython/usage.py (__doc__): updated the --help information and
3764 the ipythonrc file to indicate that -log generates
3769 the ipythonrc file to indicate that -log generates
3765 ./ipython.log. Also fixed the corresponding info in @logstart.
3770 ./ipython.log. Also fixed the corresponding info in @logstart.
3766 This and several other fixes in the manuals thanks to reports by
3771 This and several other fixes in the manuals thanks to reports by
3767 François Pinard <pinard-AT-iro.umontreal.ca>.
3772 François Pinard <pinard-AT-iro.umontreal.ca>.
3768
3773
3769 * IPython/Logger.py (Logger.switch_log): Fixed error message to
3774 * IPython/Logger.py (Logger.switch_log): Fixed error message to
3770 refer to @logstart (instead of @log, which doesn't exist).
3775 refer to @logstart (instead of @log, which doesn't exist).
3771
3776
3772 * IPython/iplib.py (InteractiveShell._prefilter): fixed
3777 * IPython/iplib.py (InteractiveShell._prefilter): fixed
3773 AttributeError crash. Thanks to Christopher Armstrong
3778 AttributeError crash. Thanks to Christopher Armstrong
3774 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
3779 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
3775 introduced recently (in 0.2.14pre37) with the fix to the eval
3780 introduced recently (in 0.2.14pre37) with the fix to the eval
3776 problem mentioned below.
3781 problem mentioned below.
3777
3782
3778 2002-10-17 Fernando Perez <fperez@colorado.edu>
3783 2002-10-17 Fernando Perez <fperez@colorado.edu>
3779
3784
3780 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
3785 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
3781 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
3786 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
3782
3787
3783 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
3788 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
3784 this function to fix a problem reported by Alex Schmolck. He saw
3789 this function to fix a problem reported by Alex Schmolck. He saw
3785 it with list comprehensions and generators, which were getting
3790 it with list comprehensions and generators, which were getting
3786 called twice. The real problem was an 'eval' call in testing for
3791 called twice. The real problem was an 'eval' call in testing for
3787 automagic which was evaluating the input line silently.
3792 automagic which was evaluating the input line silently.
3788
3793
3789 This is a potentially very nasty bug, if the input has side
3794 This is a potentially very nasty bug, if the input has side
3790 effects which must not be repeated. The code is much cleaner now,
3795 effects which must not be repeated. The code is much cleaner now,
3791 without any blanket 'except' left and with a regexp test for
3796 without any blanket 'except' left and with a regexp test for
3792 actual function names.
3797 actual function names.
3793
3798
3794 But an eval remains, which I'm not fully comfortable with. I just
3799 But an eval remains, which I'm not fully comfortable with. I just
3795 don't know how to find out if an expression could be a callable in
3800 don't know how to find out if an expression could be a callable in
3796 the user's namespace without doing an eval on the string. However
3801 the user's namespace without doing an eval on the string. However
3797 that string is now much more strictly checked so that no code
3802 that string is now much more strictly checked so that no code
3798 slips by, so the eval should only happen for things that can
3803 slips by, so the eval should only happen for things that can
3799 really be only function/method names.
3804 really be only function/method names.
3800
3805
3801 2002-10-15 Fernando Perez <fperez@colorado.edu>
3806 2002-10-15 Fernando Perez <fperez@colorado.edu>
3802
3807
3803 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
3808 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
3804 OSX information to main manual, removed README_Mac_OSX file from
3809 OSX information to main manual, removed README_Mac_OSX file from
3805 distribution. Also updated credits for recent additions.
3810 distribution. Also updated credits for recent additions.
3806
3811
3807 2002-10-10 Fernando Perez <fperez@colorado.edu>
3812 2002-10-10 Fernando Perez <fperez@colorado.edu>
3808
3813
3809 * README_Mac_OSX: Added a README for Mac OSX users for fixing
3814 * README_Mac_OSX: Added a README for Mac OSX users for fixing
3810 terminal-related issues. Many thanks to Andrea Riciputi
3815 terminal-related issues. Many thanks to Andrea Riciputi
3811 <andrea.riciputi-AT-libero.it> for writing it.
3816 <andrea.riciputi-AT-libero.it> for writing it.
3812
3817
3813 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
3818 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
3814 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
3819 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
3815
3820
3816 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
3821 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
3817 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
3822 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
3818 <syver-en-AT-online.no> who both submitted patches for this problem.
3823 <syver-en-AT-online.no> who both submitted patches for this problem.
3819
3824
3820 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
3825 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
3821 global embedding to make sure that things don't overwrite user
3826 global embedding to make sure that things don't overwrite user
3822 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
3827 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
3823
3828
3824 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
3829 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
3825 compatibility. Thanks to Hayden Callow
3830 compatibility. Thanks to Hayden Callow
3826 <h.callow-AT-elec.canterbury.ac.nz>
3831 <h.callow-AT-elec.canterbury.ac.nz>
3827
3832
3828 2002-10-04 Fernando Perez <fperez@colorado.edu>
3833 2002-10-04 Fernando Perez <fperez@colorado.edu>
3829
3834
3830 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
3835 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
3831 Gnuplot.File objects.
3836 Gnuplot.File objects.
3832
3837
3833 2002-07-23 Fernando Perez <fperez@colorado.edu>
3838 2002-07-23 Fernando Perez <fperez@colorado.edu>
3834
3839
3835 * IPython/genutils.py (timing): Added timings() and timing() for
3840 * IPython/genutils.py (timing): Added timings() and timing() for
3836 quick access to the most commonly needed data, the execution
3841 quick access to the most commonly needed data, the execution
3837 times. Old timing() renamed to timings_out().
3842 times. Old timing() renamed to timings_out().
3838
3843
3839 2002-07-18 Fernando Perez <fperez@colorado.edu>
3844 2002-07-18 Fernando Perez <fperez@colorado.edu>
3840
3845
3841 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
3846 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
3842 bug with nested instances disrupting the parent's tab completion.
3847 bug with nested instances disrupting the parent's tab completion.
3843
3848
3844 * IPython/iplib.py (all_completions): Added Alex Schmolck's
3849 * IPython/iplib.py (all_completions): Added Alex Schmolck's
3845 all_completions code to begin the emacs integration.
3850 all_completions code to begin the emacs integration.
3846
3851
3847 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
3852 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
3848 argument to allow titling individual arrays when plotting.
3853 argument to allow titling individual arrays when plotting.
3849
3854
3850 2002-07-15 Fernando Perez <fperez@colorado.edu>
3855 2002-07-15 Fernando Perez <fperez@colorado.edu>
3851
3856
3852 * setup.py (make_shortcut): changed to retrieve the value of
3857 * setup.py (make_shortcut): changed to retrieve the value of
3853 'Program Files' directory from the registry (this value changes in
3858 'Program Files' directory from the registry (this value changes in
3854 non-english versions of Windows). Thanks to Thomas Fanslau
3859 non-english versions of Windows). Thanks to Thomas Fanslau
3855 <tfanslau-AT-gmx.de> for the report.
3860 <tfanslau-AT-gmx.de> for the report.
3856
3861
3857 2002-07-10 Fernando Perez <fperez@colorado.edu>
3862 2002-07-10 Fernando Perez <fperez@colorado.edu>
3858
3863
3859 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
3864 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
3860 a bug in pdb, which crashes if a line with only whitespace is
3865 a bug in pdb, which crashes if a line with only whitespace is
3861 entered. Bug report submitted to sourceforge.
3866 entered. Bug report submitted to sourceforge.
3862
3867
3863 2002-07-09 Fernando Perez <fperez@colorado.edu>
3868 2002-07-09 Fernando Perez <fperez@colorado.edu>
3864
3869
3865 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
3870 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
3866 reporting exceptions (it's a bug in inspect.py, I just set a
3871 reporting exceptions (it's a bug in inspect.py, I just set a
3867 workaround).
3872 workaround).
3868
3873
3869 2002-07-08 Fernando Perez <fperez@colorado.edu>
3874 2002-07-08 Fernando Perez <fperez@colorado.edu>
3870
3875
3871 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
3876 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
3872 __IPYTHON__ in __builtins__ to show up in user_ns.
3877 __IPYTHON__ in __builtins__ to show up in user_ns.
3873
3878
3874 2002-07-03 Fernando Perez <fperez@colorado.edu>
3879 2002-07-03 Fernando Perez <fperez@colorado.edu>
3875
3880
3876 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
3881 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
3877 name from @gp_set_instance to @gp_set_default.
3882 name from @gp_set_instance to @gp_set_default.
3878
3883
3879 * IPython/ipmaker.py (make_IPython): default editor value set to
3884 * IPython/ipmaker.py (make_IPython): default editor value set to
3880 '0' (a string), to match the rc file. Otherwise will crash when
3885 '0' (a string), to match the rc file. Otherwise will crash when
3881 .strip() is called on it.
3886 .strip() is called on it.
3882
3887
3883
3888
3884 2002-06-28 Fernando Perez <fperez@colorado.edu>
3889 2002-06-28 Fernando Perez <fperez@colorado.edu>
3885
3890
3886 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
3891 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
3887 of files in current directory when a file is executed via
3892 of files in current directory when a file is executed via
3888 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
3893 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
3889
3894
3890 * setup.py (manfiles): fix for rpm builds, submitted by RA
3895 * setup.py (manfiles): fix for rpm builds, submitted by RA
3891 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
3896 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
3892
3897
3893 * IPython/ipmaker.py (make_IPython): fixed lookup of default
3898 * IPython/ipmaker.py (make_IPython): fixed lookup of default
3894 editor when set to '0'. Problem was, '0' evaluates to True (it's a
3899 editor when set to '0'. Problem was, '0' evaluates to True (it's a
3895 string!). A. Schmolck caught this one.
3900 string!). A. Schmolck caught this one.
3896
3901
3897 2002-06-27 Fernando Perez <fperez@colorado.edu>
3902 2002-06-27 Fernando Perez <fperez@colorado.edu>
3898
3903
3899 * IPython/ipmaker.py (make_IPython): fixed bug when running user
3904 * IPython/ipmaker.py (make_IPython): fixed bug when running user
3900 defined files at the cmd line. __name__ wasn't being set to
3905 defined files at the cmd line. __name__ wasn't being set to
3901 __main__.
3906 __main__.
3902
3907
3903 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
3908 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
3904 regular lists and tuples besides Numeric arrays.
3909 regular lists and tuples besides Numeric arrays.
3905
3910
3906 * IPython/Prompts.py (CachedOutput.__call__): Added output
3911 * IPython/Prompts.py (CachedOutput.__call__): Added output
3907 supression for input ending with ';'. Similar to Mathematica and
3912 supression for input ending with ';'. Similar to Mathematica and
3908 Matlab. The _* vars and Out[] list are still updated, just like
3913 Matlab. The _* vars and Out[] list are still updated, just like
3909 Mathematica behaves.
3914 Mathematica behaves.
3910
3915
3911 2002-06-25 Fernando Perez <fperez@colorado.edu>
3916 2002-06-25 Fernando Perez <fperez@colorado.edu>
3912
3917
3913 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
3918 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
3914 .ini extensions for profiels under Windows.
3919 .ini extensions for profiels under Windows.
3915
3920
3916 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
3921 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
3917 string form. Fix contributed by Alexander Schmolck
3922 string form. Fix contributed by Alexander Schmolck
3918 <a.schmolck-AT-gmx.net>
3923 <a.schmolck-AT-gmx.net>
3919
3924
3920 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
3925 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
3921 pre-configured Gnuplot instance.
3926 pre-configured Gnuplot instance.
3922
3927
3923 2002-06-21 Fernando Perez <fperez@colorado.edu>
3928 2002-06-21 Fernando Perez <fperez@colorado.edu>
3924
3929
3925 * IPython/numutils.py (exp_safe): new function, works around the
3930 * IPython/numutils.py (exp_safe): new function, works around the
3926 underflow problems in Numeric.
3931 underflow problems in Numeric.
3927 (log2): New fn. Safe log in base 2: returns exact integer answer
3932 (log2): New fn. Safe log in base 2: returns exact integer answer
3928 for exact integer powers of 2.
3933 for exact integer powers of 2.
3929
3934
3930 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
3935 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
3931 properly.
3936 properly.
3932
3937
3933 2002-06-20 Fernando Perez <fperez@colorado.edu>
3938 2002-06-20 Fernando Perez <fperez@colorado.edu>
3934
3939
3935 * IPython/genutils.py (timing): new function like
3940 * IPython/genutils.py (timing): new function like
3936 Mathematica's. Similar to time_test, but returns more info.
3941 Mathematica's. Similar to time_test, but returns more info.
3937
3942
3938 2002-06-18 Fernando Perez <fperez@colorado.edu>
3943 2002-06-18 Fernando Perez <fperez@colorado.edu>
3939
3944
3940 * IPython/Magic.py (Magic.magic_save): modified @save and @r
3945 * IPython/Magic.py (Magic.magic_save): modified @save and @r
3941 according to Mike Heeter's suggestions.
3946 according to Mike Heeter's suggestions.
3942
3947
3943 2002-06-16 Fernando Perez <fperez@colorado.edu>
3948 2002-06-16 Fernando Perez <fperez@colorado.edu>
3944
3949
3945 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
3950 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
3946 system. GnuplotMagic is gone as a user-directory option. New files
3951 system. GnuplotMagic is gone as a user-directory option. New files
3947 make it easier to use all the gnuplot stuff both from external
3952 make it easier to use all the gnuplot stuff both from external
3948 programs as well as from IPython. Had to rewrite part of
3953 programs as well as from IPython. Had to rewrite part of
3949 hardcopy() b/c of a strange bug: often the ps files simply don't
3954 hardcopy() b/c of a strange bug: often the ps files simply don't
3950 get created, and require a repeat of the command (often several
3955 get created, and require a repeat of the command (often several
3951 times).
3956 times).
3952
3957
3953 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
3958 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
3954 resolve output channel at call time, so that if sys.stderr has
3959 resolve output channel at call time, so that if sys.stderr has
3955 been redirected by user this gets honored.
3960 been redirected by user this gets honored.
3956
3961
3957 2002-06-13 Fernando Perez <fperez@colorado.edu>
3962 2002-06-13 Fernando Perez <fperez@colorado.edu>
3958
3963
3959 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
3964 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
3960 IPShell. Kept a copy with the old names to avoid breaking people's
3965 IPShell. Kept a copy with the old names to avoid breaking people's
3961 embedded code.
3966 embedded code.
3962
3967
3963 * IPython/ipython: simplified it to the bare minimum after
3968 * IPython/ipython: simplified it to the bare minimum after
3964 Holger's suggestions. Added info about how to use it in
3969 Holger's suggestions. Added info about how to use it in
3965 PYTHONSTARTUP.
3970 PYTHONSTARTUP.
3966
3971
3967 * IPython/Shell.py (IPythonShell): changed the options passing
3972 * IPython/Shell.py (IPythonShell): changed the options passing
3968 from a string with funky %s replacements to a straight list. Maybe
3973 from a string with funky %s replacements to a straight list. Maybe
3969 a bit more typing, but it follows sys.argv conventions, so there's
3974 a bit more typing, but it follows sys.argv conventions, so there's
3970 less special-casing to remember.
3975 less special-casing to remember.
3971
3976
3972 2002-06-12 Fernando Perez <fperez@colorado.edu>
3977 2002-06-12 Fernando Perez <fperez@colorado.edu>
3973
3978
3974 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
3979 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
3975 command. Thanks to a suggestion by Mike Heeter.
3980 command. Thanks to a suggestion by Mike Heeter.
3976 (Magic.magic_pfile): added behavior to look at filenames if given
3981 (Magic.magic_pfile): added behavior to look at filenames if given
3977 arg is not a defined object.
3982 arg is not a defined object.
3978 (Magic.magic_save): New @save function to save code snippets. Also
3983 (Magic.magic_save): New @save function to save code snippets. Also
3979 a Mike Heeter idea.
3984 a Mike Heeter idea.
3980
3985
3981 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
3986 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
3982 plot() and replot(). Much more convenient now, especially for
3987 plot() and replot(). Much more convenient now, especially for
3983 interactive use.
3988 interactive use.
3984
3989
3985 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
3990 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
3986 filenames.
3991 filenames.
3987
3992
3988 2002-06-02 Fernando Perez <fperez@colorado.edu>
3993 2002-06-02 Fernando Perez <fperez@colorado.edu>
3989
3994
3990 * IPython/Struct.py (Struct.__init__): modified to admit
3995 * IPython/Struct.py (Struct.__init__): modified to admit
3991 initialization via another struct.
3996 initialization via another struct.
3992
3997
3993 * IPython/genutils.py (SystemExec.__init__): New stateful
3998 * IPython/genutils.py (SystemExec.__init__): New stateful
3994 interface to xsys and bq. Useful for writing system scripts.
3999 interface to xsys and bq. Useful for writing system scripts.
3995
4000
3996 2002-05-30 Fernando Perez <fperez@colorado.edu>
4001 2002-05-30 Fernando Perez <fperez@colorado.edu>
3997
4002
3998 * MANIFEST.in: Changed docfile selection to exclude all the lyx
4003 * MANIFEST.in: Changed docfile selection to exclude all the lyx
3999 documents. This will make the user download smaller (it's getting
4004 documents. This will make the user download smaller (it's getting
4000 too big).
4005 too big).
4001
4006
4002 2002-05-29 Fernando Perez <fperez@colorado.edu>
4007 2002-05-29 Fernando Perez <fperez@colorado.edu>
4003
4008
4004 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
4009 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
4005 fix problems with shelve and pickle. Seems to work, but I don't
4010 fix problems with shelve and pickle. Seems to work, but I don't
4006 know if corner cases break it. Thanks to Mike Heeter
4011 know if corner cases break it. Thanks to Mike Heeter
4007 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
4012 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
4008
4013
4009 2002-05-24 Fernando Perez <fperez@colorado.edu>
4014 2002-05-24 Fernando Perez <fperez@colorado.edu>
4010
4015
4011 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
4016 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
4012 macros having broken.
4017 macros having broken.
4013
4018
4014 2002-05-21 Fernando Perez <fperez@colorado.edu>
4019 2002-05-21 Fernando Perez <fperez@colorado.edu>
4015
4020
4016 * IPython/Magic.py (Magic.magic_logstart): fixed recently
4021 * IPython/Magic.py (Magic.magic_logstart): fixed recently
4017 introduced logging bug: all history before logging started was
4022 introduced logging bug: all history before logging started was
4018 being written one character per line! This came from the redesign
4023 being written one character per line! This came from the redesign
4019 of the input history as a special list which slices to strings,
4024 of the input history as a special list which slices to strings,
4020 not to lists.
4025 not to lists.
4021
4026
4022 2002-05-20 Fernando Perez <fperez@colorado.edu>
4027 2002-05-20 Fernando Perez <fperez@colorado.edu>
4023
4028
4024 * IPython/Prompts.py (CachedOutput.__init__): made the color table
4029 * IPython/Prompts.py (CachedOutput.__init__): made the color table
4025 be an attribute of all classes in this module. The design of these
4030 be an attribute of all classes in this module. The design of these
4026 classes needs some serious overhauling.
4031 classes needs some serious overhauling.
4027
4032
4028 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
4033 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
4029 which was ignoring '_' in option names.
4034 which was ignoring '_' in option names.
4030
4035
4031 * IPython/ultraTB.py (FormattedTB.__init__): Changed
4036 * IPython/ultraTB.py (FormattedTB.__init__): Changed
4032 'Verbose_novars' to 'Context' and made it the new default. It's a
4037 'Verbose_novars' to 'Context' and made it the new default. It's a
4033 bit more readable and also safer than verbose.
4038 bit more readable and also safer than verbose.
4034
4039
4035 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
4040 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
4036 triple-quoted strings.
4041 triple-quoted strings.
4037
4042
4038 * IPython/OInspect.py (__all__): new module exposing the object
4043 * IPython/OInspect.py (__all__): new module exposing the object
4039 introspection facilities. Now the corresponding magics are dummy
4044 introspection facilities. Now the corresponding magics are dummy
4040 wrappers around this. Having this module will make it much easier
4045 wrappers around this. Having this module will make it much easier
4041 to put these functions into our modified pdb.
4046 to put these functions into our modified pdb.
4042 This new object inspector system uses the new colorizing module,
4047 This new object inspector system uses the new colorizing module,
4043 so source code and other things are nicely syntax highlighted.
4048 so source code and other things are nicely syntax highlighted.
4044
4049
4045 2002-05-18 Fernando Perez <fperez@colorado.edu>
4050 2002-05-18 Fernando Perez <fperez@colorado.edu>
4046
4051
4047 * IPython/ColorANSI.py: Split the coloring tools into a separate
4052 * IPython/ColorANSI.py: Split the coloring tools into a separate
4048 module so I can use them in other code easier (they were part of
4053 module so I can use them in other code easier (they were part of
4049 ultraTB).
4054 ultraTB).
4050
4055
4051 2002-05-17 Fernando Perez <fperez@colorado.edu>
4056 2002-05-17 Fernando Perez <fperez@colorado.edu>
4052
4057
4053 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
4058 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
4054 fixed it to set the global 'g' also to the called instance, as
4059 fixed it to set the global 'g' also to the called instance, as
4055 long as 'g' was still a gnuplot instance (so it doesn't overwrite
4060 long as 'g' was still a gnuplot instance (so it doesn't overwrite
4056 user's 'g' variables).
4061 user's 'g' variables).
4057
4062
4058 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
4063 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
4059 global variables (aliases to _ih,_oh) so that users which expect
4064 global variables (aliases to _ih,_oh) so that users which expect
4060 In[5] or Out[7] to work aren't unpleasantly surprised.
4065 In[5] or Out[7] to work aren't unpleasantly surprised.
4061 (InputList.__getslice__): new class to allow executing slices of
4066 (InputList.__getslice__): new class to allow executing slices of
4062 input history directly. Very simple class, complements the use of
4067 input history directly. Very simple class, complements the use of
4063 macros.
4068 macros.
4064
4069
4065 2002-05-16 Fernando Perez <fperez@colorado.edu>
4070 2002-05-16 Fernando Perez <fperez@colorado.edu>
4066
4071
4067 * setup.py (docdirbase): make doc directory be just doc/IPython
4072 * setup.py (docdirbase): make doc directory be just doc/IPython
4068 without version numbers, it will reduce clutter for users.
4073 without version numbers, it will reduce clutter for users.
4069
4074
4070 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
4075 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
4071 execfile call to prevent possible memory leak. See for details:
4076 execfile call to prevent possible memory leak. See for details:
4072 http://mail.python.org/pipermail/python-list/2002-February/088476.html
4077 http://mail.python.org/pipermail/python-list/2002-February/088476.html
4073
4078
4074 2002-05-15 Fernando Perez <fperez@colorado.edu>
4079 2002-05-15 Fernando Perez <fperez@colorado.edu>
4075
4080
4076 * IPython/Magic.py (Magic.magic_psource): made the object
4081 * IPython/Magic.py (Magic.magic_psource): made the object
4077 introspection names be more standard: pdoc, pdef, pfile and
4082 introspection names be more standard: pdoc, pdef, pfile and
4078 psource. They all print/page their output, and it makes
4083 psource. They all print/page their output, and it makes
4079 remembering them easier. Kept old names for compatibility as
4084 remembering them easier. Kept old names for compatibility as
4080 aliases.
4085 aliases.
4081
4086
4082 2002-05-14 Fernando Perez <fperez@colorado.edu>
4087 2002-05-14 Fernando Perez <fperez@colorado.edu>
4083
4088
4084 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
4089 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
4085 what the mouse problem was. The trick is to use gnuplot with temp
4090 what the mouse problem was. The trick is to use gnuplot with temp
4086 files and NOT with pipes (for data communication), because having
4091 files and NOT with pipes (for data communication), because having
4087 both pipes and the mouse on is bad news.
4092 both pipes and the mouse on is bad news.
4088
4093
4089 2002-05-13 Fernando Perez <fperez@colorado.edu>
4094 2002-05-13 Fernando Perez <fperez@colorado.edu>
4090
4095
4091 * IPython/Magic.py (Magic._ofind): fixed namespace order search
4096 * IPython/Magic.py (Magic._ofind): fixed namespace order search
4092 bug. Information would be reported about builtins even when
4097 bug. Information would be reported about builtins even when
4093 user-defined functions overrode them.
4098 user-defined functions overrode them.
4094
4099
4095 2002-05-11 Fernando Perez <fperez@colorado.edu>
4100 2002-05-11 Fernando Perez <fperez@colorado.edu>
4096
4101
4097 * IPython/__init__.py (__all__): removed FlexCompleter from
4102 * IPython/__init__.py (__all__): removed FlexCompleter from
4098 __all__ so that things don't fail in platforms without readline.
4103 __all__ so that things don't fail in platforms without readline.
4099
4104
4100 2002-05-10 Fernando Perez <fperez@colorado.edu>
4105 2002-05-10 Fernando Perez <fperez@colorado.edu>
4101
4106
4102 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
4107 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
4103 it requires Numeric, effectively making Numeric a dependency for
4108 it requires Numeric, effectively making Numeric a dependency for
4104 IPython.
4109 IPython.
4105
4110
4106 * Released 0.2.13
4111 * Released 0.2.13
4107
4112
4108 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
4113 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
4109 profiler interface. Now all the major options from the profiler
4114 profiler interface. Now all the major options from the profiler
4110 module are directly supported in IPython, both for single
4115 module are directly supported in IPython, both for single
4111 expressions (@prun) and for full programs (@run -p).
4116 expressions (@prun) and for full programs (@run -p).
4112
4117
4113 2002-05-09 Fernando Perez <fperez@colorado.edu>
4118 2002-05-09 Fernando Perez <fperez@colorado.edu>
4114
4119
4115 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
4120 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
4116 magic properly formatted for screen.
4121 magic properly formatted for screen.
4117
4122
4118 * setup.py (make_shortcut): Changed things to put pdf version in
4123 * setup.py (make_shortcut): Changed things to put pdf version in
4119 doc/ instead of doc/manual (had to change lyxport a bit).
4124 doc/ instead of doc/manual (had to change lyxport a bit).
4120
4125
4121 * IPython/Magic.py (Profile.string_stats): made profile runs go
4126 * IPython/Magic.py (Profile.string_stats): made profile runs go
4122 through pager (they are long and a pager allows searching, saving,
4127 through pager (they are long and a pager allows searching, saving,
4123 etc.)
4128 etc.)
4124
4129
4125 2002-05-08 Fernando Perez <fperez@colorado.edu>
4130 2002-05-08 Fernando Perez <fperez@colorado.edu>
4126
4131
4127 * Released 0.2.12
4132 * Released 0.2.12
4128
4133
4129 2002-05-06 Fernando Perez <fperez@colorado.edu>
4134 2002-05-06 Fernando Perez <fperez@colorado.edu>
4130
4135
4131 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
4136 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
4132 introduced); 'hist n1 n2' was broken.
4137 introduced); 'hist n1 n2' was broken.
4133 (Magic.magic_pdb): added optional on/off arguments to @pdb
4138 (Magic.magic_pdb): added optional on/off arguments to @pdb
4134 (Magic.magic_run): added option -i to @run, which executes code in
4139 (Magic.magic_run): added option -i to @run, which executes code in
4135 the IPython namespace instead of a clean one. Also added @irun as
4140 the IPython namespace instead of a clean one. Also added @irun as
4136 an alias to @run -i.
4141 an alias to @run -i.
4137
4142
4138 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
4143 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
4139 fixed (it didn't really do anything, the namespaces were wrong).
4144 fixed (it didn't really do anything, the namespaces were wrong).
4140
4145
4141 * IPython/Debugger.py (__init__): Added workaround for python 2.1
4146 * IPython/Debugger.py (__init__): Added workaround for python 2.1
4142
4147
4143 * IPython/__init__.py (__all__): Fixed package namespace, now
4148 * IPython/__init__.py (__all__): Fixed package namespace, now
4144 'import IPython' does give access to IPython.<all> as
4149 'import IPython' does give access to IPython.<all> as
4145 expected. Also renamed __release__ to Release.
4150 expected. Also renamed __release__ to Release.
4146
4151
4147 * IPython/Debugger.py (__license__): created new Pdb class which
4152 * IPython/Debugger.py (__license__): created new Pdb class which
4148 functions like a drop-in for the normal pdb.Pdb but does NOT
4153 functions like a drop-in for the normal pdb.Pdb but does NOT
4149 import readline by default. This way it doesn't muck up IPython's
4154 import readline by default. This way it doesn't muck up IPython's
4150 readline handling, and now tab-completion finally works in the
4155 readline handling, and now tab-completion finally works in the
4151 debugger -- sort of. It completes things globally visible, but the
4156 debugger -- sort of. It completes things globally visible, but the
4152 completer doesn't track the stack as pdb walks it. That's a bit
4157 completer doesn't track the stack as pdb walks it. That's a bit
4153 tricky, and I'll have to implement it later.
4158 tricky, and I'll have to implement it later.
4154
4159
4155 2002-05-05 Fernando Perez <fperez@colorado.edu>
4160 2002-05-05 Fernando Perez <fperez@colorado.edu>
4156
4161
4157 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
4162 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
4158 magic docstrings when printed via ? (explicit \'s were being
4163 magic docstrings when printed via ? (explicit \'s were being
4159 printed).
4164 printed).
4160
4165
4161 * IPython/ipmaker.py (make_IPython): fixed namespace
4166 * IPython/ipmaker.py (make_IPython): fixed namespace
4162 identification bug. Now variables loaded via logs or command-line
4167 identification bug. Now variables loaded via logs or command-line
4163 files are recognized in the interactive namespace by @who.
4168 files are recognized in the interactive namespace by @who.
4164
4169
4165 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
4170 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
4166 log replay system stemming from the string form of Structs.
4171 log replay system stemming from the string form of Structs.
4167
4172
4168 * IPython/Magic.py (Macro.__init__): improved macros to properly
4173 * IPython/Magic.py (Macro.__init__): improved macros to properly
4169 handle magic commands in them.
4174 handle magic commands in them.
4170 (Magic.magic_logstart): usernames are now expanded so 'logstart
4175 (Magic.magic_logstart): usernames are now expanded so 'logstart
4171 ~/mylog' now works.
4176 ~/mylog' now works.
4172
4177
4173 * IPython/iplib.py (complete): fixed bug where paths starting with
4178 * IPython/iplib.py (complete): fixed bug where paths starting with
4174 '/' would be completed as magic names.
4179 '/' would be completed as magic names.
4175
4180
4176 2002-05-04 Fernando Perez <fperez@colorado.edu>
4181 2002-05-04 Fernando Perez <fperez@colorado.edu>
4177
4182
4178 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
4183 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
4179 allow running full programs under the profiler's control.
4184 allow running full programs under the profiler's control.
4180
4185
4181 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
4186 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
4182 mode to report exceptions verbosely but without formatting
4187 mode to report exceptions verbosely but without formatting
4183 variables. This addresses the issue of ipython 'freezing' (it's
4188 variables. This addresses the issue of ipython 'freezing' (it's
4184 not frozen, but caught in an expensive formatting loop) when huge
4189 not frozen, but caught in an expensive formatting loop) when huge
4185 variables are in the context of an exception.
4190 variables are in the context of an exception.
4186 (VerboseTB.text): Added '--->' markers at line where exception was
4191 (VerboseTB.text): Added '--->' markers at line where exception was
4187 triggered. Much clearer to read, especially in NoColor modes.
4192 triggered. Much clearer to read, especially in NoColor modes.
4188
4193
4189 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
4194 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
4190 implemented in reverse when changing to the new parse_options().
4195 implemented in reverse when changing to the new parse_options().
4191
4196
4192 2002-05-03 Fernando Perez <fperez@colorado.edu>
4197 2002-05-03 Fernando Perez <fperez@colorado.edu>
4193
4198
4194 * IPython/Magic.py (Magic.parse_options): new function so that
4199 * IPython/Magic.py (Magic.parse_options): new function so that
4195 magics can parse options easier.
4200 magics can parse options easier.
4196 (Magic.magic_prun): new function similar to profile.run(),
4201 (Magic.magic_prun): new function similar to profile.run(),
4197 suggested by Chris Hart.
4202 suggested by Chris Hart.
4198 (Magic.magic_cd): fixed behavior so that it only changes if
4203 (Magic.magic_cd): fixed behavior so that it only changes if
4199 directory actually is in history.
4204 directory actually is in history.
4200
4205
4201 * IPython/usage.py (__doc__): added information about potential
4206 * IPython/usage.py (__doc__): added information about potential
4202 slowness of Verbose exception mode when there are huge data
4207 slowness of Verbose exception mode when there are huge data
4203 structures to be formatted (thanks to Archie Paulson).
4208 structures to be formatted (thanks to Archie Paulson).
4204
4209
4205 * IPython/ipmaker.py (make_IPython): Changed default logging
4210 * IPython/ipmaker.py (make_IPython): Changed default logging
4206 (when simply called with -log) to use curr_dir/ipython.log in
4211 (when simply called with -log) to use curr_dir/ipython.log in
4207 rotate mode. Fixed crash which was occuring with -log before
4212 rotate mode. Fixed crash which was occuring with -log before
4208 (thanks to Jim Boyle).
4213 (thanks to Jim Boyle).
4209
4214
4210 2002-05-01 Fernando Perez <fperez@colorado.edu>
4215 2002-05-01 Fernando Perez <fperez@colorado.edu>
4211
4216
4212 * Released 0.2.11 for these fixes (mainly the ultraTB one which
4217 * Released 0.2.11 for these fixes (mainly the ultraTB one which
4213 was nasty -- though somewhat of a corner case).
4218 was nasty -- though somewhat of a corner case).
4214
4219
4215 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
4220 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
4216 text (was a bug).
4221 text (was a bug).
4217
4222
4218 2002-04-30 Fernando Perez <fperez@colorado.edu>
4223 2002-04-30 Fernando Perez <fperez@colorado.edu>
4219
4224
4220 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
4225 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
4221 a print after ^D or ^C from the user so that the In[] prompt
4226 a print after ^D or ^C from the user so that the In[] prompt
4222 doesn't over-run the gnuplot one.
4227 doesn't over-run the gnuplot one.
4223
4228
4224 2002-04-29 Fernando Perez <fperez@colorado.edu>
4229 2002-04-29 Fernando Perez <fperez@colorado.edu>
4225
4230
4226 * Released 0.2.10
4231 * Released 0.2.10
4227
4232
4228 * IPython/__release__.py (version): get date dynamically.
4233 * IPython/__release__.py (version): get date dynamically.
4229
4234
4230 * Misc. documentation updates thanks to Arnd's comments. Also ran
4235 * Misc. documentation updates thanks to Arnd's comments. Also ran
4231 a full spellcheck on the manual (hadn't been done in a while).
4236 a full spellcheck on the manual (hadn't been done in a while).
4232
4237
4233 2002-04-27 Fernando Perez <fperez@colorado.edu>
4238 2002-04-27 Fernando Perez <fperez@colorado.edu>
4234
4239
4235 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
4240 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
4236 starting a log in mid-session would reset the input history list.
4241 starting a log in mid-session would reset the input history list.
4237
4242
4238 2002-04-26 Fernando Perez <fperez@colorado.edu>
4243 2002-04-26 Fernando Perez <fperez@colorado.edu>
4239
4244
4240 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
4245 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
4241 all files were being included in an update. Now anything in
4246 all files were being included in an update. Now anything in
4242 UserConfig that matches [A-Za-z]*.py will go (this excludes
4247 UserConfig that matches [A-Za-z]*.py will go (this excludes
4243 __init__.py)
4248 __init__.py)
4244
4249
4245 2002-04-25 Fernando Perez <fperez@colorado.edu>
4250 2002-04-25 Fernando Perez <fperez@colorado.edu>
4246
4251
4247 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
4252 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
4248 to __builtins__ so that any form of embedded or imported code can
4253 to __builtins__ so that any form of embedded or imported code can
4249 test for being inside IPython.
4254 test for being inside IPython.
4250
4255
4251 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
4256 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
4252 changed to GnuplotMagic because it's now an importable module,
4257 changed to GnuplotMagic because it's now an importable module,
4253 this makes the name follow that of the standard Gnuplot module.
4258 this makes the name follow that of the standard Gnuplot module.
4254 GnuplotMagic can now be loaded at any time in mid-session.
4259 GnuplotMagic can now be loaded at any time in mid-session.
4255
4260
4256 2002-04-24 Fernando Perez <fperez@colorado.edu>
4261 2002-04-24 Fernando Perez <fperez@colorado.edu>
4257
4262
4258 * IPython/numutils.py: removed SIUnits. It doesn't properly set
4263 * IPython/numutils.py: removed SIUnits. It doesn't properly set
4259 the globals (IPython has its own namespace) and the
4264 the globals (IPython has its own namespace) and the
4260 PhysicalQuantity stuff is much better anyway.
4265 PhysicalQuantity stuff is much better anyway.
4261
4266
4262 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
4267 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
4263 embedding example to standard user directory for
4268 embedding example to standard user directory for
4264 distribution. Also put it in the manual.
4269 distribution. Also put it in the manual.
4265
4270
4266 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
4271 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
4267 instance as first argument (so it doesn't rely on some obscure
4272 instance as first argument (so it doesn't rely on some obscure
4268 hidden global).
4273 hidden global).
4269
4274
4270 * IPython/UserConfig/ipythonrc.py: put () back in accepted
4275 * IPython/UserConfig/ipythonrc.py: put () back in accepted
4271 delimiters. While it prevents ().TAB from working, it allows
4276 delimiters. While it prevents ().TAB from working, it allows
4272 completions in open (... expressions. This is by far a more common
4277 completions in open (... expressions. This is by far a more common
4273 case.
4278 case.
4274
4279
4275 2002-04-23 Fernando Perez <fperez@colorado.edu>
4280 2002-04-23 Fernando Perez <fperez@colorado.edu>
4276
4281
4277 * IPython/Extensions/InterpreterPasteInput.py: new
4282 * IPython/Extensions/InterpreterPasteInput.py: new
4278 syntax-processing module for pasting lines with >>> or ... at the
4283 syntax-processing module for pasting lines with >>> or ... at the
4279 start.
4284 start.
4280
4285
4281 * IPython/Extensions/PhysicalQ_Interactive.py
4286 * IPython/Extensions/PhysicalQ_Interactive.py
4282 (PhysicalQuantityInteractive.__int__): fixed to work with either
4287 (PhysicalQuantityInteractive.__int__): fixed to work with either
4283 Numeric or math.
4288 Numeric or math.
4284
4289
4285 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
4290 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
4286 provided profiles. Now we have:
4291 provided profiles. Now we have:
4287 -math -> math module as * and cmath with its own namespace.
4292 -math -> math module as * and cmath with its own namespace.
4288 -numeric -> Numeric as *, plus gnuplot & grace
4293 -numeric -> Numeric as *, plus gnuplot & grace
4289 -physics -> same as before
4294 -physics -> same as before
4290
4295
4291 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
4296 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
4292 user-defined magics wouldn't be found by @magic if they were
4297 user-defined magics wouldn't be found by @magic if they were
4293 defined as class methods. Also cleaned up the namespace search
4298 defined as class methods. Also cleaned up the namespace search
4294 logic and the string building (to use %s instead of many repeated
4299 logic and the string building (to use %s instead of many repeated
4295 string adds).
4300 string adds).
4296
4301
4297 * IPython/UserConfig/example-magic.py (magic_foo): updated example
4302 * IPython/UserConfig/example-magic.py (magic_foo): updated example
4298 of user-defined magics to operate with class methods (cleaner, in
4303 of user-defined magics to operate with class methods (cleaner, in
4299 line with the gnuplot code).
4304 line with the gnuplot code).
4300
4305
4301 2002-04-22 Fernando Perez <fperez@colorado.edu>
4306 2002-04-22 Fernando Perez <fperez@colorado.edu>
4302
4307
4303 * setup.py: updated dependency list so that manual is updated when
4308 * setup.py: updated dependency list so that manual is updated when
4304 all included files change.
4309 all included files change.
4305
4310
4306 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
4311 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
4307 the delimiter removal option (the fix is ugly right now).
4312 the delimiter removal option (the fix is ugly right now).
4308
4313
4309 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
4314 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
4310 all of the math profile (quicker loading, no conflict between
4315 all of the math profile (quicker loading, no conflict between
4311 g-9.8 and g-gnuplot).
4316 g-9.8 and g-gnuplot).
4312
4317
4313 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
4318 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
4314 name of post-mortem files to IPython_crash_report.txt.
4319 name of post-mortem files to IPython_crash_report.txt.
4315
4320
4316 * Cleanup/update of the docs. Added all the new readline info and
4321 * Cleanup/update of the docs. Added all the new readline info and
4317 formatted all lists as 'real lists'.
4322 formatted all lists as 'real lists'.
4318
4323
4319 * IPython/ipmaker.py (make_IPython): removed now-obsolete
4324 * IPython/ipmaker.py (make_IPython): removed now-obsolete
4320 tab-completion options, since the full readline parse_and_bind is
4325 tab-completion options, since the full readline parse_and_bind is
4321 now accessible.
4326 now accessible.
4322
4327
4323 * IPython/iplib.py (InteractiveShell.init_readline): Changed
4328 * IPython/iplib.py (InteractiveShell.init_readline): Changed
4324 handling of readline options. Now users can specify any string to
4329 handling of readline options. Now users can specify any string to
4325 be passed to parse_and_bind(), as well as the delimiters to be
4330 be passed to parse_and_bind(), as well as the delimiters to be
4326 removed.
4331 removed.
4327 (InteractiveShell.__init__): Added __name__ to the global
4332 (InteractiveShell.__init__): Added __name__ to the global
4328 namespace so that things like Itpl which rely on its existence
4333 namespace so that things like Itpl which rely on its existence
4329 don't crash.
4334 don't crash.
4330 (InteractiveShell._prefilter): Defined the default with a _ so
4335 (InteractiveShell._prefilter): Defined the default with a _ so
4331 that prefilter() is easier to override, while the default one
4336 that prefilter() is easier to override, while the default one
4332 remains available.
4337 remains available.
4333
4338
4334 2002-04-18 Fernando Perez <fperez@colorado.edu>
4339 2002-04-18 Fernando Perez <fperez@colorado.edu>
4335
4340
4336 * Added information about pdb in the docs.
4341 * Added information about pdb in the docs.
4337
4342
4338 2002-04-17 Fernando Perez <fperez@colorado.edu>
4343 2002-04-17 Fernando Perez <fperez@colorado.edu>
4339
4344
4340 * IPython/ipmaker.py (make_IPython): added rc_override option to
4345 * IPython/ipmaker.py (make_IPython): added rc_override option to
4341 allow passing config options at creation time which may override
4346 allow passing config options at creation time which may override
4342 anything set in the config files or command line. This is
4347 anything set in the config files or command line. This is
4343 particularly useful for configuring embedded instances.
4348 particularly useful for configuring embedded instances.
4344
4349
4345 2002-04-15 Fernando Perez <fperez@colorado.edu>
4350 2002-04-15 Fernando Perez <fperez@colorado.edu>
4346
4351
4347 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
4352 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
4348 crash embedded instances because of the input cache falling out of
4353 crash embedded instances because of the input cache falling out of
4349 sync with the output counter.
4354 sync with the output counter.
4350
4355
4351 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
4356 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
4352 mode which calls pdb after an uncaught exception in IPython itself.
4357 mode which calls pdb after an uncaught exception in IPython itself.
4353
4358
4354 2002-04-14 Fernando Perez <fperez@colorado.edu>
4359 2002-04-14 Fernando Perez <fperez@colorado.edu>
4355
4360
4356 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
4361 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
4357 readline, fix it back after each call.
4362 readline, fix it back after each call.
4358
4363
4359 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
4364 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
4360 method to force all access via __call__(), which guarantees that
4365 method to force all access via __call__(), which guarantees that
4361 traceback references are properly deleted.
4366 traceback references are properly deleted.
4362
4367
4363 * IPython/Prompts.py (CachedOutput._display): minor fixes to
4368 * IPython/Prompts.py (CachedOutput._display): minor fixes to
4364 improve printing when pprint is in use.
4369 improve printing when pprint is in use.
4365
4370
4366 2002-04-13 Fernando Perez <fperez@colorado.edu>
4371 2002-04-13 Fernando Perez <fperez@colorado.edu>
4367
4372
4368 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
4373 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
4369 exceptions aren't caught anymore. If the user triggers one, he
4374 exceptions aren't caught anymore. If the user triggers one, he
4370 should know why he's doing it and it should go all the way up,
4375 should know why he's doing it and it should go all the way up,
4371 just like any other exception. So now @abort will fully kill the
4376 just like any other exception. So now @abort will fully kill the
4372 embedded interpreter and the embedding code (unless that happens
4377 embedded interpreter and the embedding code (unless that happens
4373 to catch SystemExit).
4378 to catch SystemExit).
4374
4379
4375 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
4380 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
4376 and a debugger() method to invoke the interactive pdb debugger
4381 and a debugger() method to invoke the interactive pdb debugger
4377 after printing exception information. Also added the corresponding
4382 after printing exception information. Also added the corresponding
4378 -pdb option and @pdb magic to control this feature, and updated
4383 -pdb option and @pdb magic to control this feature, and updated
4379 the docs. After a suggestion from Christopher Hart
4384 the docs. After a suggestion from Christopher Hart
4380 (hart-AT-caltech.edu).
4385 (hart-AT-caltech.edu).
4381
4386
4382 2002-04-12 Fernando Perez <fperez@colorado.edu>
4387 2002-04-12 Fernando Perez <fperez@colorado.edu>
4383
4388
4384 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
4389 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
4385 the exception handlers defined by the user (not the CrashHandler)
4390 the exception handlers defined by the user (not the CrashHandler)
4386 so that user exceptions don't trigger an ipython bug report.
4391 so that user exceptions don't trigger an ipython bug report.
4387
4392
4388 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
4393 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
4389 configurable (it should have always been so).
4394 configurable (it should have always been so).
4390
4395
4391 2002-03-26 Fernando Perez <fperez@colorado.edu>
4396 2002-03-26 Fernando Perez <fperez@colorado.edu>
4392
4397
4393 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
4398 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
4394 and there to fix embedding namespace issues. This should all be
4399 and there to fix embedding namespace issues. This should all be
4395 done in a more elegant way.
4400 done in a more elegant way.
4396
4401
4397 2002-03-25 Fernando Perez <fperez@colorado.edu>
4402 2002-03-25 Fernando Perez <fperez@colorado.edu>
4398
4403
4399 * IPython/genutils.py (get_home_dir): Try to make it work under
4404 * IPython/genutils.py (get_home_dir): Try to make it work under
4400 win9x also.
4405 win9x also.
4401
4406
4402 2002-03-20 Fernando Perez <fperez@colorado.edu>
4407 2002-03-20 Fernando Perez <fperez@colorado.edu>
4403
4408
4404 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
4409 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
4405 sys.displayhook untouched upon __init__.
4410 sys.displayhook untouched upon __init__.
4406
4411
4407 2002-03-19 Fernando Perez <fperez@colorado.edu>
4412 2002-03-19 Fernando Perez <fperez@colorado.edu>
4408
4413
4409 * Released 0.2.9 (for embedding bug, basically).
4414 * Released 0.2.9 (for embedding bug, basically).
4410
4415
4411 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
4416 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
4412 exceptions so that enclosing shell's state can be restored.
4417 exceptions so that enclosing shell's state can be restored.
4413
4418
4414 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
4419 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
4415 naming conventions in the .ipython/ dir.
4420 naming conventions in the .ipython/ dir.
4416
4421
4417 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
4422 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
4418 from delimiters list so filenames with - in them get expanded.
4423 from delimiters list so filenames with - in them get expanded.
4419
4424
4420 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
4425 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
4421 sys.displayhook not being properly restored after an embedded call.
4426 sys.displayhook not being properly restored after an embedded call.
4422
4427
4423 2002-03-18 Fernando Perez <fperez@colorado.edu>
4428 2002-03-18 Fernando Perez <fperez@colorado.edu>
4424
4429
4425 * Released 0.2.8
4430 * Released 0.2.8
4426
4431
4427 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
4432 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
4428 some files weren't being included in a -upgrade.
4433 some files weren't being included in a -upgrade.
4429 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
4434 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
4430 on' so that the first tab completes.
4435 on' so that the first tab completes.
4431 (InteractiveShell.handle_magic): fixed bug with spaces around
4436 (InteractiveShell.handle_magic): fixed bug with spaces around
4432 quotes breaking many magic commands.
4437 quotes breaking many magic commands.
4433
4438
4434 * setup.py: added note about ignoring the syntax error messages at
4439 * setup.py: added note about ignoring the syntax error messages at
4435 installation.
4440 installation.
4436
4441
4437 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
4442 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
4438 streamlining the gnuplot interface, now there's only one magic @gp.
4443 streamlining the gnuplot interface, now there's only one magic @gp.
4439
4444
4440 2002-03-17 Fernando Perez <fperez@colorado.edu>
4445 2002-03-17 Fernando Perez <fperez@colorado.edu>
4441
4446
4442 * IPython/UserConfig/magic_gnuplot.py: new name for the
4447 * IPython/UserConfig/magic_gnuplot.py: new name for the
4443 example-magic_pm.py file. Much enhanced system, now with a shell
4448 example-magic_pm.py file. Much enhanced system, now with a shell
4444 for communicating directly with gnuplot, one command at a time.
4449 for communicating directly with gnuplot, one command at a time.
4445
4450
4446 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
4451 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
4447 setting __name__=='__main__'.
4452 setting __name__=='__main__'.
4448
4453
4449 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
4454 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
4450 mini-shell for accessing gnuplot from inside ipython. Should
4455 mini-shell for accessing gnuplot from inside ipython. Should
4451 extend it later for grace access too. Inspired by Arnd's
4456 extend it later for grace access too. Inspired by Arnd's
4452 suggestion.
4457 suggestion.
4453
4458
4454 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
4459 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
4455 calling magic functions with () in their arguments. Thanks to Arnd
4460 calling magic functions with () in their arguments. Thanks to Arnd
4456 Baecker for pointing this to me.
4461 Baecker for pointing this to me.
4457
4462
4458 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
4463 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
4459 infinitely for integer or complex arrays (only worked with floats).
4464 infinitely for integer or complex arrays (only worked with floats).
4460
4465
4461 2002-03-16 Fernando Perez <fperez@colorado.edu>
4466 2002-03-16 Fernando Perez <fperez@colorado.edu>
4462
4467
4463 * setup.py: Merged setup and setup_windows into a single script
4468 * setup.py: Merged setup and setup_windows into a single script
4464 which properly handles things for windows users.
4469 which properly handles things for windows users.
4465
4470
4466 2002-03-15 Fernando Perez <fperez@colorado.edu>
4471 2002-03-15 Fernando Perez <fperez@colorado.edu>
4467
4472
4468 * Big change to the manual: now the magics are all automatically
4473 * Big change to the manual: now the magics are all automatically
4469 documented. This information is generated from their docstrings
4474 documented. This information is generated from their docstrings
4470 and put in a latex file included by the manual lyx file. This way
4475 and put in a latex file included by the manual lyx file. This way
4471 we get always up to date information for the magics. The manual
4476 we get always up to date information for the magics. The manual
4472 now also has proper version information, also auto-synced.
4477 now also has proper version information, also auto-synced.
4473
4478
4474 For this to work, an undocumented --magic_docstrings option was added.
4479 For this to work, an undocumented --magic_docstrings option was added.
4475
4480
4476 2002-03-13 Fernando Perez <fperez@colorado.edu>
4481 2002-03-13 Fernando Perez <fperez@colorado.edu>
4477
4482
4478 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
4483 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
4479 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
4484 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
4480
4485
4481 2002-03-12 Fernando Perez <fperez@colorado.edu>
4486 2002-03-12 Fernando Perez <fperez@colorado.edu>
4482
4487
4483 * IPython/ultraTB.py (TermColors): changed color escapes again to
4488 * IPython/ultraTB.py (TermColors): changed color escapes again to
4484 fix the (old, reintroduced) line-wrapping bug. Basically, if
4489 fix the (old, reintroduced) line-wrapping bug. Basically, if
4485 \001..\002 aren't given in the color escapes, lines get wrapped
4490 \001..\002 aren't given in the color escapes, lines get wrapped
4486 weirdly. But giving those screws up old xterms and emacs terms. So
4491 weirdly. But giving those screws up old xterms and emacs terms. So
4487 I added some logic for emacs terms to be ok, but I can't identify old
4492 I added some logic for emacs terms to be ok, but I can't identify old
4488 xterms separately ($TERM=='xterm' for many terminals, like konsole).
4493 xterms separately ($TERM=='xterm' for many terminals, like konsole).
4489
4494
4490 2002-03-10 Fernando Perez <fperez@colorado.edu>
4495 2002-03-10 Fernando Perez <fperez@colorado.edu>
4491
4496
4492 * IPython/usage.py (__doc__): Various documentation cleanups and
4497 * IPython/usage.py (__doc__): Various documentation cleanups and
4493 updates, both in usage docstrings and in the manual.
4498 updates, both in usage docstrings and in the manual.
4494
4499
4495 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
4500 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
4496 handling of caching. Set minimum acceptabe value for having a
4501 handling of caching. Set minimum acceptabe value for having a
4497 cache at 20 values.
4502 cache at 20 values.
4498
4503
4499 * IPython/iplib.py (InteractiveShell.user_setup): moved the
4504 * IPython/iplib.py (InteractiveShell.user_setup): moved the
4500 install_first_time function to a method, renamed it and added an
4505 install_first_time function to a method, renamed it and added an
4501 'upgrade' mode. Now people can update their config directory with
4506 'upgrade' mode. Now people can update their config directory with
4502 a simple command line switch (-upgrade, also new).
4507 a simple command line switch (-upgrade, also new).
4503
4508
4504 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
4509 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
4505 @file (convenient for automagic users under Python >= 2.2).
4510 @file (convenient for automagic users under Python >= 2.2).
4506 Removed @files (it seemed more like a plural than an abbrev. of
4511 Removed @files (it seemed more like a plural than an abbrev. of
4507 'file show').
4512 'file show').
4508
4513
4509 * IPython/iplib.py (install_first_time): Fixed crash if there were
4514 * IPython/iplib.py (install_first_time): Fixed crash if there were
4510 backup files ('~') in .ipython/ install directory.
4515 backup files ('~') in .ipython/ install directory.
4511
4516
4512 * IPython/ipmaker.py (make_IPython): fixes for new prompt
4517 * IPython/ipmaker.py (make_IPython): fixes for new prompt
4513 system. Things look fine, but these changes are fairly
4518 system. Things look fine, but these changes are fairly
4514 intrusive. Test them for a few days.
4519 intrusive. Test them for a few days.
4515
4520
4516 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
4521 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
4517 the prompts system. Now all in/out prompt strings are user
4522 the prompts system. Now all in/out prompt strings are user
4518 controllable. This is particularly useful for embedding, as one
4523 controllable. This is particularly useful for embedding, as one
4519 can tag embedded instances with particular prompts.
4524 can tag embedded instances with particular prompts.
4520
4525
4521 Also removed global use of sys.ps1/2, which now allows nested
4526 Also removed global use of sys.ps1/2, which now allows nested
4522 embeddings without any problems. Added command-line options for
4527 embeddings without any problems. Added command-line options for
4523 the prompt strings.
4528 the prompt strings.
4524
4529
4525 2002-03-08 Fernando Perez <fperez@colorado.edu>
4530 2002-03-08 Fernando Perez <fperez@colorado.edu>
4526
4531
4527 * IPython/UserConfig/example-embed-short.py (ipshell): added
4532 * IPython/UserConfig/example-embed-short.py (ipshell): added
4528 example file with the bare minimum code for embedding.
4533 example file with the bare minimum code for embedding.
4529
4534
4530 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
4535 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
4531 functionality for the embeddable shell to be activated/deactivated
4536 functionality for the embeddable shell to be activated/deactivated
4532 either globally or at each call.
4537 either globally or at each call.
4533
4538
4534 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
4539 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
4535 rewriting the prompt with '--->' for auto-inputs with proper
4540 rewriting the prompt with '--->' for auto-inputs with proper
4536 coloring. Now the previous UGLY hack in handle_auto() is gone, and
4541 coloring. Now the previous UGLY hack in handle_auto() is gone, and
4537 this is handled by the prompts class itself, as it should.
4542 this is handled by the prompts class itself, as it should.
4538
4543
4539 2002-03-05 Fernando Perez <fperez@colorado.edu>
4544 2002-03-05 Fernando Perez <fperez@colorado.edu>
4540
4545
4541 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
4546 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
4542 @logstart to avoid name clashes with the math log function.
4547 @logstart to avoid name clashes with the math log function.
4543
4548
4544 * Big updates to X/Emacs section of the manual.
4549 * Big updates to X/Emacs section of the manual.
4545
4550
4546 * Removed ipython_emacs. Milan explained to me how to pass
4551 * Removed ipython_emacs. Milan explained to me how to pass
4547 arguments to ipython through Emacs. Some day I'm going to end up
4552 arguments to ipython through Emacs. Some day I'm going to end up
4548 learning some lisp...
4553 learning some lisp...
4549
4554
4550 2002-03-04 Fernando Perez <fperez@colorado.edu>
4555 2002-03-04 Fernando Perez <fperez@colorado.edu>
4551
4556
4552 * IPython/ipython_emacs: Created script to be used as the
4557 * IPython/ipython_emacs: Created script to be used as the
4553 py-python-command Emacs variable so we can pass IPython
4558 py-python-command Emacs variable so we can pass IPython
4554 parameters. I can't figure out how to tell Emacs directly to pass
4559 parameters. I can't figure out how to tell Emacs directly to pass
4555 parameters to IPython, so a dummy shell script will do it.
4560 parameters to IPython, so a dummy shell script will do it.
4556
4561
4557 Other enhancements made for things to work better under Emacs'
4562 Other enhancements made for things to work better under Emacs'
4558 various types of terminals. Many thanks to Milan Zamazal
4563 various types of terminals. Many thanks to Milan Zamazal
4559 <pdm-AT-zamazal.org> for all the suggestions and pointers.
4564 <pdm-AT-zamazal.org> for all the suggestions and pointers.
4560
4565
4561 2002-03-01 Fernando Perez <fperez@colorado.edu>
4566 2002-03-01 Fernando Perez <fperez@colorado.edu>
4562
4567
4563 * IPython/ipmaker.py (make_IPython): added a --readline! option so
4568 * IPython/ipmaker.py (make_IPython): added a --readline! option so
4564 that loading of readline is now optional. This gives better
4569 that loading of readline is now optional. This gives better
4565 control to emacs users.
4570 control to emacs users.
4566
4571
4567 * IPython/ultraTB.py (__date__): Modified color escape sequences
4572 * IPython/ultraTB.py (__date__): Modified color escape sequences
4568 and now things work fine under xterm and in Emacs' term buffers
4573 and now things work fine under xterm and in Emacs' term buffers
4569 (though not shell ones). Well, in emacs you get colors, but all
4574 (though not shell ones). Well, in emacs you get colors, but all
4570 seem to be 'light' colors (no difference between dark and light
4575 seem to be 'light' colors (no difference between dark and light
4571 ones). But the garbage chars are gone, and also in xterms. It
4576 ones). But the garbage chars are gone, and also in xterms. It
4572 seems that now I'm using 'cleaner' ansi sequences.
4577 seems that now I'm using 'cleaner' ansi sequences.
4573
4578
4574 2002-02-21 Fernando Perez <fperez@colorado.edu>
4579 2002-02-21 Fernando Perez <fperez@colorado.edu>
4575
4580
4576 * Released 0.2.7 (mainly to publish the scoping fix).
4581 * Released 0.2.7 (mainly to publish the scoping fix).
4577
4582
4578 * IPython/Logger.py (Logger.logstate): added. A corresponding
4583 * IPython/Logger.py (Logger.logstate): added. A corresponding
4579 @logstate magic was created.
4584 @logstate magic was created.
4580
4585
4581 * IPython/Magic.py: fixed nested scoping problem under Python
4586 * IPython/Magic.py: fixed nested scoping problem under Python
4582 2.1.x (automagic wasn't working).
4587 2.1.x (automagic wasn't working).
4583
4588
4584 2002-02-20 Fernando Perez <fperez@colorado.edu>
4589 2002-02-20 Fernando Perez <fperez@colorado.edu>
4585
4590
4586 * Released 0.2.6.
4591 * Released 0.2.6.
4587
4592
4588 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
4593 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
4589 option so that logs can come out without any headers at all.
4594 option so that logs can come out without any headers at all.
4590
4595
4591 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
4596 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
4592 SciPy.
4597 SciPy.
4593
4598
4594 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
4599 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
4595 that embedded IPython calls don't require vars() to be explicitly
4600 that embedded IPython calls don't require vars() to be explicitly
4596 passed. Now they are extracted from the caller's frame (code
4601 passed. Now they are extracted from the caller's frame (code
4597 snatched from Eric Jones' weave). Added better documentation to
4602 snatched from Eric Jones' weave). Added better documentation to
4598 the section on embedding and the example file.
4603 the section on embedding and the example file.
4599
4604
4600 * IPython/genutils.py (page): Changed so that under emacs, it just
4605 * IPython/genutils.py (page): Changed so that under emacs, it just
4601 prints the string. You can then page up and down in the emacs
4606 prints the string. You can then page up and down in the emacs
4602 buffer itself. This is how the builtin help() works.
4607 buffer itself. This is how the builtin help() works.
4603
4608
4604 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
4609 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
4605 macro scoping: macros need to be executed in the user's namespace
4610 macro scoping: macros need to be executed in the user's namespace
4606 to work as if they had been typed by the user.
4611 to work as if they had been typed by the user.
4607
4612
4608 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
4613 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
4609 execute automatically (no need to type 'exec...'). They then
4614 execute automatically (no need to type 'exec...'). They then
4610 behave like 'true macros'. The printing system was also modified
4615 behave like 'true macros'. The printing system was also modified
4611 for this to work.
4616 for this to work.
4612
4617
4613 2002-02-19 Fernando Perez <fperez@colorado.edu>
4618 2002-02-19 Fernando Perez <fperez@colorado.edu>
4614
4619
4615 * IPython/genutils.py (page_file): new function for paging files
4620 * IPython/genutils.py (page_file): new function for paging files
4616 in an OS-independent way. Also necessary for file viewing to work
4621 in an OS-independent way. Also necessary for file viewing to work
4617 well inside Emacs buffers.
4622 well inside Emacs buffers.
4618 (page): Added checks for being in an emacs buffer.
4623 (page): Added checks for being in an emacs buffer.
4619 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
4624 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
4620 same bug in iplib.
4625 same bug in iplib.
4621
4626
4622 2002-02-18 Fernando Perez <fperez@colorado.edu>
4627 2002-02-18 Fernando Perez <fperez@colorado.edu>
4623
4628
4624 * IPython/iplib.py (InteractiveShell.init_readline): modified use
4629 * IPython/iplib.py (InteractiveShell.init_readline): modified use
4625 of readline so that IPython can work inside an Emacs buffer.
4630 of readline so that IPython can work inside an Emacs buffer.
4626
4631
4627 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
4632 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
4628 method signatures (they weren't really bugs, but it looks cleaner
4633 method signatures (they weren't really bugs, but it looks cleaner
4629 and keeps PyChecker happy).
4634 and keeps PyChecker happy).
4630
4635
4631 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
4636 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
4632 for implementing various user-defined hooks. Currently only
4637 for implementing various user-defined hooks. Currently only
4633 display is done.
4638 display is done.
4634
4639
4635 * IPython/Prompts.py (CachedOutput._display): changed display
4640 * IPython/Prompts.py (CachedOutput._display): changed display
4636 functions so that they can be dynamically changed by users easily.
4641 functions so that they can be dynamically changed by users easily.
4637
4642
4638 * IPython/Extensions/numeric_formats.py (num_display): added an
4643 * IPython/Extensions/numeric_formats.py (num_display): added an
4639 extension for printing NumPy arrays in flexible manners. It
4644 extension for printing NumPy arrays in flexible manners. It
4640 doesn't do anything yet, but all the structure is in
4645 doesn't do anything yet, but all the structure is in
4641 place. Ultimately the plan is to implement output format control
4646 place. Ultimately the plan is to implement output format control
4642 like in Octave.
4647 like in Octave.
4643
4648
4644 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
4649 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
4645 methods are found at run-time by all the automatic machinery.
4650 methods are found at run-time by all the automatic machinery.
4646
4651
4647 2002-02-17 Fernando Perez <fperez@colorado.edu>
4652 2002-02-17 Fernando Perez <fperez@colorado.edu>
4648
4653
4649 * setup_Windows.py (make_shortcut): documented. Cleaned up the
4654 * setup_Windows.py (make_shortcut): documented. Cleaned up the
4650 whole file a little.
4655 whole file a little.
4651
4656
4652 * ToDo: closed this document. Now there's a new_design.lyx
4657 * ToDo: closed this document. Now there's a new_design.lyx
4653 document for all new ideas. Added making a pdf of it for the
4658 document for all new ideas. Added making a pdf of it for the
4654 end-user distro.
4659 end-user distro.
4655
4660
4656 * IPython/Logger.py (Logger.switch_log): Created this to replace
4661 * IPython/Logger.py (Logger.switch_log): Created this to replace
4657 logon() and logoff(). It also fixes a nasty crash reported by
4662 logon() and logoff(). It also fixes a nasty crash reported by
4658 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
4663 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
4659
4664
4660 * IPython/iplib.py (complete): got auto-completion to work with
4665 * IPython/iplib.py (complete): got auto-completion to work with
4661 automagic (I had wanted this for a long time).
4666 automagic (I had wanted this for a long time).
4662
4667
4663 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
4668 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
4664 to @file, since file() is now a builtin and clashes with automagic
4669 to @file, since file() is now a builtin and clashes with automagic
4665 for @file.
4670 for @file.
4666
4671
4667 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
4672 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
4668 of this was previously in iplib, which had grown to more than 2000
4673 of this was previously in iplib, which had grown to more than 2000
4669 lines, way too long. No new functionality, but it makes managing
4674 lines, way too long. No new functionality, but it makes managing
4670 the code a bit easier.
4675 the code a bit easier.
4671
4676
4672 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
4677 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
4673 information to crash reports.
4678 information to crash reports.
4674
4679
4675 2002-02-12 Fernando Perez <fperez@colorado.edu>
4680 2002-02-12 Fernando Perez <fperez@colorado.edu>
4676
4681
4677 * Released 0.2.5.
4682 * Released 0.2.5.
4678
4683
4679 2002-02-11 Fernando Perez <fperez@colorado.edu>
4684 2002-02-11 Fernando Perez <fperez@colorado.edu>
4680
4685
4681 * Wrote a relatively complete Windows installer. It puts
4686 * Wrote a relatively complete Windows installer. It puts
4682 everything in place, creates Start Menu entries and fixes the
4687 everything in place, creates Start Menu entries and fixes the
4683 color issues. Nothing fancy, but it works.
4688 color issues. Nothing fancy, but it works.
4684
4689
4685 2002-02-10 Fernando Perez <fperez@colorado.edu>
4690 2002-02-10 Fernando Perez <fperez@colorado.edu>
4686
4691
4687 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
4692 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
4688 os.path.expanduser() call so that we can type @run ~/myfile.py and
4693 os.path.expanduser() call so that we can type @run ~/myfile.py and
4689 have thigs work as expected.
4694 have thigs work as expected.
4690
4695
4691 * IPython/genutils.py (page): fixed exception handling so things
4696 * IPython/genutils.py (page): fixed exception handling so things
4692 work both in Unix and Windows correctly. Quitting a pager triggers
4697 work both in Unix and Windows correctly. Quitting a pager triggers
4693 an IOError/broken pipe in Unix, and in windows not finding a pager
4698 an IOError/broken pipe in Unix, and in windows not finding a pager
4694 is also an IOError, so I had to actually look at the return value
4699 is also an IOError, so I had to actually look at the return value
4695 of the exception, not just the exception itself. Should be ok now.
4700 of the exception, not just the exception itself. Should be ok now.
4696
4701
4697 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
4702 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
4698 modified to allow case-insensitive color scheme changes.
4703 modified to allow case-insensitive color scheme changes.
4699
4704
4700 2002-02-09 Fernando Perez <fperez@colorado.edu>
4705 2002-02-09 Fernando Perez <fperez@colorado.edu>
4701
4706
4702 * IPython/genutils.py (native_line_ends): new function to leave
4707 * IPython/genutils.py (native_line_ends): new function to leave
4703 user config files with os-native line-endings.
4708 user config files with os-native line-endings.
4704
4709
4705 * README and manual updates.
4710 * README and manual updates.
4706
4711
4707 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
4712 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
4708 instead of StringType to catch Unicode strings.
4713 instead of StringType to catch Unicode strings.
4709
4714
4710 * IPython/genutils.py (filefind): fixed bug for paths with
4715 * IPython/genutils.py (filefind): fixed bug for paths with
4711 embedded spaces (very common in Windows).
4716 embedded spaces (very common in Windows).
4712
4717
4713 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
4718 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
4714 files under Windows, so that they get automatically associated
4719 files under Windows, so that they get automatically associated
4715 with a text editor. Windows makes it a pain to handle
4720 with a text editor. Windows makes it a pain to handle
4716 extension-less files.
4721 extension-less files.
4717
4722
4718 * IPython/iplib.py (InteractiveShell.init_readline): Made the
4723 * IPython/iplib.py (InteractiveShell.init_readline): Made the
4719 warning about readline only occur for Posix. In Windows there's no
4724 warning about readline only occur for Posix. In Windows there's no
4720 way to get readline, so why bother with the warning.
4725 way to get readline, so why bother with the warning.
4721
4726
4722 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
4727 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
4723 for __str__ instead of dir(self), since dir() changed in 2.2.
4728 for __str__ instead of dir(self), since dir() changed in 2.2.
4724
4729
4725 * Ported to Windows! Tested on XP, I suspect it should work fine
4730 * Ported to Windows! Tested on XP, I suspect it should work fine
4726 on NT/2000, but I don't think it will work on 98 et al. That
4731 on NT/2000, but I don't think it will work on 98 et al. That
4727 series of Windows is such a piece of junk anyway that I won't try
4732 series of Windows is such a piece of junk anyway that I won't try
4728 porting it there. The XP port was straightforward, showed a few
4733 porting it there. The XP port was straightforward, showed a few
4729 bugs here and there (fixed all), in particular some string
4734 bugs here and there (fixed all), in particular some string
4730 handling stuff which required considering Unicode strings (which
4735 handling stuff which required considering Unicode strings (which
4731 Windows uses). This is good, but hasn't been too tested :) No
4736 Windows uses). This is good, but hasn't been too tested :) No
4732 fancy installer yet, I'll put a note in the manual so people at
4737 fancy installer yet, I'll put a note in the manual so people at
4733 least make manually a shortcut.
4738 least make manually a shortcut.
4734
4739
4735 * IPython/iplib.py (Magic.magic_colors): Unified the color options
4740 * IPython/iplib.py (Magic.magic_colors): Unified the color options
4736 into a single one, "colors". This now controls both prompt and
4741 into a single one, "colors". This now controls both prompt and
4737 exception color schemes, and can be changed both at startup
4742 exception color schemes, and can be changed both at startup
4738 (either via command-line switches or via ipythonrc files) and at
4743 (either via command-line switches or via ipythonrc files) and at
4739 runtime, with @colors.
4744 runtime, with @colors.
4740 (Magic.magic_run): renamed @prun to @run and removed the old
4745 (Magic.magic_run): renamed @prun to @run and removed the old
4741 @run. The two were too similar to warrant keeping both.
4746 @run. The two were too similar to warrant keeping both.
4742
4747
4743 2002-02-03 Fernando Perez <fperez@colorado.edu>
4748 2002-02-03 Fernando Perez <fperez@colorado.edu>
4744
4749
4745 * IPython/iplib.py (install_first_time): Added comment on how to
4750 * IPython/iplib.py (install_first_time): Added comment on how to
4746 configure the color options for first-time users. Put a <return>
4751 configure the color options for first-time users. Put a <return>
4747 request at the end so that small-terminal users get a chance to
4752 request at the end so that small-terminal users get a chance to
4748 read the startup info.
4753 read the startup info.
4749
4754
4750 2002-01-23 Fernando Perez <fperez@colorado.edu>
4755 2002-01-23 Fernando Perez <fperez@colorado.edu>
4751
4756
4752 * IPython/iplib.py (CachedOutput.update): Changed output memory
4757 * IPython/iplib.py (CachedOutput.update): Changed output memory
4753 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
4758 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
4754 input history we still use _i. Did this b/c these variable are
4759 input history we still use _i. Did this b/c these variable are
4755 very commonly used in interactive work, so the less we need to
4760 very commonly used in interactive work, so the less we need to
4756 type the better off we are.
4761 type the better off we are.
4757 (Magic.magic_prun): updated @prun to better handle the namespaces
4762 (Magic.magic_prun): updated @prun to better handle the namespaces
4758 the file will run in, including a fix for __name__ not being set
4763 the file will run in, including a fix for __name__ not being set
4759 before.
4764 before.
4760
4765
4761 2002-01-20 Fernando Perez <fperez@colorado.edu>
4766 2002-01-20 Fernando Perez <fperez@colorado.edu>
4762
4767
4763 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
4768 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
4764 extra garbage for Python 2.2. Need to look more carefully into
4769 extra garbage for Python 2.2. Need to look more carefully into
4765 this later.
4770 this later.
4766
4771
4767 2002-01-19 Fernando Perez <fperez@colorado.edu>
4772 2002-01-19 Fernando Perez <fperez@colorado.edu>
4768
4773
4769 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
4774 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
4770 display SyntaxError exceptions properly formatted when they occur
4775 display SyntaxError exceptions properly formatted when they occur
4771 (they can be triggered by imported code).
4776 (they can be triggered by imported code).
4772
4777
4773 2002-01-18 Fernando Perez <fperez@colorado.edu>
4778 2002-01-18 Fernando Perez <fperez@colorado.edu>
4774
4779
4775 * IPython/iplib.py (InteractiveShell.safe_execfile): now
4780 * IPython/iplib.py (InteractiveShell.safe_execfile): now
4776 SyntaxError exceptions are reported nicely formatted, instead of
4781 SyntaxError exceptions are reported nicely formatted, instead of
4777 spitting out only offset information as before.
4782 spitting out only offset information as before.
4778 (Magic.magic_prun): Added the @prun function for executing
4783 (Magic.magic_prun): Added the @prun function for executing
4779 programs with command line args inside IPython.
4784 programs with command line args inside IPython.
4780
4785
4781 2002-01-16 Fernando Perez <fperez@colorado.edu>
4786 2002-01-16 Fernando Perez <fperez@colorado.edu>
4782
4787
4783 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
4788 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
4784 to *not* include the last item given in a range. This brings their
4789 to *not* include the last item given in a range. This brings their
4785 behavior in line with Python's slicing:
4790 behavior in line with Python's slicing:
4786 a[n1:n2] -> a[n1]...a[n2-1]
4791 a[n1:n2] -> a[n1]...a[n2-1]
4787 It may be a bit less convenient, but I prefer to stick to Python's
4792 It may be a bit less convenient, but I prefer to stick to Python's
4788 conventions *everywhere*, so users never have to wonder.
4793 conventions *everywhere*, so users never have to wonder.
4789 (Magic.magic_macro): Added @macro function to ease the creation of
4794 (Magic.magic_macro): Added @macro function to ease the creation of
4790 macros.
4795 macros.
4791
4796
4792 2002-01-05 Fernando Perez <fperez@colorado.edu>
4797 2002-01-05 Fernando Perez <fperez@colorado.edu>
4793
4798
4794 * Released 0.2.4.
4799 * Released 0.2.4.
4795
4800
4796 * IPython/iplib.py (Magic.magic_pdef):
4801 * IPython/iplib.py (Magic.magic_pdef):
4797 (InteractiveShell.safe_execfile): report magic lines and error
4802 (InteractiveShell.safe_execfile): report magic lines and error
4798 lines without line numbers so one can easily copy/paste them for
4803 lines without line numbers so one can easily copy/paste them for
4799 re-execution.
4804 re-execution.
4800
4805
4801 * Updated manual with recent changes.
4806 * Updated manual with recent changes.
4802
4807
4803 * IPython/iplib.py (Magic.magic_oinfo): added constructor
4808 * IPython/iplib.py (Magic.magic_oinfo): added constructor
4804 docstring printing when class? is called. Very handy for knowing
4809 docstring printing when class? is called. Very handy for knowing
4805 how to create class instances (as long as __init__ is well
4810 how to create class instances (as long as __init__ is well
4806 documented, of course :)
4811 documented, of course :)
4807 (Magic.magic_doc): print both class and constructor docstrings.
4812 (Magic.magic_doc): print both class and constructor docstrings.
4808 (Magic.magic_pdef): give constructor info if passed a class and
4813 (Magic.magic_pdef): give constructor info if passed a class and
4809 __call__ info for callable object instances.
4814 __call__ info for callable object instances.
4810
4815
4811 2002-01-04 Fernando Perez <fperez@colorado.edu>
4816 2002-01-04 Fernando Perez <fperez@colorado.edu>
4812
4817
4813 * Made deep_reload() off by default. It doesn't always work
4818 * Made deep_reload() off by default. It doesn't always work
4814 exactly as intended, so it's probably safer to have it off. It's
4819 exactly as intended, so it's probably safer to have it off. It's
4815 still available as dreload() anyway, so nothing is lost.
4820 still available as dreload() anyway, so nothing is lost.
4816
4821
4817 2002-01-02 Fernando Perez <fperez@colorado.edu>
4822 2002-01-02 Fernando Perez <fperez@colorado.edu>
4818
4823
4819 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
4824 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
4820 so I wanted an updated release).
4825 so I wanted an updated release).
4821
4826
4822 2001-12-27 Fernando Perez <fperez@colorado.edu>
4827 2001-12-27 Fernando Perez <fperez@colorado.edu>
4823
4828
4824 * IPython/iplib.py (InteractiveShell.interact): Added the original
4829 * IPython/iplib.py (InteractiveShell.interact): Added the original
4825 code from 'code.py' for this module in order to change the
4830 code from 'code.py' for this module in order to change the
4826 handling of a KeyboardInterrupt. This was necessary b/c otherwise
4831 handling of a KeyboardInterrupt. This was necessary b/c otherwise
4827 the history cache would break when the user hit Ctrl-C, and
4832 the history cache would break when the user hit Ctrl-C, and
4828 interact() offers no way to add any hooks to it.
4833 interact() offers no way to add any hooks to it.
4829
4834
4830 2001-12-23 Fernando Perez <fperez@colorado.edu>
4835 2001-12-23 Fernando Perez <fperez@colorado.edu>
4831
4836
4832 * setup.py: added check for 'MANIFEST' before trying to remove
4837 * setup.py: added check for 'MANIFEST' before trying to remove
4833 it. Thanks to Sean Reifschneider.
4838 it. Thanks to Sean Reifschneider.
4834
4839
4835 2001-12-22 Fernando Perez <fperez@colorado.edu>
4840 2001-12-22 Fernando Perez <fperez@colorado.edu>
4836
4841
4837 * Released 0.2.2.
4842 * Released 0.2.2.
4838
4843
4839 * Finished (reasonably) writing the manual. Later will add the
4844 * Finished (reasonably) writing the manual. Later will add the
4840 python-standard navigation stylesheets, but for the time being
4845 python-standard navigation stylesheets, but for the time being
4841 it's fairly complete. Distribution will include html and pdf
4846 it's fairly complete. Distribution will include html and pdf
4842 versions.
4847 versions.
4843
4848
4844 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
4849 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
4845 (MayaVi author).
4850 (MayaVi author).
4846
4851
4847 2001-12-21 Fernando Perez <fperez@colorado.edu>
4852 2001-12-21 Fernando Perez <fperez@colorado.edu>
4848
4853
4849 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
4854 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
4850 good public release, I think (with the manual and the distutils
4855 good public release, I think (with the manual and the distutils
4851 installer). The manual can use some work, but that can go
4856 installer). The manual can use some work, but that can go
4852 slowly. Otherwise I think it's quite nice for end users. Next
4857 slowly. Otherwise I think it's quite nice for end users. Next
4853 summer, rewrite the guts of it...
4858 summer, rewrite the guts of it...
4854
4859
4855 * Changed format of ipythonrc files to use whitespace as the
4860 * Changed format of ipythonrc files to use whitespace as the
4856 separator instead of an explicit '='. Cleaner.
4861 separator instead of an explicit '='. Cleaner.
4857
4862
4858 2001-12-20 Fernando Perez <fperez@colorado.edu>
4863 2001-12-20 Fernando Perez <fperez@colorado.edu>
4859
4864
4860 * Started a manual in LyX. For now it's just a quick merge of the
4865 * Started a manual in LyX. For now it's just a quick merge of the
4861 various internal docstrings and READMEs. Later it may grow into a
4866 various internal docstrings and READMEs. Later it may grow into a
4862 nice, full-blown manual.
4867 nice, full-blown manual.
4863
4868
4864 * Set up a distutils based installer. Installation should now be
4869 * Set up a distutils based installer. Installation should now be
4865 trivially simple for end-users.
4870 trivially simple for end-users.
4866
4871
4867 2001-12-11 Fernando Perez <fperez@colorado.edu>
4872 2001-12-11 Fernando Perez <fperez@colorado.edu>
4868
4873
4869 * Released 0.2.0. First public release, announced it at
4874 * Released 0.2.0. First public release, announced it at
4870 comp.lang.python. From now on, just bugfixes...
4875 comp.lang.python. From now on, just bugfixes...
4871
4876
4872 * Went through all the files, set copyright/license notices and
4877 * Went through all the files, set copyright/license notices and
4873 cleaned up things. Ready for release.
4878 cleaned up things. Ready for release.
4874
4879
4875 2001-12-10 Fernando Perez <fperez@colorado.edu>
4880 2001-12-10 Fernando Perez <fperez@colorado.edu>
4876
4881
4877 * Changed the first-time installer not to use tarfiles. It's more
4882 * Changed the first-time installer not to use tarfiles. It's more
4878 robust now and less unix-dependent. Also makes it easier for
4883 robust now and less unix-dependent. Also makes it easier for
4879 people to later upgrade versions.
4884 people to later upgrade versions.
4880
4885
4881 * Changed @exit to @abort to reflect the fact that it's pretty
4886 * Changed @exit to @abort to reflect the fact that it's pretty
4882 brutal (a sys.exit()). The difference between @abort and Ctrl-D
4887 brutal (a sys.exit()). The difference between @abort and Ctrl-D
4883 becomes significant only when IPyhton is embedded: in that case,
4888 becomes significant only when IPyhton is embedded: in that case,
4884 C-D closes IPython only, but @abort kills the enclosing program
4889 C-D closes IPython only, but @abort kills the enclosing program
4885 too (unless it had called IPython inside a try catching
4890 too (unless it had called IPython inside a try catching
4886 SystemExit).
4891 SystemExit).
4887
4892
4888 * Created Shell module which exposes the actuall IPython Shell
4893 * Created Shell module which exposes the actuall IPython Shell
4889 classes, currently the normal and the embeddable one. This at
4894 classes, currently the normal and the embeddable one. This at
4890 least offers a stable interface we won't need to change when
4895 least offers a stable interface we won't need to change when
4891 (later) the internals are rewritten. That rewrite will be confined
4896 (later) the internals are rewritten. That rewrite will be confined
4892 to iplib and ipmaker, but the Shell interface should remain as is.
4897 to iplib and ipmaker, but the Shell interface should remain as is.
4893
4898
4894 * Added embed module which offers an embeddable IPShell object,
4899 * Added embed module which offers an embeddable IPShell object,
4895 useful to fire up IPython *inside* a running program. Great for
4900 useful to fire up IPython *inside* a running program. Great for
4896 debugging or dynamical data analysis.
4901 debugging or dynamical data analysis.
4897
4902
4898 2001-12-08 Fernando Perez <fperez@colorado.edu>
4903 2001-12-08 Fernando Perez <fperez@colorado.edu>
4899
4904
4900 * Fixed small bug preventing seeing info from methods of defined
4905 * Fixed small bug preventing seeing info from methods of defined
4901 objects (incorrect namespace in _ofind()).
4906 objects (incorrect namespace in _ofind()).
4902
4907
4903 * Documentation cleanup. Moved the main usage docstrings to a
4908 * Documentation cleanup. Moved the main usage docstrings to a
4904 separate file, usage.py (cleaner to maintain, and hopefully in the
4909 separate file, usage.py (cleaner to maintain, and hopefully in the
4905 future some perlpod-like way of producing interactive, man and
4910 future some perlpod-like way of producing interactive, man and
4906 html docs out of it will be found).
4911 html docs out of it will be found).
4907
4912
4908 * Added @profile to see your profile at any time.
4913 * Added @profile to see your profile at any time.
4909
4914
4910 * Added @p as an alias for 'print'. It's especially convenient if
4915 * Added @p as an alias for 'print'. It's especially convenient if
4911 using automagic ('p x' prints x).
4916 using automagic ('p x' prints x).
4912
4917
4913 * Small cleanups and fixes after a pychecker run.
4918 * Small cleanups and fixes after a pychecker run.
4914
4919
4915 * Changed the @cd command to handle @cd - and @cd -<n> for
4920 * Changed the @cd command to handle @cd - and @cd -<n> for
4916 visiting any directory in _dh.
4921 visiting any directory in _dh.
4917
4922
4918 * Introduced _dh, a history of visited directories. @dhist prints
4923 * Introduced _dh, a history of visited directories. @dhist prints
4919 it out with numbers.
4924 it out with numbers.
4920
4925
4921 2001-12-07 Fernando Perez <fperez@colorado.edu>
4926 2001-12-07 Fernando Perez <fperez@colorado.edu>
4922
4927
4923 * Released 0.1.22
4928 * Released 0.1.22
4924
4929
4925 * Made initialization a bit more robust against invalid color
4930 * Made initialization a bit more robust against invalid color
4926 options in user input (exit, not traceback-crash).
4931 options in user input (exit, not traceback-crash).
4927
4932
4928 * Changed the bug crash reporter to write the report only in the
4933 * Changed the bug crash reporter to write the report only in the
4929 user's .ipython directory. That way IPython won't litter people's
4934 user's .ipython directory. That way IPython won't litter people's
4930 hard disks with crash files all over the place. Also print on
4935 hard disks with crash files all over the place. Also print on
4931 screen the necessary mail command.
4936 screen the necessary mail command.
4932
4937
4933 * With the new ultraTB, implemented LightBG color scheme for light
4938 * With the new ultraTB, implemented LightBG color scheme for light
4934 background terminals. A lot of people like white backgrounds, so I
4939 background terminals. A lot of people like white backgrounds, so I
4935 guess we should at least give them something readable.
4940 guess we should at least give them something readable.
4936
4941
4937 2001-12-06 Fernando Perez <fperez@colorado.edu>
4942 2001-12-06 Fernando Perez <fperez@colorado.edu>
4938
4943
4939 * Modified the structure of ultraTB. Now there's a proper class
4944 * Modified the structure of ultraTB. Now there's a proper class
4940 for tables of color schemes which allow adding schemes easily and
4945 for tables of color schemes which allow adding schemes easily and
4941 switching the active scheme without creating a new instance every
4946 switching the active scheme without creating a new instance every
4942 time (which was ridiculous). The syntax for creating new schemes
4947 time (which was ridiculous). The syntax for creating new schemes
4943 is also cleaner. I think ultraTB is finally done, with a clean
4948 is also cleaner. I think ultraTB is finally done, with a clean
4944 class structure. Names are also much cleaner (now there's proper
4949 class structure. Names are also much cleaner (now there's proper
4945 color tables, no need for every variable to also have 'color' in
4950 color tables, no need for every variable to also have 'color' in
4946 its name).
4951 its name).
4947
4952
4948 * Broke down genutils into separate files. Now genutils only
4953 * Broke down genutils into separate files. Now genutils only
4949 contains utility functions, and classes have been moved to their
4954 contains utility functions, and classes have been moved to their
4950 own files (they had enough independent functionality to warrant
4955 own files (they had enough independent functionality to warrant
4951 it): ConfigLoader, OutputTrap, Struct.
4956 it): ConfigLoader, OutputTrap, Struct.
4952
4957
4953 2001-12-05 Fernando Perez <fperez@colorado.edu>
4958 2001-12-05 Fernando Perez <fperez@colorado.edu>
4954
4959
4955 * IPython turns 21! Released version 0.1.21, as a candidate for
4960 * IPython turns 21! Released version 0.1.21, as a candidate for
4956 public consumption. If all goes well, release in a few days.
4961 public consumption. If all goes well, release in a few days.
4957
4962
4958 * Fixed path bug (files in Extensions/ directory wouldn't be found
4963 * Fixed path bug (files in Extensions/ directory wouldn't be found
4959 unless IPython/ was explicitly in sys.path).
4964 unless IPython/ was explicitly in sys.path).
4960
4965
4961 * Extended the FlexCompleter class as MagicCompleter to allow
4966 * Extended the FlexCompleter class as MagicCompleter to allow
4962 completion of @-starting lines.
4967 completion of @-starting lines.
4963
4968
4964 * Created __release__.py file as a central repository for release
4969 * Created __release__.py file as a central repository for release
4965 info that other files can read from.
4970 info that other files can read from.
4966
4971
4967 * Fixed small bug in logging: when logging was turned on in
4972 * Fixed small bug in logging: when logging was turned on in
4968 mid-session, old lines with special meanings (!@?) were being
4973 mid-session, old lines with special meanings (!@?) were being
4969 logged without the prepended comment, which is necessary since
4974 logged without the prepended comment, which is necessary since
4970 they are not truly valid python syntax. This should make session
4975 they are not truly valid python syntax. This should make session
4971 restores produce less errors.
4976 restores produce less errors.
4972
4977
4973 * The namespace cleanup forced me to make a FlexCompleter class
4978 * The namespace cleanup forced me to make a FlexCompleter class
4974 which is nothing but a ripoff of rlcompleter, but with selectable
4979 which is nothing but a ripoff of rlcompleter, but with selectable
4975 namespace (rlcompleter only works in __main__.__dict__). I'll try
4980 namespace (rlcompleter only works in __main__.__dict__). I'll try
4976 to submit a note to the authors to see if this change can be
4981 to submit a note to the authors to see if this change can be
4977 incorporated in future rlcompleter releases (Dec.6: done)
4982 incorporated in future rlcompleter releases (Dec.6: done)
4978
4983
4979 * More fixes to namespace handling. It was a mess! Now all
4984 * More fixes to namespace handling. It was a mess! Now all
4980 explicit references to __main__.__dict__ are gone (except when
4985 explicit references to __main__.__dict__ are gone (except when
4981 really needed) and everything is handled through the namespace
4986 really needed) and everything is handled through the namespace
4982 dicts in the IPython instance. We seem to be getting somewhere
4987 dicts in the IPython instance. We seem to be getting somewhere
4983 with this, finally...
4988 with this, finally...
4984
4989
4985 * Small documentation updates.
4990 * Small documentation updates.
4986
4991
4987 * Created the Extensions directory under IPython (with an
4992 * Created the Extensions directory under IPython (with an
4988 __init__.py). Put the PhysicalQ stuff there. This directory should
4993 __init__.py). Put the PhysicalQ stuff there. This directory should
4989 be used for all special-purpose extensions.
4994 be used for all special-purpose extensions.
4990
4995
4991 * File renaming:
4996 * File renaming:
4992 ipythonlib --> ipmaker
4997 ipythonlib --> ipmaker
4993 ipplib --> iplib
4998 ipplib --> iplib
4994 This makes a bit more sense in terms of what these files actually do.
4999 This makes a bit more sense in terms of what these files actually do.
4995
5000
4996 * Moved all the classes and functions in ipythonlib to ipplib, so
5001 * Moved all the classes and functions in ipythonlib to ipplib, so
4997 now ipythonlib only has make_IPython(). This will ease up its
5002 now ipythonlib only has make_IPython(). This will ease up its
4998 splitting in smaller functional chunks later.
5003 splitting in smaller functional chunks later.
4999
5004
5000 * Cleaned up (done, I think) output of @whos. Better column
5005 * Cleaned up (done, I think) output of @whos. Better column
5001 formatting, and now shows str(var) for as much as it can, which is
5006 formatting, and now shows str(var) for as much as it can, which is
5002 typically what one gets with a 'print var'.
5007 typically what one gets with a 'print var'.
5003
5008
5004 2001-12-04 Fernando Perez <fperez@colorado.edu>
5009 2001-12-04 Fernando Perez <fperez@colorado.edu>
5005
5010
5006 * Fixed namespace problems. Now builtin/IPyhton/user names get
5011 * Fixed namespace problems. Now builtin/IPyhton/user names get
5007 properly reported in their namespace. Internal namespace handling
5012 properly reported in their namespace. Internal namespace handling
5008 is finally getting decent (not perfect yet, but much better than
5013 is finally getting decent (not perfect yet, but much better than
5009 the ad-hoc mess we had).
5014 the ad-hoc mess we had).
5010
5015
5011 * Removed -exit option. If people just want to run a python
5016 * Removed -exit option. If people just want to run a python
5012 script, that's what the normal interpreter is for. Less
5017 script, that's what the normal interpreter is for. Less
5013 unnecessary options, less chances for bugs.
5018 unnecessary options, less chances for bugs.
5014
5019
5015 * Added a crash handler which generates a complete post-mortem if
5020 * Added a crash handler which generates a complete post-mortem if
5016 IPython crashes. This will help a lot in tracking bugs down the
5021 IPython crashes. This will help a lot in tracking bugs down the
5017 road.
5022 road.
5018
5023
5019 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
5024 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
5020 which were boud to functions being reassigned would bypass the
5025 which were boud to functions being reassigned would bypass the
5021 logger, breaking the sync of _il with the prompt counter. This
5026 logger, breaking the sync of _il with the prompt counter. This
5022 would then crash IPython later when a new line was logged.
5027 would then crash IPython later when a new line was logged.
5023
5028
5024 2001-12-02 Fernando Perez <fperez@colorado.edu>
5029 2001-12-02 Fernando Perez <fperez@colorado.edu>
5025
5030
5026 * Made IPython a package. This means people don't have to clutter
5031 * Made IPython a package. This means people don't have to clutter
5027 their sys.path with yet another directory. Changed the INSTALL
5032 their sys.path with yet another directory. Changed the INSTALL
5028 file accordingly.
5033 file accordingly.
5029
5034
5030 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
5035 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
5031 sorts its output (so @who shows it sorted) and @whos formats the
5036 sorts its output (so @who shows it sorted) and @whos formats the
5032 table according to the width of the first column. Nicer, easier to
5037 table according to the width of the first column. Nicer, easier to
5033 read. Todo: write a generic table_format() which takes a list of
5038 read. Todo: write a generic table_format() which takes a list of
5034 lists and prints it nicely formatted, with optional row/column
5039 lists and prints it nicely formatted, with optional row/column
5035 separators and proper padding and justification.
5040 separators and proper padding and justification.
5036
5041
5037 * Released 0.1.20
5042 * Released 0.1.20
5038
5043
5039 * Fixed bug in @log which would reverse the inputcache list (a
5044 * Fixed bug in @log which would reverse the inputcache list (a
5040 copy operation was missing).
5045 copy operation was missing).
5041
5046
5042 * Code cleanup. @config was changed to use page(). Better, since
5047 * Code cleanup. @config was changed to use page(). Better, since
5043 its output is always quite long.
5048 its output is always quite long.
5044
5049
5045 * Itpl is back as a dependency. I was having too many problems
5050 * Itpl is back as a dependency. I was having too many problems
5046 getting the parametric aliases to work reliably, and it's just
5051 getting the parametric aliases to work reliably, and it's just
5047 easier to code weird string operations with it than playing %()s
5052 easier to code weird string operations with it than playing %()s
5048 games. It's only ~6k, so I don't think it's too big a deal.
5053 games. It's only ~6k, so I don't think it's too big a deal.
5049
5054
5050 * Found (and fixed) a very nasty bug with history. !lines weren't
5055 * Found (and fixed) a very nasty bug with history. !lines weren't
5051 getting cached, and the out of sync caches would crash
5056 getting cached, and the out of sync caches would crash
5052 IPython. Fixed it by reorganizing the prefilter/handlers/logger
5057 IPython. Fixed it by reorganizing the prefilter/handlers/logger
5053 division of labor a bit better. Bug fixed, cleaner structure.
5058 division of labor a bit better. Bug fixed, cleaner structure.
5054
5059
5055 2001-12-01 Fernando Perez <fperez@colorado.edu>
5060 2001-12-01 Fernando Perez <fperez@colorado.edu>
5056
5061
5057 * Released 0.1.19
5062 * Released 0.1.19
5058
5063
5059 * Added option -n to @hist to prevent line number printing. Much
5064 * Added option -n to @hist to prevent line number printing. Much
5060 easier to copy/paste code this way.
5065 easier to copy/paste code this way.
5061
5066
5062 * Created global _il to hold the input list. Allows easy
5067 * Created global _il to hold the input list. Allows easy
5063 re-execution of blocks of code by slicing it (inspired by Janko's
5068 re-execution of blocks of code by slicing it (inspired by Janko's
5064 comment on 'macros').
5069 comment on 'macros').
5065
5070
5066 * Small fixes and doc updates.
5071 * Small fixes and doc updates.
5067
5072
5068 * Rewrote @history function (was @h). Renamed it to @hist, @h is
5073 * Rewrote @history function (was @h). Renamed it to @hist, @h is
5069 much too fragile with automagic. Handles properly multi-line
5074 much too fragile with automagic. Handles properly multi-line
5070 statements and takes parameters.
5075 statements and takes parameters.
5071
5076
5072 2001-11-30 Fernando Perez <fperez@colorado.edu>
5077 2001-11-30 Fernando Perez <fperez@colorado.edu>
5073
5078
5074 * Version 0.1.18 released.
5079 * Version 0.1.18 released.
5075
5080
5076 * Fixed nasty namespace bug in initial module imports.
5081 * Fixed nasty namespace bug in initial module imports.
5077
5082
5078 * Added copyright/license notes to all code files (except
5083 * Added copyright/license notes to all code files (except
5079 DPyGetOpt). For the time being, LGPL. That could change.
5084 DPyGetOpt). For the time being, LGPL. That could change.
5080
5085
5081 * Rewrote a much nicer README, updated INSTALL, cleaned up
5086 * Rewrote a much nicer README, updated INSTALL, cleaned up
5082 ipythonrc-* samples.
5087 ipythonrc-* samples.
5083
5088
5084 * Overall code/documentation cleanup. Basically ready for
5089 * Overall code/documentation cleanup. Basically ready for
5085 release. Only remaining thing: licence decision (LGPL?).
5090 release. Only remaining thing: licence decision (LGPL?).
5086
5091
5087 * Converted load_config to a class, ConfigLoader. Now recursion
5092 * Converted load_config to a class, ConfigLoader. Now recursion
5088 control is better organized. Doesn't include the same file twice.
5093 control is better organized. Doesn't include the same file twice.
5089
5094
5090 2001-11-29 Fernando Perez <fperez@colorado.edu>
5095 2001-11-29 Fernando Perez <fperez@colorado.edu>
5091
5096
5092 * Got input history working. Changed output history variables from
5097 * Got input history working. Changed output history variables from
5093 _p to _o so that _i is for input and _o for output. Just cleaner
5098 _p to _o so that _i is for input and _o for output. Just cleaner
5094 convention.
5099 convention.
5095
5100
5096 * Implemented parametric aliases. This pretty much allows the
5101 * Implemented parametric aliases. This pretty much allows the
5097 alias system to offer full-blown shell convenience, I think.
5102 alias system to offer full-blown shell convenience, I think.
5098
5103
5099 * Version 0.1.17 released, 0.1.18 opened.
5104 * Version 0.1.17 released, 0.1.18 opened.
5100
5105
5101 * dot_ipython/ipythonrc (alias): added documentation.
5106 * dot_ipython/ipythonrc (alias): added documentation.
5102 (xcolor): Fixed small bug (xcolors -> xcolor)
5107 (xcolor): Fixed small bug (xcolors -> xcolor)
5103
5108
5104 * Changed the alias system. Now alias is a magic command to define
5109 * Changed the alias system. Now alias is a magic command to define
5105 aliases just like the shell. Rationale: the builtin magics should
5110 aliases just like the shell. Rationale: the builtin magics should
5106 be there for things deeply connected to IPython's
5111 be there for things deeply connected to IPython's
5107 architecture. And this is a much lighter system for what I think
5112 architecture. And this is a much lighter system for what I think
5108 is the really important feature: allowing users to define quickly
5113 is the really important feature: allowing users to define quickly
5109 magics that will do shell things for them, so they can customize
5114 magics that will do shell things for them, so they can customize
5110 IPython easily to match their work habits. If someone is really
5115 IPython easily to match their work habits. If someone is really
5111 desperate to have another name for a builtin alias, they can
5116 desperate to have another name for a builtin alias, they can
5112 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
5117 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
5113 works.
5118 works.
5114
5119
5115 2001-11-28 Fernando Perez <fperez@colorado.edu>
5120 2001-11-28 Fernando Perez <fperez@colorado.edu>
5116
5121
5117 * Changed @file so that it opens the source file at the proper
5122 * Changed @file so that it opens the source file at the proper
5118 line. Since it uses less, if your EDITOR environment is
5123 line. Since it uses less, if your EDITOR environment is
5119 configured, typing v will immediately open your editor of choice
5124 configured, typing v will immediately open your editor of choice
5120 right at the line where the object is defined. Not as quick as
5125 right at the line where the object is defined. Not as quick as
5121 having a direct @edit command, but for all intents and purposes it
5126 having a direct @edit command, but for all intents and purposes it
5122 works. And I don't have to worry about writing @edit to deal with
5127 works. And I don't have to worry about writing @edit to deal with
5123 all the editors, less does that.
5128 all the editors, less does that.
5124
5129
5125 * Version 0.1.16 released, 0.1.17 opened.
5130 * Version 0.1.16 released, 0.1.17 opened.
5126
5131
5127 * Fixed some nasty bugs in the page/page_dumb combo that could
5132 * Fixed some nasty bugs in the page/page_dumb combo that could
5128 crash IPython.
5133 crash IPython.
5129
5134
5130 2001-11-27 Fernando Perez <fperez@colorado.edu>
5135 2001-11-27 Fernando Perez <fperez@colorado.edu>
5131
5136
5132 * Version 0.1.15 released, 0.1.16 opened.
5137 * Version 0.1.15 released, 0.1.16 opened.
5133
5138
5134 * Finally got ? and ?? to work for undefined things: now it's
5139 * Finally got ? and ?? to work for undefined things: now it's
5135 possible to type {}.get? and get information about the get method
5140 possible to type {}.get? and get information about the get method
5136 of dicts, or os.path? even if only os is defined (so technically
5141 of dicts, or os.path? even if only os is defined (so technically
5137 os.path isn't). Works at any level. For example, after import os,
5142 os.path isn't). Works at any level. For example, after import os,
5138 os?, os.path?, os.path.abspath? all work. This is great, took some
5143 os?, os.path?, os.path.abspath? all work. This is great, took some
5139 work in _ofind.
5144 work in _ofind.
5140
5145
5141 * Fixed more bugs with logging. The sanest way to do it was to add
5146 * Fixed more bugs with logging. The sanest way to do it was to add
5142 to @log a 'mode' parameter. Killed two in one shot (this mode
5147 to @log a 'mode' parameter. Killed two in one shot (this mode
5143 option was a request of Janko's). I think it's finally clean
5148 option was a request of Janko's). I think it's finally clean
5144 (famous last words).
5149 (famous last words).
5145
5150
5146 * Added a page_dumb() pager which does a decent job of paging on
5151 * Added a page_dumb() pager which does a decent job of paging on
5147 screen, if better things (like less) aren't available. One less
5152 screen, if better things (like less) aren't available. One less
5148 unix dependency (someday maybe somebody will port this to
5153 unix dependency (someday maybe somebody will port this to
5149 windows).
5154 windows).
5150
5155
5151 * Fixed problem in magic_log: would lock of logging out if log
5156 * Fixed problem in magic_log: would lock of logging out if log
5152 creation failed (because it would still think it had succeeded).
5157 creation failed (because it would still think it had succeeded).
5153
5158
5154 * Improved the page() function using curses to auto-detect screen
5159 * Improved the page() function using curses to auto-detect screen
5155 size. Now it can make a much better decision on whether to print
5160 size. Now it can make a much better decision on whether to print
5156 or page a string. Option screen_length was modified: a value 0
5161 or page a string. Option screen_length was modified: a value 0
5157 means auto-detect, and that's the default now.
5162 means auto-detect, and that's the default now.
5158
5163
5159 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
5164 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
5160 go out. I'll test it for a few days, then talk to Janko about
5165 go out. I'll test it for a few days, then talk to Janko about
5161 licences and announce it.
5166 licences and announce it.
5162
5167
5163 * Fixed the length of the auto-generated ---> prompt which appears
5168 * Fixed the length of the auto-generated ---> prompt which appears
5164 for auto-parens and auto-quotes. Getting this right isn't trivial,
5169 for auto-parens and auto-quotes. Getting this right isn't trivial,
5165 with all the color escapes, different prompt types and optional
5170 with all the color escapes, different prompt types and optional
5166 separators. But it seems to be working in all the combinations.
5171 separators. But it seems to be working in all the combinations.
5167
5172
5168 2001-11-26 Fernando Perez <fperez@colorado.edu>
5173 2001-11-26 Fernando Perez <fperez@colorado.edu>
5169
5174
5170 * Wrote a regexp filter to get option types from the option names
5175 * Wrote a regexp filter to get option types from the option names
5171 string. This eliminates the need to manually keep two duplicate
5176 string. This eliminates the need to manually keep two duplicate
5172 lists.
5177 lists.
5173
5178
5174 * Removed the unneeded check_option_names. Now options are handled
5179 * Removed the unneeded check_option_names. Now options are handled
5175 in a much saner manner and it's easy to visually check that things
5180 in a much saner manner and it's easy to visually check that things
5176 are ok.
5181 are ok.
5177
5182
5178 * Updated version numbers on all files I modified to carry a
5183 * Updated version numbers on all files I modified to carry a
5179 notice so Janko and Nathan have clear version markers.
5184 notice so Janko and Nathan have clear version markers.
5180
5185
5181 * Updated docstring for ultraTB with my changes. I should send
5186 * Updated docstring for ultraTB with my changes. I should send
5182 this to Nathan.
5187 this to Nathan.
5183
5188
5184 * Lots of small fixes. Ran everything through pychecker again.
5189 * Lots of small fixes. Ran everything through pychecker again.
5185
5190
5186 * Made loading of deep_reload an cmd line option. If it's not too
5191 * Made loading of deep_reload an cmd line option. If it's not too
5187 kosher, now people can just disable it. With -nodeep_reload it's
5192 kosher, now people can just disable it. With -nodeep_reload it's
5188 still available as dreload(), it just won't overwrite reload().
5193 still available as dreload(), it just won't overwrite reload().
5189
5194
5190 * Moved many options to the no| form (-opt and -noopt
5195 * Moved many options to the no| form (-opt and -noopt
5191 accepted). Cleaner.
5196 accepted). Cleaner.
5192
5197
5193 * Changed magic_log so that if called with no parameters, it uses
5198 * Changed magic_log so that if called with no parameters, it uses
5194 'rotate' mode. That way auto-generated logs aren't automatically
5199 'rotate' mode. That way auto-generated logs aren't automatically
5195 over-written. For normal logs, now a backup is made if it exists
5200 over-written. For normal logs, now a backup is made if it exists
5196 (only 1 level of backups). A new 'backup' mode was added to the
5201 (only 1 level of backups). A new 'backup' mode was added to the
5197 Logger class to support this. This was a request by Janko.
5202 Logger class to support this. This was a request by Janko.
5198
5203
5199 * Added @logoff/@logon to stop/restart an active log.
5204 * Added @logoff/@logon to stop/restart an active log.
5200
5205
5201 * Fixed a lot of bugs in log saving/replay. It was pretty
5206 * Fixed a lot of bugs in log saving/replay. It was pretty
5202 broken. Now special lines (!@,/) appear properly in the command
5207 broken. Now special lines (!@,/) appear properly in the command
5203 history after a log replay.
5208 history after a log replay.
5204
5209
5205 * Tried and failed to implement full session saving via pickle. My
5210 * Tried and failed to implement full session saving via pickle. My
5206 idea was to pickle __main__.__dict__, but modules can't be
5211 idea was to pickle __main__.__dict__, but modules can't be
5207 pickled. This would be a better alternative to replaying logs, but
5212 pickled. This would be a better alternative to replaying logs, but
5208 seems quite tricky to get to work. Changed -session to be called
5213 seems quite tricky to get to work. Changed -session to be called
5209 -logplay, which more accurately reflects what it does. And if we
5214 -logplay, which more accurately reflects what it does. And if we
5210 ever get real session saving working, -session is now available.
5215 ever get real session saving working, -session is now available.
5211
5216
5212 * Implemented color schemes for prompts also. As for tracebacks,
5217 * Implemented color schemes for prompts also. As for tracebacks,
5213 currently only NoColor and Linux are supported. But now the
5218 currently only NoColor and Linux are supported. But now the
5214 infrastructure is in place, based on a generic ColorScheme
5219 infrastructure is in place, based on a generic ColorScheme
5215 class. So writing and activating new schemes both for the prompts
5220 class. So writing and activating new schemes both for the prompts
5216 and the tracebacks should be straightforward.
5221 and the tracebacks should be straightforward.
5217
5222
5218 * Version 0.1.13 released, 0.1.14 opened.
5223 * Version 0.1.13 released, 0.1.14 opened.
5219
5224
5220 * Changed handling of options for output cache. Now counter is
5225 * Changed handling of options for output cache. Now counter is
5221 hardwired starting at 1 and one specifies the maximum number of
5226 hardwired starting at 1 and one specifies the maximum number of
5222 entries *in the outcache* (not the max prompt counter). This is
5227 entries *in the outcache* (not the max prompt counter). This is
5223 much better, since many statements won't increase the cache
5228 much better, since many statements won't increase the cache
5224 count. It also eliminated some confusing options, now there's only
5229 count. It also eliminated some confusing options, now there's only
5225 one: cache_size.
5230 one: cache_size.
5226
5231
5227 * Added 'alias' magic function and magic_alias option in the
5232 * Added 'alias' magic function and magic_alias option in the
5228 ipythonrc file. Now the user can easily define whatever names he
5233 ipythonrc file. Now the user can easily define whatever names he
5229 wants for the magic functions without having to play weird
5234 wants for the magic functions without having to play weird
5230 namespace games. This gives IPython a real shell-like feel.
5235 namespace games. This gives IPython a real shell-like feel.
5231
5236
5232 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
5237 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
5233 @ or not).
5238 @ or not).
5234
5239
5235 This was one of the last remaining 'visible' bugs (that I know
5240 This was one of the last remaining 'visible' bugs (that I know
5236 of). I think if I can clean up the session loading so it works
5241 of). I think if I can clean up the session loading so it works
5237 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
5242 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
5238 about licensing).
5243 about licensing).
5239
5244
5240 2001-11-25 Fernando Perez <fperez@colorado.edu>
5245 2001-11-25 Fernando Perez <fperez@colorado.edu>
5241
5246
5242 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
5247 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
5243 there's a cleaner distinction between what ? and ?? show.
5248 there's a cleaner distinction between what ? and ?? show.
5244
5249
5245 * Added screen_length option. Now the user can define his own
5250 * Added screen_length option. Now the user can define his own
5246 screen size for page() operations.
5251 screen size for page() operations.
5247
5252
5248 * Implemented magic shell-like functions with automatic code
5253 * Implemented magic shell-like functions with automatic code
5249 generation. Now adding another function is just a matter of adding
5254 generation. Now adding another function is just a matter of adding
5250 an entry to a dict, and the function is dynamically generated at
5255 an entry to a dict, and the function is dynamically generated at
5251 run-time. Python has some really cool features!
5256 run-time. Python has some really cool features!
5252
5257
5253 * Renamed many options to cleanup conventions a little. Now all
5258 * Renamed many options to cleanup conventions a little. Now all
5254 are lowercase, and only underscores where needed. Also in the code
5259 are lowercase, and only underscores where needed. Also in the code
5255 option name tables are clearer.
5260 option name tables are clearer.
5256
5261
5257 * Changed prompts a little. Now input is 'In [n]:' instead of
5262 * Changed prompts a little. Now input is 'In [n]:' instead of
5258 'In[n]:='. This allows it the numbers to be aligned with the
5263 'In[n]:='. This allows it the numbers to be aligned with the
5259 Out[n] numbers, and removes usage of ':=' which doesn't exist in
5264 Out[n] numbers, and removes usage of ':=' which doesn't exist in
5260 Python (it was a Mathematica thing). The '...' continuation prompt
5265 Python (it was a Mathematica thing). The '...' continuation prompt
5261 was also changed a little to align better.
5266 was also changed a little to align better.
5262
5267
5263 * Fixed bug when flushing output cache. Not all _p<n> variables
5268 * Fixed bug when flushing output cache. Not all _p<n> variables
5264 exist, so their deletion needs to be wrapped in a try:
5269 exist, so their deletion needs to be wrapped in a try:
5265
5270
5266 * Figured out how to properly use inspect.formatargspec() (it
5271 * Figured out how to properly use inspect.formatargspec() (it
5267 requires the args preceded by *). So I removed all the code from
5272 requires the args preceded by *). So I removed all the code from
5268 _get_pdef in Magic, which was just replicating that.
5273 _get_pdef in Magic, which was just replicating that.
5269
5274
5270 * Added test to prefilter to allow redefining magic function names
5275 * Added test to prefilter to allow redefining magic function names
5271 as variables. This is ok, since the @ form is always available,
5276 as variables. This is ok, since the @ form is always available,
5272 but whe should allow the user to define a variable called 'ls' if
5277 but whe should allow the user to define a variable called 'ls' if
5273 he needs it.
5278 he needs it.
5274
5279
5275 * Moved the ToDo information from README into a separate ToDo.
5280 * Moved the ToDo information from README into a separate ToDo.
5276
5281
5277 * General code cleanup and small bugfixes. I think it's close to a
5282 * General code cleanup and small bugfixes. I think it's close to a
5278 state where it can be released, obviously with a big 'beta'
5283 state where it can be released, obviously with a big 'beta'
5279 warning on it.
5284 warning on it.
5280
5285
5281 * Got the magic function split to work. Now all magics are defined
5286 * Got the magic function split to work. Now all magics are defined
5282 in a separate class. It just organizes things a bit, and now
5287 in a separate class. It just organizes things a bit, and now
5283 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
5288 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
5284 was too long).
5289 was too long).
5285
5290
5286 * Changed @clear to @reset to avoid potential confusions with
5291 * Changed @clear to @reset to avoid potential confusions with
5287 the shell command clear. Also renamed @cl to @clear, which does
5292 the shell command clear. Also renamed @cl to @clear, which does
5288 exactly what people expect it to from their shell experience.
5293 exactly what people expect it to from their shell experience.
5289
5294
5290 Added a check to the @reset command (since it's so
5295 Added a check to the @reset command (since it's so
5291 destructive, it's probably a good idea to ask for confirmation).
5296 destructive, it's probably a good idea to ask for confirmation).
5292 But now reset only works for full namespace resetting. Since the
5297 But now reset only works for full namespace resetting. Since the
5293 del keyword is already there for deleting a few specific
5298 del keyword is already there for deleting a few specific
5294 variables, I don't see the point of having a redundant magic
5299 variables, I don't see the point of having a redundant magic
5295 function for the same task.
5300 function for the same task.
5296
5301
5297 2001-11-24 Fernando Perez <fperez@colorado.edu>
5302 2001-11-24 Fernando Perez <fperez@colorado.edu>
5298
5303
5299 * Updated the builtin docs (esp. the ? ones).
5304 * Updated the builtin docs (esp. the ? ones).
5300
5305
5301 * Ran all the code through pychecker. Not terribly impressed with
5306 * Ran all the code through pychecker. Not terribly impressed with
5302 it: lots of spurious warnings and didn't really find anything of
5307 it: lots of spurious warnings and didn't really find anything of
5303 substance (just a few modules being imported and not used).
5308 substance (just a few modules being imported and not used).
5304
5309
5305 * Implemented the new ultraTB functionality into IPython. New
5310 * Implemented the new ultraTB functionality into IPython. New
5306 option: xcolors. This chooses color scheme. xmode now only selects
5311 option: xcolors. This chooses color scheme. xmode now only selects
5307 between Plain and Verbose. Better orthogonality.
5312 between Plain and Verbose. Better orthogonality.
5308
5313
5309 * Large rewrite of ultraTB. Much cleaner now, with a separation of
5314 * Large rewrite of ultraTB. Much cleaner now, with a separation of
5310 mode and color scheme for the exception handlers. Now it's
5315 mode and color scheme for the exception handlers. Now it's
5311 possible to have the verbose traceback with no coloring.
5316 possible to have the verbose traceback with no coloring.
5312
5317
5313 2001-11-23 Fernando Perez <fperez@colorado.edu>
5318 2001-11-23 Fernando Perez <fperez@colorado.edu>
5314
5319
5315 * Version 0.1.12 released, 0.1.13 opened.
5320 * Version 0.1.12 released, 0.1.13 opened.
5316
5321
5317 * Removed option to set auto-quote and auto-paren escapes by
5322 * Removed option to set auto-quote and auto-paren escapes by
5318 user. The chances of breaking valid syntax are just too high. If
5323 user. The chances of breaking valid syntax are just too high. If
5319 someone *really* wants, they can always dig into the code.
5324 someone *really* wants, they can always dig into the code.
5320
5325
5321 * Made prompt separators configurable.
5326 * Made prompt separators configurable.
5322
5327
5323 2001-11-22 Fernando Perez <fperez@colorado.edu>
5328 2001-11-22 Fernando Perez <fperez@colorado.edu>
5324
5329
5325 * Small bugfixes in many places.
5330 * Small bugfixes in many places.
5326
5331
5327 * Removed the MyCompleter class from ipplib. It seemed redundant
5332 * Removed the MyCompleter class from ipplib. It seemed redundant
5328 with the C-p,C-n history search functionality. Less code to
5333 with the C-p,C-n history search functionality. Less code to
5329 maintain.
5334 maintain.
5330
5335
5331 * Moved all the original ipython.py code into ipythonlib.py. Right
5336 * Moved all the original ipython.py code into ipythonlib.py. Right
5332 now it's just one big dump into a function called make_IPython, so
5337 now it's just one big dump into a function called make_IPython, so
5333 no real modularity has been gained. But at least it makes the
5338 no real modularity has been gained. But at least it makes the
5334 wrapper script tiny, and since ipythonlib is a module, it gets
5339 wrapper script tiny, and since ipythonlib is a module, it gets
5335 compiled and startup is much faster.
5340 compiled and startup is much faster.
5336
5341
5337 This is a reasobably 'deep' change, so we should test it for a
5342 This is a reasobably 'deep' change, so we should test it for a
5338 while without messing too much more with the code.
5343 while without messing too much more with the code.
5339
5344
5340 2001-11-21 Fernando Perez <fperez@colorado.edu>
5345 2001-11-21 Fernando Perez <fperez@colorado.edu>
5341
5346
5342 * Version 0.1.11 released, 0.1.12 opened for further work.
5347 * Version 0.1.11 released, 0.1.12 opened for further work.
5343
5348
5344 * Removed dependency on Itpl. It was only needed in one place. It
5349 * Removed dependency on Itpl. It was only needed in one place. It
5345 would be nice if this became part of python, though. It makes life
5350 would be nice if this became part of python, though. It makes life
5346 *a lot* easier in some cases.
5351 *a lot* easier in some cases.
5347
5352
5348 * Simplified the prefilter code a bit. Now all handlers are
5353 * Simplified the prefilter code a bit. Now all handlers are
5349 expected to explicitly return a value (at least a blank string).
5354 expected to explicitly return a value (at least a blank string).
5350
5355
5351 * Heavy edits in ipplib. Removed the help system altogether. Now
5356 * Heavy edits in ipplib. Removed the help system altogether. Now
5352 obj?/?? is used for inspecting objects, a magic @doc prints
5357 obj?/?? is used for inspecting objects, a magic @doc prints
5353 docstrings, and full-blown Python help is accessed via the 'help'
5358 docstrings, and full-blown Python help is accessed via the 'help'
5354 keyword. This cleans up a lot of code (less to maintain) and does
5359 keyword. This cleans up a lot of code (less to maintain) and does
5355 the job. Since 'help' is now a standard Python component, might as
5360 the job. Since 'help' is now a standard Python component, might as
5356 well use it and remove duplicate functionality.
5361 well use it and remove duplicate functionality.
5357
5362
5358 Also removed the option to use ipplib as a standalone program. By
5363 Also removed the option to use ipplib as a standalone program. By
5359 now it's too dependent on other parts of IPython to function alone.
5364 now it's too dependent on other parts of IPython to function alone.
5360
5365
5361 * Fixed bug in genutils.pager. It would crash if the pager was
5366 * Fixed bug in genutils.pager. It would crash if the pager was
5362 exited immediately after opening (broken pipe).
5367 exited immediately after opening (broken pipe).
5363
5368
5364 * Trimmed down the VerboseTB reporting a little. The header is
5369 * Trimmed down the VerboseTB reporting a little. The header is
5365 much shorter now and the repeated exception arguments at the end
5370 much shorter now and the repeated exception arguments at the end
5366 have been removed. For interactive use the old header seemed a bit
5371 have been removed. For interactive use the old header seemed a bit
5367 excessive.
5372 excessive.
5368
5373
5369 * Fixed small bug in output of @whos for variables with multi-word
5374 * Fixed small bug in output of @whos for variables with multi-word
5370 types (only first word was displayed).
5375 types (only first word was displayed).
5371
5376
5372 2001-11-17 Fernando Perez <fperez@colorado.edu>
5377 2001-11-17 Fernando Perez <fperez@colorado.edu>
5373
5378
5374 * Version 0.1.10 released, 0.1.11 opened for further work.
5379 * Version 0.1.10 released, 0.1.11 opened for further work.
5375
5380
5376 * Modified dirs and friends. dirs now *returns* the stack (not
5381 * Modified dirs and friends. dirs now *returns* the stack (not
5377 prints), so one can manipulate it as a variable. Convenient to
5382 prints), so one can manipulate it as a variable. Convenient to
5378 travel along many directories.
5383 travel along many directories.
5379
5384
5380 * Fixed bug in magic_pdef: would only work with functions with
5385 * Fixed bug in magic_pdef: would only work with functions with
5381 arguments with default values.
5386 arguments with default values.
5382
5387
5383 2001-11-14 Fernando Perez <fperez@colorado.edu>
5388 2001-11-14 Fernando Perez <fperez@colorado.edu>
5384
5389
5385 * Added the PhysicsInput stuff to dot_ipython so it ships as an
5390 * Added the PhysicsInput stuff to dot_ipython so it ships as an
5386 example with IPython. Various other minor fixes and cleanups.
5391 example with IPython. Various other minor fixes and cleanups.
5387
5392
5388 * Version 0.1.9 released, 0.1.10 opened for further work.
5393 * Version 0.1.9 released, 0.1.10 opened for further work.
5389
5394
5390 * Added sys.path to the list of directories searched in the
5395 * Added sys.path to the list of directories searched in the
5391 execfile= option. It used to be the current directory and the
5396 execfile= option. It used to be the current directory and the
5392 user's IPYTHONDIR only.
5397 user's IPYTHONDIR only.
5393
5398
5394 2001-11-13 Fernando Perez <fperez@colorado.edu>
5399 2001-11-13 Fernando Perez <fperez@colorado.edu>
5395
5400
5396 * Reinstated the raw_input/prefilter separation that Janko had
5401 * Reinstated the raw_input/prefilter separation that Janko had
5397 initially. This gives a more convenient setup for extending the
5402 initially. This gives a more convenient setup for extending the
5398 pre-processor from the outside: raw_input always gets a string,
5403 pre-processor from the outside: raw_input always gets a string,
5399 and prefilter has to process it. We can then redefine prefilter
5404 and prefilter has to process it. We can then redefine prefilter
5400 from the outside and implement extensions for special
5405 from the outside and implement extensions for special
5401 purposes.
5406 purposes.
5402
5407
5403 Today I got one for inputting PhysicalQuantity objects
5408 Today I got one for inputting PhysicalQuantity objects
5404 (from Scientific) without needing any function calls at
5409 (from Scientific) without needing any function calls at
5405 all. Extremely convenient, and it's all done as a user-level
5410 all. Extremely convenient, and it's all done as a user-level
5406 extension (no IPython code was touched). Now instead of:
5411 extension (no IPython code was touched). Now instead of:
5407 a = PhysicalQuantity(4.2,'m/s**2')
5412 a = PhysicalQuantity(4.2,'m/s**2')
5408 one can simply say
5413 one can simply say
5409 a = 4.2 m/s**2
5414 a = 4.2 m/s**2
5410 or even
5415 or even
5411 a = 4.2 m/s^2
5416 a = 4.2 m/s^2
5412
5417
5413 I use this, but it's also a proof of concept: IPython really is
5418 I use this, but it's also a proof of concept: IPython really is
5414 fully user-extensible, even at the level of the parsing of the
5419 fully user-extensible, even at the level of the parsing of the
5415 command line. It's not trivial, but it's perfectly doable.
5420 command line. It's not trivial, but it's perfectly doable.
5416
5421
5417 * Added 'add_flip' method to inclusion conflict resolver. Fixes
5422 * Added 'add_flip' method to inclusion conflict resolver. Fixes
5418 the problem of modules being loaded in the inverse order in which
5423 the problem of modules being loaded in the inverse order in which
5419 they were defined in
5424 they were defined in
5420
5425
5421 * Version 0.1.8 released, 0.1.9 opened for further work.
5426 * Version 0.1.8 released, 0.1.9 opened for further work.
5422
5427
5423 * Added magics pdef, source and file. They respectively show the
5428 * Added magics pdef, source and file. They respectively show the
5424 definition line ('prototype' in C), source code and full python
5429 definition line ('prototype' in C), source code and full python
5425 file for any callable object. The object inspector oinfo uses
5430 file for any callable object. The object inspector oinfo uses
5426 these to show the same information.
5431 these to show the same information.
5427
5432
5428 * Version 0.1.7 released, 0.1.8 opened for further work.
5433 * Version 0.1.7 released, 0.1.8 opened for further work.
5429
5434
5430 * Separated all the magic functions into a class called Magic. The
5435 * Separated all the magic functions into a class called Magic. The
5431 InteractiveShell class was becoming too big for Xemacs to handle
5436 InteractiveShell class was becoming too big for Xemacs to handle
5432 (de-indenting a line would lock it up for 10 seconds while it
5437 (de-indenting a line would lock it up for 10 seconds while it
5433 backtracked on the whole class!)
5438 backtracked on the whole class!)
5434
5439
5435 FIXME: didn't work. It can be done, but right now namespaces are
5440 FIXME: didn't work. It can be done, but right now namespaces are
5436 all messed up. Do it later (reverted it for now, so at least
5441 all messed up. Do it later (reverted it for now, so at least
5437 everything works as before).
5442 everything works as before).
5438
5443
5439 * Got the object introspection system (magic_oinfo) working! I
5444 * Got the object introspection system (magic_oinfo) working! I
5440 think this is pretty much ready for release to Janko, so he can
5445 think this is pretty much ready for release to Janko, so he can
5441 test it for a while and then announce it. Pretty much 100% of what
5446 test it for a while and then announce it. Pretty much 100% of what
5442 I wanted for the 'phase 1' release is ready. Happy, tired.
5447 I wanted for the 'phase 1' release is ready. Happy, tired.
5443
5448
5444 2001-11-12 Fernando Perez <fperez@colorado.edu>
5449 2001-11-12 Fernando Perez <fperez@colorado.edu>
5445
5450
5446 * Version 0.1.6 released, 0.1.7 opened for further work.
5451 * Version 0.1.6 released, 0.1.7 opened for further work.
5447
5452
5448 * Fixed bug in printing: it used to test for truth before
5453 * Fixed bug in printing: it used to test for truth before
5449 printing, so 0 wouldn't print. Now checks for None.
5454 printing, so 0 wouldn't print. Now checks for None.
5450
5455
5451 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
5456 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
5452 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
5457 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
5453 reaches by hand into the outputcache. Think of a better way to do
5458 reaches by hand into the outputcache. Think of a better way to do
5454 this later.
5459 this later.
5455
5460
5456 * Various small fixes thanks to Nathan's comments.
5461 * Various small fixes thanks to Nathan's comments.
5457
5462
5458 * Changed magic_pprint to magic_Pprint. This way it doesn't
5463 * Changed magic_pprint to magic_Pprint. This way it doesn't
5459 collide with pprint() and the name is consistent with the command
5464 collide with pprint() and the name is consistent with the command
5460 line option.
5465 line option.
5461
5466
5462 * Changed prompt counter behavior to be fully like
5467 * Changed prompt counter behavior to be fully like
5463 Mathematica's. That is, even input that doesn't return a result
5468 Mathematica's. That is, even input that doesn't return a result
5464 raises the prompt counter. The old behavior was kind of confusing
5469 raises the prompt counter. The old behavior was kind of confusing
5465 (getting the same prompt number several times if the operation
5470 (getting the same prompt number several times if the operation
5466 didn't return a result).
5471 didn't return a result).
5467
5472
5468 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
5473 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
5469
5474
5470 * Fixed -Classic mode (wasn't working anymore).
5475 * Fixed -Classic mode (wasn't working anymore).
5471
5476
5472 * Added colored prompts using Nathan's new code. Colors are
5477 * Added colored prompts using Nathan's new code. Colors are
5473 currently hardwired, they can be user-configurable. For
5478 currently hardwired, they can be user-configurable. For
5474 developers, they can be chosen in file ipythonlib.py, at the
5479 developers, they can be chosen in file ipythonlib.py, at the
5475 beginning of the CachedOutput class def.
5480 beginning of the CachedOutput class def.
5476
5481
5477 2001-11-11 Fernando Perez <fperez@colorado.edu>
5482 2001-11-11 Fernando Perez <fperez@colorado.edu>
5478
5483
5479 * Version 0.1.5 released, 0.1.6 opened for further work.
5484 * Version 0.1.5 released, 0.1.6 opened for further work.
5480
5485
5481 * Changed magic_env to *return* the environment as a dict (not to
5486 * Changed magic_env to *return* the environment as a dict (not to
5482 print it). This way it prints, but it can also be processed.
5487 print it). This way it prints, but it can also be processed.
5483
5488
5484 * Added Verbose exception reporting to interactive
5489 * Added Verbose exception reporting to interactive
5485 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
5490 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
5486 traceback. Had to make some changes to the ultraTB file. This is
5491 traceback. Had to make some changes to the ultraTB file. This is
5487 probably the last 'big' thing in my mental todo list. This ties
5492 probably the last 'big' thing in my mental todo list. This ties
5488 in with the next entry:
5493 in with the next entry:
5489
5494
5490 * Changed -Xi and -Xf to a single -xmode option. Now all the user
5495 * Changed -Xi and -Xf to a single -xmode option. Now all the user
5491 has to specify is Plain, Color or Verbose for all exception
5496 has to specify is Plain, Color or Verbose for all exception
5492 handling.
5497 handling.
5493
5498
5494 * Removed ShellServices option. All this can really be done via
5499 * Removed ShellServices option. All this can really be done via
5495 the magic system. It's easier to extend, cleaner and has automatic
5500 the magic system. It's easier to extend, cleaner and has automatic
5496 namespace protection and documentation.
5501 namespace protection and documentation.
5497
5502
5498 2001-11-09 Fernando Perez <fperez@colorado.edu>
5503 2001-11-09 Fernando Perez <fperez@colorado.edu>
5499
5504
5500 * Fixed bug in output cache flushing (missing parameter to
5505 * Fixed bug in output cache flushing (missing parameter to
5501 __init__). Other small bugs fixed (found using pychecker).
5506 __init__). Other small bugs fixed (found using pychecker).
5502
5507
5503 * Version 0.1.4 opened for bugfixing.
5508 * Version 0.1.4 opened for bugfixing.
5504
5509
5505 2001-11-07 Fernando Perez <fperez@colorado.edu>
5510 2001-11-07 Fernando Perez <fperez@colorado.edu>
5506
5511
5507 * Version 0.1.3 released, mainly because of the raw_input bug.
5512 * Version 0.1.3 released, mainly because of the raw_input bug.
5508
5513
5509 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
5514 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
5510 and when testing for whether things were callable, a call could
5515 and when testing for whether things were callable, a call could
5511 actually be made to certain functions. They would get called again
5516 actually be made to certain functions. They would get called again
5512 once 'really' executed, with a resulting double call. A disaster
5517 once 'really' executed, with a resulting double call. A disaster
5513 in many cases (list.reverse() would never work!).
5518 in many cases (list.reverse() would never work!).
5514
5519
5515 * Removed prefilter() function, moved its code to raw_input (which
5520 * Removed prefilter() function, moved its code to raw_input (which
5516 after all was just a near-empty caller for prefilter). This saves
5521 after all was just a near-empty caller for prefilter). This saves
5517 a function call on every prompt, and simplifies the class a tiny bit.
5522 a function call on every prompt, and simplifies the class a tiny bit.
5518
5523
5519 * Fix _ip to __ip name in magic example file.
5524 * Fix _ip to __ip name in magic example file.
5520
5525
5521 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
5526 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
5522 work with non-gnu versions of tar.
5527 work with non-gnu versions of tar.
5523
5528
5524 2001-11-06 Fernando Perez <fperez@colorado.edu>
5529 2001-11-06 Fernando Perez <fperez@colorado.edu>
5525
5530
5526 * Version 0.1.2. Just to keep track of the recent changes.
5531 * Version 0.1.2. Just to keep track of the recent changes.
5527
5532
5528 * Fixed nasty bug in output prompt routine. It used to check 'if
5533 * Fixed nasty bug in output prompt routine. It used to check 'if
5529 arg != None...'. Problem is, this fails if arg implements a
5534 arg != None...'. Problem is, this fails if arg implements a
5530 special comparison (__cmp__) which disallows comparing to
5535 special comparison (__cmp__) which disallows comparing to
5531 None. Found it when trying to use the PhysicalQuantity module from
5536 None. Found it when trying to use the PhysicalQuantity module from
5532 ScientificPython.
5537 ScientificPython.
5533
5538
5534 2001-11-05 Fernando Perez <fperez@colorado.edu>
5539 2001-11-05 Fernando Perez <fperez@colorado.edu>
5535
5540
5536 * Also added dirs. Now the pushd/popd/dirs family functions
5541 * Also added dirs. Now the pushd/popd/dirs family functions
5537 basically like the shell, with the added convenience of going home
5542 basically like the shell, with the added convenience of going home
5538 when called with no args.
5543 when called with no args.
5539
5544
5540 * pushd/popd slightly modified to mimic shell behavior more
5545 * pushd/popd slightly modified to mimic shell behavior more
5541 closely.
5546 closely.
5542
5547
5543 * Added env,pushd,popd from ShellServices as magic functions. I
5548 * Added env,pushd,popd from ShellServices as magic functions. I
5544 think the cleanest will be to port all desired functions from
5549 think the cleanest will be to port all desired functions from
5545 ShellServices as magics and remove ShellServices altogether. This
5550 ShellServices as magics and remove ShellServices altogether. This
5546 will provide a single, clean way of adding functionality
5551 will provide a single, clean way of adding functionality
5547 (shell-type or otherwise) to IP.
5552 (shell-type or otherwise) to IP.
5548
5553
5549 2001-11-04 Fernando Perez <fperez@colorado.edu>
5554 2001-11-04 Fernando Perez <fperez@colorado.edu>
5550
5555
5551 * Added .ipython/ directory to sys.path. This way users can keep
5556 * Added .ipython/ directory to sys.path. This way users can keep
5552 customizations there and access them via import.
5557 customizations there and access them via import.
5553
5558
5554 2001-11-03 Fernando Perez <fperez@colorado.edu>
5559 2001-11-03 Fernando Perez <fperez@colorado.edu>
5555
5560
5556 * Opened version 0.1.1 for new changes.
5561 * Opened version 0.1.1 for new changes.
5557
5562
5558 * Changed version number to 0.1.0: first 'public' release, sent to
5563 * Changed version number to 0.1.0: first 'public' release, sent to
5559 Nathan and Janko.
5564 Nathan and Janko.
5560
5565
5561 * Lots of small fixes and tweaks.
5566 * Lots of small fixes and tweaks.
5562
5567
5563 * Minor changes to whos format. Now strings are shown, snipped if
5568 * Minor changes to whos format. Now strings are shown, snipped if
5564 too long.
5569 too long.
5565
5570
5566 * Changed ShellServices to work on __main__ so they show up in @who
5571 * Changed ShellServices to work on __main__ so they show up in @who
5567
5572
5568 * Help also works with ? at the end of a line:
5573 * Help also works with ? at the end of a line:
5569 ?sin and sin?
5574 ?sin and sin?
5570 both produce the same effect. This is nice, as often I use the
5575 both produce the same effect. This is nice, as often I use the
5571 tab-complete to find the name of a method, but I used to then have
5576 tab-complete to find the name of a method, but I used to then have
5572 to go to the beginning of the line to put a ? if I wanted more
5577 to go to the beginning of the line to put a ? if I wanted more
5573 info. Now I can just add the ? and hit return. Convenient.
5578 info. Now I can just add the ? and hit return. Convenient.
5574
5579
5575 2001-11-02 Fernando Perez <fperez@colorado.edu>
5580 2001-11-02 Fernando Perez <fperez@colorado.edu>
5576
5581
5577 * Python version check (>=2.1) added.
5582 * Python version check (>=2.1) added.
5578
5583
5579 * Added LazyPython documentation. At this point the docs are quite
5584 * Added LazyPython documentation. At this point the docs are quite
5580 a mess. A cleanup is in order.
5585 a mess. A cleanup is in order.
5581
5586
5582 * Auto-installer created. For some bizarre reason, the zipfiles
5587 * Auto-installer created. For some bizarre reason, the zipfiles
5583 module isn't working on my system. So I made a tar version
5588 module isn't working on my system. So I made a tar version
5584 (hopefully the command line options in various systems won't kill
5589 (hopefully the command line options in various systems won't kill
5585 me).
5590 me).
5586
5591
5587 * Fixes to Struct in genutils. Now all dictionary-like methods are
5592 * Fixes to Struct in genutils. Now all dictionary-like methods are
5588 protected (reasonably).
5593 protected (reasonably).
5589
5594
5590 * Added pager function to genutils and changed ? to print usage
5595 * Added pager function to genutils and changed ? to print usage
5591 note through it (it was too long).
5596 note through it (it was too long).
5592
5597
5593 * Added the LazyPython functionality. Works great! I changed the
5598 * Added the LazyPython functionality. Works great! I changed the
5594 auto-quote escape to ';', it's on home row and next to '. But
5599 auto-quote escape to ';', it's on home row and next to '. But
5595 both auto-quote and auto-paren (still /) escapes are command-line
5600 both auto-quote and auto-paren (still /) escapes are command-line
5596 parameters.
5601 parameters.
5597
5602
5598
5603
5599 2001-11-01 Fernando Perez <fperez@colorado.edu>
5604 2001-11-01 Fernando Perez <fperez@colorado.edu>
5600
5605
5601 * Version changed to 0.0.7. Fairly large change: configuration now
5606 * Version changed to 0.0.7. Fairly large change: configuration now
5602 is all stored in a directory, by default .ipython. There, all
5607 is all stored in a directory, by default .ipython. There, all
5603 config files have normal looking names (not .names)
5608 config files have normal looking names (not .names)
5604
5609
5605 * Version 0.0.6 Released first to Lucas and Archie as a test
5610 * Version 0.0.6 Released first to Lucas and Archie as a test
5606 run. Since it's the first 'semi-public' release, change version to
5611 run. Since it's the first 'semi-public' release, change version to
5607 > 0.0.6 for any changes now.
5612 > 0.0.6 for any changes now.
5608
5613
5609 * Stuff I had put in the ipplib.py changelog:
5614 * Stuff I had put in the ipplib.py changelog:
5610
5615
5611 Changes to InteractiveShell:
5616 Changes to InteractiveShell:
5612
5617
5613 - Made the usage message a parameter.
5618 - Made the usage message a parameter.
5614
5619
5615 - Require the name of the shell variable to be given. It's a bit
5620 - Require the name of the shell variable to be given. It's a bit
5616 of a hack, but allows the name 'shell' not to be hardwired in the
5621 of a hack, but allows the name 'shell' not to be hardwired in the
5617 magic (@) handler, which is problematic b/c it requires
5622 magic (@) handler, which is problematic b/c it requires
5618 polluting the global namespace with 'shell'. This in turn is
5623 polluting the global namespace with 'shell'. This in turn is
5619 fragile: if a user redefines a variable called shell, things
5624 fragile: if a user redefines a variable called shell, things
5620 break.
5625 break.
5621
5626
5622 - magic @: all functions available through @ need to be defined
5627 - magic @: all functions available through @ need to be defined
5623 as magic_<name>, even though they can be called simply as
5628 as magic_<name>, even though they can be called simply as
5624 @<name>. This allows the special command @magic to gather
5629 @<name>. This allows the special command @magic to gather
5625 information automatically about all existing magic functions,
5630 information automatically about all existing magic functions,
5626 even if they are run-time user extensions, by parsing the shell
5631 even if they are run-time user extensions, by parsing the shell
5627 instance __dict__ looking for special magic_ names.
5632 instance __dict__ looking for special magic_ names.
5628
5633
5629 - mainloop: added *two* local namespace parameters. This allows
5634 - mainloop: added *two* local namespace parameters. This allows
5630 the class to differentiate between parameters which were there
5635 the class to differentiate between parameters which were there
5631 before and after command line initialization was processed. This
5636 before and after command line initialization was processed. This
5632 way, later @who can show things loaded at startup by the
5637 way, later @who can show things loaded at startup by the
5633 user. This trick was necessary to make session saving/reloading
5638 user. This trick was necessary to make session saving/reloading
5634 really work: ideally after saving/exiting/reloading a session,
5639 really work: ideally after saving/exiting/reloading a session,
5635 *everything* should look the same, including the output of @who. I
5640 *everything* should look the same, including the output of @who. I
5636 was only able to make this work with this double namespace
5641 was only able to make this work with this double namespace
5637 trick.
5642 trick.
5638
5643
5639 - added a header to the logfile which allows (almost) full
5644 - added a header to the logfile which allows (almost) full
5640 session restoring.
5645 session restoring.
5641
5646
5642 - prepend lines beginning with @ or !, with a and log
5647 - prepend lines beginning with @ or !, with a and log
5643 them. Why? !lines: may be useful to know what you did @lines:
5648 them. Why? !lines: may be useful to know what you did @lines:
5644 they may affect session state. So when restoring a session, at
5649 they may affect session state. So when restoring a session, at
5645 least inform the user of their presence. I couldn't quite get
5650 least inform the user of their presence. I couldn't quite get
5646 them to properly re-execute, but at least the user is warned.
5651 them to properly re-execute, but at least the user is warned.
5647
5652
5648 * Started ChangeLog.
5653 * Started ChangeLog.
General Comments 0
You need to be logged in to leave comments. Login now