Face Attribute Functions
This section describes functions for directly accessing and modifying the attributes of a named face.
- Function: face-attribute face attribute &optional frame inherit
-
This function returns the value of the attribute attribute for face on frame.
If frame is omitted or
nil, that means the selected frame (see Input Focus). If frame ist, this function returns the value of the specified attribute for newly-created frames (this is normallyunspecified, unless you have specified some value usingset-face-attribute; see below).If inherit is
nil, only attributes directly defined by face are considered, so the return value may beunspecified, or a relative value. If inherit is non-nil, face’s definition of attribute is merged with the faces specified by its:inheritattribute; however the return value may still beunspecifiedor relative. If inherit is a face or a list of faces, then the result is further merged with that face (or faces), until it becomes specified and absolute.To ensure that the return value is always specified and absolute, use a value of
defaultfor inherit; this will resolve any unspecified or relative values by merging with thedefaultface (which is always completely specified).For example,
(face-attribute 'bold :weight) ⇒ bold
- Function: face-attribute-relative-p attribute value
-
This function returns non-
nilif value, when used as the value of the face attribute attribute, is relative. This means it would modify, rather than completely override, any value that comes from a subsequent face in the face list or that is inherited from another face.unspecifiedis a relative value for all attributes. For:height, floating point and function values are also relative.For example:
(face-attribute-relative-p :height 2.0) ⇒ t
- Function: face-all-attributes face &optional frame
This function returns an alist of attributes of face. The elements of the result are name-value pairs of the form
(attr-name . attr-value). Optional argument frame specifies the frame whose definition of face to return; if omitted ornil, the returned value describes the default attributes of face for newly created frames.
- Function: merge-face-attribute attribute value1 value2
If value1 is a relative value for the face attribute attribute, returns it merged with the underlying value value2; otherwise, if value1 is an absolute value for the face attribute attribute, returns value1 unchanged.
Normally, Emacs uses the face specs of each face to automatically calculate its attributes on each frame (see Defining Faces). The function set-face-attribute can override this calculation by directly assigning attributes to a face, either on a specific frame or for all frames. This function is mostly intended for internal usage.
- Function: set-face-attribute face frame &rest arguments
-
This function sets one or more attributes of face for frame. The attributes specifies in this way override the face spec(s) belonging to face.
The extra arguments arguments specify the attributes to set, and the values for them. They should consist of alternating attribute names (such as
:familyor:underline) and values. Thus,(set-face-attribute 'foo nil :weight 'bold :slant 'italic)
sets the attribute
:weighttoboldand the attribute:slanttoitalic.If frame is
t, this function sets the default attributes for newly created frames. If frame isnil, this function sets the attributes for all existing frames, as well as for newly created frames.
The following commands and functions mostly provide compatibility with old versions of Emacs. They work by calling set-face-attribute. Values of t and nil (or omitted) for their frame argument are handled just like set-face-attribute and face-attribute. The commands read their arguments using the minibuffer, if called interactively.
- Command: set-face-foreground face color &optional frame
- Command: set-face-background face color &optional frame
These set the
:foregroundattribute (or:backgroundattribute, respectively) of face to color.
- Command: set-face-stipple face pattern &optional frame
This sets the
:stippleattribute of face to pattern.
- Command: set-face-font face font &optional frame
Change the font-related attributes of face to those of font (a string or a font object). See face-font-attribute, for the supported formats of the font argument. This function sets the attribute
:fontof the face, and indirectly also the:family,:foundry,:width,:height,:weight, and:slantattributes, as defined by the font. If frame is non-nil, only change the attributes on the specified frame.
- Function: set-face-bold face bold-p &optional frame
This sets the
:weightattribute of face to normal if bold-p isnil, and to bold otherwise.
- Function: set-face-italic face italic-p &optional frame
This sets the
:slantattribute of face to normal if italic-p isnil, and to italic otherwise.
- Command: set-face-underline face underline &optional frame
This sets the
:underlineattribute of face to underline.
- Command: set-face-inverse-video face inverse-video-p &optional frame
This sets the
:inverse-videoattribute of face to inverse-video-p.
- Command: invert-face face &optional frame
This swaps the foreground and background colors of face face.
- Command: set-face-extend face extend &optional frame
This sets the
:extendattribute of face to extend.
The following functions examine the attributes of a face. They mostly provide compatibility with old versions of Emacs. If you don’t specify frame, they refer to the selected frame; t refers to the default data for new frames. They return unspecified if the face doesn’t define any value for that attribute. If inherit is nil, only an attribute directly defined by the face is returned. If inherit is non-nil, any faces specified by its :inherit attribute are considered as well, and if inherit is a face or a list of faces, then they are also considered, until a specified attribute is found. To ensure that the return value is always specified, use a value of default for inherit.
- Function: face-font face &optional frame character
-
This function returns the name of the font of face face.
If the optional argument frame is specified, it returns the name of the font of face for that frame. If frame is omitted or
nil, the selected frame is used. In the latter case, if the optional third argument character is supplied, it returns the font name used for character.
- Function: face-foreground face &optional frame inherit
- Function: face-background face &optional frame inherit
These functions return the foreground color (or background color, respectively) of face face, as a string. If the color is unspecified, they return
nil.
- Function: face-stipple face &optional frame inherit
This function returns the name of the background stipple pattern of face face, or
nilif it doesn’t have one.
- Function: face-bold-p face &optional frame inherit
This function returns a non-
nilvalue if the:weightattribute of face is bolder than normal (i.e., one ofsemi-bold,bold,extra-bold, orultra-bold). Otherwise, it returnsnil.
- Function: face-italic-p face &optional frame inherit
This function returns a non-
nilvalue if the:slantattribute of face isitalicoroblique, andnilotherwise.
- Function: face-underline-p face &optional frame inherit
This function returns non-
nilif face face specifies a non-nil:underlineattribute.
- Function: face-inverse-video-p face &optional frame inherit
This function returns non-
nilif face face specifies a non-nil:inverse-videoattribute.
- Function: face-extend-p face &optional frame
This function returns non-
nilif face face specifies a non-nil:extendattribute.
Copyright © 1990-1996, 1998-2021 Free Software Foundation, Inc.
Licensed under the GNU GPL license.
https://www.gnu.org/software/emacs/manual/html_node/elisp/Attribute-Functions.html