Skip to content

Latest commit

 

History

History
792 lines (594 loc) · 34.2 KB

changes-detailed.md

File metadata and controls

792 lines (594 loc) · 34.2 KB

Detailed changes in Eastwood behavior

Intended for Eastwood developers to track down when they have time and interest.

Changes from version 0.2.0 to pre-0.2.1 version as of Dec 15 2014

Eastwood 0.2.2 as of Dec 28 2014 throws exception for same-dated version of several libraries

cheshire

lein do clean, test passes, but lein eastwood throws exception during eval of a form in namespace cheshire.core. I haven't investigated why yet.

core.async

Changes from version 0.2.0 to pre-0.2.1 version as of Dec 15 2014

Difference between Eastwood with Clojure 1.6.0 vs 1.7.0-alpha4

This is not a difference in behavior between Eastwood 0.2.0 and later, since it exists with 0.2.0 as well.

When run with Clojure 1.6.0:

lein with-profile +1.6 eastwood '{:namespaces [clojure.reflect]}'

there is no warning with either Eastwood 0.2.0 or pre-0.2.1. When run with Clojure 1.7.0-alpha4:

lein with-profile +1.7 eastwood '{:namespaces [clojure.reflect]}'

both versions of Eastwood throw this exception:

== Linting clojure.reflect ==
Exception thrown during phase :analyze+eval of linting namespace clojure.reflect
IllegalArgumentException No implementation of method: :do-reflect of protocol: #'clojure.reflect/Reflector found for class: clojure.reflect.JavaReflector
	clojure.core/-cache-protocol-fn (core_deftype.clj:555)
	clojure.reflect/eval6478/fn--6479/G--6462--6482 (form-init8277208956703103263.clj:1)
	clojure.core/partial/fn--4490 (core.clj:2489)
	clojure.reflect/type-reflect (reflect.clj:100)
	clojure.core/apply (core.clj:632)
	eastwood.copieddeps.dep2.clojure.tools.analyzer.jvm.utils/type-reflect (utils.clj:24)

[ ... rest of long stacktrace deleted ... ]

The following form was being processed during the exception:
(defprotocol
 TypeReference
 "A TypeReference can be unambiguously converted to a type name on\n   the host platform.\n\n   All typerefs are normalized into symbols. If you need to\n   normalize a typeref yourself, call typesym."
 (typename
  [o]
  "Returns Java name as returned by ASM getClassName, e.g. byte[], java.lang.String[]"))

Not sure yet what causes this difference, and which part it might be a bug in.

Changes from version 0.1.5 to 0.2.0-alpha1 plus a few commits on Nov 14 2014

Notes about behavior of new :unused-locals linter

Many :unused-locals warnings in algo.monads, both clojure.algo.monads and clojure.algo.test-monads namespaces. Would be nice to eliminate them if they are not real. Also similar code causing many such warnings in namespace clojure.tools.nrepl-test. I think this is because there are many uses of a macro that has code in the defmacro like (let [~'warn-name expr] ...), and every time the macro is invoked without the body using warn-name, the line/col numbers are in the macro definition, not where the macro is called.

Ns clojure.tools.nrepl.load-file-test has several :unused-locals warnings that appear to have line:col numbers from a different file, because they do not refer to anything reasonable in the source code of the file they are associated with. They might be for the file containing clojure.tools.nrepl-test above?

These warnings in namespace clojure.core.async.impl.channels look incorrect to me:

src/main/clojure/clojure/core/async/impl/channels.clj:121:45: unused-locals: let bound symbol 'val' never used src/main/clojure/clojure/core/async/impl/channels.clj:121:38: unused-locals: let bound symbol 'putter' never used src/main/clojure/clojure/core/async/impl/channels.clj:140:38: unused-locals: let bound symbol 'val' never used src/main/clojure/clojure/core/async/impl/channels.clj:140:31: unused-locals: let bound symbol 'putter' never used

I have analyzed these, and created a smaller test case that warns for the same reason, with details in comments, in namespaces testcases.unusedlocals, function foo2.

The warnings below in namespace clojure.core.async are confusing since they have no obvious correspondence with the original source code. Most likely this occurs because of the way go-loop macroexpands.

src/main/clojure/clojure/core/async.clj:499:22: unused-locals: let bound symbol inst_8653 never used src/main/clojure/clojure/core/async.clj:518:17: unused-locals: let bound symbol inst_8712 never used

There are many of these in the same namespace. Would be good to find a way to suppress them that does not also suppress good warnings. Would it be too 'coarse' to try to recognize the "_" suffix? Or perhaps have the normal :unused-locals that suppresses those, but a separate :unused-locals-auto-numbered that includes only those? More of these in seesaw project, and spread throughout several other projects.

This warning looks strange, since chs is not bound in a let, but in a defn arg vector. What is going on here?

src/main/clojure/clojure/core/async.clj:937:5: unused-locals: let bound symbol chs never used

This is probably due to how go-loop expands:

src/main/clojure/clojure/core/async.clj:939:18: unused-locals: let bound symbol cs never used

Many :unused-locals warnings in namespace clojure.core.match.test.core, related to how the match macro is defined, I think, and perhaps similar reason for why there are so many :suspicious-expression warnings for match, too.

These :unused-locals warnings in project core.memoize:

src/test/clojure/clojure/core/memoize/tests.clj:43:9: unused-locals: let bound symbol mine never used src/test/clojure/clojure/core/memoize/deprecation_tests.clj:21:9: unused-locals: let bound symbol mine never used

Schema has many :unused-locals warnings that appear to be at least misleading, if not wrong.

Changes due to updating :suspicious-expression linter to always use asts, never source forms

Regressions:

1 new :suspicious-expression warning in namespace potemkin.collections-test. I have checked this one out in detail. It is because of how macro potemkin.collections/def-derived-map is defined when it is invoked with no (optional) key-vals parameter. This seems best handled as an Eastwood annotation, not as a special case for Potemkin in Eastwood source code.

This warning no longer appears, but should:

== Linting clojure.algo.test-monads == {:file "clojure/algo/test_monads.clj", :line 223, :column 10, :linter :suspicious-expression, :msg "= called with 1 args. (= x) always returns true. Perhaps there are misplaced parentheses? The number of args may actually be more if it is inside of a macro like -> or ->>", :uri-or-file-name "src/test/clojure/clojure/algo/test_monads.clj"}

The one above is in the last deftest of the file, and I have verified that Eastwood 0.1.5 issues the warning even if all forms except the ns form and the last one are deleted, which makes testing and debug output much shorter.

The current latest code seems not to be catching this in my function suspicious-is-try-expr because my function is looking for (clojure.test/try-expr ...) in the :raw-forms of an ast with :op :try. In the warning above, the (is ...) is wrapped inside of a (with-monad ...) macro form, which invokes clojure.tools.macro/with-symbol-macros, which expands all macros inside of it all at once with its own macroexpander, separate from the one used by tools.analyzer, and thus tools.analyzer does not put the :raw-forms that usually occur there.

Sounds fairly tricky to enhance Eastwood for, and perhaps not worth it, given how infrequently people wrap clojure.test/is forms in other macros like this.

Many new :suspicious-expression warnings in namespace clojure.core.match.test.core. Created issue #108 to track this.

I have double checked these, and it seems like these are very common, due to the way the clojure.core.match/match macro expands. I would guess the best way to eliminate these would be to modify the match macro to suppress these :suspicious-expression warnings. Ideally it would be nice to have a way to suppress them in the macro implementation 'itself', but still enable warnings in arguments to the macro that are included unmodified as part of the macroexpansion, so that if there are issues deserving warnings there, they still are warned about. I don't know if that is easy to do.

A bad thing about that idea is that it requires the source code of match to be modified with Eastwood-specific annotations. It would also be nice if such modifications to Eastwood's behavior could be made without having to modify the source code of libraries one uses. That sounds trickier, but some way to tell Eastwood: Do not issue warnings of type X inside macro foo.bar/baz, without modifying namespace foo.bar, only a place that requires foo.bar, could be useful.

Improvements:

Namespaces with new correct warnings found. Yay!

clojurewerkz.elastisch.rest-api.facets-test

Namespaces with incorrect warnings that used to be generated inside of -> or ->>, but no longer are. Yay!

net.cgrand.xml in enlive
flatland.useful.io

Temporarily was regression, now fixed:

== Linting clojure.tools.analyzer.jvm == {:file "clojure/tools/analyzer/jvm.clj", :line 178, :column 8, :linter :suspicious-expression, :msg "doto called with 1 args. (doto x) always returns x. Perhaps there are misplaced parentheses? The number of args may actually be more if it is inside of a macro like -> or ->>", :uri-or-file-name "src/main/clojure/clojure/tools/analyzer/jvm.clj"}

Fixed this one. It was being masked out because the doto was inside of a clojure.core/or, and my code for suppressing or expansions from other or's was suppressing everything expanded inside of an or. Made the suppression condition more precise, for this and for cond.

Changes from version 0.1.4 to 0.1.5-alpha2 on Oct 31 2014

Many :wrong-tag warnings with no file, line, or column numbers:

clojure.test.array-test (project test.generative-2013-11-10)

A few more reflection warnings when linting these namespaces:

clj-ns-browser.utils

Better or worse? No longer an analysis exception for namespace:

flatland.useful.deftype

Better? Used to be exception thrown analyzing this namespace, now none.

clojure.reflect - Check with Nicola, but this appears to be a good
  change in behavior to me.

Better if the line/col numbers are reasonable: Non-nil line/col for warnings in these namespaces, formerly nil

clojurewerkz.elastisch.rest-api.multi-test (:suspicious-test)
me.raynes.core-test (:unused-ret-vals)
clojure.java.data (:unused-ret-vals)
potemkin (:unused-ret-vals)
potemkin.collections-test (:unused-ret-vals)
clojure.tools.namespace.parse (:unused-ret-vals)
clojure.tools.namespace (:unused-ret-vals)

Worse: Some line/column numbers were numbers before, now nil, in these namespaces:

clojure.core.constraints-tests (:redefd-vars)
potemkin.collections-test (:redefd-vars)

Better? Changed line/column numbers:

clojure.core.match.date (:deprecations)
clojure.core.match.test.java (:deprecations)
clojure.core.unify (:unused-ret-vals)
clojure.data.zip.xml-test (:unused-ret-vals)
flatland.useful.java-test (:unused-ret-vals)

Investigated:

Better: These namespaces used to throw exceptions because of bad tags, but now they generate a :wrong-tag warning (or multiple such warnings) instead:

cheshire.test.generative
clojure.data.fressian-test
clojurewerkz.meltdown.reactor
clojurewerkz.meltdown.consumers-test
seesaw.widgets.log-window
clojure.test.core-test
clojure.test.array-test
clojure.test.math-test
clojurewerkz.titanium.query

Better: These namespaces used to throw exceptions because of bad tags, but now they neither throw an exception nor generate a :wrong-tag warning (or multiple such warnings) instead:

clojurewerkz.meltdown.selectors-test
clojurewerkz.meltdown.reactor-test

Better: Namespaces below used to issue more reflection warnings, but now a subset. I've verified new output matches 'lein check' reflection warnings for this namespace (modulo line/col numbers), so good.

reply.eval-modes.nrepl

Better: Namespaces below issue a superset of reflection warnings compared to 0.1.4, but they turn out to be identical to those issued by 'lein check', so they are better (modulo line/col numbers are typically different than 'lein check' output):

no change from 0.1.4 seesaw.widgets.log-window clojure.test.array-test

Worse: Namespace clojure.core.logic.nominal.tests throws exception:

CompilerException java.lang.IllegalStateException: record? already refers to: #'clojure.core.logic/record? in namespace: clojure.core.logic.nominal, compiling:(clojure/core/logic/nominal.clj:1:1)

Exception only occurs for Clojure 1.6.0 and later, and for the
older core.logic-2014-02-21, not for core.logic-2014-03-28, which
has a compile-if conditional wrapper around its definition of
record?  This might even be eliminated with a fix for CLJ-1578 ?

Better: Fix for issue #74 eliminated some unwanted suspicious-expression warnings:

clojure.tools.test-macro

Changes from version 0.1.3 to 0.1.4

The new way planned to check for (is ...) expressions, so that it only lints them if they are clojure.test/is, by using the :raw-forms and :eastwood/partly-resolved-forms values in the AST, causes some lint warnings to no longer be printed. Here are some of them:

  • The last deftest called state-seq-monad in algo.monad's file test_monads.clj. This appears to be because :raw-forms includes macro expansions up to an invocation of clojure.tools.macro/with-symbol-macros, but after that the (is) macro is expanded along with everything else, or something like that. Probably t.a.j/analyze+eval's method of doing macroexpand-1 doesn't handle symbol macros.

  • core.logic-2014-02-21 namespace clojure.core.logic.nominal.tests had a :suspicious-test warning before about nil inside a deftest, probably due to a (comment ...) inside of a deftest. I didn't explicitly try to make this no longer appear, but it does not. That is good, if it is for the right reason.

  • namespace clojure.java.test-jmx has a new warning about a non-string as second arg at line 142. The second arg is a symbol whose value happens to be a string, I can tell, but I can see that this is like other cases where it is not easy for Eastwood to determine that. It probably did not occur in the output before because the 'is' macro invocation is inside of a doseq.

  • Namespace ogre.transform.traversal-test used to have 2 :suspicious-test warnings that no longer appear. This is probably due to an exception being thrown before analysis completes. This did not prevent the warnings before because they were done purely at the source code form level, not on ASTs.

  • Many new :unused-ret-vals warnings in namespace potemkin. I don't know why yet.

  • Namespace reply.reader.jlin.JlineInputReader no longer has spurious :unused-ret-vals warning due to use of :gen-class in ns form. Good!

  • Namespace clojure.tools.test-macro no longer has a spurious :suspicious-test warning due to (comment) inside deftest. Good!

  • Namespace clojure.tools.reader.impl.ExceptionInfo no longer has spurious :unused-ret-vals warning due to use of :gen-class in ns form. Good!

  • Namespace flatland.useful.deftype no longer throws a "Method code too large!" exception. Good. But now it throws an exception "Attempting to call unbound fn: #'flatland.useful.deftype/defmap". Not sure why it would do that.

  • Namespace flatland.useful.utils-test no longer shows two :suspicious-test warnings that it did before. It appears that it should. Investigate why they are no longer there.

  • Exception thrown during analyze+eval of namespace clojure.reflect. This has not occurred before. Figure out why.

Changes from version 0.1.2 to 0.1.3

GOOD CHANGE: The formerly-normal 2 reflection warnings from clojure/data/priority_map.clj and clojure/core/memoize.clj are now gone, because these libraries have been copied into Eastwood, and updated to no longer generate those reflection warnings. Note that for projects that use these versions of core.memoize and/or data.priority-map, they now have their own reflection warnings for these namespaces, whereas before these were 'masked' by the ones from Eastwood.

GOOD CHANGE: clj-ns-browser-2013-03-04 formerly caused an exception to be thrown early during linting, due to that project using a version of tools.namespace with a different API than the version used by Eastwood. Eastwood copying tools.namespace and renaming its namespace helps in 0.1.3 to do normal linting of this project.

Similarly for these projects:

  • core.cache-2014-01-31
  • core.memoize-2013-08-13

GOOD CHANGE: Linting data.priority-map-2014-03-20 had an :unlimited-use warning that used to have :line nil and :column nil, but now it has numbers there instead of nil, and they are correct. This is probably because of the same change, and thus now Eastwood's reader is actually reading the source code from the files, instead of skipping reading them because the namespaces were already there? Something like that, I would guess.

Similarly in these projects:

  • tools.reader-2014-03-05

COULD BE BETTER: core.constracts-2013-07-24 has a :redefd-vars warning, now with file names and column numbers, that gives wrong a line number in a file that does not have that many lines in it. Probably some macro expansion issue that Eastwood doesn't handle well.

WEIRD: core.logic-2014-02-21 throws IllegalStateException in both versions, but in 0.1.3 the "Shown again with metadata for debugging" has no :line :column etc. metadata, whereas it did in 0.1.2. I don't know yet why this change occurs.

Similarly for these projects:

  • ogre-(tbd-date-here)
  • potemkin - difference here is no output at all for with-metadata version
  • useful-2013-11-19 - difference here is part of output expression does not appear at all, which might be similar to potemkin change

BUG?: java.jdbc-2014-03-07 used to have these warnings in the output, but no longer. I do not know why, but suspect it is due to some kind of change in tools.analyzer(.jvm).

Error: Eastwood found no instance method named getTables for class java.sql.DatabaseMetaData taking 4 args with types (java.lang.Object, java.lang.Object, java.lang.Object, [Ljava.lang.String;).  This may occur because Eastwood does not yet do type matching in the same way that Clojure does.
Error: Eastwood found no instance method named getTables for class java.sql.DatabaseMetaData taking 4 args with types (java.lang.Object, java.lang.Object, java.lang.Object, [Ljava.lang.String;).  This may occur because Eastwood does not yet do type matching in the same way that Clojure does.

BUG?: seeaw-2014-02-21 used to have this warning in the output, but no longer. Seems similar to the java.jdbc change.

Error: Eastwood found no instance method named addStyle for class javax.swing.JTextPane taking 2 args with types (java.lang.String, java.lang.Object).  This may occur because Eastwood does not yet do type matching in the same way that Clojure does.

BUG?: tools.analyzer.jvm-2014-03-11 formerly had fairly clean output from Eastwood, but now I see this exception. I do not know yet why this new behavior occurs.

Additional info: tools.analyzer.jvm-2014-03-11/project.clj depends upon version 0.1.0-SNAPSHOT of tools.analyzer. Thus it depends upon what version of tools.analyzer happens to be in my local Maven repo at the time. By doing 'lein install' on the version of tools.analyzer in the crucible repo first, this problem about not finding rseqv disappears.

== Linting clojure.tools.analyzer.passes.jvm.clear-locals ==
Exception in thread "main" java.lang.IllegalAccessError: rseqv does not exist, compiling:(/private/var/folders/c1/gpfcdwt14075pr80tsshkws40000gn/T/form-init5513266052110466476.clj:1:142)
Caused by: java.lang.IllegalAccessError: rseqv does not exist
    ... 11 more
Error encountered performing task 'eastwood' with profile(s): 'default,1.6'
Subprocess failed

BUG?: Perhaps similar is a new exception in useful-2013-11-19 shown below:

Additional info: This error does not occur if you lint only the namespace flatland.useful.deftype-test. The function alist is defined in namespace flatland.useful.deftype, and Eastwood throws an exception while linting that namespace, probably before successfully defining fn alist, thus causing the problem below later on.

== Linting flatland.useful.deftype-test ==
{:linter :unlimited-use,
 :msg
 "Unlimited use of (clojure.test flatland.useful.deftype) in flatland.useful.deftype-test",
 :line 1,
 :column 5}

Exception thrown during phase :analyze of linting namespace flatland.useful.deftype-test
Got exception with extra ex-data:
    msg='Could not resolve var: alist'
    (keys dat)=(:file :column :line :var)
ExceptionInfo Could not resolve var: alist

BUG?: Project useful-2013-11-19 now also throws "RuntimeException Method code too large!" that it did not throw before while linting namespace flatland.useful.deftype. I do not know the reason, but would guess it might be because of line/col metadata being inside of a backquote expression and getting expanded out into something even larger than it was in the older version.

BUG IN TOOLS.READER?: Project useful-2013-11-19 used to have bad line/col numbers for some warnings, and they have been made better. Perhaps this is due to bug fixes in tools.reader, or Eastwood's new use of the IndexingReader to get the file names in metadata.

Changes from version 0.1.1 to 0.1.2

This appears to be a good change, which doesn't need fixing, but I wanted to record it here since I believe I understand the reason for the change.

With Eastwood 0.1.1, the crucible linting of namespace clojure.stacktrace (and a few others in Clojure core) did not show any reflection warnings. With Eastwood 0.1.2, it does.

The warnings from Eastwood 0.1.2 for these Clojure core namespaces are the same (or perhaps with a few minor differences) from those you see if you build Clojure using ant after enabling reflection warnings in build.xml.

I believe the reason they did not appear in 0.1.1 output, but they do appear in 0.1.2 output, is because of the change that was made to fix issue #60.

clojure.stacktrace was already loaded at the beginning of linting in both cases. With Eastwood 0.1.1 this caused the eval of analyzed-then-emitted-from-AST forms to be suppressed. With that change, the emitted forms are eval'd anyway, even though the namespace has already been loaded previously.

core.cache-2014-01-31 had change in exceptions thrown.

With Eastwood 0.1.1 the first exception was this:

== Linting clojure.core.cache ==
Exception thrown during phase :analyze of linting namespace clojure.core.cache
Got exception with extra ex-data:
    msg='Could not resolve var: cache'
    (keys dat)=(:file :column :line :var)
ExceptionInfo Could not resolve var: cache
    clojure.core/ex-info (core.clj:4403)
    clojure.tools.analyzer.passes.jvm.validate/eval2644/fn--2646 (validate.clj:32)
    clojure.lang.MultiFn.invoke (MultiFn.java:227)
    clojure.tools.analyzer.passes.jvm.validate/validate (validate.clj:237)
    eastwood.analyze-ns/run-passes/analyze--3856/fn--3857 (analyze_ns.clj:186)

With Eastwood 0.1.2 the first exception is this:

== Linting clojure.core.cache ==
Exception thrown during phase :analyze of linting namespace clojure.core.cache
IllegalArgumentException No implementation of method: :has? of protocol: #'clojure.core.cache/CacheProtocol found for class: clojure.core.memoize.PluggableMemoization
    clojure.core/-cache-protocol-fn (core_deftype.clj:544)
    clojure.core.cache/eval5394/fn--5395/G--5331--5398 (form-init1529996205346131197.clj:1)
    clojure.core.cache/through (form-init1529996205346131197.clj:53)
    clojure.core.memoize/through* (memoize.clj:52)
    clojure.lang.Atom.swap (Atom.java:65)
    clojure.core/swap! (core.clj:2234)

I do not know the reason for the change yet, but core.cache typically has strange behavior during linting, especially if the version is different than the one on which Eastwood itself depends.

Extra line numbers in :redefd-vars warnings from Eastwood 0.1.2:

== Linting clojure.core.constraints-tests ==
{:linter :redefd-vars,
 :msg "Var ->Foo def'd 2 times at lines: 154 125",
 :line 125,
 :column 6}

{:linter :redefd-vars,
 :msg "Var map->Foo def'd 2 times at lines: 154 160",
 :line 160,
 :column 8}

Eastwood 0.1.1 did not have the 154 numbers in the output. Those line numbers are not terribly helpful in either of these cases, since they are from macro definitions in a different file from the one that caused the warnings. This was due to one of the last commits to tools.analyzer before the 0.1.0-beta10 release, or perhaps to tools.analyzer.jvm.

Some small differences in the output of exceptions thrown while processing core.logic. I am pretty sure that this is due to Eastwood 0.1.1 having a special case for analyzing ns forms as a whole, whereas 0.1.2 treats them like any other form, i.e. macroexpand them and if it expands to a do form, analyze each subform independently before the next subform. Similar changes in exception messages occur for other crucible projects, too.

core.memoize-2013-08-13 throws an exception with Eastwood 0.1.1 in namespace clojure.core.memoize that Eastwood 0.1.2 does not. Not sure exactly which change caused this, but there are plenty of other differences in the output, and core.memoize being an Eastwood dependency is often troublesome.

Several reflection warnings produced by Eastwood 0.1.1 no longer occur in Eastwood 0.1.2:

== Linting clojure.core.rrb-vector ==
Reflection warning, clojure/core/rrb_vector.clj:100:17 - call to method cons on java.lang.Object can't be resolved (no such method).
Reflection warning, clojure/core/rrb_vector.clj:150:17 - call to method cons on java.lang.Object can't be resolved (no such method).

These were due to Nicola fixing issues with tools.analyzer(.jvm), probably one of these:

Many warnings have improved line:column numbers, strangely enough. This was due to a tools.analyzer(.jvm) change.

kria-2014-03-19 threw many exceptions with Eastwood 0.1.1, and no longer throws any with Eastwood 0.1.2.

potemkin-2014-03-20 analyzed without exceptions with Eastwood 0.1.1, but throws many exceptions with Eastwood 0.1.2. This is due to some changes Nicola made to tools.analyzer(.jvm) shortly before Mar 29 2014, knowing this breakage would occur. He submitted a pull request to potemkin that would enable it to analyze successfully again:

https://github.com/ztellman/potemkin/pull/20

ogre-2014-03-11 throws exceptions after this change, too, due to its use of the potemkin library.

An exception thrown by Eastwood 0.1.1 analyzing tools.analyzer-2014-03-22 namespace clojure.tools.analyzer.query-test no longer occurs.

tools.reader-2014-03-05 had these warnings with Eastwood 0.1.1 that are now gone with 0.1.2:

== Linting clojure.tools.reader.impl.utils ==
WARNING: ex-info already refers to: #'clojure.core/ex-info in namespace: clojure.tools.reader.impl.utils, being replaced by: #'clojure.tools.reader.impl.utils/ex-info
WARNING: ex-data already refers to: #'clojure.core/ex-data in namespace: clojure.tools.reader.impl.utils, being replaced by: #'clojure.tools.reader.impl.utils/ex-data
{:linter :redefd-vars,
 :msg "Var ex-info? def'd 2 times at lines: 41 44",
 :line 44,
 :column 11} 

Similarly for several other namespaces in tools.reader-2014-03-05. An exception thrown while analyzing namespace clojure.tools.reader also no longer occurs:

Exception thrown during phase :analyze of linting namespace clojure.tools.reader
Got exception with extra ex-data:
    msg='Can only recur from tail position'
    (keys dat)=(:file :line :column :exprs :form)
    (:form dat)=
(^{:line 728, :column 33, :end-line 728, :end-column 38} recur)
ExceptionInfo Can only recur from tail position

When analyzing the namespace below in Clojure core using Eastwood 0.1.1, there were no reflection warnings except 'the usual ones' from data.priority-map and core.memoize. With Eastwood 0.1.2 there are the same reflection warnings you see when you enable warnings and compile Clojure itself.

clojure.instant
clojure.main
clojure.repl
clojure.stacktrace

I am nearly certain that this is because of the change Nicola made to Eastwood where it no longer disables eval of emitted forms if the namespace was already loaded. These namespaces were already loaded, and with Eastwood 0.1.1 that caused their emitted forms not to be eval'd during analysis, but with Eastwood 0.1.2 they are eval'd anyway. Thus the reflection warnings.

Changes from version 0.1.0 to 0.1.1

Good change, which doesn't need fixing (except perhaps tracking down the few remaining differences in reflection warnings between Eastwood and lein check): Many reflection warnings issued by Eastwood 0.1.0 that were incorrect are no longer issued in 0.1.1. For example:

# With Eastwood 0.1.0

$ lein with-profile +1.6 eastwood '{:namespaces [ clojure.test ]}'
== Eastwood 0.1.0 Clojure 1.6.0-master-SNAPSHOT JVM 1.7.0_51
== Linting clojure.test ==
Reflection warning, clojure/test.clj:1:251 - call to method nth can't be resolved (target class is unknown).
Reflection warning, clojure/test.clj:1:251 - call to method nth can't be resolved (target class is unknown).

# With Eastwood 0.1.1

$ lein with-profile +1.6 eastwood '{:namespaces [ clojure.test ]}'
== Eastwood 0.1.1-SNAPSHOT Clojure 1.6.0-master-SNAPSHOT JVM 1.7.0_51
== Linting clojure.test ==

In addition, many reflection warnings that are still issued by Eastwood 0.1.1 have more useful line:column numbers than with version 0.1.0: Example:

# With Eastwood 0.1.0

$ lein with-profile +1.6 eastwood '{:namespaces [ clojure.test.junit ]}'
== Eastwood 0.1.0 Clojure 1.6.0-master-SNAPSHOT JVM 1.7.0_51
== Linting clojure.test.junit ==
Reflection warning, clojure/test/junit.clj:1:251 - call to method lastIndexOf can't be resolved (target class is unknown).
Reflection warning, clojure/test/junit.clj:1:251 - call to method substring can't be resolved (target class is unknown).
Reflection warning, clojure/test/junit.clj:1:251 - call to method substring can't be resolved (target class is unknown).

[ ... other output deleted ... ]

# With Eastwood 0.1.1

$ lein with-profile +1.6 eastwood '{:namespaces [ clojure.test.junit ]}'
== Eastwood 0.1.1-SNAPSHOT Clojure 1.6.0-master-SNAPSHOT JVM 1.7.0_51
== Linting clojure.test.junit ==
Reflection warning, clojure/test/junit.clj:84:11 - call to method lastIndexOf can't be resolved (target class is unknown).
Reflection warning, clojure/test/junit.clj:87:8 - call to method substring can't be resolved (target class is unknown).
Reflection warning, clojure/test/junit.clj:87:30 - call to method substring can't be resolved (target class is unknown).

[ ... other output deleted ... ]

Linting contrib libraries core.memoize and core.cache often leads to errors, because now tools.analyer.jvm uses them in its implementation for performance enhancements. Linting tools.analyzer or tools.analyzer.jvm can still often lead to strange errors as before, since they are used in Eastwood's implementation.

core.logic defines record? inconsistently with the new clojure.core/record? in Clojure 1.6, leading to errors during linting.

Line:column locations that used to be reported with Eastwood 0.1.0 but not by Eastwood 0.1.1. There are many other :unlimited-use warnings issued by Eastwood 0.1.1 that do have line:column number as with 0.1.0, but for some reason this one does not. I am guessing it may have something to do with the explicit metadata on the symbol clojure.data.priority-map that is in this ns form that is not in most ns forms.

# With Eastwood 0.1.0
$ lein with-profile +1.6 eastwood
== Eastwood 0.1.0 Clojure 1.6.0-master-SNAPSHOT JVM 1.7.0_51
== Linting clojure.data.priority-map ==
{:linter :unlimited-use,
 :msg "Unlimited use of (clojure.test) in clojure.data.priority-map",
 :line 181,
 :column 5}

# With Eastwood 0.1.1
$ lein with-profile +1.6 eastwood
== Eastwood 0.1.1-SNAPSHOT Clojure 1.6.0-master-SNAPSHOT JVM 1.7.0_51
== Linting clojure.data.priority-map ==
{:linter :unlimited-use,
 :msg "Unlimited use of (clojure.test) in clojure.data.priority-map",
 :line nil,
 :column nil}

New warning while linting tools.macro. This warning is due to a (comment ...) expression inside of a deftest. I do not know why it gave no warning with Eastwood 0.1.0, but unfortunately this is difficult to avoid with the way that Eastwood analyzes comment forms (which always evaluate to nil in Clojure).

== Linting clojure.tools.test-macro ==
[ ... many other warnings that have not changed deleted here ... ]
{:linter :suspicious-test,
 :msg
 "Found constant form  with class nil inside deftest.  Did you intend to compare its value to something else inside of an 'is' expresssion?",
 :line nil,
 :column nil}

New warning while linting tools.reader, which is used by Eastwood so perhaps this is just unavoidable strangeness:

== Linting clojure.tools.reader.impl.utils ==
WARNING: ex-info already refers to: #'clojure.core/ex-info in namespace: clojure.tools.reader.impl.utils, being replaced by: #'clojure.tools.reader.impl.utils/ex-info
WARNING: ex-data already refers to: #'clojure.core/ex-data in namespace: clojure.tools.reader.impl.utils, being replaced by: #'clojure.tools.reader.impl.utils/ex-data
{:linter :redefd-vars,
 :msg "Var ex-info? def'd 2 times at lines: 41 44",
 :line 44,
 :column 11}

Also new exception while linting tools.reader, again perhaps unavoidable strangeness:

== Linting clojure.tools.reader ==
[ ... some lines deleted here ... ]
Exception thrown during phase :analyze of linting namespace clojure.tools.reader
Got exception with extra ex-data:
    msg='Can only recur from tail position'
    (keys dat)=(:file :line :column :exprs :form)
    (:form dat)=
(^{:line 728, :column 33, :end-line 728, :end-column 38} recur)
ExceptionInfo Can only recur from tail position
    clojure.core/ex-info (core.clj:4403)
    clojure.tools.analyzer/eval1045/fn--1048 (analyzer.clj:525)
    clojure.lang.MultiFn.invoke (MultiFn.java:231)