public code v1

This commit is contained in:
Francisco Jesús Martínez Mimbrera
2026-05-23 00:32:57 +02:00
commit 759a8968a2
4357 changed files with 163763 additions and 0 deletions
@@ -0,0 +1,7 @@
<?xml version="1.0" encoding="UTF-8"?>
<classpath>
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.8"/>
<classpathentry kind="con" path="org.eclipse.pde.core.requiredPlugins"/>
<classpathentry kind="src" path="src"/>
<classpathentry kind="output" path="bin"/>
</classpath>
@@ -0,0 +1,14 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>flintstones.group</groupId>
<artifactId>flintstones.bundles</artifactId>
<version>1.0.0-SNAPSHOT</version>
</parent>
<artifactId>flintstones.method.ahp.sort.fuzzy</artifactId>
<version>1.0.0-SNAPSHOT</version>
<packaging>eclipse-plugin</packaging>
<name>[bundle] FuzzyAHPSort</name>
</project>
@@ -0,0 +1,45 @@
<?xml version="1.0" encoding="UTF-8"?>
<projectDescription>
<name>flintstones.method.ahp.sort.fuzzy</name>
<comment></comment>
<projects>
</projects>
<buildSpec>
<buildCommand>
<name>org.eclipse.jdt.core.javabuilder</name>
<arguments>
</arguments>
</buildCommand>
<buildCommand>
<name>org.eclipse.pde.ManifestBuilder</name>
<arguments>
</arguments>
</buildCommand>
<buildCommand>
<name>org.eclipse.pde.SchemaBuilder</name>
<arguments>
</arguments>
</buildCommand>
<buildCommand>
<name>org.eclipse.m2e.core.maven2Builder</name>
<arguments>
</arguments>
</buildCommand>
</buildSpec>
<natures>
<nature>org.eclipse.m2e.core.maven2Nature</nature>
<nature>org.eclipse.pde.PluginNature</nature>
<nature>org.eclipse.jdt.core.javanature</nature>
</natures>
<filteredResources>
<filter>
<id>1779484362621</id>
<name></name>
<type>30</type>
<matcher>
<id>org.eclipse.core.resources.regexFilterMatcher</id>
<arguments>node_modules|\.git|__CREATED_BY_JAVA_LANGUAGE_SERVER__</arguments>
</matcher>
</filter>
</filteredResources>
</projectDescription>
@@ -0,0 +1,2 @@
eclipse.preferences.version=1
encoding/<project>=UTF-8
@@ -0,0 +1,15 @@
eclipse.preferences.version=1
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
org.eclipse.jdt.core.compiler.codegen.methodParameters=do not generate
org.eclipse.jdt.core.compiler.codegen.targetPlatform=11
org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve
org.eclipse.jdt.core.compiler.compliance=11
org.eclipse.jdt.core.compiler.debug.lineNumber=generate
org.eclipse.jdt.core.compiler.debug.localVariable=generate
org.eclipse.jdt.core.compiler.debug.sourceFile=generate
org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
org.eclipse.jdt.core.compiler.problem.enablePreviewFeatures=disabled
org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
org.eclipse.jdt.core.compiler.problem.reportPreviewFeatures=warning
org.eclipse.jdt.core.compiler.release=disabled
org.eclipse.jdt.core.compiler.source=11
@@ -0,0 +1,4 @@
activeProfiles=
eclipse.preferences.version=1
resolveWorkspaceProjects=true
version=1
@@ -0,0 +1,10 @@
Manifest-Version: 1.0
Bundle-ManifestVersion: 2
Bundle-Name: FuzzyAHPSort
Bundle-SymbolicName: flintstones.method.ahp.sort.fuzzy;singleton:=true
Bundle-Version: 1.0.0.qualifier
Automatic-Module-Name: flintstones.method.ahp.sort.fuzzy
Bundle-RequiredExecutionEnvironment: JavaSE-1.8
Require-Bundle: flintstones.entity.validatedmethod,
flintstones.valuation.numeric,
flintstones.model.ahpsort.profileassignment.service
@@ -0,0 +1,5 @@
source.. = src/
output.. = bin/
bin.includes = META-INF/,\
.,\
plugin.xml
@@ -0,0 +1,34 @@
<?xml version="1.0" encoding="UTF-8"?>
<?eclipse version="3.4"?>
<plugin>
<extension
point="flintstones.method.extension">
<method
category="flintstones.entity.method.sorting"
implementation="flintstones.method.ahp.sort.fuzzy.FuzzyAHPSortMethod"
uid="flintstones.method.ahp.sort.fuzzy">
<phase
uid="flintstones.method.sorting.phase.gatheringreferencepoint">
</phase>
<phase
uid="flintstones.method.sorting.phase.criterioncriterion">
</phase>
<phase
uid="flintstones.method.sorting.phase.referencereference">
</phase>
<phase
uid="flintstones.method.sorting.phase.referencepointprofile">
</phase>
<phase
uid="flintstones.method.sorting.phase.profileprofile">
</phase>
<phase
uid="flintstones.method.ahp.sortii.phase.ranking">
</phase>
<phase
uid="flintstones.method.ahp.sort.fuzzy.ranking">
</phase>
</method>
</extension>
</plugin>
@@ -0,0 +1,77 @@
package flintstones.method.ahp.sort.fuzzy;
import javax.inject.Inject;
import org.eclipse.e4.core.contexts.ContextInjectionFactory;
import org.eclipse.e4.core.services.nls.Translation;
import flintstones.entity.problemelement.entities.Criterion;
import flintstones.entity.problemelement.entities.Expert;
import flintstones.entity.problemelement.entities.SortingClass;
import flintstones.entity.problemelement.entities.SortingProfile;
import flintstones.entity.validatedmethod.ValidatedMethod;
import flintstones.entity.valuation.Valuation;
import flintstones.helper.chainvalidator.ChainValidator;
import flintstones.helper.chainvalidator.operation.method.ValuationTypeOperation;
import flintstones.method.ahp.sort.fuzzy.messages.Messages;
import flintstones.model.ahpsort.profileassignment.service.IProfileAssignmentService;
import flintstones.model.problemelement.service.IProblemElementService;
import flintstones.valuation.numeric.NumericValuation;
public class FuzzyAHPSortMethod extends ValidatedMethod {
@Inject
IProblemElementService problemService;
@Inject
IProfileAssignmentService profileService;
@Inject
@Translation
private Messages messages;
@Override
public String getName() {
return messages.method_name; // $NON-NLS-1$
}
protected void reloadValidator() {
validator = ContextInjectionFactory.make(ChainValidator.class, context);
String numProfileEntity = problemMessages.Profile_count;
String numSortingClassEntity = problemMessages.SortingClass_count;
Valuation[] valuations = valuationService.getAll();
String valuationsEntity = valuationMessages.Valuation_entity;
ValuationTypeOperation valuationTypeOperator = new ValuationTypeOperation(valuationsEntity,
NumericValuation.class.getSimpleName(), valuations);
int numProfiles = getProfilesByExpert();
int numSortingClasses = problemService.getAll(SortingClass.Type).length;
if (profileService.getType().equals(SortingProfile.SortingProfileType.Central)) {
validator.setReturn(this.getName()).greaterThan(numSortingClassEntity, numSortingClasses, 0)
.named("numSortingClasses") //$NON-NLS-1$
.greaterThan(numProfileEntity, numProfiles, 0).named("numProfiles")//$NON-NLS-1$
.equals(numProfileEntity, numProfiles, numSortingClasses).named("numProfiles")//$NON-NLS-1$
.custom(valuationTypeOperator).named("valuations");//$NON-NLS-1$
} else {
validator.setReturn(this.getName()).greaterThan(numSortingClassEntity, numSortingClasses, 0)
.named("numSortingClasses") //$NON-NLS-1$
.greaterThan(numProfileEntity, numProfiles, 0).named("numProfiles")//$NON-NLS-1$
.equals(numProfileEntity, numProfiles, numSortingClasses - 1).named("numProfiles")//$NON-NLS-1$
.custom(valuationTypeOperator).named("valuations");//$NON-NLS-1$
}
}
private int getProfilesByExpert() {
int totalNumProfiles = problemService.getAll(SortingProfile.Type).length;
int numExperts = problemService.getAll(Expert.Type).length;
int numCriteria = problemService.getAll(Criterion.Type).length;
if (numExperts > 0 && numCriteria > 0) {
int numProfiles = totalNumProfiles / numExperts;
return numProfiles /= numCriteria;
} else
return totalNumProfiles;
}
}
@@ -0,0 +1,9 @@
package flintstones.method.ahp.sort.fuzzy.messages;
import org.eclipse.e4.core.services.nls.Message;
@Message
@SuppressWarnings("javadoc")
public class Messages {
public String method_name;
}