man services.xml (Formats) - libtranslate generic service definitions
NAME
services.xml - libtranslate generic service definitions
DESCRIPTION
The services.xml file contains translation service definitions for the libtranslate generic module.
The generic module provides an abstract framework for supporting web-based translation services.
When the generic module is initialized, it reads service definitions from the services.xml files located in /usr/share/libtranslate and ~/.libtranslate, creates the services defined in these files, and makes them available to libtranslate.
The services.xml file must be encoded in UTF-8, and conform to the services.xml Document Type Definition, located in /usr/share/libtranslate/services.dtd.
ELEMENTS
services
- Description
- The services element is the root of the document, and may contains service definitions and language mappings.
- Children
- These elements may occur zero or more times in services: custom-language, service.
custom-language
- Description
- The custom-language element maps a RFC 3066 language tag to a language name.
Note
Some RFC 3066 tag to name mappings are built into libtranslate and do not need to be added (see the Built-In RFC 3066 Tag to Name Mappings appendix in the libtranslate Reference Manual).
- Attributes
- tag (required)
- The RFC 3066 language tag.
- name (required)
- The language human-readable name.
- Parents
- This element contains custom-language: services.
service
- Description
- The service element defines a translation service.
- Attributes
- name (required)
- The service symbolic name, encoded in ASCII.
- nick (implied, default: name)
- The service human-readable name.
- max-chunk-len (optional, default: 1000)
- The maximum length of an input chunk, in characters (0 means unlimited).
- Parents
- This element contains service: services.
- Children
- This element may occur zero or more times in service: group.
group
- Description
- The group element defines a translation group (a group represents a set of languages and translation methods).
- Parents
- This element contains group: service.
- Children
- These elements may occur zero or more times in group: language, http-header.
These elements may occur zero or one time in group: text-translation, web-page-translation.
language
- Description
- The language element adds a language to the list of languages supported by a group.
- Attributes
- tag (required)
- The RFC 3066 language tag.
- service-tag (implied, default: tag)
- The language service-specific tag. This tag is not exposed to libtranslate, but is available as from and to variables (see Variable Substitution).
- to (optional, default: none)
- A comma-separated list of RFC 3066 language tags this language can be translated into. The special list element * means "every language of this group but this one".
- Parents
- This element contains language: group.
http-header
- Description
- The http-header element adds a HTTP header to the list of headers that are set when a HTTP request is issued.
If the http-header element occurs inside a group element, the header is added for text and web page translations.
If it occurs inside a text-translation or web-page-translation element, the header is only added for a text or web page translation, respectively.
- Attributes
- name (required)
- The HTTP header name.
- value (required)
- The HTTP header value.
- Parents
- These elements contain http-header: group, text-translation, web-page-translation.
text-translation
- Description
- The presence of the text-translation element specifies that the group can translate text.
- Attributes
- url (required)
- The URL to use for translating text. Variable substitution is performed on the URL (see Variable Substitution).
- post (optional, default: none)
- If this attribute is present, a HTTP POST request is issued (using the attribute value as post data). Otherwise, a HTTP GET request is issued. Variable substitution is performed on the post data (see Variable Substitution).
- Parents
- This element contains text-translation: group.
- Children
- These element may occur zero or more times in text-translation: http-header, pre-marker, error-marker.
This element may occur zero or one time in text-translation: post-marker.
pre-marker
- Description
- The pre-marker element is used to extract the translated text from the response to a text translation request.
For each pre-marker element, the parser locates text in the server response. If text is found, the parser moves to the character following text. If it is not found, the translation fails. The translated text starts at the character following the last pre-marker match. If no pre-marker element is specified, the translated text starts at the first character of the server response.
- Attributes
- text (required)
- The text to match.
- Parents
- This element contains pre-marker: text-translation.
post-marker
- Description
- The post-marker element is used to extract the translated text from the response to a text translation request.
If text can be located in the server response, the translated text ends at the character preceding text. Otherwise, the translation fails. If no post-marker element is specified, the translated text ends at the last character of the server response.
- Attributes
- text (required)
- The text to match.
- Parents
- This element contains post-marker: text-translation.
error-marker
- Description
- The error-marker element is used to check if a text translation error has occurred.
If one or more error-marker elements are specified and the text of any of them can be located anywhere in the server response, the translation fails.
- Attributes
- text (required)
- The text to match.
- Parents
- This element contains error-marker: text-translation.
web-page-translation
- Description
- The presence of the web-page-translation element specifies that the group can translate a web page.
If no http-header element is specified and if post is not specified, the generic module does not need to connect to the server. In this case, url is returned as the URL of the translated web page. Otherwise, the generic module connects to the server, issues a HTTP GET or POST request, saves the response to a local file, and returns a file:// URL pointing to that file.
- Attributes
- url (required)
- The URL to use for translating a web page. Variable substitution is performed on the URL (see Variable Substitution).
- post (optional, default: none)
- If this attribute is present, a HTTP POST request is issued (using the attribute value as post data). Otherwise, a HTTP GET request is issued (or no request at all, see above). Variable substitution is performed on the post data (see Variable Substitution).
- Parents
- This element contains web-page-translation: group.
- Children
- This element may occur zero or more times in web-page-translation: http-header.
VARIABLE SUBSTITUTION
Variable substitution is performed at translation time on the url and post attributes of the text-translation and web-page-translation elements.
A variable has the syntax ${varname[:modifiers]}.
varname may be any of the following variables:
- text (text-translation only)
- The text to translate.
- url (web-page-translation only)
- The URL of the web page to translate.
- from
- The source language service tag.
- to
- The destination language service tag.
- time
- The number of seconds since 0 hours, 0 minutes, 0 seconds, January 1, 1970, Coordinated Universal Time.
modifiers is a comma-separated list of modifiers. Each modifier is applied (in the specified order) on the contents of the variable. A modifier has the syntax name[=value].
name may be any of the following modifiers:
- escape
- Escapes the unsafe characters in the variable using URI percent notation.
- charset
- Converts the variable from UTF-8 (the libtranslate character set) to the character set value.
FILES
- /usr/share/libtranslate/services.xml
The system-wide service definitions.
- ~/.libtranslate/services.xml
The user service definitions.
- /usr/share/libtranslate/services.dtd
The services.xml Document Type Definition.
SEE ALSO
The libtranslate Reference Manual
AUTHOR
Jean-Yves Lefort.