Pakunki komunikatów w środowisku Eclipse 3.1

Opis

Standardowe pakunki zasobów Java cechują się mało wydajną charakterystyką pod względem przestrzeni. Ponieważ działanie platformy Eclipse jest związane z obecnością wielu eksternalizowanych komunikatów, zaimplementowano nową składnicę pakunków komunikatów w celu użycia na tej platformie. Mechanizm ten jest dość prosty i ogólny, przez co może być użyty w dowolnym miejscu.

Podsumowanie nowego podejścia:

Podczas tworzenia nowego komunikatu:

Przykładowe pliki:

Kod klienta

Stary kod:

public class MyClass {
  public void myMethod() {
    String message;
    ...
    // brak argumentów
    message = Messages.getString("key.one"); //$NON-NLS-1$
    ...
    // powiązanie jednego argumentu
    message = MessageFormat.format(Messages.getString("key.two"), new Object[] {"przykład użycia"}); //$NON-NLS-1$ //$NON-NLS-2$
    ...
  }
}

Nowy kod:

public class MyClass {
  public void myMethod() {
    String message;
    ...
    // brak argumentów
    message = Messages.key_one;
    ...
    // powiązanie jednego argumentu
    message = NLS.bind(Messages.key_two, "przykład użycia"); //$NON-NLS-1$
    ...
  }
}

Messages.java

Stary kod:

public class Messages {
  private static final String BUNDLE_NAME = "org.eclipse.core.utils.messages"; //$NON-NLS-1$
  private static final ResourceBundle bundle = ResourceBundle.getBundle(BUNDLE_NAME);
   
  public static String getString(String key) {
  try {
      return bundle.getString(key);
    } catch (MissingResourceException e) {
      return key;
    }
  }
}

Nowy kod:

import org.eclipse.osgi.util.NLS;
public class Messages extends NLS {
  private static final String BUNDLE_NAME = "org.eclipse.core.utils.messages"; //$NON-NLS-1$
   
  public static String key_one;
  public static String key_two;
  ...
  static {
    NLS.initializeMessages(BUNDLE_NAME, Messages.class);
  }
}

messages.properties

Stary kod:

key.one = Witaj świecie.
key.two = Jest to {0} powiązania z jednym argumentem.

Nowy kod:

key_one = Witaj świecie.
key_two = Jest to {0} powiązania z jednym argumentem.