The backend used for doctests#

This backend is active during doctests. It should mimic the behavior of the IPython command line as close as possible. Without actually launching image viewers, of course.

EXAMPLES:

sage: from sage.repl.rich_output import get_display_manager
sage: get_display_manager()
The Sage display manager using the doctest backend
>>> from sage.all import *
>>> from sage.repl.rich_output import get_display_manager
>>> get_display_manager()
The Sage display manager using the doctest backend
class sage.repl.rich_output.backend_doctest.BackendDoctest[source]#

Bases: BackendBase

default_preferences()[source]#

Return the backend’s display preferences

Matches the IPython command line display preferences to keep the differences between that and the doctests to a minimum.

OUTPUT:

Instance of DisplayPreferences.

EXAMPLES:

sage: from sage.repl.rich_output.backend_ipython import BackendIPythonCommandline
sage: backend = BackendIPythonCommandline()
sage: backend.default_preferences()
Display preferences:
* align_latex is not specified
* graphics is not specified
* supplemental_plot = never
* text is not specified
>>> from sage.all import *
>>> from sage.repl.rich_output.backend_ipython import BackendIPythonCommandline
>>> backend = BackendIPythonCommandline()
>>> backend.default_preferences()
Display preferences:
* align_latex is not specified
* graphics is not specified
* supplemental_plot = never
* text is not specified
display_immediately(plain_text, rich_output)[source]#

Display object immediately

INPUT:

Same as displayhook().

EXAMPLES:

The following example does not call the displayhook. More precisely, the show() method returns None which is ignored by the displayhook. When running the example on a Sage display backend capable of displaying graphics outside of the displayhook, the plot is still shown. Nothing is shown during doctests:

sage: plt = plot(sin)                                                       # needs sage.plot sage.symbolic
sage: plt                                                                   # needs sage.plot sage.symbolic
Graphics object consisting of 1 graphics primitive
sage: plt.show()                                                            # needs sage.plot sage.symbolic

sage: from sage.repl.rich_output import get_display_manager
sage: dm = get_display_manager()
sage: dm.display_immediately(plt)   # indirect doctest                      # needs sage.plot sage.symbolic
>>> from sage.all import *
>>> plt = plot(sin)                                                       # needs sage.plot sage.symbolic
>>> plt                                                                   # needs sage.plot sage.symbolic
Graphics object consisting of 1 graphics primitive
>>> plt.show()                                                            # needs sage.plot sage.symbolic

>>> from sage.repl.rich_output import get_display_manager
>>> dm = get_display_manager()
>>> dm.display_immediately(plt)   # indirect doctest                      # needs sage.plot sage.symbolic
displayhook(plain_text, rich_output)[source]#

Display object from displayhook

INPUT:

  • plain_text – instance of OutputPlainText. The plain text version of the output.

  • rich_output – instance of an output container class (subclass of OutputBase). Guaranteed to be one of the output containers returned from supported_output(), possibly the same as plain_text.

EXAMPLES:

This ends up calling the displayhook:

sage: plt = plot(sin)                                                       # needs sage.plot sage.symbolic
sage: plt                                                                   # needs sage.plot sage.symbolic
Graphics object consisting of 1 graphics primitive
sage: plt.show()                                                            # needs sage.plot sage.symbolic

sage: from sage.repl.rich_output import get_display_manager
sage: dm = get_display_manager()
sage: dm.displayhook(plt)       # indirect doctest                          # needs sage.plot sage.symbolic
Graphics object consisting of 1 graphics primitive
>>> from sage.all import *
>>> plt = plot(sin)                                                       # needs sage.plot sage.symbolic
>>> plt                                                                   # needs sage.plot sage.symbolic
Graphics object consisting of 1 graphics primitive
>>> plt.show()                                                            # needs sage.plot sage.symbolic

>>> from sage.repl.rich_output import get_display_manager
>>> dm = get_display_manager()
>>> dm.displayhook(plt)       # indirect doctest                          # needs sage.plot sage.symbolic
Graphics object consisting of 1 graphics primitive
install(**kwds)[source]#

Switch to the doctest backend.

This method is being called from within switch_backend(). You should never call it by hand.

INPUT:

None of the optional keyword arguments are used in the doctest backend.

EXAMPLES:

sage: from sage.repl.rich_output.backend_doctest import BackendDoctest
sage: backend = BackendDoctest()
sage: backend.install()
sage: backend.uninstall()
>>> from sage.all import *
>>> from sage.repl.rich_output.backend_doctest import BackendDoctest
>>> backend = BackendDoctest()
>>> backend.install()
>>> backend.uninstall()
supported_output()[source]#

Return the supported output types

OUTPUT:

Set of subclasses of OutputBase, the supported output container types.

EXAMPLES:

sage: from sage.repl.rich_output.backend_doctest import BackendDoctest
sage: from sage.repl.rich_output.output_catalog import *
sage: backend = BackendDoctest()
sage: OutputPlainText in backend.supported_output()
True
sage: OutputSceneJmol in backend.supported_output()
True
>>> from sage.all import *
>>> from sage.repl.rich_output.backend_doctest import BackendDoctest
>>> from sage.repl.rich_output.output_catalog import *
>>> backend = BackendDoctest()
>>> OutputPlainText in backend.supported_output()
True
>>> OutputSceneJmol in backend.supported_output()
True
uninstall()[source]#

Switch away from the doctest backend

This method is being called from within switch_backend(). You should never call it by hand.

EXAMPLES:

sage: from sage.repl.rich_output.backend_doctest import BackendDoctest
sage: backend = BackendDoctest()
sage: backend.install()
sage: backend.uninstall()
>>> from sage.all import *
>>> from sage.repl.rich_output.backend_doctest import BackendDoctest
>>> backend = BackendDoctest()
>>> backend.install()
>>> backend.uninstall()
validate(rich_output)[source]#

Perform checks on rich_output

INPUT:

  • rich_output – instance of a subclass of OutputBase.

OUTPUT:

An assertion is triggered if rich_output is invalid.

EXAMPLES:

sage: from sage.repl.rich_output import get_display_manager
sage: dm = get_display_manager()
sage: invalid = dm.types.OutputImagePng('invalid')
sage: backend = dm._backend;  backend
doctest
sage: backend.validate(invalid)
Traceback (most recent call last):
...
AssertionError
sage: backend.validate(dm.types.OutputPlainText.example())
sage: backend.validate(dm.types.OutputAsciiArt.example())
sage: backend.validate(dm.types.OutputLatex.example())
sage: backend.validate(dm.types.OutputImagePng.example())
sage: backend.validate(dm.types.OutputImageGif.example())
sage: backend.validate(dm.types.OutputImageJpg.example())
sage: backend.validate(dm.types.OutputImageSvg.example())
sage: backend.validate(dm.types.OutputImagePdf.example())
sage: backend.validate(dm.types.OutputImageDvi.example())
sage: backend.validate(dm.types.OutputSceneJmol.example())
sage: backend.validate(dm.types.OutputSceneWavefront.example())
sage: backend.validate(dm.types.OutputSceneCanvas3d.example())
sage: backend.validate(dm.types.OutputVideoOgg.example())
sage: backend.validate(dm.types.OutputVideoWebM.example())
sage: backend.validate(dm.types.OutputVideoMp4.example())
sage: backend.validate(dm.types.OutputVideoFlash.example())
sage: backend.validate(dm.types.OutputVideoMatroska.example())
sage: backend.validate(dm.types.OutputVideoAvi.example())
sage: backend.validate(dm.types.OutputVideoWmv.example())
sage: backend.validate(dm.types.OutputVideoQuicktime.example())
>>> from sage.all import *
>>> from sage.repl.rich_output import get_display_manager
>>> dm = get_display_manager()
>>> invalid = dm.types.OutputImagePng('invalid')
>>> backend = dm._backend;  backend
doctest
>>> backend.validate(invalid)
Traceback (most recent call last):
...
AssertionError
>>> backend.validate(dm.types.OutputPlainText.example())
>>> backend.validate(dm.types.OutputAsciiArt.example())
>>> backend.validate(dm.types.OutputLatex.example())
>>> backend.validate(dm.types.OutputImagePng.example())
>>> backend.validate(dm.types.OutputImageGif.example())
>>> backend.validate(dm.types.OutputImageJpg.example())
>>> backend.validate(dm.types.OutputImageSvg.example())
>>> backend.validate(dm.types.OutputImagePdf.example())
>>> backend.validate(dm.types.OutputImageDvi.example())
>>> backend.validate(dm.types.OutputSceneJmol.example())
>>> backend.validate(dm.types.OutputSceneWavefront.example())
>>> backend.validate(dm.types.OutputSceneCanvas3d.example())
>>> backend.validate(dm.types.OutputVideoOgg.example())
>>> backend.validate(dm.types.OutputVideoWebM.example())
>>> backend.validate(dm.types.OutputVideoMp4.example())
>>> backend.validate(dm.types.OutputVideoFlash.example())
>>> backend.validate(dm.types.OutputVideoMatroska.example())
>>> backend.validate(dm.types.OutputVideoAvi.example())
>>> backend.validate(dm.types.OutputVideoWmv.example())
>>> backend.validate(dm.types.OutputVideoQuicktime.example())