Bläddra i källkod

SDK
- Add check to open WelcomeScreen based on hash of loaded page content

git-svn-id: https://jmonkeyengine.googlecode.com/svn/trunk@10297 75d07b2b-3a1a-0410-a2c5-0572b91ccdca

nor..67 12 år sedan
förälder
incheckning
5a773ec05f

+ 56 - 8
jme3-welcome-screen/src/com/jme3/gde/welcome/WelcomeScreenTopComponent.java

@@ -4,7 +4,9 @@
  */
 package com.jme3.gde.welcome;
 
+import java.io.BufferedReader;
 import java.io.IOException;
+import java.io.InputStreamReader;
 import java.net.URL;
 import java.net.URLConnection;
 import java.util.logging.Level;
@@ -14,7 +16,6 @@ import javax.swing.event.HyperlinkListener;
 import org.netbeans.api.settings.ConvertAsProperties;
 import org.openide.awt.ActionID;
 import org.openide.awt.ActionReference;
-import org.openide.awt.HtmlBrowser.URLDisplayer;
 import org.openide.util.Exceptions;
 import org.openide.util.HelpCtx;
 import org.openide.windows.TopComponent;
@@ -32,7 +33,7 @@ autostore = false)
 @TopComponent.Description(
     preferredID = "WelcomeScreenTopComponent",
 //iconBase="SET/PATH/TO/ICON/HERE", 
-persistenceType = TopComponent.PERSISTENCE_NEVER)
+persistenceType = TopComponent.PERSISTENCE_ALWAYS)
 @TopComponent.Registration(mode = "editor", openAtStartup = true)
 @ActionID(category = "Window", id = "com.jme3.gde.welcome.WelcomeScreenTopComponent")
 @ActionReference(path = "Menu/Window" /*, position = 333 */)
@@ -64,12 +65,11 @@ public final class WelcomeScreenTopComponent extends TopComponent implements Hyp
     public void loadPage() {
         try {
             URL startUrl = new URL(org.openide.util.NbBundle.getMessage(WelcomeScreenTopComponent.class, "WelcomeScreenTopComponent.http.link"));
-            URLConnection conn = startUrl.openConnection();
-            long lastMod = conn.getLastModified();
+            long lastMod = getModified(startUrl);
             NbPreferences.forModule(getClass()).putLong("LAST_PAGE_UPDATE", lastMod);
             jEditorPane1.setPage(startUrl);
         } catch (IOException ex) {
-            logger.log(Level.INFO, "Loading page failed", ex);
+            logger.log(Level.INFO, "Loading welcome page from web failed", ex);
             try {
                 jEditorPane1.setPage(new URL(org.openide.util.NbBundle.getMessage(WelcomeScreenTopComponent.class, "WelcomeScreenTopComponent.local.link")));
             } catch (IOException ex1) {
@@ -79,12 +79,17 @@ public final class WelcomeScreenTopComponent extends TopComponent implements Hyp
     }
 
     public static void checkOpen() {
+        checkOpen(0);
+    }
+
+    public static void checkOpen(long lastMod) {
         try {
             long lastCheck = NbPreferences.forModule(WelcomeScreenTopComponent.class).getLong("LAST_PAGE_UPDATE", 0);
             URL startUrl = new URL(org.openide.util.NbBundle.getMessage(WelcomeScreenTopComponent.class, "WelcomeScreenTopComponent.http.link"));
-            URLConnection conn = startUrl.openConnection();
-            long lastMod = conn.getLastModified();
-            logger.log(Level.FINE, "Checking page time {0} vs stored time {1}", new Object[]{lastMod, lastCheck});
+            if (lastMod == 0) {
+                lastMod = getModified(startUrl);
+            }
+            logger.log(Level.INFO, "Checking page id {0} vs stored id {1}", new Object[]{lastMod, lastCheck});
             if (lastCheck != lastMod) {
                 WelcomeScreenTopComponent tc = (WelcomeScreenTopComponent) WindowManager.getDefault().findTopComponent("WelcomeScreenTopComponent");
                 if (tc != null) {
@@ -117,6 +122,49 @@ public final class WelcomeScreenTopComponent extends TopComponent implements Hyp
         }
     }
 
+    private static long getModified(URL url) {
+        try {
+            URLConnection conn = url.openConnection();
+            long lastMod = conn.getLastModified();
+            if (lastMod != 0) {
+                logger.log(Level.INFO, "Found getLastModified of {0}", lastMod);
+                return lastMod;
+            } else {
+                logger.log(Level.INFO, "Returning hash code of content", lastMod);
+                String content = getContent(conn);
+                return content.hashCode();
+            }
+        } catch (IOException ex) {
+            logger.log(Level.INFO, "Loading welcome page modified date from web failed", ex);
+        }
+        return 0;
+    }
+
+    private static String getContent(URLConnection connection) {
+        BufferedReader in = null;
+        try {
+            in = new BufferedReader(
+                    new InputStreamReader(
+                    connection.getInputStream()));
+            StringBuilder response = new StringBuilder();
+            String inputLine;
+            while ((inputLine = in.readLine()) != null) {
+                response.append(inputLine);
+            }
+            in.close();
+            return response.toString();
+        } catch (IOException ex) {
+            logger.log(Level.INFO, "Reading welcome page content from web failed", ex);
+        } finally {
+            try {
+                in.close();
+            } catch (IOException ex) {
+            logger.log(Level.INFO, "Closing reader for welcome page content from web failed", ex);
+            }
+        }
+        return "";
+    }
+
     /**
      * This method is called from within the constructor to initialize the form.
      * WARNING: Do NOT modify this code. The content of this method is always