All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
org.openlca.git.iterator.DatabaseIterator Maven / Gradle / Ivy
package org.openlca.git.iterator;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Set;
import java.util.stream.Collectors;
import org.eclipse.jgit.lib.FileMode;
import org.eclipse.jgit.lib.ObjectId;
import org.eclipse.jgit.lib.ObjectReader;
import org.openlca.core.model.Category;
import org.openlca.core.model.ModelType;
import org.openlca.core.model.descriptors.RootDescriptor;
import org.openlca.git.repo.ClientRepository;
import org.openlca.git.util.GitUtil;
import org.openlca.git.util.Path;
import org.openlca.util.Strings;
public class DatabaseIterator extends EntryIterator {
private final ClientRepository repo;
public DatabaseIterator(ClientRepository repo) {
this(repo, init(repo));
}
public DatabaseIterator(ClientRepository repo, String path) {
this(repo, init(repo, path));
}
private DatabaseIterator(ClientRepository repo, List entries) {
super(entries);
this.repo = repo;
}
private DatabaseIterator(DatabaseIterator parent, List entries) {
super(parent, entries);
this.repo = parent.repo;
}
private static List init(ClientRepository repo) {
return Arrays.stream(ModelType.values()).filter(type -> {
if (type == ModelType.CATEGORY)
return false;
if (!repo.descriptors.getCategories(type).isEmpty())
return true;
return !repo.descriptors.get(type).isEmpty();
}).map(TreeEntry::new)
.toList();
}
private static List init(ClientRepository repo, String path) {
if (Strings.nullOrEmpty(path))
return init(repo);
if (!path.contains("/")) {
var modelType = ModelType.parse(path);
if (modelType == null)
return new ArrayList<>();
return init(repo, modelType);
}
path = GitUtil.decode(path);
var category = repo.descriptors.getCategory(path);
if (category == null)
return new ArrayList<>();
return init(repo, category);
}
private static List init(ClientRepository repo, ModelType type) {
var entries = repo.descriptors.getCategories(type).stream()
.map(TreeEntry::new)
.collect(Collectors.toList());
entries.addAll(collect(repo, repo.descriptors.get(type)));
return entries;
}
private static List init(ClientRepository repo, Category category) {
var entries = category.childCategories.stream()
.filter(c -> !isFromLibrary(repo, c))
.map(TreeEntry::new)
.collect(Collectors.toList());
entries.addAll(collect(repo, repo.descriptors.get(category)));
if (entries.isEmpty() && !isFromLibrary(repo, category)) {
entries.add(TreeEntry.empty());
}
return entries;
}
private static List collect(ClientRepository repo, Set descriptors) {
var entries = new ArrayList();
for (var d : descriptors) {
if (d.isFromLibrary())
continue;
entries.add(new TreeEntry(d));
if (hasBinaries(repo, d)) {
// must include bin entry, otherwise tree will be different from
// commit tree and diffs will return false results; bin entries
// will be filtered with KnownFilesFilter
entries.add(new TreeEntry(d.refId + "_bin", FileMode.TREE));
}
}
return entries;
}
private static boolean hasBinaries(ClientRepository repo, RootDescriptor d) {
var folder = repo.fileStore.getFolder(d.type, d.refId);
if (!folder.exists())
return false;
var files = folder.listFiles();
return files != null && files.length > 0;
}
private static boolean isFromLibrary(ClientRepository repo, Category category) {
var hasLibrariesElements = false;
for (var model : repo.descriptors.get(category)) {
if (!model.isFromLibrary())
return false;
hasLibrariesElements = true;
}
for (var child : category.childCategories) {
if (!isFromLibrary(repo, child))
return false;
hasLibrariesElements = true;
}
return hasLibrariesElements;
}
@Override
public boolean hasId() {
var path = getPath();
if (path == null)
return false;
if (getEntryData() instanceof RootDescriptor d) {
if (!repo.index.contains(path))
return false;
return repo.index.isSameVersion(path, d);
}
return repo.index.contains(path);
}
@Override
public byte[] idBuffer() {
var path = getPath();
if (path == null)
return GitUtil.getBytes(ObjectId.zeroId());
if (!repo.index.contains(path))
return GitUtil.getBytes(ObjectId.zeroId());
if (!(getEntryData() instanceof RootDescriptor d) || repo.index.isSameVersion(path, d))
return GitUtil.getBytes(repo.index.getObjectId(path));
return GitUtil.getBytes(ObjectId.zeroId());
}
private String getPath() {
var data = getEntryData();
if (data == null)
return null;
if (data instanceof ModelType t)
return Path.of(t);
if (data instanceof Category c)
return Path.of(c);
if (data instanceof RootDescriptor d)
return Path.of(repo.descriptors.categoryPaths, d);
return null;
}
@Override
public int idOffset() {
return 0;
}
@Override
public DatabaseIterator createSubtreeIterator(ObjectReader reader) {
var data = getEntryData();
if (data instanceof ModelType type)
return new DatabaseIterator(this, init(repo, type));
if (data instanceof Category category)
return new DatabaseIterator(this, init(repo, category));
return null;
}
}