From mboxrd@z Thu Jan 1 00:00:00 1970 Path: main.gmane.org!not-for-mail From: Simon Josefsson Newsgroups: gmane.emacs.devel Subject: Re: What's the problem? Date: Wed, 10 Dec 2003 07:34:45 +0100 Sender: emacs-devel-bounces+emacs-devel=quimby.gnus.org@gnu.org Message-ID: References: <4nllpt3hr3.fsf@lockgroove.bwh.harvard.edu> <5bad69zd43.fsf@lister.roxen.com> <4noeuon378.fsf@lockgroove.bwh.harvard.edu> <4ny8tsgxy6.fsf@lockgroove.bwh.harvard.edu> <4nhe0ggv0u.fsf@lockgroove.bwh.harvard.edu> <4nk75bwjaf.fsf@lockgroove.bwh.harvard.edu> <4nsmjv8d32.fsf@collins.bwh.harvard.edu> <87iskpbloe.fsf@mail.jurta.org> , emacs-devel@gnu.org Original-X-From: emacs-devel-bounces+emacs-devel=quimby.gnus.org@gnu.org Wed Dec 10 07:38:24 2003 Return-path: Original-Received: from quimby.gnus.org ([80.91.224.244]) by deer.gmane.org with esmtp (Exim 3.35 #1 (Debian)) id 1ATxzM-00089z-00 for ; Wed, 10 Dec 2003 07:38:24 +0100 Original-Received: from monty-python.gnu.org ([199.232.76.173]) by quimby.gnus.org with esmtp (Exim 3.35 #1 (Debian)) id 1ATxzM-0001dN-00 for ; Wed, 10 Dec 2003 07:38:24 +0100 Original-Received: from localhost ([127.0.0.1] helo=monty-python.gnu.org) by monty-python.gnu.org with esmtp (Exim 4.24) id 1ATyvC-0000fp-VF for emacs-devel@quimby.gnus.org; Wed, 10 Dec 2003 02:38:10 -0500 Original-Received: from list by monty-python.gnu.org with tmda-scanned (Exim 4.24) id 1ATyuu-0000co-Fm for emacs-devel@gnu.org; Wed, 10 Dec 2003 02:37:52 -0500 Original-Received: from mail by monty-python.gnu.org with spam-scanned (Exim 4.24) id 1ATyuO-0008GQ-75 for emacs-devel@gnu.org; Wed, 10 Dec 2003 02:37:51 -0500 Original-Received: from [217.13.230.178] (helo=yxa.extundo.com) by monty-python.gnu.org with esmtp (TLSv1:DES-CBC3-SHA:168) (Exim 4.24) id 1ATyti-0006p2-SX; Wed, 10 Dec 2003 02:36:39 -0500 Original-Received: from latte (yxa.extundo.com [217.13.230.178]) (authenticated bits=0) by yxa.extundo.com (8.12.10/8.12.10) with ESMTP id hBA6ZAAU001709 (version=TLSv1/SSLv3 cipher=RC4-SHA bits=128 verify=NO); Wed, 10 Dec 2003 07:35:10 +0100 Original-To: Miles Bader Mail-Copies-To: nobody X-Payment: hashcash 1.2 0:031210:miles@gnu.org:b2d9537e7cad9373 X-Hashcash: 0:031210:miles@gnu.org:b2d9537e7cad9373 X-Payment: hashcash 1.2 0:031210:juri@jurta.org:3cb2d309c23ccf3e X-Hashcash: 0:031210:juri@jurta.org:3cb2d309c23ccf3e X-Payment: hashcash 1.2 0:031210:emacs-devel@gnu.org:60fa178354360808 X-Hashcash: 0:031210:emacs-devel@gnu.org:60fa178354360808 In-Reply-To: (Miles Bader's message of "10 Dec 2003 14:51:08 +0900") User-Agent: Gnus/5.1003 (Gnus v5.10.3) Emacs/21.3.50 (gnu/linux) X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.1.2 Precedence: list List-Id: Emacs development discussions. List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-devel-bounces+emacs-devel=quimby.gnus.org@gnu.org Xref: main.gmane.org gmane.emacs.devel:18607 X-Report-Spam: http://spam.gmane.org/gmane.emacs.devel:18607 Miles Bader writes: > Simon Josefsson writes: >> > It depends on your environment of course -- if you have a slow network >> > connection (or a slow server), it can spend a _lot_ of time waiting for >> > external processes/data. >> >> Right, with emphasis on _can_. > > At least for me, this is an issue every single day; the CPU-bound parts > of summary generation &c are slightly annoying, but really not enough to > warrant any massive rewriting -- on the order of 30s or so for a large > newsgroup -- but IO-bound delays can be 10 _minutes_. I don't know what > it's like for other people. I'm using the Agent in recent Gnus, so almost all data is locally cached (except for flag updates via IMAP and new-mail checks in NNTP), so for me the delays I see are mostly CPU bound. >> > Anyway my main point is that I think it's basically an application >> > issue, though emacs might help by adding helper functions. >> >> I don't see how fixing my perceived problem can be done without some >> kind of threading support in Emacs (co-operative or whatever). Hence, >> helper functions would do more than just help, they are critical in >> improving the application. > > What I'm trying to say is that the `threading support' need not be > particularly good, or general-purpose. Probably something could be > hacked up right _now_, without any additional core functions, using > clever programming and emacs timers, by changing the worst-offending > part of the gnus code into something event driven. I don't understand. How would making the summary buffer generation asynchronous stop Emacs from locking up during computations? For me, the summary buffer generation is CPU bound in elisp, not IO bound. Same for getting new mail into the agent, it can take 2-3 minutes with only a fraction of the time spent in IO (yes, it is not optimized). I agree doing what you suggest would improve your problem, and making Gnus more asynchronous would be useful (patches welcome!), but I don't see how it is relevant to stopping the lockups when processing data. I think there are two separate problems here. They can and need to be solved individually.