When we enable the checking of deferred warnings, the following 57 systems have issues. Now to contact the authors. Then of course, there are all the style-warnings that we are ignoring, but oh well.
s-xml mcclim cl-csv clsql-helper lisp-on-lines regex zlib cl-mediawiki cl-neo4j cleric coleslaw com.informatimago.common-lisp.parser diff gdl-ta2 lispbuilder-regex marching-cubes mgl odd-streams open-vrp-lib pg prepl webactions xmls-tools adw-charting-vecto cl-azure cl-containers-test cl-fluiddb-test cl-fsnotify cl-gdata cl-graph-test cl-markdown-test cl-memcached cl-pdf-doc cl-protobufs-tests cl-quakeinfo cl-randist cl-redis clack-handler-hunchentoot clunit com.informatimago.linc com.informatimago.xcode computable-reals dcm elephant-tests hh-web json-template kanren-trs-test km lift-test lucene-in-action-tests parseltongue postoffice spinneret trivial-timeout-test weblocks-demo weblocks-demo-popover wilbur
—♯ƒ • François-René ÐVB Rideau •Reflection&Cybernethics• http://fare.tunes.org Justice is not concerned with the results of the various transactions but only with whether the transactions themselves are fair. — F.A. Hayek, "Law, Legislation and Liberty", I.6.j
OK, so I notified the following, but more remain.
Notified: :individual-authors (("James Anderson james.anderson@setf.de" de.setf.wilbur) ("Gary King gwking@metabang.com" trivial-timeout asdf-system-connections lift lift-test cl-containers) ("Paul Rodriguez pmr@ruricolist.com" spinneret) ("Alejandro Sedeno asedeno@gmail.com" cl-protobufs cl-protobufs-tests) ("Orivej Desh orivej@gmx.fr" postoffice) ("Vincent Toups vincent.toups@gmail.com" parseltongue) ("Leslie Polzer leslie.polzer@gmx.net" montezuma) ("Alan Oursland alan.oursland@gmail.com" km) ("Ryan Davis ryan@acceleration.net" cl-csv cl-mediawiki) ("Drew Crampsie drew.crampsie@gmail.com" lisp-on-lines) ("Robert Marlow bobstopper@bobturf.org" xmls-tools) ) :mailing-lists (("mcclim-devel@common-lisp.net" mcclim) ("zlib-devel@common-lisp.net" zlib) ("clsql@b9.com" clsql) ("cleric-devel@common-lisp.net" cleric) ("cl-neo4j-devel" cl-neo4j) ) :no-valid-email (("Michael Parker mparker762@hotmail.com" regex) ;; both deferred-warnings failure and UTF8 issue, but author email not valid anymore. ))
Remain:
coleslaw com.informatimago.common-lisp.parser diff gdl-ta2 lispbuilder-regex marching-cubes mgl odd-streams open-vrp-lib pg prepl webactions adw-charting-vecto cl-azure cl-containers-test cl-fluiddb-test cl-fsnotify cl-gdata cl-graph-test cl-markdown-test cl-memcached cl-pdf-doc cl-quakeinfo cl-randist cl-redis clack-handler-hunchentoot clunit com.informatimago.linc com.informatimago.xcode computable-reals dcm elephant-tests hh-web json-template kanren-trs-test
For the record, failure logs are here: http://common-lisp.net/project/cl-test-grid/asdf/sbcl-warning-failures.html http://common-lisp.net/project/cl-test-grid/asdf/asdf-diff-13.html
—♯ƒ • François-René ÐVB Rideau •Reflection&Cybernethics• http://fare.tunes.org May you live all the days of your life. — Jonathan Swift
On Wed, Feb 20, 2013 at 9:54 PM, Faré fahree@gmail.com wrote:
I want to say do not really support chaning the warinings handling. For two reasons:
1. I don't see how it can be introduced smoothly. Faré, you did significant piece of work by contacting all the maintainers, and it will take more work to track their responses. Somebody will not respond, because the systems are not developed for several years, somebeody will report the undefined variable if fixed, but when we try we will find next undefined variable. Warnings are not always trivial to fix. It's not utf-8 where author can just set the :encoding attribute. Fixing warning involves changing code, analyzing how variables for functions are used, is it possible to reorder definitions, and so on. Also it may result in new bugs.
So I am affraid it will take half a year to push the fixes and it's work for you and for the maintainers.
Changing the warning rules without fixing the affected systems is not an option at all IMHO. This CL codebase we inherit is a valueable asset, we should direct efforts to preservig it functioning, but not breaking. If we want to direct evolution of CL into some more robust direction, it's better to find a way without rejecting previous work.
2. I do not really understand the change in warning handling. Of course, this point doesn't mean the changes are wrong, and it's all in my hands to study the subject. But untill I get the understanding I can't support this feature.
Faré, you said that the change introduces (with-compilation-unit (:override t) ... ) around compilation of every file, and the warnings reported by this with-compilation-unit are saved and may result in compilation failure. In the previous ASDF there was only one with-compilation-unit around whole ASDF system - this big with-compilation-unit remains in new ASDF too.
Do I describe it right?
Why it is better? Do we catch more warnings or why? What are the use-cases when new warnings behaviour make life better?
And in general, warnings handling. I created a file warntest.lisp with this content:
(defun f () *my-var*) (defparameter *my-var* 1) (f)
On both CCL and SBCL, (compile-file "warntest.lisp") returns the following:
;Compiler warnings for "c:/Users/anton/projects/cl-test-grid2/work/warntest.lisp" : ; In F: Undeclared free variable *MY-VAR* #P"c:/Users/anton/projects/cl-test-grid2/work/warntest.wx64fsl" T T
Recall that CLHS calls the 3 values returned output-truename, warnings-p, failure-p. So failure-p is T. Is this program non-conforming? Does it violate CLHS?
As far as I understand, this program is correct.
I creted also a wartest.asd and included wartest.lisp into this ASDF system. Old ASDF performs load-op without error on this system. I am satisfied with this behaviour. Will new ASDF fail this system?
I must say the warnings are very useful. When I work in SLIME they help me all the time. But failing asdf:load-op on warnings by default is not good IMHO. Warnigs are hints for developer.
If develper wants to be very clean, he should be able to enable for his code a mode when warnings fail compilation.
But taking into account that different compilers produce different warnings, this mode should not be enabled when system is delivered to other people. Moreover, new versions of the same compiler can introduce new warnings.
I experienced such problem with big C programs, where build scripts enforce warning free compilation. But since then gcc introduced many new warnings, so when I wanted to rebuild the system myself there were hunderds of warnings. It was unpleasant suprsie. I hoped to just "configure; make; make install", but in result abandoned the program at all.
Therefore, I think it's better to use warning-clean mode only on the developer machine.
Faré, I can help you with testing with warning, without warnings, as you want. But so far I don't see a win of the new warnings handling.
Best regards, - Anton
If the WITH-COMPILATION-UNIT is around only single files, instead of around the entire system load, then aren't we making a transition from:
OLD: Functions (and variables, etc. -- I will confine the discussion to functions for brevity) may be defined in arbitrary orders in a system
to
NEW: Forward reference to functions in the same system is forbidden, because it will cause undefined function warnings, which will break the build.
Do I understand correctly? If so, at least on ACL, the change will be very hard on the existing code base.
Or are we going to re-check the warnings at the end of the process and ignore warnings for seemed-to-be-undefined-functions-that-are-now-defined?
Thanks, r
21.02.2013, 21:24, "Anton Vodonosov" avodonosov@yandex.ru:
SBCL results arrived: http://common-lisp.net/project/cl-test-grid/asdf/asdf-diff-14.html
This table includes both warning-caused failures you saw already and new ones, not visible before because compilation failed even without deferred warnings due to encoding.
I must leave now, later will try to separate the failures to leave only new ones.
21.02.2013, 23:47, "Anton Vodonosov" avodonosov@yandex.ru:
SBCL results arrived:
Sorry, not the previous link, here is the correct one: http://common-lisp.net/project/cl-test-grid/asdf/asdf-diff-15.html
21.02.2013, 23:50, "Anton Vodonosov" avodonosov@yandex.ru:
Sorry, not the previous link, here is the correct one: http://common-lisp.net/project/cl-test-grid/asdf/asdf-diff-15.html
The table is updated with CCL results.
Here is the filtered table, showing only warning-caused failures we haven't see before, until the compilation was fixed by utf8: http://common-lisp.net/project/cl-test-grid/asdf/asdf-diff-15-utf-only.html
Here are those new failures sorted by dependencies [1]: http://common-lisp.net/project/cl-test-grid/asdf/sbcl-warning-failures-utf-o... Systems with root blocker count = 0 fail by themselves.
Others fail becuase their dependencies fail, so we don't know whether they have their own problems - they didn't have chance to compile.
1 - The dependency information is retrieved form quicklisp 2013-01-28; as we know, it's not possible to retrieve dependency information 100% precise, because .asd files can contain arbitrary code, like explicit calls to (asdf:operate). But for this diiscusssion and that small number of system I think we can count this dependency information as precise.
Thanks guys, I think all are now fixed for all systems under :genworks-gdl.
On Thu, Feb 21, 2013 at 2:49 PM, Anton Vodonosov avodonosov@yandex.ruwrote:
Opn Thu, Feb 21, 2013 at 1:30 PM, Anton Vodonosov avodonosov@yandex.ru wrote:
Well, I agree that it might not be as smooth as we'd all like, but on the other hand, as with any enforcement, it's the whole point of it that it will catch errors that were not previously seen.
Pro checking deferred warnings by default: P1- We don't go asking SBCL to remove new error checking features, or to downgrade errors to warnings, warnings to style-warnings, because these new checks find bugs in existing software. We welcome the checks and fix the bugs. P2- It's trivial to disable if desired with (setf asdf:*warnings-file-type* nil) and get the old behavior back. For backwards compatibility, make it (defparameter asdf::*warnings-file-type* nil) P3- If we don't enable it now, by induction, we won't enable it ever, because until we enforce it by default, there will always be someone somewhere who introduce new bugs. The overall cost of transitioning is not substantially reduced by postponing the transition. P4- If some maintainers are unresponsive or unwilling to maintain anymore, it's time to either fork their work (if used) or drop it (if unused). P5- As Attila Lendvai noted, users shouldn't be pulling changes to a library in isolation from changes to other libraries, but be using coherent snapshots of things that work together. And developers should be working on keeping their latest coherent with the latest of their dependencies. i.e. they should keep using the February snapshot of Quicklisp until it's time to upgrade to the March or April snapshot.
Con checking deferred warnings by default: C1- If it was compiling cleanly (enough) and working before, why complain about it now? Preventing new bug is one thing, but can't we grandfather in old bugs we know don't affect us? C2- Transition is smoother if old code doesn't have to be modified, only new code. C3- Though the overall work is made somewhat larger by spreading it over time, the instant pain is less, and that matters, too. C4- not having to either wait for the late maintainers or have some non-maintainer update in a fork allows us to make progress without any latency. C5- Inasmuch as some software works for what it's used for, even if it otherwise has bugs, as long as these bugs are not exercised, it's better to let the software run than to reject it at compile-time.
So, how can we make transition smoother without sacrificing checking for new code? I could T1- have some magic transition date wired in asdf.lisp, and enable checking for any code modified after that date. Ouch. T2- have a configurable list of systems that are grandfathered in, for which checking is disabled, there again with or without a date limit with or without some maximum applicable version number, with or without a non-empty default list wired in ASDF. T3- introduce a new defsystem keyword :asdf-version, which specifies which asdf version a defsystem was written for, so we can guess what assumptions were put into the system; but then each and every user has to worry about putting a number not too recent yet not too old in there when he updates his software. T4- implement some quicklisp variant that makes it easy to do non-maintainer upgrades for bug fixes to such issues. T5- implement some Nix-style namespace management for Lisp systems and packages, so software can always be loaded with a coherent set of dependencies, including ASDF.
Yes, it is better because we catch actual warnings: * functions used but never defined nor declared * variables used before they were defined or declared
These are often mistyped function or variable names; sometimes, it is missing functionality that is not implemented yet; in any case, probable bugs.
The third value FAILURE-P is T, indicating a failure indeed, which on SBCL would have caused us to fail the build when checking the results of COMPILE-FILE, as per *COMPILE-FILE-FAILURE-BEHAVIOUR*, if the warning hadn't been deferred -- but it is deferred by WITH-COMPILATION-UNIT, so an old ASDF will fail to fail the build because it doesn't check the warnings. A new ASDF will fail the build because it does check.
Forward reference to variables might even be non-conformant (I remember an SBCL discussion about making it wholly illegal in SBCL, but I don't remember what was the conclusion of the discussion).
That's an old discussion you should have had with Dan Barlow ten years ago. You can change *COMPILE-FILE-FAILURE-BEHAVIOUR* if you want. Downgrading it from :error to :warning would be a loss of functionality, IMHO.
Maybe Quicklisp should bind *WARNINGS-FILE-TYPE* to NIL. Or maybe ASDF should magically detect an old Quicklisp and do that. (How do I magically detect an old Quicklisp?)
Faré, I can help you with testing with warning, without warnings, as you want. But so far I don't see a win of the new warnings handling.
I agree that there's a transition issue to be handled. The current situation is certainly unsatisfying. I am not convinced what is the best solution going forward.
—♯ƒ • François-René ÐVB Rideau •Reflection&Cybernethics• http://fare.tunes.org It is said an Eastern monarch once charged his wise men to invent him a sentence to be ever in view, and which should be true and appropriate in alltimes and situations. They presented him the words: "And this, too, shall pass away." — Abraham Lincoln
I must be missing something because I thought Quicklisp already rejects at least new dists if they throw warnings on compiling. Maybe they were/are some different class of warnings, but I remember clearly that Genworks got rejected for inclusion in Quicklisp (this was just over a year ago, and we got "cantbuild" labels in our Issue in quicklisp-projects) until we got all Warnings eradicated.
In the meantime it looks like a few more mis-ordered defparameters crept in, which did not cause new Quicklisp rejections but were flagged by Anton's recent CL-test-grid results with tnew strict asdf.
So if the Quicklisp policy has been like this since the beginning, that seems to imply that any warnings in current systems have come in sometime since the system was first accepted into Quicklisp.
Dave
P.S. are style-warnings going to be next? ("First they came for my Warnings. Then, they came for my Style-Warnings..." :)
On Feb 22, 2013, at 6:01 PM, Faré fahree@gmail.com wrote:
On Fri, Feb 22, 2013 at 8:42 PM, Dave Cooper david.cooper@genworks.com wrote:
Quicklisp hasn't changed here. It relies on ASDF to build software. It's ASDF that has been catching the warnings, and on SBCL failing the build if there is any non-style-warning warning, as per asdf:*compile-file-failure-behaviour* (the default value of which varies by implementation). Now, what warnings get detected evolves as implementation are improved, or in this case as ASDF itself gets more clever and checks deferred warnings that it previously was failing to check.
—♯ƒ • François-René ÐVB Rideau •Reflection&Cybernethics• http://fare.tunes.org Democracy is but government of the busy, by the bully, for the bossy. — Arthur Seldon, "The Dilemma of Democracy"