aboutsummaryrefslogtreecommitdiffstats
path: root/util/generate-hooks-index/src
diff options
context:
space:
mode:
authorredmatrix <redmatrix@redmatrix.me>2015-11-04 19:14:32 +1100
committerredmatrix <redmatrix@redmatrix.me>2015-11-04 19:14:32 +1100
commit59e0a0fd7c32376520da36d2833e0ff116a47682 (patch)
tree6d8f3048baa697bc56761c17f42a07f26df76573 /util/generate-hooks-index/src
parentd15be53034c1c2e1d86a4e60400ca707c5b1c403 (diff)
parent4bd0e083d16d622c9ed36c810a7fd729830dcdd6 (diff)
downloadvolse-hubzilla-59e0a0fd7c32376520da36d2833e0ff116a47682.tar.gz
volse-hubzilla-59e0a0fd7c32376520da36d2833e0ff116a47682.tar.bz2
volse-hubzilla-59e0a0fd7c32376520da36d2833e0ff116a47682.zip
Merge pull request #122 from kenrestivo/add-hook-docs
Commit the tool used to generate the hooks docs.
Diffstat (limited to 'util/generate-hooks-index/src')
-rw-r--r--util/generate-hooks-index/src/generate_hooks_index/core.clj82
1 files changed, 82 insertions, 0 deletions
diff --git a/util/generate-hooks-index/src/generate_hooks_index/core.clj b/util/generate-hooks-index/src/generate_hooks_index/core.clj
new file mode 100644
index 000000000..2112647b0
--- /dev/null
+++ b/util/generate-hooks-index/src/generate_hooks_index/core.clj
@@ -0,0 +1,82 @@
+(ns generate-hooks-index.core
+ (:require [clojure.string :as str]
+ [hiccup.core :as h]
+ [taoensso.timbre :as log]
+ [clojure.java.shell :as sh])
+ (:gen-class))
+
+(log/set-level! :info)
+
+(defn clean-fn-arg
+ [s]
+ (-> s
+ (str/replace #"'" "")
+ (str/replace #"\"" "")
+ str/trim))
+
+(defn check-fn-args
+ [xs]
+ (when (-> xs first empty?)
+ (throw (Exception. "empty function")))
+ (map clean-fn-arg xs))
+
+
+(defn get-fn-arg
+ [s]
+ (->> s
+ (re-matches #".*call_hooks\((.+)\,(.*)\).*")
+ rest
+ check-fn-args))
+
+
+
+(defn fix-path
+ [path file]
+ (str/replace file path ""))
+
+
+(defn show-hooks
+ [path]
+ (for [s (-> (sh/sh "rgrep" "call_hooks" path)
+ :out
+ str/split-lines)
+ :let [[file hook] (str/split s #"\t*:")]]
+ (try
+ (-> (zipmap [:function :arg] (get-fn-arg hook))
+ (assoc :file (fix-path path file)))
+ (catch Exception e
+ (log/debug e s file hook)))))
+
+
+
+(defn hiccupy
+ [path]
+ [:div
+ [:h3 "Hooks"]
+ [:table
+ [:tr (map #(vector :td %) ["Function" "Source File" "Arg"])]
+ (for [{:keys [function arg file]}
+ (->> path
+ show-hooks
+ (sort-by :function))]
+ [:tr (map #(vector :td (h/h %)) [function file arg])])]
+ [:p "Generated " (-> (java.util.Date.) str)]])
+
+
+(defn make-hook-docs
+ [path-to-hubzillla]
+ (->> path-to-hubzillla
+ hiccupy
+ h/html
+ (spit (str path-to-hubzillla "doc/hooks.html"))))
+
+
+(defn -main
+ [& args]
+ (log/info "Starting..")
+ (make-hook-docs (str (System/getProperty "user.dir") "/../../"))
+ (log/info "Done!")
+ (System/exit 0))
+
+
+