aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristophe Grand <christophe@cgrand.net>2009-03-04 15:02:25 +0000
committerChristophe Grand <christophe@cgrand.net>2009-03-04 15:02:25 +0000
commit7d33e4a43b3cf9c741ad4b4a8ab4d4018fd70f64 (patch)
tree15461124ec23aedf374e6f78dad9980251864980
parent705dfa54b8ff577223d9a60364dec8f713230a13 (diff)
fix issue 32 http://code.google.com/p/clojure-contrib/issues/detail?id=32
-rw-r--r--src/clojure/contrib/javadoc/browse.clj102
-rw-r--r--src/clojure/contrib/javadoc/browse_ui.clj30
2 files changed, 77 insertions, 55 deletions
diff --git a/src/clojure/contrib/javadoc/browse.clj b/src/clojure/contrib/javadoc/browse.clj
index 690a6bf8..6bf2bb58 100644
--- a/src/clojure/contrib/javadoc/browse.clj
+++ b/src/clojure/contrib/javadoc/browse.clj
@@ -1,55 +1,47 @@
-;;; browse.clj -- start a web browser from Clojure
-
-; Copyright (c) Christophe Grand, December 2008. All rights reserved.
-; The use and distribution terms for this software are covered by the
-; Eclipse Public License 1.0 (http://opensource.org/licenses/eclipse-1.0.php)
-; which can be found in the file epl-v10.html at the root of this
-; distribution.
-; By using this software in any fashion, you are agreeing to be bound by
-; the terms of this license.
-; You must not remove this notice, or any other, from this software.
-
-(ns clojure.contrib.javadoc.browse
- (:require [clojure.contrib.shell-out :as sh])
- (:import (java.net URI)))
-
-(defn- macosx? []
- (-> "os.name" System/getProperty .toLowerCase
- (.startsWith "mac os x")))
-
-(def *open-url-script* (when (macosx?) "/usr/bin/open"))
-
-(defn open-url-in-browser
- "Opens url (a string) in the default system web browser. May not
- work on all platforms. Returns url on success, nil if not
- supported."
- [url]
- (try
- (when (clojure.lang.Reflector/invokeStaticMethod "java.awt.Desktop"
- "isDesktopSupported" (to-array nil))
- (-> (clojure.lang.Reflector/invokeStaticMethod "java.awt.Desktop"
- "getDesktop" (to-array nil))
- (.browse (URI. url)))
- url)
- (catch ClassNotFoundException e
- nil)))
-
-(defn open-url-in-swing
- "Opens url (a string) in a Swing window."
- [url]
- (let [htmlpane (javax.swing.JEditorPane. url)]
- (.setEditable htmlpane false)
- (.addHyperlinkListener htmlpane
- (proxy [javax.swing.event.HyperlinkListener] []
- (hyperlinkUpdate [#^javax.swing.event.HyperlinkEvent e]
- (when (= (.getEventType e) (. javax.swing.event.HyperlinkEvent$EventType ACTIVATED))
- (if (instance? javax.swing.text.html.HTMLFrameHyperlinkEvent e)
- (-> htmlpane .getDocument (.processHTMLFrameHyperlinkEvent e))
- (.setPage htmlpane (.getURL e)))))))
- (doto (javax.swing.JFrame.)
- (.setContentPane (javax.swing.JScrollPane. htmlpane))
- (.setBounds 32 32 700 900)
- (.show))))
-
-(defn browse-url [url]
- (or (open-url-in-browser url) (when *open-url-script* (sh/sh *open-url-script* (str url)) true) (open-url-in-swing url)))
+;;; browse.clj -- start a web browser from Clojure
+
+; Copyright (c) Christophe Grand, December 2008. All rights reserved.
+; The use and distribution terms for this software are covered by the
+; Eclipse Public License 1.0 (http://opensource.org/licenses/eclipse-1.0.php)
+; which can be found in the file epl-v10.html at the root of this
+; distribution.
+; By using this software in any fashion, you are agreeing to be bound by
+; the terms of this license.
+; You must not remove this notice, or any other, from this software.
+
+(ns clojure.contrib.javadoc.browse
+ (:require [clojure.contrib.shell-out :as sh])
+ (:import (java.net URI)))
+
+(defn- macosx? []
+ (-> "os.name" System/getProperty .toLowerCase
+ (.startsWith "mac os x")))
+
+(def *open-url-script* (when (macosx?) "/usr/bin/open"))
+
+(defn open-url-in-browser
+ "Opens url (a string) in the default system web browser. May not
+ work on all platforms. Returns url on success, nil if not
+ supported."
+ [url]
+ (try
+ (when (clojure.lang.Reflector/invokeStaticMethod "java.awt.Desktop"
+ "isDesktopSupported" (to-array nil))
+ (-> (clojure.lang.Reflector/invokeStaticMethod "java.awt.Desktop"
+ "getDesktop" (to-array nil))
+ (.browse (URI. url)))
+ url)
+ (catch ClassNotFoundException e
+ nil)))
+
+(defn open-url-in-swing
+ "Opens url (a string) in a Swing window."
+ [url]
+ ; the implementation of this function resides in another namespace to be loaded "on demand"
+ ; this fixes a bug on mac os x where requiring repl-utils turns the process into a GUI app
+ ; see http://code.google.com/p/clojure-contrib/issues/detail?id=32
+ (require 'clojure.contrib.javadoc.browse-ui)
+ ((find-var 'clojure.contrib.javadoc.browse-ui/open-url-in-swing) url))
+
+(defn browse-url [url]
+ (or (open-url-in-browser url) (when *open-url-script* (sh/sh *open-url-script* (str url)) true) (open-url-in-swing url)))
diff --git a/src/clojure/contrib/javadoc/browse_ui.clj b/src/clojure/contrib/javadoc/browse_ui.clj
new file mode 100644
index 00000000..c76d39dd
--- /dev/null
+++ b/src/clojure/contrib/javadoc/browse_ui.clj
@@ -0,0 +1,30 @@
+;;; browse_ui.clj -- starts a swing web browser :-(
+
+; Copyright (c) Christophe Grand, December 2008. All rights reserved.
+; The use and distribution terms for this software are covered by the
+; Eclipse Public License 1.0 (http://opensource.org/licenses/eclipse-1.0.php)
+; which can be found in the file epl-v10.html at the root of this
+; distribution.
+; By using this software in any fashion, you are agreeing to be bound by
+; the terms of this license.
+; You must not remove this notice, or any other, from this software.
+
+(ns clojure.contrib.javadoc.browse-ui)
+
+(defn open-url-in-swing
+ "Opens url (a string) in a Swing window."
+ [url]
+ (let [htmlpane (javax.swing.JEditorPane. url)]
+ (.setEditable htmlpane false)
+ (.addHyperlinkListener htmlpane
+ (proxy [javax.swing.event.HyperlinkListener] []
+ (hyperlinkUpdate [#^javax.swing.event.HyperlinkEvent e]
+ (when (= (.getEventType e) (. javax.swing.event.HyperlinkEvent$EventType ACTIVATED))
+ (if (instance? javax.swing.text.html.HTMLFrameHyperlinkEvent e)
+ (-> htmlpane .getDocument (.processHTMLFrameHyperlinkEvent e))
+ (.setPage htmlpane (.getURL e)))))))
+ (doto (javax.swing.JFrame.)
+ (.setContentPane (javax.swing.JScrollPane. htmlpane))
+ (.setBounds 32 32 700 900)
+ (.show))))
+ \ No newline at end of file