diff options
author | Christophe Grand <christophe@cgrand.net> | 2008-12-07 22:22:12 +0000 |
---|---|---|
committer | Christophe Grand <christophe@cgrand.net> | 2008-12-07 22:22:12 +0000 |
commit | ed22cdd735b9d8624681038fc1c5d6e40741fe68 (patch) | |
tree | 4cd0006d5705a0b093fa97732d075c5eb611d027 | |
parent | 1b85ca70ebcd98bdf21b57340f338ea9c1031a52 (diff) |
applied Stuart Sierra's patch to add support for other local or remote javadocs
-rwxr-xr-x | src/clojure/contrib/javadoc.clj | 103 | ||||
-rw-r--r-- | src/clojure/contrib/javadoc/browse.clj | 48 |
2 files changed, 114 insertions, 37 deletions
diff --git a/src/clojure/contrib/javadoc.clj b/src/clojure/contrib/javadoc.clj index 30c89ab4..d4f65ea3 100755 --- a/src/clojure/contrib/javadoc.clj +++ b/src/clojure/contrib/javadoc.clj @@ -1,4 +1,5 @@ ; 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. @@ -6,44 +7,72 @@ ; 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)))) +; thanks to Stuart Sierra + +; a repl helper to quickly open javadocs. + +(ns clojure.contrib.javadoc + (:use clojure.contrib.javadoc.browse) + (:import (java.io File))) + +(def + #^{:doc "Ref to a list of local paths for Javadoc-generated HTML + files."} + *local-javadocs* (ref (list))) + +(def *core-java-api* + "http://java.sun.com/javase/6/docs/api/") + +(def + #^{:doc "Ref to a map from package name prefixes to URLs for remote + Javadocs."} + *remote-javadocs* + (ref (sorted-map + "java." *core-java-api* + "javax." *core-java-api* + "org.ietf.jgss." *core-java-api* + "org.omg." *core-java-api* + "org.w3c.dom." *core-java-api* + "org.xml.sax." *core-java-api* + "org.apache.commons.codec." "http://commons.apache.org/codec/api-release/" + "org.apache.commons.io." "http://commons.apache.org/io/api-release/" + "org.apache.commons.lang." "http://commons.apache.org/lang/api-release/"))) + +(defn add-local-javadoc + "Adds to the list of local Javadoc paths." + [path] + (dosync (commute *local-javadocs* conj path))) + +(defn add-remote-javadoc + "Adds to the list of remote Javadoc URLs. package-prefix is the + beginning of the package name that has docs at this URL." + [package-prefix url] + (dosync (commute *remote-javadocs* assoc package-prefix url))) + +(defn find-javadoc-url + "Searches for a URL for the given class name. Tries + *local-javadocs* first, then *remote-javadocs*. Returns a string." + [classname] + (let [file-path (.replace classname \. File/separatorChar) + url-path (.replace classname \. \/)] + (if-let [file (first + (filter #(.exists %) + (map #(File. % (str file-path ".html")) + @*local-javadocs*)))] + (str "file://" (.getAbsolutePath file)) + ;; If no local file, try remote URLs: + (some (fn [[prefix url]] + (when (.startsWith classname prefix) + (str url url-path ".html"))) + @*remote-javadocs*)))) (defn javadoc - "Opens a browser window displaying the javadoc for the argument." - [class-or-object] + "Opens a browser window displaying the javadoc for the argument. + Tries *local-javadocs* first, then *remote-javadocs*." + [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)))) - + (class class-or-object))] + (if-let [url (find-javadoc-url (.getName c))] + (browse-url url) + (println "Could not find Javadoc for" c)))) diff --git a/src/clojure/contrib/javadoc/browse.clj b/src/clojure/contrib/javadoc/browse.clj new file mode 100644 index 00000000..af752e1c --- /dev/null +++ b/src/clojure/contrib/javadoc/browse.clj @@ -0,0 +1,48 @@ +;;; 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
+; 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.
+
+
+(ns clojure.contrib.javadoc.browse
+ (:import (java.net URI)))
+
+(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) (open-url-in-swing url)))
|