import jalview.javascript.json.JSON;
-import java.awt.Color;
+import java.awt.Component;
+import java.awt.Dimension;
import java.awt.Toolkit;
import java.awt.event.MouseEvent;
import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.Reader;
-import java.net.MalformedURLException;
import java.net.URL;
import java.util.Properties;
-import java.util.logging.ConsoleHandler;
-import java.util.logging.Level;
-import java.util.logging.Logger;
import javax.swing.SwingUtilities;
import org.json.simple.parser.JSONParser;
import org.json.simple.parser.ParseException;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Set;
+import java.util.logging.ConsoleHandler;
+import java.util.logging.Level;
+import java.util.logging.Logger;
import com.stevesoft.pat.Regex;
+import swingjs.api.JSUtilI;
+
/**
* System platform information used by Applet and Application
*
private static boolean isJS = /** @j2sNative true || */
false;
+ private static JSUtilI jsutil = /**
+ * @j2sNative new Clazz.new_("swingjs.JSUtil")
+ * ||
+ */
+ null;
+
+
private static Boolean isNoJSMac = null, isNoJSWin = null, isMac = null,
isWin = null;
- // private static Boolean isHeadless = null;
+ private static Boolean isHeadless = null;
/**
* added to group mouse events into Windows and nonWindows (mac, unix, linux)
return (isNoJSWin == null ? (isNoJSWin = !isJS && isWin()) : isNoJSWin);
}
- // /**
- // *
- // * @return true if we are running in non-interactive no UI mode
- // */
- // public static boolean isHeadless()
- // {
- // if (isHeadless == null)
- // {
- // isHeadless = "true".equals(System.getProperty("java.awt.headless"));
- // }
- // return isHeadless;
- // }
+ /**
+ *
+ * @return true if we are running in non-interactive no UI mode
+ */
+ public static boolean isHeadless()
+ {
+ if (isHeadless == null)
+ {
+ isHeadless = "true".equals(System.getProperty("java.awt.headless"));
+ }
+ return isHeadless;
+ }
/**
*
}
/**
- * escape a string according to the local platform's escape character
+ * Answers the input with every backslash replaced with a double backslash (an
+ * 'escaped' single backslash)
*
- * @param file
- * @return escaped file
+ * @param s
+ * @return
*/
- public static String escapeString(String file)
+ public static String escapeBackslashes(String s)
{
- StringBuffer f = new StringBuffer();
- int p = 0, lastp = 0;
- while ((p = file.indexOf('\\', lastp)) > -1)
- {
- f.append(file.subSequence(lastp, p));
- f.append("\\\\");
- lastp = p + 1;
- }
- f.append(file.substring(lastp));
- return f.toString();
+ return s == null ? null : s.replace("\\", "\\\\");
}
/**
*
* Platform.timeCheck("some message", Platform.TIME_MARK);
*
+ * reset...[set/mark]n...get
+ *
* @param msg
* @param mode
*/
{
case TIME_RESET:
time = mark = t;
+ duration = 0;
if (msg != null)
{
System.err.println("Platform: timer reset\t\t\t" + msg);
case TIME_MARK:
if (set > 0)
{
+ // total time between set/mark points
duration += (t - set);
}
else
case TIME_GET:
if (msg != null)
{
- System.err.println("Platform: timer dur\t" + ((t - time) / 1000f)
+ System.err.println("Platform: timer get\t" + ((t - time) / 1000f)
+ "\t" + ((duration) / 1000f) + "\t" + msg);
}
set = 0;
break;
}
}
-
+
+ ////// jsutil additions, simplifications
+
public static void cacheFileData(String path, Object data)
{
- if (!isJS() || data == null)
+ if (isJS())
{
- return;
+ jsutil.cachePathData(path, data);
}
- /**
- * @j2sNative
- *
- * swingjs.JSUtil.cacheFileData$S$O(path, data);
- *
- */
}
public static void cacheFileData(File file)
{
- byte[] data;
- if (!isJS() || (data = Platform.getFileBytes(file)) == null)
+ if (isJS())
{
- return;
+ byte[] bytes = getFileBytes(file);
+ if (bytes != null)
+ {
+ cacheFileData(file.toString(), bytes);
+ }
}
- cacheFileData(file.toString(), data);
}
public static byte[] getFileBytes(File f)
{
- // TODO temporary doubling of 秘bytes and _bytes;
- // just remove _bytes when new transpiler has been installed
- return /** @j2sNative f && (f.秘bytes || f._bytes) || */
- null;
+ return (isJS() && f != null ? jsutil.getBytes(f) : null);
}
public static byte[] getFileAsBytes(String fileStr)
{
- byte[] bytes = null;
- // BH 2018 hack for no support for access-origin
- /**
- * @j2sNative bytes = swingjs.JSUtil.getFileAsBytes$O(fileStr)
- */
- cacheFileData(fileStr, bytes);
+ byte[] bytes = (isJS() && fileStr != null
+ ? (byte[]) jsutil.getFile(fileStr, false)
+ : null);
+ if (bytes != null)
+ {
+ cacheFileData(fileStr, bytes);
+ }
return bytes;
}
- @SuppressWarnings("unused")
public static String getFileAsString(String url)
{
String ret = null;
- /**
- * @j2sNative
- *
- * ret = swingjs.JSUtil.getFileAsString$S(url);
- *
- *
- */
- cacheFileData(url, ret);
+ if (isJS())
+ {
+ ret = (String) jsutil.getFile(url, true);
+ if (ret != null)
+ {
+ cacheFileData(url, ret);
+ }
+ }
return ret;
}
{
return false;
}
- @SuppressWarnings("unused")
byte[] bytes = getFileAsBytes(urlstring);
- // TODO temporary doubling of 秘bytes and _bytes;
- // just remove _bytes when new transpiler has been installed
- /**
- * @j2sNative f.秘bytes = f._bytes = bytes;
- */
- return true;
+ boolean ok = false;
+ try
+ {
+ jsutil.setFileBytes(f, bytes);
+ } catch (Throwable t)
+ {
+ System.out.println("Platform.setFileBytes failed: " + t);
+ }
+ return ok;
}
public static void addJ2SBinaryType(String ext)
{
- /**
- * @j2sNative
- *
- * J2S._binaryTypes.push("." + ext + "?");
- *
- */
+ if (isJS())
+ {
+ jsutil.addBinaryFileType(ext);
+ }
}
/**
public static String getUniqueAppletID()
{
- @SuppressWarnings("unused")
- ThreadGroup g = Thread.currentThread().getThreadGroup();
- /**
- * @j2sNative return g.秘html5Applet._uniqueId;
- *
- */
- return null;
-
+ // Caution -- null here means using current thread instead of a known component.
+
+ return jsutil.getAppletForComponent(null)._getID();
}
/**
*/
public static void readInfoProperties(String prefix, Properties p)
{
- if (!isJS())
+ if (isJS())
{
- return;
+ jsutil.readInfoProperties(prefix, p);
}
- @SuppressWarnings("unused")
- ThreadGroup g = Thread.currentThread().getThreadGroup();
- String id = getUniqueAppletID();
- String key = "", value = "";
- /**
- * @j2sNative var info = g.秘html5Applet.__Info || {}; for (var key in info)
- * { if (key.indexOf(prefix) == 0) { value = "" + info[key];
- */
-
- System.out.println(
- "Platform id=" + id + " reading Info." + key + " = " + value);
- p.put(key, value);
-
- /**
- * @j2sNative
- *
- *
- * } }
- */
}
public static void setAjaxJSON(URL url)
public static void streamToFile(InputStream is, File outFile)
throws IOException
{
+ if (isJS() && jsutil.streamToFile(is, outFile))
+ {
+ return;
+ }
FileOutputStream fio = new FileOutputStream(outFile);
try
{
- if (isJS()
- && /**
- * @j2sNative outFile.setBytes$O && outFile.setBytes$O(is) &&
- */
- true)
- {
- return;
- }
byte[] bb = new byte[32 * 1024];
int l;
while ((l = is.read(bb)) > 0)
if (isJS())
{
- System.out.println(
- "Platform adding known access-control-allow-origin * for domain "
- + domain);
- /**
- * @j2sNative
- *
- * J2S.addDirectDatabaseCall(domain);
- */
+ jsutil.addDirectDatabaseCall(domain);
}
-
}
+ /**
+ * Retrieve the first query field as command arguments to Jalview. Include
+ * only if prior to "?j2s" or "&j2s" or "#". Assign the applet's __Info.args
+ * element to this value.
+ */
+
+ @SuppressWarnings("unused")
public static void getURLCommandArguments()
{
-
+ if (!isJS())
+ {
+ return;
+ }
+ String[] args = null;
/**
- * Retrieve the first query field as command arguments to Jalview. Include
- * only if prior to "?j2s" or "&j2s" or "#". Assign the applet's __Info.args
- * element to this value.
- *
- * @j2sNative var a =
+ * @j2sNative args =
* decodeURI((document.location.href.replace("&","?").split("?j2s")[0]
- * + "?").split("?")[1].split("#")[0]); a &&
- * (J2S.thisApplet.__Info.args = a.split(" "));
+ * + "?").split("?")[1].split("#")[0]); args && (args =
+ * args.split(" "));
*/
+ if (args != null)
+ {
+ jsutil.setAppletInfo("args", args);
+ }
}
- public static URL getDocumentBase()
+
+ /**
+ * A (case sensitive) file path comparator that ignores the difference between /
+ * and \
+ *
+ *
+ * @param path1
+ * @param path2
+ * @return
+ */
+ public static boolean pathEquals(String path1, String path2)
{
- try
+ if (path1 == null)
{
- if (isJS())
- {
- @SuppressWarnings("unused")
- Object g = Thread.currentThread().getThreadGroup();
- return new URL(/**
- * @j2sNative g.秘html5Applet._appletPanel.appletDocumentBase
- * ||
- */
- "");
- }
- } catch (MalformedURLException e)
+ return path2 == null;
+ }
+ if (path2 == null)
{
+ return false;
}
- return null;
+ String p1 = path1.replace('\\', '/');
+ String p2 = path2.replace('\\', '/');
+ return p1.equals(p2);
+ }
+
+ ///// new methods from applet branch only
+
+
+ public static URL getDocumentBase()
+ {
+ return (isJS() ? jsutil.getDocumentBase() : null);
}
public static URL getCodeBase()
{
- try
- {
- if (isJS())
- {
- @SuppressWarnings("unused")
- Object g = Thread.currentThread().getThreadGroup();
- return new URL(/**
- * @j2sNative g.秘html5Applet._appletPanel.appletCodeBase
- * ||
- */
- "");
- }
- } catch (MalformedURLException e)
- {
- }
- return null;
+ return (isJS() ? jsutil.getCodeBase() : null);
}
- /**
- * load a resource -- probably a core file -- if and only if a particular
- * class has not been instantialized. We use a String here because if we used
- * a .class object, that reference itself would simply load the class, and we
- * want the core package to include that as well.
- *
- * @param resourcePath
- * @param className
- */
- public static void loadStaticResource(Object resourcePath,
- String className)
+ public static void ensureJmol()
{
- /**
- *
- * @j2sNative if (!swingjs.JSUtil.isClassLoaded$S(className))
- * swingjs.JSUtil.loadStaticResource$S(resourcePath);
- */
+ if (isJS())
+ {
+ jsutil.loadResourceIfClassUnknown("core/core_jvjmol.z.js",
+ "org.jmol.viewer.Viewer");
+ }
}
public static void ensureRegex()
{
- loadStaticResource("core/core_stevesoft.z.js",
+ if (isJS())
+ {
+ jsutil.loadResourceIfClassUnknown("core/core_stevesoft.z.js",
"com.stevesoft.pat.Regex");
+ }
}
public static Regex newRegex(String searchString, String replaceString)
}
/**
- * @param c
- */
- public static Color getColorFromName(String name)
- {
- if (name == null)
- {
- return null;
- }
- /**
- * @j2sNative
- *
- * return swingjs.JSUtil.getColorFromName$S(name);
- */
- {
- // or make a static map; or use reflection on the field name
- switch (name.toLowerCase())
- {
- case "black":
- return Color.black;
- case "blue":
- return Color.blue;
- case "cyan":
- return Color.cyan;
- case "darkgray":
- return Color.darkGray;
- case "gray":
- return Color.gray;
- case "green":
- return Color.green;
- case "lightgray":
- return Color.lightGray;
- case "magenta":
- return Color.magenta;
- case "orange":
- return Color.orange;
- case "pink":
- return Color.pink;
- case "red":
- return Color.red;
- case "white":
- return Color.white;
- case "yellow":
- return Color.yellow;
- default:
- return null;
- }
-
- }
- }
-
- /**
* Initialize Java debug logging. A representative sample -- adapt as desired.
*/
public static void startJavaLogging()
* that page developers use that is similar to the original Java applet object
* that was accessed via LiveConnect.
*
- * @param j
+ * @param app
*/
- public static void setAppClass(Object j)
+ public static void setAppClass(Object app)
{
- if (!isJS())
+ if (isJS())
{
- return;
+ jsutil.setAppletAttribute("app", app);
}
- @SuppressWarnings("unused")
- Thread t = Thread.currentThread();
- /**
- * Set up "testApplet.app" to be this instance
- *
- * @j2sNative
- *
- * try {self[t.name].app = j}catch(e){}
- */
}
- public final static String EMBEDDED_DIM = "dim";
+ /**
+ * Retrieve the object's embedded size from a div's style on a page if
+ * embedded in SwingJS.
+ *
+ * @param frame
+ * JFrame or JInternalFrame
+ * @param defaultWidth
+ * use -1 to return null (no default size)
+ * @param defaultHeight
+ * @return the embedded dimensions or null (no default size or not embedded)
+ */
+ public static Dimension getDimIfEmbedded(Component frame,
+ int defaultWidth, int defaultHeight)
+ {
+ Dimension d = (Dimension) getEmbeddedAttribute(frame, "dim");
+ return (d == null && defaultWidth >= 0
+ ? new Dimension(defaultWidth, defaultHeight)
+ : d);
+ }
/**
*
* @param type
* @return null if frame is not embedded.
*/
- public static Object getEmbeddedAttribute(Object frame, String type)
+ public static Object getEmbeddedAttribute(Component frame, String type)
+ {
+ return (isJS() ? jsutil.getEmbeddedAttribute(frame, type) : null);
+ }
+
+ /**
+ * Only called for JavaScript.
+ *
+ * @return Map for static singleton classes unique to a given applet
+ */
+ public static HashMap<?, ?> getJSSingletons()
+ {
+ return (isJS() ? jsutil.getJSContext("jssingletons") : null);
+ }
+
+ /**
+ * By designating initialCapacity and loadFactor, we tell SwingJS to use a
+ * standard (slower) Java HashMap to back this HashSet, thus providing exactly
+ * the same iterator order (until a new Java version changes it!)
+ *
+ * @return a standard Java HashSet
+ */
+ public static Set<String> getJavaOrderedHashSet()
+ {
+ return new HashSet<>(16, 0.75f);
+ }
+
+ /**
+ * Switch the flag in SwingJS to use or not use the JavaScript Map object in
+ * any Hashtable, HashMap, or HashSet. Default is enabled.
+ *
+ * For testing purposes only.
+ *
+ */
+ public static boolean setJavaScriptMapObjectEnabled(boolean enabled)
{
if (!isJS())
{
- return null;
+ return false;
}
- return (/** swingjs@j2sNative || frame.ui.getEmbedded(type) */
- null);
+ jsutil.setJavaScriptMapObjectEnabled(enabled);
+ HashSet<String> hs = new HashSet<>();
+ // Java hash table iterator in HashMap will return "one" before "two"
+ // because of its hash code;
+ // JavaScript Map object will return "two" first because it was added first.
+ hs.add("two");
+ hs.add("one");
+ return (hs.iterator().next() == (enabled ? "two" : "one"));
}
+
public static void stackTrace()
{
- try
- {
- throw new NullPointerException();
- } catch (Exception e)
+ new NullPointerException("testing only").printStackTrace();
+ }
+
+
+ /**
+ * escape a string according to the local platform's escape character
+ *
+ * @param file
+ * @return escaped file
+ */
+ public static String escapeString(String file)
+ {
+ StringBuffer f = new StringBuffer();
+ int p = 0, lastp = 0;
+ while ((p = file.indexOf('\\', lastp)) > -1)
{
- e.printStackTrace();
+ f.append(file.subSequence(lastp, p));
+ f.append("\\\\");
+ lastp = p + 1;
}
-
+ f.append(file.substring(lastp));
+ return f.toString();
}
}