2 * Back 2 Browser Bytecode Translator
3 * Copyright (C) 2012 Jaroslav Tulach <jaroslav.tulach@apidesign.org>
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, version 2 of the License.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. Look for COPYING file in the top folder.
16 * If not, see http://opensource.org/licenses/GPL-2.0.
18 package org.apidesign.bck2brwsr.htmlpage;
20 import java.io.IOException;
21 import java.io.InputStream;
22 import java.util.Collections;
25 import java.util.TreeMap;
26 import javax.xml.parsers.DocumentBuilder;
27 import javax.xml.parsers.DocumentBuilderFactory;
28 import org.apidesign.bck2brwsr.core.ExtraJavaScript;
29 import org.w3c.dom.Document;
30 import org.w3c.dom.Element;
31 import org.w3c.dom.Node;
32 import org.w3c.dom.NodeList;
34 @ExtraJavaScript(processByteCode = false, resource = "")
36 private final Map<String,String> ids2Elems = new TreeMap<String, String>();
38 public Set<String> ids() {
39 return Collections.unmodifiableSet(ids2Elems.keySet());
42 public String tagNameForId(String id) {
43 return ids2Elems.get(id);
46 public static ProcessPage readPage(InputStream is) throws IOException {
47 DocumentBuilderFactory f = DocumentBuilderFactory.newInstance();
48 f.setValidating(false);
49 f.setIgnoringComments(true);
53 DocumentBuilder b = f.newDocumentBuilder();
55 } catch (IOException ex) {
57 } catch (Exception e) {
58 throw new IOException(e);
60 Element root = doc.getDocumentElement();
62 ProcessPage pp = new ProcessPage();
67 private void seekForIds(Element e) {
68 String val = e.getAttribute("id");
69 if (val != null && !val.isEmpty()) {
70 String prev = ids2Elems.put(val, e.getTagName());
72 NodeList arr = e.getChildNodes();
73 for (int i = 0; i < arr.getLength(); i++) {
74 final Node n = arr.item(i);
75 if (n instanceof Element) {
76 seekForIds((Element)n);