1 package org.apache.turbine.services.template.mapper;
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24 import java.util.ArrayList;
25 import java.util.Arrays;
26 import java.util.List;
27
28 import org.apache.commons.lang3.StringUtils;
29 import org.apache.logging.log4j.LogManager;
30 import org.apache.logging.log4j.Logger;
31 import org.apache.turbine.services.TurbineServices;
32 import org.apache.turbine.services.template.TemplateEngineService;
33 import org.apache.turbine.services.template.TemplateService;
34
35
36
37
38
39
40
41
42
43
44
45
46 public class ScreenDefaultTemplateMapper
47 extends BaseTemplateMapper
48 implements Mapper
49 {
50
51 private static final Logger log = LogManager.getLogger(ScreenDefaultTemplateMapper.class);
52
53
54
55
56
57
58 public ScreenDefaultTemplateMapper()
59 {
60
61 }
62
63
64
65
66
67
68
69
70 @Override
71 public String doMapping(String template)
72 {
73 log.debug("doMapping({})", template);
74
75 List<String> components
76 = new ArrayList<String>(Arrays.asList(StringUtils.split(
77 template,
78 String.valueOf(TemplateService.TEMPLATE_PARTS_SEPARATOR))));
79 int componentSize = components.size() - 1 ;
80
81
82
83 String templateName = components.get(componentSize);
84 components.remove(componentSize--);
85
86 log.debug("templateName is {}", templateName);
87
88
89 TemplateServiceorg/apache/turbine/services/template/TemplateService.html#TemplateService">TemplateService templateService = (TemplateService)TurbineServices.getInstance().getService(TemplateService.SERVICE_NAME);
90 TemplateEngineService tes = templateService.getTemplateEngineService(templateName);
91
92 if (tes == null)
93 {
94 return null;
95 }
96
97 String defaultName = "Default.vm";
98
99
100
101
102 boolean firstRun = !templateName.equals(defaultName);
103
104 for(;;)
105 {
106 String templatePackage = StringUtils.join(components.iterator(), String.valueOf(separator));
107
108 log.debug("templatePackage is now: {}", templatePackage);
109
110 StringBuilder testName = new StringBuilder();
111
112 if (!components.isEmpty())
113 {
114 testName.append(templatePackage);
115 testName.append(separator);
116 }
117
118 testName.append((firstRun)
119 ? templateName
120 : defaultName);
121
122
123 StringBuilder templatePath = new StringBuilder();
124 if (StringUtils.isNotEmpty(prefix))
125 {
126 templatePath.append(prefix);
127 templatePath.append(separator);
128 }
129 templatePath.append(testName);
130
131 log.debug("Looking for {}", templatePath);
132
133 if (tes.templateExists(templatePath.toString()))
134 {
135 log.debug("Found it, returning {}", testName);
136 return testName.toString();
137 }
138
139 if (firstRun)
140 {
141 firstRun = false;
142 }
143 else
144 {
145
146
147
148
149 break;
150 }
151 }
152
153 log.debug("Returning default");
154 return getDefaultName(template);
155 }
156 }