Source code for openmdao.utils.notebook_utils
"""Checking for interactive notebook mode."""
import sys
import importlib
import inspect
try:
from IPython.display import display, HTML, IFrame, Code
from IPython import get_ipython
ipy = get_ipython() is not None
except ImportError:
ipy = display = HTML = IFrame = None
from openmdao.utils.om_warnings import issue_warning, warn_deprecation
colab = 'google.colab' in sys.modules
def _get_object_from_reference(reference):
"""
Return object of given reference path.
Parameters
----------
reference : str
Dot path of desired class.
Returns
-------
str
Object of the given class.
"""
split = reference.split('.')
right = []
obj = None
while split:
try:
obj = importlib.import_module('.'.join(split))
break
except ModuleNotFoundError:
right.append(split.pop())
if obj:
for entry in reversed(right):
obj = getattr(obj, entry)
return obj
[docs]
def get_code(reference, hide_doc_string=False):
"""
Return the source code of the given reference path to a function.
Parameters
----------
reference : str
Dot path of desired function.
hide_doc_string : bool
Option to hide the docstring.
Returns
-------
IPython.display.Code
Source code of the given class or function.
"""
obj = inspect.getsource(_get_object_from_reference(reference))
if hide_doc_string:
obj = obj.split('"""')
del obj[1]
obj = ''.join(obj)
if ipy:
return Code(obj, language='python')
else:
issue_warning("IPython is not installed. Run `pip install openmdao[notebooks]` or "
"`pip install openmdao[docs]` to upgrade.")
[docs]
def display_source(reference, hide_doc_string=False):
"""
Display the source code of the given reference path to a function.
Parameters
----------
reference : str
Dot path of desired function.
hide_doc_string : bool
Option to hide the docstring.
"""
if ipy:
display(get_code(reference, hide_doc_string))
[docs]
def show_options_table(reference, recording_options=False, options_dict='options'):
"""
Return the options table of the given reference path.
Parameters
----------
reference : str or object
Dot path of desired class or function or an instance.
recording_options : bool
If True, display recording options instead of options.
options_dict : str
The string name of the attribute of the reference object
that provides to OptionsDictionary.
Returns
-------
IPython.display
Options table of the given class or function.
"""
from openmdao.utils.options_dictionary import OptionsDictionary
if isinstance(reference, str):
obj = _get_object_from_reference(reference)()
else:
obj = reference
if ipy:
if recording_options:
warn_deprecation('Argument `recording_options` is deprecated. Use '
'`options_dict="recording_options" to remove this '
'warning.')
opt = obj.recording_options
elif isinstance(obj, OptionsDictionary):
opt = obj
elif hasattr(obj, options_dict):
opt = getattr(obj, options_dict)
else:
raise AttributeError(f'Object {reference} has no attribute {options_dict}.')
return display(HTML(str(opt.to_table(fmt='html', display=False))))
else:
issue_warning("IPython is not installed. Run `pip install openmdao[notebooks]` or "
"`pip install openmdao[docs]` to upgrade.")
[docs]
def cite(reference):
"""
Return the citation of the given reference path.
Parameters
----------
reference : str
Dot path of desired class or function.
"""
obj = _get_object_from_reference(reference)()
print(obj.cite)
return
[docs]
def notebook_mode():
"""
Check if the environment is interactive.
Returns
-------
bool
True if the environment is an interactive notebook.
"""
return ipy
notebook = notebook_mode()