From c34b6a77da96aefb1710fa1ee22d897d66728762 2006-10-13 15:09:08 From: vivainio Date: 2006-10-13 15:09:08 Subject: [PATCH] first part of rocky bernstein's pydb patch - Magic.py and ipython.el" --- diff --git a/IPython/Magic.py b/IPython/Magic.py index 823c653..f4994e3 100644 --- a/IPython/Magic.py +++ b/IPython/Magic.py @@ -1,7 +1,7 @@ # -*- coding: utf-8 -*- """Magic functions for InteractiveShell. -$Id: Magic.py 1815 2006-10-10 04:46:24Z fptest $""" +$Id: Magic.py 1823 2006-10-13 15:09:08Z vivainio $""" #***************************************************************************** # Copyright (C) 2001 Janko Hauser and @@ -180,7 +180,7 @@ license. To use profiling, please install"python2.3-profiler" from non-free.""") cmds.append(hist[ini:fin]) return cmds - def _ofind(self,oname): + def _ofind(self, oname, namespaces=None): """Find an object in the available namespaces. self._ofind(oname) -> dict with keys: found,obj,ospace,ismagic @@ -190,19 +190,17 @@ license. To use profiling, please install"python2.3-profiler" from non-free.""") oname = oname.strip() - # Namespaces to search in: - user_ns = self.shell.user_ns - internal_ns = self.shell.internal_ns - builtin_ns = __builtin__.__dict__ - alias_ns = self.shell.alias_table - - # Put them in a list. The order is important so that we find things in - # the same order that Python finds them. - namespaces = [ ('Interactive',user_ns), - ('IPython internal',internal_ns), - ('Python builtin',builtin_ns), - ('Alias',alias_ns), - ] + alias_ns = None + if namespaces is None: + # Namespaces to search in: + # Put them in a list. The order is important so that we + # find things in the same order that Python finds them. + namespaces = [ ('Interactive', self.shell.user_ns), + ('IPython internal', self.shell.internal_ns), + ('Python builtin', __builtin__.__dict__), + ('Alias', self.shell.alias_table), + ] + alias_ns = self.shell.alias_table # initialize results to 'null' found = 0; obj = None; ospace = None; ds = None; @@ -642,13 +640,13 @@ Currently the magic system has the following functions:\n""" else: print 'No profile active.' - def _inspect(self,meth,oname,**kw): + def _inspect(self,meth,oname,namespaces=None,**kw): """Generic interface to the inspector system. This function is meant to be called by pdef, pdoc & friends.""" oname = oname.strip() - info = Struct(self._ofind(oname)) + info = Struct(self._ofind(oname, namespaces)) if info.found: # Get the docstring of the class property if it exists. @@ -679,22 +677,23 @@ Currently the magic system has the following functions:\n""" print 'Object `%s` not found.' % oname return 'not found' # so callers can take other action - def magic_pdef(self, parameter_s=''): + def magic_pdef(self, parameter_s='', namespaces=None): """Print the definition header for any callable object. If the object is a class, print the constructor information.""" - self._inspect('pdef',parameter_s) + print "+++" + self._inspect('pdef',parameter_s, namespaces) - def magic_pdoc(self, parameter_s=''): + def magic_pdoc(self, parameter_s='', namespaces=None): """Print the docstring for an object. If the given object is a class, it will print both the class and the constructor docstrings.""" - self._inspect('pdoc',parameter_s) + self._inspect('pdoc',parameter_s, namespaces) - def magic_psource(self, parameter_s=''): + def magic_psource(self, parameter_s='', namespaces=None): """Print (or run through pager) the source code for an object.""" - self._inspect('psource',parameter_s) + self._inspect('psource',parameter_s, namespaces) def magic_pfile(self, parameter_s=''): """Print (or run through pager) the file where an object is defined. @@ -719,7 +718,7 @@ Currently the magic system has the following functions:\n""" return page(self.shell.inspector.format(file(filename).read())) - def magic_pinfo(self, parameter_s=''): + def magic_pinfo(self, parameter_s='', namespaces=None): """Provide detailed information about an object. '%pinfo object' is just a synonym for object? or ?object.""" @@ -737,7 +736,8 @@ Currently the magic system has the following functions:\n""" if "*" in oname: self.magic_psearch(oname) else: - self._inspect('pinfo',oname,detail_level=detail_level) + self._inspect('pinfo', oname, detail_level=detail_level, + namespaces=namespaces) def magic_psearch(self, parameter_s=''): """Search for object in namespaces by wildcard. diff --git a/doc/ChangeLog b/doc/ChangeLog index 9667517..e47e7b5 100644 --- a/doc/ChangeLog +++ b/doc/ChangeLog @@ -1,3 +1,8 @@ +2006-10-14 Ville Vainio + + * Magic.py, ipython.el: applied first part of Rocky Bernstein's + patch set for pydb integration. + 2006-10-12 Ville Vainio * jobctrl.py: Add new "jobctrl" extension for spawning background diff --git a/doc/ipython.el b/doc/ipython.el index 6029716..dc624a9 100644 --- a/doc/ipython.el +++ b/doc/ipython.el @@ -6,7 +6,7 @@ ;; URL: http://ipython.scipy.org ;; Compatibility: Emacs21, XEmacs21 ;; FIXME: #$@! INPUT RING -(defconst ipython-version "$Revision: 1499 $" +(defconst ipython-version "$Revision: 1823 $" "VC version number.") ;;; Commentary @@ -197,8 +197,10 @@ the second for a 'normal' command, and the third for a multiline command.") (setq py-traceback-line-re "\\(^[^\t ].+?\\.py\\).*\n +[0-9]+[^\00]*?\n-+> \\([0-9]+\\) +") - ;; Recognize the ipython pdb, whose prompt is 'ipdb>' instead of '(Pdb)' - (setq py-pdbtrack-input-prompt "\n[(<]*[Ii]?[Pp]db[>)]+ ") + ;; Recognize the ipython pdb, whose prompt is 'ipdb>' or 'ipydb>' + ;;instead of '(Pdb)' + (setq py-pdbtrack-input-prompt "\n[(<]*[Ii]?[Pp]y?db[>)]+ ") + (setq py-pydbtrack-input-prompt "\n[(]*ipydb[>)]+ ") (setq py-shell-input-prompt-1-regexp "^In \\[[0-9]+\\]: *" py-shell-input-prompt-2-regexp "^ [.][.][.]+: *" )