1
2
3
4
5
6
7
8
9
10
11 package chapter3.calculator;
12
13 import java.util.HashMap;
14 import java.util.Map;
15
16 import ch.qos.logback.core.Context;
17 import ch.qos.logback.core.ContextBase;
18 import ch.qos.logback.core.joran.action.Action;
19 import ch.qos.logback.core.joran.spi.JoranException;
20 import ch.qos.logback.core.joran.spi.Pattern;
21 import ch.qos.logback.core.util.StatusPrinter;
22 import chapter3.SimpleConfigurator;
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42 public class Calculator1 {
43
44 public static void main(String[] args) throws Exception {
45 Context context = new ContextBase();
46
47 Map<Pattern, Action> ruleMap = new HashMap<Pattern, Action>();
48
49
50 ruleMap.put(new Pattern("/computation"), new ComputationAction1());
51
52
53 ruleMap.put(new Pattern("/computation/literal"), new LiteralAction());
54 ruleMap.put(new Pattern("/computation/add"), new AddAction());
55 ruleMap.put(new Pattern("/computation/multiply"), new MultiplyAction());
56
57 SimpleConfigurator simpleConfigurator = new SimpleConfigurator(ruleMap);
58
59 simpleConfigurator.setContext(context);
60
61 try {
62 simpleConfigurator.doConfigure(args[0]);
63 } catch (JoranException e) {
64
65 StatusPrinter.print(context);
66 }
67 }
68 }