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 @@
<?flintstones.helper.data.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,17 @@
<?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.valuation.numeric.real.interval.ui</artifactId>
<version>1.0.0-SNAPSHOT</version>
<packaging>eclipse-plugin</packaging>
<name>[bundle] Ui</name>
<organization>
<name>Sinbad2</name>
</organization>
</project>
@@ -0,0 +1,45 @@
<?xml version="1.0" encoding="UTF-8"?>
<projectDescription>
<name>flintstones.valuation.numeric.real.interval.ui</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>1779484362751</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,7 @@
eclipse.preferences.version=1
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8
org.eclipse.jdt.core.compiler.compliance=1.8
org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
org.eclipse.jdt.core.compiler.source=1.8
@@ -0,0 +1,4 @@
activeProfiles=
eclipse.preferences.version=1
resolveWorkspaceProjects=true
version=1
@@ -0,0 +1,19 @@
Manifest-Version: 1.0
Bundle-ManifestVersion: 2
Bundle-Name: Ui
Bundle-SymbolicName: flintstones.valuation.numeric.real.interval.ui;singleton:=true
Bundle-Version: 1.0.0.qualifier
Bundle-Vendor: Sinbad2
Bundle-RequiredExecutionEnvironment: JavaSE-1.8
Automatic-Module-Name: flintstones.valuation.real.interval.ui
Require-Bundle: flintstones.valuation.ui,
flintstones.domain.numeric.real,
flintstones.valuation.numeric.real.interval,
org.eclipse.wb.swt,
org.eclipse.swt,
javax.inject,
flintstones.entity.domain,
flintstones.model.valuation.service,
flintstones.entity.valuation,
flintstones.domain.numeric.integer,
flintstones.model.ui.service
@@ -0,0 +1,5 @@
source.. = src/
output.. = bin/
bin.includes = META-INF/,\
.,\
plugin.xml
@@ -0,0 +1,14 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE xml>
<?eclipse version="3.4"?>
<plugin>
<extension
point="flintstones.valuation.ui.extensionpoint">
<valuation_ui
uid="flintstones.valuation.real.interval.ui"
valuation="flintstones.valuation.real.interval"
valuation_panel="flintstones.valuation.numeric.real.interval.ui.ValuationPanelRealInterval">
</valuation_ui>
</extension>
</plugin>
@@ -0,0 +1,186 @@
package flintstones.valuation.numeric.real.interval.ui;
import java.util.LinkedList;
import java.util.List;
import javax.inject.Inject;
import org.eclipse.e4.core.services.nls.Translation;
import org.eclipse.swt.SWT;
import org.eclipse.swt.graphics.Color;
import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.layout.GridLayout;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Display;
import org.eclipse.swt.widgets.Label;
import org.eclipse.swt.widgets.Spinner;
import org.eclipse.wb.swt.SWTResourceManager;
import flintstones.domain.numeric.NumericDomain;
import flintstones.domain.numeric.real.NumericRealDomain;
import flintstones.entity.valuation.Valuation;
import flintstones.model.ui.service.UiService;
import flintstones.model.valuation.service.IValuationService;
import flintstones.valuation.numeric.real.interval.RealIntervalValuation;
import flintstones.valuation.numeric.real.interval.ui.messages.Messages;
import flintstones.valuation.ui.ValuationPanel;
@SuppressWarnings("javadoc")
public class ValuationPanelRealInterval extends ValuationPanel {
@Inject
IValuationService valuationService;
@Inject
@Translation
private Messages messages;
private Spinner valueSpinnerMin;
private Spinner valueSpinnerMax;
private Label intervalLowerLabel;
private Label intervalUpperLabel;
private double valueMax;
private double valueMin;
@Override
protected void createControls() {
GridLayout layout = new GridLayout(1, false);
layout.verticalSpacing = 15;
this.valuationPart.setLayout(layout);
drawBlock1Title();
drawBlock2Spinners();
}
private void drawBlock1Title() {
Label titleLabel = new Label(this.valuationPart, SWT.NONE);
titleLabel.setFont(SWTResourceManager.getFont("Cantarell", 11, SWT.BOLD)); //$NON-NLS-1$
GridData gd = UiService.setGridData(titleLabel, 0, 0, false, false);
gd.verticalIndent = 15;
titleLabel.setText(this.messages.Interval_evaluation);
titleLabel.setBackground(new Color(Display.getCurrent(), 255, 255, 255));
}
private void drawBlock2Spinners() {
Composite spinnerComposite = new Composite(this.valuationPart, SWT.NONE);
UiService.setGridLayout(spinnerComposite, 1);
UiService.setGridData(spinnerComposite, 9, 9, true, false);
spinnerComposite.setBackground(new Color(Display.getCurrent(), 255, 255, 255));
Composite intervalSpinnerComposite = new Composite(spinnerComposite, SWT.NONE);
UiService.setGridLayout(intervalSpinnerComposite, 2);
UiService.setGridData(intervalSpinnerComposite, 0, 9, true, false);
intervalSpinnerComposite.setBackground(new Color(Display.getCurrent(), 255, 255, 255));
this.intervalLowerLabel = new Label(intervalSpinnerComposite, SWT.NONE);
UiService.setGridData(intervalLowerLabel, 0, 0, false, false);
this.intervalLowerLabel.setText(this.messages.Lower_limit);
this.intervalLowerLabel.setBackground(new Color(Display.getCurrent(), 255, 255, 255));
this.valueSpinnerMin = new Spinner(intervalSpinnerComposite, SWT.BORDER);
GridData gd = UiService.setGridData(valueSpinnerMin, 0, 0, false, true);
gd.widthHint = 80;
this.valueSpinnerMin.setBackground(new Color(Display.getCurrent(), 255, 255, 255));
this.intervalUpperLabel = new Label(intervalSpinnerComposite, SWT.NONE);
UiService.setGridData(intervalUpperLabel, 0, 0, true, true);
this.intervalUpperLabel.setText(this.messages.Upper_limit);
this.intervalUpperLabel.setBackground(new Color(Display.getCurrent(), 255, 255, 255));
this.valueSpinnerMax = new Spinner(intervalSpinnerComposite, SWT.BORDER);
gd = UiService.setGridData(valueSpinnerMax, 0, 0, false, true);
gd.widthHint = 80;
gd.verticalIndent = 10;
this.valueSpinnerMax.setBackground(new Color(Display.getCurrent(), 255, 255, 255));
setSpinnersValue();
this.valueSpinnerMin.addModifyListener(e -> {
ValuationPanelRealInterval.this.valueMin = ValuationPanelRealInterval.this.valueSpinnerMin.getSelection() / 100d;
ValuationPanelRealInterval.this.valueSpinnerMin.setMaximum((int) (ValuationPanelRealInterval.this.valueMax * 100d));
ValuationPanelRealInterval.this.valueSpinnerMax.setMinimum((int) (ValuationPanelRealInterval.this.valueMin * 100d));
ValuationPanelRealInterval.this.selectionChange();
});
this.valueSpinnerMax.addModifyListener(e -> {
ValuationPanelRealInterval.this.valueMax = ValuationPanelRealInterval.this.valueSpinnerMax.getSelection() / 100d;
ValuationPanelRealInterval.this.valueSpinnerMax.setMinimum((int) (ValuationPanelRealInterval.this.valueMin * 100d));
ValuationPanelRealInterval.this.valueSpinnerMin.setMaximum((int) (ValuationPanelRealInterval.this.valueMax * 100d));
ValuationPanelRealInterval.this.selectionChange();
});
}
private void setSpinnersValue() {
if(valuation != null ) {
this.valueMin = ((RealIntervalValuation) this.valuation).getMin();
this.valueMax = ((RealIntervalValuation) this.valuation).getMax();
this.valueSpinnerMin.setDigits(2);
this.valueSpinnerMin.setMaximum((int) (this.valueMax * 100d));
this.valueSpinnerMin.setMinimum((int) (((NumericDomain) this.domain).getMin() * 100d));
this.valueSpinnerMax.setDigits(2);
this.valueSpinnerMax.setMaximum((int) (((NumericDomain) this.domain).getMax() * 100d));
this.valueSpinnerMax.setMinimum((int) (this.valueMin * 100d));
this.valueSpinnerMax.setSelection((int) (this.valueMax * 100d));
this.valueSpinnerMin.setSelection((int) (this.valueMin * 100d));
} else {
if (((NumericRealDomain) this.domain).getInRange()) {
this.valueMin = ((NumericRealDomain) this.domain).getMin();
this.valueMax = ((NumericRealDomain) this.domain).getMax();
this.valueSpinnerMin.setDigits(2);
this.valueSpinnerMin.setMaximum((int) (this.valueMax * 100d));
this.valueSpinnerMin.setMinimum((int) (this.valueMin * 100d));
this.valueSpinnerMax.setDigits(2);
this.valueSpinnerMax.setMaximum((int) (this.valueMax * 100d));
this.valueSpinnerMax.setMinimum((int) (this.valueMin * 100d));
} else {
this.valueMin = 0;
this.valueMax = 0;
this.valueSpinnerMin.setDigits(2);
this.valueSpinnerMin.setMaximum((int) Double.POSITIVE_INFINITY);
this.valueSpinnerMin.setMinimum((int) Double.NEGATIVE_INFINITY);
this.valueSpinnerMax.setDigits(2);
this.valueSpinnerMax.setMaximum((int) Double.POSITIVE_INFINITY);
this.valueSpinnerMax.setMinimum((int) Double.NEGATIVE_INFINITY);
}
}
}
@Override
public Valuation createNewValuation() {
RealIntervalValuation result = null;
if (this.valuation == null) {
result = (RealIntervalValuation) this.valuationService.create(this.domain);
result.setDomain(this.domain);
} else
result = (RealIntervalValuation) this.valuation.clone();
result.setMin(this.valueMin);
result.setMax(this.valueMax);
result.setEvaluated(true);
return result;
}
@Override
public Object getSelection() {
List<Double> minMax = new LinkedList<>();
minMax.add(this.valueMin);
minMax.add(this.valueMax);
return minMax;
}
}
@@ -0,0 +1,14 @@
// This file has been auto-generated
package flintstones.valuation.numeric.real.interval.ui.messages;
import org.eclipse.e4.core.services.nls.Message;
@Message
@SuppressWarnings("javadoc")
public class Messages {
public String Interval_evaluation;
public String Lower_limit;
public String Upper_limit;
}
@@ -0,0 +1,3 @@
Interval_evaluation=Interval evaluation
Lower_limit=Lower limit
Upper_limit=Upper limit
@@ -0,0 +1,3 @@
Interval_evaluation=Interval evaluation
Lower_limit=Lower limit
Upper_limit=Upper limit