From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on dcvr.yhbt.net X-Spam-Level: X-Spam-ASN: AS31976 209.132.180.0/23 X-Spam-Status: No, score=-3.7 required=3.0 tests=AWL,BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,RCVD_IN_DNSWL_HI shortcircuit=no autolearn=ham autolearn_force=no version=3.4.2 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by dcvr.yhbt.net (Postfix) with ESMTP id A81811F453 for ; Fri, 25 Jan 2019 12:37:56 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727826AbfAYMhz (ORCPT ); Fri, 25 Jan 2019 07:37:55 -0500 Received: from mail-wm1-f68.google.com ([209.85.128.68]:51429 "EHLO mail-wm1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726141AbfAYMhz (ORCPT ); Fri, 25 Jan 2019 07:37:55 -0500 Received: by mail-wm1-f68.google.com with SMTP id b11so6640987wmj.1 for ; Fri, 25 Jan 2019 04:37:52 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-transfer-encoding:content-language; bh=PozoKlOshI/63pxBSxSx3BYcNVcymfYzqX2tyI7mw6E=; b=a2CnjuRSK67FBZgWIdfOHpTTzPdnUWlV0+LC6Eb5+ToyatpE0mIXBjLoMRyYLJml87 0yLhzZd0CN++XVh0fTiZSg5Edl+51O6QfSds7HdZelwS2fUHsilODVrEnEmuLYZncohz zt701W7tXnay54+7IlYiyljiFVIwRp0ujBWST/kyOK2jzwpMSUgqGMSdd0DlI/yNgL2B TnNdFd8M2KKXCSpQ6Se9aw4ahT5M/3wuaecAJFEOcDFUYDNuVKU4e2ONXSNffDXo085x k2v4rz3oafSQUObxWw31ScER4qb5/LJFWzd4+5DY/utl+30/fNU+Rrunbbmn+0EaVGAc noNQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding :content-language; bh=PozoKlOshI/63pxBSxSx3BYcNVcymfYzqX2tyI7mw6E=; b=Igf71jLv6Y0NHhEFyaj7C2X7rGwE9semoHu4IxszeAwcV/9CjfIO539mmqqk1uCSV5 /nGHV2jQUgd/JyOChrjxD2XXJVwz2PTUWuoI6lrSaNR7Azq+AGGreeV9t+a5lpD6dzez G+/PbjttQXjhvhW/GWkFaHoXHE7dLkX+m2dKTVTHiJjF2BHnOPncMR9DVubfijIbvtfe nZFWkDCQdiKksgOrk6m3kp3kQDHPek5CSRV1k+Chb5XufslryUQrLtYm8NZ8UBN826YV lUrh4I1Qy7c6i6lHIjRS7+G//pE1VmVt8M547n6FBSaee1EJ0HmZq64syZ8egLW8Bwvy fKVQ== X-Gm-Message-State: AJcUukc4H73+5RctMQR1rrr12gBF3xLGLj/fyNP13U2OZ+0lcSAXg4xV 1WsRuDp9NeImh1qt1Js7hNomZ3ve X-Google-Smtp-Source: ALg8bN5hIvO4SNsSo62c1vAusqIwulPN5o1Q7s1uCQJyiLi5VnIpqFLvnUd3XjTkk+edfzZrVW2QJA== X-Received: by 2002:a1c:7719:: with SMTP id t25mr7178194wmi.7.1548419872013; Fri, 25 Jan 2019 04:37:52 -0800 (PST) Received: from [192.168.1.8] ([31.223.156.16]) by smtp.gmail.com with ESMTPSA id 143sm136184706wml.14.2019.01.25.04.37.50 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 25 Jan 2019 04:37:51 -0800 (PST) Subject: Re: [PATCH v4 0/7] Turn git add-i into built-in To: =?UTF-8?Q?Slavica_=c4=90uki=c4=87_via_GitGitGadget?= , git@vger.kernel.org Cc: phillip.wood@dunelm.org.uk References: From: Slavica Djukic Message-ID: Date: Fri, 25 Jan 2019 13:37:42 +0100 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.4.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Sender: git-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: git@vger.kernel.org Hi Phillip, Sorry for omitting you in Cc, again. I accidentally wrote yours and Ævar's email prefixed with Cc:, rather then separating them with comma, like Johannes said I should. -Slavica On 25-Jan-19 1:23 PM, Slavica Đukić via GitGitGadget wrote: > This is the first version of a patch series to start porting > git-add--interactive from Perl to C. Daniel Ferreira's patch series used as > a head start: > https://public-inbox.org/git/1494907234-28903-1-git-send-email-bnmvco@gmail.com/t/#u > > Changes since v3: > > * add error check when calling add--helper's functions from > git-add--interactive.perl > * replace trailing whitespace in the test with variable $SP used in earlier > tests > > Cc: Phillip Wood phillip.wood@dunelm.org.uk [phillip.wood@dunelm.org.uk] > > Daniel Ferreira (4): > diff: export diffstat interface > add--helper: create builtin helper for interactive add > add-interactive.c: implement status command > add--interactive.perl: use add--helper --status for status_cmd > > Slavica Djukic (3): > add-interactive.c: implement show-help command > t3701-add-interactive: test add_i_show_help() > add--interactive.perl: use add--helper --show-help for help_cmd > > .gitignore | 1 + > Makefile | 2 + > add-interactive.c | 263 +++++++++++++++++++++++++++++++++++++ > add-interactive.h | 10 ++ > builtin.h | 1 + > builtin/add--helper.c | 43 ++++++ > diff.c | 36 ++--- > diff.h | 18 +++ > git-add--interactive.perl | 17 +-- > git.c | 1 + > t/t3701-add-interactive.sh | 24 ++++ > 11 files changed, 381 insertions(+), 35 deletions(-) > create mode 100644 add-interactive.c > create mode 100644 add-interactive.h > create mode 100644 builtin/add--helper.c > > > base-commit: b21ebb671bb7dea8d342225f0d66c41f4e54d5ca > Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-103%2FslavicaDj%2Fadd-i-v4 > Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-103/slavicaDj/add-i-v4 > Pull-Request: https://github.com/gitgitgadget/git/pull/103 > > Range-diff vs v3: > > 1: 737767b6f4 = 1: 737767b6f4 diff: export diffstat interface > 2: 91b1963125 = 2: 91b1963125 add--helper: create builtin helper for interactive add > 3: d247ef69fe = 3: d247ef69fe add-interactive.c: implement status command > 4: 4950c889aa ! 4: fb3f9378ac add--interactive.perl: use add--helper --status for status_cmd > @@ -2,12 +2,21 @@ > > add--interactive.perl: use add--helper --status for status_cmd > > - Call the newly introduced add--helper builtin on > + Call the newly introduced add--helper builtin in > status_cmd() instead of relying on add--interactive's Perl > - functions to build print the numstat. > + functions to print the numstat. > + > + If an error occurs, it will be reported, but the Perl script will > + not exit, since the add--helper is called within an eval block. > + > + As the Perl script will go away soon, so will this scenario, where > + the built-in helper is called from the Perl script. Combined with > + the fact that it would be hard to test, we'll pass on adding > + a regression test for this. > > Signed-off-by: Daniel Ferreira > Signed-off-by: Slavica Djukic > + Signed-off-by: Ævar Arnfjörð Bjarmason > > diff --git a/git-add--interactive.perl b/git-add--interactive.perl > --- a/git-add--interactive.perl > @@ -19,7 +28,8 @@ > - list_and_choose({ LIST_ONLY => 1, HEADER => $status_head }, > - list_modified()); > - print "\n"; > -+ system(qw(git add--helper --status)); > ++ my @status_cmd = ("git", "add--helper", "--status"); > ++ !system(@status_cmd) or die "@status_cmd exited with code $?"; > } > > sub say_n_paths { > 5: 581b108c9c = 5: ab16afd1d5 add-interactive.c: implement show-help command > 6: aede733318 ! 6: 0a27304a84 t3701-add-interactive: test add_i_show_help() > @@ -7,6 +7,7 @@ > Also, add it before changing git-add--interactive.perl's help_cmd > to demonstrate that there are no changes introduced by the > conversion to C. > + > Prefix git add -i call with GIT_PAGER_IN_USE=true TERM=vt100 > to force colored output on Windows. > > @@ -21,7 +22,7 @@ > > +test_expect_success 'show help from add--helper' ' > + git reset --hard && > -+ cat >expect <<-\EOF && > ++ cat >expect <<-EOF && > + > + *** Commands *** > + 1: status 2: update 3: revert 4: add untracked > @@ -35,7 +36,7 @@ > + *** Commands *** > + 1: status 2: update 3: revert 4: add untracked > + 5: patch 6: diff 7: quit 8: help > -+ What now> > ++ What now>$SP > + Bye. > + EOF > + test_write_lines h | GIT_PAGER_IN_USE=true TERM=vt100 git add -i >actual.colored && > 7: b9a1a7e37a ! 7: ca2a7c4375 add--interactive.perl: use add--helper --show-help for help_cmd > @@ -5,7 +5,15 @@ > Change help_cmd sub in git-add--interactive.perl to use > show-help command from builtin add--helper. > > + If an error occurs, it will be reported, but the Perl script will > + not exit, since the add--helper is called within an eval block. > + > + Just like the change where the Perl script calls the add--helper > + to print the numstat, also here we forgo adding a regression test: > + the Perl script is on its way out (and this patch is part of that journey). > + > Signed-off-by: Slavica Djukic > + Signed-off-by: Ævar Arnfjörð Bjarmason > > diff --git a/git-add--interactive.perl b/git-add--interactive.perl > --- a/git-add--interactive.perl > @@ -24,7 +32,8 @@ > -diff - view diff between HEAD and index > -add untracked - add contents of untracked files to the staged set of changes > -EOF > -+ system(qw(git add--helper --show-help)); > ++ my @help_cmd = ("git", "add--helper", "--show-help"); > ++ !system(@help_cmd) or die "@help_cmd exited with code $?"; > } > > sub process_args { >