="x86-64"
+
+-runproperties.macos: \
+ osgi.ws=cocoa,\
+ osgi.arch=x86_64,\
+ osgi.os=macosx
+
+-runblacklist.macos: \
+ osgi.identity;filter:='(osgi.identity=*linux*)',\
+ osgi.identity;filter:='(osgi.identity=*win32*)',\
+
+-runbundles.macos: \
+ org.eclipse.core.filesystem.macosx;version='[1.3,1.4)',\
+ org.eclipse.equinox.security.macosx;version='[1.101,1.102)',\
+ org.eclipse.swt.cocoa.macosx.x86_64;version='[3.118,3.119)',\
+
diff --git a/cnf.run/launch_win32.bndrun b/cnf.run/launch_win32.bndrun
new file mode 100644
index 0000000..2f7bdd8
--- /dev/null
+++ b/cnf.run/launch_win32.bndrun
@@ -0,0 +1,19 @@
+-include: launch_base.bndrun
+
+-runsystemcapabilities: ${native_capability;osname=Windows;osversion=10;processor=x86_64}
+-runprovidedcapabilities: ${native_capability;osname=Windows;osversion=10;processor=x86_64}
+
+
+-runrequires.win32: \
+ bnd.identity;id='org.eclipse.swt.win32.win32.x86_64',\
+ bnd.identity;id='org.eclipse.core.filesystem.win32.x86_64',\
+ bnd.identity;id='org.eclipse.core.net.win32.x86_64',\
+ bnd.identity;id='org.eclipse.equinox.security.win32.x86_64'
+
+-runbundles.win32: \
+ org.eclipse.core.filesystem.win32.x86_64;version='[1.4.200,1.4.201)',\
+ org.eclipse.core.net.win32.x86_64;version='[1.1.400,1.1.401)',\
+ org.eclipse.equinox.security.win32.x86_64;version='[1.1.200,1.1.201)',\
+ org.eclipse.swt.win32.win32.x86_64;version='[3.112.0,3.112.1)'
+
+-runtrace: true
diff --git a/cnf.run/splash/splash.bmp b/cnf.run/splash/splash.bmp
new file mode 100644
index 0000000..9ee49d6
Binary files /dev/null and b/cnf.run/splash/splash.bmp differ
diff --git a/cnf.run/splash/splash.jpg b/cnf.run/splash/splash.jpg
new file mode 100644
index 0000000..275e83e
Binary files /dev/null and b/cnf.run/splash/splash.jpg differ
diff --git a/cnf.run/src/.keep b/cnf.run/src/.keep
new file mode 100644
index 0000000..e69de29
diff --git a/cnf/.gitignore b/cnf/.gitignore
new file mode 100644
index 0000000..64d5dbd
--- /dev/null
+++ b/cnf/.gitignore
@@ -0,0 +1,2 @@
+/cache/
+local_maven_repo.mvn
\ No newline at end of file
diff --git a/xyz.veronie.bgg.product/.project b/cnf/.project
similarity index 78%
rename from xyz.veronie.bgg.product/.project
rename to cnf/.project
index 4e1ca88..1397bbe 100644
--- a/xyz.veronie.bgg.product/.project
+++ b/cnf/.project
@@ -1,11 +1,11 @@
-
-
- xyz.veronie.bgg.product
-
-
-
-
-
-
-
-
+
+
+ cnf
+
+
+
+
+
+
+
+
diff --git a/cnf/build.bnd b/cnf/build.bnd
new file mode 100644
index 0000000..3203719
--- /dev/null
+++ b/cnf/build.bnd
@@ -0,0 +1,41 @@
+Automatic-Module-Name: ${def;bsn}
+
+-sources: true
+# Always use contracts
+-contract: *
+
+junit: org.apache.servicemix.bundles.junit;version="[4.13,5)"
+-testpath.junit: ${junit}
+
+javac.source: 1.11
+javac.target: 1.11
+
+# fixup for bundles with improper manifest, e.g. 'No metadata for revision *'
+-fixupmessages: \
+ "No metadata for revision"; \
+ restrict:=error;\
+ is:=warning
+
+
+eclipse.version = 4.22
+eclipse.platform.version = R-4.22-202111241800
+
+#The original Eclipse p2 repository, cached by our artifactory for faster access:
+-plugin.1.eclipse.platform: \
+ aQute.bnd.repository.p2.provider.P2Repository; \
+ name = "Eclipse Platform ${eclipse.version}"; \
+ url = "http://download.eclipse.org/eclipse/updates/${eclipse.version}/${eclipse.platform.version}"; \
+ cache = "${build}/cnf/cache"
+
+#The Nexus from Data In Motion, containing bundles to correctly start and export RCP applications
+-plugin.2.geckorcp:\
+ aQute.bnd.repository.maven.pom.provider.BndPomRepository;\
+ name="Gecko Equinox RCP BOM";\
+ releaseUrls="https://repo.maven.apache.org/maven2/";\
+ revision="org.geckoprojects.equinox:org.gecko.bnd.eclipse.bom:1.1.0"
+
+-plugin.3.central = \
+ aQute.bnd.repository.maven.provider.MavenBndRepository; \
+ releaseUrl=https://repo.maven.apache.org/maven2/; \
+ index=${.}/central.maven; \
+ name="Central"
\ No newline at end of file
diff --git a/cnf/central.maven b/cnf/central.maven
new file mode 100644
index 0000000..ee5bd81
--- /dev/null
+++ b/cnf/central.maven
@@ -0,0 +1,5 @@
+org.apache.servicemix.bundles:org.apache.servicemix.bundles.junit:4.13.2_1
+org.slf4j:log4j-over-slf4j:1.7.36
+ch.qos.logback:logback-classic:1.2.11
+ch.qos.logback:logback-core:1.2.11
+io.github.willena:sqlite-jdbc:3.37.2
\ No newline at end of file
diff --git a/cnf/ext/eclipse_plugin_config.bnd b/cnf/ext/eclipse_plugin_config.bnd
new file mode 100644
index 0000000..e590700
--- /dev/null
+++ b/cnf/ext/eclipse_plugin_config.bnd
@@ -0,0 +1,13 @@
+Bundle-ActivationPolicy: lazy
+
+-includeresource.fragment: \
+ -Application.e4xmi,\
+ -fragment.e4xmi,\
+ -fragment_always.e4xmi,\
+ -plugin_customization.ini,\
+ -plugin.xml,\
+ OSGI-INF/=-OSGI-INF,\
+ icons/=-icons,\
+ css/=-css,\
+ schema/=-schema
+
\ No newline at end of file
diff --git a/gradle.properties b/gradle.properties
new file mode 100644
index 0000000..2e5b3ed
--- /dev/null
+++ b/gradle.properties
@@ -0,0 +1,2 @@
+bnd_version=5.3.0
+bnd_snapshots=https://bndtools.jfrog.io/bndtools/libs-snapshot-local
\ No newline at end of file
diff --git a/settings.gradle b/settings.gradle
new file mode 100644
index 0000000..87b4416
--- /dev/null
+++ b/settings.gradle
@@ -0,0 +1,13 @@
+pluginManagement {
+ plugins {
+ id 'biz.aQute.bnd.workspace' version bnd_version
+ }
+ repositories {
+ maven { url bnd_snapshots }
+ gradlePluginPortal()
+ }
+}
+
+plugins {
+ id 'biz.aQute.bnd.workspace'
+}
diff --git a/xyz.veronie.bgg.feature/.project b/xyz.veronie.bgg.feature/.project
deleted file mode 100644
index 8cba78c..0000000
--- a/xyz.veronie.bgg.feature/.project
+++ /dev/null
@@ -1,17 +0,0 @@
-
-
- xyz.veronie.bgg.feature
-
-
-
-
-
- org.eclipse.pde.FeatureBuilder
-
-
-
-
-
- org.eclipse.pde.FeatureNature
-
-
diff --git a/xyz.veronie.bgg.feature/build.properties b/xyz.veronie.bgg.feature/build.properties
deleted file mode 100644
index 82ab19c..0000000
--- a/xyz.veronie.bgg.feature/build.properties
+++ /dev/null
@@ -1 +0,0 @@
-bin.includes = feature.xml
diff --git a/xyz.veronie.bgg.feature/feature.xml b/xyz.veronie.bgg.feature/feature.xml
deleted file mode 100644
index 9029343..0000000
--- a/xyz.veronie.bgg.feature/feature.xml
+++ /dev/null
@@ -1,27 +0,0 @@
-
-
-
-
- [Enter Feature Description here.]
-
-
-
- [Enter Copyright Description here.]
-
-
-
- [Enter License Description here.]
-
-
-
-
-
diff --git a/xyz.veronie.bgg.product/bggtool.product b/xyz.veronie.bgg.product/bggtool.product
deleted file mode 100644
index a0cca8c..0000000
--- a/xyz.veronie.bgg.product/bggtool.product
+++ /dev/null
@@ -1,52 +0,0 @@
-
-
-
-
-
-
-
-
-
- -clearPersistedState
-
- -XstartOnFirstThread -Dorg.eclipse.swt.internal.carbon.smallFonts
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/xyz.veronie.bgg.ui/.classpath b/xyz.veronie.bgg.ui/.classpath
index 148af0e..0fde02f 100644
--- a/xyz.veronie.bgg.ui/.classpath
+++ b/xyz.veronie.bgg.ui/.classpath
@@ -1,18 +1,15 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/xyz.veronie.bgg.ui/.project b/xyz.veronie.bgg.ui/.project
index c10fca4..40ffc58 100644
--- a/xyz.veronie.bgg.ui/.project
+++ b/xyz.veronie.bgg.ui/.project
@@ -1,28 +1,23 @@
-
-
- xyz.veronie.bgg.ui
-
-
-
-
-
- org.eclipse.jdt.core.javabuilder
-
-
-
-
- org.eclipse.pde.ManifestBuilder
-
-
-
-
- org.eclipse.pde.SchemaBuilder
-
-
-
-
-
- org.eclipse.pde.PluginNature
- org.eclipse.jdt.core.javanature
-
-
+
+
+ experiment
+
+
+
+
+
+ org.eclipse.jdt.core.javabuilder
+
+
+
+
+ bndtools.core.bndbuilder
+
+
+
+
+
+ org.eclipse.jdt.core.javanature
+ bndtools.core.bndnature
+
+
diff --git a/xyz.veronie.bgg.ui/META-INF/MANIFEST.MF b/xyz.veronie.bgg.ui/META-INF/MANIFEST.MF
deleted file mode 100644
index 38494a4..0000000
--- a/xyz.veronie.bgg.ui/META-INF/MANIFEST.MF
+++ /dev/null
@@ -1,27 +0,0 @@
-Manifest-Version: 1.0
-Bundle-ManifestVersion: 2
-Bundle-Name: Secondtry
-Bundle-SymbolicName: xyz.veronie.bgg.ui;singleton:=true
-Bundle-Version: 1.0.0.qualifier
-Bundle-ClassPath: lib/sqlite-jdbc-3.34.0.jar,
- swing2swt.jar
-Require-Bundle: org.eclipse.core.runtime,
- org.eclipse.swt,
- org.eclipse.e4.core.di,
- org.eclipse.e4.ui.workbench,
- org.eclipse.e4.ui.di,
- org.eclipse.e4.core.di.extensions,
- javax.annotation,
- org.eclipse.jface,
- org.eclipse.e4.core.services,
- org.eclipse.osgi.services,
- javax.inject,
- org.eclipse.e4.ui.model.workbench
-Bundle-RequiredExecutionEnvironment: JavaSE-1.8
-Import-Package: javax.annotation;version="1.0.0";resolution:=optional,
- javax.inject;version="1.0.0",
- org.eclipse.e4.core.commands,
- org.eclipse.e4.core.contexts;version="1.7.0",
- org.eclipse.e4.ui.model.application.descriptor.basic,
- org.eclipse.e4.ui.model.application.ui.basic
-Automatic-Module-Name: de.wt.secondtry
diff --git a/xyz.veronie.bgg.ui/bnd.bnd b/xyz.veronie.bgg.ui/bnd.bnd
new file mode 100644
index 0000000..3f326a5
--- /dev/null
+++ b/xyz.veronie.bgg.ui/bnd.bnd
@@ -0,0 +1,42 @@
+Bundle-SymbolicName: ${project.name};singleton:=true
+Bundle-Version: 1.0.0.SNAPSHOT
+
+-includeresource: \
+ Application.e4xmi,\
+ plugin.xml
+
+-buildpath: \
+ org.eclipse.swt.cocoa.macosx.x86_64,\
+ org.eclipse.e4.ui.swt.win32,\
+ org.eclipse.jface,\
+ org.eclipse.equinox.preferences,\
+ org.eclipse.osgi,\
+ org.eclipse.e4.core.di.annotations,\
+ javax.inject,\
+ org.eclipse.e4.core.contexts,\
+ org.eclipse.e4.ui.model.workbench,\
+ org.eclipse.e4.ui.workbench,\
+ org.eclipse.e4.core.services,\
+ javax.annotation,\
+ org.eclipse.e4.core.di,\
+ org.eclipse.e4.core.commands,\
+ org.eclipse.core.commands,\
+ org.eclipse.e4.ui.di,\
+ org.eclipse.core.jobs,\
+ org.eclipse.equinox.common,\
+ org.eclipse.tips.ui
+
+
+-privatepackage: \
+ xyz.veronie.bgg.localdb,\
+ xyz.veronie.bgg.result,\
+ xyz.veronie.bgg.result.internal,\
+ xyz.veronie.bgg.types,\
+ xyz.veronie.bgg.ui.dialogs,\
+ xyz.veronie.bgg.ui.filters,\
+ xyz.veronie.bgg.ui.filters.composites,\
+ xyz.veronie.bgg.ui.handlers,\
+ xyz.veronie.bgg.ui.helpers,\
+ xyz.veronie.bgg.ui.parts,\
+ xyz.veronie.bgg.ui.parts.internal,\
+ xyz.veronie.bgg.ui.result
\ No newline at end of file
diff --git a/xyz.veronie.bgg.ui/build.properties b/xyz.veronie.bgg.ui/build.properties
deleted file mode 100644
index 341ccac..0000000
--- a/xyz.veronie.bgg.ui/build.properties
+++ /dev/null
@@ -1,8 +0,0 @@
-output.. = bin/
-bin.includes = META-INF/,\
- plugin.xml,\
- Application.e4xmi,\
- lib/,\
- ./,\
- lib/sqlite-jdbc-3.34.0.jar
-source.lib/sqlite-jdbc-3.34.0.jar = src/
diff --git a/xyz.veronie.bgg.ui/src/org/eclipse/wb/swt/ResourceManager.java b/xyz.veronie.bgg.ui/src/org/eclipse/wb/swt/ResourceManager.java
deleted file mode 100644
index 8e96dfe..0000000
--- a/xyz.veronie.bgg.ui/src/org/eclipse/wb/swt/ResourceManager.java
+++ /dev/null
@@ -1,438 +0,0 @@
-/*******************************************************************************
- * Copyright (c) 2011 Google, Inc. and others
- * All rights reserved. This program and the accompanying materials
- * are made available under the terms of the Eclipse Public License v1.0
- * which accompanies this distribution, and is available at
- * http://www.eclipse.org/legal/epl-v10.html
- *
- * Contributors:
- * Google, Inc. - initial API and implementation
- * Wim Jongman - 1.8 and higher compliance
- *******************************************************************************/
-package org.eclipse.wb.swt;
-
-import java.io.File;
-import java.io.InputStream;
-import java.lang.reflect.Constructor;
-import java.lang.reflect.Method;
-import java.net.MalformedURLException;
-import java.net.URL;
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.Map;
-
-import org.eclipse.core.runtime.Platform;
-import org.eclipse.jface.resource.CompositeImageDescriptor;
-import org.eclipse.jface.resource.ImageDescriptor;
-import org.eclipse.swt.graphics.Image;
-import org.eclipse.swt.graphics.ImageData;
-import org.eclipse.swt.graphics.ImageDataProvider;
-import org.eclipse.swt.graphics.Point;
-import org.eclipse.swt.graphics.Rectangle;
-import org.osgi.framework.Bundle;
-
-/**
- * Utility class for managing OS resources associated with SWT/JFace controls
- * such as colors, fonts, images, etc.
- *
- * This class is created automatically when you fiddle around with images and
- * colors in WB. You might want to prevent your application from using this
- * class and provide your own more effective means of resource caching.
- *
- * Even though this class can be used to manage these resources, if they are
- * here for the duration of the application and not used then you still have an
- * effective resource leak.
- *
- * Application code must explicitly invoke the dispose()
method to
- * release the operating system resources managed by cached objects when those
- * objects and OS resources are no longer needed.
- *
- * This class may be freely distributed as part of any application or plugin.
- *
- *
- * @author scheglov_ke
- * @author Dan Rubel
- * @author Wim Jongman
- */
-public class ResourceManager extends SWTResourceManager {
-
- /**
- * The map where we store our images.
- */
- private static Map m_descriptorImageMap = new HashMap();
-
- /**
- * Returns an {@link ImageDescriptor} stored in the file at the specified path
- * relative to the specified class.
- *
- * @param clazz the {@link Class} relative to which to find the image
- * descriptor.
- * @param path the path to the image file.
- * @return the {@link ImageDescriptor} stored in the file at the specified path.
- */
- public static ImageDescriptor getImageDescriptor(Class> clazz, String path) {
- return ImageDescriptor.createFromFile(clazz, path);
- }
-
- /**
- * Returns an {@link ImageDescriptor} stored in the file at the specified path.
- *
- * @param path the path to the image file.
- * @return the {@link ImageDescriptor} stored in the file at the specified path.
- */
- public static ImageDescriptor getImageDescriptor(String path) {
- try {
- return ImageDescriptor.createFromURL(new File(path).toURI().toURL());
- } catch (MalformedURLException e) {
- return null;
- }
- }
-
- /**
- * Returns an {@link Image} based on the specified {@link ImageDescriptor}.
- *
- * @param descriptor the {@link ImageDescriptor} for the {@link Image}.
- * @return the {@link Image} based on the specified {@link ImageDescriptor}.
- */
- public static Image getImage(ImageDescriptor descriptor) {
- if (descriptor == null) {
- return null;
- }
- Image image = m_descriptorImageMap.get(descriptor);
- if (image == null) {
- image = descriptor.createImage();
- m_descriptorImageMap.put(descriptor, image);
- }
- return image;
- }
-
- /**
- * Maps images to decorated images.
- */
- @SuppressWarnings("unchecked")
- private static Map>[] m_decoratedImageMap = new Map[LAST_CORNER_KEY];
-
- /**
- * Returns an {@link Image} composed of a base image decorated by another image.
- *
- * @param baseImage the base {@link Image} that should be decorated.
- * @param decorator the {@link Image} to decorate the base image.
- * @return {@link Image} The resulting decorated image.
- */
- public static Image decorateImage(Image baseImage, Image decorator) {
- return decorateImage(baseImage, decorator, BOTTOM_RIGHT);
- }
-
- /**
- * Returns an {@link Image} composed of a base image decorated by another image.
- *
- * @param baseImage
- * the base {@link Image} that should be decorated.
- * @param decorator
- * the {@link Image} to decorate the base image.
- * @param corner
- * the corner to place decorator image.
- * @return the resulting decorated {@link Image}.
- */
- public static Image decorateImage(final Image baseImage, final Image decorator, final int corner) {
- if (corner <= 0 || corner >= LAST_CORNER_KEY) {
- throw new IllegalArgumentException("Wrong decorate corner");
- }
- Map> cornerDecoratedImageMap = m_decoratedImageMap[corner];
- if (cornerDecoratedImageMap == null) {
- cornerDecoratedImageMap = new HashMap>();
- m_decoratedImageMap[corner] = cornerDecoratedImageMap;
- }
- Map decoratedMap = cornerDecoratedImageMap.get(baseImage);
- if (decoratedMap == null) {
- decoratedMap = new HashMap();
- cornerDecoratedImageMap.put(baseImage, decoratedMap);
- }
- //
- Image result = decoratedMap.get(decorator);
- if (result == null) {
- final Rectangle bib = baseImage.getBounds();
- final Rectangle dib = decorator.getBounds();
- final Point baseImageSize = new Point(bib.width, bib.height);
- CompositeImageDescriptor compositImageDesc = new CompositeImageDescriptor() {
- @Override
- protected void drawCompositeImage(int width, int height) {
- drawImage(createCachedImageDataProvider(baseImage), 0, 0);
- if (corner == TOP_LEFT) {
- drawImage(getUnzoomedImageDataProvider(decorator.getImageData()) , 0, 0);
- } else if (corner == TOP_RIGHT) {
- drawImage(getUnzoomedImageDataProvider(decorator.getImageData()), bib.width - dib.width, 0);
- } else if (corner == BOTTOM_LEFT) {
- drawImage(getUnzoomedImageDataProvider(decorator.getImageData()), 0, bib.height - dib.height);
- } else if (corner == BOTTOM_RIGHT) {
- drawImage(getUnzoomedImageDataProvider(decorator.getImageData()), bib.width - dib.width, bib.height - dib.height);
- }
- }
- @Override
- protected Point getSize() {
- return baseImageSize;
- }
- };
- //
- result = compositImageDesc.createImage();
- decoratedMap.put(decorator, result);
- }
- return result;
- }
-
- private static ImageDataProvider getUnzoomedImageDataProvider(ImageData imageData) {
- return zoom -> zoom == 100 ? imageData : null;
- }
-
-
- /**
- * Dispose all of the cached images.
- */
- public static void disposeImages() {
- SWTResourceManager.disposeImages();
- // dispose ImageDescriptor images
- {
- for (Iterator I = m_descriptorImageMap.values().iterator(); I.hasNext();) {
- I.next().dispose();
- }
- m_descriptorImageMap.clear();
- }
- // dispose decorated images
- for (int i = 0; i < m_decoratedImageMap.length; i++) {
- Map> cornerDecoratedImageMap = m_decoratedImageMap[i];
- if (cornerDecoratedImageMap != null) {
- for (Map decoratedMap : cornerDecoratedImageMap.values()) {
- for (Image image : decoratedMap.values()) {
- image.dispose();
- }
- decoratedMap.clear();
- }
- cornerDecoratedImageMap.clear();
- }
- }
- // dispose plugin images
- {
- for (Iterator I = m_URLImageMap.values().iterator(); I.hasNext();) {
- I.next().dispose();
- }
- m_URLImageMap.clear();
- }
- }
-
- ////////////////////////////////////////////////////////////////////////////
- //
- // Plugin images support
- //
- ////////////////////////////////////////////////////////////////////////////
- /**
- * Maps URL to images.
- */
- private static Map m_URLImageMap = new HashMap();
-
- /**
- * Provider for plugin resources, used by WindowBuilder at design time.
- */
- public interface PluginResourceProvider {
- URL getEntry(String symbolicName, String path);
- }
-
- /**
- * Instance of {@link PluginResourceProvider}, used by WindowBuilder at design
- * time.
- */
- private static PluginResourceProvider m_designTimePluginResourceProvider = null;
-
- /**
- * Returns an {@link Image} based on a plugin and file path.
- *
- * @param plugin the plugin {@link Object} containing the image
- * @param name the path to the image within the plugin
- * @return the {@link Image} stored in the file at the specified path
- *
- * @deprecated Use {@link #getPluginImage(String, String)} instead.
- */
- @Deprecated
- public static Image getPluginImage(Object plugin, String name) {
- try {
- URL url = getPluginImageURL(plugin, name);
- if (url != null) {
- return getPluginImageFromUrl(url);
- }
- } catch (Throwable e) {
- // Ignore any exceptions
- }
- return null;
- }
-
- /**
- * Returns an {@link Image} based on a {@link Bundle} and resource entry path.
- *
- * @param symbolicName the symbolic name of the {@link Bundle}.
- * @param path the path of the resource entry.
- * @return the {@link Image} stored in the file at the specified path.
- */
- public static Image getPluginImage(String symbolicName, String path) {
- try {
- URL url = getPluginImageURL(symbolicName, path);
- if (url != null) {
- return getPluginImageFromUrl(url);
- }
- } catch (Throwable e) {
- // Ignore any exceptions
- }
- return null;
- }
-
- /**
- * Returns an {@link Image} based on given {@link URL}.
- */
- private static Image getPluginImageFromUrl(URL url) {
- try {
- try {
- String key = url.toExternalForm();
- Image image = m_URLImageMap.get(key);
- if (image == null) {
- InputStream stream = url.openStream();
- try {
- image = getImage(stream);
- m_URLImageMap.put(key, image);
- } finally {
- stream.close();
- }
- }
- return image;
- } catch (Throwable e) {
- // Ignore any exceptions
- }
- } catch (Throwable e) {
- // Ignore any exceptions
- }
- return null;
- }
-
- /**
- * Returns an {@link ImageDescriptor} based on a plugin and file path.
- *
- * @param plugin the plugin {@link Object} containing the image.
- * @param name the path to th eimage within the plugin.
- * @return the {@link ImageDescriptor} stored in the file at the specified path.
- *
- * @deprecated Use {@link #getPluginImageDescriptor(String, String)} instead.
- */
- @Deprecated
- public static ImageDescriptor getPluginImageDescriptor(Object plugin, String name) {
- try {
- try {
- URL url = getPluginImageURL(plugin, name);
- return ImageDescriptor.createFromURL(url);
- } catch (Throwable e) {
- // Ignore any exceptions
- }
- } catch (Throwable e) {
- // Ignore any exceptions
- }
- return null;
- }
-
- /**
- * Returns an {@link ImageDescriptor} based on a {@link Bundle} and resource
- * entry path.
- *
- * @param symbolicName the symbolic name of the {@link Bundle}.
- * @param path the path of the resource entry.
- * @return the {@link ImageDescriptor} based on a {@link Bundle} and resource
- * entry path.
- */
- public static ImageDescriptor getPluginImageDescriptor(String symbolicName, String path) {
- try {
- URL url = getPluginImageURL(symbolicName, path);
- if (url != null) {
- return ImageDescriptor.createFromURL(url);
- }
- } catch (Throwable e) {
- // Ignore any exceptions
- }
- return null;
- }
-
- /**
- * Returns an {@link URL} based on a {@link Bundle} and resource entry path.
- */
- private static URL getPluginImageURL(String symbolicName, String path) {
- // try runtime plugins
- {
- Bundle bundle = Platform.getBundle(symbolicName);
- if (bundle != null) {
- return bundle.getEntry(path);
- }
- }
- // try design time provider
- if (m_designTimePluginResourceProvider != null) {
- return m_designTimePluginResourceProvider.getEntry(symbolicName, path);
- }
- // no such resource
- return null;
- }
-
- /**
- * Returns an {@link URL} based on a plugin and file path.
- *
- * @param plugin the plugin {@link Object} containing the file path.
- * @param name the file path.
- * @return the {@link URL} representing the file at the specified path.
- * @throws Exception
- */
- private static URL getPluginImageURL(Object plugin, String name) throws Exception {
- // try to work with 'plugin' as with OSGI BundleContext
- try {
- Class> BundleClass = Class.forName("org.osgi.framework.Bundle"); //$NON-NLS-1$
- Class> BundleContextClass = Class.forName("org.osgi.framework.BundleContext"); //$NON-NLS-1$
- if (BundleContextClass.isAssignableFrom(plugin.getClass())) {
- Method getBundleMethod = BundleContextClass.getMethod("getBundle", new Class[0]); //$NON-NLS-1$
- Object bundle = getBundleMethod.invoke(plugin, new Object[0]);
- //
- Class> PathClass = Class.forName("org.eclipse.core.runtime.Path"); //$NON-NLS-1$
- Constructor> pathConstructor = PathClass.getConstructor(new Class[] { String.class });
- Object path = pathConstructor.newInstance(new Object[] { name });
- //
- Class> IPathClass = Class.forName("org.eclipse.core.runtime.IPath"); //$NON-NLS-1$
- Class> PlatformClass = Class.forName("org.eclipse.core.runtime.Platform"); //$NON-NLS-1$
- Method findMethod = PlatformClass.getMethod("find", new Class[] { BundleClass, IPathClass }); //$NON-NLS-1$
- return (URL) findMethod.invoke(null, new Object[] { bundle, path });
- }
- } catch (Throwable e) {
- // Ignore any exceptions
- }
- // else work with 'plugin' as with usual Eclipse plugin
- {
- Class> PluginClass = Class.forName("org.eclipse.core.runtime.Plugin"); //$NON-NLS-1$
- if (PluginClass.isAssignableFrom(plugin.getClass())) {
- //
- Class> PathClass = Class.forName("org.eclipse.core.runtime.Path"); //$NON-NLS-1$
- Constructor> pathConstructor = PathClass.getConstructor(new Class[] { String.class });
- Object path = pathConstructor.newInstance(new Object[] { name });
- //
- Class> IPathClass = Class.forName("org.eclipse.core.runtime.IPath"); //$NON-NLS-1$
- Method findMethod = PluginClass.getMethod("find", new Class[] { IPathClass }); //$NON-NLS-1$
- return (URL) findMethod.invoke(plugin, new Object[] { path });
- }
- }
- return null;
- }
-
- ////////////////////////////////////////////////////////////////////////////
- //
- // General
- //
- ////////////////////////////////////////////////////////////////////////////
- /**
- * Dispose of cached objects and their underlying OS resources. This should only
- * be called when the cached objects are no longer needed (e.g. on application
- * shutdown).
- */
- public static void dispose() {
- disposeColors();
- disposeFonts();
- disposeImages();
- }
-}
\ No newline at end of file
diff --git a/xyz.veronie.bgg.ui/src/org/eclipse/wb/swt/SWTResourceManager.java b/xyz.veronie.bgg.ui/src/org/eclipse/wb/swt/SWTResourceManager.java
deleted file mode 100644
index d8a2858..0000000
--- a/xyz.veronie.bgg.ui/src/org/eclipse/wb/swt/SWTResourceManager.java
+++ /dev/null
@@ -1,447 +0,0 @@
-/*******************************************************************************
- * Copyright (c) 2011 Google, Inc.
- * All rights reserved. This program and the accompanying materials
- * are made available under the terms of the Eclipse Public License v1.0
- * which accompanies this distribution, and is available at
- * http://www.eclipse.org/legal/epl-v10.html
- *
- * Contributors:
- * Google, Inc. - initial API and implementation
- *******************************************************************************/
-package org.eclipse.wb.swt;
-
-import java.io.FileInputStream;
-import java.io.IOException;
-import java.io.InputStream;
-import java.util.HashMap;
-import java.util.Map;
-
-import org.eclipse.swt.SWT;
-import org.eclipse.swt.graphics.Color;
-import org.eclipse.swt.graphics.Cursor;
-import org.eclipse.swt.graphics.Font;
-import org.eclipse.swt.graphics.FontData;
-import org.eclipse.swt.graphics.GC;
-import org.eclipse.swt.graphics.Image;
-import org.eclipse.swt.graphics.ImageData;
-import org.eclipse.swt.graphics.RGB;
-import org.eclipse.swt.graphics.Rectangle;
-import org.eclipse.swt.widgets.Display;
-
-/**
- * Utility class for managing OS resources associated with SWT controls such as colors, fonts, images, etc.
- *
- * !!! IMPORTANT !!! Application code must explicitly invoke the dispose()
method to release the
- * operating system resources managed by cached objects when those objects and OS resources are no longer
- * needed (e.g. on application shutdown)
- *
- * This class may be freely distributed as part of any application or plugin.
- *
- * @author scheglov_ke
- * @author Dan Rubel
- */
-public class SWTResourceManager {
- ////////////////////////////////////////////////////////////////////////////
- //
- // Color
- //
- ////////////////////////////////////////////////////////////////////////////
- private static Map m_colorMap = new HashMap();
- /**
- * Returns the system {@link Color} matching the specific ID.
- *
- * @param systemColorID
- * the ID value for the color
- * @return the system {@link Color} matching the specific ID
- */
- public static Color getColor(int systemColorID) {
- Display display = Display.getCurrent();
- return display.getSystemColor(systemColorID);
- }
- /**
- * Returns a {@link Color} given its red, green and blue component values.
- *
- * @param r
- * the red component of the color
- * @param g
- * the green component of the color
- * @param b
- * the blue component of the color
- * @return the {@link Color} matching the given red, green and blue component values
- */
- public static Color getColor(int r, int g, int b) {
- return getColor(new RGB(r, g, b));
- }
- /**
- * Returns a {@link Color} given its RGB value.
- *
- * @param rgb
- * the {@link RGB} value of the color
- * @return the {@link Color} matching the RGB value
- */
- public static Color getColor(RGB rgb) {
- Color color = m_colorMap.get(rgb);
- if (color == null) {
- Display display = Display.getCurrent();
- color = new Color(display, rgb);
- m_colorMap.put(rgb, color);
- }
- return color;
- }
- /**
- * Dispose of all the cached {@link Color}'s.
- */
- public static void disposeColors() {
- for (Color color : m_colorMap.values()) {
- color.dispose();
- }
- m_colorMap.clear();
- }
- ////////////////////////////////////////////////////////////////////////////
- //
- // Image
- //
- ////////////////////////////////////////////////////////////////////////////
- /**
- * Maps image paths to images.
- */
- private static Map m_imageMap = new HashMap();
- /**
- * Returns an {@link Image} encoded by the specified {@link InputStream}.
- *
- * @param stream
- * the {@link InputStream} encoding the image data
- * @return the {@link Image} encoded by the specified input stream
- */
- protected static Image getImage(InputStream stream) throws IOException {
- try {
- Display display = Display.getCurrent();
- ImageData data = new ImageData(stream);
- if (data.transparentPixel > 0) {
- return new Image(display, data, data.getTransparencyMask());
- }
- return new Image(display, data);
- } finally {
- stream.close();
- }
- }
- /**
- * Returns an {@link Image} stored in the file at the specified path.
- *
- * @param path
- * the path to the image file
- * @return the {@link Image} stored in the file at the specified path
- */
- public static Image getImage(String path) {
- Image image = m_imageMap.get(path);
- if (image == null) {
- try {
- image = getImage(new FileInputStream(path));
- m_imageMap.put(path, image);
- } catch (Exception e) {
- image = getMissingImage();
- m_imageMap.put(path, image);
- }
- }
- return image;
- }
- /**
- * Returns an {@link Image} stored in the file at the specified path relative to the specified class.
- *
- * @param clazz
- * the {@link Class} relative to which to find the image
- * @param path
- * the path to the image file, if starts with '/'
- * @return the {@link Image} stored in the file at the specified path
- */
- public static Image getImage(Class> clazz, String path) {
- String key = clazz.getName() + '|' + path;
- Image image = m_imageMap.get(key);
- if (image == null) {
- try {
- image = getImage(clazz.getResourceAsStream(path));
- m_imageMap.put(key, image);
- } catch (Exception e) {
- image = getMissingImage();
- m_imageMap.put(key, image);
- }
- }
- return image;
- }
- private static final int MISSING_IMAGE_SIZE = 10;
- /**
- * @return the small {@link Image} that can be used as placeholder for missing image.
- */
- private static Image getMissingImage() {
- Image image = new Image(Display.getCurrent(), MISSING_IMAGE_SIZE, MISSING_IMAGE_SIZE);
- //
- GC gc = new GC(image);
- gc.setBackground(getColor(SWT.COLOR_RED));
- gc.fillRectangle(0, 0, MISSING_IMAGE_SIZE, MISSING_IMAGE_SIZE);
- gc.dispose();
- //
- return image;
- }
- /**
- * Style constant for placing decorator image in top left corner of base image.
- */
- public static final int TOP_LEFT = 1;
- /**
- * Style constant for placing decorator image in top right corner of base image.
- */
- public static final int TOP_RIGHT = 2;
- /**
- * Style constant for placing decorator image in bottom left corner of base image.
- */
- public static final int BOTTOM_LEFT = 3;
- /**
- * Style constant for placing decorator image in bottom right corner of base image.
- */
- public static final int BOTTOM_RIGHT = 4;
- /**
- * Internal value.
- */
- protected static final int LAST_CORNER_KEY = 5;
- /**
- * Maps images to decorated images.
- */
- @SuppressWarnings("unchecked")
- private static Map>[] m_decoratedImageMap = new Map[LAST_CORNER_KEY];
- /**
- * Returns an {@link Image} composed of a base image decorated by another image.
- *
- * @param baseImage
- * the base {@link Image} that should be decorated
- * @param decorator
- * the {@link Image} to decorate the base image
- * @return {@link Image} The resulting decorated image
- */
- public static Image decorateImage(Image baseImage, Image decorator) {
- return decorateImage(baseImage, decorator, BOTTOM_RIGHT);
- }
- /**
- * Returns an {@link Image} composed of a base image decorated by another image.
- *
- * @param baseImage
- * the base {@link Image} that should be decorated
- * @param decorator
- * the {@link Image} to decorate the base image
- * @param corner
- * the corner to place decorator image
- * @return the resulting decorated {@link Image}
- */
- public static Image decorateImage(final Image baseImage, final Image decorator, final int corner) {
- if (corner <= 0 || corner >= LAST_CORNER_KEY) {
- throw new IllegalArgumentException("Wrong decorate corner");
- }
- Map> cornerDecoratedImageMap = m_decoratedImageMap[corner];
- if (cornerDecoratedImageMap == null) {
- cornerDecoratedImageMap = new HashMap>();
- m_decoratedImageMap[corner] = cornerDecoratedImageMap;
- }
- Map decoratedMap = cornerDecoratedImageMap.get(baseImage);
- if (decoratedMap == null) {
- decoratedMap = new HashMap();
- cornerDecoratedImageMap.put(baseImage, decoratedMap);
- }
- //
- Image result = decoratedMap.get(decorator);
- if (result == null) {
- Rectangle bib = baseImage.getBounds();
- Rectangle dib = decorator.getBounds();
- //
- result = new Image(Display.getCurrent(), bib.width, bib.height);
- //
- GC gc = new GC(result);
- gc.drawImage(baseImage, 0, 0);
- if (corner == TOP_LEFT) {
- gc.drawImage(decorator, 0, 0);
- } else if (corner == TOP_RIGHT) {
- gc.drawImage(decorator, bib.width - dib.width, 0);
- } else if (corner == BOTTOM_LEFT) {
- gc.drawImage(decorator, 0, bib.height - dib.height);
- } else if (corner == BOTTOM_RIGHT) {
- gc.drawImage(decorator, bib.width - dib.width, bib.height - dib.height);
- }
- gc.dispose();
- //
- decoratedMap.put(decorator, result);
- }
- return result;
- }
- /**
- * Dispose all of the cached {@link Image}'s.
- */
- public static void disposeImages() {
- // dispose loaded images
- {
- for (Image image : m_imageMap.values()) {
- image.dispose();
- }
- m_imageMap.clear();
- }
- // dispose decorated images
- for (int i = 0; i < m_decoratedImageMap.length; i++) {
- Map> cornerDecoratedImageMap = m_decoratedImageMap[i];
- if (cornerDecoratedImageMap != null) {
- for (Map decoratedMap : cornerDecoratedImageMap.values()) {
- for (Image image : decoratedMap.values()) {
- image.dispose();
- }
- decoratedMap.clear();
- }
- cornerDecoratedImageMap.clear();
- }
- }
- }
- ////////////////////////////////////////////////////////////////////////////
- //
- // Font
- //
- ////////////////////////////////////////////////////////////////////////////
- /**
- * Maps font names to fonts.
- */
- private static Map m_fontMap = new HashMap();
- /**
- * Maps fonts to their bold versions.
- */
- private static Map m_fontToBoldFontMap = new HashMap();
- /**
- * Returns a {@link Font} based on its name, height and style.
- *
- * @param name
- * the name of the font
- * @param height
- * the height of the font
- * @param style
- * the style of the font
- * @return {@link Font} The font matching the name, height and style
- */
- public static Font getFont(String name, int height, int style) {
- return getFont(name, height, style, false, false);
- }
- /**
- * Returns a {@link Font} based on its name, height and style. Windows-specific strikeout and underline
- * flags are also supported.
- *
- * @param name
- * the name of the font
- * @param size
- * the size of the font
- * @param style
- * the style of the font
- * @param strikeout
- * the strikeout flag (warning: Windows only)
- * @param underline
- * the underline flag (warning: Windows only)
- * @return {@link Font} The font matching the name, height, style, strikeout and underline
- */
- public static Font getFont(String name, int size, int style, boolean strikeout, boolean underline) {
- String fontName = name + '|' + size + '|' + style + '|' + strikeout + '|' + underline;
- Font font = m_fontMap.get(fontName);
- if (font == null) {
- FontData fontData = new FontData(name, size, style);
- if (strikeout || underline) {
- try {
- Class> logFontClass = Class.forName("org.eclipse.swt.internal.win32.LOGFONT"); //$NON-NLS-1$
- Object logFont = FontData.class.getField("data").get(fontData); //$NON-NLS-1$
- if (logFont != null && logFontClass != null) {
- if (strikeout) {
- logFontClass.getField("lfStrikeOut").set(logFont, Byte.valueOf((byte) 1)); //$NON-NLS-1$
- }
- if (underline) {
- logFontClass.getField("lfUnderline").set(logFont, Byte.valueOf((byte) 1)); //$NON-NLS-1$
- }
- }
- } catch (Throwable e) {
- System.err.println("Unable to set underline or strikeout" + " (probably on a non-Windows platform). " + e); //$NON-NLS-1$ //$NON-NLS-2$
- }
- }
- font = new Font(Display.getCurrent(), fontData);
- m_fontMap.put(fontName, font);
- }
- return font;
- }
- /**
- * Returns a bold version of the given {@link Font}.
- *
- * @param baseFont
- * the {@link Font} for which a bold version is desired
- * @return the bold version of the given {@link Font}
- */
- public static Font getBoldFont(Font baseFont) {
- Font font = m_fontToBoldFontMap.get(baseFont);
- if (font == null) {
- FontData fontDatas[] = baseFont.getFontData();
- FontData data = fontDatas[0];
- font = new Font(Display.getCurrent(), data.getName(), data.getHeight(), SWT.BOLD);
- m_fontToBoldFontMap.put(baseFont, font);
- }
- return font;
- }
- /**
- * Dispose all of the cached {@link Font}'s.
- */
- public static void disposeFonts() {
- // clear fonts
- for (Font font : m_fontMap.values()) {
- font.dispose();
- }
- m_fontMap.clear();
- // clear bold fonts
- for (Font font : m_fontToBoldFontMap.values()) {
- font.dispose();
- }
- m_fontToBoldFontMap.clear();
- }
- ////////////////////////////////////////////////////////////////////////////
- //
- // Cursor
- //
- ////////////////////////////////////////////////////////////////////////////
- /**
- * Maps IDs to cursors.
- */
- private static Map m_idToCursorMap = new HashMap();
- /**
- * Returns the system cursor matching the specific ID.
- *
- * @param id
- * int The ID value for the cursor
- * @return Cursor The system cursor matching the specific ID
- */
- public static Cursor getCursor(int id) {
- Integer key = Integer.valueOf(id);
- Cursor cursor = m_idToCursorMap.get(key);
- if (cursor == null) {
- cursor = new Cursor(Display.getDefault(), id);
- m_idToCursorMap.put(key, cursor);
- }
- return cursor;
- }
- /**
- * Dispose all of the cached cursors.
- */
- public static void disposeCursors() {
- for (Cursor cursor : m_idToCursorMap.values()) {
- cursor.dispose();
- }
- m_idToCursorMap.clear();
- }
- ////////////////////////////////////////////////////////////////////////////
- //
- // General
- //
- ////////////////////////////////////////////////////////////////////////////
- /**
- * Dispose of cached objects and their underlying OS resources. This should only be called when the cached
- * objects are no longer needed (e.g. on application shutdown).
- */
- public static void dispose() {
- disposeColors();
- disposeImages();
- disposeFonts();
- disposeCursors();
- }
-}
\ No newline at end of file
diff --git a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/dialogs/LoadGameListDialog.java b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/dialogs/LoadGameListDialog.java
index 85eb8d5..14ead0d 100644
--- a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/dialogs/LoadGameListDialog.java
+++ b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/dialogs/LoadGameListDialog.java
@@ -23,7 +23,7 @@ import org.eclipse.swt.widgets.Label;
import org.eclipse.swt.widgets.Shell;
import org.eclipse.swt.widgets.Table;
import org.eclipse.swt.widgets.TableColumn;
-import org.eclipse.wb.swt.SWTResourceManager;
+import org.eclipse.tips.ui.internal.util.SWTResourceManager;
import xyz.veronie.bgg.ui.helpers.BatColors;
diff --git a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/dialogs/SaveGameListDialog.java b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/dialogs/SaveGameListDialog.java
index 4de805e..eac2c1b 100644
--- a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/dialogs/SaveGameListDialog.java
+++ b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/dialogs/SaveGameListDialog.java
@@ -14,11 +14,13 @@ import org.eclipse.swt.widgets.Control;
import org.eclipse.swt.widgets.Label;
import org.eclipse.swt.widgets.Shell;
import org.eclipse.swt.widgets.Text;
-import org.eclipse.wb.swt.SWTResourceManager;
+import org.eclipse.tips.ui.internal.util.SWTResourceManager;
import xyz.veronie.bgg.ui.helpers.BatColors;
public class SaveGameListDialog extends Dialog {
+ private static final String DIALOG_FONT = "Segoe UI";
+
private Text textField;
private String entryString;
@@ -42,7 +44,7 @@ public class SaveGameListDialog extends Dialog {
protected Control createDialogArea(Composite parent) {
parent.setBackground(BatColors.getBackgroundColor());
Composite container = (Composite) super.createDialogArea(parent);
- container.setFont(SWTResourceManager.getFont("Segoe UI", 11, SWT.NORMAL));
+ container.setFont(SWTResourceManager.getFont(DIALOG_FONT, 11, SWT.NORMAL));
container.setBackground(BatColors.getBackgroundColor());
GridLayout gl_container = new GridLayout(1, false);
gl_container.verticalSpacing = 24;
@@ -56,7 +58,7 @@ public class SaveGameListDialog extends Dialog {
container.setLayout(gl_container);
Label lblEnterAName = new Label(container, SWT.NONE);
- lblEnterAName.setFont(SWTResourceManager.getFont("Segoe UI", 11, SWT.NORMAL));
+ lblEnterAName.setFont(SWTResourceManager.getFont(DIALOG_FONT, 11, SWT.NORMAL));
lblEnterAName.setText("Enter a name for the game list:");
textField = new Text(container, SWT.BORDER);
@@ -68,7 +70,7 @@ public class SaveGameListDialog extends Dialog {
btnOk.setEnabled(enableOk);
}
});
- textField.setFont(SWTResourceManager.getFont("Segoe UI", 11, SWT.NORMAL));
+ textField.setFont(SWTResourceManager.getFont(DIALOG_FONT, 11, SWT.NORMAL));
textField.setLayoutData(new GridData(SWT.FILL, SWT.CENTER, true, false, 1, 1));
return container;
diff --git a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/filters/composites/FilterFlagComposite.java b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/filters/composites/FilterFlagComposite.java
index 26ec591..6e15201 100644
--- a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/filters/composites/FilterFlagComposite.java
+++ b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/filters/composites/FilterFlagComposite.java
@@ -10,13 +10,13 @@ import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.layout.GridLayout;
import org.eclipse.swt.widgets.Button;
import org.eclipse.swt.widgets.Composite;
-import org.eclipse.wb.swt.ResourceManager;
import xyz.veronie.bgg.result.ResultConfigManager;
import xyz.veronie.bgg.types.EventConstants;
import xyz.veronie.bgg.types.FilterFlagState;
import xyz.veronie.bgg.types.UserFlag;
import xyz.veronie.bgg.types.UserFlagEvent;
+import xyz.veronie.bgg.ui.helpers.ResourceManager;
public class FilterFlagComposite extends Composite {
@@ -48,8 +48,8 @@ public class FilterFlagComposite extends Composite {
flagSwitch = new SwitchLabel(this, SWT.NONE);
- flagSwitch.setOnImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/noun_switch on_30x30.png"));
- flagSwitch.setOffImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/noun_switch off_30x30.png"));
+ flagSwitch.setOnImage(ResourceManager.getPluginImageDescriptor("xyz.veronie.bgg.ui", "icons/noun_switch on_30x30.png").createImage());
+ flagSwitch.setOffImage(ResourceManager.getPluginImageDescriptor("xyz.veronie.bgg.ui", "icons/noun_switch off_30x30.png").createImage());
flagSwitch.setEnabled(isTurnedOn);
diff --git a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/handlers/ExportResultHandler.java b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/handlers/ExportResultHandler.java
index 2c6e0fe..2dae818 100644
--- a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/handlers/ExportResultHandler.java
+++ b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/handlers/ExportResultHandler.java
@@ -4,14 +4,8 @@ package xyz.veronie.bgg.ui.handlers;
import org.eclipse.e4.core.di.annotations.Execute;
import xyz.veronie.bgg.result.BggApi;
-import xyz.veronie.bgg.result.Thing;
import xyz.veronie.bgg.result.ThingProvider;
-import java.util.ArrayList;
-import java.util.HashSet;
-import java.util.List;
-import java.util.Set;
-
import javax.inject.Inject;
import org.eclipse.e4.core.di.annotations.CanExecute;
diff --git a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/handlers/LoadGamelistHandler.java b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/handlers/LoadGamelistHandler.java
index 06249f9..9b71a55 100644
--- a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/handlers/LoadGamelistHandler.java
+++ b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/handlers/LoadGamelistHandler.java
@@ -20,7 +20,6 @@ import xyz.veronie.bgg.result.ThingProvider;
import xyz.veronie.bgg.types.EventConstants;
import xyz.veronie.bgg.ui.dialogs.LoadGameListDialog;
-@SuppressWarnings("restriction")
public class LoadGamelistHandler {
@Inject
diff --git a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/helpers/BatColors.java b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/helpers/BatColors.java
index 5fc2c29..9768cc7 100644
--- a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/helpers/BatColors.java
+++ b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/helpers/BatColors.java
@@ -1,7 +1,7 @@
package xyz.veronie.bgg.ui.helpers;
import org.eclipse.swt.graphics.Color;
-import org.eclipse.wb.swt.SWTResourceManager;
+import org.eclipse.tips.ui.internal.util.SWTResourceManager;
public class BatColors {
diff --git a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/helpers/ResourceManager.java b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/helpers/ResourceManager.java
new file mode 100644
index 0000000..bba8516
--- /dev/null
+++ b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/helpers/ResourceManager.java
@@ -0,0 +1,22 @@
+package xyz.veronie.bgg.ui.helpers;
+
+import java.net.URL;
+
+import org.eclipse.core.runtime.FileLocator;
+import org.eclipse.core.runtime.Path;
+import org.eclipse.jface.resource.ImageDescriptor;
+import org.osgi.framework.Bundle;
+import org.osgi.framework.FrameworkUtil;
+
+public class ResourceManager {
+
+ public static ImageDescriptor getPluginImageDescriptor(String plugin, String imagePath) {
+ Bundle bundle = FrameworkUtil.getBundle(ResourceManager.class);
+ // use the org.eclipse.core.runtime.Path as import
+ URL url = FileLocator.find(bundle,
+ new Path(imagePath), null);
+ ImageDescriptor imageDescriptor = ImageDescriptor.createFromURL(url);
+ return imageDescriptor;
+ }
+
+}
diff --git a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/parts/BatMain.java b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/parts/BatMain.java
index 409bb72..c59dd88 100644
--- a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/parts/BatMain.java
+++ b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/parts/BatMain.java
@@ -39,16 +39,15 @@ import org.eclipse.swt.widgets.Event;
import org.eclipse.swt.widgets.Label;
import org.eclipse.swt.widgets.Table;
import org.eclipse.swt.widgets.TableColumn;
-import org.eclipse.wb.swt.ResourceManager;
-import org.eclipse.wb.swt.SWTResourceManager;
+import org.eclipse.tips.ui.internal.util.SWTResourceManager;
import xyz.veronie.bgg.result.Thing;
import xyz.veronie.bgg.result.ThingProvider;
import xyz.veronie.bgg.types.EventConstants;
import xyz.veronie.bgg.ui.helpers.BatColors;
import xyz.veronie.bgg.ui.helpers.BatLayouts;
+import xyz.veronie.bgg.ui.helpers.ResourceManager;
-@SuppressWarnings("restriction")
public class BatMain {
private static final String UNNAMED_LIST = "(unsaved list)";
@@ -109,7 +108,7 @@ public class BatMain {
});
btnFetch.setToolTipText("Fetch games from BGG");
- btnFetch.setImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/noun_Download_60x60.png"));
+ btnFetch.setImage(ResourceManager.getPluginImageDescriptor("xyz.veronie.bgg.ui", "icons/noun_Download_60x60.png").createImage());
btnSave = new Button(buttonRow, SWT.NONE);
btnSave.addMouseListener(new MouseAdapter() {
@@ -123,7 +122,7 @@ public class BatMain {
}
});
btnSave.setToolTipText("Save list of games");
- btnSave.setImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/noun_Save_60x60.png"));
+ btnSave.setImage(ResourceManager.getPluginImageDescriptor("xyz.veronie.bgg.ui", "icons/noun_Save_60x60.png").createImage());
btnSave.setEnabled(false);
Button btnLoad = new Button(buttonRow, SWT.NONE);
@@ -137,14 +136,14 @@ public class BatMain {
}
}
});
- btnLoad.setImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/noun_open_60x60.png"));
+ btnLoad.setImage(ResourceManager.getPluginImageDescriptor("xyz.veronie.bgg.ui", "icons/noun_open_60x60.png").createImage());
btnLoad.setToolTipText("Load list of games");
btnUndo = new Button(buttonRow, SWT.NONE);
btnUndo.setToolTipText("Undo game list operation");
- btnUndo.setImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/noun_Undo_60x60.png"));
+ btnUndo.setImage(ResourceManager.getPluginImageDescriptor("xyz.veronie.bgg.ui", "icons/noun_Undo_60x60.png").createImage());
btnUndo.setEnabled(false);
btnExport = new Button(buttonRow, SWT.NONE);
@@ -158,7 +157,7 @@ public class BatMain {
}
}
});
- btnExport.setImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/export_nandeck_60x60.png"));
+ btnExport.setImage(ResourceManager.getPluginImageDescriptor("xyz.veronie.bgg.ui", "icons/export_nandeck_60x60.png").createImage());
btnExport.setToolTipText("Export for nanDeck");
btnExport.setEnabled(false);
diff --git a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/parts/FetchPart.java b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/parts/FetchPart.java
index 5bb00e4..aaf9ebf 100644
--- a/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/parts/FetchPart.java
+++ b/xyz.veronie.bgg.ui/src/xyz/veronie/bgg/ui/parts/FetchPart.java
@@ -27,8 +27,6 @@ import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.layout.GridLayout;
import org.eclipse.swt.widgets.Button;
import org.eclipse.swt.widgets.Composite;
-import org.eclipse.wb.swt.ResourceManager;
-import org.eclipse.wb.swt.SWTResourceManager;
import xyz.veronie.bgg.result.BggApi;
import xyz.veronie.bgg.result.ResultConfig;
@@ -43,10 +41,15 @@ import xyz.veronie.bgg.ui.filters.FamilySourceFilter;
import xyz.veronie.bgg.ui.filters.GeeklistSourceFilter;
import xyz.veronie.bgg.ui.helpers.BatColors;
import xyz.veronie.bgg.ui.helpers.BatLayouts;
+import xyz.veronie.bgg.ui.helpers.ResourceManager;
+
import org.eclipse.swt.widgets.Label;
+import org.eclipse.tips.ui.internal.util.SWTResourceManager;
public class FetchPart {
+ private static final String XYZ_VERONIE_BGG_UI = "xyz.veronie.bgg.ui";
+
@Inject
private ResultConfigManager configManager;
@@ -115,15 +118,15 @@ public class FetchPart {
btnBggUser = new Button(buttonRow, SWT.NONE);
btnBggUser.setToolTipText("Fetch by bgg user");
- btnBggUser.setImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/noun_Meeple_60x60.png"));
+ btnBggUser.setImage(ResourceManager.getPluginImageDescriptor(XYZ_VERONIE_BGG_UI, "icons/noun_Meeple_60x60.png").createImage());
btnFamily = new Button(buttonRow, SWT.NONE);
btnFamily.setToolTipText("Fetch by family");
- btnFamily.setImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/noun_Family_60x60.png"));
+ btnFamily.setImage(ResourceManager.getPluginImageDescriptor(XYZ_VERONIE_BGG_UI, "icons/noun_Family_60x60.png").createImage());
btnGeeklist = new Button(buttonRow, SWT.NONE);
btnGeeklist.setToolTipText("Fetch by geeklist");
- btnGeeklist.setImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/noun_List_60x60.png"));
+ btnGeeklist.setImage(ResourceManager.getPluginImageDescriptor(XYZ_VERONIE_BGG_UI, "icons/noun_List_60x60.png").createImage());
centerComposite = new Composite(main, SWT.NONE);
@@ -155,7 +158,7 @@ public class FetchPart {
lblResultAction.setText("How do you want to apply the result?");
Button btnReplace = new Button(applyComposite, SWT.NONE);
- btnReplace.setImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/result_replace_60x60.png"));
+ btnReplace.setImage(ResourceManager.getPluginImageDescriptor(XYZ_VERONIE_BGG_UI, "icons/result_replace_60x60.png").createImage());
btnReplace.setToolTipText("Replace");
btnReplace.addMouseListener(new MouseAdapter() {
@Override
@@ -165,7 +168,7 @@ public class FetchPart {
});
Button btnOnlyNew = new Button(applyComposite, SWT.NONE);
- btnOnlyNew.setImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/only_new_60x60.png"));
+ btnOnlyNew.setImage(ResourceManager.getPluginImageDescriptor(XYZ_VERONIE_BGG_UI, "icons/only_new_60x60.png").createImage());
btnOnlyNew.setToolTipText("Keep only new");
btnOnlyNew.addMouseListener(new MouseAdapter() {
@Override
@@ -175,7 +178,7 @@ public class FetchPart {
});
Button btnAdd = new Button(applyComposite, SWT.NONE);
- btnAdd.setImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/result_add_60x60.png"));
+ btnAdd.setImage(ResourceManager.getPluginImageDescriptor(XYZ_VERONIE_BGG_UI, "icons/result_add_60x60.png").createImage());
btnAdd.setToolTipText("Add");
btnAdd.addMouseListener(new MouseAdapter() {
@Override
@@ -185,7 +188,7 @@ public class FetchPart {
});
Button btnIntersect = new Button(applyComposite, SWT.NONE);
- btnIntersect.setImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/result_intersect_60x60.png"));
+ btnIntersect.setImage(ResourceManager.getPluginImageDescriptor(XYZ_VERONIE_BGG_UI, "icons/result_intersect_60x60.png").createImage());
btnIntersect.setToolTipText("Intersect");
btnIntersect.addMouseListener(new MouseAdapter() {
@Override
@@ -195,7 +198,7 @@ public class FetchPart {
});
Button btnSubtract = new Button(applyComposite, SWT.NONE);
- btnSubtract.setImage(ResourceManager.getPluginImage("xyz.veronie.bgg.ui", "icons/result_subtract_60x60.png"));
+ btnSubtract.setImage(ResourceManager.getPluginImageDescriptor(XYZ_VERONIE_BGG_UI, "icons/result_subtract_60x60.png").createImage());
btnSubtract.setToolTipText("Subtract");
btnSubtract.addMouseListener(new MouseAdapter() {
@Override