1Tickit::Pen(3) User Contributed Perl Documentation Tickit::Pen(3)
2
3
4
6 "Tickit::Pen" - store a collection of rendering attributes
7
9 A pen instance stores a collection of rendering attributes for text to
10 display. It comes in two forms, mutable and immutable. Both types of
11 pen are subclasses of the base "Tickit::Pen" class.
12
13 An immutable pen is an instance of "Tickit::Pen::Immutable". Its
14 attributes are set by the constructor and are fixed thereafter. Methods
15 are provided to query the presence or value of attributes, and to fetch
16 the entire set as a hash.
17
18 A mutable pen is an instance of "Tickit::Pen::Mutable". Its attributes
19 may be set by the constructor, and can be changed at any time. As well
20 as supporting the same query methods as immutable pens, more methods
21 are provided to change or remove them.
22
23 While mutable pens may initially seem more useful, they can complicate
24 logic due to their shared referential nature. If the same mutable pen
25 is shared across multiple places, care needs to be taken to redraw
26 anything that depends on it if it is ever changed. If pens need
27 sharing, especially if results are cached for performance, consider
28 using immutable pens to simplify the logic.
29
30 Attributes
31 The following named pen attributes are supported:
32
33 fg => COL
34 bg => COL
35 Foreground or background colour. "COL" may be an integer or one
36 of the eight colour names. A colour name may optionally be
37 prefixed by "hi-" for the high-intensity version (may not be
38 supported by all terminals). Some terminals may support a
39 palette of 256 colours instead, some 16, and some only 8. The
40 pen object will not check this as it cannot be reliably
41 detected in all cases.
42
43 fg:rgb8 => STRING
44 bg:rgb8 => STRING
45 Foreground or background colour secondary RGB8 specification.
46 The value is a string encoding the three 8-bit values in
47 hexadecimal notation, prefixed by a hash ("#") symbol; for
48 example
49
50 #13579B
51
52 On input, either lower- or upper-case is accepted; on output
53 the letters will be upper-case.
54
55 These attribute can only be set if the corresponding regular
56 index attribute is also set. Changing or clearing the regular
57 index will also clear the RGB8 version.
58
59 Applications wishing to use this attribute should be aware that
60 the majority of terminal drivers will not be able to support
61 it, and so should make sure to set an appropriate regular
62 colour index as well. Some terminals using the xterm driver may
63 make use of it, however, and therefore ignore the index
64 version.
65
66 b => BOOL
67 u => BOOL
68 i => BOOL
69 rv => BOOL
70 strike => BOOL
71 blink => BOOL
72 Bold, underline, italics, reverse video, strikethrough, blink.
73
74 af => INT
75 Alternate font.
76
77 Note that not all terminals can render the italics, strikethrough, or
78 alternate font attributes.
79
81 new
82 $pen = Tickit::Pen->new( %attrs )
83
84 Returns a new pen, initialised from the given attributes.
85
86 Currently this method returns a "Tickit::Pen::Mutable", though this may
87 change in a future version. It is provided for backward-compatibility
88 for code that expects to be able to construct a "Tickit::Pen" directly.
89
90 $pen = Tickit::Pen::Immutable->new( %attrs )
91
92 $pen = Tickit::Pen::Mutable->new( %attrs )
93
94 Return a new immutable, or mutable pen, initialised from the given
95 attributes.
96
97 new_from_attrs
98 $pen = Tickit::Pen->new_from_attrs( $attrs )
99
100 Returns a new pen, initialised from keys in the given HASH reference.
101 Used keys are deleted from the hash.
102
103 Currently this method returns a "Tickit::Pen::Mutable", though this may
104 change in a future version. It is provided for backward-compatibility
105 for code that expects to be able to construct a "Tickit::Pen" directly.
106
107 $pen = Tickit::Pen::Immutable->new_from_attrs( $attrs )
108
109 $pen = Tickit::Pen::Mutable->new_from_attrs( $attrs )
110
111 Return a new immutable, or mutable pen, initialised from the given
112 attributes.
113
114 as_mutable
115 clone
116 $pen = $orig->as_mutable
117
118 $pen = $orig->clone
119
120 Returns a new mutable pen, initialised by copying the attributes of the
121 original.
122
123 "clone" is provided as a legacy alias, but may be removed in a future
124 version.
125
126 as_immutable
127 $pen = $orig->as_immutable
128
129 Returns an immutable pen, initialised by copying the attributes of the
130 original. When called on an immutable pen, this method just returns the
131 same pen instance.
132
133 mutable
134 $is_mutable = $pen->mutable
135
136 Returns true on mutable pens and false on immutable ones.
137
139 The following query methods apply to both immutable and mutable pens.
140
141 hasattr
142 $exists = $pen->hasattr( $attr )
143
144 Returns true if the given attribute exists on this object
145
146 getattr
147 $value = $pen->getattr( $attr )
148
149 Returns the current value of the given attribute
150
151 getattrs
152 %values = $pen->getattrs
153
154 Returns a key/value list of all the attributes
155
156 equiv_attr
157 $equiv = $pen->equiv_attr( $other, $attr )
158
159 Returns true if the two pens have the equivalent values for the given
160 attribute; that is, either both define it to the same value, or neither
161 defines it.
162
163 equiv
164 $equiv = $pen->equiv( $other )
165
166 Returns true if the two pens have equivalent values for all attributes.
167
169 The following mutation methods exist on mutable pens.
170
171 chattr
172 $pen->chattr( $attr, $value )
173
174 Change the value of an attribute. Setting "undef" deletes the attribute
175 entirely. See also "delattr".
176
177 chattrs
178 $pen->chattrs( \%attrs )
179
180 Change the values of all the attributes given in the hash. Recgonised
181 attributes will be deleted from the hash.
182
183 delattr
184 $pen->delattr( $attr )
185
186 Delete an attribute from this pen. This attribute will no longer be
187 modified by this pen.
188
189 copy_from
190 default_from
191 $pen->copy_from( $other )
192
193 $pen->default_from( $other )
194
195 Copy attributes from the given pen. "copy_from" will override
196 attributes already defined by $pen; "default_from" will only copy
197 attributes that are not yet defined by $pen.
198
199 As a convenience both methods return $pen.
200
202 Paul Evans <leonerd@leonerd.org.uk>
203
204
205
206perl v5.36.0 2023-01-20 Tickit::Pen(3)