(latexenc-find-file-coding-system): Don't inherit the EOL part of the
[emacs.git] / lispref / strings.texi
blobb70e8d9f9d47a8fbfb3582fa20bf890ff7927e11
1 @c -*-texinfo-*-
2 @c This is part of the GNU Emacs Lisp Reference Manual.
3 @c Copyright (C) 1990, 1991, 1992, 1993, 1994, 1995, 1998, 1999, 2003
4 @c   Free Software Foundation, Inc.
5 @c See the file elisp.texi for copying conditions.
6 @setfilename ../info/strings
7 @node Strings and Characters, Lists, Numbers, Top
8 @comment  node-name,  next,  previous,  up
9 @chapter Strings and Characters
10 @cindex strings
11 @cindex character arrays
12 @cindex characters
13 @cindex bytes
15   A string in Emacs Lisp is an array that contains an ordered sequence
16 of characters.  Strings are used as names of symbols, buffers, and
17 files; to send messages to users; to hold text being copied between
18 buffers; and for many other purposes.  Because strings are so important,
19 Emacs Lisp has many functions expressly for manipulating them.  Emacs
20 Lisp programs use strings more often than individual characters.
22   @xref{Strings of Events}, for special considerations for strings of
23 keyboard character events.
25 @menu
26 * Basics: String Basics.      Basic properties of strings and characters.
27 * Predicates for Strings::    Testing whether an object is a string or char.
28 * Creating Strings::          Functions to allocate new strings.
29 * Modifying Strings::         Altering the contents of an existing string.
30 * Text Comparison::           Comparing characters or strings.
31 * String Conversion::         Converting to and from characters and strings.
32 * Formatting Strings::        @code{format}: Emacs's analogue of @code{printf}.
33 * Case Conversion::           Case conversion functions.
34 * Case Tables::               Customizing case conversion.
35 @end menu
37 @node String Basics
38 @section String and Character Basics
40   Characters are represented in Emacs Lisp as integers;
41 whether an integer is a character or not is determined only by how it is
42 used.  Thus, strings really contain integers.
44   The length of a string (like any array) is fixed, and cannot be
45 altered once the string exists.  Strings in Lisp are @emph{not}
46 terminated by a distinguished character code.  (By contrast, strings in
47 C are terminated by a character with @acronym{ASCII} code 0.)
49   Since strings are arrays, and therefore sequences as well, you can
50 operate on them with the general array and sequence functions.
51 (@xref{Sequences Arrays Vectors}.)  For example, you can access or
52 change individual characters in a string using the functions @code{aref}
53 and @code{aset} (@pxref{Array Functions}).
55   There are two text representations for non-@acronym{ASCII} characters in
56 Emacs strings (and in buffers): unibyte and multibyte (@pxref{Text
57 Representations}).  An @acronym{ASCII} character always occupies one byte in a
58 string; in fact, when a string is all @acronym{ASCII}, there is no real
59 difference between the unibyte and multibyte representations.
60 For most Lisp programming, you don't need to be concerned with these two
61 representations.
63   Sometimes key sequences are represented as strings.  When a string is
64 a key sequence, string elements in the range 128 to 255 represent meta
65 characters (which are large integers) rather than character
66 codes in the range 128 to 255.
68   Strings cannot hold characters that have the hyper, super or alt
69 modifiers; they can hold @acronym{ASCII} control characters, but no other
70 control characters.  They do not distinguish case in @acronym{ASCII} control
71 characters.  If you want to store such characters in a sequence, such as
72 a key sequence, you must use a vector instead of a string.
73 @xref{Character Type}, for more information about the representation of meta
74 and other modifiers for keyboard input characters.
76   Strings are useful for holding regular expressions.  You can also
77 match regular expressions against strings with @code{string-match}
78 (@pxref{Regexp Search}).  The functions @code{match-string}
79 (@pxref{Simple Match Data}) and @code{replace-match} (@pxref{Replacing
80 Match}) are useful for decomposing and modifying strings after
81 matching regular expressions against them.
83   Like a buffer, a string can contain text properties for the characters
84 in it, as well as the characters themselves.  @xref{Text Properties}.
85 All the Lisp primitives that copy text from strings to buffers or other
86 strings also copy the properties of the characters being copied.
88   @xref{Text}, for information about functions that display strings or
89 copy them into buffers.  @xref{Character Type}, and @ref{String Type},
90 for information about the syntax of characters and strings.
91 @xref{Non-ASCII Characters}, for functions to convert between text
92 representations and to encode and decode character codes.
94 @node Predicates for Strings
95 @section The Predicates for Strings
97 For more information about general sequence and array predicates,
98 see @ref{Sequences Arrays Vectors}, and @ref{Arrays}.
100 @defun stringp object
101 This function returns @code{t} if @var{object} is a string, @code{nil}
102 otherwise.
103 @end defun
105 @defun char-or-string-p object
106 This function returns @code{t} if @var{object} is a string or a
107 character (i.e., an integer), @code{nil} otherwise.
108 @end defun
110 @node Creating Strings
111 @section Creating Strings
113   The following functions create strings, either from scratch, or by
114 putting strings together, or by taking them apart.
116 @defun make-string count character
117 This function returns a string made up of @var{count} repetitions of
118 @var{character}.  If @var{count} is negative, an error is signaled.
120 @example
121 (make-string 5 ?x)
122      @result{} "xxxxx"
123 (make-string 0 ?x)
124      @result{} ""
125 @end example
127   Other functions to compare with this one include @code{char-to-string}
128 (@pxref{String Conversion}), @code{make-vector} (@pxref{Vectors}), and
129 @code{make-list} (@pxref{Building Lists}).
130 @end defun
132 @defun string &rest characters
133 This returns a string containing the characters @var{characters}.
135 @example
136 (string ?a ?b ?c)
137      @result{} "abc"
138 @end example
139 @end defun
141 @defun substring string start &optional end
142 This function returns a new string which consists of those characters
143 from @var{string} in the range from (and including) the character at the
144 index @var{start} up to (but excluding) the character at the index
145 @var{end}.  The first character is at index zero.
147 @example
148 @group
149 (substring "abcdefg" 0 3)
150      @result{} "abc"
151 @end group
152 @end example
154 @noindent
155 Here the index for @samp{a} is 0, the index for @samp{b} is 1, and the
156 index for @samp{c} is 2.  Thus, three letters, @samp{abc}, are copied
157 from the string @code{"abcdefg"}.  The index 3 marks the character
158 position up to which the substring is copied.  The character whose index
159 is 3 is actually the fourth character in the string.
161 A negative number counts from the end of the string, so that @minus{}1
162 signifies the index of the last character of the string.  For example:
164 @example
165 @group
166 (substring "abcdefg" -3 -1)
167      @result{} "ef"
168 @end group
169 @end example
171 @noindent
172 In this example, the index for @samp{e} is @minus{}3, the index for
173 @samp{f} is @minus{}2, and the index for @samp{g} is @minus{}1.
174 Therefore, @samp{e} and @samp{f} are included, and @samp{g} is excluded.
176 When @code{nil} is used for @var{end}, it stands for the length of the
177 string.  Thus,
179 @example
180 @group
181 (substring "abcdefg" -3 nil)
182      @result{} "efg"
183 @end group
184 @end example
186 Omitting the argument @var{end} is equivalent to specifying @code{nil}.
187 It follows that @code{(substring @var{string} 0)} returns a copy of all
188 of @var{string}.
190 @example
191 @group
192 (substring "abcdefg" 0)
193      @result{} "abcdefg"
194 @end group
195 @end example
197 @noindent
198 But we recommend @code{copy-sequence} for this purpose (@pxref{Sequence
199 Functions}).
201 If the characters copied from @var{string} have text properties, the
202 properties are copied into the new string also.  @xref{Text Properties}.
204 @code{substring} also accepts a vector for the first argument.
205 For example:
207 @example
208 (substring [a b (c) "d"] 1 3)
209      @result{} [b (c)]
210 @end example
212 A @code{wrong-type-argument} error is signaled if @var{start} is not
213 an integer or if @var{end} is neither an integer nor @code{nil}.  An
214 @code{args-out-of-range} error is signaled if @var{start} indicates a
215 character following @var{end}, or if either integer is out of range
216 for @var{string}.
218 Contrast this function with @code{buffer-substring} (@pxref{Buffer
219 Contents}), which returns a string containing a portion of the text in
220 the current buffer.  The beginning of a string is at index 0, but the
221 beginning of a buffer is at index 1.
222 @end defun
224 @defun substring-no-properties string &optional start end
225 This works like @code{substring} but discards all text properties from
226 the value.  Also, @var{start} may be omitted or @code{nil}, which is
227 equivalent to 0.  Thus, @w{@code{(substring-no-properties
228 @var{string})}} returns a copy of @var{string}, with all text
229 properties removed.
230 @end defun
232 @defun concat &rest sequences
233 @cindex copying strings
234 @cindex concatenating strings
235 This function returns a new string consisting of the characters in the
236 arguments passed to it (along with their text properties, if any).  The
237 arguments may be strings, lists of numbers, or vectors of numbers; they
238 are not themselves changed.  If @code{concat} receives no arguments, it
239 returns an empty string.
241 @example
242 (concat "abc" "-def")
243      @result{} "abc-def"
244 (concat "abc" (list 120 121) [122])
245      @result{} "abcxyz"
246 ;; @r{@code{nil} is an empty sequence.}
247 (concat "abc" nil "-def")
248      @result{} "abc-def"
249 (concat "The " "quick brown " "fox.")
250      @result{} "The quick brown fox."
251 (concat)
252      @result{} ""
253 @end example
255 @noindent
256 The @code{concat} function always constructs a new string that is
257 not @code{eq} to any existing string.
259 In Emacs versions before 21, when an argument was an integer (not a
260 sequence of integers), it was converted to a string of digits making up
261 the decimal printed representation of the integer.  This obsolete usage
262 no longer works.  The proper way to convert an integer to its decimal
263 printed form is with @code{format} (@pxref{Formatting Strings}) or
264 @code{number-to-string} (@pxref{String Conversion}).
266 For information about other concatenation functions, see the
267 description of @code{mapconcat} in @ref{Mapping Functions},
268 @code{vconcat} in @ref{Vector Functions}, and @code{append} in @ref{Building
269 Lists}.
270 @end defun
272 @defun split-string string &optional separators omit-nulls
273 This function splits @var{string} into substrings at matches for the
274 regular expression @var{separators}.  Each match for @var{separators}
275 defines a splitting point; the substrings between the splitting points
276 are made into a list, which is the value returned by
277 @code{split-string}.
279 If @var{omit-nulls} is @code{nil}, the result contains null strings
280 whenever there are two consecutive matches for @var{separators}, or a
281 match is adjacent to the beginning or end of @var{string}.  If
282 @var{omit-nulls} is @code{t}, these null strings are omitted from the
283 result list.
285 If @var{separators} is @code{nil} (or omitted),
286 the default is the value of @code{split-string-default-separators}.
288 As a special case, when @var{separators} is @code{nil} (or omitted),
289 null strings are always omitted from the result.  Thus:
291 @example
292 (split-string "  two words ")
293      @result{} ("two" "words")
294 @end example
296 The result is not @samp{("" "two" "words" "")}, which would rarely be
297 useful.  If you need such a result, use an explicit value for
298 @var{separators}:
300 @example
301 (split-string "  two words " split-string-default-separators)
302      @result{} ("" "two" "words" "")
303 @end example
305 More examples:
307 @example
308 (split-string "Soup is good food" "o")
309      @result{} ("S" "up is g" "" "d f" "" "d")
310 (split-string "Soup is good food" "o" t)
311      @result{} ("S" "up is g" "d f" "d")
312 (split-string "Soup is good food" "o+")
313      @result{} ("S" "up is g" "d f" "d")
314 @end example
316 Empty matches do count, except that @code{split-string} will not look
317 for a final empty match when it already reached the end of the string
318 using a non-empty match or when @var{string} is empty:
320 @example
321 (split-string "aooob" "o*")
322      @result{} ("" "a" "" "b" "")
323 (split-string "ooaboo" "o*")
324      @result{} ("" "" "a" "b" "")
325 (split-string "" "")
326      @result{} ("")
327 @end example
329 However, when @var{separators} can match the empty string,
330 @var{omit-nulls} is usually @code{t}, so that the subtleties in the
331 three previous examples are rarely relevant:
333 @example
334 (split-string "Soup is good food" "o*" t)
335      @result{} ("S" "u" "p" " " "i" "s" " " "g" "d" " " "f" "d")
336 (split-string "Nice doggy!" "" t)
337      @result{} ("N" "i" "c" "e" " " "d" "o" "g" "g" "y" "!")
338 (split-string "" "" t)
339      @result{} nil
340 @end example
342 Somewhat odd, but predictable, behavior can occur for certain
343 ``non-greedy'' values of @var{separators} that can prefer empty
344 matches over non-empty matches.  Again, such values rarely occur in
345 practice:
347 @example
348 (split-string "ooo" "o*" t)
349      @result{} nil
350 (split-string "ooo" "\\|o+" t)
351      @result{} ("o" "o" "o")
352 @end example
353 @end defun
355 @defvar split-string-default-separators
356 The default value of @var{separators} for @code{split-string}, initially
357 @w{@samp{"[ \f\t\n\r\v]+"}}.
358 @end defvar
360 @node Modifying Strings
361 @section Modifying Strings
363   The most basic way to alter the contents of an existing string is with
364 @code{aset} (@pxref{Array Functions}).  @code{(aset @var{string}
365 @var{idx} @var{char})} stores @var{char} into @var{string} at index
366 @var{idx}.  Each character occupies one or more bytes, and if @var{char}
367 needs a different number of bytes from the character already present at
368 that index, @code{aset} signals an error.
370   A more powerful function is @code{store-substring}:
372 @defun store-substring string idx obj
373 This function alters part of the contents of the string @var{string}, by
374 storing @var{obj} starting at index @var{idx}.  The argument @var{obj}
375 may be either a character or a (smaller) string.
377 Since it is impossible to change the length of an existing string, it is
378 an error if @var{obj} doesn't fit within @var{string}'s actual length,
379 or if any new character requires a different number of bytes from the
380 character currently present at that point in @var{string}.
381 @end defun
383   To clear out a string that contained a password, use
384 @code{clear-string}:
386 @defun clear-string string
387 This clears the contents of @var{string} to zeros.
388 It may also change @var{string}'s length and convert it to
389 a unibyte string.
390 @end defun
392 @need 2000
393 @node Text Comparison
394 @section Comparison of Characters and Strings
395 @cindex string equality
397 @defun char-equal character1 character2
398 This function returns @code{t} if the arguments represent the same
399 character, @code{nil} otherwise.  This function ignores differences
400 in case if @code{case-fold-search} is non-@code{nil}.
402 @example
403 (char-equal ?x ?x)
404      @result{} t
405 (let ((case-fold-search nil))
406   (char-equal ?x ?X))
407      @result{} nil
408 @end example
409 @end defun
411 @defun string= string1 string2
412 This function returns @code{t} if the characters of the two strings
413 match exactly.  Symbols are also allowed as arguments, in which case
414 their print names are used.
415 Case is always significant, regardless of @code{case-fold-search}.
417 @example
418 (string= "abc" "abc")
419      @result{} t
420 (string= "abc" "ABC")
421      @result{} nil
422 (string= "ab" "ABC")
423      @result{} nil
424 @end example
426 The function @code{string=} ignores the text properties of the two
427 strings.  When @code{equal} (@pxref{Equality Predicates}) compares two
428 strings, it uses @code{string=}.
430 For technical reasons, a unibyte and a multibyte string are
431 @code{equal} if and only if they contain the same sequence of
432 character codes and all these codes are either in the range 0 through
433 127 (@acronym{ASCII}) or 160 through 255 (@code{eight-bit-graphic}).
434 However, when a unibyte string gets converted to a multibyte string,
435 all characters with codes in the range 160 through 255 get converted
436 to characters with higher codes, whereas @acronym{ASCII} characters
437 remain unchanged.  Thus, a unibyte string and its conversion to
438 multibyte are only @code{equal} if the string is all @acronym{ASCII}.
439 Character codes 160 through 255 are not entirely proper in multibyte
440 text, even though they can occur.  As a consequence, the situation
441 where a unibyte and a multibyte string are @code{equal} without both
442 being all @acronym{ASCII} is a technical oddity that very few Emacs
443 Lisp programmers ever get confronted with.  @xref{Text
444 Representations}.
445 @end defun
447 @defun string-equal string1 string2
448 @code{string-equal} is another name for @code{string=}.
449 @end defun
451 @cindex lexical comparison
452 @defun string< string1 string2
453 @c (findex string< causes problems for permuted index!!)
454 This function compares two strings a character at a time.  It
455 scans both the strings at the same time to find the first pair of corresponding
456 characters that do not match.  If the lesser character of these two is
457 the character from @var{string1}, then @var{string1} is less, and this
458 function returns @code{t}.  If the lesser character is the one from
459 @var{string2}, then @var{string1} is greater, and this function returns
460 @code{nil}.  If the two strings match entirely, the value is @code{nil}.
462 Pairs of characters are compared according to their character codes.
463 Keep in mind that lower case letters have higher numeric values in the
464 @acronym{ASCII} character set than their upper case counterparts; digits and
465 many punctuation characters have a lower numeric value than upper case
466 letters.  An @acronym{ASCII} character is less than any non-@acronym{ASCII}
467 character; a unibyte non-@acronym{ASCII} character is always less than any
468 multibyte non-@acronym{ASCII} character (@pxref{Text Representations}).
470 @example
471 @group
472 (string< "abc" "abd")
473      @result{} t
474 (string< "abd" "abc")
475      @result{} nil
476 (string< "123" "abc")
477      @result{} t
478 @end group
479 @end example
481 When the strings have different lengths, and they match up to the
482 length of @var{string1}, then the result is @code{t}.  If they match up
483 to the length of @var{string2}, the result is @code{nil}.  A string of
484 no characters is less than any other string.
486 @example
487 @group
488 (string< "" "abc")
489      @result{} t
490 (string< "ab" "abc")
491      @result{} t
492 (string< "abc" "")
493      @result{} nil
494 (string< "abc" "ab")
495      @result{} nil
496 (string< "" "")
497      @result{} nil
498 @end group
499 @end example
501 Symbols are also allowed as arguments, in which case their print names
502 are used.
503 @end defun
505 @defun string-lessp string1 string2
506 @code{string-lessp} is another name for @code{string<}.
507 @end defun
509 @defun compare-strings string1 start1 end1 string2 start2 end2 &optional ignore-case
510 This function compares the specified part of @var{string1} with the
511 specified part of @var{string2}.  The specified part of @var{string1}
512 runs from index @var{start1} up to index @var{end1} (@code{nil} means
513 the end of the string).  The specified part of @var{string2} runs from
514 index @var{start2} up to index @var{end2} (@code{nil} means the end of
515 the string).
517 The strings are both converted to multibyte for the comparison
518 (@pxref{Text Representations}) so that a unibyte string and its
519 conversion to multibyte are always regarded as equal.  If
520 @var{ignore-case} is non-@code{nil}, then case is ignored, so that
521 upper case letters can be equal to lower case letters.
523 If the specified portions of the two strings match, the value is
524 @code{t}.  Otherwise, the value is an integer which indicates how many
525 leading characters agree, and which string is less.  Its absolute value
526 is one plus the number of characters that agree at the beginning of the
527 two strings.  The sign is negative if @var{string1} (or its specified
528 portion) is less.
529 @end defun
531 @defun assoc-string key alist &optional case-fold
532 This function works like @code{assoc}, except that @var{key} must be a
533 string, and comparison is done using @code{compare-strings}.  If
534 @var{case-fold} is non-@code{nil}, it ignores case differences.
535 Unlike @code{assoc}, this function can also match elements of the alist
536 that are strings rather than conses.  In particular, @var{alist} can
537 be a list of strings rather than an actual alist.
538 @xref{Association Lists}.
539 @end defun
541   See also @code{compare-buffer-substrings} in @ref{Comparing Text}, for
542 a way to compare text in buffers.  The function @code{string-match},
543 which matches a regular expression against a string, can be used
544 for a kind of string comparison; see @ref{Regexp Search}.
546 @node String Conversion
547 @comment  node-name,  next,  previous,  up
548 @section Conversion of Characters and Strings
549 @cindex conversion of strings
551   This section describes functions for conversions between characters,
552 strings and integers.  @code{format} (@pxref{Formatting Strings})
553 and @code{prin1-to-string}
554 (@pxref{Output Functions}) can also convert Lisp objects into strings.
555 @code{read-from-string} (@pxref{Input Functions}) can ``convert'' a
556 string representation of a Lisp object into an object.  The functions
557 @code{string-make-multibyte} and @code{string-make-unibyte} convert the
558 text representation of a string (@pxref{Converting Representations}).
560   @xref{Documentation}, for functions that produce textual descriptions
561 of text characters and general input events
562 (@code{single-key-description} and @code{text-char-description}).  These
563 functions are used primarily for making help messages.
565 @defun char-to-string character
566 @cindex character to string
567 This function returns a new string containing one character,
568 @var{character}.  This function is semi-obsolete because the function
569 @code{string} is more general.  @xref{Creating Strings}.
570 @end defun
572 @defun string-to-char string
573 @cindex string to character
574   This function returns the first character in @var{string}.  If the
575 string is empty, the function returns 0.  The value is also 0 when the
576 first character of @var{string} is the null character, @acronym{ASCII} code
579 @example
580 (string-to-char "ABC")
581      @result{} 65
582 (string-to-char "xyz")
583      @result{} 120
584 (string-to-char "")
585      @result{} 0
586 @group
587 (string-to-char "\000")
588      @result{} 0
589 @end group
590 @end example
592 This function may be eliminated in the future if it does not seem useful
593 enough to retain.
594 @end defun
596 @defun number-to-string number
597 @cindex integer to string
598 @cindex integer to decimal
599 This function returns a string consisting of the printed base-ten
600 representation of @var{number}, which may be an integer or a floating
601 point number.  The returned value starts with a minus sign if the argument is
602 negative.
604 @example
605 (number-to-string 256)
606      @result{} "256"
607 @group
608 (number-to-string -23)
609      @result{} "-23"
610 @end group
611 (number-to-string -23.5)
612      @result{} "-23.5"
613 @end example
615 @cindex int-to-string
616 @code{int-to-string} is a semi-obsolete alias for this function.
618 See also the function @code{format} in @ref{Formatting Strings}.
619 @end defun
621 @defun string-to-number string &optional base
622 @cindex string to number
623 This function returns the numeric value of the characters in
624 @var{string}.  If @var{base} is non-@code{nil}, it must be an integer
625 between 2 and 16 (inclusive), and integers are converted in that base.
626 If @var{base} is @code{nil}, then base ten is used.  Floating point
627 conversion only works in base ten; we have not implemented other
628 radices for floating point numbers, because that would be much more
629 work and does not seem useful.  If @var{string} looks like an integer
630 but its value is too large to fit into a Lisp integer,
631 @code{string-to-number} returns a floating point result.
633 The parsing skips spaces and tabs at the beginning of @var{string},
634 then reads as much of @var{string} as it can interpret as a number in
635 the given base.  (On some systems it ignores other whitespace at the
636 beginning, not just spaces and tabs.)  If the first character after
637 the ignored whitespace is neither a digit in the given base, nor a
638 plus or minus sign, nor the leading dot of a floating point number,
639 this function returns 0.
641 @example
642 (string-to-number "256")
643      @result{} 256
644 (string-to-number "25 is a perfect square.")
645      @result{} 25
646 (string-to-number "X256")
647      @result{} 0
648 (string-to-number "-4.5")
649      @result{} -4.5
650 (string-to-number "1e5")
651      @result{} 100000.0
652 @end example
654 @findex string-to-int
655 @code{string-to-int} is an obsolete alias for this function.
656 @end defun
658   Here are some other functions that can convert to or from a string:
660 @table @code
661 @item concat
662 @code{concat} can convert a vector or a list into a string.
663 @xref{Creating Strings}.
665 @item vconcat
666 @code{vconcat} can convert a string into a vector.  @xref{Vector
667 Functions}.
669 @item append
670 @code{append} can convert a string into a list.  @xref{Building Lists}.
671 @end table
673 @node Formatting Strings
674 @comment  node-name,  next,  previous,  up
675 @section Formatting Strings
676 @cindex formatting strings
677 @cindex strings, formatting them
679   @dfn{Formatting} means constructing a string by substitution of
680 computed values at various places in a constant string.  This constant string
681 controls how the other values are printed, as well as where they appear;
682 it is called a @dfn{format string}.
684   Formatting is often useful for computing messages to be displayed.  In
685 fact, the functions @code{message} and @code{error} provide the same
686 formatting feature described here; they differ from @code{format} only
687 in how they use the result of formatting.
689 @defun format string &rest objects
690 This function returns a new string that is made by copying
691 @var{string} and then replacing any format specification
692 in the copy with encodings of the corresponding @var{objects}.  The
693 arguments @var{objects} are the computed values to be formatted.
695 The characters in @var{string}, other than the format specifications,
696 are copied directly into the output; if they have text properties,
697 these are copied into the output also.
698 @end defun
700 @cindex @samp{%} in format
701 @cindex format specification
702   A format specification is a sequence of characters beginning with a
703 @samp{%}.  Thus, if there is a @samp{%d} in @var{string}, the
704 @code{format} function replaces it with the printed representation of
705 one of the values to be formatted (one of the arguments @var{objects}).
706 For example:
708 @example
709 @group
710 (format "The value of fill-column is %d." fill-column)
711      @result{} "The value of fill-column is 72."
712 @end group
713 @end example
715   If @var{string} contains more than one format specification, the
716 format specifications correspond to successive values from
717 @var{objects}.  Thus, the first format specification in @var{string}
718 uses the first such value, the second format specification uses the
719 second such value, and so on.  Any extra format specifications (those
720 for which there are no corresponding values) cause an error.  Any
721 extra values to be formatted are ignored.
723   Certain format specifications require values of particular types.  If
724 you supply a value that doesn't fit the requirements, an error is
725 signaled.
727   Here is a table of valid format specifications:
729 @table @samp
730 @item %s
731 Replace the specification with the printed representation of the object,
732 made without quoting (that is, using @code{princ}, not
733 @code{prin1}---@pxref{Output Functions}).  Thus, strings are represented
734 by their contents alone, with no @samp{"} characters, and symbols appear
735 without @samp{\} characters.
737 If the object is a string, its text properties are
738 copied into the output.  The text properties of the @samp{%s} itself
739 are also copied, but those of the object take priority.
741 @item %S
742 Replace the specification with the printed representation of the object,
743 made with quoting (that is, using @code{prin1}---@pxref{Output
744 Functions}).  Thus, strings are enclosed in @samp{"} characters, and
745 @samp{\} characters appear where necessary before special characters.
747 @item %o
748 @cindex integer to octal
749 Replace the specification with the base-eight representation of an
750 integer.
752 @item %d
753 Replace the specification with the base-ten representation of an
754 integer.
756 @item %x
757 @itemx %X
758 @cindex integer to hexadecimal
759 Replace the specification with the base-sixteen representation of an
760 integer.  @samp{%x} uses lower case and @samp{%X} uses upper case.
762 @item %c
763 Replace the specification with the character which is the value given.
765 @item %e
766 Replace the specification with the exponential notation for a floating
767 point number.
769 @item %f
770 Replace the specification with the decimal-point notation for a floating
771 point number.
773 @item %g
774 Replace the specification with notation for a floating point number,
775 using either exponential notation or decimal-point notation, whichever
776 is shorter.
778 @item %%
779 Replace the specification with a single @samp{%}.  This format
780 specification is unusual in that it does not use a value.  For example,
781 @code{(format "%% %d" 30)} returns @code{"% 30"}.
782 @end table
784   Any other format character results in an @samp{Invalid format
785 operation} error.
787   Here are several examples:
789 @example
790 @group
791 (format "The name of this buffer is %s." (buffer-name))
792      @result{} "The name of this buffer is strings.texi."
794 (format "The buffer object prints as %s." (current-buffer))
795      @result{} "The buffer object prints as strings.texi."
797 (format "The octal value of %d is %o,
798          and the hex value is %x." 18 18 18)
799      @result{} "The octal value of 18 is 22,
800          and the hex value is 12."
801 @end group
802 @end example
804 @cindex field width
805 @cindex padding
806   All the specification characters allow an optional ``width'', which
807 is a digit-string between the @samp{%} and the character.  If the
808 printed representation of the object contains fewer characters than
809 this width, then it is padded.  The padding is on the left if the
810 width is positive (or starts with zero) and on the right if the
811 width is negative.  The padding character is normally a space, but if
812 the width starts with a zero, zeros are used for padding.  Some of
813 these conventions are ignored for specification characters for which
814 they do not make sense.  That is, @samp{%s}, @samp{%S} and @samp{%c}
815 accept a width starting with 0, but still pad with @emph{spaces} on
816 the left.  Also, @samp{%%} accepts a width, but ignores it.  Here are
817 some examples of padding:
819 @example
820 (format "%06d is padded on the left with zeros" 123)
821      @result{} "000123 is padded on the left with zeros"
823 (format "%-6d is padded on the right" 123)
824      @result{} "123    is padded on the right"
825 @end example
827 If the width is too small, @code{format} does not truncate the
828 object's printed representation.  Thus, you can use a width to specify
829 a minimum spacing between columns with no risk of losing information.
831   In the following three examples, @samp{%7s} specifies a minimum width
832 of 7.  In the first case, the string inserted in place of @samp{%7s} has
833 only 3 letters, so 4 blank spaces are inserted for padding.  In the
834 second case, the string @code{"specification"} is 13 letters wide but is
835 not truncated.  In the third case, the padding is on the right.
837 @smallexample
838 @group
839 (format "The word `%7s' actually has %d letters in it."
840         "foo" (length "foo"))
841      @result{} "The word `    foo' actually has 3 letters in it."
842 @end group
844 @group
845 (format "The word `%7s' actually has %d letters in it."
846         "specification" (length "specification"))
847      @result{} "The word `specification' actually has 13 letters in it."
848 @end group
850 @group
851 (format "The word `%-7s' actually has %d letters in it."
852         "foo" (length "foo"))
853      @result{} "The word `foo    ' actually has 3 letters in it."
854 @end group
855 @end smallexample
857 @cindex precision in format specifications
858   All the specification characters allow an optional ``precision''
859 before the character (after the width, if present).  The precision is
860 a decimal-point @samp{.} followed by a digit-string.  For the
861 floating-point specifications (@samp{%e}, @samp{%f}, @samp{%g}), the
862 precision specifies how many decimal places to show; if zero, the
863 decimal-point itself is also omitted.  For @samp{%s} and @samp{%S},
864 the precision truncates the string to the given width, so
865 @samp{%.3s} shows only the first three characters of the
866 representation for @var{object}.  Precision is ignored for other
867 specification characters.
869 @cindex flags in format specifications
870 Immediately after the @samp{%} and before the optional width and
871 precision, you can put certain ``flag'' characters.
873 A space character inserts a space for positive numbers (otherwise
874 nothing is inserted for positive numbers).  This flag is ignored
875 except for @samp{%d}, @samp{%e}, @samp{%f}, @samp{%g}.
877 The flag @samp{#} indicates ``alternate form''.  For @samp{%o} it
878 ensures that the result begins with a 0.  For @samp{%x} and @samp{%X}
879 the result is prefixed with @samp{0x} or @samp{0X}. For @samp{%e},
880 @samp{%f}, and @samp{%g} a decimal point is always shown even if the
881 precision is zero.
883 @node Case Conversion
884 @comment node-name, next, previous, up
885 @section Case Conversion in Lisp
886 @cindex upper case
887 @cindex lower case
888 @cindex character case
889 @cindex case conversion in Lisp
891   The character case functions change the case of single characters or
892 of the contents of strings.  The functions normally convert only
893 alphabetic characters (the letters @samp{A} through @samp{Z} and
894 @samp{a} through @samp{z}, as well as non-@acronym{ASCII} letters); other
895 characters are not altered.  You can specify a different case
896 conversion mapping by specifying a case table (@pxref{Case Tables}).
898   These functions do not modify the strings that are passed to them as
899 arguments.
901   The examples below use the characters @samp{X} and @samp{x} which have
902 @acronym{ASCII} codes 88 and 120 respectively.
904 @defun downcase string-or-char
905 This function converts a character or a string to lower case.
907 When the argument to @code{downcase} is a string, the function creates
908 and returns a new string in which each letter in the argument that is
909 upper case is converted to lower case.  When the argument to
910 @code{downcase} is a character, @code{downcase} returns the
911 corresponding lower case character.  This value is an integer.  If the
912 original character is lower case, or is not a letter, then the value
913 equals the original character.
915 @example
916 (downcase "The cat in the hat")
917      @result{} "the cat in the hat"
919 (downcase ?X)
920      @result{} 120
921 @end example
922 @end defun
924 @defun upcase string-or-char
925 This function converts a character or a string to upper case.
927 When the argument to @code{upcase} is a string, the function creates
928 and returns a new string in which each letter in the argument that is
929 lower case is converted to upper case.
931 When the argument to @code{upcase} is a character, @code{upcase}
932 returns the corresponding upper case character.  This value is an integer.
933 If the original character is upper case, or is not a letter, then the
934 value returned equals the original character.
936 @example
937 (upcase "The cat in the hat")
938      @result{} "THE CAT IN THE HAT"
940 (upcase ?x)
941      @result{} 88
942 @end example
943 @end defun
945 @defun capitalize string-or-char
946 @cindex capitalization
947 This function capitalizes strings or characters.  If
948 @var{string-or-char} is a string, the function creates and returns a new
949 string, whose contents are a copy of @var{string-or-char} in which each
950 word has been capitalized.  This means that the first character of each
951 word is converted to upper case, and the rest are converted to lower
952 case.
954 The definition of a word is any sequence of consecutive characters that
955 are assigned to the word constituent syntax class in the current syntax
956 table (@pxref{Syntax Class Table}).
958 When the argument to @code{capitalize} is a character, @code{capitalize}
959 has the same result as @code{upcase}.
961 @example
962 @group
963 (capitalize "The cat in the hat")
964      @result{} "The Cat In The Hat"
965 @end group
967 @group
968 (capitalize "THE 77TH-HATTED CAT")
969      @result{} "The 77th-Hatted Cat"
970 @end group
972 @group
973 (capitalize ?x)
974      @result{} 88
975 @end group
976 @end example
977 @end defun
979 @defun upcase-initials string-or-char
980 If @var{string-or-char} is a string, this function capitalizes the
981 initials of the words in @var{string-or-char}, without altering any
982 letters other than the initials.  It returns a new string whose
983 contents are a copy of @var{string-or-char}, in which each word has
984 had its initial letter converted to upper case.
986 The definition of a word is any sequence of consecutive characters that
987 are assigned to the word constituent syntax class in the current syntax
988 table (@pxref{Syntax Class Table}).
990 When the argument to @code{upcase-initials} is a character,
991 @code{upcase-initials} has the same result as @code{upcase}.
993 @example
994 @group
995 (upcase-initials "The CAT in the hAt")
996      @result{} "The CAT In The HAt"
997 @end group
998 @end example
999 @end defun
1001   @xref{Text Comparison}, for functions that compare strings; some of
1002 them ignore case differences, or can optionally ignore case differences.
1004 @node Case Tables
1005 @section The Case Table
1007   You can customize case conversion by installing a special @dfn{case
1008 table}.  A case table specifies the mapping between upper case and lower
1009 case letters.  It affects both the case conversion functions for Lisp
1010 objects (see the previous section) and those that apply to text in the
1011 buffer (@pxref{Case Changes}).  Each buffer has a case table; there is
1012 also a standard case table which is used to initialize the case table
1013 of new buffers.
1015   A case table is a char-table (@pxref{Char-Tables}) whose subtype is
1016 @code{case-table}.  This char-table maps each character into the
1017 corresponding lower case character.  It has three extra slots, which
1018 hold related tables:
1020 @table @var
1021 @item upcase
1022 The upcase table maps each character into the corresponding upper
1023 case character.
1024 @item canonicalize
1025 The canonicalize table maps all of a set of case-related characters
1026 into a particular member of that set.
1027 @item equivalences
1028 The equivalences table maps each one of a set of case-related characters
1029 into the next character in that set.
1030 @end table
1032   In simple cases, all you need to specify is the mapping to lower-case;
1033 the three related tables will be calculated automatically from that one.
1035   For some languages, upper and lower case letters are not in one-to-one
1036 correspondence.  There may be two different lower case letters with the
1037 same upper case equivalent.  In these cases, you need to specify the
1038 maps for both lower case and upper case.
1040   The extra table @var{canonicalize} maps each character to a canonical
1041 equivalent; any two characters that are related by case-conversion have
1042 the same canonical equivalent character.  For example, since @samp{a}
1043 and @samp{A} are related by case-conversion, they should have the same
1044 canonical equivalent character (which should be either @samp{a} for both
1045 of them, or @samp{A} for both of them).
1047   The extra table @var{equivalences} is a map that cyclically permutes
1048 each equivalence class (of characters with the same canonical
1049 equivalent).  (For ordinary @acronym{ASCII}, this would map @samp{a} into
1050 @samp{A} and @samp{A} into @samp{a}, and likewise for each set of
1051 equivalent characters.)
1053   When you construct a case table, you can provide @code{nil} for
1054 @var{canonicalize}; then Emacs fills in this slot from the lower case
1055 and upper case mappings.  You can also provide @code{nil} for
1056 @var{equivalences}; then Emacs fills in this slot from
1057 @var{canonicalize}.  In a case table that is actually in use, those
1058 components are non-@code{nil}.  Do not try to specify @var{equivalences}
1059 without also specifying @var{canonicalize}.
1061   Here are the functions for working with case tables:
1063 @defun case-table-p object
1064 This predicate returns non-@code{nil} if @var{object} is a valid case
1065 table.
1066 @end defun
1068 @defun set-standard-case-table table
1069 This function makes @var{table} the standard case table, so that it will
1070 be used in any buffers created subsequently.
1071 @end defun
1073 @defun standard-case-table
1074 This returns the standard case table.
1075 @end defun
1077 @defun current-case-table
1078 This function returns the current buffer's case table.
1079 @end defun
1081 @defun set-case-table table
1082 This sets the current buffer's case table to @var{table}.
1083 @end defun
1085   The following three functions are convenient subroutines for packages
1086 that define non-@acronym{ASCII} character sets.  They modify the specified
1087 case table @var{case-table}; they also modify the standard syntax table.
1088 @xref{Syntax Tables}.  Normally you would use these functions to change
1089 the standard case table.
1091 @defun set-case-syntax-pair uc lc case-table
1092 This function specifies a pair of corresponding letters, one upper case
1093 and one lower case.
1094 @end defun
1096 @defun set-case-syntax-delims l r case-table
1097 This function makes characters @var{l} and @var{r} a matching pair of
1098 case-invariant delimiters.
1099 @end defun
1101 @defun set-case-syntax char syntax case-table
1102 This function makes @var{char} case-invariant, with syntax
1103 @var{syntax}.
1104 @end defun
1106 @deffn Command describe-buffer-case-table
1107 This command displays a description of the contents of the current
1108 buffer's case table.
1109 @end deffn
1111 @ignore
1112    arch-tag: 700b8e95-7aa5-4b52-9eb3-8f2e1ea152b4
1113 @end ignore