Show More
@@ -28,7 +28,8 b' def install_editor(run_template, wait = False):' | |||
|
28 | 28 | line = 0 |
|
29 | 29 | cmd = itplns(run_template, locals()) |
|
30 | 30 | print ">",cmd |
|
31 | os.system(cmd) | |
|
31 | if os.system(cmd) != 0: | |
|
32 | raise IPython.ipapi.TryNext() | |
|
32 | 33 | if wait: |
|
33 | 34 | raw_input("Press Enter when done editing:") |
|
34 | 35 | |
@@ -65,6 +66,9 b' def idle(exe = None):' | |||
|
65 | 66 | exe = p + '/idle.py' |
|
66 | 67 | install_editor(exe + ' "$file"') |
|
67 | 68 | |
|
69 | def mate(exe = 'mate'): | |
|
70 | """ TextMate, the missing editor""" | |
|
71 | install_editor(exe + ' -w -l $line "$file"') | |
|
68 | 72 | |
|
69 | 73 | # these are untested, report any problems |
|
70 | 74 |
@@ -8,7 +8,7 b' compatibility)' | |||
|
8 | 8 | """ |
|
9 | 9 | |
|
10 | 10 | from IPython import ipapi |
|
11 | import os,textwrap | |
|
11 | import os,re,textwrap | |
|
12 | 12 | |
|
13 | 13 | # The import below effectively obsoletes your old-style ipythonrc[.ini], |
|
14 | 14 | # so consider yourself warned! |
@@ -129,7 +129,7 b' def main():' | |||
|
129 | 129 | # and the next best thing to real 'ls -F' |
|
130 | 130 | ip.defalias('d','dir /w /og /on') |
|
131 | 131 | |
|
132 |
ip.set_hook('input_prefilter', |
|
|
132 | ip.set_hook('input_prefilter', slash_prefilter_f) | |
|
133 | 133 | extend_shell_behavior(ip) |
|
134 | 134 | |
|
135 | 135 | class LastArgFinder: |
@@ -151,13 +151,13 b' class LastArgFinder:' | |||
|
151 | 151 | return parts[-1] |
|
152 | 152 | return "" |
|
153 | 153 | |
|
154 |
def |
|
|
155 |
""" ./foo now run |
|
|
154 | def slash_prefilter_f(self,line): | |
|
155 | """ ./foo, ~/foo and /bin/foo now run foo as system command | |
|
156 | 156 | |
|
157 | Removes the need for doing !./foo | |
|
157 | Removes the need for doing !./foo, !~/foo or !/bin/foo | |
|
158 | 158 | """ |
|
159 | 159 | import IPython.genutils |
|
160 | if line.startswith("./"): | |
|
160 | if re.match('(?:[.~]|/[a-zA-Z_0-9]+)/', line): | |
|
161 | 161 | return "_ip.system(" + IPython.genutils.make_quoted_expr(line)+")" |
|
162 | 162 | raise ipapi.TryNext |
|
163 | 163 |
@@ -422,7 +422,11 b' python-profiler package from non-free.""")' | |||
|
422 | 422 | else: |
|
423 | 423 | fndoc = 'No documentation' |
|
424 | 424 | else: |
|
425 | if fn.__doc__: | |
|
425 | 426 | fndoc = fn.__doc__.rstrip() |
|
427 | else: | |
|
428 | fndoc = 'No documentation' | |
|
429 | ||
|
426 | 430 | |
|
427 | 431 | if mode == 'rest': |
|
428 | 432 | rest_docs.append('**%s%s**::\n\n\t%s\n\n' %(self.shell.ESC_MAGIC, |
@@ -2328,7 +2332,11 b' Currently the magic system has the following functions:\\n"""' | |||
|
2328 | 2332 | # do actual editing here |
|
2329 | 2333 | print 'Editing...', |
|
2330 | 2334 | sys.stdout.flush() |
|
2335 | try: | |
|
2331 | 2336 | self.shell.hooks.editor(filename,lineno) |
|
2337 | except IPython.ipapi.TryNext: | |
|
2338 | warn('Could not open editor') | |
|
2339 | return | |
|
2332 | 2340 | |
|
2333 | 2341 | # XXX TODO: should this be generalized for all string vars? |
|
2334 | 2342 | # For now, this is special-cased to blocks created by cpaste |
@@ -415,7 +415,7 b' class MTInteractiveShell(InteractiveShell):' | |||
|
415 | 415 | if (self.worker_ident is None |
|
416 | 416 | or self.worker_ident == thread.get_ident() ): |
|
417 | 417 | InteractiveShell.runcode(self,code) |
|
418 | return | |
|
418 | return False | |
|
419 | 419 | |
|
420 | 420 | # Case 3 |
|
421 | 421 | # Store code in queue, so the execution thread can handle it. |
@@ -776,6 +776,17 b' class IPShellGTK(IPThread):' | |||
|
776 | 776 | debug=1,shell_class=MTInteractiveShell): |
|
777 | 777 | |
|
778 | 778 | import gtk |
|
779 | # Check for set_interactive, coming up in new pygtk. | |
|
780 | # Disable it so that this code works, but notify | |
|
781 | # the user that he has a better option as well. | |
|
782 | # XXX TODO better support when set_interactive is released | |
|
783 | try: | |
|
784 | gtk.set_interactive(False) | |
|
785 | print "Your PyGtk has set_interactive(), so you can use the" | |
|
786 | print "more stable single-threaded Gtk mode." | |
|
787 | print "See https://bugs.launchpad.net/ipython/+bug/270856" | |
|
788 | except AttributeError: | |
|
789 | pass | |
|
779 | 790 | |
|
780 | 791 | self.gtk = gtk |
|
781 | 792 | self.gtk_mainloop = hijack_gtk() |
@@ -180,7 +180,7 b' def re_mark(mark):' | |||
|
180 | 180 | |
|
181 | 181 | class Demo(object): |
|
182 | 182 | |
|
183 |
re_stop = re_mark('- |
|
|
183 | re_stop = re_mark('-*\s?stop\s?-*') | |
|
184 | 184 | re_silent = re_mark('silent') |
|
185 | 185 | re_auto = re_mark('auto') |
|
186 | 186 | re_auto_all = re_mark('auto_all') |
@@ -25,7 +25,8 b' ip = IPython.ipapi.get()' | |||
|
25 | 25 | def calljed(self,filename, linenum): |
|
26 | 26 | "My editor hook calls the jed editor directly." |
|
27 | 27 | print "Calling my own editor, jed ..." |
|
28 | os.system('jed +%d %s' % (linenum,filename)) | |
|
28 | if os.system('jed +%d %s' % (linenum,filename)) != 0: | |
|
29 | raise ipapi.TryNext() | |
|
29 | 30 | |
|
30 | 31 | ip.set_hook('editor', calljed) |
|
31 | 32 | |
@@ -84,7 +85,8 b' def editor(self,filename, linenum=None):' | |||
|
84 | 85 | editor = '"%s"' % editor |
|
85 | 86 | |
|
86 | 87 | # Call the actual editor |
|
87 | os.system('%s %s %s' % (editor,linemark,filename)) | |
|
88 | if os.system('%s %s %s' % (editor,linemark,filename)) != 0: | |
|
89 | raise ipapi.TryNext() | |
|
88 | 90 | |
|
89 | 91 | import tempfile |
|
90 | 92 | def fix_error_editor(self,filename,linenum,column,msg): |
@@ -105,7 +107,8 b' def fix_error_editor(self,filename,linenum,column,msg):' | |||
|
105 | 107 | return |
|
106 | 108 | t = vim_quickfix_file() |
|
107 | 109 | try: |
|
108 | os.system('vim --cmd "set errorformat=%f:%l:%c:%m" -q ' + t.name) | |
|
110 | if os.system('vim --cmd "set errorformat=%f:%l:%c:%m" -q ' + t.name): | |
|
111 | raise ipapi.TryNext() | |
|
109 | 112 | finally: |
|
110 | 113 | t.close() |
|
111 | 114 |
@@ -1419,8 +1419,12 b' want to merge them back into the new files.""" % locals()' | |||
|
1419 | 1419 | except TypeError: |
|
1420 | 1420 | return 0 |
|
1421 | 1421 | # always pass integer line and offset values to editor hook |
|
1422 | try: | |
|
1422 | 1423 | self.hooks.fix_error_editor(e.filename, |
|
1423 | 1424 | int0(e.lineno),int0(e.offset),e.msg) |
|
1425 | except IPython.ipapi.TryNext: | |
|
1426 | warn('Could not open editor') | |
|
1427 | return False | |
|
1424 | 1428 | return True |
|
1425 | 1429 | |
|
1426 | 1430 | def edit_syntax_error(self): |
@@ -1572,6 +1576,11 b' want to merge them back into the new files.""" % locals()' | |||
|
1572 | 1576 | else: |
|
1573 | 1577 | banner = self.BANNER+self.banner2 |
|
1574 | 1578 | |
|
1579 | # if you run stuff with -c <cmd>, raw hist is not updated | |
|
1580 | # ensure that it's in sync | |
|
1581 | if len(self.input_hist) != len (self.input_hist_raw): | |
|
1582 | self.input_hist_raw = InputList(self.input_hist) | |
|
1583 | ||
|
1575 | 1584 | while 1: |
|
1576 | 1585 | try: |
|
1577 | 1586 | self.interact(banner) |
@@ -91,7 +91,7 b' def start_engine():' | |||
|
91 | 91 | try: |
|
92 | 92 | engine_service.execute(shell_import_statement) |
|
93 | 93 | except: |
|
94 | log.msg("Error running import_statement: %s" % sis) | |
|
94 | log.msg("Error running import_statement: %s" % shell_import_statement) | |
|
95 | 95 | |
|
96 | 96 | # Create the service hierarchy |
|
97 | 97 | main_service = service.MultiService() |
@@ -2397,9 +2397,11 b' module, now part of the standard Python library.' | |||
|
2397 | 2397 | Input caching system |
|
2398 | 2398 | -------------------- |
|
2399 | 2399 | |
|
2400 |
IPython offers numbered prompts (In/Out) with input and output caching |
|
|
2401 | All input is saved and can be retrieved as variables (besides the usual | |
|
2402 | arrow key recall). | |
|
2400 | IPython offers numbered prompts (In/Out) with input and output caching | |
|
2401 | (also referred to as 'input history'). All input is saved and can be | |
|
2402 | retrieved as variables (besides the usual arrow key recall), in | |
|
2403 | addition to the %rep magic command that brings a history entry | |
|
2404 | up for editing on the next command line. | |
|
2403 | 2405 | |
|
2404 | 2406 | The following GLOBAL variables always exist (so don't overwrite them!): |
|
2405 | 2407 | _i: stores previous input. _ii: next previous. _iii: next-next previous. |
@@ -2432,6 +2434,42 b' sec. 6.2 <#sec:magic> for more details on the macro system.' | |||
|
2432 | 2434 | A history function %hist allows you to see any part of your input |
|
2433 | 2435 | history by printing a range of the _i variables. |
|
2434 | 2436 | |
|
2437 | You can also search ('grep') through your history by typing | |
|
2438 | '%hist -g somestring'. This also searches through the so called *shadow history*, | |
|
2439 | which remembers all the commands (apart from multiline code blocks) | |
|
2440 | you have ever entered. Handy for searching for svn/bzr URL's, IP adrresses | |
|
2441 | etc. You can bring shadow history entries listed by '%hist -g' up for editing | |
|
2442 | (or re-execution by just pressing ENTER) with %rep command. Shadow history | |
|
2443 | entries are not available as _iNUMBER variables, and they are identified by | |
|
2444 | the '0' prefix in %hist -g output. That is, history entry 12 is a normal | |
|
2445 | history entry, but 0231 is a shadow history entry. | |
|
2446 | ||
|
2447 | Shadow history was added because the readline history is inherently very | |
|
2448 | unsafe - if you have multiple IPython sessions open, the last session | |
|
2449 | to close will overwrite the history of previountly closed session. Likewise, | |
|
2450 | if a crash occurs, history is never saved, whereas shadow history entries | |
|
2451 | are added after entering every command (so a command executed | |
|
2452 | in another IPython session is immediately available in other IPython | |
|
2453 | sessions that are open). | |
|
2454 | ||
|
2455 | To conserve space, a command can exist in shadow history only once - it doesn't | |
|
2456 | make sense to store a common line like "cd .." a thousand times. The idea is | |
|
2457 | mainly to provide a reliable place where valuable, hard-to-remember commands can | |
|
2458 | always be retrieved, as opposed to providing an exact sequence of commands | |
|
2459 | you have entered in actual order. | |
|
2460 | ||
|
2461 | Because shadow history has all the commands you have ever executed, | |
|
2462 | time taken by %hist -g will increase oven time. If it ever starts to take | |
|
2463 | too long (or it ends up containing sensitive information like passwords), | |
|
2464 | clear the shadow history by `%clear shadow_nuke`. | |
|
2465 | ||
|
2466 | Time taken to add entries to shadow history should be negligible, but | |
|
2467 | in any case, if you start noticing performance degradation after using | |
|
2468 | IPython for a long time (or running a script that floods the shadow history!), | |
|
2469 | you can 'compress' the shadow history by executing | |
|
2470 | `%clear shadow_compress`. In practice, this should never be necessary | |
|
2471 | in normal use. | |
|
2472 | ||
|
2435 | 2473 | .. _output_caching: |
|
2436 | 2474 | |
|
2437 | 2475 | Output caching system |
@@ -2475,7 +2513,7 b' Directory history' | |||
|
2475 | 2513 | |
|
2476 | 2514 | Your history of visited directories is kept in the global list _dh, and |
|
2477 | 2515 | the magic %cd command can be used to go to any entry in that list. The |
|
2478 |
%dhist command allows you to view this history. |
|
|
2516 | %dhist command allows you to view this history. Do ``cd -<TAB`` to | |
|
2479 | 2517 | conventiently view the directory history. |
|
2480 | 2518 | |
|
2481 | 2519 |
General Comments 0
You need to be logged in to leave comments.
Login now