<div dir="ltr"><div class="gmail_default" style="font-family:'courier new',monospace">On Mon, Sep 30, 2013 at 8:32 AM, Andrs, David <span dir="ltr"><<a href="mailto:david.andrs@inl.gov" target="_blank">david.andrs@inl.gov</a>></span> wrote:<br>
</div><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="ltr">
<div class="im"><div style="font-family:'courier new',monospace">On Sun, Sep 29, 2013 at 3:07 PM, Barry Smith <span dir="ltr"><<a href="mailto:bsmith@mcs.anl.gov" target="_blank">bsmith@mcs.anl.gov</a>></span> wrote:<br>
</div></div><div class="gmail_extra"><div class="gmail_quote"><div class="im"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<br>
patch-review doesn't happen. Aside from you, none of the rest of us give a shit about patch review hence we should automatically check for whatever we can to make up for the lack of review.<br>
<br>
Lots of lame excuses why standards shouldn't be enforced automatically. Maybe we should work exclusively inside a IDE that can enforce all kinds of rules without security concerns etc etc or we could do development of each project in its own VM and thus "make normal commands behave differently inside the VM" without security fears. I don't buy these arguments. Our IDE is Emacs+shell+make+python and we can make that IDE help us out, it won't be perfect but if blocks 80% of the goof ups that is a great thing.<br>
<br>
There is also an enormous psychological/sociological advantage to "the development system" enforcing standards: people hate it when after days or weeks of working some wise-ass reviewer says your code doesn't adhere to standards and they will likely push less code in the future but when an automatic test rejects some code and tells the user how to fix it that doesn't make them less likely to push code in the future. Linus has surely lost many decent developers over the years by being an asshole, we don't need to lose the few we have. I'm not saying there should be no code review, just that the sooner in the process each problem is found the better for productively and I see no reason why each git repository couldn't have in it somewhere a list of rules for that project that git verifies are being followed as the user commits code, pushes code, edits code etc. Many of these could just be warnings, for example<br>
<br>
commit -a directly into maint, next, or master: "Are you sure you want to do this COMMIT DIRECTLY INTO maint, normally this is not desirable?"<br></blockquote><div><br></div></div><div><div>
If you put this little "script" into .git/hooks/pre-commit, it will do it:</div></div></div></div></div></blockquote><div><br></div><div><div style="font-family:'courier new',monospace" class="gmail_default">
Sorry, too fast. Here is the script:</div><br></div><div>branch_name=$(git symbolic-ref -q HEAD)<br></div><div>if [ "$branch_name" == "refs/heads/maint" ] || [ "$branch_name" == "refs/heads/next" ]</div>
<div>then</div><div> echo "Trying to commit to into " $branch_name ". This is normally not desireable."</div><div> exit 1</div><div>fi</div><div><br></div><div>exit 0</div><div><br></div><div><br></div>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">
<div><div></div><br></div><div><div class="h5"><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
branch off of next: "Are you sure you want to branch off of NEXT?"<br>
commit a file with // in it. "Yoo Mark, PETSc requires the silly old fashion /* comments, you cannot commit this file since you used the modern //!"<br>
variables declared in the middle of source code. "Yoo, we use C89 here, make sure all variables are declared at the top of scope!"<br>
commit a file with hundreds of lines of commented out source. "Don't be putting commented out code in the repository!"<br>
etc.<br></blockquote></div></div></div></div></div></blockquote><div><br></div><div><div style="font-family:'courier new',monospace" class="gmail_default">Not quite sure how to prevent that branching off of next.</div>
<div style="font-family:'courier new',monospace" class="gmail_default"><br></div><div style="font-family:'courier new',monospace" class="gmail_default">The rest of the checks can probably go into pre-commit hook as well.</div>
<div style="font-family:'courier new',monospace" class="gmail_default"><br></div><div style="font-family:'courier new',monospace" class="gmail_default">The only problem is that it is a client side script, so it will not get cloned from the central repo (AFAIK).</div>
<div style="font-family:'courier new',monospace" class="gmail_default"><br></div><div style="font-family:'courier new',monospace" class="gmail_default">HTH,</div><div style="font-family:'courier new',monospace" class="gmail_default">
<br></div><div style="font-family:'courier new',monospace" class="gmail_default">David</div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div><div class="h5"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">
<br>
Going back to my maint screw up today. Just one useful warning from git/"our Emacs/shell/make/python IDE" along the way and we would have a nice branch we could continue to improve on, instead we have this ugly illegal commit directly into maint that will be harder to work with. Yes, you can easily say, "that Barry is an idiot who always fucks up procedure" but that doesn't help resolve the problem. One damn warning and it won't have happened, but no, you refuse to consider having any enforcement mechanisms at all and expect all developers to internalize 100% all these rules.<br>
<span><font color="#888888"><br>
Barry<br>
</font></span><div><div><br>
<br>
<br>
<br>
<br>
On Sep 29, 2013, at 3:01 PM, Jed Brown <<a href="mailto:jedbrown@mcs.anl.gov" target="_blank">jedbrown@mcs.anl.gov</a>> wrote:<br>
<br>
> Barry Smith <<a href="mailto:bsmith@mcs.anl.gov" target="_blank">bsmith@mcs.anl.gov</a>> writes:<br>
><br>
>>> On the Reported-by tags, could you do them in a structured way as<br>
>>><br>
>>> Reported-by: Matteo Parsani <<a href="mailto:parsani.matteo@gmail.com" target="_blank">parsani.matteo@gmail.com</a>><br>
>>> Reported-by: Lisandro Dalcin <<a href="mailto:dalcinl@gmail.com" target="_blank">dalcinl@gmail.com</a>><br>
>><br>
>> This is fine, but there needs to be a mechanism to ensure this,<br>
><br>
> We already have whitespace conventions, a convention that there are no<br>
> memory leaks, a convention that type-specialized functions use dynamic<br>
> composition, a convention that we do not create dependency loops, a<br>
> function naming convention, a convention about avoiding globals, a<br>
> branch usage convention, etc. None of these are enforced and only some<br>
> have automated checking.<br>
><br>
>> imposing requirements on developers that do not have enforcement<br>
>> mechanisms (besides being yelled at later) don't work.<br>
><br>
> Patch review is more flexible than any automated tool can be. It is<br>
> only time to write an automated tool when the effort to do so, and the<br>
> attainable accuracy, is a better use of human time than had the same<br>
> time been devoted to patch review. Note that patch review can catch<br>
> many things, but automated tools can only catch that which has been<br>
> automated.<br>
><br>
>> Note that this is the same kind of situation as me accidentally<br>
>> editing directly into maint. I did<br>
>><br>
>> git branch barry/fix-matmpibaijsetpreallocationcsr<br>
><br>
> This creates a branch without checking it out. If you want to create<br>
> the branch _and_ check it out, use<br>
><br>
> $ git checkout -b barry/fix-matmpibaijsetpreallocationcsr<br>
><br>
>> happily edited away and tested<br>
>> git commit -a<br>
>> git push<br>
>><br>
>> Now what should have happened is as soon as I tried to happily edit<br>
>> away, something should come back and said to me: "are you sure you<br>
>> want to edit in maint?"<br>
><br>
> This is policy on the branch rather than the fact that you created a new<br>
> branch prior to starting this work. (I do that sometimes so that I'll<br>
> be able to easily compare to the old state later.) We could perhaps<br>
> prevent direct commits on 'maint'.<br>
><br>
>> And don't go and mail me some elisp that I can stick in somewhere to<br>
>> warn me about the maint editing business; that would only solve the<br>
>> problem for me, not for the n-1 other people in the world who make the<br>
>> same mistake. Git needs some way of "baking in" a set of standards<br>
>> (optional obviously) that it does its best to enforce and not leaving<br>
>> it up to each user to remember 324 things they need to constantly be<br>
>> checking depending on what project they are working on.<br>
><br>
> There is a security problem with making normal commands behave<br>
> differently when run inside some repository that you just cloned. Any<br>
> such policy would need to be opt-in.<br>
<br>
</div></div></blockquote></div></div></div><br></div></div>
</blockquote></div><br></div></div>