Package edu.wisc.ssec.mcidasv.util
Class WebBrowser
java.lang.Object
edu.wisc.ssec.mcidasv.util.WebBrowser
A simple utility class for opening a web browser to a given link.
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate static final String
IOException
formatting string used when all browsing methods have failed.private static final org.slf4j.Logger
Logging object.private static final String
IOException
formatting string used byopenOldStyle(String)
when no browsers could be identified on the system.private static final String
Message displayed to the user when all browsing methods have failed.Probe Unix-like systems for these browsers, in this order. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionstatic void
Attempts to use the system default browser to visiturl
.private static boolean
isMac()
Test for whether or not the current platform is Mac OS X.private static boolean
isUnix()
Test for whether or not the current platform is some form of "unix" (but not OS X!).private static boolean
Test for whether or not the current platform is Windows.static void
private static boolean
openNewStyle
(String url) Use the functionality withinDesktop
to try opening the user's preferred web browser.private static void
openOldStyle
(String url) UsesRuntime.exec(String)
to launch the user's preferred web browser.private static boolean
Attempts to launch the browser pointed at by the "idv.browser.path" IDV property, if it has been set.static boolean
useBrowserForUrl
(String url) Test whether or not a given URL should be opened in a web browser.
-
Field Details
-
logger
Logging object. -
unixBrowsers
Probe Unix-like systems for these browsers, in this order. -
ALL_METHODS_ERRMSG
IOException
formatting string used when all browsing methods have failed.- See Also:
-
NO_BROWSER_ERRMSG
IOException
formatting string used byopenOldStyle(String)
when no browsers could be identified on the system.- See Also:
-
THINGS_DUN_BROKE_ERRMSG
Message displayed to the user when all browsing methods have failed.- See Also:
-
-
Constructor Details
-
WebBrowser
private WebBrowser()Do not create instances ofWebBrowser
.
-
-
Method Details
-
browse
Attempts to use the system default browser to visiturl
. Tries looking for and executing any browser specified by the IDV property "idv.browser.path".If the property wasn't given or there was an error, try the new (as of Java 1.6) way of opening a browser.
If the previous attempts failed (or we're in 1.5), we finally try some more primitive measures.
Note: if you are trying to use this method with a
JTextPane
you may need to turn off editing viaJTextComponent.setEditable(boolean)
.- Parameters:
url
- URL to visit.- See Also:
-
useBrowserForUrl
Test whether or not a given URL should be opened in a web browser.- Parameters:
url
- URL to test. Cannot benull
.- Returns:
true
ifurl
begins with either "http:" or "https:".
-
openNewStyle
Use the functionality withinDesktop
to try opening the user's preferred web browser.- Parameters:
url
- URL to visit.- Returns:
- Either
true
if things look ok,false
if there were problems.
-
openOldStyle
UsesRuntime.exec(String)
to launch the user's preferred web browser. This method isn't really recommended unless you're stuck with Java 1.5.Note that the browsers need to be somewhere in the PATH, as this method uses the
which
command (also needs to be in the PATH!).- Parameters:
url
- URL to visit.
-
tryUserSpecifiedBrowser
Attempts to launch the browser pointed at by the "idv.browser.path" IDV property, if it has been set.- Parameters:
url
- URL to open.- Returns:
- Either
true
if the command-line was executed,false
if either the command-line wasn't launched or "idv.browser.path" was not set.
-
isMac
Test for whether or not the current platform is Mac OS X.- Returns:
- Are we shiny, happy OS X users?
-
isUnix
Test for whether or not the current platform is some form of "unix" (but not OS X!).- Returns:
- Do we perhaps think that beards and suspenders are the height of fashion?
-
isWindows
Test for whether or not the current platform is Windows.- Returns:
- Are we running Windows??
-
main
-