Display Preferences¶
This class is used to express display preferences that are not simply
a choice of a particular output format. For example, whether to prefer
vector over raster graphics. By convention, the value None is
always a valid value for a preference and means no particular
preference.
EXAMPLES:
sage: from sage.repl.rich_output.preferences import DisplayPreferences
sage: prefs = DisplayPreferences()
sage: prefs.available_options()
(align_latex, graphics, supplemental_plot, text)
sage: prefs.text is None
True
sage: prefs.text = 'ascii_art'
sage: prefs.text
'ascii_art'
sage: prefs
Display preferences:
* align_latex is not specified
* graphics is not specified
* supplemental_plot is not specified
* text = ascii_art
>>> from sage.all import *
>>> from sage.repl.rich_output.preferences import DisplayPreferences
>>> prefs = DisplayPreferences()
>>> prefs.available_options()
(align_latex, graphics, supplemental_plot, text)
>>> prefs.text is None
True
>>> prefs.text = 'ascii_art'
>>> prefs.text
'ascii_art'
>>> prefs
Display preferences:
* align_latex is not specified
* graphics is not specified
* supplemental_plot is not specified
* text = ascii_art
Properties can be unset by deleting them or by assigning None:
sage: prefs.text = 'ascii_art'
sage: del prefs.text
sage: prefs.text is None
True
sage: prefs.text = 'ascii_art'
sage: prefs.text = None
sage: prefs.text is None
True
>>> from sage.all import *
>>> prefs.text = 'ascii_art'
>>> del prefs.text
>>> prefs.text is None
True
>>> prefs.text = 'ascii_art'
>>> prefs.text = None
>>> prefs.text is None
True
Properties have documentation attached:
sage: import pydoc
sage: doc = pydoc.render_doc(prefs)
sage: assert ' graphics' in doc
sage: assert '     Preferred graphics format' in doc
sage: assert ' text' in doc
sage: assert '     Which textual representation is preferred' in doc
>>> from sage.all import *
>>> import pydoc
>>> doc = pydoc.render_doc(prefs)
>>> assert ' graphics' in doc
>>> assert '     Preferred graphics format' in doc
>>> assert ' text' in doc
>>> assert '     Which textual representation is preferred' in doc
Values can also be specified as keyword arguments to the constructor:
sage: DisplayPreferences(text='latex')
Display preferences:
* align_latex is not specified
* graphics is not specified
* supplemental_plot is not specified
* text = latex
>>> from sage.all import *
>>> DisplayPreferences(text='latex')
Display preferences:
* align_latex is not specified
* graphics is not specified
* supplemental_plot is not specified
* text = latex
Todo
A value-checking preference system should be used elsewhere in Sage, too. The class here is just a simple implementation, a proper implementation would use a metaclass to construct the preference items.
- class sage.repl.rich_output.preferences.DisplayPreferences(*args, **kwds)[source]¶
- Bases: - PreferencesABC- property align_latex[source]¶
- Preferred mode of latex displays - Allowed values: - None(default): no preference
- ‘center’ 
- ‘left’ 
 
 - property graphics[source]¶
- Preferred graphics format - Allowed values: - None(default): no preference
- ‘disable’ 
- ‘vector’ 
- ‘raster’ 
 
 
- class sage.repl.rich_output.preferences.PreferencesABC(*args, **kwds)[source]¶
- Bases: - SageObject- Preferences for displaying graphics. - These can be preferences expressed by the user or by the display backend. They are specified as keyword arguments. - INPUT: - *args*– positional arguments are preferences instances. The property values will be inherited from left to right, that is, later parents override values from earlier parents.
- **kwds– keyword arguments; will be used to initialize properties, and override inherited values if necessary
 - EXAMPLES: - sage: from sage.repl.rich_output.preferences import DisplayPreferences sage: p1 = DisplayPreferences(graphics='vector') sage: p2 = DisplayPreferences(graphics='raster') sage: DisplayPreferences(p1, p2) Display preferences: * align_latex is not specified * graphics = raster * supplemental_plot is not specified * text is not specified - >>> from sage.all import * >>> from sage.repl.rich_output.preferences import DisplayPreferences >>> p1 = DisplayPreferences(graphics='vector') >>> p2 = DisplayPreferences(graphics='raster') >>> DisplayPreferences(p1, p2) Display preferences: * align_latex is not specified * graphics = raster * supplemental_plot is not specified * text is not specified - If specified in the opposite order, the setting from - p1is inherited:- sage: DisplayPreferences(p2, p1) Display preferences: * align_latex is not specified * graphics = vector * supplemental_plot is not specified * text is not specified - >>> from sage.all import * >>> DisplayPreferences(p2, p1) Display preferences: * align_latex is not specified * graphics = vector * supplemental_plot is not specified * text is not specified - Further keywords override: - sage: DisplayPreferences(p2, p1, graphics='disable') Display preferences: * align_latex is not specified * graphics = disable * supplemental_plot is not specified * text is not specified - >>> from sage.all import * >>> DisplayPreferences(p2, p1, graphics='disable') Display preferences: * align_latex is not specified * graphics = disable * supplemental_plot is not specified * text is not specified - available_options()[source]¶
- Return the available options. - OUTPUT: - tuple of the preference items as instances of - Property- EXAMPLES: - sage: from sage.repl.rich_output.preferences import DisplayPreferences sage: DisplayPreferences().available_options() (align_latex, graphics, supplemental_plot, text) - >>> from sage.all import * >>> from sage.repl.rich_output.preferences import DisplayPreferences >>> DisplayPreferences().available_options() (align_latex, graphics, supplemental_plot, text) 
 
- class sage.repl.rich_output.preferences.Property(name, allowed_values, doc=None)[source]¶
- Bases: - property- Preference item. - INPUT: - name– string; the name of the property
- allowed_values– list/tuple/iterable of allowed values
- doc– string (optional); the docstring of the property
 - EXAMPLES: - sage: from sage.repl.rich_output.preferences import Property sage: prop = Property('foo', [0, 1, 2], 'The Foo Property') sage: prop.__doc__ 'The Foo Property\n\nAllowed values:\n\n* ``None`` (default): no preference\n\n* 0\n\n* 1\n\n* 2' sage: prop.allowed_values (0, 1, 2) - >>> from sage.all import * >>> from sage.repl.rich_output.preferences import Property >>> prop = Property('foo', [Integer(0), Integer(1), Integer(2)], 'The Foo Property') >>> prop.__doc__ 'The Foo Property\n\nAllowed values:\n\n* ``None`` (default): no preference\n\n* 0\n\n* 1\n\n* 2' >>> prop.allowed_values (0, 1, 2) - deleter(prefs)[source]¶
- Delete the current value of the property. - INPUT: - prefs– the- PreferencesABCinstance that the property is bound to
 - EXAMPLES: - sage: from sage.repl.rich_output.preferences import Property, PreferencesABC sage: prop = Property('foo', [0, 1, 2], 'The Foo Property') sage: prefs = PreferencesABC() sage: prop.getter(prefs) is None True sage: prop.setter(prefs, 1) sage: prop.deleter(prefs) sage: prop.getter(prefs) is None True - >>> from sage.all import * >>> from sage.repl.rich_output.preferences import Property, PreferencesABC >>> prop = Property('foo', [Integer(0), Integer(1), Integer(2)], 'The Foo Property') >>> prefs = PreferencesABC() >>> prop.getter(prefs) is None True >>> prop.setter(prefs, Integer(1)) >>> prop.deleter(prefs) >>> prop.getter(prefs) is None True 
 - getter(prefs)[source]¶
- Get the current value of the property. - INPUT: - prefs– the- PreferencesABCinstance that the property is bound to
 - OUTPUT: one of the allowed values or - Noneif not set- EXAMPLES: - sage: from sage.repl.rich_output.preferences import Property, PreferencesABC sage: prop = Property('foo', [0, 1, 2], 'The Foo Property') sage: prefs = PreferencesABC() sage: prop.getter(prefs) is None True sage: prop.setter(prefs, 1) sage: prop.getter(prefs) 1 - >>> from sage.all import * >>> from sage.repl.rich_output.preferences import Property, PreferencesABC >>> prop = Property('foo', [Integer(0), Integer(1), Integer(2)], 'The Foo Property') >>> prefs = PreferencesABC() >>> prop.getter(prefs) is None True >>> prop.setter(prefs, Integer(1)) >>> prop.getter(prefs) 1 
 - setter(prefs, value)[source]¶
- Get the current value of the property. - INPUT: - prefs– the- PreferencesABCinstance that the property is bound to
- value– anything. The new value of the property. Setting a property to- Noneis equivalent to deleting the value.
 - OUTPUT: - This method does not return anything. A - ValueErroris raised if the given- valueis not one of the allowed values.- EXAMPLES: - sage: from sage.repl.rich_output.preferences import Property, PreferencesABC sage: prop = Property('foo', [0, 1, 2], 'The Foo Property') sage: prefs = PreferencesABC() sage: prop.getter(prefs) is None True sage: prop.setter(prefs, 1) sage: prop.getter(prefs) 1 sage: prop.setter(prefs, None) sage: prop.getter(prefs) is None True - >>> from sage.all import * >>> from sage.repl.rich_output.preferences import Property, PreferencesABC >>> prop = Property('foo', [Integer(0), Integer(1), Integer(2)], 'The Foo Property') >>> prefs = PreferencesABC() >>> prop.getter(prefs) is None True >>> prop.setter(prefs, Integer(1)) >>> prop.getter(prefs) 1 >>> prop.setter(prefs, None) >>> prop.getter(prefs) is None True