Ported lib to new is-model utilities

This commit is contained in:
Luca Frosini 2023-02-07 14:09:25 +01:00
parent 183d662403
commit 195a3af39b
9 changed files with 69 additions and 171 deletions

10
pom.xml
View File

@ -75,11 +75,11 @@
<artifactId>logback-classic</artifactId> <artifactId>logback-classic</artifactId>
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<dependency> <!-- <dependency> -->
<groupId>org.gcube.resource-management</groupId> <!-- <groupId>org.gcube.resource-management</groupId> -->
<artifactId>gcube-model</artifactId> <!-- <artifactId>gcube-model</artifactId> -->
<scope>test</scope> <!-- <scope>test</scope> -->
</dependency> <!-- </dependency> -->
</dependencies> </dependencies>
</project> </project>

View File

@ -1,86 +0,0 @@
package org.gcube.informationsystem.utils.documentation.generator;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;
import java.util.ServiceLoader;
import org.gcube.informationsystem.base.reference.AccessType;
import org.gcube.informationsystem.base.reference.Element;
import org.gcube.informationsystem.types.TypeMapper;
import org.gcube.informationsystem.types.reference.Type;
import org.gcube.informationsystem.utils.discovery.ElementSpecilizationDiscovery;
import org.gcube.informationsystem.utils.discovery.RegistrationProvider;
/**
* @author Luca Frosini (ISTI - CNR)
*/
public class ClassesDiscoveryGenerator extends Generator {
protected TreeGenerator treeGenerator;
public ClassesDiscoveryGenerator() {
}
public List<Package> getPackages(){
List<Package> packages = new ArrayList<Package>();
AccessType[] accessTypes = new AccessType[] {
AccessType.PROPERTY,
AccessType.ENTITY,
AccessType.RELATION
};
for(AccessType accessType : accessTypes) {
Class<Element> clz = accessType.getTypeClass();
packages.add(clz.getPackage());
}
return packages;
}
public List<Package> getExtensionsPackages(){
List<Package> packages = new ArrayList<Package>();
ServiceLoader<? extends RegistrationProvider> regsitrationProviders = ServiceLoader
.load(RegistrationProvider.class);
for(RegistrationProvider registrationProvider : regsitrationProviders) {
packages.addAll(registrationProvider.getPackagesToRegister());
}
return packages;
}
public void generate() throws Exception {
List<Package> packages = getPackages();
packages.addAll(getExtensionsPackages());
generate(packages);
}
protected <E extends Element> void discover(AccessType at, List<Package> packages) throws Exception {
ElementSpecilizationDiscovery<E> discovery = new ElementSpecilizationDiscovery<>(at.getTypeClass(), false);
if(Objects.nonNull(packages)) {
for(Package p : packages) {
discovery.addPackage(p);
}
}
discovery.discover();
for(Class<? extends E> clz : discovery.getDiscovered()) {
Type type = TypeMapper.createTypeDefinition(clz);
treeGenerator.addType(type);
}
}
public void generate(List<Package> packages) throws Exception {
treeGenerator = new TreeGenerator();
AccessType[] types = new AccessType[] {
AccessType.PROPERTY,
AccessType.RESOURCE, AccessType.FACET,
AccessType.CONSISTS_OF, AccessType.IS_RELATED_TO};
for(AccessType at : types) {
discover(at, packages);
}
treeGenerator.generate();
}
}

View File

@ -25,14 +25,8 @@ public class Generator {
private static final Logger logger = LoggerFactory.getLogger(Generator.class); private static final Logger logger = LoggerFactory.getLogger(Generator.class);
protected AccessType[] accessTypes;
public Generator() { public Generator() {
accessTypes = new AccessType[] {
AccessType.PROPERTY,
AccessType.ENTITY, AccessType.RESOURCE, AccessType.FACET,
AccessType.RELATION, AccessType.CONSISTS_OF, AccessType.IS_RELATED_TO
};
} }
public Class<? extends DocumentationGenerator> getDocumentationGeneratorClass(AccessType accessType) public Class<? extends DocumentationGenerator> getDocumentationGeneratorClass(AccessType accessType)
@ -132,6 +126,14 @@ public class Generator {
return file; return file;
} }
protected void writeSectionOnly(Type type, File file, Integer level) throws Exception {
DocumentationGenerator dg = getDocumentationGenerator(type);
if(level!=null) {
dg.setLevel(level);
}
StringBuffer sb = dg.generateSection();
Files.write(file.toPath(), sb.toString().getBytes(), StandardOpenOption.APPEND);
}
protected void writeTypeToFile(Type type, File file, Integer level) throws Exception { protected void writeTypeToFile(Type type, File file, Integer level) throws Exception {
DocumentationGenerator dg = getDocumentationGenerator(type); DocumentationGenerator dg = getDocumentationGenerator(type);

View File

@ -1,24 +1,19 @@
package org.gcube.informationsystem.utils.documentation.generator; package org.gcube.informationsystem.utils.documentation.generator;
import java.io.File; import java.io.File;
import java.nio.file.Files; import java.util.Collection;
import java.nio.file.StandardOpenOption; import java.util.ServiceLoader;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.TreeMap;
import org.gcube.informationsystem.base.reference.AccessType; import org.gcube.informationsystem.base.reference.AccessType;
import org.gcube.informationsystem.model.reference.properties.Encrypted; import org.gcube.informationsystem.base.reference.Element;
import org.gcube.informationsystem.model.reference.properties.Header; import org.gcube.informationsystem.discovery.ISModelRegistrationProvider;
import org.gcube.informationsystem.model.reference.properties.PropagationConstraint; import org.gcube.informationsystem.discovery.RegistrationProvider;
import org.gcube.informationsystem.model.reference.properties.Property; import org.gcube.informationsystem.discovery.knowledge.ModelKnowledge;
import org.gcube.informationsystem.tree.Node;
import org.gcube.informationsystem.tree.NodeElaborator;
import org.gcube.informationsystem.tree.Tree;
import org.gcube.informationsystem.types.TypeMapper; import org.gcube.informationsystem.types.TypeMapper;
import org.gcube.informationsystem.types.reference.Type; import org.gcube.informationsystem.types.reference.Type;
import org.gcube.informationsystem.utils.documentation.model.DocumentationGenerator;
import org.gcube.informationsystem.utils.knowledge.Node;
import org.gcube.informationsystem.utils.knowledge.NodeElaborator;
import org.gcube.informationsystem.utils.knowledge.Tree;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
@ -34,62 +29,36 @@ public class TreeGenerator extends Generator {
public static final String ENTITIES_FILENAME = "entities.rst"; public static final String ENTITIES_FILENAME = "entities.rst";
public static final String RELATIONS_FILENAME = "relations.rst"; public static final String RELATIONS_FILENAME = "relations.rst";
protected static final List<Class<? extends Property>> isModelProperties;
static {
isModelProperties = new ArrayList<>();
isModelProperties.add(Header.class);
isModelProperties.add(Encrypted.class);
isModelProperties.add(PropagationConstraint.class);
}
protected Map<AccessType, Tree> types;
public TreeGenerator() { public TreeGenerator() {
types = new TreeMap<>();
} }
public void addType(Type type) { public void elaborateTree(final AccessType at, Tree<Class<Element>> tree, File file, RegistrationProvider rp) throws Exception {
AccessType accessType = type.getAccessType();
if(types.get(accessType)==null) {
Type head = TypeMapper.createTypeDefinition(accessType.getTypeClass());
Tree tree = new Tree(head);
types.put(accessType, tree);
}
if(type.getName().compareTo(accessType.getName())==0) {
// Head has been already added
return;
}
Tree tree = types.get(accessType);
tree.addNode(type);
}
public void elaborateTree(final AccessType at, Tree tree, final File file) throws Exception {
logger.info("Going to elaborate the following type tree\n{}", tree.toString()); logger.info("Going to elaborate the following type tree\n{}", tree.toString());
NodeElaborator documentationNE = new NodeElaborator() { Collection<Package> packages = rp.getPackagesToRegister();
protected void writeSectionOnly(Type type, int level) throws Exception { NodeElaborator<Class<Element>> documentationNE = new NodeElaborator<Class<Element>>() {
DocumentationGenerator dg = getDocumentationGenerator(type);
dg.setLevel(level);
StringBuffer sb = dg.generateSection();
Files.write(file.toPath(), sb.toString().getBytes(), StandardOpenOption.APPEND);
}
@Override @Override
public void elaborate(Node node, int level) throws Exception { public void elaborate(Node<Class<Element>> node, int level) throws Exception {
Type type = node.getType(); 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);
if(level==0) { if(level==0) {
/* /*
* Root node has been already documented in IS_MODEL_FILENAME * Root node has been already documented in IS_MODEL_FILENAME
* Going to skip it * Going to skip it
*/ */
writeSectionOnly(type, level); writeSectionOnly(type, file, level);
} else { } else {
writeTypeToFile(type, file, level); writeTypeToFile(type, file, level);
} }
} }
}; };
tree.elaborate(documentationNE); tree.elaborate(documentationNE);
@ -97,36 +66,49 @@ public class TreeGenerator extends Generator {
public void generate() throws Exception { public void generate() throws Exception {
ModelKnowledge modelKnowledge = ModelKnowledge.getInstance();
modelKnowledge.createKnowledge();
File is = getFile(IS_MODEL_FILENAME, true); File is = getFile(IS_MODEL_FILENAME, true);
File file = null; File file = null;
for(AccessType at : accessTypes) { for(AccessType at : AccessType.getModelTypes()) {
Type type = TypeMapper.createTypeDefinition(at.getTypeClass());
writeTypeToFile(type, is);
switch (at) { switch (at) {
case PROPERTY: case PROPERTY:
file = getFile(PROPERTIES_FILENAME, true); file = getFile(PROPERTIES_FILENAME, true);
for(Class<? extends Property> clz : isModelProperties) {
Type t = TypeMapper.createTypeDefinition(clz);
writeTypeToFile(t, is, 1);
}
break; break;
case ENTITY: case RESOURCE:
file = getFile(ENTITIES_FILENAME, true); file = getFile(ENTITIES_FILENAME, true);
continue; Type type = TypeMapper.createTypeDefinition(AccessType.ENTITY.getTypeClass());
writeTypeToFile(type, is);
break;
case RELATION: case IS_RELATED_TO:
file = getFile(RELATIONS_FILENAME, true); file = getFile(RELATIONS_FILENAME, true);
continue; type = TypeMapper.createTypeDefinition(AccessType.RELATION.getTypeClass());
writeTypeToFile(type, is);
break;
default: default:
break; break;
} }
Tree tree = types.get(at); Type type = TypeMapper.createTypeDefinition(at.getTypeClass());
elaborateTree(at, tree, file); writeTypeToFile(type, is);
Tree<Class<Element>> tree = modelKnowledge.getClassesTree(at);
ServiceLoader<? extends RegistrationProvider> registrationProviders = ServiceLoader
.load(RegistrationProvider.class);
for(RegistrationProvider rp : registrationProviders) {
if(!(rp instanceof ISModelRegistrationProvider)) {
elaborateTree(at, tree, file, rp);
}
}
} }
} }

View File

@ -3,11 +3,11 @@ package org.gcube.informationsystem.utils.documentation.model.entities;
import java.util.Set; import java.util.Set;
import org.gcube.informationsystem.base.reference.AccessType; import org.gcube.informationsystem.base.reference.AccessType;
import org.gcube.informationsystem.discovery.knowledge.UsageKnowledge;
import org.gcube.informationsystem.types.reference.Type; import org.gcube.informationsystem.types.reference.Type;
import org.gcube.informationsystem.types.reference.properties.LinkedEntity; import org.gcube.informationsystem.types.reference.properties.LinkedEntity;
import org.gcube.informationsystem.types.reference.properties.PropertyDefinition; import org.gcube.informationsystem.types.reference.properties.PropertyDefinition;
import org.gcube.informationsystem.utils.documentation.rst.table.Table; import org.gcube.informationsystem.utils.documentation.rst.table.Table;
import org.gcube.informationsystem.utils.knowledge.UsageKnowledge;
/** /**
* @author Luca Frosini (ISTI - CNR) * @author Luca Frosini (ISTI - CNR)

View File

@ -3,11 +3,11 @@ package org.gcube.informationsystem.utils.documentation.model.entities;
import java.util.Set; import java.util.Set;
import org.gcube.informationsystem.base.reference.AccessType; import org.gcube.informationsystem.base.reference.AccessType;
import org.gcube.informationsystem.discovery.knowledge.UsageKnowledge;
import org.gcube.informationsystem.types.reference.Type; import org.gcube.informationsystem.types.reference.Type;
import org.gcube.informationsystem.types.reference.entities.ResourceType; import org.gcube.informationsystem.types.reference.entities.ResourceType;
import org.gcube.informationsystem.types.reference.properties.LinkedEntity; import org.gcube.informationsystem.types.reference.properties.LinkedEntity;
import org.gcube.informationsystem.utils.documentation.rst.table.Table; import org.gcube.informationsystem.utils.documentation.rst.table.Table;
import org.gcube.informationsystem.utils.knowledge.UsageKnowledge;
/** /**
* @author Luca Frosini (ISTI - CNR) * @author Luca Frosini (ISTI - CNR)

View File

@ -3,10 +3,10 @@ package org.gcube.informationsystem.utils.documentation.model.relations;
import java.util.Set; import java.util.Set;
import org.gcube.informationsystem.base.reference.AccessType; import org.gcube.informationsystem.base.reference.AccessType;
import org.gcube.informationsystem.discovery.knowledge.UsageKnowledge;
import org.gcube.informationsystem.types.reference.Type; import org.gcube.informationsystem.types.reference.Type;
import org.gcube.informationsystem.types.reference.properties.LinkedEntity; import org.gcube.informationsystem.types.reference.properties.LinkedEntity;
import org.gcube.informationsystem.utils.documentation.rst.table.Table; import org.gcube.informationsystem.utils.documentation.rst.table.Table;
import org.gcube.informationsystem.utils.knowledge.UsageKnowledge;
/** /**
* @author Luca Frosini (ISTI - CNR) * @author Luca Frosini (ISTI - CNR)

View File

@ -3,10 +3,10 @@ package org.gcube.informationsystem.utils.documentation.model.relations;
import java.util.Set; import java.util.Set;
import org.gcube.informationsystem.base.reference.AccessType; import org.gcube.informationsystem.base.reference.AccessType;
import org.gcube.informationsystem.discovery.knowledge.UsageKnowledge;
import org.gcube.informationsystem.types.reference.Type; import org.gcube.informationsystem.types.reference.Type;
import org.gcube.informationsystem.types.reference.properties.LinkedEntity; import org.gcube.informationsystem.types.reference.properties.LinkedEntity;
import org.gcube.informationsystem.utils.documentation.rst.table.Table; import org.gcube.informationsystem.utils.documentation.rst.table.Table;
import org.gcube.informationsystem.utils.knowledge.UsageKnowledge;
/** /**
* @author Luca Frosini (ISTI - CNR) * @author Luca Frosini (ISTI - CNR)

View File

@ -1,6 +1,6 @@
package org.gcube.informationsystem.utils.documentation; package org.gcube.informationsystem.utils.documentation;
import org.gcube.informationsystem.utils.documentation.generator.ClassesDiscoveryGenerator; import org.gcube.informationsystem.utils.documentation.generator.TreeGenerator;
import org.gcube.informationsystem.utils.documentation.model.DocumentationGenerator; import org.gcube.informationsystem.utils.documentation.model.DocumentationGenerator;
import org.junit.Test; import org.junit.Test;
@ -12,8 +12,8 @@ public class GenerateTest {
@Test @Test
public void testDocGeneration() throws Exception { public void testDocGeneration() throws Exception {
DocumentationGenerator.setDefaultOffsetLevel(2); DocumentationGenerator.setDefaultOffsetLevel(2);
ClassesDiscoveryGenerator documentationGenerator = new ClassesDiscoveryGenerator(); TreeGenerator treeGenerator = new TreeGenerator();
documentationGenerator.generate(); treeGenerator.generate();
} }
} }