Skip to content

Commit

Permalink
DTD Formatting implemented
Browse files Browse the repository at this point in the history
Fixes eclipse-lemminx#221 and eclipse-lemminx#268

Signed-off-by: Nikolas Komonen <[email protected]>
  • Loading branch information
NikolasKomonen authored and fbricon committed Jan 9, 2019
1 parent 23f8355 commit 393ca72
Show file tree
Hide file tree
Showing 24 changed files with 1,432 additions and 437 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -770,7 +770,7 @@ public boolean isDTD() {
*/
public Collection<DOMNode> findDTDAttrList(String elementName) {
DOMDocumentType docType = getDoctype();
if (docType == null) {
if (docType == null || elementName == null) {
return Collections.emptyList();
}
return docType.getChildren().stream().filter(DOMNode::isDTDAttListDecl)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,27 +16,20 @@
* A doctype node.
*
*/
public class DOMDocumentType extends DOMNode implements org.w3c.dom.DocumentType {
public class DOMDocumentType extends DTDDeclNode implements org.w3c.dom.DocumentType {

public enum DocumentTypeKind {
PUBLIC, SYSTEM, INVALID
}

// Offset values relative to start of the XML Document
Integer nameStart, nameEnd;
Integer kindStart, kindEnd;
Integer publicIdStart, publicIdEnd;
Integer systemIdStart, systemIdEnd;
Integer internalSubsetStart, internalSubsetEnd;


private String name;
private String kind; // SYSTEM || PUBLIC
private String publicId;
private String systemId;
private String internalSubset;
DTDDeclParameter name;
DTDDeclParameter kind; // SYSTEM || PUBLIC
DTDDeclParameter publicId;
DTDDeclParameter systemId;
DTDDeclParameter internalSubset;

private String content; // |<!DOCTYPE ... >|
//private String unrecognizedParameters;

public DOMDocumentType(int start, int end, DOMDocument ownerDocument) {
super(start, end, ownerDocument);
Expand All @@ -49,43 +42,30 @@ public String getContent() {
return content;
}

void setEnd(int end) {
this.end = end;
this.content = getOwnerDocument().getText().substring(start, end);
}

/**
* The text immediately after DOCTYPE, "<!DOCTYPE this_is_the_name ..."
*/
@Override
public String getName() {
if (name == null && this.nameStart != null && this.nameEnd != null) {
name = getSubstring(nameStart, nameEnd);
}
return name;
return name != null ? name.getParameter() : null;
}

void setName(int start, int end) {
nameStart = start;
nameEnd = end;
name = addNewParameter(start, end);
}

/**
* @return the DocumentTypeKind
*/
public String getKind() {
if (kind == null && kindStart != null && kindEnd != null) {
kind = getSubstring(kindStart, kindEnd);
}
return kind;
return kind != null ? kind.getParameter() : null;
}

/**
* @param kind the DocumentTypeKind to set
*/
void setKind(int start, int end) {
kindStart = start;
kindEnd = end;
kind = addNewParameter(start, end);
}

/*
Expand Down Expand Up @@ -125,28 +105,31 @@ public NamedNodeMap getEntities() {
*/
@Override
public String getInternalSubset() {
if (internalSubset == null && internalSubsetStart != null && internalSubsetEnd != null) {
internalSubset = getSubstring(internalSubsetStart + 1, internalSubsetEnd - 1);
String subset;
if(internalSubset != null) {
subset = internalSubset.getParameter();
subset = subset.substring(1, subset.length() - 1);
internalSubset.parameter = subset; // Set parameter to a value without '[' and ']'
return subset;

}
return internalSubset;
return null;
}

/**
* Returns the start offset of internal subset and null otherwise.
*
* @return the start offset of internal subset and null otherwise.
*/
public Integer getStartInternalSubset() {
return internalSubsetStart;

public void setStartInternalSubset(int start) {
internalSubset = addNewParameter(start, start + 1);
}

/**
* Returns the end offset of internal subset and null otherwise.
*
* @return the end offset of internal subset and null otherwise.
*/
public Integer getEndInternalSubset() {
return internalSubsetEnd;
public void setEndInternalSubset(int end) {
updateLastParameterEnd(end);
}

public boolean isInternalSubset(DTDDeclParameter parameter) {
if(this.internalSubset != null) {
return this.internalSubset.equals(parameter);
}
return false;
}

/*
Expand All @@ -166,18 +149,18 @@ public NamedNodeMap getNotations() {
*/
@Override
public String getPublicId() {
if (publicId == null && publicIdStart != null && publicIdEnd != null) {
publicId = cleanURL(getSubstring(publicIdStart, publicIdEnd));
}
return publicId;
return publicId != null ? publicId.getParameter() : null;
}

public String getPublicIdWithoutQuotes() {
return publicId != null ? publicId.getParameterWithoutFirstAndLastChar() : null;
}

/**
* @param publicId the publicId to set
*/
void setPublicId(int start, int end) {
publicIdStart = start;
publicIdEnd = end;
publicId = addNewParameter(start, end);
}

/*
Expand All @@ -187,18 +170,18 @@ void setPublicId(int start, int end) {
*/
@Override
public String getSystemId() {
if (systemId == null && systemIdStart != null && systemIdEnd != null) {
systemId = cleanURL(getSubstring(systemIdStart, systemIdEnd));
}
return systemId;
return systemId != null ? systemId.getParameter() : null;
}

public String getSystemIdWithoutQuotes() {
return systemId != null ? systemId.getParameterWithoutFirstAndLastChar() : null;
}

/**
* @param systemId the systemId to set
*/
void setSystemId(int start, int end) {
systemIdStart = start;
systemIdEnd = end;
systemId = addNewParameter(start, end);
}

/**
Expand All @@ -217,6 +200,9 @@ private static String cleanURL(String url) {
}

/**
* Returns a substring of the whole document.
*
*
* Since offset values are relative to 'this.start' we need to
* subtract getStart() to make them relative to 'content'
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -394,6 +394,10 @@ public DOMElement getParentElement() {
return null;
}

public String getNodeAsString() {
return ownerDocument.getText().substring(start, end);
}

public boolean isComment() {
return getNodeType() == DOMNode.COMMENT_NODE;
}
Expand Down
Loading

0 comments on commit 393ca72

Please sign in to comment.