
cat.inspiracio.html.HTMLDOMImplementation Maven / Gradle / Ivy
/*
Copyright 2015 Alexander Bunkenburg
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package cat.inspiracio.html;
import org.w3c.dom.DOMException;
import org.w3c.dom.DocumentType;
import cat.inspiracio.dom.InitialDOMImplementation;
import cat.inspiracio.lang.NotImplementedException;
/** Builds html5 documents.
*
* Public visibility so that it can be extended.
* */
public class HTMLDOMImplementation
extends InitialDOMImplementation
implements org.w3c.dom.html.HTMLDOMImplementation //maybe don't need this
{
/** Knows how to instantiate elements for each tag. */
private ElementCreator creator=new ElementCreator();
/** protected so that outside of this package, only subclasses can instantiate. */
protected HTMLDOMImplementation(){super();}
/** XXX Investigate the features and return the right value.
* XML 2.0: false
* */
@Override public boolean hasFeature(String feature, String version){
System.out.println("hasFeature(" + feature + ", " + version + ")");
return false;
}
/** Called for newDocument() */
@Override public HTMLDocument createDocument(String namespaceURI, String qualifiedName, DocumentType doctype)throws DOMException{
String title=null;
return createHTMLDocument(title);
}
/** Creates an empty HTMLDocument
.
*
* If the title is not null, already creates the elements html/head/title.
*
* @param title The title of the document to be set as the content of the
* title
element, through a child Text
node.
*
* @return A new HTMLDocument
object.
*/
@Override public HTMLDocument createHTMLDocument(String title) {
HTMLDocumentImp d=new HTMLDocumentImp(this);
if(title!=null)
d.setTitle(title);
return d;
}
/** Register a class as implementation for a custom element.
*
* @param cl A class for the custom element.
* The class must have a public constructor with one parameter of type HTMLDocumentImp
* that calls the super-constructor with two parameters: the same HTMLDocumentImp and the desired tag name.
*
* @param tags Registers the class for these tag names.
*
* There may be zero tag names. In that case, the implementation will try to get the tag name
* from the class by instantiating it (with owner == null) and calling getTagName().
*
* There may be exactly one tag name. That is a usual case.
*
* There may be several tag names. In that case, the constructor of the class must remember the
* tag name.
*
* */
public void register(Class extends HTMLElementImp> cl, String... tags){creator.register(cl, tags);}
/** Creates an element.
* @param d
* @param tag
* */
HTMLElement createElement(HTMLDocumentImp d, String tag){return creator.create(d, tag);}
/** Create an element of this class.
*
* Convenience during java programming: the return type is exact.
*
* Not implemented for all element classes.
*
* Some element classes are used to several tags,
* for those this method does not work.
*
* @param A subinterface of HTMLElement that represents one html element
* @param c The class object
* @return A fresh instance of the element
* @throws NotImplementedException Not (yet) implemented for this interface.
* */
T createElement(HTMLDocumentImp d, Class c){return creator.create(d, c);}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy