de.spricom.dessert.slicing.PackageSlice Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dessert-core Show documentation
Show all versions of dessert-core Show documentation
A library for unit-tests to check the dependencies between classes.
The newest version!
package de.spricom.dessert.slicing;
/*-
* #%L
* Dessert Dependency Assertion Library for Java
* %%
* Copyright (C) 2017 - 2023 Hans Jörg Heßmann
* %%
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* #L%
*/
import java.util.Collections;
import java.util.Map;
import java.util.Set;
/**
* A slice represents (subset of) a single Java package for one concrete root.
* It's elements are .class files contained in the package. A root is either a
* directory in the file-system or a jar file. Hence, each element of a slice is
* unique. (There may be two classes with the same name on the classpath, but
* with the combination of classname and root given by a PackageSlice the class is
* uniquely defined.) A slice may represent a subset of the .class files in a
* package, for example all interfaces, all classes complying some naming
* convention, all classes implementing some interfaces, all inner classes etc.
*/
public class PackageSlice extends PartitionSlice {
private final Map otherPackages;
private PackageSlice(String packageName, Set entries, Map otherPackages) {
super(packageName, entries);
this.otherPackages = otherPackages;
}
public static SlicePartitioner partitioner() {
return new SlicePartitioner() {
@Override
public String partKey(Clazz clazz) {
return clazz.getPackageName();
}
};
}
public static PartitionSliceFactory factory() {
return new PartitionSliceFactory() {
@Override
public PackageSlice createPartSlice(String packageName, Set entries, Map slices) {
return new PackageSlice(packageName, entries, slices);
}
};
}
public String getPackageName() {
return getPartKey();
}
public String getParentPackageName() {
String packageName = getPackageName();
int pos = packageName.lastIndexOf('.');
if (pos == -1) {
return "";
}
return packageName.substring(0, pos);
}
public PackageSlice getParentPackage() {
PackageSlice parentPackage = otherPackages.get(getParentPackageName());
if (parentPackage == null) {
parentPackage = new PackageSlice(getParentPackageName(), Collections.emptySet(), otherPackages);
}
return parentPackage;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy