From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from sender4-op-o12.zoho.com (sender4-op-o12.zoho.com [136.143.188.12]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id DA0901B983F for ; Sat, 21 Feb 2026 14:27:53 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=pass smtp.client-ip=136.143.188.12 ARC-Seal:i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1771684075; cv=pass; b=AUbd9DmpTKapMAuzJrTXXWyP2TtauRD7nap3lOqRruSvNQsTYW48bDKe2ioUbKsNWKSh34MGvupl+BspBI03yAyJwwoAnXgsLCbVqPrZ/dQyz65MvZSIvcv71NbSER/+cKdf+0jQTuN3sYnoSzkEaxXeAGYepCh5jdB1YCvuFgE= ARC-Message-Signature:i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1771684075; c=relaxed/simple; bh=9nbCBpGY0TnpSIR9Meo60EU9QKEMokN754Nq9JBFQGU=; h=From:To:Cc:Subject:In-Reply-To:References:Date:Message-ID: MIME-Version:Content-Type; b=fSFYNaDqsE7BDoVll9HRLGTMLvtE07UiTx1UkgNFHibEBVNC6EA8O+WojNXffbgn+ZRM7b3sHjPPCjdyUi9UZAHPLQt9lGmn/XfWPaxY2AD/EU+iNdbF5r7OO5wgFu+b5RseSWJlpqqc7rxy0f3hiE0EbnSAno8kTSoi1mDYzWo= ARC-Authentication-Results:i=2; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=collabora.com; spf=pass smtp.mailfrom=collabora.com; dkim=pass (1024-bit key) header.d=collabora.com header.i=adrian.ratiu@collabora.com header.b=PJAIf2+T; arc=pass smtp.client-ip=136.143.188.12 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=collabora.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=collabora.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=collabora.com header.i=adrian.ratiu@collabora.com header.b="PJAIf2+T" ARC-Seal: i=1; a=rsa-sha256; t=1771684052; cv=none; d=zohomail.com; s=zohoarc; b=Oh1ke8PhyXsvv1YnOu1ma/TWSQxlxslDzM0z+l3imthCy2ZAdRL9RLcNilGXX0VXye5I5YcmwczsmonLLEGk7ut8xV/0bkbt2u7mPdBXTKjvH0BC3cT54yJZFQ3LJlv0eHCf1FMjufPdWZy1S2Ch9uF58aFwz4J+JvUqqIxnORY= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1771684052; h=Content-Type:Cc:Cc:Date:Date:From:From:In-Reply-To:MIME-Version:Message-ID:References:Subject:Subject:To:To:Message-Id:Reply-To; bh=KS1j1JPsLgr+500mX6KH7jaCY6Q0cZ4VRW//c9D7W/c=; b=jylr5awUurk0CB57B1uUyJE1bpYEK3azqrevnXGEdTJpKO0Rw3jgFyiv9Lyl/fv2XFOC4P1Fal6wU8At+5fzU7/9T37E63QFvdqDGz/1eTL32v+8bH37zZHtsnHrOF2bjLLjIZ5AG3aQIi/jgUO0hebjnVVrdUIEKMxQ+kaBVe4= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass header.i=collabora.com; spf=pass smtp.mailfrom=adrian.ratiu@collabora.com; dmarc=pass header.from= DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; t=1771684052; s=zohomail; d=collabora.com; i=adrian.ratiu@collabora.com; h=From:From:To:To:Cc:Cc:Subject:Subject:In-Reply-To:References:Date:Date:Message-ID:MIME-Version:Content-Type:Message-Id:Reply-To; bh=KS1j1JPsLgr+500mX6KH7jaCY6Q0cZ4VRW//c9D7W/c=; b=PJAIf2+Tg+sj1fpBooVpiMcK6KsP/aA3jKfD1WQTEcGTLRqHjpjLU+Jc0JvkJO9P /DcpmOETCSCuOMgxQF3OqGriQ7/sGLMKTEmmcAii4h0IKzAFlcbEfLrno1vVZDPDrkR 1BKNJfrRenuApY5CMQORmwC0ik6KJJvocBdwIi/o= Received: by mx.zohomail.com with SMTPS id 1771684050826792.8788522684885; Sat, 21 Feb 2026 06:27:30 -0800 (PST) From: Adrian Ratiu To: "brian m. carlson" Cc: git@vger.kernel.org, Jeff King , Emily Shaffer , Junio C Hamano , Patrick Steinhardt , Josh Steadmon , Kristoffer Haugsbakk Subject: Re: [PATCH v2 0/8] Specify hooks via configs In-Reply-To: References: <20260204165126.1548805-1-adrian.ratiu@collabora.com> <20260218222352.55393-1-adrian.ratiu@collabora.com> Date: Sat, 21 Feb 2026 16:27:26 +0200 Message-ID: <87o6liw4s1.fsf@collabora.com> Precedence: bulk X-Mailing-List: git@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain X-ZohoMailClient: External On Fri, 20 Feb 2026, "brian m. carlson" wrote: > On 2026-02-18 at 22:23:44, Adrian Ratiu wrote: >> Hello everyone, >> >> v2 addresses all feedback received in v1. >> >> This series adds a new feature: the ability to specify commands to run >> for hook events via config entries (including shell commands). >> >> So instead of dropping a shell script or a custom program in .git/hooks >> you can now tell git via config files to run a program or shell script >> (can be specified directly in the config) when you run hook "foo". >> >> This also means you can setup global hooks to run in multiple repos via >> global configs and there's an option to disable them if necessary. >> >> For simplicity, because this series is becoming rather big, hooks are >> still executed sequentially (.jobs == 1). Parallel execution is added >> in another patch series. > > I'm interested in how you plan to make parallel execution work > gracefully. > > We've already established that it's necessary to preserve stdout and > stderr (including wiring them up to the TTY) so as to not break > existing, widely deployed hooks, such as those in Git LFS. That means > that to get parallel execution where the hooks don't write over each > other's output and fight for the terminal, you'd need to multiplex each > one, including providing a PTY if the appropriate descriptor already has > a terminal, such that the output is at the very least handled line by > line and ideally batched into per-hook chunks. Is that the plan, or do > you plan to do it differently? > > I ask because situations where the hook output is not handled gracefully > and hooks fight over output or where the existence of TTY on a file > descriptor is not preserved will result in bug reports and broken tests > for tools that use Git, which I think we'd all like to avoid. Hi Brian, Yes, this is all done already. Phillip Wood actually brought this TTY issue up in his review of the v1 parallel hooks series (many thanks). :) > Of course, that's not in this series, so it may not even be written yet, > but if it's not, then this is something to keep in mind for when it gets > submitted. Yes, that's a separate series [1] and I'm about to send v2 very soon. Please review v2 directly when I send it because it will contain significant changes from v1. v1 is not worth reviewing at this point. To give you a high level description: All hooks continue to run sequentially (serialized) by default, just like before. To run some of the hooks in parallel, I had to introduce an extension, because we need to break backwards compatibility by combining stdout and stderr and piping them through run-command's muxer, detached from the terminal. There is only 1 known hook requiring this extension (pre-push) but it's trivial to add more, if necessary. Patrick's idea is to leave it up to the user to decide what to parallelize, because the user knows if their hooks are safe or not (eg if they write the same file or call the same program), or if it's ok the enable the extension or not. Some hooks are known never to be safe to parallelize, in that case git will always enforce serial execution. Please wait for v2 of that series, it's my top priority to get it out, Adrian 1: https://lore.kernel.org/git/20260204173328.1601807-1-adrian.ratiu@collabora.com/n