blob: a018b08f096831a0b9b21d1acf11a6adce709328 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2001, 2005 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
*
*******************************************************************************/
package org.eclipse.wst.xml.ui.internal.provisional;
import org.eclipse.jface.text.BadLocationException;
import org.eclipse.wst.sse.ui.internal.provisional.extensions.ISourceEditingTextTools;
import org.eclipse.wst.sse.ui.internal.provisional.extensions.breakpoint.NodeLocation;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
public interface IDOMSourceEditingTextTools extends ISourceEditingTextTools {
/**
* Returns a W3C DOM document
*
* @return Document object or <code>null</code> if corresponding
* document does not exist
*/
Document getDOMDocument();
/**
* Returns the W3C DOM Node at the given offset
*
* @param offset
* the offset within the IDocument
* @return a Node at that location, if one is present
*
* @throws BadLocationException
* for invalid offsets
*/
Node getNode(int offset) throws BadLocationException;
/**
* Returns a NodeLocation object describing the position information of
* the Node's start and end tags.
*
* @param node
* @return The NodeLocation for this Node, null for unsupported Node
* instances.
*/
NodeLocation getNodeLocation(Node node);
/**
* Returns the current server-side page language for the Document of the
* given Node.
*
* @return The server-side page language for this nodem null for Nodes
* within unsupported Documents.
*/
String getPageLanguage(Node node);
/**
* Returns start offset of given Node.
*
* @param node
* w3c <code>Node</code> object to check
* @return the start offset or -1 for unsupported Nodes
*/
int getStartOffset(Node node);
}