aboutsummaryrefslogtreecommitdiffstats
path: root/src/org/apache/fop/viewer/SecureResourceBundle.java
blob: 41c9971834545bb1ee1af2a1cd190c54fba4a011 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
package org.apache.fop.viewer;

import java.util.*;
import org.apache.fop.messaging.MessageHandler;
import java.io.*;


/**
 * Die Klasse <code>SecureResourceBundle</code> ist ein Resourceundle, das im Falle eines fehlenden
 * Eintrages keinen Absturz verursacht, sondern die Meldung
 * <strong>Key <i>key</i> not found</strong> zur�ckgibt.
 * @see PropertyResourceBundle
 *
 * @author Stanislav.Gorkhover@af-software.de
 * @version 1.0 18.03.1999
 */
public class SecureResourceBundle extends ResourceBundle implements Translator {

  // Fehlende keys mit einer Meldung zur�ckgeben.
  private boolean isMissingEmphasized = false;

  //private Properties lookup = new Properties();
  private LoadableProperties lookup = new LoadableProperties();

  private boolean isSourceFound = true;

  public void setMissingEmphasized(boolean flag) {
    isMissingEmphasized = flag;
  }

  /**
  * Kreiert ein ResourceBundle mit der Quelle in <strong>in</strong>.
  */

  public SecureResourceBundle(InputStream in) {
    try {
      lookup.load(in);
    } catch(Exception ex) {
      MessageHandler.logln("Abgefangene Exception: " + ex.getMessage());
      isSourceFound = false;
    }
  }



  public Enumeration getKeys() {
    return lookup.keys();
  }



  /**
  * H�ndelt den abgefragten Key, liefert entweder den zugeh�rigen Wert oder eine Meldung.
  * Die <strong>null</strong> wird nie zur�ckgegeben.
  * Schreibt die fehlenden Suchschl�ssel in die Protokoll-Datei.
  * @return <code>Object</code><UL>
  * <LI>den zu dem Suchschl�ssel <strong>key</strong> gefundenen Wert, falls vorhanden, <br>
  * <LI>Meldung <strong>Key <i>key</i> not found</strong>, falls der Suchschl�ssel fehlt
  * und die Eigenschaft "jCatalog.DevelopmentStartModus" in der ini-Datei aus true gesetzt ist.
  * <LI>Meldung <strong>Key is null</strong>, falls der Suchschl�ssel <code>null</code> ist.
  * </UL>
  *
  */
  public Object handleGetObject(String key) {

    if (key == null)
      return "Key is null";

    Object obj = lookup.get(key);
    if (obj != null)
      return obj;
    else {
      if (isMissingEmphasized) {
        MessageHandler.logln(getClass().getName() + ": missing key: " + key);
        return getMissedRepresentation(key.toString());
      }
      else
        return key.toString();
    }
  }

  /**
   * Stellt fest, ob es den Key gibt.
   */
  public boolean contains(String key) {
    return (key == null || lookup.get(key) == null) ? false : true;
  }


  private String getMissedRepresentation(String str) {
    return "<!" + str + "!>";
  }

  public boolean isSourceFound() {
    return isSourceFound;
  }

}