diff --git a/CHANGELOG.md b/CHANGELOG.md index 16f0d0a912..aa2f452a84 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,8 @@ - Don't instrument in .class compilation path - Lein init form instrumentation ignore + - Move maybe-init-flow-storm out of clojure.main/repl to support nrepl >= 1.3.0 + - Move maybe-execute-storm-specials into Compiler.eval to support nrepl >= 1.3.0 ### Bugs fixed diff --git a/src/clj/clojure/main.clj b/src/clj/clojure/main.clj index 65b5c0f324..af22500acb 100644 --- a/src/clj/clojure/main.clj +++ b/src/clj/clojure/main.clj @@ -22,6 +22,8 @@ ;;(:use [clojure.repl :only (demunge root-cause stack-element-str)]) ) +(storm-repl/maybe-init-flow-storm) + (declare main) ;;;;;;;;;;;;;;;;;;; redundantly copied from clojure.repl to avoid dep ;;;;;;;;;;;;;; @@ -412,11 +414,6 @@ by default when a new command-line REPL is started."} repl-requires [& options] (let [cl (.getContextClassLoader (Thread/currentThread))] (.setContextClassLoader (Thread/currentThread) (clojure.lang.DynamicClassLoader. cl))) - - ;; the if needed part is because nrepl will call this - ;; repl fn on each evaluation. Maybe we should find a better place - ;; to initialize flow-storm recordings - (storm-repl/init-flow-storm-if-needed) (let [{:keys [init need-prompt prompt flush read eval print caught] :or {init #() @@ -440,16 +437,15 @@ by default when a new command-line REPL is started."} repl-requires (with-read-known (read request-prompt request-exit)) (catch LispReader$ReaderException e (throw (ex-info nil {:clojure.error/phase :read-source} e))))] - (or (storm-repl/maybe-execute-storm-specials input) - (#{request-prompt request-exit} input) - (let [value (binding [*read-eval* read-eval] (eval input))] - (set! *3 *2) - (set! *2 *1) - (set! *1 value) - (try - (print value) - (catch Throwable e - (throw (ex-info nil {:clojure.error/phase :print-eval-result} e))))))) + (or (#{request-prompt request-exit} input) + (let [value (binding [*read-eval* read-eval] (eval input))] + (set! *3 *2) + (set! *2 *1) + (set! *1 value) + (try + (print value) + (catch Throwable e + (throw (ex-info nil {:clojure.error/phase :print-eval-result} e))))))) (catch Throwable e (caught e) (set! *e e))))] diff --git a/src/clj/clojure/storm/repl.clj b/src/clj/clojure/storm/repl.clj index ef8edf6f97..9a3b950b4b 100644 --- a/src/clj/clojure/storm/repl.clj +++ b/src/clj/clojure/storm/repl.clj @@ -1,8 +1,6 @@ (ns clojure.storm.repl (:import [clojure.storm Emitter Tracer])) -(def ^:private storm-initialized? (atom false)) - (defn- call-flow-storm [fn-symb & args] (try (let [fqsym (symbol "flow-storm.storm-api" (name fn-symb)) @@ -41,8 +39,6 @@ :noinst (do (Emitter/setInstrumentationEnable false) true) (call-flow-storm 'maybe-execute-flow-storm-specials input))) -(defn init-flow-storm-if-needed [] - (when-not @storm-initialized? - (call-flow-storm 'start-recorder) - (reset! storm-initialized? true))) +(defn maybe-init-flow-storm [] + (call-flow-storm 'start-recorder)) diff --git a/src/jvm/clojure/lang/Compiler.java b/src/jvm/clojure/lang/Compiler.java index e7a37e7632..c0b5547a33 100644 --- a/src/jvm/clojure/lang/Compiler.java +++ b/src/jvm/clojure/lang/Compiler.java @@ -7927,7 +7927,19 @@ private static void maybeRegisterForm(Integer formId, String file, Object line, } } + +public static void stormEnhancedReplEval(Object form) { + try { + Var maybeExecuteStormSpecials = Var.find(Symbol.create("clojure.storm.repl", "maybe-execute-storm-specials")); + if (maybeExecuteStormSpecials != null) + ((IFn)(maybeExecuteStormSpecials.deref())).invoke(form); + } catch (Exception e) {} +} + public static Object eval(Object form, boolean freshLoader) { + + stormEnhancedReplEval(form); + boolean createdLoader = false; if(true)//!LOADER.isBound())