X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Futil%2FPlatform.java;h=a5bee7c79f6b06e602e62a51e39b634db1651367;hb=8bcec0698d13dede379ac8079d544d2da50e106c;hp=ad9a9b75de1f22614a8681eba66a0c91a78e0cae;hpb=8582787ca677bf6978b23a8d6c9741f3b7842179;p=jalview.git diff --git a/src/jalview/util/Platform.java b/src/jalview/util/Platform.java index ad9a9b7..a5bee7c 100644 --- a/src/jalview/util/Platform.java +++ b/src/jalview/util/Platform.java @@ -1,73 +1,176 @@ -/* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.7) - * Copyright (C) 2011 J Procter, AM Waterhouse, G Barton, M Clamp, S Searle - * - * This file is part of Jalview. - * - * Jalview is free software: you can redistribute it and/or - * modify it under the terms of the GNU General Public License - * as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. - * - * Jalview is distributed in the hope that it will be useful, but - * WITHOUT ANY WARRANTY; without even the implied warranty - * of MERCHANTABILITY or FITNESS FOR A PARTICULAR - * PURPOSE. See the GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License along with Jalview. If not, see . - */ -package jalview.util; - -/** - * System platform information used by Applet and Application - * - * @author Jim Procter - */ -public class Platform -{ - /** - * sorry folks - Macs really are different - * - * @return true if we do things in a special way. - */ - public boolean isAMac() - { - return java.lang.System.getProperty("os.name").indexOf("Mac") > -1; - - } - - public boolean isHeadless() - { - String hdls = java.lang.System.getProperty("java.awt.headless"); - - return hdls != null && hdls.equals("true"); - } - - /** - * - * @return nominal maximum command line length for this platform - */ - public static int getMaxCommandLineLength() - { - // TODO: determine nominal limits for most platforms. - return 2046; // this is the max length for a windows NT system. - } - - /** - * 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) - { - f.append(file.subSequence(lastp,p)); - f.append("\\\\"); - lastp=p+1; - } - f.append(file.substring(lastp)); - return f.toString(); - } -} +/* + * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) + * Copyright (C) $$Year-Rel$$ The Jalview Authors + * + * This file is part of Jalview. + * + * Jalview is free software: you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation, either version 3 + * of the License, or (at your option) any later version. + * + * Jalview is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty + * of MERCHANTABILITY or FITNESS FOR A PARTICULAR + * PURPOSE. See the GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with Jalview. If not, see . + * The Jalview Authors are detailed in the 'AUTHORS' file. + */ +package jalview.util; + +import java.awt.event.MouseEvent; + +/** + * System platform information used by Applet and Application + * + * @author Jim Procter + */ +public class Platform +{ + private static Boolean isAMac = null, isWindows = null, isLinux = null; + + private static Boolean isHeadless = null; + + /** + * added to check LaF for Linux + * + * @return + */ + public static boolean isLinux() + { + return (isLinux == null + ? (isLinux = (System.getProperty("os.name").indexOf("Linux") >= 0)) + : isLinux); + } + + /** + * sorry folks - Macs really are different + * + * @return true if we do things in a special way. + */ + public static boolean isAMac() + { + if (isAMac == null) + { + isAMac = System.getProperty("os.name").indexOf("Mac") > -1; + } + + return isAMac.booleanValue(); + + } + + /** + * Check if we are on a Microsoft plaform... + * + * @return true if we have to cope with another platform variation + */ + public static boolean isWindows() + { + if (isWindows == null) + { + isWindows = System.getProperty("os.name").indexOf("Win") > -1; + } + return isWindows.booleanValue(); + } + + /** + * + * @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 nominal maximum command line length for this platform + */ + public static int getMaxCommandLineLength() + { + // TODO: determine nominal limits for most platforms. + return 2046; // this is the max length for a windows NT system. + } + + /** + * 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 e + * @param aMac + * @return + */ + protected static boolean isControlDown(MouseEvent e, boolean aMac) + { + 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) + { + return false; + } + String p1 = path1.replace('\\', '/'); + String p2 = path2.replace('\\', '/'); + return p1.equals(p2); + } +}