Show More
@@ -0,0 +1,48 b'' | |||||
|
1 | """Tests for the IPython tab-completion machinery. | |||
|
2 | """ | |||
|
3 | #----------------------------------------------------------------------------- | |||
|
4 | # Module imports | |||
|
5 | #----------------------------------------------------------------------------- | |||
|
6 | ||||
|
7 | # stdlib | |||
|
8 | import os | |||
|
9 | import sys | |||
|
10 | import unittest | |||
|
11 | ||||
|
12 | # third party | |||
|
13 | import nose.tools as nt | |||
|
14 | ||||
|
15 | # our own packages | |||
|
16 | from IPython.utils.tempdir import TemporaryDirectory | |||
|
17 | from IPython.core.history import HistoryManager | |||
|
18 | ||||
|
19 | def test_history(): | |||
|
20 | ||||
|
21 | ip = get_ipython() | |||
|
22 | with TemporaryDirectory() as tmpdir: | |||
|
23 | #tmpdir = '/software/temp' | |||
|
24 | histfile = os.path.realpath(os.path.join(tmpdir, 'history.json')) | |||
|
25 | # Ensure that we restore the history management that we mess with in | |||
|
26 | # this test doesn't affect the IPython instance used by the test suite | |||
|
27 | # beyond this test. | |||
|
28 | hist_manager_ori = ip.history_manager | |||
|
29 | try: | |||
|
30 | ip.history_manager = HistoryManager(ip) | |||
|
31 | ip.history_manager.hist_file = histfile | |||
|
32 | print 'test',histfile | |||
|
33 | hist = ['a=1\n', 'def f():\n test = 1\n return test\n', 'b=2\n'] | |||
|
34 | # test save and load | |||
|
35 | ip.history_manager.input_hist_raw[:] = [] | |||
|
36 | for h in hist: | |||
|
37 | ip.history_manager.input_hist_raw.append(h) | |||
|
38 | ip.save_history() | |||
|
39 | ip.history_manager.input_hist_raw[:] = [] | |||
|
40 | ip.reload_history() | |||
|
41 | print type(ip.history_manager.input_hist_raw) | |||
|
42 | print ip.history_manager.input_hist_raw | |||
|
43 | nt.assert_equal(len(ip.history_manager.input_hist_raw), len(hist)) | |||
|
44 | for i,h in enumerate(hist): | |||
|
45 | nt.assert_equal(hist[i], ip.history_manager.input_hist_raw[i]) | |||
|
46 | finally: | |||
|
47 | # Restore history manager | |||
|
48 | ip.history_manager = hist_manager_ori |
@@ -90,6 +90,8 b' c = get_config()' | |||||
90 |
|
90 | |||
91 | # c.InteractiveShell.quiet = False |
|
91 | # c.InteractiveShell.quiet = False | |
92 |
|
92 | |||
|
93 | # c.InteractiveShell.history_length = 10000 | |||
|
94 | ||||
93 | # Readline |
|
95 | # Readline | |
94 | # c.InteractiveShell.readline_use = True |
|
96 | # c.InteractiveShell.readline_use = True | |
95 |
|
97 |
@@ -173,7 +173,7 b' class DisplayHook(Configurable):' | |||||
173 | """Should we silence the display hook because of ';'?""" |
|
173 | """Should we silence the display hook because of ';'?""" | |
174 | # do not print output if input ends in ';' |
|
174 | # do not print output if input ends in ';' | |
175 | try: |
|
175 | try: | |
176 | if self.shell.input_hist[self.prompt_count].endswith(';\n'): |
|
176 | if self.shell.history_manager.input_hist_parsed[self.prompt_count].endswith(';\n'): | |
177 | return True |
|
177 | return True | |
178 | except IndexError: |
|
178 | except IndexError: | |
179 | # some uses of ipshellembed may fail here |
|
179 | # some uses of ipshellembed may fail here |
@@ -14,6 +14,7 b' from __future__ import print_function' | |||||
14 |
|
14 | |||
15 | # Stdlib imports |
|
15 | # Stdlib imports | |
16 | import fnmatch |
|
16 | import fnmatch | |
|
17 | import json | |||
17 | import os |
|
18 | import os | |
18 | import sys |
|
19 | import sys | |
19 |
|
20 | |||
@@ -37,7 +38,7 b' class HistoryManager(object):' | |||||
37 | # An instance of the IPython shell we are attached to |
|
38 | # An instance of the IPython shell we are attached to | |
38 | shell = None |
|
39 | shell = None | |
39 | # An InputList instance to hold processed history |
|
40 | # An InputList instance to hold processed history | |
40 | input_hist = None |
|
41 | input_hist_parsed = None | |
41 | # An InputList instance to hold raw history (as typed by user) |
|
42 | # An InputList instance to hold raw history (as typed by user) | |
42 | input_hist_raw = None |
|
43 | input_hist_raw = None | |
43 | # A list of directories visited during session |
|
44 | # A list of directories visited during session | |
@@ -64,11 +65,11 b' class HistoryManager(object):' | |||||
64 | self.shell = shell |
|
65 | self.shell = shell | |
65 |
|
66 | |||
66 | # List of input with multi-line handling. |
|
67 | # List of input with multi-line handling. | |
67 |
self.input_hist = |
|
68 | self.input_hist_parsed = [] | |
68 | # This one will hold the 'raw' input history, without any |
|
69 | # This one will hold the 'raw' input history, without any | |
69 | # pre-processing. This will allow users to retrieve the input just as |
|
70 | # pre-processing. This will allow users to retrieve the input just as | |
70 | # it was exactly typed in by the user, with %hist -r. |
|
71 | # it was exactly typed in by the user, with %hist -r. | |
71 |
self.input_hist_raw = |
|
72 | self.input_hist_raw = [] | |
72 |
|
73 | |||
73 | # list of visited directories |
|
74 | # list of visited directories | |
74 | try: |
|
75 | try: | |
@@ -84,7 +85,7 b' class HistoryManager(object):' | |||||
84 | histfname = 'history-%s' % shell.profile |
|
85 | histfname = 'history-%s' % shell.profile | |
85 | else: |
|
86 | else: | |
86 | histfname = 'history' |
|
87 | histfname = 'history' | |
87 | self.hist_file = os.path.join(shell.ipython_dir, histfname) |
|
88 | self.hist_file = os.path.join(shell.ipython_dir, histfname + '.json') | |
88 |
|
89 | |||
89 | # Objects related to shadow history management |
|
90 | # Objects related to shadow history management | |
90 | self._init_shadow_hist() |
|
91 | self._init_shadow_hist() | |
@@ -96,17 +97,6 b' class HistoryManager(object):' | |||||
96 | # Fill the history zero entry, user counter starts at 1 |
|
97 | # Fill the history zero entry, user counter starts at 1 | |
97 | self.store_inputs('\n', '\n') |
|
98 | self.store_inputs('\n', '\n') | |
98 |
|
99 | |||
99 | # For backwards compatibility, we must put these back in the shell |
|
|||
100 | # object, until we've removed all direct uses of the history objects in |
|
|||
101 | # the shell itself. |
|
|||
102 | shell.input_hist = self.input_hist |
|
|||
103 | shell.input_hist_raw = self.input_hist_raw |
|
|||
104 | shell.output_hist = self.output_hist |
|
|||
105 | shell.dir_hist = self.dir_hist |
|
|||
106 | shell.histfile = self.hist_file |
|
|||
107 | shell.shadowhist = self.shadow_hist |
|
|||
108 | shell.db = self.shadow_db |
|
|||
109 |
|
||||
110 | def _init_shadow_hist(self): |
|
100 | def _init_shadow_hist(self): | |
111 | try: |
|
101 | try: | |
112 | self.shadow_db = PickleShareDB(os.path.join( |
|
102 | self.shadow_db = PickleShareDB(os.path.join( | |
@@ -119,23 +109,40 b' class HistoryManager(object):' | |||||
119 | sys.exit() |
|
109 | sys.exit() | |
120 | self.shadow_hist = ShadowHist(self.shadow_db, self.shell) |
|
110 | self.shadow_hist = ShadowHist(self.shadow_db, self.shell) | |
121 |
|
111 | |||
122 |
def |
|
112 | def populate_readline_history(self): | |
123 | """Save input history to a file (via readline library).""" |
|
113 | """Populate the readline history from the raw history. | |
124 |
|
||||
125 | try: |
|
|||
126 | self.shell.readline.write_history_file(self.hist_file) |
|
|||
127 | except: |
|
|||
128 | print('Unable to save IPython command history to file: ' + |
|
|||
129 | `self.hist_file`) |
|
|||
130 |
|
|
114 | ||
131 | def reload_hist(self): |
|
115 | We only store one copy of the raw history, which is persisted to a json | |
132 | """Reload the input history from disk file.""" |
|
116 | file on disk. The readline history is repopulated from the contents of | |
|
117 | this file.""" | |||
133 |
|
118 | |||
134 | try: |
|
119 | try: | |
135 | self.shell.readline.clear_history() |
|
120 | self.shell.readline.clear_history() | |
136 | self.shell.readline.read_history_file(self.hist_file) |
|
|||
137 | except AttributeError: |
|
121 | except AttributeError: | |
138 | pass |
|
122 | pass | |
|
123 | else: | |||
|
124 | for h in self.input_hist_raw: | |||
|
125 | if not h.isspace(): | |||
|
126 | for line in h.splitlines(): | |||
|
127 | self.shell.readline.add_history(line) | |||
|
128 | ||||
|
129 | def save_history(self): | |||
|
130 | """Save input history to a file (via readline library).""" | |||
|
131 | hist = dict(raw=self.input_hist_raw, #[-self.shell.history_length:], | |||
|
132 | parsed=self.input_hist_parsed) #[-self.shell.history_length:]) | |||
|
133 | with open(self.hist_file,'wt') as hfile: | |||
|
134 | json.dump(hist, hfile, | |||
|
135 | sort_keys=True, indent=4) | |||
|
136 | ||||
|
137 | def reload_history(self): | |||
|
138 | """Reload the input history from disk file.""" | |||
|
139 | ||||
|
140 | with open(self.hist_file,'rt') as hfile: | |||
|
141 | hist = json.load(hfile) | |||
|
142 | self.input_hist_parsed = hist['parsed'] | |||
|
143 | self.input_hist_raw = hist['raw'] | |||
|
144 | if self.shell.has_readline: | |||
|
145 | self.populate_readline_history() | |||
139 |
|
146 | |||
140 | def get_history(self, index=None, raw=False, output=True): |
|
147 | def get_history(self, index=None, raw=False, output=True): | |
141 | """Get the history list. |
|
148 | """Get the history list. | |
@@ -163,7 +170,7 b' class HistoryManager(object):' | |||||
163 | if raw: |
|
170 | if raw: | |
164 | input_hist = self.input_hist_raw |
|
171 | input_hist = self.input_hist_raw | |
165 | else: |
|
172 | else: | |
166 | input_hist = self.input_hist |
|
173 | input_hist = self.input_hist_parsed | |
167 | if output: |
|
174 | if output: | |
168 | output_hist = self.output_hist |
|
175 | output_hist = self.output_hist | |
169 | n = len(input_hist) |
|
176 | n = len(input_hist) | |
@@ -201,7 +208,7 b' class HistoryManager(object):' | |||||
201 | """ |
|
208 | """ | |
202 | if source_raw is None: |
|
209 | if source_raw is None: | |
203 | source_raw = source |
|
210 | source_raw = source | |
204 | self.input_hist.append(source) |
|
211 | self.input_hist_parsed.append(source) | |
205 | self.input_hist_raw.append(source_raw) |
|
212 | self.input_hist_raw.append(source_raw) | |
206 | self.shadow_hist.add(source) |
|
213 | self.shadow_hist.add(source) | |
207 |
|
214 | |||
@@ -221,12 +228,12 b' class HistoryManager(object):' | |||||
221 |
|
228 | |||
222 | def sync_inputs(self): |
|
229 | def sync_inputs(self): | |
223 | """Ensure raw and translated histories have same length.""" |
|
230 | """Ensure raw and translated histories have same length.""" | |
224 | if len(self.input_hist) != len (self.input_hist_raw): |
|
231 | if len(self.input_hist_parsed) != len (self.input_hist_raw): | |
225 | self.input_hist_raw = InputList(self.input_hist) |
|
232 | self.input_hist_raw = InputList(self.input_hist_parsed) | |
226 |
|
233 | |||
227 | def reset(self): |
|
234 | def reset(self): | |
228 | """Clear all histories managed by this object.""" |
|
235 | """Clear all histories managed by this object.""" | |
229 | self.input_hist[:] = [] |
|
236 | self.input_hist_parsed[:] = [] | |
230 | self.input_hist_raw[:] = [] |
|
237 | self.input_hist_raw[:] = [] | |
231 | self.output_hist.clear() |
|
238 | self.output_hist.clear() | |
232 | # The directory history can't be completely empty |
|
239 | # The directory history can't be completely empty | |
@@ -299,12 +306,12 b" def magic_history(self, parameter_s = ''):" | |||||
299 | close_at_end = True |
|
306 | close_at_end = True | |
300 |
|
307 | |||
301 | if 't' in opts: |
|
308 | if 't' in opts: | |
302 | input_hist = self.shell.input_hist |
|
309 | input_hist = self.shell.history_manager.input_hist_parsed | |
303 | elif 'r' in opts: |
|
310 | elif 'r' in opts: | |
304 | input_hist = self.shell.input_hist_raw |
|
311 | input_hist = self.shell.history_manager.input_hist_raw | |
305 | else: |
|
312 | else: | |
306 | # Raw history is the default |
|
313 | # Raw history is the default | |
307 | input_hist = self.shell.input_hist_raw |
|
314 | input_hist = self.shell.history_manager.input_hist_raw | |
308 |
|
315 | |||
309 | default_length = 40 |
|
316 | default_length = 40 | |
310 | pattern = None |
|
317 | pattern = None | |
@@ -337,7 +344,7 b" def magic_history(self, parameter_s = ''):" | |||||
337 |
|
344 | |||
338 | found = False |
|
345 | found = False | |
339 | if pattern is not None: |
|
346 | if pattern is not None: | |
340 | sh = self.shell.shadowhist.all() |
|
347 | sh = self.shell.history_manager.shadowhist.all() | |
341 | for idx, s in sh: |
|
348 | for idx, s in sh: | |
342 | if fnmatch.fnmatch(s, pattern): |
|
349 | if fnmatch.fnmatch(s, pattern): | |
343 | print("0%d: %s" %(idx, s.expandtabs(4)), file=outfile) |
|
350 | print("0%d: %s" %(idx, s.expandtabs(4)), file=outfile) | |
@@ -373,7 +380,7 b" def magic_history(self, parameter_s = ''):" | |||||
373 | else: |
|
380 | else: | |
374 | print(inline, end='', file=outfile) |
|
381 | print(inline, end='', file=outfile) | |
375 | if print_outputs: |
|
382 | if print_outputs: | |
376 | output = self.shell.output_hist.get(in_num) |
|
383 | output = self.shell.history_manager.output_hist.get(in_num) | |
377 | if output is not None: |
|
384 | if output is not None: | |
378 | print(repr(output), file=outfile) |
|
385 | print(repr(output), file=outfile) | |
379 |
|
386 |
@@ -45,7 +45,6 b' from IPython.core.error import TryNext, UsageError' | |||||
45 | from IPython.core.extensions import ExtensionManager |
|
45 | from IPython.core.extensions import ExtensionManager | |
46 | from IPython.core.fakemodule import FakeModule, init_fakemod_dict |
|
46 | from IPython.core.fakemodule import FakeModule, init_fakemod_dict | |
47 | from IPython.core.history import HistoryManager |
|
47 | from IPython.core.history import HistoryManager | |
48 | from IPython.core.inputlist import InputList |
|
|||
49 | from IPython.core.inputsplitter import IPythonInputSplitter |
|
48 | from IPython.core.inputsplitter import IPythonInputSplitter | |
50 | from IPython.core.logger import Logger |
|
49 | from IPython.core.logger import Logger | |
51 | from IPython.core.magic import Magic |
|
50 | from IPython.core.magic import Magic | |
@@ -176,6 +175,8 b' class InteractiveShell(Configurable, Magic):' | |||||
176 | prompts_pad_left = CBool(True, config=True) |
|
175 | prompts_pad_left = CBool(True, config=True) | |
177 | quiet = CBool(False, config=True) |
|
176 | quiet = CBool(False, config=True) | |
178 |
|
177 | |||
|
178 | history_length = Int(10000, config=True) | |||
|
179 | ||||
179 | # The readline stuff will eventually be moved to the terminal subclass |
|
180 | # The readline stuff will eventually be moved to the terminal subclass | |
180 | # but for now, we can't do that as readline is welded in everywhere. |
|
181 | # but for now, we can't do that as readline is welded in everywhere. | |
181 | readline_use = CBool(True, config=True) |
|
182 | readline_use = CBool(True, config=True) | |
@@ -293,6 +294,14 b' class InteractiveShell(Configurable, Magic):' | |||||
293 | self.hooks.late_startup_hook() |
|
294 | self.hooks.late_startup_hook() | |
294 | atexit.register(self.atexit_operations) |
|
295 | atexit.register(self.atexit_operations) | |
295 |
|
296 | |||
|
297 | # While we're trying to have each part of the code directly access what it | |||
|
298 | # needs without keeping redundant references to objects, we have too much | |||
|
299 | # legacy code that expects ip.db to exist, so let's make it a property that | |||
|
300 | # retrieves the underlying object from our new history manager. | |||
|
301 | @property | |||
|
302 | def db(self): | |||
|
303 | return self.history_manager.shadow_db | |||
|
304 | ||||
296 | @classmethod |
|
305 | @classmethod | |
297 | def instance(cls, *args, **kwargs): |
|
306 | def instance(cls, *args, **kwargs): | |
298 | """Returns a global InteractiveShell instance.""" |
|
307 | """Returns a global InteractiveShell instance.""" | |
@@ -947,16 +956,16 b' class InteractiveShell(Configurable, Magic):' | |||||
947 | warn('help() not available - check site.py') |
|
956 | warn('help() not available - check site.py') | |
948 |
|
957 | |||
949 | # make global variables for user access to the histories |
|
958 | # make global variables for user access to the histories | |
950 | ns['_ih'] = self.input_hist |
|
959 | ns['_ih'] = self.history_manager.input_hist_parsed | |
951 | ns['_oh'] = self.output_hist |
|
960 | ns['_oh'] = self.history_manager.output_hist | |
952 | ns['_dh'] = self.dir_hist |
|
961 | ns['_dh'] = self.history_manager.dir_hist | |
953 |
|
962 | |||
954 | ns['_sh'] = shadowns |
|
963 | ns['_sh'] = shadowns | |
955 |
|
964 | |||
956 | # user aliases to input and output histories. These shouldn't show up |
|
965 | # user aliases to input and output histories. These shouldn't show up | |
957 | # in %who, as they can have very large reprs. |
|
966 | # in %who, as they can have very large reprs. | |
958 | ns['In'] = self.input_hist |
|
967 | ns['In'] = self.history_manager.input_hist_parsed | |
959 | ns['Out'] = self.output_hist |
|
968 | ns['Out'] = self.history_manager.output_hist | |
960 |
|
969 | |||
961 | # Store myself as the public api!!! |
|
970 | # Store myself as the public api!!! | |
962 | ns['get_ipython'] = self.get_ipython |
|
971 | ns['get_ipython'] = self.get_ipython | |
@@ -1228,19 +1237,13 b' class InteractiveShell(Configurable, Magic):' | |||||
1228 | def init_history(self): |
|
1237 | def init_history(self): | |
1229 | self.history_manager = HistoryManager(shell=self) |
|
1238 | self.history_manager = HistoryManager(shell=self) | |
1230 |
|
1239 | |||
1231 | def save_hist(self): |
|
1240 | def save_history(self): | |
1232 | """Save input history to a file (via readline library).""" |
|
1241 | """Save input history to a file (via readline library).""" | |
1233 | self.history_manager.save_hist() |
|
1242 | self.history_manager.save_history() | |
1234 |
|
1243 | |||
1235 | # For backwards compatibility |
|
1244 | def reload_history(self): | |
1236 | savehist = save_hist |
|
|||
1237 |
|
||||
1238 | def reload_hist(self): |
|
|||
1239 | """Reload the input history from disk file.""" |
|
1245 | """Reload the input history from disk file.""" | |
1240 | self.history_manager.reload_hist() |
|
1246 | self.history_manager.reload_history() | |
1241 |
|
||||
1242 | # For backwards compatibility |
|
|||
1243 | reloadhist = reload_hist |
|
|||
1244 |
|
1247 | |||
1245 | def history_saving_wrapper(self, func): |
|
1248 | def history_saving_wrapper(self, func): | |
1246 | """ Wrap func for readline history saving |
|
1249 | """ Wrap func for readline history saving | |
@@ -1254,11 +1257,11 b' class InteractiveShell(Configurable, Magic):' | |||||
1254 | return func |
|
1257 | return func | |
1255 |
|
1258 | |||
1256 | def wrapper(): |
|
1259 | def wrapper(): | |
1257 | self.save_hist() |
|
1260 | self.save_history() | |
1258 | try: |
|
1261 | try: | |
1259 | func() |
|
1262 | func() | |
1260 | finally: |
|
1263 | finally: | |
1261 |
|
|
1264 | self.reload_history() | |
1262 | return wrapper |
|
1265 | return wrapper | |
1263 |
|
1266 | |||
1264 | #------------------------------------------------------------------------- |
|
1267 | #------------------------------------------------------------------------- | |
@@ -1488,8 +1491,6 b' class InteractiveShell(Configurable, Magic):' | |||||
1488 | self.has_readline = False |
|
1491 | self.has_readline = False | |
1489 | self.readline = None |
|
1492 | self.readline = None | |
1490 | # Set a number of methods that depend on readline to be no-op |
|
1493 | # Set a number of methods that depend on readline to be no-op | |
1491 | self.save_hist = no_op |
|
|||
1492 | self.reload_hist = no_op |
|
|||
1493 | self.set_readline_completer = no_op |
|
1494 | self.set_readline_completer = no_op | |
1494 | self.set_custom_completer = no_op |
|
1495 | self.set_custom_completer = no_op | |
1495 | self.set_completer_frame = no_op |
|
1496 | self.set_completer_frame = no_op | |
@@ -1541,17 +1542,13 b' class InteractiveShell(Configurable, Magic):' | |||||
1541 | delims = delims.replace(ESC_MAGIC, '') |
|
1542 | delims = delims.replace(ESC_MAGIC, '') | |
1542 | readline.set_completer_delims(delims) |
|
1543 | readline.set_completer_delims(delims) | |
1543 | # otherwise we end up with a monster history after a while: |
|
1544 | # otherwise we end up with a monster history after a while: | |
1544 |
readline.set_history_length( |
|
1545 | readline.set_history_length(self.history_length) | |
1545 | try: |
|
1546 | try: | |
1546 | #print '*** Reading readline history' # dbg |
|
1547 | #print '*** Reading readline history' # dbg | |
1547 |
|
|
1548 | self.reload_history() | |
1548 | except IOError: |
|
1549 | except IOError: | |
1549 | pass # It doesn't exist yet. |
|
1550 | pass # It doesn't exist yet. | |
1550 |
|
1551 | |||
1551 | # If we have readline, we want our history saved upon ipython |
|
|||
1552 | # exiting. |
|
|||
1553 | atexit.register(self.save_hist) |
|
|||
1554 |
|
||||
1555 | # Configure auto-indent for all platforms |
|
1552 | # Configure auto-indent for all platforms | |
1556 | self.set_autoindent(self.autoindent) |
|
1553 | self.set_autoindent(self.autoindent) | |
1557 |
|
1554 | |||
@@ -2109,7 +2106,8 b' class InteractiveShell(Configurable, Magic):' | |||||
2109 | list.append(self, val) |
|
2106 | list.append(self, val) | |
2110 |
|
2107 | |||
2111 | import new |
|
2108 | import new | |
2112 |
self.input_hist.append = types.MethodType(myapp, |
|
2109 | self.history_manager.input_hist_parsed.append = types.MethodType(myapp, | |
|
2110 | self.history_manager.input_hist_parsed) | |||
2113 | # End dbg |
|
2111 | # End dbg | |
2114 |
|
2112 | |||
2115 | # All user code execution must happen with our context managers active |
|
2113 | # All user code execution must happen with our context managers active | |
@@ -2521,6 +2519,9 b' class InteractiveShell(Configurable, Magic):' | |||||
2521 | except OSError: |
|
2519 | except OSError: | |
2522 | pass |
|
2520 | pass | |
2523 |
|
2521 | |||
|
2522 | ||||
|
2523 | self.save_history() | |||
|
2524 | ||||
2524 | # Clear all user namespaces to release all references cleanly. |
|
2525 | # Clear all user namespaces to release all references cleanly. | |
2525 | self.reset() |
|
2526 | self.reset() | |
2526 |
|
2527 |
@@ -186,9 +186,9 b' python-profiler package from non-free.""")' | |||||
186 | N-M -> include items N..M (closed endpoint).""" |
|
186 | N-M -> include items N..M (closed endpoint).""" | |
187 |
|
187 | |||
188 | if raw: |
|
188 | if raw: | |
189 | hist = self.shell.input_hist_raw |
|
189 | hist = self.shell.history_manager.input_hist_raw | |
190 | else: |
|
190 | else: | |
191 | hist = self.shell.input_hist |
|
191 | hist = self.shell.history_manager.input_hist_parsed | |
192 |
|
192 | |||
193 | cmds = [] |
|
193 | cmds = [] | |
194 | for chunk in slices: |
|
194 | for chunk in slices: | |
@@ -200,7 +200,7 b' python-profiler package from non-free.""")' | |||||
200 | else: |
|
200 | else: | |
201 | ini = int(chunk) |
|
201 | ini = int(chunk) | |
202 | fin = ini+1 |
|
202 | fin = ini+1 | |
203 | cmds.append(hist[ini:fin]) |
|
203 | cmds.append(''.join(hist[ini:fin])) | |
204 | return cmds |
|
204 | return cmds | |
205 |
|
205 | |||
206 | def arg_err(self,func): |
|
206 | def arg_err(self,func): | |
@@ -1106,19 +1106,19 b' Currently the magic system has the following functions:\\n"""' | |||||
1106 | logger.timestamp = False |
|
1106 | logger.timestamp = False | |
1107 |
|
1107 | |||
1108 | if log_raw_input: |
|
1108 | if log_raw_input: | |
1109 | input_hist = self.shell.input_hist_raw |
|
1109 | input_hist = self.shell.history_manager.input_hist_raw | |
1110 | else: |
|
1110 | else: | |
1111 | input_hist = self.shell.input_hist |
|
1111 | input_hist = self.shell.history_manager.input_hist_parsed | |
1112 |
|
1112 | |||
1113 | if log_output: |
|
1113 | if log_output: | |
1114 | log_write = logger.log_write |
|
1114 | log_write = logger.log_write | |
1115 | output_hist = self.shell.output_hist |
|
1115 | output_hist = self.shell.history_manager.output_hist | |
1116 | for n in range(1,len(input_hist)-1): |
|
1116 | for n in range(1,len(input_hist)-1): | |
1117 | log_write(input_hist[n].rstrip()) |
|
1117 | log_write(input_hist[n].rstrip()) | |
1118 | if n in output_hist: |
|
1118 | if n in output_hist: | |
1119 | log_write(repr(output_hist[n]),'output') |
|
1119 | log_write(repr(output_hist[n]),'output') | |
1120 | else: |
|
1120 | else: | |
1121 | logger.log_write(input_hist[1:]) |
|
1121 | logger.log_write(''.join(input_hist[1:])) | |
1122 | if timestamp: |
|
1122 | if timestamp: | |
1123 | # re-enable timestamping |
|
1123 | # re-enable timestamping | |
1124 | logger.timestamp = True |
|
1124 | logger.timestamp = True | |
@@ -1551,7 +1551,7 b' Currently the magic system has the following functions:\\n"""' | |||||
1551 |
|
1551 | |||
1552 | stats = None |
|
1552 | stats = None | |
1553 | try: |
|
1553 | try: | |
1554 | self.shell.save_hist() |
|
1554 | self.shell.save_history() | |
1555 |
|
1555 | |||
1556 | if opts.has_key('p'): |
|
1556 | if opts.has_key('p'): | |
1557 | stats = self.magic_prun('',0,opts,arg_lst,prog_ns) |
|
1557 | stats = self.magic_prun('',0,opts,arg_lst,prog_ns) | |
@@ -1670,7 +1670,7 b' Currently the magic system has the following functions:\\n"""' | |||||
1670 | # contained therein. |
|
1670 | # contained therein. | |
1671 | del sys.modules[main_mod_name] |
|
1671 | del sys.modules[main_mod_name] | |
1672 |
|
1672 | |||
1673 | self.shell.reload_hist() |
|
1673 | self.shell.reload_history() | |
1674 |
|
1674 | |||
1675 | return stats |
|
1675 | return stats | |
1676 |
|
1676 | |||
@@ -2980,8 +2980,8 b' Defaulting color scheme to \'NoColor\'"""' | |||||
2980 | else: |
|
2980 | else: | |
2981 | start_magic = start |
|
2981 | start_magic = start | |
2982 | # Look through the input history in reverse |
|
2982 | # Look through the input history in reverse | |
2983 | for n in range(len(self.shell.input_hist)-2,0,-1): |
|
2983 | for n in range(len(self.shell.history_manager.input_hist_parsed)-2,0,-1): | |
2984 | input = self.shell.input_hist[n] |
|
2984 | input = self.shell.history_manager.input_hist_parsed[n] | |
2985 | # skip plain 'r' lines so we don't recurse to infinity |
|
2985 | # skip plain 'r' lines so we don't recurse to infinity | |
2986 | if input != '_ip.magic("r")\n' and \ |
|
2986 | if input != '_ip.magic("r")\n' and \ | |
2987 | (input.startswith(start) or input.startswith(start_magic)): |
|
2987 | (input.startswith(start) or input.startswith(start_magic)): |
@@ -332,14 +332,14 b' class TerminalInteractiveShell(InteractiveShell):' | |||||
332 | if self.has_readline and self.readline_use: |
|
332 | if self.has_readline and self.readline_use: | |
333 | histlen = self.readline.get_current_history_length() |
|
333 | histlen = self.readline.get_current_history_length() | |
334 | if histlen > 1: |
|
334 | if histlen > 1: | |
335 | newhist = self.input_hist_raw[-1].rstrip() |
|
335 | newhist = self.history_manager.input_hist_raw[-1].rstrip() | |
336 | self.readline.remove_history_item(histlen-1) |
|
336 | self.readline.remove_history_item(histlen-1) | |
337 | self.readline.replace_history_item(histlen-2, |
|
337 | self.readline.replace_history_item(histlen-2, | |
338 | newhist.encode(self.stdin_encoding)) |
|
338 | newhist.encode(self.stdin_encoding)) | |
339 | else: |
|
339 | else: | |
340 | self.input_hist_raw.append('%s\n' % line) |
|
340 | self.history_manager.input_hist_raw.append('%s\n' % line) | |
341 | elif not continue_prompt: |
|
341 | elif not continue_prompt: | |
342 | self.input_hist_raw.append('\n') |
|
342 | self.history_manager.input_hist_raw.append('\n') | |
343 | try: |
|
343 | try: | |
344 | lineout = self.prefilter_manager.prefilter_lines(line,continue_prompt) |
|
344 | lineout = self.prefilter_manager.prefilter_lines(line,continue_prompt) | |
345 | except: |
|
345 | except: |
@@ -50,8 +50,8 b' def clear_f(self,arg):' | |||||
50 | del user_ns[key] |
|
50 | del user_ns[key] | |
51 | except: pass |
|
51 | except: pass | |
52 | # must be done in-place |
|
52 | # must be done in-place | |
53 | self.input_hist[:] = ['\n'] * pc |
|
53 | self.history_manager.input_hist_parsed[:] = ['\n'] * pc | |
54 | self.input_hist_raw[:] = ['\n'] * pc |
|
54 | self.history_manager.input_hist_raw[:] = ['\n'] * pc | |
55 |
|
55 | |||
56 | elif target == 'array': |
|
56 | elif target == 'array': | |
57 | # Support cleaning up numpy arrays |
|
57 | # Support cleaning up numpy arrays |
@@ -118,7 +118,7 b" def jot_obj(self, obj, name, comment=''):" | |||||
118 |
|
118 | |||
119 | # which one works better? |
|
119 | # which one works better? | |
120 | #all = ip.shadowhist.all() |
|
120 | #all = ip.shadowhist.all() | |
121 | all = ip.shell.input_hist |
|
121 | all = ip.shell.history_manager.input_hist_parsed | |
122 |
|
122 | |||
123 | # We may actually want to make snapshot of files that are run-ned. |
|
123 | # We may actually want to make snapshot of files that are run-ned. | |
124 |
|
124 |
General Comments 0
You need to be logged in to leave comments.
Login now