All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.gwt.i18n.client.LocalizableResource Maven / Gradle / Ivy

There is a newer version: 2.10.0
Show newest version
/*
 * Copyright 2008 Google Inc.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not
 * use this file except in compliance with the License. You may obtain a copy of
 * the License at
 * 
 * http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations under
 * the License.
 */
package com.google.gwt.i18n.client;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * This is the common superinterface to Messages and Constants.
 * 
 * Each (and the Constants subinterface ConstantsWithLookup) provide
 * compile-time localization of various forms of data.  Messages is
 * used for MessageFormat-style strings which can have
 * parameters (including support for plural forms), while Constants
 * can be other types, have simplified quoting requirements, and do
 * not take any parameters.
 * 
 * The annotations defined here are common to both -- see the individual
 * subinterfaces for additional annotations which apply only to each
 * one.
 */
public interface LocalizableResource extends Localizable {
  
  /**
   * Specifies the default locale for messages in this file.  If not
   * specified, the default is DEFAULT_LOCALE.
   */
  @Retention(RetentionPolicy.RUNTIME)
  @Target(ElementType.TYPE)
  public @interface DefaultLocale {

    String DEFAULT_LOCALE = "en";

    String value() default DEFAULT_LOCALE;
  }

  /**
   * Specifies a description of the string to be translated, such as a note
   * about the context.
   */
  @Retention(RetentionPolicy.RUNTIME)
  @Target(ElementType.METHOD)
  public @interface Description {
    String value();
  }

  /**
   * Requests that a translation source file be generated from the annotated
   * interface.  The file type is determined by the format argument, and the
   * file name by the optional fileName argument.  Some file formats support
   * aggregating messages from multiple interfaces into one file, while others
   * do not; also, additional parameters may be specified via format-specific
   * annotations -- see the documentation of the MessageCatalogFormat implementation
   * for details.
   * 
   * Examples:
   * 
    *
  • @Generate(format = "com.google.gwt.i18n.server.PropertyCatalogFactory") *
    generates properties files for all locales, and the names will be * of the form MyMessages_locale.properties *
  • @Generate(format = {"com.example.ProprietaryFormat1", * "com.example.ProprietaryFormat2"}, * fileName = "myapp_translate_source", locales = {"default"}) *
    generates default files in two proprietary formats, with filenames like * myapp_translate_source.p1 and myapp_translate_source.p2 *
*/ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) public @interface Generate { /** * Constant "magic" default value used to detect that no value was supplied * for the fileName parameter. */ String DEFAULT = "[default]"; /** * Fully-qualified class names of the generator classes. Each class must * implement com.google.gwt.i18n.server.MessageCatalogFactory * (com.google.gwt.i18n.rebind.format.MessageCatalogFormat still works, but * is deprecated). * * Strings are used here instead of class literals because the generators * will likely contain non-translatable code and thus can't be referenced * from translatable code directly. * * Each generator may define additional annotations to supply other * necessary parameters. */ String[] format(); /** * A platform-specific filename for output. If not present, the file will be * named based on the fully-qualified name of the annotated interface. File * names without a slash are given a relative name based on the * fully-qualified package name of the annotated interface. Relative * pathnames are generated in the auxiliary module directory (moduleName-aux * in the output directory, which is specified by the "-out" flag to the * compiler, or the current directory if not present) -- absolute path names * are not allowed. Unless exactly one locale is specified for locales (not * just only one locale happened to be compiled for), the locale will be * appended to the name (such as _default [for the default locale], _en_US, * etc) as well as the proper extension for the specified format. * * Note that if multiple generators are used, they will have the same base * filename so the extensions must be different. */ String fileName() default DEFAULT; /** * A list of locales for which to generate this output file. If no locales * are specified, all locales for which the application is compiled for will * be generated. Note that the default locale is "default". */ String[] locales() default {}; } /** * Annotation indicating this is a generated file and the source file it was * generated from. */ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) public @interface GeneratedFrom { String value(); } /** * Requests that the keys for messages be generated automatically. If the * annotation is supplied with no value, the default is to use an MD5 hash of * the text and meaning. If this annotation is not supplied, the keys will be * the unqualified method names. * *

The value is either the name of an inner class of {@code KeyGenerator} or the * fully-qualified class name of some implementation of {@code KeyGenerator}. */ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) public @interface GenerateKeys { String value() default "com.google.gwt.i18n.server.keygen.MD5KeyGenerator"; } /** * The key used for lookup of translated strings. If not present, the * key will be generated based on the {@code @GenerateKeys} annotation, * or the unqualified method name if it is not present. */ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface Key { String value(); } /** * Specifies the meaning of the translated string. For example, to * distinguish between multiple meanings of a word or phrase. */ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) @Documented public @interface Meaning { String value(); } }



© 2015 - 2024 Weber Informatics LLC | Privacy Policy