2 .\" Copyright 1989 AT&T Copyright (c) 1990, Sun Microsystems, Inc. All Rights Reserved
3 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License"). You may not use this file except in compliance with the License.
4 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing. See the License for the specific language governing permissions and limitations under the License.
5 .\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE. If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
6 .TH EXSTR 1 "Jul 5, 1990"
8 exstr \- extract strings from source files
12 \fBexstr\fR \fIfilename\fR...
17 \fBexstr\fR \fB-e\fR \fIfilename\fR...
22 \fBexstr\fR \fB-r\fR [\fB-d\fR] \fIfilename\fR...
28 The \fBexstr\fR utility is used to extract strings from C-language source files
29 and replace them by calls to the message retrieval function (see
30 \fBgettxt\fR(3C)). This utility will extract all character strings surrounded
31 by double quotes, not just strings used as arguments to the \fBprintf\fR
32 command or the \fBprintf\fR routine. In the first form, \fBexstr\fR finds all
33 strings in the source files and writes them on the standard output. Each string
34 is preceded by the source file name and a colon (\fB:\fR).
37 The first step is to use \fBexstr\fR \fB-e\fR to extract a list of strings and
38 save it in a file. Next, examine this list and determine which strings can be
39 translated and subsequently retrieved by the message retrieval function. Then,
40 modify this file by deleting lines that can't be translated and, for lines that
41 can be translated, by adding the message file names and the message numbers as
42 the fourth (\fImsgfile\fR) and fifth (\fImsgnum\fR) entries on a line. The
43 message files named must have been created by \fBmkmsgs\fR(1) and exist in
44 \fB/usr/lib/locale/\fR\fBlocale\fR\fB/\fR\fBLC_MESSAGES\fR\fB \fR. (The
45 directory \fBlocale\fR corresponds to the language in which the text strings
46 are written; see \fBsetlocale\fR(3C)). The message numbers used must correspond
47 to the sequence numbers of strings in the message files.
50 Now use this modified file as input to \fBexstr\fR \fB-r\fR to produce a new
51 version of the original C-language source file in which the strings have been
52 replaced by calls to the message retrieval function \fBgettxt\fR(). The
53 \fImsgfile\fR and \fImsgnum\fR fields are used to construct the first argument
54 to \fBgettxt\fR(). The second argument to \fBgettxt\fR() is printed if the
55 message retrieval fails at run-time. This argument is the null string, unless
56 the \fB-d\fR option is used.
59 This utility cannot replace strings in all instances. For example, a static
60 initialized character string cannot be replaced by a function call. A second
61 example is that a string could be in a form of an escape sequence which could
62 not be translated. In order not to break existing code, the files created by
63 invoking \fBexstr\fR \fB-e\fR must be examined and lines containing strings not
64 replaceable by function calls must be deleted. In some cases the code may
65 require modifications so that strings can be extracted and replaced by calls to
66 the message retrieval function.
70 The following options are supported:
77 Extract a list of strings from the named C-language source files, with
78 positional information. This list is produced on standard output in the
83 \fB\fIfile:line:position:msgfile:msgnum:string\fR \fR
97 the name of a C-language source file
107 line number in the file
113 \fB\fIposition\fR \fR
117 character position in the line
147 the extracted text string
150 Normally you would redirect this output into a file. Then you would edit this
151 file to add the values you want to use for \fImsgfile\fR and \fImsgnum\fR:
158 the file that contains the text strings that will replace \fIstring\fR. A file
159 with this name must be created and installed in the appropriate place by the
160 \fBmkmsgs\fR(1) utility.
169 the sequence number of the string in \fImsgfile\fR.
172 The next step is to use \fBexstr\fR \fB-r\fR to replace \fIstring\fRs in
182 Replace strings in a C-language source file with function calls to the message
183 retrieval function \fBgettxt\fR().
192 This option is used together with the \fB-r\fR option. If the message retrieval
193 fails when \fBgettxt\fR() is invoked at run-time, then the extracted string is
194 printed. You would use the capability provided by \fBexstr\fR on an application
195 program that needs to run in an international environment and have messages
196 print in more than one language. \fBexstr\fR replaces text strings with
197 function calls that point at strings in a message data base. The data base used
198 depends on the run-time value of the \fBLC_MESSAGES\fR environment variable
199 (see \fBenviron\fR(5)).
204 \fBExample 1 \fRThe following examples show uses of exstr
207 Assume that the file \fBexample.c\fR contains two strings:
216 printf("This is an example\en");
218 printf("Hello world!\en");
226 The \fBexstr\fR utility, invoked with the argument \fBexample.c\fR extracts
227 strings from the named file and prints them on the standard output.
232 example% \fBexstr example.c\fR
239 produces the following output:
244 example.c:This is an example\en
245 example.c:Hello world!\en
252 The \fBexstr\fR utility, invoked with the \fB-e\fR option and the argument
253 \fBexample.c\fR, and redirecting output to the file \fBexample.stringsout\fR
258 example% \fBexstr -e example.c > example.stringsout\fR
265 produces the following output in the file \fBexample.stringsout\fR
270 example.c:3:8:::This is an example\en
271 example.c:4:8:::Hello world!\en
278 You must edit \fBexample.stringsout\fR to add the values you want to use for
279 the \fImsgfile\fR and \fImsgnum\fR fields before these strings can be replaced
280 by calls to the retrieval function. If \fBUX\fR is the name of the message
281 file, and the numbers \fB1\fR and \fB2\fR represent the sequence number of the
282 strings in the file, here is what \fBexample.stringsout\fR looks like after you
283 add this information:
288 example.c:3:8:UX:1:This is an example\en
289 example.c:4:8:UX:2:Hello world!\en
296 The \fBexstr\fR utility can now be invoked with the \fB-r\fR option to replace
297 the strings in the source file by calls to the message retrieval function
303 example% \fBexstr -r example.c <example.stringsout >intlexample.c\fR
310 produces the following output:
315 \fBextern char *gettxt();
321 printf(gettxt("UX:1", ""));
323 printf(gettxt("UX:2", ""));
332 The following example:
337 example% \fBexstr -rd example.c <example.stringsout >intlexample.c\fR
344 uses the extracted strings as a second argument to \fBgettxt()\fR:
349 extern char *gettxt();
355 printf(gettxt("UX:1", "This is an example\en"));
357 printf(gettxt("UX:2", "Hello world!\en"));
368 \fB\fB/usr/lib/locale/\fR\fIlocale\fR\fB/LC_MESSAGES/* \fR\fR
372 files created by \fBmkmsgs\fR(1)
378 \fBgettxt\fR(1), \fBmkmsgs\fR(1), \fBprintf\fR(1), \fBsrchtxt\fR(1),
379 \fBgettxt\fR(3C), \fBprintf\fR(3C), \fBsetlocale\fR(3C), \fBattributes\fR(5),
384 The error messages produced by \fBexstr\fR are intended to be self-explanatory.
385 They indicate errors in the command line or format errors encountered within