aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristophe Grand <christophe@cgrand.net>2008-11-16 20:06:37 +0000
committerChristophe Grand <christophe@cgrand.net>2008-11-16 20:06:37 +0000
commit76bc4f1f19f85b246963b3da1eece3b5400820a4 (patch)
tree155263845551e497c3e12e371f77c796791db169
parent9784ebfab888a43f0d18663d39de744cf997f38a (diff)
adding the javadoc function to contrib
-rwxr-xr-xsrc/clojure/contrib/javadoc.clj49
1 files changed, 49 insertions, 0 deletions
diff --git a/src/clojure/contrib/javadoc.clj b/src/clojure/contrib/javadoc.clj
new file mode 100755
index 00000000..711a57b0
--- /dev/null
+++ b/src/clojure/contrib/javadoc.clj
@@ -0,0 +1,49 @@
+; Copyright (c) Christophe Grand, November 2008. All rights reserved.
+; The use and distribution terms for this software are covered by the
+; Common Public License 1.0 (http://opensource.org/licenses/cpl.php)
+; which can be found in the file CPL.TXT 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.
+
+; a repl helper to quickly open JDK javadocs.
+
+(ns clojure.contrib.javadoc)
+
+(defn- open-url-in-browser [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 (java.net.URI. url)))
+ url)
+ (catch ClassNotFoundException e
+ nil)))
+
+(defn- open-url-in-swing [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 javadoc
+ "Opens a browser window displaying the javadoc for the argument."
+ [class-or-object]
+ (let [c (if (instance? Class class-or-object)
+ class-or-object
+ (class class-or-object))
+ url (str "http://java.sun.com/javase/6/docs/api/"
+ (-> c .getName (.replace \. \/) (.replace \$ \.))
+ ".html")]
+ (or (open-url-in-browser url) (open-url-in-swing url))))
+