X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Futil%2FPlatform.java;h=e8558fa14739a0fced7f5360c43712746dfdfce4;hb=9d2ac8fe3057585a37586379a3c1cd2ead49aafe;hp=21decf30dd78512bbe37a5bcdca72d53f934e0e4;hpb=47168f025aefdaa044802bd5f8f510ffe43a4808;p=jalview.git diff --git a/src/jalview/util/Platform.java b/src/jalview/util/Platform.java index 21decf3..e8558fa 100644 --- a/src/jalview/util/Platform.java +++ b/src/jalview/util/Platform.java @@ -1,6 +1,6 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8.2) - * Copyright (C) 2014 The Jalview Authors + * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) + * Copyright (C) $$Year-Rel$$ The Jalview Authors * * This file is part of Jalview. * @@ -20,6 +20,8 @@ */ package jalview.util; +import java.awt.event.MouseEvent; + /** * System platform information used by Applet and Application * @@ -27,22 +29,51 @@ package jalview.util; */ public class Platform { + private static Boolean isAMac = null, isWindows = null; + + private static Boolean isHeadless = null; + /** * sorry folks - Macs really are different * * @return true if we do things in a special way. */ - public boolean isAMac() + public static boolean isAMac() { - return java.lang.System.getProperty("os.name").indexOf("Mac") > -1; + if (isAMac == null) + { + isAMac = System.getProperty("os.name").indexOf("Mac") > -1; + } + + return isAMac.booleanValue(); } - public boolean isHeadless() + /** + * Check if we are on a Microsoft plaform... + * + * @return true if we have to cope with another platform variation + */ + public static boolean isWindows() { - String hdls = java.lang.System.getProperty("java.awt.headless"); + if (isWindows == null) + { + isWindows = System.getProperty("os.name").indexOf("Win") > -1; + } + return isWindows.booleanValue(); + } - return hdls != null && hdls.equals("true"); + /** + * + * @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; } /** @@ -56,22 +87,77 @@ public class Platform } /** - * 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 s + * @return + */ + public static String escapeBackslashes(String s) + { + return s == null ? null : s.replace("\\", "\\\\"); + } + + /** + * Answers true if the mouse event has Meta-down (Command key on Mac) or + * Ctrl-down (on other o/s). Note this answers _false_ if the Ctrl key is + * pressed instead of the Meta/Cmd key on Mac. To test for Ctrl-click on Mac, + * you can use e.isPopupTrigger(). + * + * @param e + * @return + */ + public static boolean isControlDown(MouseEvent e) + { + boolean aMac = isAMac(); + return isControlDown(e, aMac); + } + + /** + * Overloaded version of method (to allow unit testing) * - * @param file - * @return escaped file + * @param e + * @param aMac + * @return */ - public static String escapeString(String file) + protected static boolean isControlDown(MouseEvent e, boolean aMac) { - StringBuffer f = new StringBuffer(); - int p = 0, lastp = 0; - while ((p = file.indexOf('\\', lastp)) > -1) + if (aMac) + { + /* + * answer false for right mouse button + */ + if (e.isPopupTrigger()) + { + return false; + } + return (jalview.util.ShortcutKeyMaskExWrapper.getMenuShortcutKeyMaskEx() // .getMenuShortcutKeyMaskEx() + & jalview.util.ShortcutKeyMaskExWrapper + .getModifiersEx(e)) != 0; // getModifiers()) != 0; + } + return e.isControlDown(); + } + + /** + * 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) + { + if (path1 == null) + { + return path2 == null; + } + if (path2 == null) { - f.append(file.subSequence(lastp, p)); - f.append("\\\\"); - lastp = p + 1; + return false; } - f.append(file.substring(lastp)); - return f.toString(); + String p1 = path1.replace('\\', '/'); + String p2 = path2.replace('\\', '/'); + return p1.equals(p2); } }