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;
}
}
|