2 .\" Portions Copyright (c) 2004, 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 GENMSG 1 "May 14, 2004"
8 genmsg \- generate a message source file by extracting messages from source
13 \fBgenmsg\fR [\fB-abdfrntx\fR] [\fB-c\fR \fImessage-tag\fR] [\fB-g\fR \fIproject-file\fR]
14 [\fB-l\fR \fIproject-file\fR] [\fB-m\fR \fIprefix\fR] [\fB-M\fR \fIsuffix\fR]
15 [\fB-o\fR \fImessage-file\fR] [\fB-p\fR \fIpreprocessor\fR] [\fB-s\fR \fIset-tags\fR] \fI file\fR...
21 The \fBgenmsg\fR utility extracts message strings with calls to
22 \fBcatgets\fR(3C) from source files and writes them in a format suitable for
23 input to \fBgencat\fR(1).
27 \fBgenmsg\fR reads one or more input files and, by default, generates a message
28 source file whose name is composed of the first input file name with
29 \fB\&.msg\fR. If the \fB-o\fR option is specified, \fBgenmsg\fR uses the option
30 argument for its output file.
38 \fICommand\fR \fIOutput File\fR
40 \fBgenmsg prog.c\fR prog.c.msg
41 \fBgensmg main.c util.c tool.c\fR main.c.msg
42 \fBgenmsg -o prog.msg mail.c util.c\fR prog.msg
47 \fBgenmsg\fR also allows you to invoke a preprocessor to solve the dependencies
48 of macros and define statements for the \fBcatgets\fR(3C) calls.
49 .SS "Auto Message Numbering"
52 \fBgenmsg\fR replaces message numbers with the calculated numbers based upon
53 the project file if the message numbers are \fB-1\fR, and it generates copies
54 of the input files with the new message numbers and a copy of the project file
55 with the new maximum message numbers.
58 A project file is a database that stores a list of set numbers with their
59 maximum message numbers. Each line in a project file is composed of a set
60 number and its maximum message number:
64 \fB\fISet_number\fR\fR
67 \fIMaximum_message_number\fR
72 In a project file, a line beginning with a number sign (\fB#\fR) or an
73 \fBASCII\fR space is considered as a comment and ignored.
76 \fBgenmsg\fR also has the reverse operation to replace all message numbers with
78 .SS "Comment Extraction"
81 \fBgenmsg\fR allows you to comment about messages and set numbers to inform the
82 translator how the messages should be translated. It extracts the comment,
83 which is surrounded with the comment indicators and has the specified tag
84 inside the comment, from the input file and writes it with a dollar (\fB$\fR)
85 prefix in the output file. \fBgenmsg\fR supports the C and C++ comment
86 indicators, '\fB/*\fR', '\fB*/\fR', and '\fB//\fR'.
90 \fBgenmsg\fR generates two kinds of messages for testing, prefixed messages and
91 long messages. Prefixed messages allow you to check that your program is
92 retrieving the messages from the message catalog. Long messages allow you to
93 check the appearance of your window program's initial size and position.
97 The following options are supported:
104 Append the output into the message file \fImessage-file\fR that is specified by
105 the \fB-o\fR option. If two different messages that have the same set and
106 message number are found, the message in the specified message file is kept and
107 the other message in the input file is discarded.
116 Place the extracted comment after the corresponding message in the output file.
117 This option changes the placement behavior of the \fB-s\fR or \fB-c\fR option.
123 \fB\fB-c\fR\fI message-tag\fR\fR
126 Extract message comments having \fImessage-tag\fR inside them from the input
127 files and write them with a '\fB$\fR' prefix as a comment in the output file.
136 Include an original text of a message as a comment to be preserved along with
137 its translations. With this option, the translator can see the original
138 messages even after they are replaced with their translations.
147 Overwrite the input files and the project file when used with the \fB-l\fR or
148 \fB-r\fR option. With the \fB-r\fR option, \fBgenmsg\fR overwrites only the
155 \fB\fB-g\fR\fI project-file\fR\fR
158 Generate \fIproject-file\fR that has a list of set numbers and their maximum
159 message numbers in the input files.
165 \fB\fB-l\fR\fI project-file\fR\fR
168 Replace message numbers with the calculated numbers based upon
169 \fIproject-file\fR if the message numbers are \fB-1\fR in the input files, and
170 then generate copies of the input files with the new message numbers and a copy
171 of \fIproject-file\fR with the new maximum message numbers. If
172 \fIproject-file\fR is not found, \fBgenmsg\fR uses the maximum message number
173 in the input file as a base number and generates \fIproject-file\fR.
179 \fB\fB-m\fR\fI prefix\fR\fR
182 Fill in the message with \fIprefix\fR. This option is useful for testing.
188 \fB\fB-M\fR\fI suffix\fR\fR
191 Fill in the message with \fIsuffix\fR. This option is useful for testing.
200 Add comment lines to the output file indicating the file name and line number
201 in the input files where each extracted string is encountered.
207 \fB\fB-o\fR\fI message-file\fR\fR
210 Write the output to \fImessage-file\fR.
216 \fB\fB-p\fR\fI preprocessor\fR\fR
219 Invoke \fIpreprocessor\fR to preprocess macros and define statements for the
220 \fBcatgets\fR(3C) calls. \fBgenmsg\fR first invokes the option argument as a
221 preprocesser and then starts the normal process against the output from the
222 preprocessor. \fBgenmsg\fR initiates this process for all the input files.
231 Replace message numbers with \fB-1\fR. This is the reverse operation of the
238 \fB\fB-s\fR\fI set-tag\fR\fR
241 Extract set number comments having \fIset-tag\fR inside them from the input
242 files and write them with a '\fB$\fR' prefix as a comment in the output file.
243 If multiple comments are specified for one set number, the first one is
244 extracted and the rest of them are discarded.
253 Generate a message that is three times as long as the original message. This
254 option is useful for testing.
263 Suppress warning messages about message and set number range checks and
274 An input source file.
279 \fBExample 1 \fRAssigning Message Numbers and Generating New Files
282 Suppose that you have the following source and project files:
288 printf(catgets(catfd, 1, -1, "line too long\en"));
289 printf(catgets(catfd, 2, -1, "invalid code\en"));
305 example% genmsg \fB-l\fR proj test.c
312 would assign the calculated message numbers based upon \fBproj\fR and generate
318 \fB\fBtest.c.msg\fR\fR
336 \fB\fBtest.c.new\fR\fR
345 example% cat test.c.msg
348 11 "line too long\en"
352 example% cat proj.new
356 example% cat test.c.new
357 printf(catgets(catfd, 1, 11, "line too long\en"));
358 printf(catgets(catfd, 2, 21, "invalid code\en"));
364 \fBExample 2 \fRExtracting Comments Into a File
372 example% genmsg \fB-s\fR SET \fB-c\fR MSG test.c
374 /* SET: tar messages */
375 /* MSG: don't translate "tar". */
376 catgets(catfd, 1, 1, "tar: tape write error");
377 // MSG: don't translate "tar" and "\fB-I\fR".
378 catgets(catfd, 1, 2, "tar: missing argument for \fB-I\fR flag");
385 would extract the comments and write them in the following output file:
390 example% cat test.c.msg
391 $ /* SET: tar messages */
393 $ /* MSG: don't translate "tar". */
394 1 "tar: tape write error"
395 $ // MSG: don't translate "tar" and "-I".
396 2 "tar: missing argument for -I flag"
402 \fBExample 3 \fRGenerating Test Messages
405 The following command:
410 example% genmsg \fB-m\fR PRE: \fB-M\fR :FIX test.c
417 might generate the following messages for testing:
422 example% cat test.c.msg
430 \fBExample 4 \fRParsing a Macro and Writing the Extracted Messages
433 Given the following input:
438 example% cat example.c
439 #include <nl_types.h>
440 #define MSG1 "message1"
441 #define MSG2 "message2"
442 #define MSG3 "message3"
443 #define MSG(n) catgets(catd, 1, n, MSG ## n)
445 main(int argc, char **argv)
447 nl_catd catd = catopen(argv[0], NL_CAT_LOCALE);
448 (void) printf("%s0\en, MSG(1));
449 (void) printf("%s0\en, MSG(2));
450 (void) printf("%s0\en, MSG(3));
451 (void) catclose(catd);
459 The following command:
464 example% genmsg \fB-p\fR "cc \fB-E\fR" \fB-o\fR example.msg example.c
471 would parse the \fBMSG\fR macros and write the extracted messages in
475 \fBExample 5 \fRAssigning Calculated Message Numbers
478 Suppose that you have the following header, source, and project files:
483 example% cat ../inc/msg.h
486 #define WARN_MSG(id, msg) catgets(catd, WARN_SET, (id), (msg))
487 #define ERR_MSG(id, msg) catgets(catd, ERR_SET, (id), (msg))
490 printf("%s, WARN_MSG(-1, "Warning error"));
491 printf("%s, ERR_MSG(-1, "Fatal error"));
506 example% genmsg \fB-f\fR -p "cc \fB-E\fR \fB-I\fR../inc" \fB-l\fR proj \e
507 \fB-o\fR example.msg example.c
514 would assign each of the \fB-1\fR message numbers a calculated number based
515 upon \fBproj\fR and would overwrite the results to \fBexample.c\fR and
516 \fBproj\fR. Also, this command writes the extracted messages in
519 .SH ENVIRONMENT VARIABLES
522 See \fBenviron\fR(5) for descriptions of the following environment variables
523 that affect the execution of \fBgenmsg\fR: \fBLC_MESSAGES\fR and \fBNLSPATH\fR.
527 The following exit values are returned:
534 Successful completion.
549 \fBgencat\fR(1), \fBcatgets\fR(3C), \fBcatopen\fR(3C), \fBattributes\fR(5),
554 \fBgenmsg\fR does not handle pointers or variables in the \fBcatgets\fR(3C)
560 const int set_num = 1;
561 extern int msg_num(const char *);
562 const char *msg = "Hello";
563 catgets(catd, set_num, msg_num(msg), msg);
570 When the auto message numbering is turned on with a preprocessor, if there are
571 multiple \fB-1's\fR in the \fBcatgets\fR(3C) line, \fBgenmsg\fR replaces all of
572 the \fB-1's\fR in the line with a calculated number. For example, given the
577 #define MSG(id, msg) catgets(catd, 1, (id), (msg))
578 if (ret == -1) printf("%s, MSG(-1, "Failed"));
589 genmsg \fB-l\fR proj \fB-p\fR "cc \fB-E\fR"
600 #define MSG(id, msg) catgets(catd, 1, (id), (msg))
601 if (ret == 1) printf("%s, MSG(1, "Failed"));
608 The workaround would be to split it into two lines as follows:
613 printf("%s, MSG(-1, "Failed"));