##// END OF EJS Templates
Backport PR #2102: Fix logging on interactive shell....
Backport PR #2102: Fix logging on interactive shell. Add a missing string format code in init_logs() and move init_logstart() after init_magics(), to fix dependency issues. This is a proposed fix for the case a log file is given in `ipython_config.py`, eg: ```python # Start logging to the given file in append mode. import os from time import strftime f = os.path.join(c.TerminalIPythonApp.ipython_dir, strftime('%Y-%m-%d')+".py") c.TerminalInteractiveShell.logappend = f ``` which completely breaks in current `master` code

File last commit:

r2267:928c921b
r7990:a4d72683
Show More
ipy_p4.py
47 lines | 1.3 KiB | text/x-python | PythonLexer
vivainio
New extensions ipy_p4 for %p4 magic (perforce)
r524 # -*- coding: utf-8 -*-
"""
Add %p4 magic for pythonic p4 (Perforce) usage.
"""
Brian Granger
ipapi.py => core/ipapi.py and imports updated.
r2027 from IPython.core import ipapi
ip = ipapi.get()
vivainio
New extensions ipy_p4 for %p4 magic (perforce)
r524
import os,sys,marshal
import ipy_stock_completers
def p4_f(self, parameter_s=''):
cmd = 'p4 -G ' + parameter_s
vivainio
unmarshal p4 -G output to list
r526 fobj = os.popen(cmd)
out = []
while 1:
try:
out.append(marshal.load(fobj))
except EOFError:
break
return out
vivainio
New extensions ipy_p4 for %p4 magic (perforce)
r524
vivainio
a bit longer prompt for sh profile, p4d func in ipy_p4
r630 def p4d(fname):
return os.popen('p4 where ' + fname).read().split()[0]
Brian Granger
Continuing a massive refactor of everything.
r2205 ip.push("p4d")
vivainio
a bit longer prompt for sh profile, p4d func in ipy_p4
r630
Brian Granger
Continuing a massive refactor of everything.
r2205 ip.define_magic('p4', p4_f)
vivainio
New extensions ipy_p4 for %p4 magic (perforce)
r524
p4_commands = """\
add admin annotate branch branches change changes changelist
changelists client clients counter counters delete depot depots
describe diff diff2 dirs edit filelog files fix fixes flush fstat
group groups have help info integrate integrated job jobs jobspec
label labels labelsync lock logger login logout monitor obliterate
opened passwd print protect rename reopen resolve resolved revert
review reviews set submit sync tag tickets triggers typemap unlock
user users verify workspace workspaces where"""
def p4_completer(self,event):
return ipy_stock_completers.vcs_completer(p4_commands, event)
ip.set_hook('complete_command', p4_completer, str_key = '%p4')
vivainio
unmarshal p4 -G output to list
r526 ip.set_hook('complete_command', p4_completer, str_key = 'p4')
vivainio
New extensions ipy_p4 for %p4 magic (perforce)
r524