##// 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_kitcfg.py
80 lines | 2.0 KiB | text/x-python | PythonLexer
import os,sys
import ipy_rehashdir,glob
from ipy_rehashdir import selflaunch, PyLauncher
def pylaunchers():
"""Create launchers for python scripts in cwd and store them in alias table
This is useful if you want to invoke .py scripts from ipykit session,
just adding .py files in PATH does not work without file association.
.ipy files will be run like macros.
"""
fs = glob.glob('*.py') + glob.glob('*.ipy')
for f in fs:
l = PyLauncher(f)
n = os.path.splitext(f)[0]
ip.define_alias(n, l)
ip.magic('store '+n)
def exta_imports():
# add some modules that you'd want to be bundled in the ipykit
# library zip file here. Do this if you get ImportErrors from scripts you
# try to launch with 'py' or pylaunchers. In theory you could include
# the whole stdlib here for full script coverage
# note that this is never run, it's just here for py2exe
import distutils.dir_util
def kitroot():
return os.environ.get('IPYKITROOT', None)
def main():
if not kitroot():
print "Can't configure ipykit, IPYKITROOT should be set."
return
os.environ["PATH"] = os.environ["PATH"] + ";" + kitroot() + "\\bin;"
ip.push("pylaunchers")
cmds = ip.db.get('syscmdlist', None)
if cmds is None:
ip.magic('rehashx')
cmds = ip.db.get('syscmdlist', [])
#print cmds
if 'sc1' in cmds:
print "Default editor: Sc1"
import ipy_editors
ipy_editors.scite('sc1')
# for icp, imv, imkdir, etc.
import ipy_fsops
greeting = """\n\n === Welcome to ipykit ===
%quickref - learn quickly about IPython.
"""
def ipython_firstrun(ip):
print "First run of ipykit - configuring"
ip.define_alias('py',selflaunch)
ip.define_alias('d','dir /w /og /on')
ip.magic('store py')
ip.magic('store d')
bins = kitroot() +'/bin'
print greeting
def init_ipython(ipy):
global ip
ip = ipy
main()