Skip to main content
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWim Jongman2018-04-29 19:35:31 +0000
committerWim Jongman2018-04-29 20:28:12 +0000
commit0042755f51c37aa19cf5f0cfea5259ef71437683 (patch)
tree196ec3a8da994187c62f542367da48c17952deac
parentfde39fc97b47e4743249cbd96c62985967700bda (diff)
downloadeclipse.platform.ua-0042755f51c37aa19cf5f0cfea5259ef71437683.tar.gz
eclipse.platform.ua-0042755f51c37aa19cf5f0cfea5259ef71437683.tar.xz
eclipse.platform.ua-0042755f51c37aa19cf5f0cfea5259ef71437683.zip
Bug 534073: [Tips] Create JSon based Tip Provider for PlatformI20180430-0715I20180429-2000
* Added photon new and noteworthy provider * Changed startup sequence * Added logging * Removed warnings from examples * Fixed Twitter Feed to not use the Twitter URL * Added TipProvider#hasContent * Changes IUrlTip#getURL Change-Id: I100d32c49d27d850697ae1f347282d99d52417e2 Signed-off-by: Wim Jongman <wim.jongman@remainsoftware.com>
-rw-r--r--org.eclipse.tips.core/src/org/eclipse/tips/core/ITipManager.java18
-rw-r--r--org.eclipse.tips.core/src/org/eclipse/tips/core/IUrlTip.java11
-rw-r--r--org.eclipse.tips.core/src/org/eclipse/tips/core/TipProvider.java8
-rw-r--r--org.eclipse.tips.core/src/org/eclipse/tips/core/internal/TipManager.java10
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/EclipseTipsProvider.java8
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip1.java2
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip2.java2
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip3.java2
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/TwitterTip.java1
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/java/java9/Java9TipProvider.java2
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/java/java9/Tip1.java1
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/json/JsonTipProviderPhoton.java4
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/json/provider.json48
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider.java3
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider1.java3
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider2.java3
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider3.java3
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider4.java3
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider5.java3
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider6.java3
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider7.java3
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/tips/MediaWikiTip.java24
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/tips/TwitterTip.java24
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/GithubTip.java2
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/MatrixRainTip.java6
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/Navigate1Tip.java2
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/Navigate2Tip.java2
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/StartingTip.java2
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/TipsTipProvider.java3
-rw-r--r--org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/WelcomeTip.java1
-rw-r--r--org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/IDETipManager.java18
-rw-r--r--org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/Startup.java105
-rw-r--r--org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/TipSourceProvider.java13
-rw-r--r--org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/TipsPreferences.java24
-rw-r--r--org.eclipse.tips.json/src/org/eclipse/tips/json/JsonTipProvider.java89
-rw-r--r--org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonConstants.java5
-rw-r--r--org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonHTMLTip.java17
-rw-r--r--org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonUrlTip.java30
-rw-r--r--org.eclipse.tips.json/src/org/eclipse/tips/json/internal/ProviderLoader.java32
-rw-r--r--org.eclipse.tips.json/src/org/eclipse/tips/json/internal/Util.java92
-rw-r--r--org.eclipse.tips.tests/META-INF/MANIFEST.MF1
-rw-r--r--org.eclipse.tips.tests/src/org/eclipse/tips/json/internal/UtilTest.java69
-rw-r--r--org.eclipse.tips.tests/src/org/eclipse/tips/manual/tests/SleakTipManager.java3
-rw-r--r--org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/DefaultTipManager.java10
-rw-r--r--org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/Slider.java26
-rw-r--r--org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/TipComposite.java21
46 files changed, 541 insertions, 221 deletions
diff --git a/org.eclipse.tips.core/src/org/eclipse/tips/core/ITipManager.java b/org.eclipse.tips.core/src/org/eclipse/tips/core/ITipManager.java
index 52fbe3434..16007f3fc 100644
--- a/org.eclipse.tips.core/src/org/eclipse/tips/core/ITipManager.java
+++ b/org.eclipse.tips.core/src/org/eclipse/tips/core/ITipManager.java
@@ -61,14 +61,14 @@ public interface ITipManager {
* @return this
*/
public ITipManager register(TipProvider provider);
-
+
/**
* Opens the Tip of the Day dialog.
*
* @param startUp When called from a startup situation, true must be passed for
- * <code>startup</code>. If in a manual starting situation,
- * false must be passed. This enables the manager to decide to
- * skip opening the dialog at startup (e.g., no new tip items).
+ * <code>startup</code>. If in a manual starting situation, false
+ * must be passed. This enables the manager to decide to skip
+ * opening the dialog at startup (e.g., no new tip items).
*
* @return this
*
@@ -82,4 +82,14 @@ public interface ITipManager {
* @return true if this manager is open, false otherwise.
*/
public boolean isOpen();
+
+ /**
+ * Indicates if this manager has providers with tips (based on the read or
+ * unread requirement). Be aware that subsequent calls to this method may return
+ * different results based on the async nature of loading providers.
+ *
+ * @return true if this {@link TipManager} has providers with tips.
+ * @see TipProvider#getTips()
+ */
+ public boolean hasContent();
} \ No newline at end of file
diff --git a/org.eclipse.tips.core/src/org/eclipse/tips/core/IUrlTip.java b/org.eclipse.tips.core/src/org/eclipse/tips/core/IUrlTip.java
index 01ec04a59..497d76cca 100644
--- a/org.eclipse.tips.core/src/org/eclipse/tips/core/IUrlTip.java
+++ b/org.eclipse.tips.core/src/org/eclipse/tips/core/IUrlTip.java
@@ -19,12 +19,13 @@ import java.net.URL;
public interface IUrlTip {
/**
- * Return an URL with the primary goal to be rendered by the tip manager.
- * Implementations of Tip may also use the URL to aid the rendering (e.g. by
- * providing other data than HTML, e.g. a text file).
+ * Return the string representation of an {@link URL} with the primary goal to
+ * be rendered by the tip manager. Implementations of Tip may also use the URL
+ * to aid the rendering (e.g. by providing other data than HTML, e.g. a text
+ * file).
*
- * @return the URL to the (remote) content
+ * @return the string representation of URL to the (remote) content
*
*/
- public URL getURL();
+ public String getURL();
} \ No newline at end of file
diff --git a/org.eclipse.tips.core/src/org/eclipse/tips/core/TipProvider.java b/org.eclipse.tips.core/src/org/eclipse/tips/core/TipProvider.java
index e5f364716..caa79cbf1 100644
--- a/org.eclipse.tips.core/src/org/eclipse/tips/core/TipProvider.java
+++ b/org.eclipse.tips.core/src/org/eclipse/tips/core/TipProvider.java
@@ -21,6 +21,7 @@ import java.util.stream.Collectors;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.tips.core.internal.FinalTip;
+import org.eclipse.tips.core.internal.LogUtil;
/**
* Class to provide tips to the tip framework. It is the job of this provider to
@@ -268,9 +269,10 @@ public abstract class TipProvider {
* @see #loadNewTips(IProgressMonitor)
*/
public TipProvider setTips(List<Tip> tips) {
- if (!getManager().isOpen()) {
- return this;
- }
+// if (!getManager().isOpen()) {
+// return this;
+// }
+ getManager().log(LogUtil.info(String.format("Setting tips")));
doSetTips(tips, true);
fReady = true;
fChangeSupport.firePropertyChange(PROP_READY, false, true);
diff --git a/org.eclipse.tips.core/src/org/eclipse/tips/core/internal/TipManager.java b/org.eclipse.tips.core/src/org/eclipse/tips/core/internal/TipManager.java
index 4d2a8ace4..2c1be0d8b 100644
--- a/org.eclipse.tips.core/src/org/eclipse/tips/core/internal/TipManager.java
+++ b/org.eclipse.tips.core/src/org/eclipse/tips/core/internal/TipManager.java
@@ -249,4 +249,14 @@ public abstract class TipManager implements ITipManager {
public boolean isDisposed() {
return fIsDiposed;
}
+
+ @Override
+ public boolean hasContent() {
+ for (TipProvider provider : getProviders()) {
+ if (provider.isReady() && !provider.getTips().isEmpty()) {
+ return true;
+ }
+ }
+ return false;
+ }
} \ No newline at end of file
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/EclipseTipsProvider.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/EclipseTipsProvider.java
index c9fdbbacc..3a90de101 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/EclipseTipsProvider.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/EclipseTipsProvider.java
@@ -26,17 +26,20 @@ import org.eclipse.tips.examples.tips.MediaWikiTip;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
+@SuppressWarnings("restriction")
public class EclipseTipsProvider extends org.eclipse.tips.core.TipProvider {
public int fCurrentTip;
private Tip createTip1() {
- return new org.eclipse.tips.examples.tips.TwitterTip(getID(), "https://twitter.com/EclipseJavaIDE/status/919915440041840641", DateUtil.getDateFromYYMMDD("08/12/017"),
+ return new org.eclipse.tips.examples.tips.TwitterTip(getID(),
+ "https://twitter.com/EclipseJavaIDE/status/919915440041840641", DateUtil.getDateFromYYMMDD("08/12/017"),
"Twitter Tip");
}
private Tip createTip2() {
- return new org.eclipse.tips.examples.tips.MediaWikiTip(getID(), "https://wiki.eclipse.org/Tip_of_the_Day/Eclipse_Tips/Show_In_System_Explorer",
+ return new org.eclipse.tips.examples.tips.MediaWikiTip(getID(),
+ "https://wiki.eclipse.org/Tip_of_the_Day/Eclipse_Tips/Show_In_System_Explorer",
DateUtil.getDateFromYYMMDD("08/01/2017"), "Show in Systems Explorer");
}
@@ -83,7 +86,6 @@ public class EclipseTipsProvider extends org.eclipse.tips.core.TipProvider {
return fImage48;
}
-
@Override
public synchronized IStatus loadNewTips(IProgressMonitor pMonitor) {
SubMonitor subMonitor = SubMonitor.convert(pMonitor);
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip1.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip1.java
index 86903b0de..411fb26d9 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip1.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip1.java
@@ -16,8 +16,6 @@ import java.util.Date;
import org.eclipse.tips.core.IHtmlTip;
import org.eclipse.tips.core.Tip;
import org.eclipse.tips.core.TipImage;
-import org.eclipse.tips.core.TipProvider;
-import org.eclipse.tips.core.internal.LogUtil;
import org.eclipse.tips.examples.DateUtil;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip2.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip2.java
index b6bd14322..30b40e01c 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip2.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip2.java
@@ -16,8 +16,6 @@ import java.util.Date;
import org.eclipse.tips.core.IHtmlTip;
import org.eclipse.tips.core.Tip;
import org.eclipse.tips.core.TipImage;
-import org.eclipse.tips.core.TipProvider;
-import org.eclipse.tips.core.internal.LogUtil;
import org.eclipse.tips.examples.DateUtil;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip3.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip3.java
index c67d4403f..a4881e6fd 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip3.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/Tip3.java
@@ -16,8 +16,6 @@ import java.util.Date;
import org.eclipse.tips.core.IHtmlTip;
import org.eclipse.tips.core.Tip;
import org.eclipse.tips.core.TipImage;
-import org.eclipse.tips.core.TipProvider;
-import org.eclipse.tips.core.internal.LogUtil;
import org.eclipse.tips.examples.DateUtil;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/TwitterTip.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/TwitterTip.java
index afe11e766..12735053a 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/TwitterTip.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/eclipsetips/TwitterTip.java
@@ -15,7 +15,6 @@ import java.util.Date;
import org.eclipse.tips.core.IHtmlTip;
import org.eclipse.tips.core.Tip;
import org.eclipse.tips.core.TipImage;
-import org.eclipse.tips.core.TipProvider;
import org.eclipse.tips.examples.DateUtil;
public class TwitterTip extends Tip implements IHtmlTip {
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/java/java9/Java9TipProvider.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/java/java9/Java9TipProvider.java
index 16e532921..ea3af71a8 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/java/java9/Java9TipProvider.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/java/java9/Java9TipProvider.java
@@ -28,9 +28,9 @@ import org.osgi.framework.FrameworkUtil;
/**
*
-
*
*/
+@SuppressWarnings("restriction")
public class Java9TipProvider extends TipProvider {
@Override
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/java/java9/Tip1.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/java/java9/Tip1.java
index 5d9045522..f4a2f8005 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/java/java9/Tip1.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/java/java9/Tip1.java
@@ -22,7 +22,6 @@ import org.eclipse.tips.core.Tip;
import org.eclipse.tips.core.TipAction;
import org.eclipse.tips.core.TipImage;
import org.eclipse.tips.core.TipProvider;
-import org.eclipse.tips.core.internal.LogUtil;
import org.eclipse.tips.examples.DateUtil;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/json/JsonTipProviderPhoton.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/json/JsonTipProviderPhoton.java
index d77193c1a..292c86ab7 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/json/JsonTipProviderPhoton.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/json/JsonTipProviderPhoton.java
@@ -11,13 +11,15 @@
package org.eclipse.tips.examples.json;
import java.net.MalformedURLException;
+import java.net.URL;
import org.eclipse.tips.json.JsonTipProvider;
public class JsonTipProviderPhoton extends JsonTipProvider {
public JsonTipProviderPhoton() throws MalformedURLException {
- setJsonUrl("https://raw.githubusercontent.com/wimjongman/jsontips/master/photon/m3tips.json");
+ URL resource = getClass().getResource("provider.json");
+ setJsonUrl(resource.toString());
}
@Override
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/json/provider.json b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/json/provider.json
new file mode 100644
index 000000000..7c249998a
--- /dev/null
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/json/provider.json
@@ -0,0 +1,48 @@
+{
+ "provider": {
+ "image": "",
+ "description": "JSon Tip Provider",
+ "expression": "<with variable=\"activeWorkbenchWindow.activePerspective\"><equals value=\"org.eclipse.jdt.ui.JavaPerspective\"></equals></with>",
+ "tips": [
+ {
+ "subject": "Embedded Full Screen YouTube video",
+ "date": "2018-02-12",
+ "html": "<style> * { box-sizing: border-box; } .video-background { background: #000; position: fixed; top: 0; right: 0; bottom: 0; left: 0; z-index: -99; } .video-foreground, .video-background iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; pointer-events: none; } #vidtop-content { top: 0; color: #fff; } .vid-info { position: absolute; top: 0; right: 0; width: 33%; background: rgba(0, 0, 0, 0.3); color: #fff; padding: 1rem; font-family: Avenir, Helvetica, sans-serif; } .vid-info h1 { font-size: 2rem; font-weight: 700; margin-top: 0; line-height: 1.2; } .vid-info a { display: block; color: #fff; text-decoration: none; background: rgba(0, 0, 0, 0.5); transition: .6s background; border-bottom: none; margin: 1rem auto; text-align: center; } @media (min-aspect-ratio: 16\/9) { .video-foreground { height: 300%; top: -100%; } } @media (max-aspect-ratio: 16\/9) { .video-foreground { width: 300%; left: -100%; } } @media all and (max-width: 600px) { .vid-info { width: 50%; padding: .5rem; } .vid-info h1 { margin-bottom: .2rem; } } @media all and (max-width: 500px) { .vid-info .acronym { display: none; }<\/style><div class=\"video-background\"> <div class=\"video-foreground\"> <iframe src=\"https:\/\/www.youtube.com\/embed\/W0LHTWG-UmQ?controls=0&showinfo=0&rel=0&autoplay=1&loop=1&playlist=W0LHTWG-UmQ\" frameborder=\"0\" allowfullscreen><\/iframe> <\/div><\/div><div id=\"vidtop-content\"> <div class=\"vid-info\"> <\/div><\/div>",
+ "variables": {
+ "foo": "Example of substitution variable inside your url or html: ${tip.foo}",
+ "bar": "Example of substitution variable inside your url or html: ${tip.bar}"
+ }
+ },
+ {
+ "subject": "The DirectoryDialog now uses modern style",
+ "date": "2018-01-21",
+ "image": "",
+ "ratio": 1.35,
+ "maxHeight": 300,
+ "actionId": "preferences",
+ "html": "<h2>The DirectoryDialog now uses modern style</h2>The <b>DirectoryDialog</b> has been re-implemented to use modern native widget introduced in Windows Vista. The new look and feel is as illustrated below:<p><b>Regarding usage of newer <code>DirectoryDialog</code> on Windows:</b> In the old <code>DirectoryDialog</code>, we used to have the option to set a text message to specify the purpose of the <code>DirectoryDialog</code> using <code>DirectoryDialog#setMessage(String)</code>. This functionality is no more possible with the newer <code>DirectoryDialog</code>.</p><p>Hence, revisit the usage of <code>DirectoryDialog.setMessage(String)</code> in your projects, and if needed elaborate the <code>Title</code> field of <code>DirectoryDialog</code> using <code>DirectoryDialog.setText(String)</code> method.</p><p>Note: Recommend to use a minimal set of words in the <code>Title.</code> field of </code>DirectoryDialog</code> and avoid making it look clumsy.</p>"
+ },
+ {
+ "subject": "Expanded Highlighting in Open Resource Dialog",
+ "image": "",
+ "date": "2018-01-21",
+ "ratio": 1.3,
+ "maxWidth": 500,
+ "html": "<h2>Expanded Highlighting in Open Resource Dialog</h2>The Open Resource dialog now shows you how the search term matches the found resources by highlighting the names based on camel-case and pattern ( * and ? ) searches."
+ },
+ {
+ "subject": "Json Tip",
+ "date": "2018-02-07",
+ "maxWidth": 500,
+ "url": "https://wiki.eclipse.org/Tip_of_the_Day/Eclipse_Tips/Json_Tip?action=render"
+ },
+ {
+ "subject": "Import/export preferences from preference dialog",
+ "date": "2018-01-21",
+ "image": "",
+ "ratio": 1.3,
+ "html": "<h2>Import/export preferences from preference dialog</h2>Easily accessible buttons for opening the <b>Import/Export</b> preferences wizards have been added to the lower left corner of the <b>Preferences</b> dialog. The wizards are still accessible through the <b>File > Import...</b> and <b>File > Export...</b> wizards."
+ }
+ ]
+ }
+}
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider.java
index 6036ace4d..b5a74d801 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider.java
@@ -27,9 +27,10 @@ import org.eclipse.tips.examples.tipsframework.Navigate2Tip;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
+@SuppressWarnings("restriction")
public class TestProvider extends org.eclipse.tips.core.TipProvider {
- private TipImage fImage64, fImage48;
+ private TipImage fImage48;
@Override
public TipImage getImage() {
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider1.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider1.java
index 5e900cd70..b83f98f70 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider1.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider1.java
@@ -27,9 +27,10 @@ import org.eclipse.tips.examples.tipsframework.Navigate2Tip;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
+@SuppressWarnings("restriction")
public class TestProvider1 extends org.eclipse.tips.core.TipProvider {
- private TipImage fImage64, fImage48;
+ private TipImage fImage48;
@Override
public TipImage getImage() {
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider2.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider2.java
index 3bd6b11b2..1bf781d16 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider2.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider2.java
@@ -27,9 +27,10 @@ import org.eclipse.tips.examples.tipsframework.Navigate2Tip;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
+@SuppressWarnings("restriction")
public class TestProvider2 extends org.eclipse.tips.core.TipProvider {
- private TipImage fImage64, fImage48;
+ private TipImage fImage48;
@Override
public TipImage getImage() {
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider3.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider3.java
index 18ee0bf31..54e0bfd96 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider3.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider3.java
@@ -27,9 +27,10 @@ import org.eclipse.tips.examples.tipsframework.Navigate2Tip;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
+@SuppressWarnings("restriction")
public class TestProvider3 extends org.eclipse.tips.core.TipProvider {
- private TipImage fImage64, fImage48;
+ private TipImage fImage48;
@Override
public TipImage getImage() {
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider4.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider4.java
index d896afae1..50b6da046 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider4.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider4.java
@@ -27,9 +27,10 @@ import org.eclipse.tips.examples.tipsframework.Navigate2Tip;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
+@SuppressWarnings("restriction")
public class TestProvider4 extends org.eclipse.tips.core.TipProvider {
- private TipImage fImage64, fImage48;
+ private TipImage fImage48;
@Override
public TipImage getImage() {
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider5.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider5.java
index cff85162c..271ddd4b0 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider5.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider5.java
@@ -27,9 +27,10 @@ import org.eclipse.tips.examples.tipsframework.Navigate2Tip;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
+@SuppressWarnings("restriction")
public class TestProvider5 extends org.eclipse.tips.core.TipProvider {
- private TipImage fImage64, fImage48;
+ private TipImage fImage48;
@Override
public TipImage getImage() {
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider6.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider6.java
index 6626d1b59..5bd3d4552 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider6.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider6.java
@@ -26,8 +26,9 @@ import org.eclipse.tips.examples.tipsframework.Navigate2Tip;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
+@SuppressWarnings("restriction")
public class TestProvider6 extends org.eclipse.tips.core.TipProvider {
- private TipImage fImage64, fImage48;
+ private TipImage fImage48;
@Override
public TipImage getImage() {
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider7.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider7.java
index f3fe1fdee..4cd095a49 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider7.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/test/TestProvider7.java
@@ -26,9 +26,10 @@ import org.eclipse.tips.examples.tipsframework.Navigate2Tip;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
+@SuppressWarnings("restriction")
public class TestProvider7 extends org.eclipse.tips.core.TipProvider {
- private TipImage fImage64, fImage48;
+ private TipImage fImage48;
@Override
public TipImage getImage() {
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tips/MediaWikiTip.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tips/MediaWikiTip.java
index b43867fe0..2e095d1dd 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tips/MediaWikiTip.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tips/MediaWikiTip.java
@@ -10,14 +10,11 @@
*******************************************************************************/
package org.eclipse.tips.examples.tips;
-import java.net.MalformedURLException;
-import java.net.URL;
import java.util.Date;
import org.eclipse.tips.core.IUrlTip;
import org.eclipse.tips.core.Tip;
import org.eclipse.tips.core.TipProvider;
-import org.eclipse.tips.core.internal.LogUtil;
/**
* Specialisation of Tip that receives an URL of a mediawiki page (e.g. Eclipse
@@ -45,14 +42,10 @@ public class MediaWikiTip extends Tip implements IUrlTip {
* "https://wiki.eclipse.org/Tip_of_the_Day/Eclipse_Tips/Now_where_was_I">https://wiki.eclipse.org/Tip_of_the_Day/Eclipse_Tips/Now_where_was_I</a>
* </p>
*
- * @param pProvider
- * the {@link TipProvider} that created this Tip
- * @param pPageUrl
- * the Eclipse wiki page containing a simple tip
- * @param pCreationDate
- * creation date
- * @param pSubject
- * the tips' subject
+ * @param pProvider the {@link TipProvider} that created this Tip
+ * @param pPageUrl the Eclipse wiki page containing a simple tip
+ * @param pCreationDate creation date
+ * @param pSubject the tips' subject
*/
public MediaWikiTip(String providerId, String pPageUrl, Date pCreationDate, String pSubject) {
super(providerId);
@@ -72,12 +65,7 @@ public class MediaWikiTip extends Tip implements IUrlTip {
}
@Override
- public URL getURL() {
- try {
- return new URL(fPageUrl.trim() + "?action=render");
- } catch (MalformedURLException e) {
-// getProvider().getManager().log(LogUtil.error(getClass(), e));
- }
- return null;
+ public String getURL() {
+ return fPageUrl.trim() + "?action=render";
}
} \ No newline at end of file
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tips/TwitterTip.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tips/TwitterTip.java
index 0d1e2cbcc..14a4cc21c 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tips/TwitterTip.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tips/TwitterTip.java
@@ -10,14 +10,11 @@
*******************************************************************************/
package org.eclipse.tips.examples.tips;
-import java.net.MalformedURLException;
-import java.net.URL;
import java.util.Date;
import org.eclipse.tips.core.IUrlTip;
import org.eclipse.tips.core.Tip;
import org.eclipse.tips.core.TipProvider;
-import org.eclipse.tips.core.internal.LogUtil;
/**
* Specialisation of Tip that receives an URL of a tweet in the constructor. The
@@ -41,14 +38,10 @@ public class TwitterTip extends Tip implements IUrlTip {
* "https://twitter.com/EclipseJavaIDE/status/919915440041840641">https://twitter.com/EclipseJavaIDE/status/919915440041840641</a>
* </p>
*
- * @param pProvider
- * the {@link TipProvider} that created this Tip
- * @param pTweetUrl
- * the URL of the tweet
- * @param pCreationDate
- * creation date
- * @param pSubject
- * the tips' subject
+ * @param pProvider the {@link TipProvider} that created this Tip
+ * @param pTweetUrl the URL of the tweet
+ * @param pCreationDate creation date
+ * @param pSubject the tips' subject
*/
public TwitterTip(String providerId, String pTweetUrl, Date pCreationDate, String pSubject) {
super(providerId);
@@ -68,12 +61,7 @@ public class TwitterTip extends Tip implements IUrlTip {
}
@Override
- public URL getURL() {
- try {
- return new URL(fPageUrl);
- } catch (MalformedURLException e) {
-// getProvider().getManager().log(LogUtil.error(getClass(), e));
- }
- return null;
+ public String getURL() {
+ return fPageUrl;
}
} \ No newline at end of file
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/GithubTip.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/GithubTip.java
index cad686913..525b5b245 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/GithubTip.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/GithubTip.java
@@ -26,8 +26,6 @@ import org.eclipse.tips.core.IHtmlTip;
import org.eclipse.tips.core.Tip;
import org.eclipse.tips.core.TipAction;
import org.eclipse.tips.core.TipImage;
-import org.eclipse.tips.core.TipProvider;
-import org.eclipse.tips.core.internal.LogUtil;
import org.eclipse.tips.examples.DateUtil;
public class GithubTip extends Tip implements IHtmlTip {
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/MatrixRainTip.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/MatrixRainTip.java
index c672a1bec..d6e64a9db 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/MatrixRainTip.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/MatrixRainTip.java
@@ -10,12 +10,10 @@
*******************************************************************************/
package org.eclipse.tips.examples.tipsframework;
-import java.net.URL;
import java.util.Date;
import org.eclipse.tips.core.IUrlTip;
import org.eclipse.tips.core.Tip;
-import org.eclipse.tips.core.TipProvider;
import org.eclipse.tips.examples.DateUtil;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
@@ -37,8 +35,8 @@ public class MatrixRainTip extends Tip implements IUrlTip {
}
@Override
- public URL getURL() {
+ public String getURL() {
Bundle bundle = FrameworkUtil.getBundle(getClass());
- return bundle.getEntry("matrixrain/index.html");
+ return bundle.getEntry("matrixrain/index.html").toString();
}
} \ No newline at end of file
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/Navigate1Tip.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/Navigate1Tip.java
index e39a02e2f..9abecd207 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/Navigate1Tip.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/Navigate1Tip.java
@@ -22,8 +22,6 @@ import org.eclipse.tips.core.IHtmlTip;
import org.eclipse.tips.core.Tip;
import org.eclipse.tips.core.TipAction;
import org.eclipse.tips.core.TipImage;
-import org.eclipse.tips.core.TipProvider;
-import org.eclipse.tips.core.internal.LogUtil;
import org.eclipse.tips.examples.DateUtil;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/Navigate2Tip.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/Navigate2Tip.java
index e997e5102..d22a62d93 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/Navigate2Tip.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/Navigate2Tip.java
@@ -15,8 +15,6 @@ import java.util.Date;
import org.eclipse.tips.core.IHtmlTip;
import org.eclipse.tips.core.Tip;
import org.eclipse.tips.core.TipImage;
-import org.eclipse.tips.core.TipProvider;
-import org.eclipse.tips.core.internal.LogUtil;
import org.eclipse.tips.examples.DateUtil;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/StartingTip.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/StartingTip.java
index f55cdacd5..a720c6815 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/StartingTip.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/StartingTip.java
@@ -15,8 +15,6 @@ import java.util.Date;
import org.eclipse.tips.core.IHtmlTip;
import org.eclipse.tips.core.Tip;
import org.eclipse.tips.core.TipImage;
-import org.eclipse.tips.core.TipProvider;
-import org.eclipse.tips.core.internal.LogUtil;
import org.eclipse.tips.examples.DateUtil;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/TipsTipProvider.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/TipsTipProvider.java
index ff6a1299f..598befcf6 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/TipsTipProvider.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/TipsTipProvider.java
@@ -24,9 +24,10 @@ import org.eclipse.tips.core.internal.LogUtil;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
+@SuppressWarnings("restriction")
public class TipsTipProvider extends org.eclipse.tips.core.TipProvider {
- private TipImage fImage64, fImage48;
+ private TipImage fImage48;
@Override
public TipImage getImage() {
diff --git a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/WelcomeTip.java b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/WelcomeTip.java
index f07436127..f68ea4a16 100644
--- a/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/WelcomeTip.java
+++ b/org.eclipse.tips.examples/src/org/eclipse/tips/examples/tipsframework/WelcomeTip.java
@@ -15,7 +15,6 @@ import java.util.Date;
import org.eclipse.tips.core.IHtmlTip;
import org.eclipse.tips.core.Tip;
import org.eclipse.tips.core.TipImage;
-import org.eclipse.tips.core.TipProvider;
import org.eclipse.tips.examples.DateUtil;
public class WelcomeTip extends Tip implements IHtmlTip {
diff --git a/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/IDETipManager.java b/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/IDETipManager.java
index 5cd8f4d55..a7e64f51a 100644
--- a/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/IDETipManager.java
+++ b/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/IDETipManager.java
@@ -27,7 +27,6 @@ import org.eclipse.core.expressions.ExpressionConverter;
import org.eclipse.core.expressions.IEvaluationContext;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
-import org.eclipse.core.runtime.Platform;
import org.eclipse.core.runtime.Status;
import org.eclipse.core.runtime.SubMonitor;
import org.eclipse.core.runtime.jobs.Job;
@@ -39,8 +38,6 @@ import org.eclipse.tips.core.internal.TipManager;
import org.eclipse.tips.ui.internal.DefaultTipManager;
import org.eclipse.ui.PlatformUI;
import org.eclipse.ui.services.IEvaluationService;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.FrameworkUtil;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
@@ -50,7 +47,7 @@ import org.w3c.dom.Element;
@SuppressWarnings("restriction")
public class IDETipManager extends DefaultTipManager {
- private TipSourceProvider fSourceProvider = new TipSourceProvider();
+ private TipSourceProvider fSourceProvider = new TipSourceProvider(this);
private Map<String, List<Integer>> fReadTips = new HashMap<>();
@@ -75,13 +72,14 @@ public class IDETipManager extends DefaultTipManager {
@Override
public ITipManager register(TipProvider provider) {
+ log(LogUtil.info("Registering provider " + provider.getID()));
super.register(provider);
load(provider);
return this;
}
private void load(TipProvider provider) {
- Job job = new Job("Loading " + provider.getDescription()) {
+ Job job = new Job("Loading " + provider.getID()) {
@Override
protected IStatus run(IProgressMonitor monitor) {
return provider.loadNewTips(monitor);
@@ -89,6 +87,7 @@ public class IDETipManager extends DefaultTipManager {
};
job.addJobChangeListener(new ProviderLoadJobChangeListener(this, provider));
job.schedule();
+ provider.getManager().log(LogUtil.info(String.format("Load new tips job started for %s", provider.getID())));
}
@Override
@@ -167,13 +166,7 @@ public class IDETipManager extends DefaultTipManager {
@Override
public ITipManager log(IStatus status) {
- if (status.matches(IStatus.ERROR | IStatus.WARNING)) {
- Bundle bundle = FrameworkUtil.getBundle(getClass());
- Platform.getLog(bundle).log(status);
- }
- if (System.getProperty("org.eclipse.tips.consolelog") != null) {
- System.out.println(status.toString());
- }
+ TipsPreferences.log(status);
return this;
}
@@ -200,6 +193,7 @@ public class IDETipManager extends DefaultTipManager {
}
protected synchronized IDETipManager setNewTips(boolean newTips) {
+ log(LogUtil.info(String.format("New tips %s", newTips + "")));
if (fNewTips != newTips) {
fNewTips = newTips;
fSourceProvider.setStatus(fNewTips);
diff --git a/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/Startup.java b/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/Startup.java
index 6dd253b62..96a7e55aa 100644
--- a/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/Startup.java
+++ b/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/Startup.java
@@ -16,6 +16,8 @@ import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.Platform;
import org.eclipse.core.runtime.Status;
+import org.eclipse.core.runtime.SubMonitor;
+import org.eclipse.core.runtime.jobs.Job;
import org.eclipse.tips.core.TipProvider;
import org.eclipse.tips.json.internal.ProviderLoader;
import org.eclipse.ui.IStartup;
@@ -33,33 +35,47 @@ public class Startup implements IStartup {
@Override
public void earlyStartup() {
- openManager();
loadProviders();
+ openManager();
}
/**
* Reloads the tip providers.
*/
public static void loadProviders() {
- loadExternalProviders();
loadInternalProviders();
+ loadExternalProviders();
}
- private static void loadExternalProviders() {
- String baseURL = System.getProperty("org.eclipse.tips.ide.provider.url");
- if (baseURL == null) {
- baseURL = "http://www.eclipse.org/downloads/download.php?r=1&file=/e4/tips/";
- }
- try {
- ProviderLoader.loadProviderData(IDETipManager.getInstance(), baseURL, IDETipManager.getStateLocation());
- } catch (Exception e) {
- IDETipManager.getInstance()
- .log(new Status(IStatus.ERROR, FrameworkUtil.getBundle(Startup.class).getSymbolicName(),
- "Failure getting the Tips state location.", e));
- }
+ private static void loadInternalProviders() {
+ getInternalProvidersJob().schedule();
}
- private static void loadInternalProviders() {
+ private static Job getInternalProvidersJob() {
+ Job job = new Job("Load default IDE Tip Providers") {
+
+ @Override
+ protected IStatus run(IProgressMonitor pArg0) {
+ String baseURL = System.getProperty("org.eclipse.tips.ide.provider.url");
+ if (baseURL == null) {
+ baseURL = "http://www.eclipse.org/downloads/download.php?r=1&file=/e4/tips/";
+ }
+ try {
+ ProviderLoader.loadProviderData(IDETipManager.getInstance(), baseURL,
+ IDETipManager.getStateLocation());
+ } catch (Exception e) {
+ Status status = new Status(IStatus.ERROR, FrameworkUtil.getBundle(Startup.class).getSymbolicName(),
+ "Failure getting the Tips state location.", e);
+ IDETipManager.getInstance().log(status);
+ return status;
+ }
+ return Status.OK_STATUS;
+ };
+ };
+ return job;
+ }
+
+ private static void loadExternalProviders() {
IConfigurationElement[] elements = Platform.getExtensionRegistry()
.getConfigurationElementsFor("org.eclipse.tips.core.tips");
for (IConfigurationElement element : elements) {
@@ -116,14 +132,69 @@ public class Startup implements IStartup {
}
private static void openManager() {
- UIJob job = new UIJob(PlatformUI.getWorkbench().getDisplay(), "Tip of the Day") {
+ if (IDETipManager.getInstance().hasContent()) {
+ getOpenUIJob().schedule();
+ } else {
+ getWaitJob().schedule();
+ }
+ }
+
+ private static Job getWaitJob() {
+ Job waitJob = new Job("Tip Delay") {
+
+ @Override
+ protected IStatus run(IProgressMonitor pMonitor) {
+ int attempts = 3;
+ SubMonitor monitor = SubMonitor.convert(pMonitor, attempts);
+ for (int i = 0; i < attempts; i++) {
+ monitor.setTaskName("Checking for content " + i);
+ if (openOrSleep(monitor)) {
+ if (monitor.isCanceled()) {
+ return Status.CANCEL_STATUS;
+ } else {
+ monitor.done();
+ return Status.OK_STATUS;
+ }
+ }
+ monitor.worked(1);
+ }
+ monitor.done();
+ return Status.OK_STATUS;
+ }
+
+ private boolean openOrSleep(SubMonitor pMonitor) {
+ if (IDETipManager.getInstance().hasContent()) {
+ getOpenUIJob().schedule();
+ return true;
+ }
+ if (sleep(1000)) {
+ pMonitor.setCanceled(true);
+ return true;
+ }
+ return false;
+ }
+
+ private boolean sleep(int millis) {
+ try {
+ Thread.sleep(millis);
+ return false;
+ } catch (InterruptedException e) {
+ return true;
+ }
+ }
+ };
+ return waitJob;
+ }
+
+ private static UIJob getOpenUIJob() {
+ UIJob uiJob = new UIJob(PlatformUI.getWorkbench().getDisplay(), "Tip of the Day") {
@Override
public IStatus runInUIThread(IProgressMonitor monitor) {
IDETipManager.getInstance().open(true);
return Status.OK_STATUS;
}
};
- job.schedule();
+ return uiJob;
}
private static void log(CoreException e) {
diff --git a/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/TipSourceProvider.java b/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/TipSourceProvider.java
index 3877c8c73..60f0a8664 100644
--- a/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/TipSourceProvider.java
+++ b/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/TipSourceProvider.java
@@ -16,6 +16,8 @@ import java.util.Map;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.Status;
+import org.eclipse.tips.core.ITipManager;
+import org.eclipse.tips.core.internal.LogUtil;
import org.eclipse.ui.AbstractSourceProvider;
import org.eclipse.ui.ISources;
import org.eclipse.ui.IWorkbenchWindow;
@@ -26,10 +28,13 @@ import org.eclipse.ui.progress.UIJob;
* Internal class to source a new boolean variable in the IDE called "newtips".
*
*/
+@SuppressWarnings("restriction")
public class TipSourceProvider extends AbstractSourceProvider {
private boolean fNewTips;
+ private ITipManager fManager;
- public TipSourceProvider() {
+ public TipSourceProvider(ITipManager manager) {
+ fManager = manager;
}
@Override
@@ -52,8 +57,8 @@ public class TipSourceProvider extends AbstractSourceProvider {
* Propagate the new status of the <code>newtips</code> variable but always
* layouts all workbench windows to update the trim status.
*
- * @param newTips
- * true if there are new tips, false if there are no more new tips.
+ * @param newTips true if there are new tips, false if there are no more new
+ * tips.
*/
public synchronized void setStatus(boolean newTips) {
boolean changed = fNewTips != newTips;
@@ -71,7 +76,7 @@ public class TipSourceProvider extends AbstractSourceProvider {
fireSourceChanged(ISources.ACTIVE_WORKBENCH_WINDOW, getCurrentState());
}
for (IWorkbenchWindow window : PlatformUI.getWorkbench().getWorkbenchWindows()) {
- System.out.println("layout on " + window + " -> " + fNewTips);
+ fManager.log(LogUtil.info("Layout on " + window + " -> " + fNewTips));
window.getShell().layout(true, true);
}
return Status.OK_STATUS;
diff --git a/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/TipsPreferences.java b/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/TipsPreferences.java
index 13bccf699..144e9f912 100644
--- a/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/TipsPreferences.java
+++ b/org.eclipse.tips.ide/src/org/eclipse/tips/ide/internal/TipsPreferences.java
@@ -13,6 +13,7 @@ package org.eclipse.tips.ide.internal;
import java.io.File;
import java.io.FilenameFilter;
import java.util.ArrayList;
+import java.util.Calendar;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@@ -135,13 +136,14 @@ public class TipsPreferences extends AbstractPreferenceInitializer {
return node;
}
- private static void log(IStatus status) {
- if (status.matches(IStatus.ERROR | IStatus.WARNING)) {
+ public static void log(IStatus status) {
+ if (status.matches(IStatus.ERROR | IStatus.WARNING) || isDebug()) {
Bundle bundle = FrameworkUtil.getBundle(TipsPreferences.class);
Platform.getLog(bundle).log(status);
}
- if (System.getProperty("org.eclipse.tips.consolelog") != null) {
- System.out.println(status.toString());
+ if (isConsoleLog()) {
+ System.out.println(
+ String.format("%1$tR:%1$tS:%1$tN - %2$s", Calendar.getInstance().getTime(), status.toString()));
}
}
@@ -172,4 +174,18 @@ public class TipsPreferences extends AbstractPreferenceInitializer {
throw new RuntimeException(e);
}
}
+
+ /**
+ * @return true if tips are in debug mode.
+ */
+ public static boolean isDebug() {
+ return !System.getProperty("org.eclipse.tips.debug", "false").equals("false");
+ }
+
+ /**
+ * @return true if console logging is required
+ */
+ public static boolean isConsoleLog() {
+ return !System.getProperty("org.eclipse.tips.consolelog", "false").equals("false");
+ }
} \ No newline at end of file
diff --git a/org.eclipse.tips.json/src/org/eclipse/tips/json/JsonTipProvider.java b/org.eclipse.tips.json/src/org/eclipse/tips/json/JsonTipProvider.java
index c9286268a..9f76231ee 100644
--- a/org.eclipse.tips.json/src/org/eclipse/tips/json/JsonTipProvider.java
+++ b/org.eclipse.tips.json/src/org/eclipse/tips/json/JsonTipProvider.java
@@ -10,6 +10,7 @@
*******************************************************************************/
package org.eclipse.tips.json;
+import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
@@ -45,6 +46,7 @@ public abstract class JsonTipProvider extends TipProvider {
private URL fJsonUrl;
private String fDescription;
private String fImage;
+ private JsonObject fJsonObject;
/**
* A method to set the a url containing a JSon file that describes this tip
@@ -57,39 +59,76 @@ public abstract class JsonTipProvider extends TipProvider {
fJsonUrl = new URL(jsonUrl);
}
+ /**
+ * Returns a specific portion of the underlying json file as a json object, if
+ * the json object was not yet fetched it will be done here, making it a
+ * potential costly operation. The passed part can be an array to indicate a
+ * structure e.g. {"provider","variables"}.
+ *
+ * @param part one or more keys of the underlying json file, may not be null.
+ * @return the JSon Object as a string
+ * @throws IOException
+ * @see {@link #loadNewTips(IProgressMonitor)}
+ */
+ public synchronized String getJsonObject(String... part) throws IOException {
+ if (fJsonObject == null) {
+ fJsonObject = loadJsonObject();
+ }
+ JsonObject temp = fJsonObject.getAsJsonObject(part[0]);
+ for (int i = 1; i < part.length; i++) {
+ temp = temp.getAsJsonObject(part[0]);
+
+ }
+ return temp.getAsString();
+ }
+
+ /**
+ *
+ * {@inheritDoc}
+ *
+ * <p>
+ * <b>Implementation Details</b><br>
+ * The implementation of this method in this provider will fetch the json file
+ * and store it locally.
+ *
+ */
@Override
- public IStatus loadNewTips(IProgressMonitor monitor) {
+ public synchronized IStatus loadNewTips(IProgressMonitor monitor) {
SubMonitor subMonitor = SubMonitor.convert(monitor);
ArrayList<Tip> result = new ArrayList<>();
try {
subMonitor.beginTask(getDescription() + " Loading Tips", -1);
- try (InputStream stream = fJsonUrl.openStream(); InputStreamReader reader = new InputStreamReader(stream)) {
- JsonObject value = (JsonObject) new JsonParser().parse(reader);
- JsonObject provider = value.getAsJsonObject(JsonConstants.P_PROVIDER);
- fDescription = Util.getValueOrDefault(provider, JsonConstants.P_DESCRIPTION, "not set");
- fImage = Util.getValueOrDefault(provider, JsonConstants.P_IMAGE, null);
- setExpression(Util.getValueOrDefault(provider, JsonConstants.P_EXPRESSION, null));
- JsonArray tips = provider.getAsJsonArray(JsonConstants.P_TIPS);
- subMonitor.beginTask(getDescription() + " Creating Tips", -1);
- tips.forEach(parm -> result.add(createJsonTip(parm)));
- }
+ fJsonObject = loadJsonObject();
+ JsonObject provider = fJsonObject.getAsJsonObject(JsonConstants.P_PROVIDER);
+ fDescription = Util.getValueOrDefault(provider, JsonConstants.P_DESCRIPTION, "not set");
+ fImage = Util.getValueOrDefault(provider, JsonConstants.P_IMAGE, null);
+ setExpression(Util.getValueOrDefault(provider, JsonConstants.P_EXPRESSION, null));
+ JsonArray tips = provider.getAsJsonArray(JsonConstants.P_TIPS);
+ subMonitor.beginTask(getDescription() + " Creating Tips", -1);
+ tips.forEach(parm -> result.add(createJsonTip(parm)));
} catch (Exception e) {
Status status = new Status(IStatus.ERROR, "org.eclipse.tips.json", e.getMessage(), e);
getManager().log(status);
return status;
}
+ getManager().log(LogUtil.info(String.format("%s Tips loaded ", result.size() + "")));
setTips(result);
subMonitor.done();
return Status.OK_STATUS;
}
+ private JsonObject loadJsonObject() throws IOException {
+ try (InputStream stream = fJsonUrl.openStream(); InputStreamReader reader = new InputStreamReader(stream)) {
+ return (JsonObject) new JsonParser().parse(reader);
+ }
+ }
+
@Override
public TipImage getImage() {
if (fImage == null) {
return null;
}
return new TipImage(fImage);
-
}
@Override
@@ -99,11 +138,12 @@ public abstract class JsonTipProvider extends TipProvider {
private Tip createJsonTip(JsonElement parm) {
JsonObject json = (JsonObject) parm;
+ replaceVariables(json);
try {
- if (json.get(JsonConstants.T_URL) == null) {
- return new JsonHTMLTip(getID(), json);
- } else {
+ if (json.get(JsonConstants.T_URL) != null) {
return new JsonUrlTip(getID(), json);
+ } else {
+ return new JsonHTMLTip(getID(), json);
}
} catch (ParseException e) {
getManager().log(LogUtil.error(getClass(), e));
@@ -111,6 +151,25 @@ public abstract class JsonTipProvider extends TipProvider {
}
}
+ private void replaceVariables(JsonObject pJson) {
+ String url = Util.getValueOrDefault(pJson, JsonConstants.T_URL, null);
+ String html = Util.getValueOrDefault(pJson, JsonConstants.T_HTML, null);
+ JsonObject vars = fJsonObject.getAsJsonObject(JsonConstants.P_PROVIDER)
+ .getAsJsonObject(JsonConstants.T_VARIABLES);
+ if (vars != null) {
+ if (url != null) {
+ url = Util.replace(vars, url);
+ pJson.remove(JsonConstants.T_URL);
+ pJson.addProperty(JsonConstants.T_URL, url);
+ }
+ if (html != null) {
+ html = Util.replace(vars, html);
+ pJson.remove(JsonConstants.T_HTML);
+ pJson.addProperty(JsonConstants.T_HTML, html);
+ }
+ }
+ }
+
@Override
public void dispose() {
}
diff --git a/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonConstants.java b/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonConstants.java
index 9e5df148e..5a4a7b095 100644
--- a/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonConstants.java
+++ b/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonConstants.java
@@ -100,4 +100,9 @@ public class JsonConstants {
* Tip URL
*/
public static final String T_URL = "url";
+
+ /**
+ * Tip variables
+ */
+ public static final String T_VARIABLES = "variables";
} \ No newline at end of file
diff --git a/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonHTMLTip.java b/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonHTMLTip.java
index 96e0f2af6..91d2aafd0 100644
--- a/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonHTMLTip.java
+++ b/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonHTMLTip.java
@@ -31,21 +31,18 @@ public class JsonHTMLTip extends Tip implements IJsonTip, IHtmlTip {
private Date fDate;
private String fHtml;
private TipImage fTipImage;
- private String fJsonObject;
+ private JsonObject fJsonObject;
/**
* Creates the tip out od the passed Json object.
*
- * @param jsonObject
- * the json object
- * @param provider
- * the provider
- * @throws ParseException
- * when the json object could not be parsed.
+ * @param jsonObject the json object
+ * @param provider the provider
+ * @throws ParseException when the json object could not be parsed.
*/
public JsonHTMLTip(String providerId, JsonObject jsonObject) throws ParseException {
super(providerId);
- fJsonObject = jsonObject.toString();
+ fJsonObject = jsonObject;
fSubject = Util.getValueOrDefault(jsonObject, JsonConstants.T_SUBJECT, "Not set");
fDate = getDate(jsonObject);
fHtml = Util.getValueOrDefault(jsonObject, JsonConstants.T_HTML, null);
@@ -75,7 +72,7 @@ public class JsonHTMLTip extends Tip implements IJsonTip, IHtmlTip {
@Override
public String getJsonObject() {
- return fJsonObject;
+ return fJsonObject.toString();
}
@Override
@@ -85,7 +82,7 @@ public class JsonHTMLTip extends Tip implements IJsonTip, IHtmlTip {
@Override
public String getHTML() {
- return fHtml;
+ return Util.replace(fJsonObject, fHtml);
}
@Override
diff --git a/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonUrlTip.java b/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonUrlTip.java
index 399c2e126..558063ffe 100644
--- a/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonUrlTip.java
+++ b/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/JsonUrlTip.java
@@ -10,8 +10,6 @@
*******************************************************************************/
package org.eclipse.tips.json.internal;
-import java.net.MalformedURLException;
-import java.net.URL;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
@@ -30,21 +28,18 @@ public class JsonUrlTip extends Tip implements IUrlTip, IJsonTip {
private String fSubject;
private Date fDate;
private String fUrl;
- private String fJsonObject;
+ private JsonObject fJsonObject;
/**
* Creates the tip out of the passed Json object.
*
- * @param jsonObject
- * the json object
- * @param provider
- * the provider
- * @throws ParseException
- * when the json object could not be parsed.
+ * @param jsonObject the json object
+ * @param provider the provider
+ * @throws ParseException when the json object could not be parsed.
*/
public JsonUrlTip(String providerId, JsonObject jsonObject) throws ParseException {
super(providerId);
- fJsonObject = jsonObject.toString();
+ fJsonObject = jsonObject;
fSubject = Util.getValueOrDefault(jsonObject, JsonConstants.T_SUBJECT, "Not set");
fDate = getDate(jsonObject);
fUrl = Util.getValueOrDefault(jsonObject, JsonConstants.T_URL, null);
@@ -62,17 +57,8 @@ public class JsonUrlTip extends Tip implements IUrlTip, IJsonTip {
}
@Override
- public URL getURL() {
- if (fUrl == null) {
- return null;
- }
- try {
- return new URL(fUrl);
- } catch (MalformedURLException e) {
- // TODO shoud thrown exeception and calling code should log
-// getProvider().getManager().log(LogUtil.error(getClass(), e));
- return null;
- }
+ public String getURL() {
+ return Util.replace(fJsonObject, fUrl);
}
@Override
@@ -82,6 +68,6 @@ public class JsonUrlTip extends Tip implements IUrlTip, IJsonTip {
@Override
public String getJsonObject() {
- return fJsonObject;
+ return fJsonObject.getAsString();
}
} \ No newline at end of file
diff --git a/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/ProviderLoader.java b/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/ProviderLoader.java
index 2173001fe..db2aad371 100644
--- a/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/ProviderLoader.java
+++ b/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/ProviderLoader.java
@@ -23,10 +23,12 @@ import java.net.URL;
import java.nio.file.Files;
import java.nio.file.StandardCopyOption;
+import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.Platform;
import org.eclipse.core.runtime.Status;
import org.eclipse.tips.core.ITipManager;
+import org.eclipse.tips.core.internal.LogUtil;
import org.eclipse.tips.json.JsonTipProvider;
import org.osgi.framework.Bundle;
import org.osgi.framework.FrameworkUtil;
@@ -40,6 +42,7 @@ import com.google.gson.JsonParser;
* A helper class to load providers from an internet location.
*
*/
+@SuppressWarnings("restriction")
public class ProviderLoader {
/**
@@ -56,11 +59,12 @@ public class ProviderLoader {
private static void loadProviders(ITipManager pManager, String pBaseURL, File stateLocation) {
try {
- URL webFile = new URL(pBaseURL + "providers.json");
- File target = new File(stateLocation, "providers.json");
+ URL webFile = new URL(pBaseURL + "index.json");
+ File target = new File(stateLocation, "index.json");
try (InputStream in = webFile.openStream()) {
Files.copy(in, target.toPath(), StandardCopyOption.REPLACE_EXISTING);
}
+ pManager.log(LogUtil.info("Internal Providers index file loaded to " + target.toPath()));
createProviders(pManager, target, pBaseURL, stateLocation);
} catch (Exception e) {
String symbolicName = FrameworkUtil.getBundle(ProviderLoader.class).getSymbolicName();
@@ -80,12 +84,15 @@ public class ProviderLoader {
private static void loadProvider(ITipManager pManager, JsonElement pProvider, String pBaseURL, File userLocation) {
JsonObject provider = pProvider.getAsJsonObject();
String version = Util.getValueOrDefault(provider, "version", null);
+ String location = Util.getValueOrDefault(provider, "location", null);
String bundleName = Util.getValueOrDefault(provider, "require-bundle", null);
if (version == null || bundleName == null) {
logInvalidProvider(pManager, provider);
return;
}
-
+ pManager.log(LogUtil
+ .info(String.format("Provider points to location %s. Last fetched version %s. Requires bundle %s",
+ location, version, bundleName)));
Bundle bundle = Platform.getBundle(bundleName);
if (bundle == null) {
logInvalidProvider(pManager, provider);
@@ -109,7 +116,8 @@ public class ProviderLoader {
String existingVersion = getFileContent(versionFile);
File providerFile = new File(fileLocation, "provider.json");
if (!version.equals(existingVersion) || !providerFile.exists()) {
- URL webFile = new URL(pBaseURL + "/" + bundleName + "/provider.json");
+ pManager.log(LogUtil.info(String.format("Old version: %s. New version %s", existingVersion, version)));
+ URL webFile = new URL(pBaseURL + "/" + location);
try (InputStream in = webFile.openStream()) {
Files.copy(in, providerFile.toPath(), StandardCopyOption.REPLACE_EXISTING);
}
@@ -128,17 +136,27 @@ public class ProviderLoader {
private static void registerProvider(ITipManager pManager, String bundleName, File pFileLocation)
throws IOException, MalformedURLException {
- File fileLocation;
JsonTipProvider tipProvider = new JsonTipProvider() {
@Override
public String getID() {
return bundleName + ".json.provider";
}
+
+ @Override
+ public synchronized IStatus loadNewTips(IProgressMonitor pMonitor) {
+ getManager().log(LogUtil.info(String.format("Load new tips START for %s", getID())));
+ IStatus status = super.loadNewTips(pMonitor);
+ getManager().log(status);
+ getManager().log(LogUtil.info(String.format("Load new tips END for %s", getID())));
+ return status;
+ }
};
- fileLocation = new File(pFileLocation, "provider.json");
- tipProvider.setJsonUrl(fileLocation.toURI().toURL().toString());
+ File providerFile = new File(pFileLocation, "provider.json");
+ String fileLocation = providerFile.toURI().toURL().toString();
+ tipProvider.setJsonUrl(fileLocation);
+ pManager.log(LogUtil.info(String.format("Provider file stored at %s", fileLocation)));
pManager.register(tipProvider);
}
diff --git a/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/Util.java b/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/Util.java
index c66a89ed1..7e69ea58c 100644
--- a/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/Util.java
+++ b/org.eclipse.tips.json/src/org/eclipse/tips/json/internal/Util.java
@@ -1,6 +1,13 @@
package org.eclipse.tips.json.internal;
+import java.io.ByteArrayInputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+
+import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
+import com.google.gson.JsonParser;
public class Util {
@@ -8,12 +15,10 @@ public class Util {
* Parses the passed json or returns a default value.
*
* @param jsonObject
- * @param element
- * the value to return in case the jsonObject does not contain the
- * specified value.
- * @param defaultValue
- * the value to return in case the jsonObject does not contain the
- * specified value.
+ * @param element the value to return in case the jsonObject does not
+ * contain the specified value.
+ * @param defaultValue the value to return in case the jsonObject does not
+ * contain the specified value.
* @return the returned value
*/
public static String getValueOrDefault(JsonObject jsonObject, String element, String defaultValue) {
@@ -27,12 +32,10 @@ public class Util {
* Parses the passed json or returns a default value.
*
* @param jsonObject
- * @param element
- * the value to return in case the jsonObject does not contain the
- * specified value.
- * @param defaultValue
- * the value to return in case the jsonObject does not contain the
- * specified value.
+ * @param element the value to return in case the jsonObject does not
+ * contain the specified value.
+ * @param defaultValue the value to return in case the jsonObject does not
+ * contain the specified value.
* @return the returned value
*/
public static int getValueOrDefault(JsonObject jsonObject, String element, int defaultValue) {
@@ -46,12 +49,10 @@ public class Util {
* Parses the passed json or returns a default value.
*
* @param jsonObject
- * @param element
- * the value to return in case the jsonObject does not contain the
- * specified value.
- * @param defaultValue
- * the value to return in case the jsonObject does not contain the
- * specified value.
+ * @param element the value to return in case the jsonObject does not
+ * contain the specified value.
+ * @param defaultValue the value to return in case the jsonObject does not
+ * contain the specified value.
* @return the returned value
*/
public static double getValueOrDefault(JsonObject jsonObject, String element, double defaultValue) {
@@ -60,4 +61,59 @@ public class Util {
}
return defaultValue;
}
+
+ /**
+ * Replaces all keys in the passed, json object that represent a primitive
+ * value, in the input string. If the passed json object contains a
+ * {@link JsonConstants#T_VARIABLES} object then this is parsed as well.
+ * <p>
+ * Example:
+ *
+ * <pre>
+ * json object: {"first": "Wim", "last": "Jongman", "variables": {"title": "Mr.", "age": 53}}
+ * input: "${title} ${first} ${last} is ${age} years old."
+ * output: "Mr. Wim Jongman is 53 years old"
+ * </pre>
+ *
+ * @param object the input json object
+ * @param input the string to scan
+ * @return the replaced string
+ */
+ public static String replace(JsonObject object, String input) {
+ String result = doReplace(object, input);
+ JsonObject vars = object.getAsJsonObject(JsonConstants.T_VARIABLES);
+ if (vars != null) {
+ result = Util.replace(vars, result);
+ }
+ return result;
+ }
+
+ private static String doReplace(JsonObject object, String input) {
+ String result = input;
+ for (String key : object.keySet()) {
+ JsonElement jsonElement = object.get(key);
+ if (jsonElement.isJsonPrimitive()) {
+ String search = "${" + key + "}";
+ String replace = jsonElement.getAsString();
+ int index = result.indexOf(search);
+ while (index > -1) {
+ result = result.substring(0, index) + replace + result.substring(index + search.length());
+ index = result.indexOf(search);
+ }
+ }
+ }
+ return result;
+ }
+
+ /**
+ * @param input the json string representation
+ * @return the parsed json object
+ * @throws IOException
+ */
+ public static JsonObject getJson(String input) throws IOException {
+ try (InputStream stream = new ByteArrayInputStream(input.getBytes());
+ InputStreamReader reader = new InputStreamReader(stream)) {
+ return (JsonObject) new JsonParser().parse(reader);
+ }
+ }
}
diff --git a/org.eclipse.tips.tests/META-INF/MANIFEST.MF b/org.eclipse.tips.tests/META-INF/MANIFEST.MF
index f1959ea29..7df8e332e 100644
--- a/org.eclipse.tips.tests/META-INF/MANIFEST.MF
+++ b/org.eclipse.tips.tests/META-INF/MANIFEST.MF
@@ -15,3 +15,4 @@ Require-Bundle: org.junit;bundle-version="4.12.0",
org.eclipse.tips.ui;bundle-version="0.1.0",
org.eclipse.tips.json;bundle-version="0.1.0"
Automatic-Module-Name: org.eclipse.tips.tests
+Import-Package: com.google.gson
diff --git a/org.eclipse.tips.tests/src/org/eclipse/tips/json/internal/UtilTest.java b/org.eclipse.tips.tests/src/org/eclipse/tips/json/internal/UtilTest.java
new file mode 100644
index 000000000..7e16c41a6
--- /dev/null
+++ b/org.eclipse.tips.tests/src/org/eclipse/tips/json/internal/UtilTest.java
@@ -0,0 +1,69 @@
+package org.eclipse.tips.json.internal;
+
+import static org.junit.Assert.assertTrue;
+
+import java.io.IOException;
+
+import org.junit.Test;
+
+import com.google.gson.JsonObject;
+
+public class UtilTest {
+
+ @SuppressWarnings("restriction")
+ @Test
+ public void testGetValueOrDefaultJsonObjectStringString() throws IOException {
+ String jsonString = "{\"first\": \"Wim\", \"last\": \"Jongman\", \"variables\": {\"title\": \"Mr.\", \"age\": 53}}";
+ JsonObject jsonObject = Util.getJson(jsonString);
+ assertTrue(Util.getValueOrDefault(jsonObject, "first", "Mark").equals("Wim"));
+ assertTrue(Util.getValueOrDefault(jsonObject, "fake", "Mark").equals("Mark"));
+ }
+
+ @SuppressWarnings("restriction")
+ @Test
+ public void testGetValueOrDefaultJsonObjectStringInt() throws IOException {
+ String jsonString = "{\"age\": \"53\", \"last\": \"Jongman\"}";
+ JsonObject jsonObject = Util.getJson(jsonString);
+ assertTrue(Util.getValueOrDefault(jsonObject, "age", 100) == 53);
+ assertTrue(Util.getValueOrDefault(jsonObject, "fake", 101) == 101);
+ }
+
+ @SuppressWarnings("restriction")
+ @Test
+ public void testGetValueOrDefaultJsonObjectStringDouble() throws IOException {
+ String jsonString = "{\"double\": 5.21, \"last\": \"Jongman\"}";
+ JsonObject jsonObject = Util.getJson(jsonString);
+ assertTrue(Util.getValueOrDefault(jsonObject, "double", 10.10) == 5.21);
+ assertTrue(Util.getValueOrDefault(jsonObject, "fake", 101.6) == 101.6);
+ }
+
+ @SuppressWarnings("restriction")
+ @Test
+ public void testReplace() throws IOException {
+ String input = "${title} ${first} ${last} is ${age} years old.";
+ String result = "Mr. Wim Jongman is 53 years old.";
+ String jsonString = "{\"first\": \"Wim\", \"last\": \"Jongman\", \"variables\": {\"title\": \"Mr.\", \"age\": 53}}";
+ String replace = Util.replace(Util.getJson(jsonString), input);
+ assertTrue(replace, replace.equals(result));
+ }
+
+ @SuppressWarnings("restriction")
+ @Test
+ public void testReplace2() throws IOException {
+ String input = "${title} ${first} ${last} ${ddd} is ${age} years old.${title}";
+ String result = "Mr. Wim Jongman ${ddd} is 53 years old.Mr.";
+ String jsonString = "{\"first\": \"Wim\", \"last\": \"Jongman\", \"variables\": {\"title\": \"Mr.\", \"age\": 53}}";
+ String replace = Util.replace(Util.getJson(jsonString), input);
+ assertTrue(replace, replace.equals(result));
+ }
+
+ @SuppressWarnings("restriction")
+ @Test
+ public void testReplace3() throws IOException {
+ String input = "${tit${empty}le}";
+ String result = "Mr.";
+ String jsonString = "{\"first\": \"Wim\", \"empty\": \"\", \"variables\": {\"title\": \"Mr.\", \"age\": 53}}";
+ String replace = Util.replace(Util.getJson(jsonString), input);
+ assertTrue(replace, replace.equals(result));
+ }
+}
diff --git a/org.eclipse.tips.tests/src/org/eclipse/tips/manual/tests/SleakTipManager.java b/org.eclipse.tips.tests/src/org/eclipse/tips/manual/tests/SleakTipManager.java
index 20fa208c0..9d2de1702 100644
--- a/org.eclipse.tips.tests/src/org/eclipse/tips/manual/tests/SleakTipManager.java
+++ b/org.eclipse.tips.tests/src/org/eclipse/tips/manual/tests/SleakTipManager.java
@@ -122,8 +122,7 @@ public class SleakTipManager extends TipManager {
@Override
public ITipManager log(IStatus pStatus) {
- // TODO Auto-generated method stub
- return null;
+ return this;
}
@Override
diff --git a/org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/DefaultTipManager.java b/org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/DefaultTipManager.java
index a2883e08e..78ce7658f 100644
--- a/org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/DefaultTipManager.java
+++ b/org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/DefaultTipManager.java
@@ -13,7 +13,6 @@ package org.eclipse.tips.ui.internal;
import org.eclipse.core.runtime.Assert;
import org.eclipse.swt.widgets.Display;
import org.eclipse.tips.core.ITipManager;
-import org.eclipse.tips.core.TipProvider;
import org.eclipse.tips.core.internal.LogUtil;
import org.eclipse.tips.core.internal.TipManager;
@@ -65,13 +64,8 @@ public abstract class DefaultTipManager extends TipManager {
return true;
}
if (startUp && isRunAtStartup()) {
- for (TipProvider provider : getProviders()) {
- if (provider.isReady() && !provider.getTips().isEmpty()) {
- return true;
- }
- }
+ return hasContent();
}
- return true;
+ return false;
}
-
} \ No newline at end of file
diff --git a/org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/Slider.java b/org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/Slider.java
index bf94357fe..6640d4178 100644
--- a/org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/Slider.java
+++ b/org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/Slider.java
@@ -112,7 +112,10 @@ public class Slider extends Composite {
}
private void setupProviderListener() {
- fPropertyChangeListener = provider -> getDisplay().asyncExec(() -> load());
+ fPropertyChangeListener = provider -> {
+ if (!isDisposed())
+ getDisplay().asyncExec(() -> load());
+ };
}
private static Image getImage(String icon) {
@@ -314,6 +317,9 @@ public class Slider extends Composite {
private void paintButton(GC gc, Composite providerButton, TipProvider provider) {
gc.setAdvanced(true);
+ if (!gc.getAdvanced()) {
+ throw new RuntimeException("not advanced");
+ }
if (provider.equals(fSelectedProvider)) {
gc.setForeground(getDisplay().getSystemColor(SWT.COLOR_LIST_SELECTION_TEXT));
gc.setBackground(getDisplay().getSystemColor(SWT.COLOR_LIST_SELECTION));
@@ -357,12 +363,9 @@ public class Slider extends Composite {
if (provider.getTips().isEmpty()) {
return getProviderImage(provider, selectProviderImage(provider));
}
- GC gc2 = new GC(providerButton);
- gc2.setAdvanced(true);
- gc2.setFont(SWTResourceManager.getBoldFont(gc2.getFont()));
+
int tipCount = provider.getTips().size();
- Point textExtent = gc2.textExtent(tipCount + "");
- gc2.dispose();
+ Point textExtent = getTipCountTextSize(providerButton, tipCount);
Image image = null;
if (tipCount > 9) {
@@ -383,7 +386,7 @@ public class Slider extends Composite {
}
gc.setForeground(getDisplay().getSystemColor(SWT.COLOR_WHITE));
gc.setFont(SWTResourceManager.getBoldFont(gc.getFont()));
- gc.setAlpha(210);
+ gc.setAlpha(200);
gc.setTextAntialias(SWT.ON);
if (tipCount > 9) {
gc.fillOval(0, 0, textExtent.x + 8, textExtent.y + 5);
@@ -398,4 +401,13 @@ public class Slider extends Composite {
gc.dispose();
return result;
}
+
+ private Point getTipCountTextSize(Composite providerButton, int tipCount) {
+ GC gc2 = new GC(providerButton);
+ gc2.setAdvanced(true);
+ gc2.setFont(SWTResourceManager.getBoldFont(gc2.getFont()));
+ Point textExtent = gc2.textExtent(tipCount + "");
+ gc2.dispose();
+ return textExtent;
+ }
} \ No newline at end of file
diff --git a/org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/TipComposite.java b/org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/TipComposite.java
index f1a792c5f..ae36efb51 100644
--- a/org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/TipComposite.java
+++ b/org.eclipse.tips.ui/src/org/eclipse/tips/ui/internal/TipComposite.java
@@ -11,6 +11,7 @@
package org.eclipse.tips.ui.internal;
import java.io.IOException;
+import java.net.URL;
import java.util.ArrayList;
import java.util.List;
import java.util.Timer;
@@ -85,10 +86,8 @@ public class TipComposite extends Composite implements ProviderSelectionListener
/**
* Constructor.
*
- * @param parent
- * the parent
- * @param style
- * the style
+ * @param parent the parent
+ * @param style the style
*/
public TipComposite(Composite parent, int style) {
super(parent, style);
@@ -280,8 +279,7 @@ public class TipComposite extends Composite implements ProviderSelectionListener
/**
* Sets the selected provider.
*
- * @param provider
- * the {@link TipProvider}
+ * @param provider the {@link TipProvider}
*/
public void setProvider(TipProvider provider) {
fProvider = provider;
@@ -345,7 +343,7 @@ public class TipComposite extends Composite implements ProviderSelectionListener
} else if (tip instanceof IUrlTip) {
loadContentUrl((IUrlTip) tip);
} else {
- fTipManager.log(LogUtil.error(getClass(), "Unknown Tip implementation: " + tip)) ;
+ fTipManager.log(LogUtil.error(getClass(), "Unknown Tip implementation: " + tip));
}
fContentComposite.requestLayout();
}
@@ -360,7 +358,8 @@ public class TipComposite extends Composite implements ProviderSelectionListener
private void loadContentUrl(IUrlTip tip) {
try {
- fBrowser.setUrl(FileLocator.resolve(tip.getURL()).toString());
+ String url = FileLocator.resolve(new URL(tip.getURL())).toString();
+ fBrowser.setUrl(url);
} catch (IOException e) {
fTipManager.log(LogUtil.error(getClass(), e));
}
@@ -473,8 +472,7 @@ public class TipComposite extends Composite implements ProviderSelectionListener
/**
* Get the timeout script in case the tips takes too to load.
*
- * @param timeout
- * the timeout in milliseconds
+ * @param timeout the timeout in milliseconds
* @return the script
*/
private static String getLoadingScript(int timeout) {
@@ -559,8 +557,7 @@ public class TipComposite extends Composite implements ProviderSelectionListener
/**
* Sets the {@link TipManager}
*
- * @param tipManager
- * the {@link TipManager} that opened the dialog.
+ * @param tipManager the {@link TipManager} that opened the dialog.
*/
public void setTipManager(TipManager tipManager) {
fTipManager = tipManager;

Back to the top