Bugfixes and startup optimizations, update README.md

This commit is contained in:
Skylar 2015-06-02 12:14:28 -06:00
parent db689e81b6
commit 8a5cdb94d1
7 changed files with 453 additions and 428 deletions

View File

@ -15,4 +15,4 @@ http://symatapp.com/
Report a Bug Report a Bug
------ ------
To report bugs, go to: http://bugs.aplabs.us/thebuggenie/symat/issues/new To report bugs, go to: https://github.com/ApocalypseLaboratories/SyMAT/issues

View File

@ -39,6 +39,7 @@ file.reference.flamingo-6.3.jar=lib/flamingo-6.3.jar
file.reference.htmlcleaner-2.10.jar=lib/htmlcleaner-2.10.jar file.reference.htmlcleaner-2.10.jar=lib/htmlcleaner-2.10.jar
file.reference.iText-4.2.0-com.itextpdf.jar=lib/iText-4.2.0-com.itextpdf.jar file.reference.iText-4.2.0-com.itextpdf.jar=lib/iText-4.2.0-com.itextpdf.jar
file.reference.JavaPrettify-1.2.1.jar=lib\\JavaPrettify-1.2.1.jar file.reference.JavaPrettify-1.2.1.jar=lib\\JavaPrettify-1.2.1.jar
file.reference.JGoogleAnalytics_0.4.jar=lib\\JGoogleAnalytics_0.4.jar
file.reference.jmathplot.jar=lib/jmathplot.jar file.reference.jmathplot.jar=lib/jmathplot.jar
file.reference.js-engine.jar=lib/js-engine.jar file.reference.js-engine.jar=lib/js-engine.jar
file.reference.js.jar=lib/js.jar file.reference.js.jar=lib/js.jar
@ -70,7 +71,8 @@ javac.classpath=\
${file.reference.seaglasslookandfeel-0.2.jar}:\ ${file.reference.seaglasslookandfeel-0.2.jar}:\
${file.reference.symja-2014-11-01.jar}:\ ${file.reference.symja-2014-11-01.jar}:\
${file.reference.trident-6.3.jar}:\ ${file.reference.trident-6.3.jar}:\
${file.reference.JavaPrettify-1.2.1.jar} ${file.reference.JavaPrettify-1.2.1.jar}:\
${file.reference.JGoogleAnalytics_0.4.jar}
# Space-separated list of extra javac options # Space-separated list of extra javac options
javac.compilerargs= javac.compilerargs=
javac.deprecation=false javac.deprecation=false

View File

@ -56,17 +56,12 @@ import java.awt.event.ActionEvent;
import java.awt.event.ActionListener; import java.awt.event.ActionListener;
import java.awt.event.WindowAdapter; import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent; import java.awt.event.WindowEvent;
import java.io.BufferedReader;
import java.io.File; import java.io.File;
import java.io.FilenameFilter; import java.io.FilenameFilter;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.URL;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Calendar; import java.util.Calendar;
import java.util.Date;
import java.util.GregorianCalendar; import java.util.GregorianCalendar;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
@ -104,7 +99,7 @@ public class Main extends JRibbonFrame {
/** /**
* Version name, as it should be displayed. * Version name, as it should be displayed.
*/ */
public static final String VERSION_NAME = "2.0"; public static final String VERSION_NAME = "2.0.1";
/** /**
* The word "SyMAT". * The word "SyMAT".
@ -117,7 +112,7 @@ public class Main extends JRibbonFrame {
/** /**
* Version number, for updates and //needs in scripts * Version number, for updates and //needs in scripts
*/ */
public static final double APP_CODE = 21; public static final double APP_CODE = 22;
/** /**
* Base URL for building API calls * Base URL for building API calls
*/ */
@ -139,6 +134,7 @@ public class Main extends JRibbonFrame {
public static boolean updateAvailable = false; // Update available? public static boolean updateAvailable = false; // Update available?
public static String updateString = ""; public static String updateString = "";
public static boolean licValid = false; // License valid?
/** /**
* Application icon, for setting frame icons. Has different sizes. * Application icon, for setting frame icons. Has different sizes.
@ -205,47 +201,18 @@ public class Main extends JRibbonFrame {
} }
loaded = true; loaded = true;
} }
boolean licValid = false;
if (PrefStorage.getSetting("license").equals("")
|| PrefStorage.getSetting("licensetype").equals("demo")) {
if (PrefStorage.getSetting("licensetype").equals("demo")) {
Calendar c = Calendar.getInstance();
c.setTime(new Date());
try {
long expire = Long.parseLong(PrefStorage.getSetting("license"));
if (expire > c.getTimeInMillis()) {
licValid = true;
}
} catch (NumberFormatException e) {
}
}
} else {
try {
Debug.println("Checking license...");
URL url = new URL(API_URL + "liccheck.php?email="
+ PrefStorage.getSetting("license")
+ "&quick=1");
String line;
try (InputStream is = url.openStream();
BufferedReader br
= new BufferedReader(new InputStreamReader(is))) {
line = br.readLine();
}
if (line.equals("ok")) {
licValid = true;
}
} catch (Exception ex) {
// Assume valid
licValid = true;
}
}
if (!licValid) { if (!licValid) {
licenseRestrict(true); licenseRestrict(true);
SwingUtilities.invokeLater(new Runnable() {
public void run() {
loadFrame(new License()); loadFrame(new License());
}
});
loaded = true; loaded = true;
} }
// Only load shell if nothing else is going on // Only load shell if nothing else is going on
if (argfile.equals("") && !loaded) { if (argfile.equals("") && !loaded) {
loadFrame(new Interpreter()); loadFrame(new Interpreter());
} }

View File

@ -7,16 +7,10 @@
<Property name="cursor" type="java.awt.Cursor" editor="org.netbeans.modules.form.editors2.CursorEditor"> <Property name="cursor" type="java.awt.Cursor" editor="org.netbeans.modules.form.editors2.CursorEditor">
<Color id="Default Cursor"/> <Color id="Default Cursor"/>
</Property> </Property>
<Property name="maximumSize" type="java.awt.Dimension" editor="org.netbeans.beaninfo.editors.DimensionEditor">
<Dimension value="[500, 400]"/>
</Property>
<Property name="minimumSize" type="java.awt.Dimension" editor="org.netbeans.beaninfo.editors.DimensionEditor"> <Property name="minimumSize" type="java.awt.Dimension" editor="org.netbeans.beaninfo.editors.DimensionEditor">
<Dimension value="[500, 400]"/> <Dimension value="[500, 400]"/>
</Property> </Property>
<Property name="undecorated" type="boolean" value="true"/> <Property name="undecorated" type="boolean" value="true"/>
<Property name="preferredSize" type="java.awt.Dimension" editor="org.netbeans.beaninfo.editors.DimensionEditor">
<Dimension value="[500, 400]"/>
</Property>
<Property name="resizable" type="boolean" value="false"/> <Property name="resizable" type="boolean" value="false"/>
<Property name="type" type="java.awt.Window$Type" editor="org.netbeans.modules.form.editors.EnumEditor"> <Property name="type" type="java.awt.Window$Type" editor="org.netbeans.modules.form.editors.EnumEditor">
<Value id="POPUP"/> <Value id="POPUP"/>

View File

@ -54,6 +54,8 @@ import java.io.InputStreamReader;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.net.URL; import java.net.URL;
import java.net.URLClassLoader; import java.net.URLClassLoader;
import java.util.Calendar;
import java.util.Date;
import javax.swing.SwingUtilities; import javax.swing.SwingUtilities;
import static net.apocalypselabs.symat.Main.API_URL; import static net.apocalypselabs.symat.Main.API_URL;
import static net.apocalypselabs.symat.Main.APP_CODE; import static net.apocalypselabs.symat.Main.APP_CODE;
@ -202,13 +204,16 @@ public class SplashScreen extends javax.swing.JFrame {
Debug.stacktrace(ex); Debug.stacktrace(ex);
} }
setProgress("Checking license...");
checkLicense();
if (!PrefStorage.getSetting("skipupdates").equals("yes")) { if (!PrefStorage.getSetting("skipupdates").equals("yes")) {
setProgress("Checking for updates..."); setProgress("Checking for updates...");
checkUpdates(); checkUpdates();
} }
setProgress("Loading main interface..."); setProgress("Loading main interface...");
Main main = new Main(); new Main();
setProgress("Done!"); setProgress("Done!");
dispose(); dispose();
} }
@ -221,6 +226,43 @@ public class SplashScreen extends javax.swing.JFrame {
Debug.println("Loaded toolkit " + file.getName()); Debug.println("Loaded toolkit " + file.getName());
} }
private void checkLicense() {
if (PrefStorage.getSetting("license").equals("")
|| PrefStorage.getSetting("licensetype").equals("demo")) {
if (PrefStorage.getSetting("licensetype").equals("demo")) {
Calendar c = Calendar.getInstance();
c.setTime(new Date());
try {
long expire = Long.parseLong(PrefStorage.getSetting("license"));
if (expire > c.getTimeInMillis()) {
Main.licValid = true;
}
} catch (NumberFormatException e) {
}
}
} else {
try {
Debug.println("Checking license...");
URL url = new URL(API_URL + "liccheck.php?email="
+ PrefStorage.getSetting("license")
+ "&quick=1");
String line;
try (InputStream is = url.openStream();
BufferedReader br
= new BufferedReader(new InputStreamReader(is))) {
line = br.readLine();
}
if (line.equals("ok")) {
Main.licValid = true;
}
} catch (Exception ex) {
// Assume valid
Main.licValid = true;
}
}
}
private void checkUpdates() { private void checkUpdates() {
// Check for updates. // Check for updates.
try { try {

View File

@ -120,5 +120,14 @@
</Component> </Component>
</SubComponents> </SubComponents>
</Container> </Container>
<Container class="javax.swing.JPanel" name="browserBox">
<Constraints>
<Constraint layoutClass="org.netbeans.modules.form.compat2.layouts.DesignBorderLayout" value="org.netbeans.modules.form.compat2.layouts.DesignBorderLayout$BorderConstraintsDescription">
<BorderConstraints direction="Center"/>
</Constraint>
</Constraints>
<Layout class="org.netbeans.modules.form.compat2.layouts.DesignBorderLayout"/>
</Container>
</SubComponents> </SubComponents>
</Form> </Form>

View File

@ -110,7 +110,7 @@ public class WebBrowser extends javax.swing.JInternalFrame {
webEngine.loadContent(homepage()); webEngine.loadContent(homepage());
} }
}); });
getContentPane().add(jfxPanel, BorderLayout.CENTER); browserBox.add(jfxPanel, BorderLayout.CENTER);
} }
public WebBrowser(String title) { public WebBrowser(String title) {
@ -168,6 +168,12 @@ public class WebBrowser extends javax.swing.JInternalFrame {
loadURL(url); loadURL(url);
} }
public void showNavbar(boolean yesno) {
navBar.setVisible(yesno);
goBtn.setEnabled(yesno);
backBtn.setEnabled(yesno);
}
public void loadURL(final String url) { public void loadURL(final String url) {
Platform.runLater(new Runnable() { Platform.runLater(new Runnable() {
@Override @Override
@ -207,6 +213,7 @@ public class WebBrowser extends javax.swing.JInternalFrame {
backBtn = new javax.swing.JButton(); backBtn = new javax.swing.JButton();
urlBox = new javax.swing.JTextField(); urlBox = new javax.swing.JTextField();
goBtn = new javax.swing.JButton(); goBtn = new javax.swing.JButton();
browserBox = new javax.swing.JPanel();
setClosable(true); setClosable(true);
setIconifiable(true); setIconifiable(true);
@ -293,6 +300,9 @@ public class WebBrowser extends javax.swing.JInternalFrame {
getContentPane().add(navBar, java.awt.BorderLayout.PAGE_START); getContentPane().add(navBar, java.awt.BorderLayout.PAGE_START);
browserBox.setLayout(new java.awt.BorderLayout());
getContentPane().add(browserBox, java.awt.BorderLayout.CENTER);
pack(); pack();
}// </editor-fold>//GEN-END:initComponents }// </editor-fold>//GEN-END:initComponents
@ -344,15 +354,16 @@ public class WebBrowser extends javax.swing.JInternalFrame {
Platform.runLater(new Runnable() { Platform.runLater(new Runnable() {
@Override @Override
public void run() { public void run() {
jfxPanel.setSize(getWidth(), getHeight()); jfxPanel.setSize(browserBox.getWidth(), browserBox.getHeight());
browser.setPrefSize(getWidth() - 12, getHeight() - 32); browser.setPrefSize(browserBox.getWidth(), browserBox.getHeight());
browser.resize(getWidth() - 12, getHeight() - 32); browser.resize(browserBox.getWidth(), browserBox.getHeight());
} }
}); });
} }
// Variables declaration - do not modify//GEN-BEGIN:variables // Variables declaration - do not modify//GEN-BEGIN:variables
private javax.swing.JButton backBtn; private javax.swing.JButton backBtn;
private javax.swing.JPanel browserBox;
private javax.swing.JButton goBtn; private javax.swing.JButton goBtn;
private javax.swing.JToolBar navBar; private javax.swing.JToolBar navBar;
private javax.swing.JTextField urlBox; private javax.swing.JTextField urlBox;