| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.apache.cocoon.pipeline.component.AbstractPipelineComponent
org.apache.cocoon.sax.AbstractSAXPipelineComponent
org.apache.cocoon.sax.AbstractSAXProducer
org.apache.cocoon.sax.AbstractSAXTransformer
org.apache.cocoon.sax.component.I18nTransformer
public class I18nTransformer
Internationalization transformer is used to transform i18n markup into text based on a particular locale.
The i18n transformer works by finding a translation for the user's locale
 in the passed resource bundles ResourceBundle.
 Locale is passed as parameter to the transformer.
For the passed local it then attempts to find a resource bundle that satisfies the locale, and uses it for for processing text replacement directed by i18n markup.
Files to be translated contain the following markup:
<?xml version="1.0"?> ... some text, translate <i18n:text>key</i18n:text>At runtime, the i18n transformer will find a resource bundle for the user's locale, and will appropriately replace the text between the
<i18n:text> markup, using the value between the tags as
 the lookup key.
 To use the transformer in a pipeline, simply specify it in a particular transform, and pass locale, bundle and (optional) untranslated parameters:
 <map:match pattern="file">
   <map:generate src="file.xml"/>
   <map:transform type="i18n">
     <map:parameter name="locale" value="..."/>
     <map:parameter name="bundle" value="..."/>
     <map:parameter name="untranslated" value="..."/>
   </map:transform>
   <map:serialize/>
 </map:match>
 
 For date, time and number formatting use the following tags:
date, date-time and time
 accept pattern and src-pattern attribute, with
 values of:
 short
  medium
  long
  full
 DateFormat for more info on these values.
 Elements date, date-time, time and
 number, a different locale and
 source-locale can be specified:
 
<i18n:date src-pattern="short" src-locale="en_US" locale="de_DE"> 12/24/11 </i18n:date>Will result in 24.12.2011.
A given real pattern and src-pattern (not
 keywords short, medium, long, full) overrides any value
 specified by locale and src-locale attributes.
| Nested Class Summary | |
|---|---|
| static class | I18nTransformer.CustomEncodingControlSupport for custom encodings in bundle files. | 
| Field Summary | |
|---|---|
| static String | ATTR_ATTRThis attribute is used with any element (even not i18n) to translate attribute values. | 
| static String | ATTR_CURRENCYThis attribute is used to specify a different locale for the currency. | 
| static String | ATTR_EXPRThis attribute is used with any element (even not i18n) to evaluate attribute values. | 
| static String | ATTR_FRACTION_DIGITSfraction-digitsattribute is used withi18:numberto
 indicate the number of digits behind the fraction | 
| static String | ATTR_LOCALEThis attribute is used with date and number formatting elements to indicate the locale that should be used to format the element value. | 
| static String | ATTR_PARAM_NAMEThis attribute affects a name to the param that could be used for substitution. | 
| static String | ATTR_PATTERNThis attribute is used with date and number formatting elements to indicate the pattern that should be used to format the element value. | 
| static String | ATTR_SRC_LOCALEThis attribute is used with date and number formatting elements to indicate the locale that should be used to parse the element value. | 
| static String | ATTR_SRC_PATTERNThis attribute is used with date and number formatting elements to indicate the pattern that should be used to parse the element value. | 
| static String | ATTR_TYPEThis attribute is used with number formatting elements to indicate the type of formatting (currency | int-currency | percent | ...) | 
| static String | ATTR_VALUEThis attribute is used with date and number formatting elements to indicate the value that should be parsed and formatted. | 
| static String | DEFAULT_ENCODINGThe default encoding of the resource bundle files. | 
| static String | DEFAULT_NAMESPACEThe namespace for XML elements inside messages. | 
| static String | ELEM_CHOOSEi18n:chooseelement is used to translate elements in-place. | 
| static String | ELEM_CURRENCYCurrency element name | 
| static String | ELEM_CURRENCY_NO_UNITCurrency without unit element name | 
| static String | ELEM_DATEi18n:dateis used to provide a localized date string. | 
| static String | ELEM_DATE_TIMEi18n:date-timeis used to provide a localized date and
 time string. | 
| static String | ELEM_IFi18n:ifis used to test a locale. | 
| static String | ELEM_INT_CURRENCYInteger currency element name | 
| static String | ELEM_INT_CURRENCY_NO_UNITInteger currency without unit element name | 
| static String | ELEM_NUMBERi18n:numberis used to provide a localized number string. | 
| static String | ELEM_OTHERWISEi18n:otherwiseis used to match any locale when
 no matching locale has been found inside ani18n:chooseblock. | 
| static String | ELEM_PARAMi18n:paramis used with i18n:translate to provide
 substitution params. | 
| static String | ELEM_PERCENTPercent element name | 
| static String | ELEM_TEXTi18n:textelement is used to translate any text, with
 or without markup. | 
| static String | ELEM_TIMEi18n:timeis used to provide a localized time string. | 
| static String | ELEM_TRANSLATEi18n:translateelement is used to translate text with
 parameter substitution. | 
| static String | ELEM_WHENi18n:whenis used to test a locale. | 
| static String | KEY_ATTRThis attribute is used with i18n:text element to indicate the key of the according message. | 
| static String | NS_I18N | 
| static String | PARAM_BUNDLEThis configuration parameter specifies the resource bundle's name to be used. | 
| static String | PARAM_ENCODINGThe encoding of the resource bundle files. | 
| static String | PARAM_LOCALEThis configuration parameter specifies the default locale to be used. | 
| static String | PARAM_PARSE_NAMESPACEThe namespace for XML elements inside messages. | 
| static String | PARAM_PARSE_XMLIf XML inside i18n messages shall be parsed. | 
| static String | PARAM_UNTRANSLATEDThis configuration parameter specifies the message that should be displayed in case of a not translated text (message not found). | 
| Constructor Summary | |
|---|---|
| I18nTransformer()Empty constructor, for usage with sitemap. | |
| I18nTransformer(Locale locale,
                String bundle) | |
| I18nTransformer(Locale locale,
                String bundle,
                String untranslated) | |
| I18nTransformer(Locale locale,
                String bundle,
                String untranslated,
                String encoding) | |
| I18nTransformer(String bundle) | |
| Method Summary | |
|---|---|
|  void | characters(char[] chars,
           int start,
           int len) | 
|  CacheKey | constructCacheKey() | 
|  void | endElement(String uri,
           String name,
           String raw) | 
|  Locale | parseLocale(String localeString)Parses given locale string to Locale object. | 
|  void | setConfiguration(Map<String,? extends Object> configuration)Pass component specific configuration parameters to the pipeline component in a generic way. | 
|  void | setParseNamespace(String parseNamespace) | 
|  void | setParseXml(boolean parseXml) | 
|  void | setup(Map<String,Object> parameters)The shared object map for this pipeline run. | 
|  void | startElement(String uri,
             String name,
             String raw,
             Attributes attr) | 
| Methods inherited from class org.apache.cocoon.sax.AbstractSAXTransformer | 
|---|
| comment, endCDATA, endDocument, endDTD, endEntity, endPrefixMapping, endSAXRecording, endTextRecording, findPrefixMapping, ignorableWhitespace, processingInstruction, removeRecorder, sendEndPrefixMapping, sendStartPrefixMapping, setDocumentLocator, setRecorder, skippedEntity, startCDATA, startDocument, startDTD, startEntity, startPrefixMapping, startSAXRecording, startTextRecording | 
| Methods inherited from class org.apache.cocoon.sax.AbstractSAXProducer | 
|---|
| getSAXConsumer, setConsumer, setSAXConsumer, toString | 
| Methods inherited from class org.apache.cocoon.pipeline.component.AbstractPipelineComponent | 
|---|
| finish | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait | 
| Methods inherited from interface org.apache.cocoon.pipeline.component.PipelineComponent | 
|---|
| finish | 
| Field Detail | 
|---|
public static final String NS_I18N
public static final String ELEM_TEXT
i18n:text element is used to translate any text, with
 or without markup. Example:
 
   <i18n:text>
     This is <strong>translated</strong> string.
   </i18n:text>
 
public static final String ELEM_TRANSLATE
i18n:translate element is used to translate text with
 parameter substitution. Example:
 
 <i18n:translate>
   <i18n:text>This is translated string with {0} param</i18n:text>
   <i18n:param>1</i18n:param>
 </i18n:translate>
 
 The i18n:text fragment can include markup and parameters
 at any place. Also do parameters, which can include i18n:text,
 i18n:date, etc. elements (without keys only).
ELEM_TEXT, 
ELEM_PARAM, 
Constant Field Valuespublic static final String ELEM_CHOOSE
i18n:choose element is used to translate elements in-place.
 The first i18n:when element matching the current locale
 is selected and the others are discarded.
 To specify what to do if no locale matched, simply add a node with
 locale="*". Note that this element must be the last
 child of <i18n:choose>.
 <i18n:choose>
   <i18n:when locale="en">
     Good Morning
   </en>
   <i18n:when locale="fr">
     Bonjour
   </jp>
   <i18n:when locale="jp">
     Aligato?
   </jp>
   <i18n:otherwise>
     Sorry, i don't know how to say hello in your language
   </jp>
 <i18n:translate>
 
 You can include any markup within i18n:when elements,
 with the exception of other i18n:* elements.
ELEM_IF, 
ATTR_LOCALE, 
Constant Field Valuespublic static final String ELEM_WHEN
i18n:when is used to test a locale.
 It can be used within i18:choose elements or alone.
 Note: Using locale="*" here has no sense.
 Example:
 <greeting> <i18n:when locale="en">Hello</i18n:when> <i18n:when locale="fr">Bonjour</i18n:when> </greeting>
ATTR_LOCALE, 
ELEM_CHOOSE, 
Constant Field Valuespublic static final String ELEM_IF
i18n:if is used to test a locale. Example:
 <greeting> <i18n:if locale="en">Hello</i18n:when> <i18n:if locale="fr">Bonjour</i18n:when> </greeting>
ATTR_LOCALE, 
ELEM_CHOOSE, 
ELEM_WHEN, 
Constant Field Valuespublic static final String ELEM_OTHERWISE
i18n:otherwise is used to match any locale when
 no matching locale has been found inside an i18n:choose
 block.
ELEM_CHOOSE, 
ELEM_WHEN, 
Constant Field Valuespublic static final String ELEM_PARAM
i18n:param is used with i18n:translate to provide
 substitution params. The param can have i18n:text as
 its value to provide multilingual value. Parameters can have
 additional attributes to be used for formatting:
 type: can be date, date-time, time,
   number, currency, currency-no-unit or percent.
   Used to format params before substitution.value: the value of the param. If no value is
   specified then the text inside of the param element will be used.locale: used only with number, date, time,
   date-time types and used to override the current locale to
   format the given value.src-locale: used with number, date, time,
   date-time types and specify the locale that should be used to
   parse the given value.pattern: used with number, date, time,
   date-time types and specify the pattern that should be used
   to format the given value.src-pattern: used with number, date, time,
   date-time types and specify the pattern that should be used
   to parse the given value.
ELEM_TRANSLATE, 
ELEM_DATE, 
ELEM_TIME, 
ELEM_DATE_TIME, 
ELEM_NUMBER, 
Constant Field Valuespublic static final String ATTR_PARAM_NAME
public static final String ELEM_DATE
i18n:date is used to provide a localized date string.
 Allowed attributes are: pattern, src-pattern, locale,
 src-locale. Usage examples:
 
  <i18n:date src-pattern="short" src-locale="en_US" locale="de_DE">
    12/24/01
  </i18n:date>
  <i18n:date pattern="dd/MM/yyyy" />
 
 If no value is specified then the current date will be used. E.g.:
 <i18n:date />Displays the current date formatted with default pattern for the current locale.
ELEM_PARAM, 
ELEM_DATE_TIME, 
ELEM_TIME, 
ELEM_NUMBER, 
Constant Field Valuespublic static final String ELEM_DATE_TIME
i18n:date-time is used to provide a localized date and
 time string. Allowed attributes are: pattern, src-pattern,
 locale, src-locale. Usage examples:
 
  <i18n:date-time src-pattern="short" src-locale="en_US" locale="de_DE">
    12/24/01 1:00 AM
  </i18n:date>
  <i18n:date-time pattern="dd/MM/yyyy hh:mm" />
 
 If no value is specified then the current date and time will be used.
 E.g.:
 <i18n:date-time />Displays the current date formatted with default pattern for the current locale.
ELEM_PARAM, 
ELEM_DATE, 
ELEM_TIME, 
ELEM_NUMBER, 
Constant Field Valuespublic static final String ELEM_TIME
i18n:time is used to provide a localized time string.
 Allowed attributes are: pattern, src-pattern, locale,
 src-locale. Usage examples:
 
  <i18n:time src-pattern="short" src-locale="en_US" locale="de_DE">
    1:00 AM
  </i18n:time>
 <i18n:time pattern="hh:mm:ss" />
 
 If no value is specified then the current time will be used. E.g.:
 <i18n:time />Displays the current time formatted with default pattern for the current locale.
ELEM_PARAM, 
ELEM_DATE_TIME, 
ELEM_DATE, 
ELEM_NUMBER, 
Constant Field Valuespublic static final String ELEM_NUMBER
i18n:number is used to provide a localized number string.
 Allowed attributes are: pattern, src-pattern, locale, src-locale,
 type. Usage examples:
 
  <i18n:number src-pattern="short" src-locale="en_US" locale="de_DE">
    1000.0
  </i18n:number>
 <i18n:number type="currency" />
 
 If no value is specifies then 0 will be used.
ELEM_PARAM, 
ELEM_DATE_TIME, 
ELEM_TIME, 
ELEM_DATE, 
Constant Field Valuespublic static final String ELEM_CURRENCY
public static final String ELEM_PERCENT
public static final String ELEM_INT_CURRENCY
public static final String ELEM_CURRENCY_NO_UNIT
public static final String ELEM_INT_CURRENCY_NO_UNIT
public static final String KEY_ATTR
<i18n:text i18n:key="a_key">article_text1</i18n:text>
public static final String ATTR_ATTR
<para title="first" name="article" i18n:attr="title name"/>
public static final String ATTR_EXPR
 <para title="first" name="{one} {two}" i18n:attr="name"/>
 
public static final String ATTR_SRC_PATTERN
ELEM_PARAM, 
ELEM_DATE_TIME, 
ELEM_DATE, 
ELEM_TIME, 
ELEM_NUMBER, 
Constant Field Valuespublic static final String ATTR_PATTERN
ELEM_PARAM, 
ELEM_DATE_TIME, 
ELEM_DATE, 
ELEM_TIME, 
ELEM_NUMBER, 
Constant Field Valuespublic static final String ATTR_LOCALE
ELEM_PARAM, 
ELEM_DATE_TIME, 
ELEM_DATE, 
ELEM_TIME, 
ELEM_NUMBER, 
ELEM_WHEN, 
Constant Field Valuespublic static final String ATTR_SRC_LOCALE
ELEM_PARAM, 
ELEM_DATE_TIME, 
ELEM_DATE, 
ELEM_TIME, 
ELEM_NUMBER, 
Constant Field Valuespublic static final String ATTR_VALUE
ELEM_PARAM, 
ELEM_DATE_TIME, 
ELEM_DATE, 
ELEM_TIME, 
ELEM_NUMBER, 
Constant Field Valuespublic static final String ATTR_TYPE
ELEM_NUMBER, 
Constant Field Valuespublic static final String ATTR_CURRENCY
public static final String ATTR_FRACTION_DIGITS
fraction-digits attribute is used with
 i18:number to
 indicate the number of digits behind the fraction
public static final String PARAM_LOCALE
public static final String PARAM_BUNDLE
public static final String PARAM_UNTRANSLATED
public static final String PARAM_ENCODING
public static final String DEFAULT_ENCODING
public static final String PARAM_PARSE_XML
public static final String PARAM_PARSE_NAMESPACE
public static final String DEFAULT_NAMESPACE
| Constructor Detail | 
|---|
public I18nTransformer()
public I18nTransformer(String bundle)
public I18nTransformer(Locale locale,
                       String bundle)
public I18nTransformer(Locale locale,
                       String bundle,
                       String untranslated)
public I18nTransformer(Locale locale,
                       String bundle,
                       String untranslated,
                       String encoding)
| Method Detail | 
|---|
public void setParseXml(boolean parseXml)
public void setParseNamespace(String parseNamespace)
public void setConfiguration(Map<String,? extends Object> configuration)
PipelineComponent
setConfiguration in interface PipelineComponentsetConfiguration in class AbstractPipelineComponentconfiguration - The Map of configuration parameters.public void setup(Map<String,Object> parameters)
PipelineComponent
setup in interface PipelineComponentsetup in class AbstractPipelineComponentparameters - A Map of parameters that are available to all
            PipelineComponents. This is a modifiable map that can
            be changed by this pipeline component.public CacheKey constructCacheKey()
constructCacheKey in interface CachingPipelineComponent
public void startElement(String uri,
                         String name,
                         String raw,
                         Attributes attr)
                  throws SAXException
startElement in interface ContentHandlerstartElement in class AbstractSAXTransformerSAXException
public void endElement(String uri,
                       String name,
                       String raw)
                throws SAXException
endElement in interface ContentHandlerendElement in class AbstractSAXTransformerSAXException
public void characters(char[] chars,
                       int start,
                       int len)
                throws SAXException
characters in interface ContentHandlercharacters in class AbstractSAXTransformerSAXExceptionpublic Locale parseLocale(String localeString)
localeString - - a string containing locale in
        language_country_variant format.defaultLocale - - returned if localeString is null
        or ""| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||