Show More
@@ -24,26 +24,26 b' Tip: to use the tab key as the completion key, call' | |||
|
24 | 24 | Notes: |
|
25 | 25 | |
|
26 | 26 | - Exceptions raised by the completer function are *ignored* (and |
|
27 | generally cause the completion to fail). This is a feature -- since | |
|
28 | readline sets the tty device in raw (or cbreak) mode, printing a | |
|
29 | traceback wouldn't work well without some complicated hoopla to save, | |
|
30 | reset and restore the tty state. | |
|
27 | generally cause the completion to fail). This is a feature -- since | |
|
28 | readline sets the tty device in raw (or cbreak) mode, printing a | |
|
29 | traceback wouldn't work well without some complicated hoopla to save, | |
|
30 | reset and restore the tty state. | |
|
31 | 31 | |
|
32 | 32 | - The evaluation of the NAME.NAME... form may cause arbitrary |
|
33 | application defined code to be executed if an object with a | |
|
34 | __getattr__ hook is found. Since it is the responsibility of the | |
|
35 | application (or the user) to enable this feature, I consider this an | |
|
36 | acceptable risk. More complicated expressions (e.g. function calls or | |
|
37 | indexing operations) are *not* evaluated. | |
|
33 | application defined code to be executed if an object with a | |
|
34 | ``__getattr__`` hook is found. Since it is the responsibility of the | |
|
35 | application (or the user) to enable this feature, I consider this an | |
|
36 | acceptable risk. More complicated expressions (e.g. function calls or | |
|
37 | indexing operations) are *not* evaluated. | |
|
38 | 38 | |
|
39 | 39 | - GNU readline is also used by the built-in functions input() and |
|
40 | raw_input(), and thus these also benefit/suffer from the completer | |
|
41 | features. Clearly an interactive application can benefit by | |
|
42 | specifying its own completer function and using raw_input() for all | |
|
43 | its input. | |
|
40 | raw_input(), and thus these also benefit/suffer from the completer | |
|
41 | features. Clearly an interactive application can benefit by | |
|
42 | specifying its own completer function and using raw_input() for all | |
|
43 | its input. | |
|
44 | 44 | |
|
45 | 45 | - When the original stdin is not a tty device, GNU readline is never |
|
46 | used, and this module (and the readline module) are silently inactive. | |
|
46 | used, and this module (and the readline module) are silently inactive. | |
|
47 | 47 | """ |
|
48 | 48 | |
|
49 | 49 | #***************************************************************************** |
@@ -441,17 +441,17 b' class IPCompleter(Completer):' | |||
|
441 | 441 | Inputs: |
|
442 | 442 | |
|
443 | 443 | - shell: a pointer to the ipython shell itself. This is needed |
|
444 | because this completer knows about magic functions, and those can | |
|
445 | only be accessed via the ipython instance. | |
|
444 | because this completer knows about magic functions, and those can | |
|
445 | only be accessed via the ipython instance. | |
|
446 | 446 | |
|
447 | 447 | - namespace: an optional dict where completions are performed. |
|
448 | 448 | |
|
449 | 449 | - global_namespace: secondary optional dict for completions, to |
|
450 | handle cases (such as IPython embedded inside functions) where | |
|
451 | both Python scopes are visible. | |
|
450 | handle cases (such as IPython embedded inside functions) where | |
|
451 | both Python scopes are visible. | |
|
452 | 452 | |
|
453 | 453 | - If alias_table is supplied, it should be a dictionary of aliases |
|
454 | to complete. | |
|
454 | to complete. | |
|
455 | 455 | |
|
456 | 456 | use_readline : bool, optional |
|
457 | 457 | If true, use the readline library. This completer can still function |
@@ -96,19 +96,24 b' class Tracer(object):' | |||
|
96 | 96 | def __init__(self,colors=None): |
|
97 | 97 | """Create a local debugger instance. |
|
98 | 98 | |
|
99 |
|
|
|
99 | Parameters | |
|
100 | ---------- | |
|
100 | 101 | |
|
101 | - `colors` (None): a string containing the name of the color scheme to | |
|
102 | use, it must be one of IPython's valid color schemes. If not given, the | |
|
103 | function will default to the current IPython scheme when running inside | |
|
104 | IPython, and to 'NoColor' otherwise. | |
|
102 | colors : str, optional | |
|
103 | The name of the color scheme to use, it must be one of IPython's | |
|
104 | valid color schemes. If not given, the function will default to | |
|
105 | the current IPython scheme when running inside IPython, and to | |
|
106 | 'NoColor' otherwise. | |
|
105 | 107 | |
|
106 |
|
|
|
108 | Examples | |
|
109 | -------- | |
|
110 | :: | |
|
107 | 111 | |
|
108 | from IPython.core.debugger import Tracer; debug_here = Tracer() | |
|
112 | from IPython.core.debugger import Tracer; debug_here = Tracer() | |
|
109 | 113 | |
|
110 |
|
|
|
111 | debug_here() # -> will open up the debugger at that point. | |
|
114 | Later in your code:: | |
|
115 | ||
|
116 | debug_here() # -> will open up the debugger at that point. | |
|
112 | 117 | |
|
113 | 118 | Once the debugger activates, you can use all of its regular commands to |
|
114 | 119 | step through code, set breakpoints, etc. See the pdb documentation |
@@ -916,9 +916,9 b' class InteractiveShell(SingletonConfigurable):' | |||
|
916 | 916 | Keywords: |
|
917 | 917 | |
|
918 | 918 | - force(False): by default, this routine checks the instance call_pdb |
|
919 | flag and does not actually invoke the debugger if the flag is false. | |
|
920 | The 'force' option forces the debugger to activate even if the flag | |
|
921 | is false. | |
|
919 | flag and does not actually invoke the debugger if the flag is false. | |
|
920 | The 'force' option forces the debugger to activate even if the flag | |
|
921 | is false. | |
|
922 | 922 | """ |
|
923 | 923 | |
|
924 | 924 | if not (force or self.call_pdb): |
@@ -2987,7 +2987,7 b' class InteractiveShell(SingletonConfigurable):' | |||
|
2987 | 2987 | Optional inputs: |
|
2988 | 2988 | |
|
2989 | 2989 | - data(None): if data is given, it gets written out to the temp file |
|
2990 | immediately, and the file is closed again.""" | |
|
2990 | immediately, and the file is closed again.""" | |
|
2991 | 2991 | |
|
2992 | 2992 | filename = tempfile.mktemp('.py', prefix) |
|
2993 | 2993 | self.tempfiles.append(filename) |
@@ -3030,13 +3030,14 b' class InteractiveShell(SingletonConfigurable):' | |||
|
3030 | 3030 | |
|
3031 | 3031 | Optional Parameters: |
|
3032 | 3032 | - raw(False): by default, the processed input is used. If this is |
|
3033 | true, the raw input history is used instead. | |
|
3033 | true, the raw input history is used instead. | |
|
3034 | 3034 | |
|
3035 | 3035 | Note that slices can be called with two notations: |
|
3036 | 3036 | |
|
3037 | 3037 | N:M -> standard python form, means including items N...(M-1). |
|
3038 | 3038 | |
|
3039 |
N-M -> include items N..M (closed endpoint). |
|
|
3039 | N-M -> include items N..M (closed endpoint). | |
|
3040 | """ | |
|
3040 | 3041 | lines = self.history_manager.get_range_by_str(range_str, raw=raw) |
|
3041 | 3042 | return "\n".join(x for _, _, x in lines) |
|
3042 | 3043 |
@@ -171,11 +171,11 b' which already exists. But you must first start the logging process with' | |||
|
171 | 171 | Inputs: |
|
172 | 172 | |
|
173 | 173 | - line_mod: possibly modified input, such as the transformations made |
|
174 |
by input prefilters or input handlers of various kinds. |
|
|
175 | always be valid Python. | |
|
174 | by input prefilters or input handlers of various kinds. This should | |
|
175 | always be valid Python. | |
|
176 | 176 | |
|
177 |
- line_ori: unmodified input line from the user. |
|
|
178 | necessarily valid Python. | |
|
177 | - line_ori: unmodified input line from the user. This is not | |
|
178 | necessarily valid Python. | |
|
179 | 179 | """ |
|
180 | 180 | |
|
181 | 181 | # Write the log line, but decide which one according to the |
@@ -489,11 +489,11 b' class Magics(object):' | |||
|
489 | 489 | MUST: |
|
490 | 490 | |
|
491 | 491 | - Use the method decorators `@line_magic` and `@cell_magic` to decorate |
|
492 | individual methods as magic functions, AND | |
|
492 | individual methods as magic functions, AND | |
|
493 | 493 | |
|
494 | 494 | - Use the class decorator `@magics_class` to ensure that the magic |
|
495 | methods are properly registered at the instance level upon instance | |
|
496 | initialization. | |
|
495 | methods are properly registered at the instance level upon instance | |
|
496 | initialization. | |
|
497 | 497 | |
|
498 | 498 | See :mod:`magic_functions` for examples of actual implementation classes. |
|
499 | 499 | """ |
@@ -102,75 +102,84 b' python-profiler package from non-free.""")' | |||
|
102 | 102 | |
|
103 | 103 | Options: |
|
104 | 104 | |
|
105 | -l <limit>: you can place restrictions on what or how much of the | |
|
106 | profile gets printed. The limit value can be: | |
|
107 | ||
|
108 | * A string: only information for function names containing this string | |
|
109 | is printed. | |
|
110 | ||
|
111 | * An integer: only these many lines are printed. | |
|
112 | ||
|
113 | * A float (between 0 and 1): this fraction of the report is printed | |
|
114 | (for example, use a limit of 0.4 to see the topmost 40% only). | |
|
115 | ||
|
116 | You can combine several limits with repeated use of the option. For | |
|
117 | example, '-l __init__ -l 5' will print only the topmost 5 lines of | |
|
118 | information about class constructors. | |
|
119 | ||
|
120 | -r: return the pstats.Stats object generated by the profiling. This | |
|
121 | object has all the information about the profile in it, and you can | |
|
122 | later use it for further analysis or in other functions. | |
|
123 | ||
|
124 | -s <key>: sort profile by given key. You can provide more than one key | |
|
125 | by using the option several times: '-s key1 -s key2 -s key3...'. The | |
|
126 | default sorting key is 'time'. | |
|
127 | ||
|
128 | The following is copied verbatim from the profile documentation | |
|
129 | referenced below: | |
|
130 | ||
|
131 | When more than one key is provided, additional keys are used as | |
|
132 | secondary criteria when the there is equality in all keys selected | |
|
133 | before them. | |
|
134 | ||
|
135 | Abbreviations can be used for any key names, as long as the | |
|
136 | abbreviation is unambiguous. The following are the keys currently | |
|
137 | defined: | |
|
138 | ||
|
139 | Valid Arg Meaning | |
|
140 | "calls" call count | |
|
141 | "cumulative" cumulative time | |
|
142 | "file" file name | |
|
143 | "module" file name | |
|
144 | "pcalls" primitive call count | |
|
145 | "line" line number | |
|
146 | "name" function name | |
|
147 |
|
|
|
148 | "stdname" standard name | |
|
149 | "time" internal time | |
|
150 | ||
|
151 | Note that all sorts on statistics are in descending order (placing | |
|
152 | most time consuming items first), where as name, file, and line number | |
|
153 | searches are in ascending order (i.e., alphabetical). The subtle | |
|
154 | distinction between "nfl" and "stdname" is that the standard name is a | |
|
155 | sort of the name as printed, which means that the embedded line | |
|
156 | numbers get compared in an odd way. For example, lines 3, 20, and 40 | |
|
157 | would (if the file names were the same) appear in the string order | |
|
158 | "20" "3" and "40". In contrast, "nfl" does a numeric compare of the | |
|
159 | line numbers. In fact, sort_stats("nfl") is the same as | |
|
160 | sort_stats("name", "file", "line"). | |
|
161 | ||
|
162 | -T <filename>: save profile results as shown on screen to a text | |
|
163 | file. The profile is still shown on screen. | |
|
164 | ||
|
165 | -D <filename>: save (via dump_stats) profile statistics to given | |
|
166 | filename. This data is in a format understood by the pstats module, and | |
|
167 | is generated by a call to the dump_stats() method of profile | |
|
168 | objects. The profile is still shown on screen. | |
|
169 | ||
|
170 | -q: suppress output to the pager. Best used with -T and/or -D above. | |
|
105 | -l <limit> | |
|
106 | you can place restrictions on what or how much of the | |
|
107 | profile gets printed. The limit value can be: | |
|
108 | ||
|
109 | * A string: only information for function names containing this string | |
|
110 | is printed. | |
|
111 | ||
|
112 | * An integer: only these many lines are printed. | |
|
113 | ||
|
114 | * A float (between 0 and 1): this fraction of the report is printed | |
|
115 | (for example, use a limit of 0.4 to see the topmost 40% only). | |
|
116 | ||
|
117 | You can combine several limits with repeated use of the option. For | |
|
118 | example, ``-l __init__ -l 5`` will print only the topmost 5 lines of | |
|
119 | information about class constructors. | |
|
120 | ||
|
121 | -r | |
|
122 | return the pstats.Stats object generated by the profiling. This | |
|
123 | object has all the information about the profile in it, and you can | |
|
124 | later use it for further analysis or in other functions. | |
|
125 | ||
|
126 | -s <key> | |
|
127 | sort profile by given key. You can provide more than one key | |
|
128 | by using the option several times: '-s key1 -s key2 -s key3...'. The | |
|
129 | default sorting key is 'time'. | |
|
130 | ||
|
131 | The following is copied verbatim from the profile documentation | |
|
132 | referenced below: | |
|
133 | ||
|
134 | When more than one key is provided, additional keys are used as | |
|
135 | secondary criteria when the there is equality in all keys selected | |
|
136 | before them. | |
|
137 | ||
|
138 | Abbreviations can be used for any key names, as long as the | |
|
139 | abbreviation is unambiguous. The following are the keys currently | |
|
140 | defined: | |
|
141 | ||
|
142 | ============ ===================== | |
|
143 | Valid Arg Meaning | |
|
144 | ============ ===================== | |
|
145 | "calls" call count | |
|
146 | "cumulative" cumulative time | |
|
147 | "file" file name | |
|
148 | "module" file name | |
|
149 | "pcalls" primitive call count | |
|
150 | "line" line number | |
|
151 | "name" function name | |
|
152 | "nfl" name/file/line | |
|
153 | "stdname" standard name | |
|
154 | "time" internal time | |
|
155 | ============ ===================== | |
|
156 | ||
|
157 | Note that all sorts on statistics are in descending order (placing | |
|
158 | most time consuming items first), where as name, file, and line number | |
|
159 | searches are in ascending order (i.e., alphabetical). The subtle | |
|
160 | distinction between "nfl" and "stdname" is that the standard name is a | |
|
161 | sort of the name as printed, which means that the embedded line | |
|
162 | numbers get compared in an odd way. For example, lines 3, 20, and 40 | |
|
163 | would (if the file names were the same) appear in the string order | |
|
164 | "20" "3" and "40". In contrast, "nfl" does a numeric compare of the | |
|
165 | line numbers. In fact, sort_stats("nfl") is the same as | |
|
166 | sort_stats("name", "file", "line"). | |
|
167 | ||
|
168 | -T <filename> | |
|
169 | save profile results as shown on screen to a text | |
|
170 | file. The profile is still shown on screen. | |
|
171 | ||
|
172 | -D <filename> | |
|
173 | save (via dump_stats) profile statistics to given | |
|
174 | filename. This data is in a format understood by the pstats module, and | |
|
175 | is generated by a call to the dump_stats() method of profile | |
|
176 | objects. The profile is still shown on screen. | |
|
177 | ||
|
178 | -q | |
|
179 | suppress output to the pager. Best used with -T and/or -D above. | |
|
171 | 180 | |
|
172 | 181 | If you want to run complete programs under the profiler's control, use |
|
173 |
|
|
|
182 | ``%run -p [prof_opts] filename.py [args to program]`` where prof_opts | |
|
174 | 183 | contains profiler specific options as described here. |
|
175 | 184 | |
|
176 | 185 | You can read the complete documentation for the profile module with:: |
@@ -362,7 +371,8 b' python-profiler package from non-free.""")' | |||
|
362 | 371 | file_finder=get_py_filename): |
|
363 | 372 | """Run the named file inside IPython as a program. |
|
364 | 373 | |
|
365 | Usage: | |
|
374 | Usage:: | |
|
375 | ||
|
366 | 376 | %run [-n -i -e -G] |
|
367 | 377 | [( -t [-N<N>] | -d [-b<N>] | -p [profile options] )] |
|
368 | 378 | ( -m mod | file ) [args] |
@@ -371,14 +381,13 b' python-profiler package from non-free.""")' | |||
|
371 | 381 | the program (put in sys.argv). Then, control returns to IPython's |
|
372 | 382 | prompt. |
|
373 | 383 | |
|
374 |
This is similar to running at a system prompt |
|
|
375 | $ python file args\\ | |
|
384 | This is similar to running at a system prompt ``python file args``, | |
|
376 | 385 | but with the advantage of giving you IPython's tracebacks, and of |
|
377 | 386 | loading all variables into your interactive namespace for further use |
|
378 | 387 | (unless -p is used, see below). |
|
379 | 388 | |
|
380 | 389 | The file is executed in a namespace initially consisting only of |
|
381 | __name__=='__main__' and sys.argv constructed as indicated. It thus | |
|
390 | ``__name__=='__main__'`` and sys.argv constructed as indicated. It thus | |
|
382 | 391 | sees its environment as if it were being run as a stand-alone program |
|
383 | 392 | (except for sharing global objects such as previously imported |
|
384 | 393 | modules). But after execution, the IPython interactive namespace gets |
@@ -390,33 +399,37 b' python-profiler package from non-free.""")' | |||
|
390 | 399 | '*', '?', '[seq]' and '[!seq]' can be used. Additionally, |
|
391 | 400 | tilde '~' will be expanded into user's home directory. Unlike |
|
392 | 401 | real shells, quotation does not suppress expansions. Use |
|
393 |
*two* back slashes (e.g. |
|
|
402 | *two* back slashes (e.g. ``\\\\*``) to suppress expansions. | |
|
394 | 403 | To completely disable these expansions, you can use -G flag. |
|
395 | 404 | |
|
396 | 405 | Options: |
|
397 | 406 | |
|
398 | -n: __name__ is NOT set to '__main__', but to the running file's name | |
|
399 | without extension (as python does under import). This allows running | |
|
400 | scripts and reloading the definitions in them without calling code | |
|
401 | protected by an ' if __name__ == "__main__" ' clause. | |
|
402 | ||
|
403 | -i: run the file in IPython's namespace instead of an empty one. This | |
|
404 | is useful if you are experimenting with code written in a text editor | |
|
405 | which depends on variables defined interactively. | |
|
406 | ||
|
407 | -e: ignore sys.exit() calls or SystemExit exceptions in the script | |
|
408 | being run. This is particularly useful if IPython is being used to | |
|
409 | run unittests, which always exit with a sys.exit() call. In such | |
|
410 | cases you are interested in the output of the test results, not in | |
|
411 | seeing a traceback of the unittest module. | |
|
412 | ||
|
413 | -t: print timing information at the end of the run. IPython will give | |
|
414 | you an estimated CPU time consumption for your script, which under | |
|
415 | Unix uses the resource module to avoid the wraparound problems of | |
|
416 | time.clock(). Under Unix, an estimate of time spent on system tasks | |
|
417 | is also given (for Windows platforms this is reported as 0.0). | |
|
418 | ||
|
419 | If -t is given, an additional -N<N> option can be given, where <N> | |
|
407 | -n | |
|
408 | __name__ is NOT set to '__main__', but to the running file's name | |
|
409 | without extension (as python does under import). This allows running | |
|
410 | scripts and reloading the definitions in them without calling code | |
|
411 | protected by an ``if __name__ == "__main__"`` clause. | |
|
412 | ||
|
413 | -i | |
|
414 | run the file in IPython's namespace instead of an empty one. This | |
|
415 | is useful if you are experimenting with code written in a text editor | |
|
416 | which depends on variables defined interactively. | |
|
417 | ||
|
418 | -e | |
|
419 | ignore sys.exit() calls or SystemExit exceptions in the script | |
|
420 | being run. This is particularly useful if IPython is being used to | |
|
421 | run unittests, which always exit with a sys.exit() call. In such | |
|
422 | cases you are interested in the output of the test results, not in | |
|
423 | seeing a traceback of the unittest module. | |
|
424 | ||
|
425 | -t | |
|
426 | print timing information at the end of the run. IPython will give | |
|
427 | you an estimated CPU time consumption for your script, which under | |
|
428 | Unix uses the resource module to avoid the wraparound problems of | |
|
429 | time.clock(). Under Unix, an estimate of time spent on system tasks | |
|
430 | is also given (for Windows platforms this is reported as 0.0). | |
|
431 | ||
|
432 | If -t is given, an additional ``-N<N>`` option can be given, where <N> | |
|
420 | 433 | must be an integer indicating how many times you want the script to |
|
421 | 434 | run. The final timing report will include total and per run results. |
|
422 | 435 | |
@@ -424,74 +437,78 b' python-profiler package from non-free.""")' | |||
|
424 | 437 | |
|
425 | 438 | In [1]: run -t uniq_stable |
|
426 | 439 | |
|
427 |
IPython CPU timings (estimated): |
|
|
428 |
User : 0.19597 s. |
|
|
429 |
System: 0.0 s. |
|
|
440 | IPython CPU timings (estimated): | |
|
441 | User : 0.19597 s. | |
|
442 | System: 0.0 s. | |
|
430 | 443 | |
|
431 | 444 | In [2]: run -t -N5 uniq_stable |
|
432 | 445 | |
|
433 |
IPython CPU timings (estimated): |
|
|
434 |
Total runs performed: 5 |
|
|
435 |
Times : Total Per run |
|
|
436 |
User : 0.910862 s, 0.1821724 s. |
|
|
446 | IPython CPU timings (estimated): | |
|
447 | Total runs performed: 5 | |
|
448 | Times : Total Per run | |
|
449 | User : 0.910862 s, 0.1821724 s. | |
|
437 | 450 | System: 0.0 s, 0.0 s. |
|
438 | 451 | |
|
439 | -d: run your program under the control of pdb, the Python debugger. | |
|
440 | This allows you to execute your program step by step, watch variables, | |
|
441 | etc. Internally, what IPython does is similar to calling: | |
|
452 | -d | |
|
453 | run your program under the control of pdb, the Python debugger. | |
|
454 | This allows you to execute your program step by step, watch variables, | |
|
455 | etc. Internally, what IPython does is similar to calling:: | |
|
442 | 456 | |
|
443 | pdb.run('execfile("YOURFILENAME")') | |
|
457 | pdb.run('execfile("YOURFILENAME")') | |
|
444 | 458 | |
|
445 | with a breakpoint set on line 1 of your file. You can change the line | |
|
446 | number for this automatic breakpoint to be <N> by using the -bN option | |
|
447 |
(where N must be an integer). |
|
|
459 | with a breakpoint set on line 1 of your file. You can change the line | |
|
460 | number for this automatic breakpoint to be <N> by using the -bN option | |
|
461 | (where N must be an integer). For example:: | |
|
448 | 462 | |
|
449 | %run -d -b40 myscript | |
|
463 | %run -d -b40 myscript | |
|
450 | 464 | |
|
451 | will set the first breakpoint at line 40 in myscript.py. Note that | |
|
452 | the first breakpoint must be set on a line which actually does | |
|
453 | something (not a comment or docstring) for it to stop execution. | |
|
465 | will set the first breakpoint at line 40 in myscript.py. Note that | |
|
466 | the first breakpoint must be set on a line which actually does | |
|
467 | something (not a comment or docstring) for it to stop execution. | |
|
454 | 468 | |
|
455 | Or you can specify a breakpoint in a different file:: | |
|
469 | Or you can specify a breakpoint in a different file:: | |
|
456 | 470 | |
|
457 | %run -d -b myotherfile.py:20 myscript | |
|
471 | %run -d -b myotherfile.py:20 myscript | |
|
458 | 472 | |
|
459 | When the pdb debugger starts, you will see a (Pdb) prompt. You must | |
|
460 | first enter 'c' (without quotes) to start execution up to the first | |
|
461 | breakpoint. | |
|
473 | When the pdb debugger starts, you will see a (Pdb) prompt. You must | |
|
474 | first enter 'c' (without quotes) to start execution up to the first | |
|
475 | breakpoint. | |
|
462 | 476 | |
|
463 | Entering 'help' gives information about the use of the debugger. You | |
|
464 | can easily see pdb's full documentation with "import pdb;pdb.help()" | |
|
465 | at a prompt. | |
|
477 | Entering 'help' gives information about the use of the debugger. You | |
|
478 | can easily see pdb's full documentation with "import pdb;pdb.help()" | |
|
479 | at a prompt. | |
|
466 | 480 | |
|
467 | -p: run program under the control of the Python profiler module (which | |
|
468 | prints a detailed report of execution times, function calls, etc). | |
|
481 | -p | |
|
482 | run program under the control of the Python profiler module (which | |
|
483 | prints a detailed report of execution times, function calls, etc). | |
|
469 | 484 | |
|
470 | You can pass other options after -p which affect the behavior of the | |
|
471 | profiler itself. See the docs for %prun for details. | |
|
485 | You can pass other options after -p which affect the behavior of the | |
|
486 | profiler itself. See the docs for %prun for details. | |
|
472 | 487 | |
|
473 | In this mode, the program's variables do NOT propagate back to the | |
|
474 | IPython interactive namespace (because they remain in the namespace | |
|
475 | where the profiler executes them). | |
|
488 | In this mode, the program's variables do NOT propagate back to the | |
|
489 | IPython interactive namespace (because they remain in the namespace | |
|
490 | where the profiler executes them). | |
|
476 | 491 | |
|
477 | Internally this triggers a call to %prun, see its documentation for | |
|
478 | details on the options available specifically for profiling. | |
|
492 | Internally this triggers a call to %prun, see its documentation for | |
|
493 | details on the options available specifically for profiling. | |
|
479 | 494 | |
|
480 | 495 | There is one special usage for which the text above doesn't apply: |
|
481 | 496 | if the filename ends with .ipy, the file is run as ipython script, |
|
482 | 497 | just as if the commands were written on IPython prompt. |
|
483 | 498 | |
|
484 | -m: specify module name to load instead of script path. Similar to | |
|
485 | the -m option for the python interpreter. Use this option last if you | |
|
486 | want to combine with other %run options. Unlike the python interpreter | |
|
487 | only source modules are allowed no .pyc or .pyo files. | |
|
488 | For example:: | |
|
499 | -m | |
|
500 | specify module name to load instead of script path. Similar to | |
|
501 | the -m option for the python interpreter. Use this option last if you | |
|
502 | want to combine with other %run options. Unlike the python interpreter | |
|
503 | only source modules are allowed no .pyc or .pyo files. | |
|
504 | For example:: | |
|
489 | 505 | |
|
490 | %run -m example | |
|
506 | %run -m example | |
|
491 | 507 | |
|
492 | will run the example module. | |
|
508 | will run the example module. | |
|
493 | 509 | |
|
494 | -G: disable shell-like glob expansion of arguments. | |
|
510 | -G | |
|
511 | disable shell-like glob expansion of arguments. | |
|
495 | 512 | |
|
496 | 513 | """ |
|
497 | 514 |
@@ -42,34 +42,48 b' class LoggingMagics(Magics):' | |||
|
42 | 42 | history up to that point and then continues logging. |
|
43 | 43 | |
|
44 | 44 | %logstart takes a second optional parameter: logging mode. This can be one |
|
45 |
of (note that the modes are given unquoted): |
|
|
46 | append: well, that says it.\\ | |
|
47 | backup: rename (if exists) to name~ and start name.\\ | |
|
48 | global: single logfile in your home dir, appended to.\\ | |
|
49 | over : overwrite existing log.\\ | |
|
50 | rotate: create rotating logs name.1~, name.2~, etc. | |
|
45 | of (note that the modes are given unquoted): | |
|
46 | ||
|
47 | append | |
|
48 | Keep logging at the end of any existing file. | |
|
49 | ||
|
50 | backup | |
|
51 | Rename any existing file to name~ and start name. | |
|
52 | ||
|
53 | global | |
|
54 | Append to a single logfile in your home directory. | |
|
55 | ||
|
56 | over | |
|
57 | Overwrite any existing log. | |
|
58 | ||
|
59 | rotate | |
|
60 | Create rotating logs: name.1~, name.2~, etc. | |
|
51 | 61 | |
|
52 | 62 | Options: |
|
53 | 63 | |
|
54 | -o: log also IPython's output. In this mode, all commands which | |
|
55 | generate an Out[NN] prompt are recorded to the logfile, right after | |
|
56 | their corresponding input line. The output lines are always | |
|
57 | prepended with a '#[Out]# ' marker, so that the log remains valid | |
|
58 | Python code. | |
|
64 | -o | |
|
65 | log also IPython's output. In this mode, all commands which | |
|
66 | generate an Out[NN] prompt are recorded to the logfile, right after | |
|
67 | their corresponding input line. The output lines are always | |
|
68 | prepended with a '#[Out]# ' marker, so that the log remains valid | |
|
69 | Python code. | |
|
59 | 70 | |
|
60 | 71 | Since this marker is always the same, filtering only the output from |
|
61 | 72 | a log is very easy, using for example a simple awk call:: |
|
62 | 73 | |
|
63 | 74 | awk -F'#\\[Out\\]# ' '{if($2) {print $2}}' ipython_log.py |
|
64 | 75 | |
|
65 | -r: log 'raw' input. Normally, IPython's logs contain the processed | |
|
66 | input, so that user lines are logged in their final form, converted | |
|
67 | into valid Python. For example, %Exit is logged as | |
|
68 | _ip.magic("Exit"). If the -r flag is given, all input is logged | |
|
69 | exactly as typed, with no transformations applied. | |
|
70 | ||
|
71 | -t: put timestamps before each input line logged (these are put in | |
|
72 |
|
|
|
76 | -r | |
|
77 | log 'raw' input. Normally, IPython's logs contain the processed | |
|
78 | input, so that user lines are logged in their final form, converted | |
|
79 | into valid Python. For example, %Exit is logged as | |
|
80 | _ip.magic("Exit"). If the -r flag is given, all input is logged | |
|
81 | exactly as typed, with no transformations applied. | |
|
82 | ||
|
83 | -t | |
|
84 | put timestamps before each input line logged (these are put in | |
|
85 | comments). | |
|
86 | """ | |
|
73 | 87 | |
|
74 | 88 | opts,par = self.parse_options(parameter_s,'ort') |
|
75 | 89 | log_output = 'o' in opts |
@@ -354,10 +354,10 b' class NamespaceMagics(Magics):' | |||
|
354 | 354 | - For {},[],(): their length. |
|
355 | 355 | |
|
356 | 356 | - For numpy arrays, a summary with shape, number of |
|
357 | elements, typecode and size in memory. | |
|
357 | elements, typecode and size in memory. | |
|
358 | 358 | |
|
359 | 359 | - Everything else: a string representation, snipping their middle if |
|
360 | too long. | |
|
360 | too long. | |
|
361 | 361 | |
|
362 | 362 | Examples |
|
363 | 363 | -------- |
@@ -156,8 +156,8 b' def getsource(obj,is_binary=False):' | |||
|
156 | 156 | Optional inputs: |
|
157 | 157 | |
|
158 | 158 | - is_binary: whether the object is known to come from a binary source. |
|
159 | This implementation will skip returning any output for binary objects, but | |
|
160 | custom extractors may know how to meaningfully process them.""" | |
|
159 | This implementation will skip returning any output for binary objects, but | |
|
160 | custom extractors may know how to meaningfully process them.""" | |
|
161 | 161 | |
|
162 | 162 | if is_binary: |
|
163 | 163 | return None |
@@ -545,7 +545,7 b' class Inspector:' | |||
|
545 | 545 | - formatter: special formatter for docstrings (see pdoc) |
|
546 | 546 | |
|
547 | 547 | - info: a structure with some information fields which may have been |
|
548 | precomputed already. | |
|
548 | precomputed already. | |
|
549 | 549 | |
|
550 | 550 | - detail_level: if set to 1, more information is given. |
|
551 | 551 | """ |
@@ -609,7 +609,7 b' class Inspector:' | |||
|
609 | 609 | - formatter: special formatter for docstrings (see pdoc) |
|
610 | 610 | |
|
611 | 611 | - info: a structure with some information fields which may have been |
|
612 | precomputed already. | |
|
612 | precomputed already. | |
|
613 | 613 | |
|
614 | 614 | - detail_level: if set to 1, more information is given. |
|
615 | 615 | """ |
@@ -829,8 +829,8 b' class Inspector:' | |||
|
829 | 829 | Arguments: |
|
830 | 830 | |
|
831 | 831 | - pattern: string containing shell-like wildcards to use in namespace |
|
832 | searches and optionally a type specification to narrow the search to | |
|
833 | objects of that type. | |
|
832 | searches and optionally a type specification to narrow the search to | |
|
833 | objects of that type. | |
|
834 | 834 | |
|
835 | 835 | - ns_table: dict of name->namespaces for search. |
|
836 | 836 | |
@@ -841,7 +841,7 b' class Inspector:' | |||
|
841 | 841 | - ignore_case(False): make the search case-insensitive. |
|
842 | 842 | |
|
843 | 843 | - show_all(False): show all names, including those starting with |
|
844 | underscores. | |
|
844 | underscores. | |
|
845 | 845 | """ |
|
846 | 846 | #print 'ps pattern:<%r>' % pattern # dbg |
|
847 | 847 |
@@ -325,9 +325,11 b" def snip_print(str,width = 75,print_full = 0,header = ''):" | |||
|
325 | 325 | """Print a string snipping the midsection to fit in width. |
|
326 | 326 | |
|
327 | 327 | print_full: mode control: |
|
328 | ||
|
328 | 329 | - 0: only snip long strings |
|
329 | 330 | - 1: send to page() directly. |
|
330 | 331 | - 2: snip long strings and ask for full length viewing with page() |
|
332 | ||
|
331 | 333 | Return 1 if snipping was necessary, 0 otherwise.""" |
|
332 | 334 | |
|
333 | 335 | if print_full == 1: |
@@ -8,7 +8,8 b' ColorTB class is a solution to that problem. It colors the different parts of a' | |||
|
8 | 8 | traceback in a manner similar to what you would expect from a syntax-highlighting |
|
9 | 9 | text editor. |
|
10 | 10 | |
|
11 | Installation instructions for ColorTB: | |
|
11 | Installation instructions for ColorTB:: | |
|
12 | ||
|
12 | 13 | import sys,ultratb |
|
13 | 14 | sys.excepthook = ultratb.ColorTB() |
|
14 | 15 | |
@@ -21,7 +22,7 b' but kind of neat, and maybe useful for long-running programs that you believe' | |||
|
21 | 22 | are bug-free. If a crash *does* occur in that type of program you want details. |
|
22 | 23 | Give it a shot--you'll love it or you'll hate it. |
|
23 | 24 | |
|
24 | Note: | |
|
25 | .. note:: | |
|
25 | 26 | |
|
26 | 27 | The Verbose mode prints the variables currently visible where the exception |
|
27 | 28 | happened (shortening their strings if too long). This can potentially be |
@@ -36,25 +37,28 b' Note:' | |||
|
36 | 37 | Verbose). |
|
37 | 38 | |
|
38 | 39 | |
|
39 | Installation instructions for ColorTB: | |
|
40 | Installation instructions for ColorTB:: | |
|
41 | ||
|
40 | 42 | import sys,ultratb |
|
41 | 43 | sys.excepthook = ultratb.VerboseTB() |
|
42 | 44 | |
|
43 | 45 | Note: Much of the code in this module was lifted verbatim from the standard |
|
44 | 46 | library module 'traceback.py' and Ka-Ping Yee's 'cgitb.py'. |
|
45 | 47 | |
|
46 |
|
|
|
48 | Color schemes | |
|
49 | ------------- | |
|
50 | ||
|
47 | 51 | The colors are defined in the class TBTools through the use of the |
|
48 | 52 | ColorSchemeTable class. Currently the following exist: |
|
49 | 53 | |
|
50 | 54 | - NoColor: allows all of this module to be used in any terminal (the color |
|
51 | escapes are just dummy blank strings). | |
|
55 | escapes are just dummy blank strings). | |
|
52 | 56 | |
|
53 | 57 | - Linux: is meant to look good in a terminal like the Linux console (black |
|
54 | or very dark background). | |
|
58 | or very dark background). | |
|
55 | 59 | |
|
56 | 60 | - LightBG: similar to Linux but swaps dark/light colors to be more readable |
|
57 | in light background terminals. | |
|
61 | in light background terminals. | |
|
58 | 62 | |
|
59 | 63 | You can implement other color schemes easily, the syntax is fairly |
|
60 | 64 | self-explanatory. Please send back new schemes you develop to the author for |
@@ -359,8 +363,8 b' class TBTools(object):' | |||
|
359 | 363 | Valid values are: |
|
360 | 364 | |
|
361 | 365 | - None: the default, which means that IPython will dynamically resolve |
|
362 | to io.stdout. This ensures compatibility with most tools, including | |
|
363 | Windows (where plain stdout doesn't recognize ANSI escapes). | |
|
366 | to io.stdout. This ensures compatibility with most tools, including | |
|
367 | Windows (where plain stdout doesn't recognize ANSI escapes). | |
|
364 | 368 | |
|
365 | 369 | - Any object with 'write' and 'flush' attributes. |
|
366 | 370 | """ |
@@ -974,9 +978,9 b' class VerboseTB(TBTools):' | |||
|
974 | 978 | Keywords: |
|
975 | 979 | |
|
976 | 980 | - force(False): by default, this routine checks the instance call_pdb |
|
977 | flag and does not actually invoke the debugger if the flag is false. | |
|
978 | The 'force' option forces the debugger to activate even if the flag | |
|
979 | is false. | |
|
981 | flag and does not actually invoke the debugger if the flag is false. | |
|
982 | The 'force' option forces the debugger to activate even if the flag | |
|
983 | is false. | |
|
980 | 984 | |
|
981 | 985 | If the call_pdb flag is set, the pdb interactive debugger is |
|
982 | 986 | invoked. In all cases, the self.tb reference to the current traceback |
@@ -14,14 +14,14 b' The classes are (see their docstrings for further details):' | |||
|
14 | 14 | - Demo: pure python demos |
|
15 | 15 | |
|
16 | 16 | - IPythonDemo: demos with input to be processed by IPython as if it had been |
|
17 | typed interactively (so magics work, as well as any other special syntax you | |
|
18 | may have added via input prefilters). | |
|
17 | typed interactively (so magics work, as well as any other special syntax you | |
|
18 | may have added via input prefilters). | |
|
19 | 19 | |
|
20 | 20 | - LineDemo: single-line version of the Demo class. These demos are executed |
|
21 | one line at a time, and require no markup. | |
|
21 | one line at a time, and require no markup. | |
|
22 | 22 | |
|
23 | 23 | - IPythonLineDemo: IPython version of the LineDemo class (the demo is |
|
24 | executed a line at a time, but processed via IPython). | |
|
24 | executed a line at a time, but processed via IPython). | |
|
25 | 25 | |
|
26 | 26 | - ClearMixin: mixin to make Demo classes with less visual clutter. It |
|
27 | 27 | declares an empty marquee and a pre_cmd that clears the screen before each |
@@ -214,18 +214,18 b' class Demo(object):' | |||
|
214 | 214 | Optional inputs: |
|
215 | 215 | |
|
216 | 216 | - title: a string to use as the demo name. Of most use when the demo |
|
217 | you are making comes from an object that has no filename, or if you | |
|
218 | want an alternate denotation distinct from the filename. | |
|
217 | you are making comes from an object that has no filename, or if you | |
|
218 | want an alternate denotation distinct from the filename. | |
|
219 | 219 | |
|
220 | 220 | - arg_str(''): a string of arguments, internally converted to a list |
|
221 | just like sys.argv, so the demo script can see a similar | |
|
222 | environment. | |
|
221 | just like sys.argv, so the demo script can see a similar | |
|
222 | environment. | |
|
223 | 223 | |
|
224 | 224 | - auto_all(None): global flag to run all blocks automatically without |
|
225 | confirmation. This attribute overrides the block-level tags and | |
|
226 | applies to the whole demo. It is an attribute of the object, and | |
|
227 | can be changed at runtime simply by reassigning it to a boolean | |
|
228 | value. | |
|
225 | confirmation. This attribute overrides the block-level tags and | |
|
226 | applies to the whole demo. It is an attribute of the object, and | |
|
227 | can be changed at runtime simply by reassigning it to a boolean | |
|
228 | value. | |
|
229 | 229 | """ |
|
230 | 230 | if hasattr(src, "read"): |
|
231 | 231 | # It seems to be a file or a file-like object |
@@ -93,9 +93,9 b' class InteractiveRunner(object):' | |||
|
93 | 93 | - program: command to execute the given program. |
|
94 | 94 | |
|
95 | 95 | - prompts: a list of patterns to match as valid prompts, in the |
|
96 | format used by pexpect. This basically means that it can be either | |
|
97 | a string (to be compiled as a regular expression) or a list of such | |
|
98 | (it must be a true list, as pexpect does type checks). | |
|
96 | format used by pexpect. This basically means that it can be either | |
|
97 | a string (to be compiled as a regular expression) or a list of such | |
|
98 | (it must be a true list, as pexpect does type checks). | |
|
99 | 99 | |
|
100 | 100 | If more than one prompt is given, the first is treated as the main |
|
101 | 101 | program prompt and the others as 'continuation' prompts, like |
@@ -107,19 +107,19 b' class InteractiveRunner(object):' | |||
|
107 | 107 | Optional inputs: |
|
108 | 108 | |
|
109 | 109 | - args(None): optional list of strings to pass as arguments to the |
|
110 | child program. | |
|
110 | child program. | |
|
111 | 111 | |
|
112 | 112 | - out(sys.stdout): if given, an output stream to be used when writing |
|
113 | output. The only requirement is that it must have a .write() method. | |
|
113 | output. The only requirement is that it must have a .write() method. | |
|
114 | 114 | |
|
115 | 115 | Public members not parameterized in the constructor: |
|
116 | 116 | |
|
117 | 117 | - delaybeforesend(0): Newer versions of pexpect have a delay before |
|
118 | sending each new input. For our purposes here, it's typically best | |
|
119 | to just set this to zero, but if you encounter reliability problems | |
|
120 | or want an interactive run to pause briefly at each prompt, just | |
|
121 | increase this value (it is measured in seconds). Note that this | |
|
122 | variable is not honored at all by older versions of pexpect. | |
|
118 | sending each new input. For our purposes here, it's typically best | |
|
119 | to just set this to zero, but if you encounter reliability problems | |
|
120 | or want an interactive run to pause briefly at each prompt, just | |
|
121 | increase this value (it is measured in seconds). Note that this | |
|
122 | variable is not honored at all by older versions of pexpect. | |
|
123 | 123 | """ |
|
124 | 124 | |
|
125 | 125 | self.program = program |
@@ -154,7 +154,7 b' class InteractiveRunner(object):' | |||
|
154 | 154 | |
|
155 | 155 | Inputs: |
|
156 | 156 | |
|
157 | -fname: name of the file to execute. | |
|
157 | - fname: name of the file to execute. | |
|
158 | 158 | |
|
159 | 159 | See the run_source docstring for the meaning of the optional |
|
160 | 160 | arguments.""" |
@@ -173,15 +173,15 b' class InteractiveRunner(object):' | |||
|
173 | 173 | Inputs: |
|
174 | 174 | |
|
175 | 175 | - source: a string of code to be executed, or an open file object we |
|
176 | can iterate over. | |
|
176 | can iterate over. | |
|
177 | 177 | |
|
178 | 178 | Optional inputs: |
|
179 | 179 | |
|
180 | 180 | - interact(False): if true, start to interact with the running |
|
181 | program at the end of the script. Otherwise, just exit. | |
|
181 | program at the end of the script. Otherwise, just exit. | |
|
182 | 182 | |
|
183 | 183 | - get_output(False): if true, capture the output of the child process |
|
184 | (filtering the input commands out) and return it as a string. | |
|
184 | (filtering the input commands out) and return it as a string. | |
|
185 | 185 | |
|
186 | 186 | Returns: |
|
187 | 187 | A string containing the process output, but only if requested. |
@@ -19,7 +19,8 b' def cell_preprocessor(function):' | |||
|
19 | 19 | Wrap a function to be executed on all cells of a notebook |
|
20 | 20 | |
|
21 | 21 | Wrapped Parameters |
|
22 | ---------- | |
|
22 | ------------------ | |
|
23 | ||
|
23 | 24 | cell : NotebookNode cell |
|
24 | 25 | Notebook cell being processed |
|
25 | 26 | resources : dictionary |
@@ -44,8 +44,8 b' class AvoidUNCPath(object):' | |||
|
44 | 44 | change and None otherwise, so that users can apply the necessary adjustment |
|
45 | 45 | to their system calls in the event of a change. |
|
46 | 46 | |
|
47 | Example | |
|
48 | ------- | |
|
47 | Examples | |
|
48 | -------- | |
|
49 | 49 | :: |
|
50 | 50 | cmd = 'dir' |
|
51 | 51 | with AvoidUNCPath() as path: |
@@ -161,8 +161,8 b' class AvoidUNCPath(object):' | |||
|
161 | 161 | change and None otherwise, so that users can apply the necessary adjustment |
|
162 | 162 | to their system calls in the event of a change. |
|
163 | 163 | |
|
164 | Example | |
|
165 | ------- | |
|
164 | Examples | |
|
165 | -------- | |
|
166 | 166 | :: |
|
167 | 167 | cmd = 'dir' |
|
168 | 168 | with AvoidUNCPath() as path: |
@@ -69,12 +69,12 b' class CapturedIO(object):' | |||
|
69 | 69 | |
|
70 | 70 | Each instance `c` has three attributes: |
|
71 | 71 | |
|
72 |
|
|
|
73 |
|
|
|
74 |
|
|
|
72 | - ``c.stdout`` : standard output as a string | |
|
73 | - ``c.stderr`` : standard error as a string | |
|
74 | - ``c.outputs``: a list of rich display outputs | |
|
75 | 75 | |
|
76 | Additionally, there's a `c.show()` method which will print all of the | |
|
77 | above in the same order, and can be invoked simply via `c()`. | |
|
76 | Additionally, there's a ``c.show()`` method which will print all of the | |
|
77 | above in the same order, and can be invoked simply via ``c()``. | |
|
78 | 78 | """ |
|
79 | 79 | |
|
80 | 80 | def __init__(self, stdout, stderr, outputs=None): |
@@ -105,8 +105,8 b' class CapturedIO(object):' | |||
|
105 | 105 | def outputs(self): |
|
106 | 106 | """A list of the captured rich display outputs, if any. |
|
107 | 107 | |
|
108 | If you have a CapturedIO object `c`, these can be displayed in IPython | |
|
109 | using: | |
|
108 | If you have a CapturedIO object ``c``, these can be displayed in IPython | |
|
109 | using:: | |
|
110 | 110 | |
|
111 | 111 | from IPython.display import display |
|
112 | 112 | for o in c.outputs: |
@@ -27,8 +27,8 b' class preserve_keys(object):' | |||
|
27 | 27 | which did not exist when entering the context manager will be |
|
28 | 28 | deleted. |
|
29 | 29 | |
|
30 | Example | |
|
31 | ------- | |
|
30 | Examples | |
|
31 | -------- | |
|
32 | 32 | |
|
33 | 33 | >>> d = {'a': 1, 'b': 2, 'c': 3} |
|
34 | 34 | >>> with preserve_keys(d, 'b', 'c', 'd'): |
@@ -98,18 +98,20 b' def pkg_info(pkg_path):' | |||
|
98 | 98 | def sys_info(): |
|
99 | 99 | """Return useful information about IPython and the system, as a string. |
|
100 | 100 | |
|
101 | Example | |
|
102 | ------- | |
|
103 | In [2]: print sys_info() | |
|
104 | {'commit_hash': '144fdae', # random | |
|
105 | 'commit_source': 'repository', | |
|
106 | 'ipython_path': '/home/fperez/usr/lib/python2.6/site-packages/IPython', | |
|
107 | 'ipython_version': '0.11.dev', | |
|
108 | 'os_name': 'posix', | |
|
109 | 'platform': 'Linux-2.6.35-22-generic-i686-with-Ubuntu-10.10-maverick', | |
|
110 | 'sys_executable': '/usr/bin/python', | |
|
111 | 'sys_platform': 'linux2', | |
|
112 | 'sys_version': '2.6.6 (r266:84292, Sep 15 2010, 15:52:39) \\n[GCC 4.4.5]'} | |
|
101 | Examples | |
|
102 | -------- | |
|
103 | :: | |
|
104 | ||
|
105 | In [2]: print sys_info() | |
|
106 | {'commit_hash': '144fdae', # random | |
|
107 | 'commit_source': 'repository', | |
|
108 | 'ipython_path': '/home/fperez/usr/lib/python2.6/site-packages/IPython', | |
|
109 | 'ipython_version': '0.11.dev', | |
|
110 | 'os_name': 'posix', | |
|
111 | 'platform': 'Linux-2.6.35-22-generic-i686-with-Ubuntu-10.10-maverick', | |
|
112 | 'sys_executable': '/usr/bin/python', | |
|
113 | 'sys_platform': 'linux2', | |
|
114 | 'sys_version': '2.6.6 (r266:84292, Sep 15 2010, 15:52:39) \\n[GCC 4.4.5]'} | |
|
113 | 115 | """ |
|
114 | 116 | p = os.path |
|
115 | 117 | path = p.dirname(p.abspath(p.join(__file__, '..'))) |
General Comments 0
You need to be logged in to leave comments.
Login now