information-system-model-do.../src/main/java/org/gcube/informationsystem/utils/documentation/generator/TreeGenerator.java

133 lines
3.8 KiB
Java
Raw Normal View History

2023-01-23 16:21:01 +01:00
package org.gcube.informationsystem.utils.documentation.generator;
2023-01-24 16:54:00 +01:00
import java.io.File;
2023-02-07 14:09:25 +01:00
import java.util.Collection;
2023-01-23 16:21:01 +01:00
import org.gcube.informationsystem.base.reference.AccessType;
2023-02-07 14:09:25 +01:00
import org.gcube.informationsystem.base.reference.Element;
import org.gcube.informationsystem.discovery.ISModelRegistrationProvider;
import org.gcube.informationsystem.discovery.RegistrationProvider;
import org.gcube.informationsystem.tree.Node;
import org.gcube.informationsystem.tree.NodeElaborator;
import org.gcube.informationsystem.tree.Tree;
2023-01-23 16:21:01 +01:00
import org.gcube.informationsystem.types.TypeMapper;
import org.gcube.informationsystem.types.reference.Type;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* @author Luca Frosini (ISTI - CNR)
*/
2023-01-24 16:54:00 +01:00
public class TreeGenerator extends Generator {
2023-01-23 16:21:01 +01:00
private static final Logger logger = LoggerFactory.getLogger(TreeGenerator.class);
2023-02-07 15:18:58 +01:00
public static final String EXTENSION = ".rst";
2023-01-24 16:54:00 +01:00
2023-02-07 14:34:44 +01:00
protected RegistrationProvider rp;
2023-02-07 15:18:58 +01:00
protected boolean splittedFiles;
2023-02-07 14:34:44 +01:00
public TreeGenerator(RegistrationProvider rp) {
super();
this.rp = rp;
2023-02-07 15:18:58 +01:00
this.splittedFiles = false;
}
public void setSplittedFiles(boolean splittedFiles) {
if(rp instanceof ISModelRegistrationProvider && splittedFiles) {
throw new RuntimeException(rp.getModelName() + " documentation can be only produced in a single file");
}
this.splittedFiles = splittedFiles;
2023-01-23 16:21:01 +01:00
}
2023-02-07 14:09:25 +01:00
public void elaborateTree(final AccessType at, Tree<Class<Element>> tree, File file, RegistrationProvider rp) throws Exception {
2023-01-24 19:30:40 +01:00
logger.info("Going to elaborate the following type tree\n{}", tree.toString());
2023-01-24 16:54:00 +01:00
2023-02-07 14:09:25 +01:00
Collection<Package> packages = rp.getPackagesToRegister();
NodeElaborator<Class<Element>> documentationNE = new NodeElaborator<Class<Element>>() {
2023-01-24 17:36:06 +01:00
2023-01-24 16:54:00 +01:00
@Override
2023-02-07 14:09:25 +01:00
public void elaborate(Node<Class<Element>> node, int level) throws Exception {
Class<Element> clz = node.getNodeElement();
if(level!=0 && !packages.contains(clz.getPackage())) {
logger.debug("Discarding {} because it does not belong to {}", clz.getSimpleName(), rp.getModelName());
return;
}
Type type = TypeMapper.createTypeDefinition(clz);
2023-01-24 16:54:00 +01:00
if(level==0) {
/*
* Root node has been already documented in IS_MODEL_FILENAME
* Going to skip it
*/
2023-02-07 14:09:25 +01:00
writeSectionOnly(type, file, level);
2023-01-24 17:36:06 +01:00
} else {
2023-01-24 16:54:00 +01:00
writeTypeToFile(type, file, level);
}
}
2023-02-07 14:09:25 +01:00
2023-01-24 16:54:00 +01:00
};
2023-01-23 16:21:01 +01:00
2023-01-24 18:17:47 +01:00
tree.elaborate(documentationNE);
2023-01-23 16:21:01 +01:00
}
2023-02-07 15:18:58 +01:00
protected String getFileName(AccessType accessType) {
String modelName = rp.getModelName();
StringBuffer stringBuffer = new StringBuffer();
stringBuffer.append(modelName.toLowerCase().replaceAll(" ", "_"));
if(accessType!=null && splittedFiles) {
stringBuffer.append("_");
stringBuffer.append(accessType.getName().toLowerCase());
}
stringBuffer.append(EXTENSION);
return stringBuffer.toString();
}
2023-01-23 16:21:01 +01:00
public void generate() throws Exception {
2023-02-07 15:18:58 +01:00
modelKnowledge.addRegistrationProvider(rp);
2023-02-07 14:09:25 +01:00
modelKnowledge.createKnowledge();
2023-01-24 16:54:00 +01:00
File file = null;
2023-02-07 15:18:58 +01:00
if(!splittedFiles) {
file = getFile(getFileName(null), true);
}
2023-02-07 14:09:25 +01:00
for(AccessType at : AccessType.getModelTypes()) {
2023-02-07 15:18:58 +01:00
if(splittedFiles) {
file = getFile(getFileName(at), true);
}
2023-01-24 16:54:00 +01:00
switch (at) {
case PROPERTY:
break;
2023-02-07 14:09:25 +01:00
case RESOURCE:
2023-02-07 15:18:58 +01:00
if(rp instanceof ISModelRegistrationProvider) {
Type type = TypeMapper.createTypeDefinition(AccessType.ENTITY.getTypeClass());
writeTypeToFile(type, file);
}
2023-02-07 14:09:25 +01:00
break;
2023-01-24 16:54:00 +01:00
2023-02-07 14:09:25 +01:00
case IS_RELATED_TO:
2023-02-07 15:18:58 +01:00
if(rp instanceof ISModelRegistrationProvider) {
Type type = TypeMapper.createTypeDefinition(AccessType.RELATION.getTypeClass());
writeTypeToFile(type, file);
}
2023-02-07 14:09:25 +01:00
break;
2023-01-24 16:54:00 +01:00
default:
break;
}
2023-02-07 14:09:25 +01:00
Tree<Class<Element>> tree = modelKnowledge.getClassesTree(at);
2023-02-07 15:18:58 +01:00
elaborateTree(at, tree, file, rp);
2023-02-07 14:09:25 +01:00
2023-01-23 16:21:01 +01:00
}
}
}