 
msgfilter Command in Linux
msgfilter is a Linux command line tool from GNU gettext utilities. This utility is especially beneficial for developers engaged in the internationalization and localization of software.
By using msgfilter, you can apply various filters and transformations to the messages within a .po file (Portable Object file). This enables you to automate the manipulation of translation messages and ensures they adhere to specific standards or requirements.
Table of Contents
Here is a comprehensive guide to the options available with the msgfilter command −
Syntax of msgfilter Command
Here's the standard syntax for running the msgfilter command in Linux −
msgfilter [options] filter [filter options]
Where −
- [options] are optional parameters that modify the command's behavior.
- filter is the command or filter program to apply to each message.
- [filter options] are any extra settings for the filter command.
msgfilter Command Options
Here are some various options you can apply with the msgfilter command −
Input File Location
| Option | Description | 
|---|---|
| -i, --input=INPUTFILE | Defines the input PO file. | 
| -D, --directory=DIRECTORY | Includes DIRECTORY in the search path for input files. | 
If no input file is given or if it is -, the command reads from standard input.
Output File Location
| Option | Description | 
|---|---|
| -o, --output-file=FILE | Defines the file where the output will be written. | 
If no output file is specified or if it is -, the results are written to standard output.
The FILTER can be any program that reads a translation from standard input and writes a modified translation to standard output.
Useful FILTER-OPTIONs when the FILTER is sed
| Option | Description | 
|---|---|
| -e, --expression=SCRIPT | Adds SCRIPT to the commands to be executed. | 
| -f, --file=SCRIPTFILE | Includes the contents of SCRIPTFILE in the commands to be executed. | 
| -n, --quiet, --silent | Prevents automatic printing of the pattern space. | 
Input File Syntax
| Option | Description | 
|---|---|
| -P, --properties-input | Treats the input file as a Java .properties file rather than a PO file. | 
| --stringtable-input | Treats the input file as a NeXTstep/GNUstep .strings file rather than a PO file. | 
Output Details
| Option | Description | 
|---|---|
| --no-escape | Disables the use of C escapes in the output (default). | 
| -E, --escape | Uses C escapes in output, without extended characters. | 
| --force-po | Writes a PO file even if empty. | 
| --indent | Produces indented output style. | 
| --keep-header | Keeps the header entry unmodified, excluding it from filtering. | 
| --no-location | Omits the #: filename:line lines. | 
| --add-location | Preserves the #: filename:line lines (default behavior). | 
| --strict | Generates a PO file that strictly adheres to the Uniforum standard. | 
| -p, --properties-output | Writes out a Java .properties file. | 
| --stringtable-output | Writes out a NeXTstep/GNUstep .strings file. | 
| -w, --width=NUMBER | Sets output page width. | 
| --no-wrap | Prevents long message lines from wrapping into multiple lines. | 
| -F, --sort-by-file | Sorts output by file location. | 
Informative Output
| Option | Description | 
|---|---|
| -h, --help | Displays help information and exits. | 
| -V, --version | Outputs version information and exits. | 
Examples of msgfilter Command in Linux
Below are a few examples illustrating how to use the msgfilter command in various scenarios to effectively filter and transform message catalogs −
- Basic Filtering with sed
- Specifying Input Directory
- Using a Custom Script
- Using Java Properties File Syntax
- Using NEXTstep/GNUstep Strings File Syntax
- Specifying Output File
Basic Filtering with sed
To filter messages in a .po file using sed to replace text −
msgfilter -i input.po sed 's/oldtext/newtext/g'
This command processes input.po and uses sed to replace 'oldtext' with 'newtext' in each message.
Specifying Input Directory
If your input file is located in a specific directory, use the -D option −
msgfilter -D /path/to/directory -i input.po tr 'a-z' 'A-Z'
This command processes input.po from the specified directory and uses the tr command to convert all lowercase letters to uppercase.
Using a Custom Script
To apply a custom script to each message in the .po file −
msgfilter -i input.po ./my_script.sh
This command processes input.po and executes my_script.sh on each message, allowing for customized filtering and transformation.
Using Java Properties File Syntax
If the input file is in Java .properties format, use the -P option −
msgfilter -P -i input.properties awk '{print toupper($0)}'
This command processes input.properties as a Java properties file and uses awk to convert each message to uppercase.
Using NeXTstep/GNUstep Strings File Syntax
If the input file is in NeXTstep/GNUstep .strings format, use the --stringtable-input option −
msgfilter --stringtable-input -i input.strings sort
This command processes input.strings as a NeXTstep/GNUstep strings file and sorts the messages.
Specifying Output File
To direct the output to a specific file, use the -o option −
msgfilter -i input.po -o output.po sed 's/oldtext/newtext/g'
This command processes input.po, applies the sed command to replace 'oldtext' with 'newtext', and saves the results in output.po.
Conclusion
msgfilter is an essential tool for developers working on software localization. It allows you to filter and transform messages in your translation files, making it easier to manage and standardize them.
Whether you are replacing text, converting letter cases, or using custom scripts, msgfilter helps you automate these tasks efficiently.