##// END OF EJS Templates
WIP: Update test.yml python 3.13 (#14536)
r28894:d2b6c2aa merge
Show More
config.py
140 lines | 4.8 KiB | text/x-python | PythonLexer
Fernando Perez
Create core.magics.config according to new API.
r6961 """Implementation of configuration-related magic functions.
"""
#-----------------------------------------------------------------------------
# Copyright (c) 2012 The IPython Development Team.
#
# Distributed under the terms of the Modified BSD License.
#
# The full license is in the file COPYING.txt, distributed with this software.
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
# Imports
#-----------------------------------------------------------------------------
# Stdlib
import re
# Our own packages
from IPython.core.error import UsageError
Fernando Perez
Renamed @register_magics to @magics_class to avoid confusion....
r6973 from IPython.core.magic import Magics, magics_class, line_magic
Pierre Gerold
Replace all import of IPython.utils.warn module
r22092 from logging import error
Fernando Perez
Create core.magics.config according to new API.
r6961
#-----------------------------------------------------------------------------
# Magic implementation classes
#-----------------------------------------------------------------------------
Matthias Bussonnier
Fix more escape sequences
r24452 reg = re.compile(r'^\w+\.\w+$')
Fernando Perez
Renamed @register_magics to @magics_class to avoid confusion....
r6973 @magics_class
Fernando Perez
Create core.magics.config according to new API.
r6961 class ConfigMagics(Magics):
def __init__(self, shell):
super(ConfigMagics, self).__init__(shell)
self.configurables = []
@line_magic
def config(self, s):
"""configure IPython
%config Class[.trait=value]
This magic exposes most of the IPython config system. Any
Configurable class should be able to be configured with the simple
line::
%config Class.trait=value
Where `value` will be resolved in the user's namespace, if it is an
expression or variable name.
Examples
--------
To see what classes are available for config, pass no arguments::
In [1]: %config
Available objects for config:
AliasManager
DisplayFormatter
Nikita Kniazev
Preserve function/method identity in magic decorators...
r27102 HistoryManager
IPCompleter
LoggingMagics
MagicsManager
OSMagics
PrefilterManager
ScriptMagics
TerminalInteractiveShell
Fernando Perez
Create core.magics.config according to new API.
r6961
To view what is configurable on a given class, just pass the class
name::
krassowski
Polish documentation, hide private functions
r27918 In [2]: %config LoggingMagics
LoggingMagics(Magics) options
---------------------------
LoggingMagics.quiet=<Bool>
Suppress output of log state when logging is enabled
Nikita Kniazev
Preserve function/method identity in magic decorators...
r27102 Current: False
Fernando Perez
Create core.magics.config according to new API.
r6961
but the real use is in setting values::
krassowski
Polish documentation, hide private functions
r27918 In [3]: %config LoggingMagics.quiet = True
Fernando Perez
Create core.magics.config according to new API.
r6961
and these values are read from the user_ns if they are variables::
krassowski
Polish documentation, hide private functions
r27918 In [4]: feeling_quiet=False
Fernando Perez
Create core.magics.config according to new API.
r6961
krassowski
Polish documentation, hide private functions
r27918 In [5]: %config LoggingMagics.quiet = feeling_quiet
Fernando Perez
Create core.magics.config according to new API.
r6961
"""
Min RK
update dependency imports...
r21253 from traitlets.config.loader import Config
Fernando Perez
Create core.magics.config according to new API.
r6961 # some IPython objects are Configurable, but do not yet have
# any configurable traits. Exclude them from the effects of
# this magic, as their presence is just noise:
Sang Min Park
Sort and unique %config results
r23617 configurables = sorted(set([ c for c in self.shell.configurables
if c.__class__.class_traits(config=True)
]), key=lambda x: x.__class__.__name__)
Fernando Perez
Create core.magics.config according to new API.
r6961 classnames = [ c.__class__.__name__ for c in configurables ]
line = s.strip()
if not line:
# print available configurable names
Thomas Kluyver
Convert print statements to print function calls...
r13348 print("Available objects for config:")
Fernando Perez
Create core.magics.config according to new API.
r6961 for name in classnames:
Nikita Kniazev
Preserve function/method identity in magic decorators...
r27102 print(" ", name)
Fernando Perez
Create core.magics.config according to new API.
r6961 return
elif line in classnames:
# `%config TerminalInteractiveShell` will print trait info for
# TerminalInteractiveShell
c = configurables[classnames.index(line)]
cls = c.__class__
help = cls.class_get_help(c)
# strip leading '--' from cl-args:
help = re.sub(re.compile(r'^--', re.MULTILINE), '', help)
Thomas Kluyver
Convert print statements to print function calls...
r13348 print(help)
Fernando Perez
Create core.magics.config according to new API.
r6961 return
Matthias BUSSONNIER
improve config line magic...
r10207 elif reg.match(line):
cls, attr = line.split('.')
return getattr(configurables[classnames.index(cls)],attr)
Fernando Perez
Create core.magics.config according to new API.
r6961 elif '=' not in line:
Matthias BUSSONNIER
improve config line magic...
r10207 msg = "Invalid config statement: %r, "\
"should be `Class.trait = value`."
MinRK
finish up PR #3116...
r10245
ll = line.lower()
for classname in classnames:
if ll == classname.lower():
msg = msg + '\nDid you mean %s (note the case)?' % classname
break
Matthias BUSSONNIER
improve config line magic...
r10207
raise UsageError( msg % line)
Fernando Perez
Create core.magics.config according to new API.
r6961
# otherwise, assume we are setting configurables.
# leave quotes on args when splitting, because we want
# unquoted args to eval in user_ns
cfg = Config()
linar-jether
Fix locals collisions with shell variables...
r25530 exec("cfg."+line, self.shell.user_ns, locals())
Fernando Perez
Create core.magics.config according to new API.
r6961
for configurable in configurables:
try:
configurable.update_config(cfg)
except Exception as e:
error(e)