<div dir="rtl"><div dir="ltr">Hi Manuel,</div><div dir="ltr"><br></div><div dir="ltr">The situation with Phab is somewhat different than the e-mail lists since you can create a revision without CC the lists but you can't post on the lists without mailing it...</div>
<div dir="ltr"><br></div><div dir="ltr">Sending to both lists of course make no sense, I thought about having a CC default of the two lists and the engineer will choose which one (or possibly both) to remove while creating the revision rather having none and the engineer choosing which one to add. This way one can't forget to add the CC list since they are the default.</div>
<div dir="ltr"><br></div><div dir="ltr">Yaron</div><div dir="ltr"><br></div><div dir="ltr"><br></div></div><div class="gmail_extra"><div dir="ltr"><br><br><div class="gmail_quote">2014-06-16 14:44 GMT+03:00 Manuel Klimek <span dir="ltr"><<a href="mailto:klimek@google.com" target="_blank">klimek@google.com</a>></span>:<br>
<blockquote class="gmail_quote" style="margin:0 .8ex;border-left:1px #ccc solid;border-right:1px #ccc solid;padding-left:1ex;padding-right:1ex"><div class="gmail_extra"><div class="gmail_quote"><div class="">On Mon, Jun 16, 2014 at 1:34 PM, Yaron Keren <span dir="ltr"><<a href="mailto:yaron.keren@gmail.com" target="_blank">yaron.keren@gmail.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="rtl"><div dir="ltr">I had seen messages from the mailing list bot telling me as a revision owner that the automated e-mail from Phab needs approval since it addressed too many e-mails. This may be another possible point of failure. Otherwise, I find Phab to be much more orderly way of reviewing than the list.</div>
<div dir="ltr"><br></div><div dir="ltr">Right now the default in Phab is no CC to the lists. How about making the default CC to llvm-commits and/or cfe-commits?</div></div></blockquote><div><br></div></div><div>I think using both would be too spammy, and deciding on one would need somebody to put some implementation effort into it. I think engineers are generally very capable of adding the right list to CC, much like they are when sending emails.</div>
<div><br></div><div>Cheers,</div><div>/Manuel</div><div><div class="h5"><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="rtl"><div dir="ltr"><br>
</div></div><div class="gmail_extra">
<br><br><div class="gmail_quote"><div dir="ltr">2014-06-16 14:02 GMT+03:00 Timur Iskhodzhanov <span dir="ltr"><<a href="mailto:timurrrr@google.com" target="_blank">timurrrr@google.com</a>></span>:</div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div><div>
<p dir="ltr">I by no means blame you for pointing that out.  I don't support the exact way it was done though.</p>
<div class="gmail_quote">16 июня 2014 г. 15:00 пользователь "Alp Toker" <<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a>> написал:<div><div><br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
On 16/06/2014 13:28, Timur Iskhodzhanov wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
Some of these are good questions for whoever runs Phab (not David AFAIK), but for a different discussion (feel free to start a new thread on the list).<br>
<br>
I see nothing wrong David had done intentionally during this review, so I'd prefer if you apologize to him for the rant and we get back to work (and I'll get back to my sick leave).<br>
<br>
</blockquote>
<br>
Timur, that's out of order. The developer policy makes it clear the list is the place for patches. It's also made clear:<br>
<br>
  " If someone sends you a patch privately, encourage them to submit it to the appropriate list first."<br>
<br>
  <a href="http://llvm.org/docs/DeveloperPolicy.html" target="_blank">http://llvm.org/docs/<u></u>DeveloperPolicy.html</a><br>
<br>
It's basically not OK that every time the community is excluded from review, some tool gets blamed and the person pointing it out gets personally attacked.<br>
<br>
The policy makes it clear that responsibility lies with the author. If I hadn't pointed this out, the code would have just slipped through as happens quite often, without anyone outside the closed circle getting a say.<br>
<br>
How about we focus on fixing that instead of making this about personalities?<br>
<br>
The patch workflow is becoming increasingly dysfunctional with 3.5 just round the corner and I'm concerned, and speaking up about it.<br>
<br>
Alp.<br>
<br>
<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
16 июня 2014 г. 14:01 пользователь "Alp Toker" <<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a> <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a>>> написал:<br>
<br>
<br>
    On 16/06/2014 12:11, Timur Iskhodzhanov wrote:<br>
<br>
<br>
        I'm sorry to see that you've read my email very differently<br>
        from what I've intended.<br>
        I think you should calm down a little bit and read the Phab<br>
        log in our shoes.  I don't think anyone on this thread tried<br>
        to do anything suspicious on purpose.<br>
<br>
<br>
    Okay, let's try to understand how the patch workflow goes in your<br>
    shoes. I think more transparency about the web-based review<br>
    workflow is needed.<br>
<br>
    None of the below is actually clear to people using the mailing<br>
    list for review, and very often the web-based changes seem fly by<br>
    in read-only form or on-list reviews get summarily ignored:<br>
<br>
    How are the CC lists for patches decided? The names don't seem to<br>
    be derived from the canonical CODE_OWNERS.txt -- are they<br>
    maintained in SVN or a separate repository?<br>
<br>
    Is there public access to see who is assigned to what piece of<br>
    code? How are these decided, and are mailing list reviewers able<br>
    to join the CC list or is it exclusive to web-based reviewers?<br>
<br>
    What determines if a patch is in "private pre-review" and excluded<br>
    from public mailing lists? Is there some kind of subscription-only<br>
    mailing list to track such patches, or are they kept in a private<br>
    database?<br>
<br>
    Why do arbitrary names show up on the "Reviewers" line when review<br>
    was actually been done by someone on-list?<br>
<br>
    Why do on-list reviews of web-based patches frequently get<br>
    ignored? Are the patch authors ignoring something, or is it a bug<br>
    in the web interface?<br>
<br>
    Alp.<br>
<br>
<br>
<br>
        16 июня 2014 г. 13:00 пользователь "Alp Toker" <<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a><br>
        <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a>> <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a><br>
        <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a>>>> написал:<br>
<br>
<br>
            On 16/06/2014 11:32, Timur Iskhodzhanov wrote:<br>
<br>
<br>
                I think it wasn't hard to see llvm-commits on CC in<br>
        Phab.  I<br>
                can't imagine a single reason for an ADT review to be<br>
        private<br>
                and David responses were perfectly reasonable for me<br>
        (note I<br>
                was one of the reviewers and saw all the mail).<br>
<br>
<br>
            That attitude is part of the problem. I don't think it's<br>
        OK for<br>
            the patch to skip the mailing list Just because it seemed<br>
            reasonable to you and David.<br>
<br>
            Did you notice there are two duplicate copies of a large<br>
        chunk of<br>
            code in the patch, presumably attempting to provide<br>
        const-correctness?<br>
<br>
            I guess not, but why exclude others from pointing out<br>
        flaws and<br>
            improving quality of review?<br>
<br>
                It looks like this time you've trusted the technology more<br>
                than you've trusted people -- if you ask me, you<br>
        should have<br>
                much stronger arguments before blaming people like this.<br>
<br>
<br>
            It turns out the technology was right -- as Manuel pointed<br>
        out,<br>
            the patch was *never sent to the list* and only you guys<br>
        had the<br>
            chance to comment.<br>
<br>
            Alp.<br>
<br>
<br>
                16 июня 2014 г. 12:07 пользователь "Alp Toker"<br>
        <<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a> <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a>><br>
                <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a> <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a>>><br>
        <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a> <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a>><br>
                <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a> <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a>>>>> написал:<br>
<br>
<br>
                    On 16/06/2014 10:32, David Blaikie wrote:<br>
<br>
                        On Mon, Jun 16, 2014 at 12:28 AM, Alp Toker<br>
                <<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a> <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a>><br>
        <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a> <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a>>><br>
                        <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a> <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a>><br>
        <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a> <mailto:<a href="mailto:alp@nuanti.com" target="_blank">alp@nuanti.com</a>>>>> wrote:<br>
<br>
                            On 16/06/2014 10:01, David Blaikie wrote:<br>
<br>
                                The test case looks a bit thin - it<br>
        doesn't<br>
                test the<br>
                                return value of<br>
                                insert, only tests one of the two insert<br>
                functions the<br>
                                patch<br>
                                introduces, and doesn't test positive<br>
        and negative<br>
                                cases of insert<br>
                                (pre-existing element and new insertion)<br>
<br>
                                Does this function have some/all<br>
        redundancy with<br>
                                existing interface?<br>
                                (should the other insert-like APIs be<br>
                refactored to<br>
                                call insert (&<br>
                                perhaps eventually removed in favor of<br>
        just using<br>
                                insert?))<br>
<br>
                                In the other code review you mention<br>
        StringMap<br>
                has an<br>
                                insert that<br>
                                returns bool? Yet you're not modifying<br>
        that<br>
                version<br>
                                here? What<br>
                                arguments does it take that make it<br>
        distinct<br>
                from the<br>
                                two functions<br>
                                you're adding?<br>
<br>
                                (though don't get me wrong, this seems<br>
        like a good<br>
                                change to make)<br>
<br>
<br>
                            I'm sorry David, that's not your decision<br>
        to make.<br>
                This is<br>
                            taking the<br>
                            private review idea way too far.<br>
<br>
                            The patch should be posted to llvm-commits for<br>
                public review.<br>
<br>
                        I'm not sure what you're referring to, but I guess<br>
                it's a Phab<br>
                        bug/mail delivery issue, because I replied to the<br>
                on-list mail<br>
                        with an<br>
                        on-list reply. This is a code review occurring on<br>
                llvm-commits.<br>
<br>
                        Perhaps it ended up in your spam filter?<br>
<br>
<br>
<br>
                    David, could you check your facts instead of<br>
        firing off<br>
                defensive<br>
                    one-liners?<br>
<br>
                    The revision is private and there is no public<br>
        record of<br>
                the patch<br>
                    at all:<br>
<br>
        <a href="http://lists.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20140616/thread.html" target="_blank">http://lists.cs.uiuc.edu/<u></u>pipermail/llvm-commits/Week-<u></u>of-Mon-20140616/thread.html</a><br>
<br>
                    Sneaking commits into SVN without inviting public<br>
        review, and<br>
                    blaming tools when it gets noticed is so last week.<br>
<br>
                    Alp.<br>
<br>
<br>
<br>
                        - David<br>
<br>
                            Alp.<br>
<br>
<br>
                                On Sun, Jun 15, 2014 at 6:17 PM,<br>
        Agustín Bergé<br>
                                <<a href="mailto:kaballo86@hotmail.com" target="_blank">kaballo86@hotmail.com</a><br>
        <mailto:<a href="mailto:kaballo86@hotmail.com" target="_blank">kaballo86@hotmail.com</a>><br>
                <mailto:<a href="mailto:kaballo86@hotmail.com" target="_blank">kaballo86@hotmail.com</a><br>
        <mailto:<a href="mailto:kaballo86@hotmail.com" target="_blank">kaballo86@hotmail.com</a>><u></u>> <mailto:<a href="mailto:kaballo86@hotmail.com" target="_blank">kaballo86@hotmail.com</a><br>
        <mailto:<a href="mailto:kaballo86@hotmail.com" target="_blank">kaballo86@hotmail.com</a>><br>
                <mailto:<a href="mailto:kaballo86@hotmail.com" target="_blank">kaballo86@hotmail.com</a><br>
        <mailto:<a href="mailto:kaballo86@hotmail.com" target="_blank">kaballo86@hotmail.com</a>><u></u>>>><br>
                                wrote:<br>
<br>
                                    Hi timurrrr, dblaikie, bkramer,<br>
<br>
                                    This patch adds to `StringMap`<br>
        overloads of<br>
                                    `insert` taking a<br>
                                    `std::pair<K, V>`, following the<br>
        standard<br>
                                    associative container interface.<br>
                                    This was suggested in<br>
        <a href="http://reviews.llvm.org/D4130" target="_blank">http://reviews.llvm.org/D4130</a><br>
<br>
        <a href="http://reviews.llvm.org/D4153" target="_blank">http://reviews.llvm.org/D4153</a><br>
<br>
                                    Files:<br>
                                        include/llvm/ADT/StringMap.h<br>
                                        unittests/ADT/StringMapTest.<u></u>cpp<br>
<br>
                                    Index: include/llvm/ADT/StringMap.h<br>
         ==============================<u></u>==============================<u></u>=======<br>
                                    --- include/llvm/ADT/StringMap.h<br>
                                    +++ include/llvm/ADT/StringMap.h<br>
                                    @@ -323,6 +323,51 @@<br>
                                           return true;<br>
                                         }<br>
<br>
                                    +  /// insert - Inserts the specified<br>
                key/value<br>
                                    pair into the map if the<br>
                                    key<br>
                                    +  /// isn't already in the map.<br>
        If the key is<br>
                                    already in the map, it<br>
                                    returns<br>
                                    +  // false and doesn't update the<br>
        value.<br>
                                    +  std::pair<iterator, bool><br>
        insert(const<br>
                                    std::pair<StringRef, ValueTy><br>
                                    &KV) {<br>
                                    +    unsigned BucketNo =<br>
                LookupBucketFor(KV.first);<br>
                                    +    StringMapEntryBase *&Bucket =<br>
                TheTable[BucketNo];<br>
                                    +    if (Bucket && Bucket !=<br>
                getTombstoneVal())<br>
                                    +      return<br>
                std::make_pair(iterator(&<u></u>Bucket, false),<br>
                                    +  false); //<br>
                Already<br>
                                    exists in map.<br>
                                    +<br>
                                    +    MapEntryTy *NewItem =<br>
                                    MapEntryTy::Create(KV.first,<br>
        Allocator,<br>
                                    KV.second);<br>
                                    +<br>
                                    +    if (Bucket == getTombstoneVal())<br>
                                    +      --NumTombstones;<br>
                                    +    Bucket = NewItem;<br>
                                    +    ++NumItems;<br>
                                    +    assert(NumItems +<br>
        NumTombstones <=<br>
                NumBuckets);<br>
                                    +<br>
                                    +    RehashTable();<br>
                                    +    return<br>
        std::make_pair(iterator(&<u></u>Bucket,<br>
                                    false), true);<br>
                                    +  }<br>
                                    +<br>
                                    +  /// insert - Inserts the specified<br>
                key/value<br>
                                    pair into the map if the<br>
                                    key<br>
                                    +  /// isn't already in the map.<br>
        If the key is<br>
                                    already in the map, it<br>
                                    returns<br>
                                    +  // false and doesn't update the<br>
        value.<br>
                                    +  std::pair<iterator, bool><br>
                                    insert(std::pair<StringRef,<br>
        ValueTy> &&KV) {<br>
                                    +    unsigned BucketNo =<br>
                LookupBucketFor(KV.first);<br>
                                    +    StringMapEntryBase *&Bucket =<br>
                TheTable[BucketNo];<br>
                                    +    if (Bucket && Bucket !=<br>
                getTombstoneVal())<br>
                                    +      return<br>
                std::make_pair(iterator(&<u></u>Bucket, false),<br>
                                    +  false); //<br>
                Already<br>
                                    exists in map.<br>
                                    +<br>
                                    +    MapEntryTy *NewItem =<br>
                                    +  MapEntryTy::Create(KV.first,<br>
                Allocator,<br>
                                    std::move(KV.second));<br>
                                    +<br>
                                    +    if (Bucket == getTombstoneVal())<br>
                                    +      --NumTombstones;<br>
                                    +    Bucket = NewItem;<br>
                                    +    ++NumItems;<br>
                                    +    assert(NumItems +<br>
        NumTombstones <=<br>
                NumBuckets);<br>
                                    +<br>
                                    +    RehashTable();<br>
                                    +    return<br>
        std::make_pair(iterator(&<u></u>Bucket,<br>
                                    false), true);<br>
                                    +  }<br>
                                    +<br>
                                         // clear - Empties out the<br>
        StringMap<br>
                                         void clear() {<br>
                                           if (empty()) return;<br>
                                    Index: unittests/ADT/StringMapTest.<u></u>cpp<br>
         ==============================<u></u>==============================<u></u>=======<br>
                                    --- unittests/ADT/StringMapTest.<u></u>cpp<br>
                                    +++ unittests/ADT/StringMapTest.<u></u>cpp<br>
                                    @@ -203,6 +203,13 @@<br>
                                         assertSingleItemMap();<br>
                                       }<br>
<br>
                                    +// Test insert(pair<K, V>) method<br>
                                    +TEST_F(StringMapTest,<br>
        InsertTestPair) {<br>
                                    +<br>
         testMap.insert(std::make_pair(<u></u>testKeyFirst,<br>
                                    testValue));<br>
                                    +  EXPECT_EQ(1u, testMap.size());<br>
                                    +  EXPECT_EQ(testValue,<br>
                testMap[testKeyFirst]);<br>
                                    +}<br>
                                    +<br>
                                       // Create a non-default<br>
        constructable value<br>
                                       struct StringMapTestStruct {<br>
                                         StringMapTestStruct(int i) :<br>
        i(i) {}<br>
<br>
                                       ______________________________<u></u>_________________<br>
                                llvm-commits mailing list<br>
        <a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.edu</a> <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a>><br>
        <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a><br>
        <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a>>><br>
                <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a><br>
        <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a>><br>
                <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a><br>
        <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a>>>><br>
        <a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" target="_blank">http://lists.cs.uiuc.edu/<u></u>mailman/listinfo/llvm-commits</a><br>
<br>
<br>
                            --<br>
        <a href="http://www.nuanti.com" target="_blank">http://www.nuanti.com</a><br>
                            the browser experts<br>
<br>
<br>
                    -- <a href="http://www.nuanti.com" target="_blank">http://www.nuanti.com</a><br>
                    the browser experts<br>
<br>
                    ______________________________<u></u>_________________<br>
                    llvm-commits mailing list<br>
        <a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.edu</a> <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a>><br>
        <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a><br>
        <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a>>><br>
                <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a><br>
        <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a>><br>
                <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a><br>
        <mailto:<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.<u></u>edu</a>>>><br>
        <a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" target="_blank">http://lists.cs.uiuc.edu/<u></u>mailman/listinfo/llvm-commits</a><br>
<br>
<br>
            -- <a href="http://www.nuanti.com" target="_blank">http://www.nuanti.com</a><br>
            the browser experts<br>
<br>
<br>
    --     <a href="http://www.nuanti.com" target="_blank">http://www.nuanti.com</a><br>
    the browser experts<br>
<br>
</blockquote>
<br>
-- <br>
<a href="http://www.nuanti.com" target="_blank">http://www.nuanti.com</a><br>
the browser experts<br>
<br>
</blockquote></div></div></div>
<br>_______________________________________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.edu</a><br>
</div></div><a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a><br>
<br></blockquote></div><br></div>
<br>_______________________________________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@cs.uiuc.edu" target="_blank">llvm-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a><br>
<br></blockquote></div></div></div><br></div></blockquote></div></div></div>