From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.io!.POSTED.blaine.gmane.org!not-for-mail From: "Eric S. Raymond" <esr@thyrsus.com> Newsgroups: gmane.emacs.devel Subject: Insight into the mystery hangs Date: Sun, 11 Feb 2024 16:37:37 -0500 (EST) Message-ID: <20240211213737.3A38C18A1647@snark.thyrsus.com> Injection-Info: ciao.gmane.io; posting-host="blaine.gmane.org:116.202.254.214"; logging-data="17442"; mail-complaints-to="usenet@ciao.gmane.io" To: emacs-devel@gnu.org Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org Sun Feb 11 22:38:39 2024 Return-path: <emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org> Envelope-to: ged-emacs-devel@m.gmane-mx.org Original-Received: from lists.gnu.org ([209.51.188.17]) by ciao.gmane.io with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from <emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org>) id 1rZHX4-0004Jo-0N for ged-emacs-devel@m.gmane-mx.org; Sun, 11 Feb 2024 22:38:38 +0100 Original-Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from <emacs-devel-bounces@gnu.org>) id 1rZHWA-0000UT-Sp; Sun, 11 Feb 2024 16:37:42 -0500 Original-Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from <esr@thyrsus.com>) id 1rZHW9-0000UI-T3 for emacs-devel@gnu.org; Sun, 11 Feb 2024 16:37:41 -0500 Original-Received: from thyrsus.com ([71.162.243.5] helo=snark.thyrsus.com) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from <esr@thyrsus.com>) id 1rZHW6-0001Tc-Jy for emacs-devel@gnu.org; Sun, 11 Feb 2024 16:37:40 -0500 Original-Received: by snark.thyrsus.com (Postfix, from userid 1000) id 3A38C18A1647; Sun, 11 Feb 2024 16:37:37 -0500 (EST) Received-SPF: pass client-ip=71.162.243.5; envelope-from=esr@thyrsus.com; helo=snark.thyrsus.com X-Spam_score_int: -18 X-Spam_score: -1.9 X-Spam_bar: - X-Spam_report: (-1.9 / 5.0 requ) BAYES_00=-1.9, SPF_HELO_PASS=-0.001, SPF_PASS=-0.001, T_SCC_BODY_TEXT_LINE=-0.01 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: "Emacs development discussions." <emacs-devel.gnu.org> List-Unsubscribe: <https://lists.gnu.org/mailman/options/emacs-devel>, <mailto:emacs-devel-request@gnu.org?subject=unsubscribe> List-Archive: <https://lists.gnu.org/archive/html/emacs-devel> List-Post: <mailto:emacs-devel@gnu.org> List-Help: <mailto:emacs-devel-request@gnu.org?subject=help> List-Subscribe: <https://lists.gnu.org/mailman/listinfo/emacs-devel>, <mailto:emacs-devel-request@gnu.org?subject=subscribe> Errors-To: emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org Original-Sender: emacs-devel-bounces+ged-emacs-devel=m.gmane-mx.org@gnu.org Xref: news.gmane.io gmane.emacs.devel:316118 Archived-At: <http://permalink.gmane.org/gmane.emacs.devel/316118> I finally beat Emacs into giving me a debug trace from one of the mode-initialization hangs I described in previous email. I know what's going on with at least a subset of them now. At the top of the stack trace was a call-process to "src status -a". Turns out it was VC-mode doing this, trying to get the version-control status of the file being visited. Both hangs I've seen were files I keep under SRC control. For those of you unfamiliar, SRC is a little version-control system I wrote for single-file, single-developer projects - things like config files that you want to track modifications on without mingling the history with thst of other files, even other files in the same directory. It's directly supported in VC because I wrote that support. When I saw that trace, I thought SRC was hanging and I had a serious bug to trace. Turns out not - turns out src status was incautiously recursing through every single file in my WWW directory looking for a match to the path I was visiting. This was due to some recent cghanges I made to make SRC behave more naturally in trees of directories containing SRC-controlled files. I made a two-line change to SRC to stop it from recursing into directories that don't contain a .src, RCS, or SCCS directory (SRC can work with all three of those - in particular, if you use it on an RCS directory it behaves like RCS with a non-horrible UI). With this change, src status on even very large directories is fast, and the hang goes away. However. Emacs is not entirely off the hook here. When I'm not under deadline pressure I will file a bug with a title something like "With debug-on-quit enabled, Emacs does not reliably raise a debug trace on interrupt of call-process" There's some kind of timing or window issue here. You have to get lucky to get a debug trace - I didn't, previously, in dozens of tries. -- <a href="http://www.catb.org/~esr/">Eric S. Raymond</a> No matter how one approaches the figures, one is forced to the rather startling conclusion that the use of firearms in crime was very much less when there were no controls of any sort and when anyone, convicted criminal or lunatic, could buy any type of firearm without restriction. Half a century of strict controls on pistols has ended, perversely, with a far greater use of this weapon in crime than ever before. -- Colin Greenwood, in the study "Firearms Control", 1972