3 <!-- This HTML file has been created by texi2html 1.52a
4 from gettext.texi on 11 April 2005 -->
6 <TITLE>GNU gettext utilities -
7 Manipulating PO Files
</TITLE>
9 Go to the
<A HREF=
"gettext_1.html">first
</A>,
<A HREF=
"gettext_6.html">previous
</A>,
<A HREF=
"gettext_8.html">next
</A>,
<A HREF=
"gettext_22.html">last
</A> section,
<A HREF=
"gettext_toc.html">table of contents
</A>.
13 <H1><A NAME=
"SEC66" HREF=
"gettext_toc.html#TOC66">7 Manipulating PO Files
</A></H1>
19 Sometimes it is necessary to manipulate PO files in a way that is better
20 performed automatically than by hand. GNU
<CODE>gettext
</CODE> includes a
21 complete set of tools for this purpose.
26 When merging two packages into a single package, the resulting POT file
27 will be the concatenation of the two packages' POT files. Thus the
28 maintainer must concatenate the two existing package translations into
29 a single translation catalog, for each language. This is best performed
30 using
<SAMP>`msgcat
´</SAMP>. It is then the translators' duty to deal with any
31 possible conflicts that arose during the merge.
36 When a translator takes over the translation job from another translator,
37 but she uses a different character encoding in her locale, she will
38 convert the catalog to her character encoding. This is best done through
39 the
<SAMP>`msgconv
´</SAMP> program.
43 When a maintainer takes a source file with tagged messages from another
44 package, he should also take the existing translations for this source
45 file (and not let the translators do the same job twice). One way to do
46 this is through
<SAMP>`msggrep
´</SAMP>, another is to create a POT file for
47 that source file and use
<SAMP>`msgmerge
´</SAMP>.
53 When a translator wants to adjust some translation catalog for a special
54 dialect or orthography -- for example, German as written in Switzerland
55 versus German as written in Germany -- she needs to apply some text
56 processing to every message in the catalog. The tool for doing this is
57 <SAMP>`msgfilter
´</SAMP>.
61 Another use of
<CODE>msgfilter
</CODE> is to produce approximately the POT file for
62 which a given PO file was made. This can be done through a filter command
63 like
<SAMP>`msgfilter sed -e d | sed -e '/^# /d'
´</SAMP>. Note that the original
64 POT file may have had different comments and different plural message counts,
65 that's why it's better to use the original POT file if available.
70 When a translator wants to check her translations, for example according
71 to orthography rules or using a non-interactive spell checker, she can do
72 so using the
<SAMP>`msgexec
´</SAMP> program.
77 When third party tools create PO or POT files, sometimes duplicates cannot
78 be avoided. But the GNU
<CODE>gettext
</CODE> tools give an error when they
79 encounter duplicate msgids in the same file and in the same domain.
80 To merge duplicates, the
<SAMP>`msguniq
´</SAMP> program can be used.
84 <SAMP>`msgcomm
´</SAMP> is a more general tool for keeping or throwing away
85 duplicates, occurring in different files.
89 <SAMP>`msgcmp
´</SAMP> can be used to check whether a translation catalog is
90 completely translated.
95 <SAMP>`msgattrib
´</SAMP> can be used to select and extract only the fuzzy
96 or untranslated messages of a translation catalog.
100 <SAMP>`msgen
´</SAMP> is useful as a first step for preparing English translation
101 catalogs. It copies each message's msgid to its msgstr.
105 Finally, for those applications where all these various programs are not
106 sufficient, a library
<SAMP>`libgettextpo
´</SAMP> is provided that can be used to
107 write other specialized programs that process PO files.
113 <H2><A NAME=
"SEC67" HREF=
"gettext_toc.html#TOC67">7.1 Invoking the
<CODE>msgcat
</CODE> Program
</A></H2>
116 <A NAME=
"IDX492"></A>
117 <A NAME=
"IDX493"></A>
120 msgcat [
<VAR>option
</VAR>] [
<VAR>inputfile
</VAR>]...
124 <A NAME=
"IDX494"></A>
125 <A NAME=
"IDX495"></A>
126 The
<CODE>msgcat
</CODE> program concatenates and merges the specified PO files.
127 It finds messages which are common to two or more of the specified PO files.
128 By using the
<CODE>--more-than
</CODE> option, greater commonality may be requested
129 before messages are printed. Conversely, the
<CODE>--less-than
</CODE> option may be
130 used to specify less commonality before messages are printed (i.e.
131 <SAMP>`--less-than=
2´</SAMP> will only print the unique messages). Translations,
132 comments and extract comments will be cumulated, except that if
133 <CODE>--use-first
</CODE> is specified, they will be taken from the first PO file
134 to define them. File positions from all PO files will be cumulated.
139 <H3><A NAME=
"SEC68" HREF=
"gettext_toc.html#TOC68">7.1.1 Input file location
</A></H3>
143 <DT><SAMP>`
<VAR>inputfile
</VAR> ...
´</SAMP>
147 <DT><SAMP>`-f
<VAR>file
</VAR>´</SAMP>
149 <DT><SAMP>`--files-from=
<VAR>file
</VAR>´</SAMP>
151 <A NAME=
"IDX496"></A>
152 <A NAME=
"IDX497"></A>
153 Read the names of the input files from
<VAR>file
</VAR> instead of getting
154 them from the command line.
156 <DT><SAMP>`-D
<VAR>directory
</VAR>´</SAMP>
158 <DT><SAMP>`--directory=
<VAR>directory
</VAR>´</SAMP>
160 <A NAME=
"IDX498"></A>
161 <A NAME=
"IDX499"></A>
162 Add
<VAR>directory
</VAR> to the list of directories. Source files are
163 searched relative to this list of directories. The resulting
<TT>`.po
´</TT>
164 file will be written relative to the current directory, though.
169 If
<VAR>inputfile
</VAR> is
<SAMP>`-
´</SAMP>, standard input is read.
174 <H3><A NAME=
"SEC69" HREF=
"gettext_toc.html#TOC69">7.1.2 Output file location
</A></H3>
178 <DT><SAMP>`-o
<VAR>file
</VAR>´</SAMP>
180 <DT><SAMP>`--output-file=
<VAR>file
</VAR>´</SAMP>
182 <A NAME=
"IDX500"></A>
183 <A NAME=
"IDX501"></A>
184 Write output to specified file.
189 <A NAME=
"IDX502"></A>
190 The results are written to standard output if no output file is specified
191 or if it is
<SAMP>`-
´</SAMP>.
196 <H3><A NAME=
"SEC70" HREF=
"gettext_toc.html#TOC70">7.1.3 Message selection
</A></H3>
200 <DT><SAMP>`-
< <VAR>number
</VAR>´</SAMP>
202 <DT><SAMP>`--less-than=
<VAR>number
</VAR>´</SAMP>
204 <A NAME=
"IDX503"></A>
205 <A NAME=
"IDX504"></A>
206 Print messages with less than
<VAR>number
</VAR> definitions, defaults to infinite
209 <DT><SAMP>`-
> <VAR>number
</VAR>´</SAMP>
211 <DT><SAMP>`--more-than=
<VAR>number
</VAR>´</SAMP>
213 <A NAME=
"IDX505"></A>
214 <A NAME=
"IDX506"></A>
215 Print messages with more than
<VAR>number
</VAR> definitions, defaults to
0 if not
218 <DT><SAMP>`-u
´</SAMP>
220 <DT><SAMP>`--unique
´</SAMP>
222 <A NAME=
"IDX507"></A>
223 <A NAME=
"IDX508"></A>
224 Shorthand for
<SAMP>`--less-than=
2´</SAMP>. Requests that only unique messages be
231 <H3><A NAME=
"SEC71" HREF=
"gettext_toc.html#TOC71">7.1.4 Input file syntax
</A></H3>
235 <DT><SAMP>`-P
´</SAMP>
237 <DT><SAMP>`--properties-input
´</SAMP>
239 <A NAME=
"IDX509"></A>
240 <A NAME=
"IDX510"></A>
241 Assume the input files are Java ResourceBundles in Java
<CODE>.properties
</CODE>
242 syntax, not in PO file syntax.
244 <DT><SAMP>`--stringtable-input
´</SAMP>
246 <A NAME=
"IDX511"></A>
247 Assume the input files are NeXTstep/GNUstep localized resource files in
248 <CODE>.strings
</CODE> syntax, not in PO file syntax.
254 <H3><A NAME=
"SEC72" HREF=
"gettext_toc.html#TOC72">7.1.5 Output details
</A></H3>
258 <DT><SAMP>`-t
´</SAMP>
260 <DT><SAMP>`--to-code=
<VAR>name
</VAR>´</SAMP>
262 <A NAME=
"IDX512"></A>
263 <A NAME=
"IDX513"></A>
264 Specify encoding for output.
266 <DT><SAMP>`--use-first
´</SAMP>
268 <A NAME=
"IDX514"></A>
269 Use first available translation for each message. Don't merge several
270 translations into one.
272 <DT><SAMP>`--force-po
´</SAMP>
274 <A NAME=
"IDX515"></A>
275 Always write an output file even if it contains no message.
277 <DT><SAMP>`-i
´</SAMP>
279 <DT><SAMP>`--indent
´</SAMP>
281 <A NAME=
"IDX516"></A>
282 <A NAME=
"IDX517"></A>
283 Write the .po file using indented style.
285 <DT><SAMP>`--no-location
´</SAMP>
287 <A NAME=
"IDX518"></A>
288 Do not write
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines.
290 <DT><SAMP>`-n
´</SAMP>
292 <DT><SAMP>`--add-location
´</SAMP>
294 <A NAME=
"IDX519"></A>
295 <A NAME=
"IDX520"></A>
296 Generate
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines (default).
298 <DT><SAMP>`--strict
´</SAMP>
300 <A NAME=
"IDX521"></A>
301 Write out a strict Uniforum conforming PO file. Note that this
302 Uniforum format should be avoided because it doesn't support the
305 <DT><SAMP>`-p
´</SAMP>
307 <DT><SAMP>`--properties-output
´</SAMP>
309 <A NAME=
"IDX522"></A>
310 <A NAME=
"IDX523"></A>
311 Write out a Java ResourceBundle in Java
<CODE>.properties
</CODE> syntax. Note
312 that this file format doesn't support plural forms and silently drops
315 <DT><SAMP>`--stringtable-output
´</SAMP>
317 <A NAME=
"IDX524"></A>
318 Write out a NeXTstep/GNUstep localized resource file in
<CODE>.strings
</CODE> syntax.
319 Note that this file format doesn't support plural forms.
321 <DT><SAMP>`-w
<VAR>number
</VAR>´</SAMP>
323 <DT><SAMP>`--width=
<VAR>number
</VAR>´</SAMP>
325 <A NAME=
"IDX525"></A>
326 <A NAME=
"IDX526"></A>
327 Set the output page width. Long strings in the output files will be
328 split across multiple lines in order to ensure that each line's width
329 (= number of screen columns) is less or equal to the given
<VAR>number
</VAR>.
331 <DT><SAMP>`--no-wrap
´</SAMP>
333 <A NAME=
"IDX527"></A>
334 Do not break long message lines. Message lines whose width exceeds the
335 output page width will not be split into several lines. Only file reference
336 lines which are wider than the output page width will be split.
338 <DT><SAMP>`-s
´</SAMP>
340 <DT><SAMP>`--sort-output
´</SAMP>
342 <A NAME=
"IDX528"></A>
343 <A NAME=
"IDX529"></A>
344 <A NAME=
"IDX530"></A>
345 Generate sorted output. Note that using this option makes it much harder
346 for the translator to understand each message's context.
348 <DT><SAMP>`-F
´</SAMP>
350 <DT><SAMP>`--sort-by-file
´</SAMP>
352 <A NAME=
"IDX531"></A>
353 <A NAME=
"IDX532"></A>
354 Sort output by file location.
360 <H3><A NAME=
"SEC73" HREF=
"gettext_toc.html#TOC73">7.1.6 Informative output
</A></H3>
364 <DT><SAMP>`-h
´</SAMP>
366 <DT><SAMP>`--help
´</SAMP>
368 <A NAME=
"IDX533"></A>
369 <A NAME=
"IDX534"></A>
370 Display this help and exit.
372 <DT><SAMP>`-V
´</SAMP>
374 <DT><SAMP>`--version
´</SAMP>
376 <A NAME=
"IDX535"></A>
377 <A NAME=
"IDX536"></A>
378 Output version information and exit.
384 <H2><A NAME=
"SEC74" HREF=
"gettext_toc.html#TOC74">7.2 Invoking the
<CODE>msgconv
</CODE> Program
</A></H2>
387 <A NAME=
"IDX537"></A>
388 <A NAME=
"IDX538"></A>
391 msgconv [
<VAR>option
</VAR>] [
<VAR>inputfile
</VAR>]
395 <A NAME=
"IDX539"></A>
396 The
<CODE>msgconv
</CODE> program converts a translation catalog to a different
402 <H3><A NAME=
"SEC75" HREF=
"gettext_toc.html#TOC75">7.2.1 Input file location
</A></H3>
406 <DT><SAMP>`
<VAR>inputfile
</VAR>´</SAMP>
410 <DT><SAMP>`-D
<VAR>directory
</VAR>´</SAMP>
412 <DT><SAMP>`--directory=
<VAR>directory
</VAR>´</SAMP>
414 <A NAME=
"IDX540"></A>
415 <A NAME=
"IDX541"></A>
416 Add
<VAR>directory
</VAR> to the list of directories. Source files are
417 searched relative to this list of directories. The resulting
<TT>`.po
´</TT>
418 file will be written relative to the current directory, though.
423 If no
<VAR>inputfile
</VAR> is given or if it is
<SAMP>`-
´</SAMP>, standard input is read.
428 <H3><A NAME=
"SEC76" HREF=
"gettext_toc.html#TOC76">7.2.2 Output file location
</A></H3>
432 <DT><SAMP>`-o
<VAR>file
</VAR>´</SAMP>
434 <DT><SAMP>`--output-file=
<VAR>file
</VAR>´</SAMP>
436 <A NAME=
"IDX542"></A>
437 <A NAME=
"IDX543"></A>
438 Write output to specified file.
443 The results are written to standard output if no output file is specified
444 or if it is
<SAMP>`-
´</SAMP>.
449 <H3><A NAME=
"SEC77" HREF=
"gettext_toc.html#TOC77">7.2.3 Conversion target
</A></H3>
453 <DT><SAMP>`-t
´</SAMP>
455 <DT><SAMP>`--to-code=
<VAR>name
</VAR>´</SAMP>
457 <A NAME=
"IDX544"></A>
458 <A NAME=
"IDX545"></A>
459 Specify encoding for output.
464 The default encoding is the current locale's encoding.
469 <H3><A NAME=
"SEC78" HREF=
"gettext_toc.html#TOC78">7.2.4 Input file syntax
</A></H3>
473 <DT><SAMP>`-P
´</SAMP>
475 <DT><SAMP>`--properties-input
´</SAMP>
477 <A NAME=
"IDX546"></A>
478 <A NAME=
"IDX547"></A>
479 Assume the input file is a Java ResourceBundle in Java
<CODE>.properties
</CODE>
480 syntax, not in PO file syntax.
482 <DT><SAMP>`--stringtable-input
´</SAMP>
484 <A NAME=
"IDX548"></A>
485 Assume the input file is a NeXTstep/GNUstep localized resource file in
486 <CODE>.strings
</CODE> syntax, not in PO file syntax.
492 <H3><A NAME=
"SEC79" HREF=
"gettext_toc.html#TOC79">7.2.5 Output details
</A></H3>
496 <DT><SAMP>`--force-po
´</SAMP>
498 <A NAME=
"IDX549"></A>
499 Always write an output file even if it contains no message.
501 <DT><SAMP>`-i
´</SAMP>
503 <DT><SAMP>`--indent
´</SAMP>
505 <A NAME=
"IDX550"></A>
506 <A NAME=
"IDX551"></A>
507 Write the .po file using indented style.
509 <DT><SAMP>`--no-location
´</SAMP>
511 <A NAME=
"IDX552"></A>
512 Do not write
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines.
514 <DT><SAMP>`--add-location
´</SAMP>
516 <A NAME=
"IDX553"></A>
517 Generate
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines (default).
519 <DT><SAMP>`--strict
´</SAMP>
521 <A NAME=
"IDX554"></A>
522 Write out a strict Uniforum conforming PO file. Note that this
523 Uniforum format should be avoided because it doesn't support the
526 <DT><SAMP>`-p
´</SAMP>
528 <DT><SAMP>`--properties-output
´</SAMP>
530 <A NAME=
"IDX555"></A>
531 <A NAME=
"IDX556"></A>
532 Write out a Java ResourceBundle in Java
<CODE>.properties
</CODE> syntax. Note
533 that this file format doesn't support plural forms and silently drops
536 <DT><SAMP>`--stringtable-output
´</SAMP>
538 <A NAME=
"IDX557"></A>
539 Write out a NeXTstep/GNUstep localized resource file in
<CODE>.strings
</CODE> syntax.
540 Note that this file format doesn't support plural forms.
542 <DT><SAMP>`-w
<VAR>number
</VAR>´</SAMP>
544 <DT><SAMP>`--width=
<VAR>number
</VAR>´</SAMP>
546 <A NAME=
"IDX558"></A>
547 <A NAME=
"IDX559"></A>
548 Set the output page width. Long strings in the output files will be
549 split across multiple lines in order to ensure that each line's width
550 (= number of screen columns) is less or equal to the given
<VAR>number
</VAR>.
552 <DT><SAMP>`--no-wrap
´</SAMP>
554 <A NAME=
"IDX560"></A>
555 Do not break long message lines. Message lines whose width exceeds the
556 output page width will not be split into several lines. Only file reference
557 lines which are wider than the output page width will be split.
559 <DT><SAMP>`-s
´</SAMP>
561 <DT><SAMP>`--sort-output
´</SAMP>
563 <A NAME=
"IDX561"></A>
564 <A NAME=
"IDX562"></A>
565 Generate sorted output. Note that using this option makes it much harder
566 for the translator to understand each message's context.
568 <DT><SAMP>`-F
´</SAMP>
570 <DT><SAMP>`--sort-by-file
´</SAMP>
572 <A NAME=
"IDX563"></A>
573 <A NAME=
"IDX564"></A>
574 Sort output by file location.
580 <H3><A NAME=
"SEC80" HREF=
"gettext_toc.html#TOC80">7.2.6 Informative output
</A></H3>
584 <DT><SAMP>`-h
´</SAMP>
586 <DT><SAMP>`--help
´</SAMP>
588 <A NAME=
"IDX565"></A>
589 <A NAME=
"IDX566"></A>
590 Display this help and exit.
592 <DT><SAMP>`-V
´</SAMP>
594 <DT><SAMP>`--version
´</SAMP>
596 <A NAME=
"IDX567"></A>
597 <A NAME=
"IDX568"></A>
598 Output version information and exit.
604 <H2><A NAME=
"SEC81" HREF=
"gettext_toc.html#TOC81">7.3 Invoking the
<CODE>msggrep
</CODE> Program
</A></H2>
607 <A NAME=
"IDX569"></A>
608 <A NAME=
"IDX570"></A>
611 msggrep [
<VAR>option
</VAR>] [
<VAR>inputfile
</VAR>]
615 <A NAME=
"IDX571"></A>
616 The
<CODE>msggrep
</CODE> program extracts all messages of a translation catalog
617 that match a given pattern or belong to some given source files.
622 <H3><A NAME=
"SEC82" HREF=
"gettext_toc.html#TOC82">7.3.1 Input file location
</A></H3>
626 <DT><SAMP>`
<VAR>inputfile
</VAR>´</SAMP>
630 <DT><SAMP>`-D
<VAR>directory
</VAR>´</SAMP>
632 <DT><SAMP>`--directory=
<VAR>directory
</VAR>´</SAMP>
634 <A NAME=
"IDX572"></A>
635 <A NAME=
"IDX573"></A>
636 Add
<VAR>directory
</VAR> to the list of directories. Source files are
637 searched relative to this list of directories. The resulting
<TT>`.po
´</TT>
638 file will be written relative to the current directory, though.
643 If no
<VAR>inputfile
</VAR> is given or if it is
<SAMP>`-
´</SAMP>, standard input is read.
648 <H3><A NAME=
"SEC83" HREF=
"gettext_toc.html#TOC83">7.3.2 Output file location
</A></H3>
652 <DT><SAMP>`-o
<VAR>file
</VAR>´</SAMP>
654 <DT><SAMP>`--output-file=
<VAR>file
</VAR>´</SAMP>
656 <A NAME=
"IDX574"></A>
657 <A NAME=
"IDX575"></A>
658 Write output to specified file.
663 The results are written to standard output if no output file is specified
664 or if it is
<SAMP>`-
´</SAMP>.
669 <H3><A NAME=
"SEC84" HREF=
"gettext_toc.html#TOC84">7.3.3 Message selection
</A></H3>
673 [-N
<VAR>sourcefile
</VAR>]... [-M
<VAR>domainname
</VAR>]...
674 [-K
<VAR>msgid-pattern
</VAR>] [-T
<VAR>msgstr-pattern
</VAR>] [-C
<VAR>comment-pattern
</VAR>]
678 A message is selected if
681 <LI>it comes from one of the specified source files,
683 <LI>or if it comes from one of the specified domains,
685 <LI>or if
<SAMP>`-K
´</SAMP> is given and its key (msgid or msgid_plural) matches
687 <VAR>msgid-pattern
</VAR>,
688 <LI>or if
<SAMP>`-T
´</SAMP> is given and its translation (msgstr) matches
690 <VAR>msgstr-pattern
</VAR>,
691 <LI>or if
<SAMP>`-C
´</SAMP> is given and the translator's comment matches
693 <VAR>comment-pattern
</VAR>.
697 When more than one selection criterion is specified, the set of selected
698 messages is the union of the selected messages of each criterion.
702 <VAR>msgid-pattern
</VAR> or
<VAR>msgstr-pattern
</VAR> syntax:
705 [-E | -F] [-e
<VAR>pattern
</VAR> | -f
<VAR>file
</VAR>]...
709 <VAR>pattern
</VAR>s are basic regular expressions by default, or extended regular
710 expressions if -E is given, or fixed strings if -F is given.
715 <DT><SAMP>`-N
<VAR>sourcefile
</VAR>´</SAMP>
717 <DT><SAMP>`--location=
<VAR>sourcefile
</VAR>´</SAMP>
719 <A NAME=
"IDX576"></A>
720 <A NAME=
"IDX577"></A>
721 Select messages extracted from
<VAR>sourcefile
</VAR>.
<VAR>sourcefile
</VAR> can be
722 either a literal file name or a wildcard pattern.
724 <DT><SAMP>`-M
<VAR>domainname
</VAR>´</SAMP>
726 <DT><SAMP>`--domain=
<VAR>domainname
</VAR>´</SAMP>
728 <A NAME=
"IDX578"></A>
729 <A NAME=
"IDX579"></A>
730 Select messages belonging to domain
<VAR>domainname
</VAR>.
732 <DT><SAMP>`-K
´</SAMP>
734 <DT><SAMP>`--msgid
´</SAMP>
736 <A NAME=
"IDX580"></A>
737 <A NAME=
"IDX581"></A>
738 Start of patterns for the msgid.
740 <DT><SAMP>`-T
´</SAMP>
742 <DT><SAMP>`--msgstr
´</SAMP>
744 <A NAME=
"IDX582"></A>
745 <A NAME=
"IDX583"></A>
746 Start of patterns for the msgstr.
748 <DT><SAMP>`-C
´</SAMP>
750 <DT><SAMP>`--comment
´</SAMP>
752 <A NAME=
"IDX584"></A>
753 <A NAME=
"IDX585"></A>
754 Start of patterns for the translator's comment.
756 <DT><SAMP>`-E
´</SAMP>
758 <DT><SAMP>`--extended-regexp
´</SAMP>
760 <A NAME=
"IDX586"></A>
761 <A NAME=
"IDX587"></A>
762 Specify that
<VAR>pattern
</VAR> is an extended regular expression.
764 <DT><SAMP>`-F
´</SAMP>
766 <DT><SAMP>`--fixed-strings
´</SAMP>
768 <A NAME=
"IDX588"></A>
769 <A NAME=
"IDX589"></A>
770 Specify that
<VAR>pattern
</VAR> is a set of newline-separated strings.
772 <DT><SAMP>`-e
<VAR>pattern
</VAR>´</SAMP>
774 <DT><SAMP>`--regexp=
<VAR>pattern
</VAR>´</SAMP>
776 <A NAME=
"IDX590"></A>
777 <A NAME=
"IDX591"></A>
778 Use
<VAR>pattern
</VAR> as a regular expression.
780 <DT><SAMP>`-f
<VAR>file
</VAR>´</SAMP>
782 <DT><SAMP>`--file=
<VAR>file
</VAR>´</SAMP>
784 <A NAME=
"IDX592"></A>
785 <A NAME=
"IDX593"></A>
786 Obtain
<VAR>pattern
</VAR> from
<VAR>file
</VAR>.
788 <DT><SAMP>`-i
´</SAMP>
790 <DT><SAMP>`--ignore-case
´</SAMP>
792 <A NAME=
"IDX594"></A>
793 <A NAME=
"IDX595"></A>
794 Ignore case distinctions.
800 <H3><A NAME=
"SEC85" HREF=
"gettext_toc.html#TOC85">7.3.4 Input file syntax
</A></H3>
804 <DT><SAMP>`-P
´</SAMP>
806 <DT><SAMP>`--properties-input
´</SAMP>
808 <A NAME=
"IDX596"></A>
809 <A NAME=
"IDX597"></A>
810 Assume the input file is a Java ResourceBundle in Java
<CODE>.properties
</CODE>
811 syntax, not in PO file syntax.
813 <DT><SAMP>`--stringtable-input
´</SAMP>
815 <A NAME=
"IDX598"></A>
816 Assume the input file is a NeXTstep/GNUstep localized resource file in
817 <CODE>.strings
</CODE> syntax, not in PO file syntax.
823 <H3><A NAME=
"SEC86" HREF=
"gettext_toc.html#TOC86">7.3.5 Output details
</A></H3>
827 <DT><SAMP>`--force-po
´</SAMP>
829 <A NAME=
"IDX599"></A>
830 Always write an output file even if it contains no message.
832 <DT><SAMP>`--indent
´</SAMP>
834 <A NAME=
"IDX600"></A>
835 Write the .po file using indented style.
837 <DT><SAMP>`--no-location
´</SAMP>
839 <A NAME=
"IDX601"></A>
840 Do not write
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines.
842 <DT><SAMP>`--add-location
´</SAMP>
844 <A NAME=
"IDX602"></A>
845 Generate
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines (default).
847 <DT><SAMP>`--strict
´</SAMP>
849 <A NAME=
"IDX603"></A>
850 Write out a strict Uniforum conforming PO file. Note that this
851 Uniforum format should be avoided because it doesn't support the
854 <DT><SAMP>`-p
´</SAMP>
856 <DT><SAMP>`--properties-output
´</SAMP>
858 <A NAME=
"IDX604"></A>
859 <A NAME=
"IDX605"></A>
860 Write out a Java ResourceBundle in Java
<CODE>.properties
</CODE> syntax. Note
861 that this file format doesn't support plural forms and silently drops
864 <DT><SAMP>`--stringtable-output
´</SAMP>
866 <A NAME=
"IDX606"></A>
867 Write out a NeXTstep/GNUstep localized resource file in
<CODE>.strings
</CODE> syntax.
868 Note that this file format doesn't support plural forms.
870 <DT><SAMP>`-w
<VAR>number
</VAR>´</SAMP>
872 <DT><SAMP>`--width=
<VAR>number
</VAR>´</SAMP>
874 <A NAME=
"IDX607"></A>
875 <A NAME=
"IDX608"></A>
876 Set the output page width. Long strings in the output files will be
877 split across multiple lines in order to ensure that each line's width
878 (= number of screen columns) is less or equal to the given
<VAR>number
</VAR>.
880 <DT><SAMP>`--no-wrap
´</SAMP>
882 <A NAME=
"IDX609"></A>
883 Do not break long message lines. Message lines whose width exceeds the
884 output page width will not be split into several lines. Only file reference
885 lines which are wider than the output page width will be split.
887 <DT><SAMP>`--sort-output
´</SAMP>
889 <A NAME=
"IDX610"></A>
890 Generate sorted output. Note that using this option makes it much harder
891 for the translator to understand each message's context.
893 <DT><SAMP>`--sort-by-file
´</SAMP>
895 <A NAME=
"IDX611"></A>
896 Sort output by file location.
902 <H3><A NAME=
"SEC87" HREF=
"gettext_toc.html#TOC87">7.3.6 Informative output
</A></H3>
906 <DT><SAMP>`-h
´</SAMP>
908 <DT><SAMP>`--help
´</SAMP>
910 <A NAME=
"IDX612"></A>
911 <A NAME=
"IDX613"></A>
912 Display this help and exit.
914 <DT><SAMP>`-V
´</SAMP>
916 <DT><SAMP>`--version
´</SAMP>
918 <A NAME=
"IDX614"></A>
919 <A NAME=
"IDX615"></A>
920 Output version information and exit.
926 <H2><A NAME=
"SEC88" HREF=
"gettext_toc.html#TOC88">7.4 Invoking the
<CODE>msgfilter
</CODE> Program
</A></H2>
929 <A NAME=
"IDX616"></A>
930 <A NAME=
"IDX617"></A>
933 msgfilter [
<VAR>option
</VAR>]
<VAR>filter
</VAR> [
<VAR>filter-option
</VAR>]
937 <A NAME=
"IDX618"></A>
938 The
<CODE>msgfilter
</CODE> program applies a filter to all translations of a
944 <H3><A NAME=
"SEC89" HREF=
"gettext_toc.html#TOC89">7.4.1 Input file location
</A></H3>
948 <DT><SAMP>`-i
<VAR>inputfile
</VAR>´</SAMP>
950 <DT><SAMP>`--input=
<VAR>inputfile
</VAR>´</SAMP>
952 <A NAME=
"IDX619"></A>
953 <A NAME=
"IDX620"></A>
956 <DT><SAMP>`-D
<VAR>directory
</VAR>´</SAMP>
958 <DT><SAMP>`--directory=
<VAR>directory
</VAR>´</SAMP>
960 <A NAME=
"IDX621"></A>
961 <A NAME=
"IDX622"></A>
962 Add
<VAR>directory
</VAR> to the list of directories. Source files are
963 searched relative to this list of directories. The resulting
<TT>`.po
´</TT>
964 file will be written relative to the current directory, though.
969 If no
<VAR>inputfile
</VAR> is given or if it is
<SAMP>`-
´</SAMP>, standard input is read.
974 <H3><A NAME=
"SEC90" HREF=
"gettext_toc.html#TOC90">7.4.2 Output file location
</A></H3>
978 <DT><SAMP>`-o
<VAR>file
</VAR>´</SAMP>
980 <DT><SAMP>`--output-file=
<VAR>file
</VAR>´</SAMP>
982 <A NAME=
"IDX623"></A>
983 <A NAME=
"IDX624"></A>
984 Write output to specified file.
989 The results are written to standard output if no output file is specified
990 or if it is
<SAMP>`-
´</SAMP>.
995 <H3><A NAME=
"SEC91" HREF=
"gettext_toc.html#TOC91">7.4.3 The filter
</A></H3>
998 The
<VAR>filter
</VAR> can be any program that reads a translation from standard
999 input and writes a modified translation to standard output. A frequently
1000 used filter is
<SAMP>`sed
´</SAMP>.
1004 <A NAME=
"IDX625"></A>
1005 Note: It is your responsibility to ensure that the
<VAR>filter
</VAR> can cope
1006 with input encoded in the translation catalog's encoding. If the
1007 <VAR>filter
</VAR> wants input in a particular encoding, you can in a first step
1008 convert the translation catalog to that encoding using the
<SAMP>`msgconv
´</SAMP>
1009 program, before invoking
<SAMP>`msgfilter
´</SAMP>. If the
<VAR>filter
</VAR> wants input
1010 in the locale's encoding, but you want to avoid the locale's encoding, then
1011 you can first convert the translation catalog to UTF-
8 using the
1012 <SAMP>`msgconv
´</SAMP> program and then make
<SAMP>`msgfilter
´</SAMP> work in an UTF-
8
1013 locale, by using the
<CODE>LC_ALL
</CODE> environment variable.
1017 <A NAME=
"IDX626"></A>
1018 Note: Most translations in a translation catalog don't end with a newline
1019 character. For this reason, it is important that the
<VAR>filter
</VAR>
1020 recognizes its last input line even if it ends without a newline, and that
1021 it doesn't add an undesired trailing newline at the end. The
<SAMP>`sed
´</SAMP>
1022 program on some platforms is known to ignore the last line of input if it
1023 is not terminated with a newline. You can use GNU
<CODE>sed
</CODE> instead; it
1024 does not have this limitation.
1029 <H3><A NAME=
"SEC92" HREF=
"gettext_toc.html#TOC92">7.4.4 Useful
<VAR>filter-option
</VAR>s when the
<VAR>filter
</VAR> is
<SAMP>`sed
´</SAMP></A></H3>
1033 <DT><SAMP>`-e
<VAR>script
</VAR>´</SAMP>
1035 <DT><SAMP>`--expression=
<VAR>script
</VAR>´</SAMP>
1037 <A NAME=
"IDX627"></A>
1038 <A NAME=
"IDX628"></A>
1039 Add
<VAR>script
</VAR> to the commands to be executed.
1041 <DT><SAMP>`-f
<VAR>scriptfile
</VAR>´</SAMP>
1043 <DT><SAMP>`--file=
<VAR>scriptfile
</VAR>´</SAMP>
1045 <A NAME=
"IDX629"></A>
1046 <A NAME=
"IDX630"></A>
1047 Add the contents of
<VAR>scriptfile
</VAR> to the commands to be executed.
1049 <DT><SAMP>`-n
´</SAMP>
1051 <DT><SAMP>`--quiet
´</SAMP>
1053 <DT><SAMP>`--silent
´</SAMP>
1055 <A NAME=
"IDX631"></A>
1056 <A NAME=
"IDX632"></A>
1057 <A NAME=
"IDX633"></A>
1058 Suppress automatic printing of pattern space.
1064 <H3><A NAME=
"SEC93" HREF=
"gettext_toc.html#TOC93">7.4.5 Input file syntax
</A></H3>
1068 <DT><SAMP>`-P
´</SAMP>
1070 <DT><SAMP>`--properties-input
´</SAMP>
1072 <A NAME=
"IDX634"></A>
1073 <A NAME=
"IDX635"></A>
1074 Assume the input file is a Java ResourceBundle in Java
<CODE>.properties
</CODE>
1075 syntax, not in PO file syntax.
1077 <DT><SAMP>`--stringtable-input
´</SAMP>
1079 <A NAME=
"IDX636"></A>
1080 Assume the input file is a NeXTstep/GNUstep localized resource file in
1081 <CODE>.strings
</CODE> syntax, not in PO file syntax.
1087 <H3><A NAME=
"SEC94" HREF=
"gettext_toc.html#TOC94">7.4.6 Output details
</A></H3>
1091 <DT><SAMP>`--force-po
´</SAMP>
1093 <A NAME=
"IDX637"></A>
1094 Always write an output file even if it contains no message.
1096 <DT><SAMP>`--indent
´</SAMP>
1098 <A NAME=
"IDX638"></A>
1099 Write the .po file using indented style.
1101 <DT><SAMP>`--keep-header
´</SAMP>
1103 <A NAME=
"IDX639"></A>
1104 Keep the header entry, i.e. the message with
<SAMP>`msgid
""´</SAMP>, unmodified,
1105 instead of filtering it. By default, the header entry is subject to
1106 filtering like any other message.
1108 <DT><SAMP>`--no-location
´</SAMP>
1110 <A NAME=
"IDX640"></A>
1111 Do not write
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines.
1113 <DT><SAMP>`--add-location
´</SAMP>
1115 <A NAME=
"IDX641"></A>
1116 Generate
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines (default).
1118 <DT><SAMP>`--strict
´</SAMP>
1120 <A NAME=
"IDX642"></A>
1121 Write out a strict Uniforum conforming PO file. Note that this
1122 Uniforum format should be avoided because it doesn't support the
1125 <DT><SAMP>`-p
´</SAMP>
1127 <DT><SAMP>`--properties-output
´</SAMP>
1129 <A NAME=
"IDX643"></A>
1130 <A NAME=
"IDX644"></A>
1131 Write out a Java ResourceBundle in Java
<CODE>.properties
</CODE> syntax. Note
1132 that this file format doesn't support plural forms and silently drops
1135 <DT><SAMP>`--stringtable-output
´</SAMP>
1137 <A NAME=
"IDX645"></A>
1138 Write out a NeXTstep/GNUstep localized resource file in
<CODE>.strings
</CODE> syntax.
1139 Note that this file format doesn't support plural forms.
1141 <DT><SAMP>`-w
<VAR>number
</VAR>´</SAMP>
1143 <DT><SAMP>`--width=
<VAR>number
</VAR>´</SAMP>
1145 <A NAME=
"IDX646"></A>
1146 <A NAME=
"IDX647"></A>
1147 Set the output page width. Long strings in the output files will be
1148 split across multiple lines in order to ensure that each line's width
1149 (= number of screen columns) is less or equal to the given
<VAR>number
</VAR>.
1151 <DT><SAMP>`--no-wrap
´</SAMP>
1153 <A NAME=
"IDX648"></A>
1154 Do not break long message lines. Message lines whose width exceeds the
1155 output page width will not be split into several lines. Only file reference
1156 lines which are wider than the output page width will be split.
1158 <DT><SAMP>`-s
´</SAMP>
1160 <DT><SAMP>`--sort-output
´</SAMP>
1162 <A NAME=
"IDX649"></A>
1163 <A NAME=
"IDX650"></A>
1164 Generate sorted output. Note that using this option makes it much harder
1165 for the translator to understand each message's context.
1167 <DT><SAMP>`-F
´</SAMP>
1169 <DT><SAMP>`--sort-by-file
´</SAMP>
1171 <A NAME=
"IDX651"></A>
1172 <A NAME=
"IDX652"></A>
1173 Sort output by file location.
1179 <H3><A NAME=
"SEC95" HREF=
"gettext_toc.html#TOC95">7.4.7 Informative output
</A></H3>
1183 <DT><SAMP>`-h
´</SAMP>
1185 <DT><SAMP>`--help
´</SAMP>
1187 <A NAME=
"IDX653"></A>
1188 <A NAME=
"IDX654"></A>
1189 Display this help and exit.
1191 <DT><SAMP>`-V
´</SAMP>
1193 <DT><SAMP>`--version
´</SAMP>
1195 <A NAME=
"IDX655"></A>
1196 <A NAME=
"IDX656"></A>
1197 Output version information and exit.
1203 <H2><A NAME=
"SEC96" HREF=
"gettext_toc.html#TOC96">7.5 Invoking the
<CODE>msguniq
</CODE> Program
</A></H2>
1206 <A NAME=
"IDX657"></A>
1207 <A NAME=
"IDX658"></A>
1210 msguniq [
<VAR>option
</VAR>] [
<VAR>inputfile
</VAR>]
1214 <A NAME=
"IDX659"></A>
1215 <A NAME=
"IDX660"></A>
1216 The
<CODE>msguniq
</CODE> program unifies duplicate translations in a translation
1217 catalog. It finds duplicate translations of the same message ID. Such
1218 duplicates are invalid input for other programs like
<CODE>msgfmt
</CODE>,
1219 <CODE>msgmerge
</CODE> or
<CODE>msgcat
</CODE>. By default, duplicates are merged
1220 together. When using the
<SAMP>`--repeated
´</SAMP> option, only duplicates are
1221 output, and all other messages are discarded. Comments and extracted
1222 comments will be cumulated, except that if
<SAMP>`--use-first
´</SAMP> is
1223 specified, they will be taken from the first translation. File positions
1224 will be cumulated. When using the
<SAMP>`--unique
´</SAMP> option, duplicates are
1230 <H3><A NAME=
"SEC97" HREF=
"gettext_toc.html#TOC97">7.5.1 Input file location
</A></H3>
1234 <DT><SAMP>`
<VAR>inputfile
</VAR>´</SAMP>
1238 <DT><SAMP>`-D
<VAR>directory
</VAR>´</SAMP>
1240 <DT><SAMP>`--directory=
<VAR>directory
</VAR>´</SAMP>
1242 <A NAME=
"IDX661"></A>
1243 <A NAME=
"IDX662"></A>
1244 Add
<VAR>directory
</VAR> to the list of directories. Source files are
1245 searched relative to this list of directories. The resulting
<TT>`.po
´</TT>
1246 file will be written relative to the current directory, though.
1251 If no
<VAR>inputfile
</VAR> is given or if it is
<SAMP>`-
´</SAMP>, standard input is read.
1256 <H3><A NAME=
"SEC98" HREF=
"gettext_toc.html#TOC98">7.5.2 Output file location
</A></H3>
1260 <DT><SAMP>`-o
<VAR>file
</VAR>´</SAMP>
1262 <DT><SAMP>`--output-file=
<VAR>file
</VAR>´</SAMP>
1264 <A NAME=
"IDX663"></A>
1265 <A NAME=
"IDX664"></A>
1266 Write output to specified file.
1271 The results are written to standard output if no output file is specified
1272 or if it is
<SAMP>`-
´</SAMP>.
1277 <H3><A NAME=
"SEC99" HREF=
"gettext_toc.html#TOC99">7.5.3 Message selection
</A></H3>
1281 <DT><SAMP>`-d
´</SAMP>
1283 <DT><SAMP>`--repeated
´</SAMP>
1285 <A NAME=
"IDX665"></A>
1286 <A NAME=
"IDX666"></A>
1287 Print only duplicates.
1289 <DT><SAMP>`-u
´</SAMP>
1291 <DT><SAMP>`--unique
´</SAMP>
1293 <A NAME=
"IDX667"></A>
1294 <A NAME=
"IDX668"></A>
1295 Print only unique messages, discard duplicates.
1301 <H3><A NAME=
"SEC100" HREF=
"gettext_toc.html#TOC100">7.5.4 Input file syntax
</A></H3>
1305 <DT><SAMP>`-P
´</SAMP>
1307 <DT><SAMP>`--properties-input
´</SAMP>
1309 <A NAME=
"IDX669"></A>
1310 <A NAME=
"IDX670"></A>
1311 Assume the input file is a Java ResourceBundle in Java
<CODE>.properties
</CODE>
1312 syntax, not in PO file syntax.
1314 <DT><SAMP>`--stringtable-input
´</SAMP>
1316 <A NAME=
"IDX671"></A>
1317 Assume the input file is a NeXTstep/GNUstep localized resource file in
1318 <CODE>.strings
</CODE> syntax, not in PO file syntax.
1324 <H3><A NAME=
"SEC101" HREF=
"gettext_toc.html#TOC101">7.5.5 Output details
</A></H3>
1328 <DT><SAMP>`-t
´</SAMP>
1330 <DT><SAMP>`--to-code=
<VAR>name
</VAR>´</SAMP>
1332 <A NAME=
"IDX672"></A>
1333 <A NAME=
"IDX673"></A>
1334 Specify encoding for output.
1336 <DT><SAMP>`--use-first
´</SAMP>
1338 <A NAME=
"IDX674"></A>
1339 Use first available translation for each message. Don't merge several
1340 translations into one.
1342 <DT><SAMP>`--force-po
´</SAMP>
1344 <A NAME=
"IDX675"></A>
1345 Always write an output file even if it contains no message.
1347 <DT><SAMP>`-i
´</SAMP>
1349 <DT><SAMP>`--indent
´</SAMP>
1351 <A NAME=
"IDX676"></A>
1352 <A NAME=
"IDX677"></A>
1353 Write the .po file using indented style.
1355 <DT><SAMP>`--no-location
´</SAMP>
1357 <A NAME=
"IDX678"></A>
1358 Do not write
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines.
1360 <DT><SAMP>`-n
´</SAMP>
1362 <DT><SAMP>`--add-location
´</SAMP>
1364 <A NAME=
"IDX679"></A>
1365 <A NAME=
"IDX680"></A>
1366 Generate
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines (default).
1368 <DT><SAMP>`--strict
´</SAMP>
1370 <A NAME=
"IDX681"></A>
1371 Write out a strict Uniforum conforming PO file. Note that this
1372 Uniforum format should be avoided because it doesn't support the
1375 <DT><SAMP>`-p
´</SAMP>
1377 <DT><SAMP>`--properties-output
´</SAMP>
1379 <A NAME=
"IDX682"></A>
1380 <A NAME=
"IDX683"></A>
1381 Write out a Java ResourceBundle in Java
<CODE>.properties
</CODE> syntax. Note
1382 that this file format doesn't support plural forms and silently drops
1385 <DT><SAMP>`--stringtable-output
´</SAMP>
1387 <A NAME=
"IDX684"></A>
1388 Write out a NeXTstep/GNUstep localized resource file in
<CODE>.strings
</CODE> syntax.
1389 Note that this file format doesn't support plural forms.
1391 <DT><SAMP>`-w
<VAR>number
</VAR>´</SAMP>
1393 <DT><SAMP>`--width=
<VAR>number
</VAR>´</SAMP>
1395 <A NAME=
"IDX685"></A>
1396 <A NAME=
"IDX686"></A>
1397 Set the output page width. Long strings in the output files will be
1398 split across multiple lines in order to ensure that each line's width
1399 (= number of screen columns) is less or equal to the given
<VAR>number
</VAR>.
1401 <DT><SAMP>`--no-wrap
´</SAMP>
1403 <A NAME=
"IDX687"></A>
1404 Do not break long message lines. Message lines whose width exceeds the
1405 output page width will not be split into several lines. Only file reference
1406 lines which are wider than the output page width will be split.
1408 <DT><SAMP>`-s
´</SAMP>
1410 <DT><SAMP>`--sort-output
´</SAMP>
1412 <A NAME=
"IDX688"></A>
1413 <A NAME=
"IDX689"></A>
1414 Generate sorted output. Note that using this option makes it much harder
1415 for the translator to understand each message's context.
1417 <DT><SAMP>`-F
´</SAMP>
1419 <DT><SAMP>`--sort-by-file
´</SAMP>
1421 <A NAME=
"IDX690"></A>
1422 <A NAME=
"IDX691"></A>
1423 Sort output by file location.
1429 <H3><A NAME=
"SEC102" HREF=
"gettext_toc.html#TOC102">7.5.6 Informative output
</A></H3>
1433 <DT><SAMP>`-h
´</SAMP>
1435 <DT><SAMP>`--help
´</SAMP>
1437 <A NAME=
"IDX692"></A>
1438 <A NAME=
"IDX693"></A>
1439 Display this help and exit.
1441 <DT><SAMP>`-V
´</SAMP>
1443 <DT><SAMP>`--version
´</SAMP>
1445 <A NAME=
"IDX694"></A>
1446 <A NAME=
"IDX695"></A>
1447 Output version information and exit.
1453 <H2><A NAME=
"SEC103" HREF=
"gettext_toc.html#TOC103">7.6 Invoking the
<CODE>msgcomm
</CODE> Program
</A></H2>
1456 <A NAME=
"IDX696"></A>
1457 <A NAME=
"IDX697"></A>
1460 msgcomm [
<VAR>option
</VAR>] [
<VAR>inputfile
</VAR>]...
1464 <A NAME=
"IDX698"></A>
1465 The
<CODE>msgcomm
</CODE> program finds messages which are common to two or more
1466 of the specified PO files.
1467 By using the
<CODE>--more-than
</CODE> option, greater commonality may be requested
1468 before messages are printed. Conversely, the
<CODE>--less-than
</CODE> option may be
1469 used to specify less commonality before messages are printed (i.e.
1470 <SAMP>`--less-than=
2´</SAMP> will only print the unique messages). Translations,
1471 comments and extract comments will be preserved, but only from the first
1472 PO file to define them. File positions from all PO files will be
1478 <H3><A NAME=
"SEC104" HREF=
"gettext_toc.html#TOC104">7.6.1 Input file location
</A></H3>
1482 <DT><SAMP>`
<VAR>inputfile
</VAR> ...
´</SAMP>
1486 <DT><SAMP>`-f
<VAR>file
</VAR>´</SAMP>
1488 <DT><SAMP>`--files-from=
<VAR>file
</VAR>´</SAMP>
1490 <A NAME=
"IDX699"></A>
1491 <A NAME=
"IDX700"></A>
1492 Read the names of the input files from
<VAR>file
</VAR> instead of getting
1493 them from the command line.
1495 <DT><SAMP>`-D
<VAR>directory
</VAR>´</SAMP>
1497 <DT><SAMP>`--directory=
<VAR>directory
</VAR>´</SAMP>
1499 <A NAME=
"IDX701"></A>
1500 <A NAME=
"IDX702"></A>
1501 Add
<VAR>directory
</VAR> to the list of directories. Source files are
1502 searched relative to this list of directories. The resulting
<TT>`.po
´</TT>
1503 file will be written relative to the current directory, though.
1508 If
<VAR>inputfile
</VAR> is
<SAMP>`-
´</SAMP>, standard input is read.
1513 <H3><A NAME=
"SEC105" HREF=
"gettext_toc.html#TOC105">7.6.2 Output file location
</A></H3>
1517 <DT><SAMP>`-o
<VAR>file
</VAR>´</SAMP>
1519 <DT><SAMP>`--output-file=
<VAR>file
</VAR>´</SAMP>
1521 <A NAME=
"IDX703"></A>
1522 <A NAME=
"IDX704"></A>
1523 Write output to specified file.
1528 The results are written to standard output if no output file is specified
1529 or if it is
<SAMP>`-
´</SAMP>.
1534 <H3><A NAME=
"SEC106" HREF=
"gettext_toc.html#TOC106">7.6.3 Message selection
</A></H3>
1538 <DT><SAMP>`-
< <VAR>number
</VAR>´</SAMP>
1540 <DT><SAMP>`--less-than=
<VAR>number
</VAR>´</SAMP>
1542 <A NAME=
"IDX705"></A>
1543 <A NAME=
"IDX706"></A>
1544 Print messages with less than
<VAR>number
</VAR> definitions, defaults to infinite
1547 <DT><SAMP>`-
> <VAR>number
</VAR>´</SAMP>
1549 <DT><SAMP>`--more-than=
<VAR>number
</VAR>´</SAMP>
1551 <A NAME=
"IDX707"></A>
1552 <A NAME=
"IDX708"></A>
1553 Print messages with more than
<VAR>number
</VAR> definitions, defaults to
1 if not
1556 <DT><SAMP>`-u
´</SAMP>
1558 <DT><SAMP>`--unique
´</SAMP>
1560 <A NAME=
"IDX709"></A>
1561 <A NAME=
"IDX710"></A>
1562 Shorthand for
<SAMP>`--less-than=
2´</SAMP>. Requests that only unique messages be
1569 <H3><A NAME=
"SEC107" HREF=
"gettext_toc.html#TOC107">7.6.4 Input file syntax
</A></H3>
1573 <DT><SAMP>`-P
´</SAMP>
1575 <DT><SAMP>`--properties-input
´</SAMP>
1577 <A NAME=
"IDX711"></A>
1578 <A NAME=
"IDX712"></A>
1579 Assume the input files are Java ResourceBundles in Java
<CODE>.properties
</CODE>
1580 syntax, not in PO file syntax.
1582 <DT><SAMP>`--stringtable-input
´</SAMP>
1584 <A NAME=
"IDX713"></A>
1585 Assume the input files are NeXTstep/GNUstep localized resource files in
1586 <CODE>.strings
</CODE> syntax, not in PO file syntax.
1592 <H3><A NAME=
"SEC108" HREF=
"gettext_toc.html#TOC108">7.6.5 Output details
</A></H3>
1596 <DT><SAMP>`--force-po
´</SAMP>
1598 <A NAME=
"IDX714"></A>
1599 Always write an output file even if it contains no message.
1601 <DT><SAMP>`-i
´</SAMP>
1603 <DT><SAMP>`--indent
´</SAMP>
1605 <A NAME=
"IDX715"></A>
1606 <A NAME=
"IDX716"></A>
1607 Write the .po file using indented style.
1609 <DT><SAMP>`--no-location
´</SAMP>
1611 <A NAME=
"IDX717"></A>
1612 Do not write
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines.
1614 <DT><SAMP>`-n
´</SAMP>
1616 <DT><SAMP>`--add-location
´</SAMP>
1618 <A NAME=
"IDX718"></A>
1619 <A NAME=
"IDX719"></A>
1620 Generate
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines (default).
1622 <DT><SAMP>`--strict
´</SAMP>
1624 <A NAME=
"IDX720"></A>
1625 Write out a strict Uniforum conforming PO file. Note that this
1626 Uniforum format should be avoided because it doesn't support the
1629 <DT><SAMP>`-p
´</SAMP>
1631 <DT><SAMP>`--properties-output
´</SAMP>
1633 <A NAME=
"IDX721"></A>
1634 <A NAME=
"IDX722"></A>
1635 Write out a Java ResourceBundle in Java
<CODE>.properties
</CODE> syntax. Note
1636 that this file format doesn't support plural forms and silently drops
1639 <DT><SAMP>`--stringtable-output
´</SAMP>
1641 <A NAME=
"IDX723"></A>
1642 Write out a NeXTstep/GNUstep localized resource file in
<CODE>.strings
</CODE> syntax.
1643 Note that this file format doesn't support plural forms.
1645 <DT><SAMP>`-w
<VAR>number
</VAR>´</SAMP>
1647 <DT><SAMP>`--width=
<VAR>number
</VAR>´</SAMP>
1649 <A NAME=
"IDX724"></A>
1650 <A NAME=
"IDX725"></A>
1651 Set the output page width. Long strings in the output files will be
1652 split across multiple lines in order to ensure that each line's width
1653 (= number of screen columns) is less or equal to the given
<VAR>number
</VAR>.
1655 <DT><SAMP>`--no-wrap
´</SAMP>
1657 <A NAME=
"IDX726"></A>
1658 Do not break long message lines. Message lines whose width exceeds the
1659 output page width will not be split into several lines. Only file reference
1660 lines which are wider than the output page width will be split.
1662 <DT><SAMP>`-s
´</SAMP>
1664 <DT><SAMP>`--sort-output
´</SAMP>
1666 <A NAME=
"IDX727"></A>
1667 <A NAME=
"IDX728"></A>
1668 Generate sorted output. Note that using this option makes it much harder
1669 for the translator to understand each message's context.
1671 <DT><SAMP>`-F
´</SAMP>
1673 <DT><SAMP>`--sort-by-file
´</SAMP>
1675 <A NAME=
"IDX729"></A>
1676 <A NAME=
"IDX730"></A>
1677 Sort output by file location.
1679 <DT><SAMP>`--omit-header
´</SAMP>
1681 <A NAME=
"IDX731"></A>
1682 Don't write header with
<SAMP>`msgid
""´</SAMP> entry.
1688 <H3><A NAME=
"SEC109" HREF=
"gettext_toc.html#TOC109">7.6.6 Informative output
</A></H3>
1692 <DT><SAMP>`-h
´</SAMP>
1694 <DT><SAMP>`--help
´</SAMP>
1696 <A NAME=
"IDX732"></A>
1697 <A NAME=
"IDX733"></A>
1698 Display this help and exit.
1700 <DT><SAMP>`-V
´</SAMP>
1702 <DT><SAMP>`--version
´</SAMP>
1704 <A NAME=
"IDX734"></A>
1705 <A NAME=
"IDX735"></A>
1706 Output version information and exit.
1712 <H2><A NAME=
"SEC110" HREF=
"gettext_toc.html#TOC110">7.7 Invoking the
<CODE>msgcmp
</CODE> Program
</A></H2>
1715 <A NAME=
"IDX736"></A>
1716 <A NAME=
"IDX737"></A>
1719 msgcmp [
<VAR>option
</VAR>]
<VAR>def
</VAR>.po
<VAR>ref
</VAR>.pot
1723 <A NAME=
"IDX738"></A>
1724 The
<CODE>msgcmp
</CODE> program compares two Uniforum style .po files to check that
1725 both contain the same set of msgid strings. The
<VAR>def
</VAR>.po file is an
1726 existing PO file with the translations. The
<VAR>ref
</VAR>.pot file is the last
1727 created PO file, or a PO Template file (generally created by
<CODE>xgettext
</CODE>).
1728 This is useful for checking that you have translated each and every message
1729 in your program. Where an exact match cannot be found, fuzzy matching is
1730 used to produce better diagnostics.
1735 <H3><A NAME=
"SEC111" HREF=
"gettext_toc.html#TOC111">7.7.1 Input file location
</A></H3>
1739 <DT><SAMP>`
<VAR>def
</VAR>.po
´</SAMP>
1743 <DT><SAMP>`
<VAR>ref
</VAR>.pot
´</SAMP>
1745 References to the sources.
1747 <DT><SAMP>`-D
<VAR>directory
</VAR>´</SAMP>
1749 <DT><SAMP>`--directory=
<VAR>directory
</VAR>´</SAMP>
1751 <A NAME=
"IDX739"></A>
1752 <A NAME=
"IDX740"></A>
1753 Add
<VAR>directory
</VAR> to the list of directories. Source files are
1754 searched relative to this list of directories.
1760 <H3><A NAME=
"SEC112" HREF=
"gettext_toc.html#TOC112">7.7.2 Operation modifiers
</A></H3>
1764 <DT><SAMP>`-m
´</SAMP>
1766 <DT><SAMP>`--multi-domain
´</SAMP>
1768 <A NAME=
"IDX741"></A>
1769 <A NAME=
"IDX742"></A>
1770 Apply
<VAR>ref
</VAR>.pot to each of the domains in
<VAR>def
</VAR>.po.
1776 <H3><A NAME=
"SEC113" HREF=
"gettext_toc.html#TOC113">7.7.3 Input file syntax
</A></H3>
1780 <DT><SAMP>`-P
´</SAMP>
1782 <DT><SAMP>`--properties-input
´</SAMP>
1784 <A NAME=
"IDX743"></A>
1785 <A NAME=
"IDX744"></A>
1786 Assume the input files are Java ResourceBundles in Java
<CODE>.properties
</CODE>
1787 syntax, not in PO file syntax.
1789 <DT><SAMP>`--stringtable-input
´</SAMP>
1791 <A NAME=
"IDX745"></A>
1792 Assume the input files are NeXTstep/GNUstep localized resource files in
1793 <CODE>.strings
</CODE> syntax, not in PO file syntax.
1799 <H3><A NAME=
"SEC114" HREF=
"gettext_toc.html#TOC114">7.7.4 Informative output
</A></H3>
1803 <DT><SAMP>`-h
´</SAMP>
1805 <DT><SAMP>`--help
´</SAMP>
1807 <A NAME=
"IDX746"></A>
1808 <A NAME=
"IDX747"></A>
1809 Display this help and exit.
1811 <DT><SAMP>`-V
´</SAMP>
1813 <DT><SAMP>`--version
´</SAMP>
1815 <A NAME=
"IDX748"></A>
1816 <A NAME=
"IDX749"></A>
1817 Output version information and exit.
1823 <H2><A NAME=
"SEC115" HREF=
"gettext_toc.html#TOC115">7.8 Invoking the
<CODE>msgattrib
</CODE> Program
</A></H2>
1826 <A NAME=
"IDX750"></A>
1827 <A NAME=
"IDX751"></A>
1830 msgattrib [
<VAR>option
</VAR>] [
<VAR>inputfile
</VAR>]
1834 <A NAME=
"IDX752"></A>
1835 <A NAME=
"IDX753"></A>
1836 The
<CODE>msgattrib
</CODE> program filters the messages of a translation catalog
1837 according to their attributes, and manipulates the attributes.
1842 <H3><A NAME=
"SEC116" HREF=
"gettext_toc.html#TOC116">7.8.1 Input file location
</A></H3>
1846 <DT><SAMP>`
<VAR>inputfile
</VAR>´</SAMP>
1850 <DT><SAMP>`-D
<VAR>directory
</VAR>´</SAMP>
1852 <DT><SAMP>`--directory=
<VAR>directory
</VAR>´</SAMP>
1854 <A NAME=
"IDX754"></A>
1855 <A NAME=
"IDX755"></A>
1856 Add
<VAR>directory
</VAR> to the list of directories. Source files are
1857 searched relative to this list of directories. The resulting
<TT>`.po
´</TT>
1858 file will be written relative to the current directory, though.
1863 If no
<VAR>inputfile
</VAR> is given or if it is
<SAMP>`-
´</SAMP>, standard input is read.
1868 <H3><A NAME=
"SEC117" HREF=
"gettext_toc.html#TOC117">7.8.2 Output file location
</A></H3>
1872 <DT><SAMP>`-o
<VAR>file
</VAR>´</SAMP>
1874 <DT><SAMP>`--output-file=
<VAR>file
</VAR>´</SAMP>
1876 <A NAME=
"IDX756"></A>
1877 <A NAME=
"IDX757"></A>
1878 Write output to specified file.
1883 The results are written to standard output if no output file is specified
1884 or if it is
<SAMP>`-
´</SAMP>.
1889 <H3><A NAME=
"SEC118" HREF=
"gettext_toc.html#TOC118">7.8.3 Message selection
</A></H3>
1893 <DT><SAMP>`--translated
´</SAMP>
1895 <A NAME=
"IDX758"></A>
1896 Keep translated messages, remove untranslated messages.
1898 <DT><SAMP>`--untranslated
´</SAMP>
1900 <A NAME=
"IDX759"></A>
1901 Keep untranslated messages, remove translated messages.
1903 <DT><SAMP>`--no-fuzzy
´</SAMP>
1905 <A NAME=
"IDX760"></A>
1906 Remove `fuzzy' marked messages.
1908 <DT><SAMP>`--only-fuzzy
´</SAMP>
1910 <A NAME=
"IDX761"></A>
1911 Keep `fuzzy' marked messages, remove all other messsages.
1913 <DT><SAMP>`--no-obsolete
´</SAMP>
1915 <A NAME=
"IDX762"></A>
1916 Remove obsolete #~ messages.
1918 <DT><SAMP>`--only-obsolete
´</SAMP>
1920 <A NAME=
"IDX763"></A>
1921 Keep obsolete #~ messages, remove all other messages.
1927 <H3><A NAME=
"SEC119" HREF=
"gettext_toc.html#TOC119">7.8.4 Attribute manipulation
</A></H3>
1930 <A NAME=
"IDX764"></A>
1931 Attributes are modified after the message selection/removal has been
1932 performed. If the
<SAMP>`--only-file
´</SAMP> or
<SAMP>`--ignore-file
´</SAMP> option is
1933 specified, the attribute modification is applied only to those messages
1934 that are listed in the
<VAR>only-file
</VAR> and not listed in the
1935 <VAR>ignore-file
</VAR>.
1940 <DT><SAMP>`--set-fuzzy
´</SAMP>
1942 <A NAME=
"IDX765"></A>
1943 Set all messages `fuzzy'.
1945 <DT><SAMP>`--clear-fuzzy
´</SAMP>
1947 <A NAME=
"IDX766"></A>
1948 Set all messages non-`fuzzy'.
1950 <DT><SAMP>`--set-obsolete
´</SAMP>
1952 <A NAME=
"IDX767"></A>
1953 Set all messages obsolete.
1955 <DT><SAMP>`--clear-obsolete
´</SAMP>
1957 <A NAME=
"IDX768"></A>
1958 Set all messages non-obsolete.
1960 <DT><SAMP>`--only-file=
<VAR>file
</VAR>´</SAMP>
1962 <A NAME=
"IDX769"></A>
1963 Limit the attribute changes to entries that are listed in
<VAR>file
</VAR>.
1964 <VAR>file
</VAR> should be a PO or POT file.
1966 <DT><SAMP>`--ignore-file=
<VAR>file
</VAR>´</SAMP>
1968 <A NAME=
"IDX770"></A>
1969 Limit the attribute changes to entries that are not listed in
<VAR>file
</VAR>.
1970 <VAR>file
</VAR> should be a PO or POT file.
1972 <DT><SAMP>`--fuzzy
´</SAMP>
1974 <A NAME=
"IDX771"></A>
1975 Synonym for
<SAMP>`--only-fuzzy --clear-fuzzy
´</SAMP>: It keeps only the fuzzy
1976 messages and removes their `fuzzy' mark.
1978 <DT><SAMP>`--obsolete
´</SAMP>
1980 <A NAME=
"IDX772"></A>
1981 Synonym for
<SAMP>`--only-obsolete --clear-obsolete
´</SAMP>: It keeps only the
1982 obsolete messages and makes them non-obsolete.
1988 <H3><A NAME=
"SEC120" HREF=
"gettext_toc.html#TOC120">7.8.5 Input file syntax
</A></H3>
1992 <DT><SAMP>`-P
´</SAMP>
1994 <DT><SAMP>`--properties-input
´</SAMP>
1996 <A NAME=
"IDX773"></A>
1997 <A NAME=
"IDX774"></A>
1998 Assume the input file is a Java ResourceBundle in Java
<CODE>.properties
</CODE>
1999 syntax, not in PO file syntax.
2001 <DT><SAMP>`--stringtable-input
´</SAMP>
2003 <A NAME=
"IDX775"></A>
2004 Assume the input file is a NeXTstep/GNUstep localized resource file in
2005 <CODE>.strings
</CODE> syntax, not in PO file syntax.
2011 <H3><A NAME=
"SEC121" HREF=
"gettext_toc.html#TOC121">7.8.6 Output details
</A></H3>
2015 <DT><SAMP>`--force-po
´</SAMP>
2017 <A NAME=
"IDX776"></A>
2018 Always write an output file even if it contains no message.
2020 <DT><SAMP>`-i
´</SAMP>
2022 <DT><SAMP>`--indent
´</SAMP>
2024 <A NAME=
"IDX777"></A>
2025 <A NAME=
"IDX778"></A>
2026 Write the .po file using indented style.
2028 <DT><SAMP>`--no-location
´</SAMP>
2030 <A NAME=
"IDX779"></A>
2031 Do not write
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines.
2033 <DT><SAMP>`-n
´</SAMP>
2035 <DT><SAMP>`--add-location
´</SAMP>
2037 <A NAME=
"IDX780"></A>
2038 <A NAME=
"IDX781"></A>
2039 Generate
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines (default).
2041 <DT><SAMP>`--strict
´</SAMP>
2043 <A NAME=
"IDX782"></A>
2044 Write out a strict Uniforum conforming PO file. Note that this
2045 Uniforum format should be avoided because it doesn't support the
2048 <DT><SAMP>`-p
´</SAMP>
2050 <DT><SAMP>`--properties-output
´</SAMP>
2052 <A NAME=
"IDX783"></A>
2053 <A NAME=
"IDX784"></A>
2054 Write out a Java ResourceBundle in Java
<CODE>.properties
</CODE> syntax. Note
2055 that this file format doesn't support plural forms and silently drops
2058 <DT><SAMP>`--stringtable-output
´</SAMP>
2060 <A NAME=
"IDX785"></A>
2061 Write out a NeXTstep/GNUstep localized resource file in
<CODE>.strings
</CODE> syntax.
2062 Note that this file format doesn't support plural forms.
2064 <DT><SAMP>`-w
<VAR>number
</VAR>´</SAMP>
2066 <DT><SAMP>`--width=
<VAR>number
</VAR>´</SAMP>
2068 <A NAME=
"IDX786"></A>
2069 <A NAME=
"IDX787"></A>
2070 Set the output page width. Long strings in the output files will be
2071 split across multiple lines in order to ensure that each line's width
2072 (= number of screen columns) is less or equal to the given
<VAR>number
</VAR>.
2074 <DT><SAMP>`--no-wrap
´</SAMP>
2076 <A NAME=
"IDX788"></A>
2077 Do not break long message lines. Message lines whose width exceeds the
2078 output page width will not be split into several lines. Only file reference
2079 lines which are wider than the output page width will be split.
2081 <DT><SAMP>`-s
´</SAMP>
2083 <DT><SAMP>`--sort-output
´</SAMP>
2085 <A NAME=
"IDX789"></A>
2086 <A NAME=
"IDX790"></A>
2087 Generate sorted output. Note that using this option makes it much harder
2088 for the translator to understand each message's context.
2090 <DT><SAMP>`-F
´</SAMP>
2092 <DT><SAMP>`--sort-by-file
´</SAMP>
2094 <A NAME=
"IDX791"></A>
2095 <A NAME=
"IDX792"></A>
2096 Sort output by file location.
2102 <H3><A NAME=
"SEC122" HREF=
"gettext_toc.html#TOC122">7.8.7 Informative output
</A></H3>
2106 <DT><SAMP>`-h
´</SAMP>
2108 <DT><SAMP>`--help
´</SAMP>
2110 <A NAME=
"IDX793"></A>
2111 <A NAME=
"IDX794"></A>
2112 Display this help and exit.
2114 <DT><SAMP>`-V
´</SAMP>
2116 <DT><SAMP>`--version
´</SAMP>
2118 <A NAME=
"IDX795"></A>
2119 <A NAME=
"IDX796"></A>
2120 Output version information and exit.
2126 <H2><A NAME=
"SEC123" HREF=
"gettext_toc.html#TOC123">7.9 Invoking the
<CODE>msgen
</CODE> Program
</A></H2>
2129 <A NAME=
"IDX797"></A>
2130 <A NAME=
"IDX798"></A>
2133 msgen [
<VAR>option
</VAR>]
<VAR>inputfile
</VAR>
2137 <A NAME=
"IDX799"></A>
2138 The
<CODE>msgen
</CODE> program creates an English translation catalog. The
2139 input file is the last created English PO file, or a PO Template file
2140 (generally created by xgettext). Untranslated entries are assigned a
2141 translation that is identical to the msgid.
2145 Note:
<SAMP>`msginit --no-translator --locale=en
´</SAMP> performs a very similar
2146 task. The main difference is that
<CODE>msginit
</CODE> cares specially about
2147 the header entry, whereas
<CODE>msgen
</CODE> doesn't.
2152 <H3><A NAME=
"SEC124" HREF=
"gettext_toc.html#TOC124">7.9.1 Input file location
</A></H3>
2156 <DT><SAMP>`
<VAR>inputfile
</VAR>´</SAMP>
2158 Input PO or POT file.
2160 <DT><SAMP>`-D
<VAR>directory
</VAR>´</SAMP>
2162 <DT><SAMP>`--directory=
<VAR>directory
</VAR>´</SAMP>
2164 <A NAME=
"IDX800"></A>
2165 <A NAME=
"IDX801"></A>
2166 Add
<VAR>directory
</VAR> to the list of directories. Source files are
2167 searched relative to this list of directories. The resulting
<TT>`.po
´</TT>
2168 file will be written relative to the current directory, though.
2173 If
<VAR>inputfile
</VAR> is
<SAMP>`-
´</SAMP>, standard input is read.
2178 <H3><A NAME=
"SEC125" HREF=
"gettext_toc.html#TOC125">7.9.2 Output file location
</A></H3>
2182 <DT><SAMP>`-o
<VAR>file
</VAR>´</SAMP>
2184 <DT><SAMP>`--output-file=
<VAR>file
</VAR>´</SAMP>
2186 <A NAME=
"IDX802"></A>
2187 <A NAME=
"IDX803"></A>
2188 Write output to specified file.
2193 The results are written to standard output if no output file is specified
2194 or if it is
<SAMP>`-
´</SAMP>.
2199 <H3><A NAME=
"SEC126" HREF=
"gettext_toc.html#TOC126">7.9.3 Input file syntax
</A></H3>
2203 <DT><SAMP>`-P
´</SAMP>
2205 <DT><SAMP>`--properties-input
´</SAMP>
2207 <A NAME=
"IDX804"></A>
2208 <A NAME=
"IDX805"></A>
2209 Assume the input file is a Java ResourceBundle in Java
<CODE>.properties
</CODE>
2210 syntax, not in PO file syntax.
2212 <DT><SAMP>`--stringtable-input
´</SAMP>
2214 <A NAME=
"IDX806"></A>
2215 Assume the input file is a NeXTstep/GNUstep localized resource file in
2216 <CODE>.strings
</CODE> syntax, not in PO file syntax.
2222 <H3><A NAME=
"SEC127" HREF=
"gettext_toc.html#TOC127">7.9.4 Output details
</A></H3>
2226 <DT><SAMP>`--force-po
´</SAMP>
2228 <A NAME=
"IDX807"></A>
2229 Always write an output file even if it contains no message.
2231 <DT><SAMP>`-i
´</SAMP>
2233 <DT><SAMP>`--indent
´</SAMP>
2235 <A NAME=
"IDX808"></A>
2236 <A NAME=
"IDX809"></A>
2237 Write the .po file using indented style.
2239 <DT><SAMP>`--no-location
´</SAMP>
2241 <A NAME=
"IDX810"></A>
2242 Do not write
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines.
2244 <DT><SAMP>`--add-location
´</SAMP>
2246 <A NAME=
"IDX811"></A>
2247 Generate
<SAMP>`#:
<VAR>filename
</VAR>:
<VAR>line
</VAR>´</SAMP> lines (default).
2249 <DT><SAMP>`--strict
´</SAMP>
2251 <A NAME=
"IDX812"></A>
2252 Write out a strict Uniforum conforming PO file. Note that this
2253 Uniforum format should be avoided because it doesn't support the
2256 <DT><SAMP>`-p
´</SAMP>
2258 <DT><SAMP>`--properties-output
´</SAMP>
2260 <A NAME=
"IDX813"></A>
2261 <A NAME=
"IDX814"></A>
2262 Write out a Java ResourceBundle in Java
<CODE>.properties
</CODE> syntax. Note
2263 that this file format doesn't support plural forms and silently drops
2266 <DT><SAMP>`--stringtable-output
´</SAMP>
2268 <A NAME=
"IDX815"></A>
2269 Write out a NeXTstep/GNUstep localized resource file in
<CODE>.strings
</CODE> syntax.
2270 Note that this file format doesn't support plural forms.
2272 <DT><SAMP>`-w
<VAR>number
</VAR>´</SAMP>
2274 <DT><SAMP>`--width=
<VAR>number
</VAR>´</SAMP>
2276 <A NAME=
"IDX816"></A>
2277 <A NAME=
"IDX817"></A>
2278 Set the output page width. Long strings in the output files will be
2279 split across multiple lines in order to ensure that each line's width
2280 (= number of screen columns) is less or equal to the given
<VAR>number
</VAR>.
2282 <DT><SAMP>`--no-wrap
´</SAMP>
2284 <A NAME=
"IDX818"></A>
2285 Do not break long message lines. Message lines whose width exceeds the
2286 output page width will not be split into several lines. Only file reference
2287 lines which are wider than the output page width will be split.
2289 <DT><SAMP>`-s
´</SAMP>
2291 <DT><SAMP>`--sort-output
´</SAMP>
2293 <A NAME=
"IDX819"></A>
2294 <A NAME=
"IDX820"></A>
2295 Generate sorted output. Note that using this option makes it much harder
2296 for the translator to understand each message's context.
2298 <DT><SAMP>`-F
´</SAMP>
2300 <DT><SAMP>`--sort-by-file
´</SAMP>
2302 <A NAME=
"IDX821"></A>
2303 <A NAME=
"IDX822"></A>
2304 Sort output by file location.
2310 <H3><A NAME=
"SEC128" HREF=
"gettext_toc.html#TOC128">7.9.5 Informative output
</A></H3>
2314 <DT><SAMP>`-h
´</SAMP>
2316 <DT><SAMP>`--help
´</SAMP>
2318 <A NAME=
"IDX823"></A>
2319 <A NAME=
"IDX824"></A>
2320 Display this help and exit.
2322 <DT><SAMP>`-V
´</SAMP>
2324 <DT><SAMP>`--version
´</SAMP>
2326 <A NAME=
"IDX825"></A>
2327 <A NAME=
"IDX826"></A>
2328 Output version information and exit.
2334 <H2><A NAME=
"SEC129" HREF=
"gettext_toc.html#TOC129">7.10 Invoking the
<CODE>msgexec
</CODE> Program
</A></H2>
2337 <A NAME=
"IDX827"></A>
2338 <A NAME=
"IDX828"></A>
2341 msgexec [
<VAR>option
</VAR>]
<VAR>command
</VAR> [
<VAR>command-option
</VAR>]
2345 <A NAME=
"IDX829"></A>
2346 The
<CODE>msgexec
</CODE> program applies a command to all translations of a
2347 translation catalog.
2348 The
<VAR>command
</VAR> can be any program that reads a translation from standard
2349 input. It is invoked once for each translation. Its output becomes
2350 msgexec's output.
<CODE>msgexec
</CODE>'s return code is the maximum return code
2351 across all invocations.
2355 <A NAME=
"IDX830"></A>
2356 A special builtin command called
<SAMP>`
0´</SAMP> outputs the translation, followed
2357 by a null byte. The output of
<SAMP>`msgexec
0´</SAMP> is suitable as input for
2358 <SAMP>`xargs -
0´</SAMP>.
2362 <A NAME=
"IDX831"></A>
2363 <A NAME=
"IDX832"></A>
2364 During each
<VAR>command
</VAR> invocation, the environment variable
2365 <CODE>MSGEXEC_MSGID
</CODE> is bound to the message's msgid, and the environment
2366 variable
<CODE>MSGEXEC_LOCATION
</CODE> is bound to the location in the PO file
2371 <A NAME=
"IDX833"></A>
2372 Note: It is your responsibility to ensure that the
<VAR>command
</VAR> can cope
2373 with input encoded in the translation catalog's encoding. If the
2374 <VAR>command
</VAR> wants input in a particular encoding, you can in a first step
2375 convert the translation catalog to that encoding using the
<SAMP>`msgconv
´</SAMP>
2376 program, before invoking
<SAMP>`msgexec
´</SAMP>. If the
<VAR>command
</VAR> wants input
2377 in the locale's encoding, but you want to avoid the locale's encoding, then
2378 you can first convert the translation catalog to UTF-
8 using the
2379 <SAMP>`msgconv
´</SAMP> program and then make
<SAMP>`msgexec
´</SAMP> work in an UTF-
8
2380 locale, by using the
<CODE>LC_ALL
</CODE> environment variable.
2385 <H3><A NAME=
"SEC130" HREF=
"gettext_toc.html#TOC130">7.10.1 Input file location
</A></H3>
2389 <DT><SAMP>`-i
<VAR>inputfile
</VAR>´</SAMP>
2391 <DT><SAMP>`--input=
<VAR>inputfile
</VAR>´</SAMP>
2393 <A NAME=
"IDX834"></A>
2394 <A NAME=
"IDX835"></A>
2397 <DT><SAMP>`-D
<VAR>directory
</VAR>´</SAMP>
2399 <DT><SAMP>`--directory=
<VAR>directory
</VAR>´</SAMP>
2401 <A NAME=
"IDX836"></A>
2402 <A NAME=
"IDX837"></A>
2403 Add
<VAR>directory
</VAR> to the list of directories. Source files are
2404 searched relative to this list of directories. The resulting
<TT>`.po
´</TT>
2405 file will be written relative to the current directory, though.
2410 If no
<VAR>inputfile
</VAR> is given or if it is
<SAMP>`-
´</SAMP>, standard input is read.
2415 <H3><A NAME=
"SEC131" HREF=
"gettext_toc.html#TOC131">7.10.2 Input file syntax
</A></H3>
2419 <DT><SAMP>`-P
´</SAMP>
2421 <DT><SAMP>`--properties-input
´</SAMP>
2423 <A NAME=
"IDX838"></A>
2424 <A NAME=
"IDX839"></A>
2425 Assume the input file is a Java ResourceBundle in Java
<CODE>.properties
</CODE>
2426 syntax, not in PO file syntax.
2428 <DT><SAMP>`--stringtable-input
´</SAMP>
2430 <A NAME=
"IDX840"></A>
2431 Assume the input file is a NeXTstep/GNUstep localized resource file in
2432 <CODE>.strings
</CODE> syntax, not in PO file syntax.
2438 <H3><A NAME=
"SEC132" HREF=
"gettext_toc.html#TOC132">7.10.3 Informative output
</A></H3>
2442 <DT><SAMP>`-h
´</SAMP>
2444 <DT><SAMP>`--help
´</SAMP>
2446 <A NAME=
"IDX841"></A>
2447 <A NAME=
"IDX842"></A>
2448 Display this help and exit.
2450 <DT><SAMP>`-V
´</SAMP>
2452 <DT><SAMP>`--version
´</SAMP>
2454 <A NAME=
"IDX843"></A>
2455 <A NAME=
"IDX844"></A>
2456 Output version information and exit.
2462 <H2><A NAME=
"SEC133" HREF=
"gettext_toc.html#TOC133">7.11 Writing your own programs that process PO files
</A></H2>
2465 For the tasks for which a combination of
<SAMP>`msgattrib
´</SAMP>,
<SAMP>`msgcat
´</SAMP> etc.
2466 is not sufficient, a set of C functions is provided in a library, to make it
2467 possible to process PO files in your own programs. When you use this library,
2468 you don't need to write routines to parse the PO file; instead, you retreive
2469 a pointer in memory to each of messages contained in the PO file. Functions
2470 for writing PO files are not provided at this time.
2474 The functions are declared in the header file
<SAMP>`
<gettext-po.h
>´</SAMP>, and are
2475 defined in a library called
<SAMP>`libgettextpo
´</SAMP>.
2480 <DT><U>Data Type:
</U> <B>po_file_t
</B>
2481 <DD><A NAME=
"IDX845"></A>
2482 This is a pointer type that refers to the contents of a PO file, after it has
2483 been read into memory.
2489 <DT><U>Data Type:
</U> <B>po_message_iterator_t
</B>
2490 <DD><A NAME=
"IDX846"></A>
2491 This is a pointer type that refers to an iterator that produces a sequence of
2498 <DT><U>Data Type:
</U> <B>po_message_t
</B>
2499 <DD><A NAME=
"IDX847"></A>
2500 This is a pointer type that refers to a message of a PO file, including its
2507 <DT><U>Function:
</U> po_file_t
<B>po_file_read
</B> <I>(const char *
<VAR>filename
</VAR>)
</I>
2508 <DD><A NAME=
"IDX848"></A>
2509 The
<CODE>po_file_read
</CODE> function reads a PO file into memory. The file name
2510 is given as argument. The return value is a handle to the PO file's contents,
2511 valid until
<CODE>po_file_free
</CODE> is called on it. In case of error, the return
2512 value is
<CODE>NULL
</CODE>, and
<CODE>errno
</CODE> is set.
2518 <DT><U>Function:
</U> void
<B>po_file_free
</B> <I>(po_file_t
<VAR>file
</VAR>)
</I>
2519 <DD><A NAME=
"IDX849"></A>
2520 The
<CODE>po_file_free
</CODE> function frees a PO file's contents from memory,
2521 including all messages that are only implicitly accessible through iterators.
2527 <DT><U>Function:
</U> const char * const *
<B>po_file_domains
</B> <I>(po_file_t
<VAR>file
</VAR>)
</I>
2528 <DD><A NAME=
"IDX850"></A>
2529 The
<CODE>po_file_domains
</CODE> function returns the domains for which the given
2530 PO file has messages. The return value is a
<CODE>NULL
</CODE> terminated array
2531 which is valid as long as the
<VAR>file
</VAR> handle is valid. For PO files which
2532 contain no
<SAMP>`domain
´</SAMP> directive, the return value contains only one domain,
2533 namely the default domain
<CODE>"messages"</CODE>.
2539 <DT><U>Function:
</U> po_message_iterator_t
<B>po_message_iterator
</B> <I>(po_file_t
<VAR>file
</VAR>, const char *
<VAR>domain
</VAR>)
</I>
2540 <DD><A NAME=
"IDX851"></A>
2541 The
<CODE>po_message_iterator
</CODE> returns an iterator that will produce the
2542 messages of
<VAR>file
</VAR> that belong to the given
<VAR>domain
</VAR>. If
<VAR>domain
</VAR>
2543 is
<CODE>NULL
</CODE>, the default domain is used instead. To list the messages,
2544 use the function
<CODE>po_next_message
</CODE> repeatedly.
2550 <DT><U>Function:
</U> void
<B>po_message_iterator_free
</B> <I>(po_message_iterator_t
<VAR>iterator
</VAR>)
</I>
2551 <DD><A NAME=
"IDX852"></A>
2552 The
<CODE>po_message_iterator_free
</CODE> function frees an iterator previously
2553 allocated through the
<CODE>po_message_iterator
</CODE> function.
2559 <DT><U>Function:
</U> po_message_t
<B>po_next_message
</B> <I>(po_message_iterator_t
<VAR>iterator
</VAR>)
</I>
2560 <DD><A NAME=
"IDX853"></A>
2561 The
<CODE>po_next_message
</CODE> function returns the next message from
2562 <VAR>iterator
</VAR> and advances the iterator. It returns
<CODE>NULL
</CODE> when the
2563 iterator has reached the end of its message list.
2568 The following functions returns details of a
<CODE>po_message_t
</CODE>. Recall
2569 that the results are valid as long as the
<VAR>file
</VAR> handle is valid.
2574 <DT><U>Function:
</U> const char *
<B>po_message_msgid
</B> <I>(po_message_t
<VAR>message
</VAR>)
</I>
2575 <DD><A NAME=
"IDX854"></A>
2576 The
<CODE>po_message_msgid
</CODE> function returns the
<CODE>msgid
</CODE> (untranslated
2577 English string) of a message. This is guaranteed to be non-
<CODE>NULL
</CODE>.
2583 <DT><U>Function:
</U> const char *
<B>po_message_msgid_plural
</B> <I>(po_message_t
<VAR>message
</VAR>)
</I>
2584 <DD><A NAME=
"IDX855"></A>
2585 The
<CODE>po_message_msgid_plural
</CODE> function returns the
<CODE>msgid_plural
</CODE>
2586 (untranslated English plural string) of a message with plurals, or
<CODE>NULL
</CODE>
2587 for a message without plural.
2593 <DT><U>Function:
</U> const char *
<B>po_message_msgstr
</B> <I>(po_message_t
<VAR>message
</VAR>)
</I>
2594 <DD><A NAME=
"IDX856"></A>
2595 The
<CODE>po_message_msgstr
</CODE> function returns the
<CODE>msgstr
</CODE> (translation)
2596 of a message. For an untranslated message, the return value is an empty
2603 <DT><U>Function:
</U> const char *
<B>po_message_msgstr_plural
</B> <I>(po_message_t
<VAR>message
</VAR>, int
<VAR>index
</VAR>)
</I>
2604 <DD><A NAME=
"IDX857"></A>
2605 The
<CODE>po_message_msgstr_plural
</CODE> function returns the
2606 <CODE>msgstr[
<VAR>index
</VAR>]
</CODE> of a message with plurals, or
<CODE>NULL
</CODE> when
2607 the
<VAR>index
</VAR> is out of range or for a message without plural.
2612 Here is an example code how these functions can be used.
2617 const char *filename = ...;
2618 po_file_t file = po_file_read (filename);
2621 error (EXIT_FAILURE, errno,
"couldn't open the PO file %s", filename);
2623 const char * const *domains = po_file_domains (file);
2624 const char * const *domainp;
2626 for (domainp = domains; *domainp; domainp++)
2628 const char *domain = *domainp;
2629 po_message_iterator_t iterator = po_message_iterator (file, domain);
2633 po_message_t *message = po_next_message (iterator);
2635 if (message == NULL)
2638 const char *msgid = po_message_msgid (message);
2639 const char *msgstr = po_message_msgstr (message);
2644 po_message_iterator_free (iterator);
2647 po_file_free (file);
2651 Go to the
<A HREF=
"gettext_1.html">first
</A>,
<A HREF=
"gettext_6.html">previous
</A>,
<A HREF=
"gettext_8.html">next
</A>,
<A HREF=
"gettext_22.html">last
</A> section,
<A HREF=
"gettext_toc.html">table of contents
</A>.