Revision 5829
Added by ben leinfelder almost 14 years ago
lib/spatial/map.jsp | ||
---|---|---|
1 |
<% |
|
2 |
String map = request.getParameter("map"); |
|
3 |
if (map == null) |
|
4 |
map = "demisWorldMap"; |
|
5 |
|
|
6 |
String template = request.getParameter("template"); |
|
7 |
if (template == null) |
|
8 |
template = "default"; |
|
9 |
|
|
10 |
// Currently "mapbuilder" and "openlayers" are supported |
|
11 |
String client = request.getParameter("template"); |
|
12 |
if (client != "mapbuilder" || client != "openlayers" || client == null) |
|
13 |
client = "mapbuilder"; |
|
14 |
|
|
15 |
if (client == "mapbuilder") { |
|
16 |
String mapbuilderURL = request.getContextPath() + "/spatial/mapbuilder/demo/metacat/index.jsp" + |
|
17 |
"?map=" + map + |
|
18 |
"&template=" + template; |
|
19 |
response.sendRedirect(mapbuilderURL); |
|
20 |
} |
|
21 |
%> |
|
22 | 0 |
lib/spatial/WEB-INF/taglibs-xtags.tld | ||
---|---|---|
1 |
<?xml version="1.0" encoding="UTF-8"?> |
|
2 |
|
|
3 |
|
|
4 |
|
|
5 |
<!DOCTYPE taglib PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.1//EN" "http://java.sun.com/j2ee/dtds/web-jsptaglibrary_1_1.dtd"> |
|
6 |
<taglib> |
|
7 |
<tlibversion>1.0</tlibversion> |
|
8 |
<jspversion>1.1</jspversion> |
|
9 |
<shortname>xtags</shortname> |
|
10 |
<uri>http://jakarta.apache.org/taglibs/xtags-1.0</uri> |
|
11 |
<info>XTags is a JSP tag library for working with XSLT and XPath. |
|
12 |
XTags lets you navigate, process and style XML documents directly in JSP. |
|
13 |
XTags makes heavy use of the XPath expression language. |
|
14 |
For a good tutorial on XPath you could try the either the |
|
15 |
Zvon tutorial or the |
|
16 |
specification. |
|
17 |
XTags is currently built on top of dom4j the |
|
18 |
flexible open source XML framework for the Java platform. |
|
19 |
Though increasingly XTags will use a pluggable XPath engine to support |
|
20 |
the travesal of DOM and Java Beans too. |
|
21 |
To begin with you need to parse an XML document from somewhere. |
|
22 |
You can parse a variety of sources of XML documents from local resources, |
|
23 |
the output of JSP or external web services. |
|
24 |
You can parse the body of the tag |
|
25 |
|
|
26 |
<xtags:parse> |
|
27 |
<root> |
|
28 |
<child/> |
|
29 |
</root> |
|
30 |
</xtags:parse> |
|
31 |
Or parse an absolute URL via the "url" attribute |
|
32 |
|
|
33 |
<xtags:parse url="http://something.com"/> |
|
34 |
You can parse a web app resource using an absolute URI relative to the web-app |
|
35 |
context using the "uri" attribute |
|
36 |
|
|
37 |
<xtags:parse uri="/data/foo.xml"/> |
|
38 |
Or you can use a URI relative to the the current JSP file |
|
39 |
|
|
40 |
<xtags:parse uri="foo.xml"/> |
|
41 |
Then for more complex |
|
42 |
requirements such as parsing the output of a piece of JSP, you can do the following (provided you are using a JSP 1.2 container) |
|
43 |
|
|
44 |
<xtags:parse> |
|
45 |
<jsp:include page="foo.jsp"/> |
|
46 |
</xtags:parse> |
|
47 |
Until then you can use the IO tag library to make these requests such as |
|
48 |
|
|
49 |
<xtags:parse> |
|
50 |
<io:request url="/foo.jsp"/> |
|
51 |
</xtags:parse> |
|
52 |
Though the above would result in a seperate HTTP request which would loose |
|
53 |
all page, request and session scope state. |
|
54 |
So if it must be in the same request the following should work |
|
55 |
though care should be taken to avoid scripting variable clashes |
|
56 |
|
|
57 |
<xtags:parse> |
|
58 |
<%@ include file="/foo.jsp" %> |
|
59 |
</xtags:parse> |
|
60 |
To parse the output of an XML-RPC (or SOAP) call, using the IO taglib |
|
61 |
you could do the following. |
|
62 |
|
|
63 |
<xtags:parse> |
|
64 |
<io:xmlrpc url="/xmlrpc_echo.jsp"> |
|
65 |
<io:pipe> |
|
66 |
<methodCall> |
|
67 |
<methodName>examples.getStateName</methodName> |
|
68 |
<params> |
|
69 |
<param> |
|
70 |
<value><i4>41</i4></value> |
|
71 |
</param> |
|
72 |
</params> |
|
73 |
</methodCall> |
|
74 |
</io:pipe> |
|
75 |
</io:xmlrpc> |
|
76 |
|
|
77 |
</xtags:parse> |
|
78 |
Once you have a document parsed you can navigate around its structure using XPath |
|
79 |
expressions in a similar manner to that used in XSLT.Loops are as follows (an optional variable id can be specified to define a |
|
80 |
scriptlet expression inside the loop):- |
|
81 |
|
|
82 |
<xtags:forEach select="expression"> |
|
83 |
... |
|
84 |
</xtags:forEach> |
|
85 |
Simple conditional branching is:- |
|
86 |
|
|
87 |
<xtags:if test="booeanExpression"> |
|
88 |
... |
|
89 |
</xtags:if> |
|
90 |
More complex conditional branching is:- |
|
91 |
|
|
92 |
<xtags:choose> |
|
93 |
<xtags:when test="booeanExpression"> |
|
94 |
... |
|
95 |
</xtags:when> |
|
96 |
<xtags:when test="booeanExpression2"> |
|
97 |
... |
|
98 |
</xtags:when> |
|
99 |
<xtags:otherwise> |
|
100 |
... |
|
101 |
</xtags:otherwise> |
|
102 |
</xtags:choose> |
|
103 |
Expression evaluation |
|
104 |
|
|
105 |
<xtags:valueOf select="expression"/> |
|
106 |
Defining scriptlet variables |
|
107 |
|
|
108 |
<xtags:variable id="variableName" select="expression"/> |
|
109 |
All these tags are very similar to their XSLT equivalents, so anyone who's |
|
110 |
done XSLT before should find them familiar. |
|
111 |
There's also an <xtags:style> tag which performs complete XSL transform |
|
112 |
in one tag. |
|
113 |
Accessing JSP scopes from XPathXPath expressions can use variables with the syntax $foo. |
|
114 |
XTags binds these variables to either page/request/session/application scope |
|
115 |
attributes or request parameters which allows xtags to be used as a |
|
116 |
conditional logic scripting language too - even without the existence of XML |
|
117 |
documents. |
|
118 |
A prefix can be used to denote the exact JSP scope from which a variable comes |
|
119 |
from such as $request:foo to denote request scope. |
|
120 |
There now follows a full breakdown of all the current JSP scopes |
|
121 |
$foomaps to pageContext.findAttribute("foo")$page:foomaps to page scope$request:foomaps to request scope$session:foomaps to session scope$app:foomaps to application scope$param:foomaps to request.getParameter("foo")$initParam:foomaps to request.getInitParameter("foo")$cookie:foomaps to the cookie's value for name foo$header:foomaps to request.getHeader("foo") For example, the following JSP would branch logically based on the value of |
|
122 |
the (say) request parameter "param":- |
|
123 |
|
|
124 |
<xtags:choose> |
|
125 |
<xtags:when test="$param='a'"> |
|
126 |
current param is 'a' |
|
127 |
</xtags:when> |
|
128 |
<xtags:when test="$param='b'"> |
|
129 |
current param is 'b' |
|
130 |
</xtags:when> |
|
131 |
<xtags:otherwise> |
|
132 |
no valid param selected |
|
133 |
</xtags:otherwise> |
|
134 |
</xtags:choose> |
|
135 |
|
|
136 |
XTags even supports the <xtags:stylesheet> <xtags:template> and |
|
137 |
<xtags:applyTemplates> tags from XSLT too though the body of a template must |
|
138 |
be an Action object or a seperate JSP file. |
|
139 |
</info> |
|
140 |
<tag> |
|
141 |
<name>style</name> |
|
142 |
<tagclass>org.apache.taglibs.xtags.xslt.StyleTag</tagclass> |
|
143 |
<bodycontent>JSP</bodycontent> |
|
144 |
<attribute> |
|
145 |
<name>document</name> |
|
146 |
<required>false</required> |
|
147 |
<rtexprvalue>true</rtexprvalue> |
|
148 |
</attribute> |
|
149 |
<attribute> |
|
150 |
<name>xml</name> |
|
151 |
<required>false</required> |
|
152 |
<rtexprvalue>true</rtexprvalue> |
|
153 |
</attribute> |
|
154 |
<attribute> |
|
155 |
<name>xmlReader</name> |
|
156 |
<required>false</required> |
|
157 |
<rtexprvalue>true</rtexprvalue> |
|
158 |
</attribute> |
|
159 |
<attribute> |
|
160 |
<name>xmlSource</name> |
|
161 |
<required>false</required> |
|
162 |
<rtexprvalue>true</rtexprvalue> |
|
163 |
</attribute> |
|
164 |
<attribute> |
|
165 |
<name>xsl</name> |
|
166 |
<required>false</required> |
|
167 |
<rtexprvalue>true</rtexprvalue> |
|
168 |
</attribute> |
|
169 |
<attribute> |
|
170 |
<name>xslReader</name> |
|
171 |
<required>false</required> |
|
172 |
<rtexprvalue>true</rtexprvalue> |
|
173 |
</attribute> |
|
174 |
<attribute> |
|
175 |
<name>xslSource</name> |
|
176 |
<required>false</required> |
|
177 |
<rtexprvalue>true</rtexprvalue> |
|
178 |
</attribute> |
|
179 |
<attribute> |
|
180 |
<name>result</name> |
|
181 |
<required>false</required> |
|
182 |
<rtexprvalue>true</rtexprvalue> |
|
183 |
</attribute> |
|
184 |
<attribute> |
|
185 |
<name>writer</name> |
|
186 |
<required>false</required> |
|
187 |
<rtexprvalue>true</rtexprvalue> |
|
188 |
</attribute> |
|
189 |
<attribute> |
|
190 |
<name>outputMethod</name> |
|
191 |
<required>false</required> |
|
192 |
<rtexprvalue>true</rtexprvalue> |
|
193 |
</attribute> |
|
194 |
</tag> |
|
195 |
<tag> |
|
196 |
<name>param</name> |
|
197 |
<tagclass>org.apache.taglibs.xtags.xslt.ParamTag</tagclass> |
|
198 |
<bodycontent>JSP</bodycontent> |
|
199 |
<attribute> |
|
200 |
<name>name</name> |
|
201 |
<required>true</required> |
|
202 |
<rtexprvalue>true</rtexprvalue> |
|
203 |
</attribute> |
|
204 |
<attribute> |
|
205 |
<name>value</name> |
|
206 |
<required>false</required> |
|
207 |
<rtexprvalue>true</rtexprvalue> |
|
208 |
</attribute> |
|
209 |
</tag> |
|
210 |
<tag> |
|
211 |
<name>parse</name> |
|
212 |
<tagclass>org.apache.taglibs.xtags.xpath.ParseTag</tagclass> |
|
213 |
<teiclass>org.apache.taglibs.xtags.xpath.ParseTagExtraInfo</teiclass> |
|
214 |
<bodycontent>JSP</bodycontent> |
|
215 |
<attribute> |
|
216 |
<name>id</name> |
|
217 |
<required>false</required> |
|
218 |
<rtexprvalue>false</rtexprvalue> |
|
219 |
</attribute> |
|
220 |
<attribute> |
|
221 |
<name>uri</name> |
|
222 |
<required>false</required> |
|
223 |
<rtexprvalue>true</rtexprvalue> |
|
224 |
</attribute> |
|
225 |
<attribute> |
|
226 |
<name>url</name> |
|
227 |
<required>false</required> |
|
228 |
<rtexprvalue>true</rtexprvalue> |
|
229 |
</attribute> |
|
230 |
<attribute> |
|
231 |
<name>reader</name> |
|
232 |
<required>false</required> |
|
233 |
<rtexprvalue>true</rtexprvalue> |
|
234 |
</attribute> |
|
235 |
<attribute> |
|
236 |
<name>validate</name> |
|
237 |
<required>false</required> |
|
238 |
<rtexprvalue>true</rtexprvalue> |
|
239 |
</attribute> |
|
240 |
</tag> |
|
241 |
<tag> |
|
242 |
<name>valueOf</name> |
|
243 |
<tagclass>org.apache.taglibs.xtags.xpath.ValueOfTag</tagclass> |
|
244 |
<bodycontent>empty</bodycontent> |
|
245 |
<attribute> |
|
246 |
<name>select</name> |
|
247 |
<required>true</required> |
|
248 |
<rtexprvalue>true</rtexprvalue> |
|
249 |
</attribute> |
|
250 |
<attribute> |
|
251 |
<name>context</name> |
|
252 |
<required>false</required> |
|
253 |
<rtexprvalue>true</rtexprvalue> |
|
254 |
</attribute> |
|
255 |
</tag> |
|
256 |
<tag> |
|
257 |
<name>forEach</name> |
|
258 |
<tagclass>org.apache.taglibs.xtags.xpath.ForEachTag</tagclass> |
|
259 |
<teiclass>org.apache.taglibs.xtags.xpath.ForEachTagExtraInfo</teiclass> |
|
260 |
<bodycontent>JSP</bodycontent> |
|
261 |
<attribute> |
|
262 |
<name>select</name> |
|
263 |
<required>true</required> |
|
264 |
<rtexprvalue>true</rtexprvalue> |
|
265 |
</attribute> |
|
266 |
<attribute> |
|
267 |
<name>sort</name> |
|
268 |
<required>false</required> |
|
269 |
<rtexprvalue>true</rtexprvalue> |
|
270 |
</attribute> |
|
271 |
<attribute> |
|
272 |
<name>distinct</name> |
|
273 |
<required>false</required> |
|
274 |
<rtexprvalue>true</rtexprvalue> |
|
275 |
</attribute> |
|
276 |
<attribute> |
|
277 |
<name>ascending</name> |
|
278 |
<required>false</required> |
|
279 |
<rtexprvalue>true</rtexprvalue> |
|
280 |
</attribute> |
|
281 |
<attribute> |
|
282 |
<name>context</name> |
|
283 |
<required>false</required> |
|
284 |
<rtexprvalue>true</rtexprvalue> |
|
285 |
</attribute> |
|
286 |
<attribute> |
|
287 |
<name>id</name> |
|
288 |
<required>false</required> |
|
289 |
<rtexprvalue>false</rtexprvalue> |
|
290 |
</attribute> |
|
291 |
<attribute> |
|
292 |
<name>type</name> |
|
293 |
<required>false</required> |
|
294 |
<rtexprvalue>false</rtexprvalue> |
|
295 |
</attribute> |
|
296 |
</tag> |
|
297 |
<tag> |
|
298 |
<name>choose</name> |
|
299 |
<tagclass>org.apache.taglibs.xtags.xpath.ChooseTag</tagclass> |
|
300 |
<bodycontent>JSP</bodycontent> |
|
301 |
</tag> |
|
302 |
<tag> |
|
303 |
<name>when</name> |
|
304 |
<tagclass>org.apache.taglibs.xtags.xpath.WhenTag</tagclass> |
|
305 |
<bodycontent>JSP</bodycontent> |
|
306 |
<attribute> |
|
307 |
<name>test</name> |
|
308 |
<required>true</required> |
|
309 |
<rtexprvalue>true</rtexprvalue> |
|
310 |
</attribute> |
|
311 |
<attribute> |
|
312 |
<name>context</name> |
|
313 |
<required>false</required> |
|
314 |
<rtexprvalue>true</rtexprvalue> |
|
315 |
</attribute> |
|
316 |
</tag> |
|
317 |
<tag> |
|
318 |
<name>otherwise</name> |
|
319 |
<tagclass>org.apache.taglibs.xtags.xpath.OtherwiseTag</tagclass> |
|
320 |
<bodycontent>JSP</bodycontent> |
|
321 |
</tag> |
|
322 |
<tag> |
|
323 |
<name>break</name> |
|
324 |
<tagclass>org.apache.taglibs.xtags.xpath.BreakTag</tagclass> |
|
325 |
<bodycontent>empty</bodycontent> |
|
326 |
</tag> |
|
327 |
<tag> |
|
328 |
<name>if</name> |
|
329 |
<tagclass>org.apache.taglibs.xtags.xpath.IfTag</tagclass> |
|
330 |
<bodycontent>JSP</bodycontent> |
|
331 |
<attribute> |
|
332 |
<name>test</name> |
|
333 |
<required>true</required> |
|
334 |
<rtexprvalue>true</rtexprvalue> |
|
335 |
</attribute> |
|
336 |
<attribute> |
|
337 |
<name>context</name> |
|
338 |
<required>false</required> |
|
339 |
<rtexprvalue>true</rtexprvalue> |
|
340 |
</attribute> |
|
341 |
</tag> |
|
342 |
<tag> |
|
343 |
<name>variable</name> |
|
344 |
<tagclass>org.apache.taglibs.xtags.xpath.VariableTag</tagclass> |
|
345 |
<teiclass>org.apache.taglibs.xtags.xpath.VariableTagExtraInfo</teiclass> |
|
346 |
<bodycontent>empty</bodycontent> |
|
347 |
<attribute> |
|
348 |
<name>id</name> |
|
349 |
<required>true</required> |
|
350 |
<rtexprvalue>false</rtexprvalue> |
|
351 |
</attribute> |
|
352 |
<attribute> |
|
353 |
<name>type</name> |
|
354 |
<required>false</required> |
|
355 |
<rtexprvalue>false</rtexprvalue> |
|
356 |
</attribute> |
|
357 |
<attribute> |
|
358 |
<name>select</name> |
|
359 |
<required>true</required> |
|
360 |
<rtexprvalue>true</rtexprvalue> |
|
361 |
</attribute> |
|
362 |
<attribute> |
|
363 |
<name>context</name> |
|
364 |
<required>false</required> |
|
365 |
<rtexprvalue>true</rtexprvalue> |
|
366 |
</attribute> |
|
367 |
</tag> |
|
368 |
<tag> |
|
369 |
<name>stylesheet</name> |
|
370 |
<tagclass>org.apache.taglibs.xtags.xpath.StylesheetTag</tagclass> |
|
371 |
<bodycontent>JSP</bodycontent> |
|
372 |
<attribute> |
|
373 |
<name>context</name> |
|
374 |
<required>false</required> |
|
375 |
<rtexprvalue>true</rtexprvalue> |
|
376 |
</attribute> |
|
377 |
</tag> |
|
378 |
<tag> |
|
379 |
<name>template</name> |
|
380 |
<tagclass>org.apache.taglibs.xtags.xpath.TemplateTag</tagclass> |
|
381 |
<bodycontent>JSP</bodycontent> |
|
382 |
<attribute> |
|
383 |
<name>match</name> |
|
384 |
<required>true</required> |
|
385 |
<rtexprvalue>true</rtexprvalue> |
|
386 |
</attribute> |
|
387 |
<attribute> |
|
388 |
<name>mode</name> |
|
389 |
<required>false</required> |
|
390 |
<rtexprvalue>true</rtexprvalue> |
|
391 |
</attribute> |
|
392 |
<attribute> |
|
393 |
<name>avt</name> |
|
394 |
<required>false</required> |
|
395 |
<rtexprvalue>true</rtexprvalue> |
|
396 |
</attribute> |
|
397 |
<attribute> |
|
398 |
<name>action</name> |
|
399 |
<required>false</required> |
|
400 |
<rtexprvalue>true</rtexprvalue> |
|
401 |
</attribute> |
|
402 |
</tag> |
|
403 |
<tag> |
|
404 |
<name>applyTemplates</name> |
|
405 |
<tagclass>org.apache.taglibs.xtags.xpath.ApplyTemplatesTag</tagclass> |
|
406 |
<bodycontent>JSP</bodycontent> |
|
407 |
<attribute> |
|
408 |
<name>select</name> |
|
409 |
<required>false</required> |
|
410 |
<rtexprvalue>true</rtexprvalue> |
|
411 |
</attribute> |
|
412 |
<attribute> |
|
413 |
<name>mode</name> |
|
414 |
<required>false</required> |
|
415 |
<rtexprvalue>true</rtexprvalue> |
|
416 |
</attribute> |
|
417 |
</tag> |
|
418 |
<tag> |
|
419 |
<name>element</name> |
|
420 |
<tagclass>org.apache.taglibs.xtags.xpath.ElementTag</tagclass> |
|
421 |
<bodycontent>JSP</bodycontent> |
|
422 |
<attribute> |
|
423 |
<name>name</name> |
|
424 |
<required>true</required> |
|
425 |
<rtexprvalue>true</rtexprvalue> |
|
426 |
</attribute> |
|
427 |
</tag> |
|
428 |
<tag> |
|
429 |
<name>attribute</name> |
|
430 |
<tagclass>org.apache.taglibs.xtags.xpath.AttributeTag</tagclass> |
|
431 |
<bodycontent>JSP</bodycontent> |
|
432 |
<attribute> |
|
433 |
<name>name</name> |
|
434 |
<required>true</required> |
|
435 |
<rtexprvalue>true</rtexprvalue> |
|
436 |
</attribute> |
|
437 |
</tag> |
|
438 |
<tag> |
|
439 |
<name>output</name> |
|
440 |
<tagclass>org.apache.taglibs.xtags.xpath.OutputTag</tagclass> |
|
441 |
<bodycontent>JSP</bodycontent> |
|
442 |
<attribute> |
|
443 |
<name>method</name> |
|
444 |
<required>false</required> |
|
445 |
<rtexprvalue>true</rtexprvalue> |
|
446 |
</attribute> |
|
447 |
<attribute> |
|
448 |
<name>indent</name> |
|
449 |
<required>false</required> |
|
450 |
<rtexprvalue>true</rtexprvalue> |
|
451 |
</attribute> |
|
452 |
<attribute> |
|
453 |
<name>omitXmlDeclaration</name> |
|
454 |
<required>false</required> |
|
455 |
<rtexprvalue>true</rtexprvalue> |
|
456 |
</attribute> |
|
457 |
</tag> |
|
458 |
<tag> |
|
459 |
<name>copy</name> |
|
460 |
<tagclass>org.apache.taglibs.xtags.xpath.CopyTag</tagclass> |
|
461 |
<bodycontent>JSP</bodycontent> |
|
462 |
<attribute> |
|
463 |
<name>select</name> |
|
464 |
<required>true</required> |
|
465 |
<rtexprvalue>true</rtexprvalue> |
|
466 |
</attribute> |
|
467 |
<attribute> |
|
468 |
<name>context</name> |
|
469 |
<required>false</required> |
|
470 |
<rtexprvalue>true</rtexprvalue> |
|
471 |
</attribute> |
|
472 |
</tag> |
|
473 |
<tag> |
|
474 |
<name>copyOf</name> |
|
475 |
<tagclass>org.apache.taglibs.xtags.xpath.CopyOfTag</tagclass> |
|
476 |
<bodycontent>JSP</bodycontent> |
|
477 |
<attribute> |
|
478 |
<name>select</name> |
|
479 |
<required>true</required> |
|
480 |
<rtexprvalue>true</rtexprvalue> |
|
481 |
</attribute> |
|
482 |
<attribute> |
|
483 |
<name>context</name> |
|
484 |
<required>false</required> |
|
485 |
<rtexprvalue>true</rtexprvalue> |
|
486 |
</attribute> |
|
487 |
</tag> |
|
488 |
<tag> |
|
489 |
<name>context</name> |
|
490 |
<tagclass>org.apache.taglibs.xtags.xpath.ContextTag</tagclass> |
|
491 |
<bodycontent>JSP</bodycontent> |
|
492 |
<attribute> |
|
493 |
<name>select</name> |
|
494 |
<required>true</required> |
|
495 |
<rtexprvalue>true</rtexprvalue> |
|
496 |
</attribute> |
|
497 |
<attribute> |
|
498 |
<name>context</name> |
|
499 |
<required>false</required> |
|
500 |
<rtexprvalue>true</rtexprvalue> |
|
501 |
</attribute> |
|
502 |
</tag> |
|
503 |
<tag> |
|
504 |
<name>remove</name> |
|
505 |
<tagclass>org.apache.taglibs.xtags.xpath.RemoveTag</tagclass> |
|
506 |
<bodycontent>empty</bodycontent> |
|
507 |
<attribute> |
|
508 |
<name>select</name> |
|
509 |
<required>true</required> |
|
510 |
<rtexprvalue>true</rtexprvalue> |
|
511 |
</attribute> |
|
512 |
</tag> |
|
513 |
<tag> |
|
514 |
<name>add</name> |
|
515 |
<tagclass>org.apache.taglibs.xtags.xpath.AddTag</tagclass> |
|
516 |
<bodycontent>jsp</bodycontent> |
|
517 |
<attribute> |
|
518 |
<name>before</name> |
|
519 |
<required>false</required> |
|
520 |
<rtexprvalue>true</rtexprvalue> |
|
521 |
</attribute> |
|
522 |
<attribute> |
|
523 |
<name>after</name> |
|
524 |
<required>false</required> |
|
525 |
<rtexprvalue>true</rtexprvalue> |
|
526 |
</attribute> |
|
527 |
</tag> |
|
528 |
<tag> |
|
529 |
<name>replace</name> |
|
530 |
<tagclass>org.apache.taglibs.xtags.xpath.ReplaceTag</tagclass> |
|
531 |
<bodycontent>jsp</bodycontent> |
|
532 |
</tag> |
|
533 |
</taglib> |
|
534 |
|
|
535 |
|
|
536 |
|
|
537 |
|
|
538 |
|
|
539 |
|
|
540 |
|
|
541 |
|
|
542 |
|
|
543 |
|
|
544 |
|
|
545 |
|
|
546 |
|
|
547 |
|
|
548 |
|
|
549 |
|
|
550 |
|
|
551 |
|
|
552 |
|
|
553 |
|
|
554 |
|
|
555 |
|
|
556 | 0 |
lib/spatial/mapbuilder/README | ||
---|---|---|
1 |
mapbuilder-lib |
|
2 |
============== |
|
3 |
|
|
4 |
Installation |
|
5 |
============ |
|
6 |
Download the latest mapbuilder-lib file from |
|
7 |
http://sourceforge.net/projects/mapbuilder |
|
8 |
|
|
9 |
Uncompress the file. |
|
10 |
|
|
11 |
Run |
|
12 |
=== |
|
13 |
You can view an index of demonstration applications by viewing the |
|
14 |
following file in a recent web browser: mapbuilder\example\examples.html |
|
15 |
|
|
16 |
Some demonstrations require mapbuilder to be installed in a web server |
|
17 |
which supports PHP (like Apache), or a Servlet Container (like Tomcat). |
|
18 |
|
|
19 |
Browser Support |
|
20 |
=============== |
|
21 |
Internet Explorer 6+, Netscape 6+, Mozilla 1.3+ are supported. |
|
22 |
(Applications using vector rendering via SVG require Mozilla 1.5+) |
|
23 |
|
|
24 |
Documentation |
|
25 |
============= |
|
26 |
More detailed documentation is available at http://communitymapbuilder.org |
|
27 | 0 |
lib/spatial/mapbuilder/LGPL | ||
---|---|---|
1 |
GNU LESSER GENERAL PUBLIC LICENSE |
|
2 |
Version 2.1, February 1999 |
|
3 |
|
|
4 |
Copyright (C) 1991, 1999 Free Software Foundation, Inc. |
|
5 |
51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
|
6 |
Everyone is permitted to copy and distribute verbatim copies |
|
7 |
of this license document, but changing it is not allowed. |
|
8 |
|
|
9 |
[This is the first released version of the Lesser LGPL. It also counts |
|
10 |
as the successor of the GNU Library Public License, version 2, hence |
|
11 |
the version number 2.1.] |
|
12 |
|
|
13 |
Preamble |
|
14 |
|
|
15 |
The licenses for most software are designed to take away your |
|
16 |
freedom to share and change it. By contrast, the GNU General Public |
|
17 |
Licenses are intended to guarantee your freedom to share and change |
|
18 |
free software--to make sure the software is free for all its users. |
|
19 |
|
|
20 |
This license, the Lesser General Public License, applies to some |
|
21 |
specially designated software packages--typically libraries--of the |
|
22 |
Free Software Foundation and other authors who decide to use it. You |
|
23 |
can use it too, but we suggest you first think carefully about whether |
|
24 |
this license or the ordinary General Public License is the better |
|
25 |
strategy to use in any particular case, based on the explanations below. |
|
26 |
|
|
27 |
When we speak of free software, we are referring to freedom of use, |
|
28 |
not price. Our General Public Licenses are designed to make sure that |
|
29 |
you have the freedom to distribute copies of free software (and charge |
|
30 |
for this service if you wish); that you receive source code or can get |
|
31 |
it if you want it; that you can change the software and use pieces of |
|
32 |
it in new free programs; and that you are informed that you can do |
|
33 |
these things. |
|
34 |
|
|
35 |
To protect your rights, we need to make restrictions that forbid |
|
36 |
distributors to deny you these rights or to ask you to surrender these |
|
37 |
rights. These restrictions translate to certain responsibilities for |
|
38 |
you if you distribute copies of the library or if you modify it. |
|
39 |
|
|
40 |
For example, if you distribute copies of the library, whether gratis |
|
41 |
or for a fee, you must give the recipients all the rights that we gave |
|
42 |
you. You must make sure that they, too, receive or can get the source |
|
43 |
code. If you link other code with the library, you must provide |
|
44 |
complete object files to the recipients, so that they can relink them |
|
45 |
with the library after making changes to the library and recompiling |
|
46 |
it. And you must show them these terms so they know their rights. |
|
47 |
|
|
48 |
We protect your rights with a two-step method: (1) we copyright the |
|
49 |
library, and (2) we offer you this license, which gives you legal |
|
50 |
permission to copy, distribute and/or modify the library. |
|
51 |
|
|
52 |
To protect each distributor, we want to make it very clear that |
|
53 |
there is no warranty for the free library. Also, if the library is |
|
54 |
modified by someone else and passed on, the recipients should know |
|
55 |
that what they have is not the original version, so that the original |
|
56 |
author's reputation will not be affected by problems that might be |
|
57 |
introduced by others. |
|
58 |
|
|
59 |
Finally, software patents pose a constant threat to the existence of |
|
60 |
any free program. We wish to make sure that a company cannot |
|
61 |
effectively restrict the users of a free program by obtaining a |
|
62 |
restrictive license from a patent holder. Therefore, we insist that |
|
63 |
any patent license obtained for a version of the library must be |
|
64 |
consistent with the full freedom of use specified in this license. |
|
65 |
|
|
66 |
Most GNU software, including some libraries, is covered by the |
|
67 |
ordinary GNU General Public License. This license, the GNU Lesser |
|
68 |
General Public License, applies to certain designated libraries, and |
|
69 |
is quite different from the ordinary General Public License. We use |
|
70 |
this license for certain libraries in order to permit linking those |
|
71 |
libraries into non-free programs. |
|
72 |
|
|
73 |
When a program is linked with a library, whether statically or using |
|
74 |
a shared library, the combination of the two is legally speaking a |
|
75 |
combined work, a derivative of the original library. The ordinary |
|
76 |
General Public License therefore permits such linking only if the |
|
77 |
entire combination fits its criteria of freedom. The Lesser General |
|
78 |
Public License permits more lax criteria for linking other code with |
|
79 |
the library. |
|
80 |
|
|
81 |
We call this license the "Lesser" General Public License because it |
|
82 |
does Less to protect the user's freedom than the ordinary General |
|
83 |
Public License. It also provides other free software developers Less |
|
84 |
of an advantage over competing non-free programs. These disadvantages |
|
85 |
are the reason we use the ordinary General Public License for many |
|
86 |
libraries. However, the Lesser license provides advantages in certain |
|
87 |
special circumstances. |
|
88 |
|
|
89 |
For example, on rare occasions, there may be a special need to |
|
90 |
encourage the widest possible use of a certain library, so that it becomes |
|
91 |
a de-facto standard. To achieve this, non-free programs must be |
|
92 |
allowed to use the library. A more frequent case is that a free |
|
93 |
library does the same job as widely used non-free libraries. In this |
|
94 |
case, there is little to gain by limiting the free library to free |
|
95 |
software only, so we use the Lesser General Public License. |
|
96 |
|
|
97 |
In other cases, permission to use a particular library in non-free |
|
98 |
programs enables a greater number of people to use a large body of |
|
99 |
free software. For example, permission to use the GNU C Library in |
|
100 |
non-free programs enables many more people to use the whole GNU |
|
101 |
operating system, as well as its variant, the GNU/Linux operating |
|
102 |
system. |
|
103 |
|
|
104 |
Although the Lesser General Public License is Less protective of the |
|
105 |
users' freedom, it does ensure that the user of a program that is |
|
106 |
linked with the Library has the freedom and the wherewithal to run |
|
107 |
that program using a modified version of the Library. |
|
108 |
|
|
109 |
The precise terms and conditions for copying, distribution and |
|
110 |
modification follow. Pay close attention to the difference between a |
|
111 |
"work based on the library" and a "work that uses the library". The |
|
112 |
former contains code derived from the library, whereas the latter must |
|
113 |
be combined with the library in order to run. |
|
114 |
|
|
115 |
GNU LESSER GENERAL PUBLIC LICENSE |
|
116 |
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION |
|
117 |
|
|
118 |
0. This License Agreement applies to any software library or other |
|
119 |
program which contains a notice placed by the copyright holder or |
|
120 |
other authorized party saying it may be distributed under the terms of |
|
121 |
this Lesser General Public License (also called "this License"). |
|
122 |
Each licensee is addressed as "you". |
|
123 |
|
|
124 |
A "library" means a collection of software functions and/or data |
|
125 |
prepared so as to be conveniently linked with application programs |
|
126 |
(which use some of those functions and data) to form executables. |
|
127 |
|
|
128 |
The "Library", below, refers to any such software library or work |
|
129 |
which has been distributed under these terms. A "work based on the |
|
130 |
Library" means either the Library or any derivative work under |
|
131 |
copyright law: that is to say, a work containing the Library or a |
|
132 |
portion of it, either verbatim or with modifications and/or translated |
|
133 |
straightforwardly into another language. (Hereinafter, translation is |
|
134 |
included without limitation in the term "modification".) |
|
135 |
|
|
136 |
"Source code" for a work means the preferred form of the work for |
|
137 |
making modifications to it. For a library, complete source code means |
|
138 |
all the source code for all modules it contains, plus any associated |
|
139 |
interface definition files, plus the scripts used to control compilation |
|
140 |
and installation of the library. |
|
141 |
|
|
142 |
Activities other than copying, distribution and modification are not |
|
143 |
covered by this License; they are outside its scope. The act of |
|
144 |
running a program using the Library is not restricted, and output from |
|
145 |
such a program is covered only if its contents constitute a work based |
|
146 |
on the Library (independent of the use of the Library in a tool for |
|
147 |
writing it). Whether that is true depends on what the Library does |
|
148 |
and what the program that uses the Library does. |
|
149 |
|
|
150 |
1. You may copy and distribute verbatim copies of the Library's |
|
151 |
complete source code as you receive it, in any medium, provided that |
|
152 |
you conspicuously and appropriately publish on each copy an |
|
153 |
appropriate copyright notice and disclaimer of warranty; keep intact |
|
154 |
all the notices that refer to this License and to the absence of any |
|
155 |
warranty; and distribute a copy of this License along with the |
|
156 |
Library. |
|
157 |
|
|
158 |
You may charge a fee for the physical act of transferring a copy, |
|
159 |
and you may at your option offer warranty protection in exchange for a |
|
160 |
fee. |
|
161 |
|
|
162 |
2. You may modify your copy or copies of the Library or any portion |
|
163 |
of it, thus forming a work based on the Library, and copy and |
|
164 |
distribute such modifications or work under the terms of Section 1 |
|
165 |
above, provided that you also meet all of these conditions: |
|
166 |
|
|
167 |
a) The modified work must itself be a software library. |
|
168 |
|
|
169 |
b) You must cause the files modified to carry prominent notices |
|
170 |
stating that you changed the files and the date of any change. |
|
171 |
|
|
172 |
c) You must cause the whole of the work to be licensed at no |
|
173 |
charge to all third parties under the terms of this License. |
|
174 |
|
|
175 |
d) If a facility in the modified Library refers to a function or a |
|
176 |
table of data to be supplied by an application program that uses |
|
177 |
the facility, other than as an argument passed when the facility |
|
178 |
is invoked, then you must make a good faith effort to ensure that, |
|
179 |
in the event an application does not supply such function or |
|
180 |
table, the facility still operates, and performs whatever part of |
|
181 |
its purpose remains meaningful. |
|
182 |
|
|
183 |
(For example, a function in a library to compute square roots has |
|
184 |
a purpose that is entirely well-defined independent of the |
|
185 |
application. Therefore, Subsection 2d requires that any |
|
186 |
application-supplied function or table used by this function must |
|
187 |
be optional: if the application does not supply it, the square |
|
188 |
root function must still compute square roots.) |
|
189 |
|
|
190 |
These requirements apply to the modified work as a whole. If |
|
191 |
identifiable sections of that work are not derived from the Library, |
|
192 |
and can be reasonably considered independent and separate works in |
|
193 |
themselves, then this License, and its terms, do not apply to those |
|
194 |
sections when you distribute them as separate works. But when you |
|
195 |
distribute the same sections as part of a whole which is a work based |
|
196 |
on the Library, the distribution of the whole must be on the terms of |
|
197 |
this License, whose permissions for other licensees extend to the |
|
198 |
entire whole, and thus to each and every part regardless of who wrote |
|
199 |
it. |
|
200 |
|
|
201 |
Thus, it is not the intent of this section to claim rights or contest |
|
202 |
your rights to work written entirely by you; rather, the intent is to |
|
203 |
exercise the right to control the distribution of derivative or |
|
204 |
collective works based on the Library. |
|
205 |
|
|
206 |
In addition, mere aggregation of another work not based on the Library |
|
207 |
with the Library (or with a work based on the Library) on a volume of |
|
208 |
a storage or distribution medium does not bring the other work under |
|
209 |
the scope of this License. |
|
210 |
|
|
211 |
3. You may opt to apply the terms of the ordinary GNU General Public |
|
212 |
License instead of this License to a given copy of the Library. To do |
|
213 |
this, you must alter all the notices that refer to this License, so |
|
214 |
that they refer to the ordinary GNU General Public License, version 2, |
|
215 |
instead of to this License. (If a newer version than version 2 of the |
|
216 |
ordinary GNU General Public License has appeared, then you can specify |
|
217 |
that version instead if you wish.) Do not make any other change in |
|
218 |
these notices. |
|
219 |
|
|
220 |
Once this change is made in a given copy, it is irreversible for |
|
221 |
that copy, so the ordinary GNU General Public License applies to all |
|
222 |
subsequent copies and derivative works made from that copy. |
|
223 |
|
|
224 |
This option is useful when you wish to copy part of the code of |
|
225 |
the Library into a program that is not a library. |
|
226 |
|
|
227 |
4. You may copy and distribute the Library (or a portion or |
|
228 |
derivative of it, under Section 2) in object code or executable form |
|
229 |
under the terms of Sections 1 and 2 above provided that you accompany |
|
230 |
it with the complete corresponding machine-readable source code, which |
|
231 |
must be distributed under the terms of Sections 1 and 2 above on a |
|
232 |
medium customarily used for software interchange. |
|
233 |
|
|
234 |
If distribution of object code is made by offering access to copy |
|
235 |
from a designated place, then offering equivalent access to copy the |
|
236 |
source code from the same place satisfies the requirement to |
|
237 |
distribute the source code, even though third parties are not |
|
238 |
compelled to copy the source along with the object code. |
|
239 |
|
|
240 |
5. A program that contains no derivative of any portion of the |
|
241 |
Library, but is designed to work with the Library by being compiled or |
|
242 |
linked with it, is called a "work that uses the Library". Such a |
|
243 |
work, in isolation, is not a derivative work of the Library, and |
|
244 |
therefore falls outside the scope of this License. |
|
245 |
|
|
246 |
However, linking a "work that uses the Library" with the Library |
|
247 |
creates an executable that is a derivative of the Library (because it |
|
248 |
contains portions of the Library), rather than a "work that uses the |
|
249 |
library". The executable is therefore covered by this License. |
|
250 |
Section 6 states terms for distribution of such executables. |
|
251 |
|
|
252 |
When a "work that uses the Library" uses material from a header file |
|
253 |
that is part of the Library, the object code for the work may be a |
|
254 |
derivative work of the Library even though the source code is not. |
|
255 |
Whether this is true is especially significant if the work can be |
|
256 |
linked without the Library, or if the work is itself a library. The |
|
257 |
threshold for this to be true is not precisely defined by law. |
|
258 |
|
|
259 |
If such an object file uses only numerical parameters, data |
|
260 |
structure layouts and accessors, and small macros and small inline |
|
261 |
functions (ten lines or less in length), then the use of the object |
|
262 |
file is unrestricted, regardless of whether it is legally a derivative |
|
263 |
work. (Executables containing this object code plus portions of the |
|
264 |
Library will still fall under Section 6.) |
|
265 |
|
|
266 |
Otherwise, if the work is a derivative of the Library, you may |
|
267 |
distribute the object code for the work under the terms of Section 6. |
|
268 |
Any executables containing that work also fall under Section 6, |
|
269 |
whether or not they are linked directly with the Library itself. |
|
270 |
|
|
271 |
6. As an exception to the Sections above, you may also combine or |
|
272 |
link a "work that uses the Library" with the Library to produce a |
|
273 |
work containing portions of the Library, and distribute that work |
|
274 |
under terms of your choice, provided that the terms permit |
|
275 |
modification of the work for the customer's own use and reverse |
|
276 |
engineering for debugging such modifications. |
|
277 |
|
|
278 |
You must give prominent notice with each copy of the work that the |
|
279 |
Library is used in it and that the Library and its use are covered by |
|
280 |
this License. You must supply a copy of this License. If the work |
|
281 |
during execution displays copyright notices, you must include the |
|
282 |
copyright notice for the Library among them, as well as a reference |
|
283 |
directing the user to the copy of this License. Also, you must do one |
|
284 |
of these things: |
|
285 |
|
|
286 |
a) Accompany the work with the complete corresponding |
|
287 |
machine-readable source code for the Library including whatever |
|
288 |
changes were used in the work (which must be distributed under |
|
289 |
Sections 1 and 2 above); and, if the work is an executable linked |
|
290 |
with the Library, with the complete machine-readable "work that |
|
291 |
uses the Library", as object code and/or source code, so that the |
|
292 |
user can modify the Library and then relink to produce a modified |
|
293 |
executable containing the modified Library. (It is understood |
|
294 |
that the user who changes the contents of definitions files in the |
|
295 |
Library will not necessarily be able to recompile the application |
|
296 |
to use the modified definitions.) |
|
297 |
|
|
298 |
b) Use a suitable shared library mechanism for linking with the |
|
299 |
Library. A suitable mechanism is one that (1) uses at run time a |
|
300 |
copy of the library already present on the user's computer system, |
|
301 |
rather than copying library functions into the executable, and (2) |
|
302 |
will operate properly with a modified version of the library, if |
|
303 |
the user installs one, as long as the modified version is |
|
304 |
interface-compatible with the version that the work was made with. |
|
305 |
|
|
306 |
c) Accompany the work with a written offer, valid for at |
|
307 |
least three years, to give the same user the materials |
|
308 |
specified in Subsection 6a, above, for a charge no more |
|
309 |
than the cost of performing this distribution. |
|
310 |
|
|
311 |
d) If distribution of the work is made by offering access to copy |
|
312 |
from a designated place, offer equivalent access to copy the above |
|
313 |
specified materials from the same place. |
|
314 |
|
|
315 |
e) Verify that the user has already received a copy of these |
|
316 |
materials or that you have already sent this user a copy. |
|
317 |
|
|
318 |
For an executable, the required form of the "work that uses the |
|
319 |
Library" must include any data and utility programs needed for |
|
320 |
reproducing the executable from it. However, as a special exception, |
|
321 |
the materials to be distributed need not include anything that is |
|
322 |
normally distributed (in either source or binary form) with the major |
|
323 |
components (compiler, kernel, and so on) of the operating system on |
|
324 |
which the executable runs, unless that component itself accompanies |
|
325 |
the executable. |
|
326 |
|
|
327 |
It may happen that this requirement contradicts the license |
|
328 |
restrictions of other proprietary libraries that do not normally |
|
329 |
accompany the operating system. Such a contradiction means you cannot |
|
330 |
use both them and the Library together in an executable that you |
|
331 |
distribute. |
|
332 |
|
|
333 |
7. You may place library facilities that are a work based on the |
|
334 |
Library side-by-side in a single library together with other library |
|
335 |
facilities not covered by this License, and distribute such a combined |
|
336 |
library, provided that the separate distribution of the work based on |
|
337 |
the Library and of the other library facilities is otherwise |
|
338 |
permitted, and provided that you do these two things: |
|
339 |
|
|
340 |
a) Accompany the combined library with a copy of the same work |
|
341 |
based on the Library, uncombined with any other library |
|
342 |
facilities. This must be distributed under the terms of the |
|
343 |
Sections above. |
|
344 |
|
|
345 |
b) Give prominent notice with the combined library of the fact |
|
346 |
that part of it is a work based on the Library, and explaining |
|
347 |
where to find the accompanying uncombined form of the same work. |
|
348 |
|
|
349 |
8. You may not copy, modify, sublicense, link with, or distribute |
|
350 |
the Library except as expressly provided under this License. Any |
|
351 |
attempt otherwise to copy, modify, sublicense, link with, or |
|
352 |
distribute the Library is void, and will automatically terminate your |
|
353 |
rights under this License. However, parties who have received copies, |
|
354 |
or rights, from you under this License will not have their licenses |
|
355 |
terminated so long as such parties remain in full compliance. |
|
356 |
|
|
357 |
9. You are not required to accept this License, since you have not |
|
358 |
signed it. However, nothing else grants you permission to modify or |
|
359 |
distribute the Library or its derivative works. These actions are |
|
360 |
prohibited by law if you do not accept this License. Therefore, by |
|
361 |
modifying or distributing the Library (or any work based on the |
|
362 |
Library), you indicate your acceptance of this License to do so, and |
|
363 |
all its terms and conditions for copying, distributing or modifying |
|
364 |
the Library or works based on it. |
|
365 |
|
|
366 |
10. Each time you redistribute the Library (or any work based on the |
|
367 |
Library), the recipient automatically receives a license from the |
|
368 |
original licensor to copy, distribute, link with or modify the Library |
|
369 |
subject to these terms and conditions. You may not impose any further |
|
370 |
restrictions on the recipients' exercise of the rights granted herein. |
|
371 |
You are not responsible for enforcing compliance by third parties with |
|
372 |
this License. |
|
373 |
|
|
374 |
11. If, as a consequence of a court judgment or allegation of patent |
|
375 |
infringement or for any other reason (not limited to patent issues), |
|
376 |
conditions are imposed on you (whether by court order, agreement or |
|
377 |
otherwise) that contradict the conditions of this License, they do not |
|
378 |
excuse you from the conditions of this License. If you cannot |
|
379 |
distribute so as to satisfy simultaneously your obligations under this |
|
380 |
License and any other pertinent obligations, then as a consequence you |
|
381 |
may not distribute the Library at all. For example, if a patent |
|
382 |
license would not permit royalty-free redistribution of the Library by |
|
383 |
all those who receive copies directly or indirectly through you, then |
|
384 |
the only way you could satisfy both it and this License would be to |
|
385 |
refrain entirely from distribution of the Library. |
|
386 |
|
|
387 |
If any portion of this section is held invalid or unenforceable under any |
|
388 |
particular circumstance, the balance of the section is intended to apply, |
|
389 |
and the section as a whole is intended to apply in other circumstances. |
|
390 |
|
|
391 |
It is not the purpose of this section to induce you to infringe any |
|
392 |
patents or other property right claims or to contest validity of any |
|
393 |
such claims; this section has the sole purpose of protecting the |
|
394 |
integrity of the free software distribution system which is |
|
395 |
implemented by public license practices. Many people have made |
|
396 |
generous contributions to the wide range of software distributed |
|
397 |
through that system in reliance on consistent application of that |
|
398 |
system; it is up to the author/donor to decide if he or she is willing |
|
399 |
to distribute software through any other system and a licensee cannot |
|
400 |
impose that choice. |
|
401 |
|
|
402 |
This section is intended to make thoroughly clear what is believed to |
|
403 |
be a consequence of the rest of this License. |
|
404 |
|
|
405 |
12. If the distribution and/or use of the Library is restricted in |
|
406 |
certain countries either by patents or by copyrighted interfaces, the |
|
407 |
original copyright holder who places the Library under this License may add |
|
408 |
an explicit geographical distribution limitation excluding those countries, |
|
409 |
so that distribution is permitted only in or among countries not thus |
|
410 |
excluded. In such case, this License incorporates the limitation as if |
|
411 |
written in the body of this License. |
|
412 |
|
|
413 |
13. The Free Software Foundation may publish revised and/or new |
|
414 |
versions of the Lesser General Public License from time to time. |
|
415 |
Such new versions will be similar in spirit to the present version, |
|
416 |
but may differ in detail to address new problems or concerns. |
|
417 |
|
|
418 |
Each version is given a distinguishing version number. If the Library |
|
419 |
specifies a version number of this License which applies to it and |
|
420 |
"any later version", you have the option of following the terms and |
|
421 |
conditions either of that version or of any later version published by |
|
422 |
the Free Software Foundation. If the Library does not specify a |
|
423 |
license version number, you may choose any version ever published by |
|
424 |
the Free Software Foundation. |
|
425 |
|
|
426 |
14. If you wish to incorporate parts of the Library into other free |
|
427 |
programs whose distribution conditions are incompatible with these, |
|
428 |
write to the author to ask for permission. For software which is |
|
429 |
copyrighted by the Free Software Foundation, write to the Free |
|
430 |
Software Foundation; we sometimes make exceptions for this. Our |
|
431 |
decision will be guided by the two goals of preserving the free status |
|
432 |
of all derivatives of our free software and of promoting the sharing |
|
433 |
and reuse of software generally. |
|
434 |
|
|
435 |
NO WARRANTY |
|
436 |
|
|
437 |
15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO |
|
438 |
WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW. |
|
439 |
EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR |
|
440 |
OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY |
|
441 |
KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE |
|
442 |
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
|
443 |
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE |
|
444 |
LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME |
|
445 |
THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. |
|
446 |
|
|
447 |
16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN |
|
448 |
WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY |
|
449 |
AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU |
|
450 |
FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR |
|
451 |
CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE |
|
452 |
LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING |
|
453 |
RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A |
|
454 |
FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF |
|
455 |
SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH |
|
456 |
DAMAGES. |
|
457 |
|
|
458 |
END OF TERMS AND CONDITIONS |
|
459 |
|
|
460 |
How to Apply These Terms to Your New Libraries |
|
461 |
|
|
462 |
If you develop a new library, and you want it to be of the greatest |
|
463 |
possible use to the public, we recommend making it free software that |
|
464 |
everyone can redistribute and change. You can do so by permitting |
|
465 |
redistribution under these terms (or, alternatively, under the terms of the |
|
466 |
ordinary General Public License). |
|
467 |
|
|
468 |
To apply these terms, attach the following notices to the library. It is |
|
469 |
safest to attach them to the start of each source file to most effectively |
|
470 |
convey the exclusion of warranty; and each file should have at least the |
|
471 |
"copyright" line and a pointer to where the full notice is found. |
|
472 |
|
|
473 |
<one line to give the library's name and a brief idea of what it does.> |
|
474 |
Copyright (C) <year> <name of author> |
|
475 |
|
|
476 |
This library is free software; you can redistribute it and/or |
|
477 |
modify it under the terms of the GNU Lesser General Public |
|
478 |
License as published by the Free Software Foundation; either |
|
479 |
version 2.1 of the License, or (at your option) any later version. |
|
480 |
|
|
481 |
This library is distributed in the hope that it will be useful, |
|
482 |
but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
483 |
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|
484 |
Lesser General Public License for more details. |
|
485 |
|
|
486 |
You should have received a copy of the GNU Lesser General Public |
|
487 |
License along with this library; if not, write to the Free Software |
|
488 |
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
|
489 |
|
|
490 |
Also add information on how to contact you by electronic and paper mail. |
|
491 |
|
|
492 |
You should also get your employer (if you work as a programmer) or your |
|
493 |
school, if any, to sign a "copyright disclaimer" for the library, if |
|
494 |
necessary. Here is a sample; alter the names: |
|
495 |
|
|
496 |
Yoyodyne, Inc., hereby disclaims all copyright interest in the |
|
497 |
library `Frob' (a library for tweaking knobs) written by James Random Hacker. |
|
498 |
|
|
499 |
<signature of Ty Coon>, 1 April 1990 |
|
500 |
Ty Coon, President of Vice |
|
501 |
|
|
502 |
That's all there is to it! |
|
503 |
|
|
504 |
|
|
505 | 0 |
lib/spatial/mapbuilder/examples/mapViewer/index.html | ||
---|---|---|
1 |
<?xml version="1.0" encoding="UTF-8"?> |
|
2 |
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN"> |
|
3 |
|
|
4 |
<html xmlns="http://www.w3.org/1999/xhtml" > |
|
5 |
<head> |
|
6 |
<title>Mapbuilder Enhanced Map Viewer</title> |
|
7 |
<link rel='StyleSheet' type='text/css' href='../../lib/skin/default/demoStyles.css'/> |
|
8 |
<link rel='StyleSheet' type='text/css' href='../../lib/skin/default/mapStyle.css'/> |
|
9 |
<link rel='StyleSheet' type='text/css' href='../../lib/skin/default/scalebar-fat.css'/><!-- This style sheet is needed for the scalebar --> |
|
10 |
<script> |
|
11 |
// URL of Mapbuilder configuration file. |
|
12 |
var mbConfigUrl='config.xml'; |
|
13 |
</script> |
|
14 |
<!-- This points to the core mapbuilder library, replaces this with MapbuilderCompressed.js when you want to use the compressed version --> |
|
15 |
<script type="text/javascript" src="../../lib/Mapbuilder.js"></script> |
|
16 |
</head> |
|
17 |
<!-- This onload event starts mapbuilder --> |
|
18 |
<body onload="mbDoLoad()" > |
|
19 |
<!-- |
|
20 |
|
|
21 |
############################# cut here 1 ############################# |
|
22 |
|
|
23 |
--> |
|
24 |
<div id="header"> <!-- The header of the page --> |
|
25 |
<h1><a href="http://communitymapbuilder.org">MapBuilder</a> <!--Version-->1.5-rc2<!--VersionEnd--> Enhanced Map Viewer</h1> |
|
26 |
<!-- The version tag will be inserted into the comment tags above |
|
27 |
during the build process. --> |
|
28 |
<a href="#help" class="help">Explanation</a> |
|
29 |
</div><!-- /header --> |
|
30 |
<div id="middle"><!-- The center piece of the page with left menubar and right mainbody --> |
|
31 |
<div id="exampleList"></div><!-- this is the container where the menubar will be drawn --> |
|
32 |
<!-- |
|
33 |
|
|
34 |
############################# end cut 1 ############################# |
|
35 |
|
|
36 |
--> |
|
37 |
<div id="mainbody"><!-- right side of the middle div, is also divided into two areas --> |
|
38 |
|
|
39 |
<div class="left"> |
|
40 |
|
|
41 |
<div id="locatorMap"></div><!-- This is the container where the small locator map will be drawn --> |
|
42 |
<div id="legend"></div><!-- This is the container where the legend will be drawn --> |
|
43 |
<!-- |
|
44 |
|
|
45 |
############################# cut here 2 ############################# |
|
46 |
|
|
47 |
--> |
|
48 |
<p> |
|
49 |
<a name="help"></a><h3>Explanation</h3> |
|
50 |
This is an enhanced mapviewer. It has some extra functions when compared with the basic map viewer.<br/> |
|
51 |
It adds an <i>extent history</i>, so you can go back to previous viewed extents.<br/> |
|
52 |
It uses the new <i>GetFeatureInfoWSR</i> widget, which uses the WebServiceRequest tool to talk to a WMS server, |
|
53 |
issuing a GetFeatureInfo request. With that you can get more information of an area on the map. <b>Note</b> that the result |
|
54 |
is shown outside the visible area, scroll down to see it. The FeatureInfo widget is used to render the result.<br/> |
|
55 |
A <i>graticule</i> widget which toggles a grid on top of the map.<br/> |
|
56 |
A <i>legend</i> widget which shows the map layers it displays the legend graphic on the other side of the |
|
57 |
map in the <i>legendGraphic</i> container. This is a modification on the stock legend widget.<br/> |
|
58 |
An <i>overview map</i> which shows the current extent on a world map.<br/> |
|
59 |
A <i>scalebar</i> which style is defined by the scalebar stylesheet loaded with the page.<br/> |
|
60 |
An <i>abstract</i> this is only a XSL document which filters the abstract out of a WMC.<br/> |
|
61 |
A <i>maptitle</i> which is also only a XSL document.<p> |
|
62 |
The customisation of the legend is done by using a different XSL document and point the widget to that |
|
63 |
XSL in de config file (using the <stylesheet>< parameter).<br/> |
|
64 |
Customisation of widgets is also possible using a different javascript file |
|
65 |
specified in the config file (with the <scriptfile> parameter). This is used in the <a href="../flickr/index.html">flickr</a> example, for the custom <i>FlickrRest2Wfs</i> widget. |
|
66 |
<br /> |
|
67 |
Have a look at <a href="http://communitymapbuilder.org/display/MAP/Modifying+the+Basic+Examples">this guide</a> if you want to modify this example. |
|
68 |
</p> |
|
69 |
|
|
70 |
<!-- |
|
71 |
|
|
72 |
############################# end cut 2 ############################# |
|
73 |
|
|
74 |
--> |
|
75 |
</div><!-- /left --> |
|
76 |
<div class="right"> |
|
77 |
<h2 id="mapTitle"><!-- This is the container where the maptitle will be drawn, note that it is not a DIV but a H2 element, which works as well --></h2> |
|
78 |
<table cellspacing="0"> |
|
79 |
<tr> |
|
80 |
<td align="center" valign="top"> <!-- right side of page --> |
|
81 |
<table> |
|
82 |
<tr> |
|
83 |
<td id="mainMapPane" valign="top" align="left"><!-- This is the container where the map will be drawn, this time it is a TD element --> |
|
84 |
<td id="legendGraphic" valign="top" align="right"><!-- This is the container where the seperate legend graphic will be drawn --> |
|
85 |
</tr> |
|
86 |
<tr> |
|
87 |
<td valign="top"> |
|
88 |
<table style=" margin:0; padding:0"> |
|
89 |
<tr> |
|
90 |
<td id="mainButtonBar" style="width: 192px" align="left"/><!-- This is the container where the buttons will be drawn --> |
|
91 |
<td id="cursorTrack" align="right"/><!-- This is the container where the coordinates below the mouse will be written --> |
|
92 |
</tr> |
|
93 |
<tr> |
|
94 |
<td/> |
|
95 |
<td id="scalebar"/><!-- This is the container where the scalebar will be drawn --> |
|
96 |
</tr> |
|
97 |
</table> |
|
98 |
</td> |
|
99 |
</tr> |
|
100 |
<tr> |
|
101 |
<td id="workspace" valign="top" colspan="2"/><!-- This is the container where the abstract will be drawn, note that in the config a htmlTagId property is set, which points to this element, also getFeatureInfo will plot its results here --> |
|
102 |
</tr> |
|
103 |
</table> |
|
104 |
</td> |
|
105 |
</tr> |
|
106 |
</table> |
|
107 |
</div><!-- /right --> |
|
108 |
|
|
109 |
</div><!-- /mainbody --> |
|
110 |
<!-- |
|
111 |
|
|
112 |
################### cut here 3 ############################ |
|
113 |
|
|
114 |
--> |
|
115 |
</div><!-- /middle --> |
|
116 |
<div id="footer"> |
|
117 |
<div class="right"> |
|
118 |
<a href="http://communitymapbuilder.org/" title="powered by community mapbuilder"><img src="../../lib/skin/default/images/Icon.gif"/></a> |
|
119 |
<a href="https://www.osgeo.org/" title="member of OSgeo"><img src="../../lib/skin/default/images/Osgeo.png"/></a> |
|
120 |
</div><!-- /right --> |
|
121 |
</div><!-- /footer --> |
|
122 |
<!-- |
|
123 |
|
|
124 |
############################# end cut 3 ############################# |
|
125 |
|
|
126 |
--> |
|
127 |
</body> |
|
128 |
</html> |
lib/spatial/mapbuilder/examples/mapViewer/LegendOpaque.xsl | ||
---|---|---|
1 |
<?xml version="1.0" encoding="UTF-8"?> |
|
2 |
<xsl:stylesheet |
|
3 |
xmlns:wmc="http://www.opengis.net/context" |
|
4 |
xmlns:xsl="http://www.w3.org/1999/XSL/Transform" |
|
5 |
xmlns:gml='http://www.opengis.net/gml' |
|
6 |
xmlns:wfs='http://www.opengis.net/wfs' |
|
7 |
xmlns:xlink='http://www.w3.org/1999/xlink' |
|
8 |
version="1.0"> |
|
9 |
<!-- |
|
10 |
Description: Convert a Web Map Context into a HTML Legend |
|
11 |
Author: Cameron Shorter cameron ATshorter.net |
|
12 |
Licence: LGPL as per: http://www.gnu.org/copyleft/lesser.html |
|
13 |
|
|
14 |
$Id: LegendOpaque.xsl 3907 2008-03-06 10:27:06Z steven $ |
|
15 |
$Name$ |
|
16 |
--> |
|
17 |
<xsl:output method="xml" encoding="utf-8" omit-xml-declaration="yes"/> |
|
18 |
|
|
19 |
<!-- The common params set for all widgets --> |
|
20 |
<xsl:param name="lang">en</xsl:param> |
|
21 |
<xsl:param name="modelId"/> |
|
22 |
<xsl:param name="widgetId"/> |
|
23 |
|
|
24 |
<xsl:param name="skinDir"/> |
|
25 |
<xsl:param name="selectIcon">/images/id.gif</xsl:param> |
|
26 |
|
|
27 |
<!-- Text params for this widget --> |
|
28 |
<xsl:param name="title"/> |
|
29 |
|
|
30 |
<!-- The name of the javascript context object to call --> |
|
31 |
<xsl:param name="featureName"/> |
|
32 |
<xsl:param name="hidden"/> |
|
33 |
<xsl:param name="context">config.objects.<xsl:value-of select="$modelId"/></xsl:param> |
|
34 |
|
|
35 |
<!-- Main html --> |
|
36 |
<xsl:template match="/wmc:ViewContext"> |
|
37 |
<table> |
|
38 |
<tr> |
|
39 |
<th align="left" ><xsl:value-of select="$title"/></th> |
|
40 |
</tr> |
|
41 |
<xsl:choose> |
|
42 |
<xsl:when test="$featureName"> |
|
43 |
<xsl:apply-templates select="wmc:ResourceList[wmc:Name='$featureName'] | wmc:LayerList[wmc:Name='$featureName']"/> |
|
44 |
</xsl:when> |
|
45 |
<xsl:otherwise> |
|
46 |
<xsl:apply-templates select="wmc:ResourceList/* | wmc:LayerList/*"> |
|
47 |
<xsl:sort select="position()" order="descending" data-type="number"/> |
|
48 |
</xsl:apply-templates> |
|
49 |
</xsl:otherwise> |
|
50 |
</xsl:choose> |
|
51 |
</table> |
|
52 |
</xsl:template> |
|
53 |
|
|
54 |
<!-- Layer --> |
|
55 |
<xsl:template match="wmc:Layer"> |
|
56 |
<tr> |
|
57 |
<!-- Visiblity --> |
|
58 |
<td> |
|
59 |
<input id="legend_{wmc:name}"> |
|
60 |
<xsl:choose> |
|
61 |
<xsl:when test="@opaque='1'"> |
|
62 |
<xsl:attribute name="type">radio</xsl:attribute> |
|
63 |
<xsl:attribute name="name">legendGroup</xsl:attribute> |
|
64 |
<xsl:attribute name="onclick">config.objects.<xsl:value-of select="$widgetId"/>.swapOpaqueLayer('<xsl:value-of select="wmc:Name"/>',!this.checked)</xsl:attribute> |
|
65 |
</xsl:when> |
|
66 |
<xsl:otherwise> |
|
67 |
<xsl:attribute name="type">checkbox</xsl:attribute> |
|
68 |
<xsl:attribute name="onclick"><xsl:value-of select="$context"/>.setHidden('<xsl:value-of select="wmc:Name"/>',!this.checked)</xsl:attribute> |
|
69 |
</xsl:otherwise> |
|
70 |
</xsl:choose> |
|
71 |
<xsl:if test="@hidden='0'"><xsl:attribute name="checked">checked</xsl:attribute></xsl:if> |
|
72 |
</input> |
|
73 |
<xsl:choose> |
|
74 |
<xsl:when test="wmc:Title/@xml:lang"> |
|
75 |
<xsl:value-of select="wmc:Title[@xml:lang=$lang]"/> |
|
76 |
</xsl:when> |
|
77 |
<xsl:otherwise> |
|
78 |
<xsl:value-of select="wmc:Title"/> |
|
79 |
</xsl:otherwise> |
|
80 |
</xsl:choose> |
|
81 |
</td> |
|
82 |
</tr> |
|
83 |
<!-- StyleList |
|
84 |
<tr> |
|
85 |
<td></td> |
|
86 |
<td></td> |
|
87 |
<td> |
|
88 |
<xsl:if test="wmc:StyleList/wmc:Style[@current='1']/wmc:LegendURL"> |
|
89 |
<xsl:element name="img"> |
|
90 |
<xsl:attribute name="src"> |
|
91 |
<xsl:value-of select="wmc:StyleList/wmc:Style[@current='1']/wmc:LegendURL/wmc:OnlineResource/@xlink:href"/> |
|
92 |
</xsl:attribute> |
|
93 |
</xsl:element> |
|
94 |
</xsl:if> |
|
95 |
</td> |
|
96 |
</tr> --> |
|
97 |
</xsl:template> |
|
98 |
|
|
99 |
<xsl:template match="text()|@*"/> |
|
100 |
|
|
101 |
</xsl:stylesheet> |
lib/spatial/mapbuilder/examples/mapViewer/bejingWind.xml | ||
---|---|---|
1 |
<ViewContext version="1.1.0" id="bejingWindDemo" xmlns="http://www.opengis.net/context" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.opengis.net/context http://schemas.opengis.net/context/1.1.0/context.xsd"> |
|
2 |
<General> |
|
3 |
<Window width="400" height="378"/> |
|
4 |
<BoundingBox SRS="EPSG:4326" minx="106.440" miny="15.638" maxx="113.640" maxy="22.4420"/> |
|
5 |
<Title>Wind Energy Atlas for Hainan<br/>Environment Canada </Title> |
|
6 |
<KeywordList> |
|
7 |
<Keyword>Canadian wind energy atlas</Keyword> |
|
8 |
<Keyword>canada wind maps</Keyword> |
|
9 |
<Keyword>wind roses and wind speed histograms.wind</Keyword> |
|
10 |
<Keyword>maps</Keyword> |
|
11 |
<Keyword>map</Keyword> |
|
12 |
<Keyword>Canada</Keyword> |
|
13 |
<Keyword>Canada map</Keyword> |
|
14 |
<Keyword>power</Keyword> |
|
15 |
<Keyword>energy</Keyword> |
|
16 |
<Keyword>Environment Canada</Keyword> |
|
17 |
<Keyword>RPN</Keyword> |
|
18 |
<Keyword>WEST</Keyword> |
|
19 |
<Keyword>inVisu</Keyword> |
|
20 |
<Keyword>wind power</Keyword> |
|
21 |
<Keyword>turbine</Keyword> |
|
22 |
<Keyword>formula</Keyword> |
|
23 |
<Keyword>wind rose</Keyword> |
|
24 |
<Keyword>wind speed</Keyword> |
|
25 |
<Keyword>wind energy</Keyword> |
|
26 |
<Keyword>scattergram</Keyword> |
|
27 |
<Keyword>roughness length</Keyword> |
|
28 |
<Keyword>topography</Keyword> |
|
29 |
<Keyword>land/water mask</Keyword> |
|
30 |
</KeywordList> |
|
31 |
<Abstract>A wind mapping software by Environment Canada (EC), <a href='http://www.anemoscope.ca/'>AnemoScope</a>, |
|
32 |
was applied to Hainan Dao (China) in support to the upcoming Open Geospatial Consortium (OGC) Web Services |
|
33 |
Demonstration for the Global Earth Observing System of Systems (GEOSS) Service Network Workshop in Beijing. |
|
34 |
The current web site was designed by Environment Canada in collaboration with Natural Resources Canada. |
|
35 |
The images shown are mean wind speed, wind energy potential, surface properties, etc. |
|
36 |
It is in the Departmental plan to make the existing <a href='http://www.windatlas.ca/'>Canadian Wind Energy Atlas</a> web site |
|
37 |
Web Map Service (WMS) compliant. |
|
38 |
Environment Canada has developed a wind mapping software, Wind Energy Simulation Toolkit (WEST). |
|
39 |
WEST was used to create the <a href='http://www.windatlas.ca/'>Canadian Wind Energy Atlas</a>, and will be |
|
40 |
used for the Chinese Wind Energy Atlas in collaboration with Chinese Meteorological Administration. |
|
41 |
WEST has also been ported to Windows operating system with user-friendly interface under the name of AnemoScope. |
|
42 |
AnemoScope was specially designed for use by wind energy industries not having sophisticated computer facilities. |
|
43 |
</Abstract> |
|
44 |
<LogoURL width="85" height="47" format="image/gif"> |
|
45 |
<OnlineResource xlink:type="simple" xlink:href="http://www.windatlas.ca/theme/icon1.gif"/> |
|
46 |
</LogoURL> |
|
47 |
<DescriptionURL format="text/html"> |
|
48 |
<OnlineResource xlink:type="simple" xlink:href="http://www.windatlas.ca/methodologyHainan.doc"/> |
|
49 |
</DescriptionURL> |
|
50 |
<ContactInformation> |
|
51 |
<ContactPersonPrimary> |
|
52 |
<ContactPerson>Wei Yu</ContactPerson> |
|
53 |
<ContactOrganization>Environment Canada</ContactOrganization> |
|
54 |
</ContactPersonPrimary> |
|
55 |
<ContactPosition>Numeric Modelling Specialist</ContactPosition> |
|
56 |
<ContactAddress> |
|
57 |
<AddressType>postal</AddressType> |
|
58 |
<Address>2121 Trans Canada Highway</Address> |
|
59 |
<City>Dorval</City> |
|
60 |
<StateOrProvince>Quebec</StateOrProvince> |
|
61 |
<PostCode>H9P-1J3</PostCode> |
|
62 |
<Country>Canada</Country> |
|
63 |
</ContactAddress> |
|
64 |
<ContactVoiceTelephone>+01-514-421-4773</ContactVoiceTelephone> |
|
65 |
<ContactFacsimileTelephone>+01-514-421-2106</ContactFacsimileTelephone> |
|
66 |
<ContactElectronicMailAddress>wei.yu@ec.gc.ca</ContactElectronicMailAddress> |
|
67 |
</ContactInformation> |
|
68 |
</General> |
|
69 |
<LayerList> |
|
70 |
<Layer queryable="1" hidden="0" opaque="1"> |
|
71 |
<Server service="OGC:WMS" version="1.1.1" title="Environment Canada Wind Energy Atlas"> |
Also available in: Unified diff
geoserver upgrade:
-remove embedded geoserver
-include geotools api and update spatial harvesting
-include simple template for using maps in skin (openlayers now, not mapbuilder)