From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!.POSTED.blaine.gmane.org!not-for-mail From: Ergus Newsgroups: gmane.emacs.help Subject: Re: Is Elisp really that slow? Date: Thu, 16 May 2019 22:23:27 +0200 Message-ID: <20190516202327.5cgy2s4kppy3ahxa@Ergus> References: <20190514235412.kncazq45szlum2gr@Ergus> <83v9yb92c7.fsf@gnu.org> <878sv7sp3r.fsf@telefonica.net> <83r28z8zl9.fsf@gnu.org> <20190515210924.sijzy6mnpgzkt4gm@Ergus> <83ftpecwu1.fsf@gnu.org> <20190516161408.4dov3dwk5h4yoizn@Ergus> <838sv6cmwt.fsf@gnu.org> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii; format=flowed Injection-Info: blaine.gmane.org; posting-host="blaine.gmane.org:195.159.176.226"; logging-data="8591"; mail-complaints-to="usenet@blaine.gmane.org" User-Agent: NeoMutt/20180716 Cc: help-gnu-emacs@gnu.org To: Eli Zaretskii Original-X-From: help-gnu-emacs-bounces+geh-help-gnu-emacs=m.gmane.org@gnu.org Thu May 16 22:23:50 2019 Return-path: Envelope-to: geh-help-gnu-emacs@m.gmane.org Original-Received: from lists.gnu.org ([209.51.188.17]) by blaine.gmane.org with esmtps (TLS1.0:RSA_AES_256_CBC_SHA1:256) (Exim 4.89) (envelope-from ) id 1hRMur-00026u-OM for geh-help-gnu-emacs@m.gmane.org; Thu, 16 May 2019 22:23:50 +0200 Original-Received: from localhost ([127.0.0.1]:35546 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1hRMuq-0007OW-Lm for geh-help-gnu-emacs@m.gmane.org; Thu, 16 May 2019 16:23:48 -0400 Original-Received: from eggs.gnu.org ([209.51.188.92]:37044) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1hRMud-0007OL-8g for help-gnu-emacs@gnu.org; Thu, 16 May 2019 16:23:36 -0400 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1hRMub-0003fa-VV for help-gnu-emacs@gnu.org; Thu, 16 May 2019 16:23:35 -0400 Original-Received: from sonic313-14.consmr.mail.bf2.yahoo.com ([74.6.133.124]:35869) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1hRMub-0003fF-Lw for help-gnu-emacs@gnu.org; Thu, 16 May 2019 16:23:33 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=aol.com; s=a2048; t=1558038212; bh=jj+8P5sngjLJVLr9XNWsGNx/Z/X1MnoaaM+6scHdUCs=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From:Subject; b=E9IOrVzaUjEZRJhc8lsB+MM9RDqzdpx3Ad6pQwE8vXOSzMaN44m91WzaCiW0Fn+d4AlspePlbi1V4gkL2ULiLKotG6HUaohZgf3c9DhQAC3tykhMbh5VXq94SvaDsRWpqQIpCQUrEKtWHuO4xQYrv8pkZpjWrLw4CcMSBmPhAOUgBXtXYQobVUzdNH50Oy18fTY0BZsGoYG/l1CnKuBi4NdfZE04md+cpmi1pay7pHxLjzNfvu3x1w0u+2LckBUqRjTpIBXIt7Z7XBEWa3GPqAaB3O3qw5XhSsppH1ZgfR6Elh+ZW/Q7mQXUnAZNSE0Uwizz5f7o/Ku6/z3HdXhfqg== X-YMail-OSG: WCLIRPIVM1nAEfToIxVMm8mh6KMxaQy71XIlKFU.VssfLW09pyBPBMSZIR1Gli2 pO19iZ51geWdc1L9Fp0fDyyzdJQ.pJxdwZzMV7_lm4t8QYvv5Z06yfz2bA1UIxdbISLqqihcR_u. ULM_vqNYi.frJZiyc3qJ.7SUc_6I_x2HGbmrWK67CLpdVK.MOA8Sq77gzjDg57P3uny1dSo1xrMf ugMtKSOvucYcmif6v6KdeoyngwmWxoYYrEug3VWlGTI1l165uWqIGZcSfBg.aO5pY.LHaifAu3Qm PL7QNpVcj_b15ADSBF6Ysvqgjs4.OIIjmIgVTaEFQs5z3qqCq6PDCtH1ANHD4rayS7EdRbiFMq6F CVSbNleNFJjNsuDEYJ6O7oTfUr9uj3m7LnG1pl.0UzgkRMScv2DNFsqsTSNF5.NpRWlXTWK5qsYn YpEUBniqtfb7SNvwavX51RN_2svhck0pjtgThlPlfh4F96Sa8mOd8MyNRu4y7h8paLgRQYzbhHNZ 0n4WM79OdR0DjpJJ.k9uLfYPF6RBvxmNuKl_i7VDYKl1e71vRfERrQUJD6Q3umgC1THWaeYrzxKQ w6kXCUdo5TwdkU6zygVSuC51LmvbQtf2cy8rVlML7hBdSakYlc1xGGrXx7eBBIIStI.RvnopR.TX VvgxXvycTzxT8O171AAw3wJnCdh8M7kxhW2Jm3MHowgR5Q_aNqRwpWxGLJ8kw9P0q5Az2AnMqGdn .aInbcHbA5_Clrm_wU1SnEvBa5uj8BApJQTlA6kyXFyxQZft76NdUXTKhdTYgc52WZhbvhGGtjhg KMb6hjTfX9wnq84T0OmA8vRQmEG8NfKz342WhpsstE Original-Received: from sonic.gate.mail.ne1.yahoo.com by sonic313.consmr.mail.bf2.yahoo.com with HTTP; Thu, 16 May 2019 20:23:32 +0000 Original-Received: from 2.152.205.184.dyn.user.ono.com (EHLO Ergus) ([2.152.205.184]) by smtp408.mail.ir2.yahoo.com (Oath Hermes SMTP Server) with ESMTPA ID b31e67fae4b0beaea4e9686fb4152f1f; Thu, 16 May 2019 20:23:31 +0000 (UTC) Content-Disposition: inline In-Reply-To: <838sv6cmwt.fsf@gnu.org> X-Mailer: WebService/1.1.13634 hermes Apache-HttpAsyncClient/4.1.4 (Java/1.8.0_181) X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 74.6.133.124 X-BeenThere: help-gnu-emacs@gnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: Users list for the GNU Emacs text editor List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: help-gnu-emacs-bounces+geh-help-gnu-emacs=m.gmane.org@gnu.org Original-Sender: "help-gnu-emacs" Xref: news.gmane.org gmane.emacs.help:120446 Archived-At: Hi Eli: I agree a little bit too much here. But... > >Emacs is an old program, with users who stay with it for 25 and more >years. Changing old defaults or making other incompatible changes >definitely annoys at least some of those users, especially since quite >a few people don't track the development, and don't see the changes >until years later, sometimes even after skipping several releases >in-between. This isn't theory, this is our (and my personal) actual >experience from watching Emacs development. When someone comes up and >asks why we made a certain change in how Emacs worked for decades, we >should have a good reason, and if we don't, we shouldn't make the >change "just because we can". That's the price of maintaining and >developing an old and stable program. > My point of view since the beginning of my first email ever in the mailing list was based in 3 things: 1) Some design choices and limitations in the actual emacs were imposed due to technology 40 years ago. (keyboard bindings, coding system, screen resolutions, memory available and CPU, network latency, storage capacity) but most of them are not issues anymore (at least not in the emacs scales) so we are limiting the potential of emacs due to issues that disappeared long time ago. 2) Many new features and functionalities (pure editing oriented) have been introduced/proved/improved in other editors, and they have proven to be useful (move line, initial configuration, associative bindings, specific key combinations like in cua-mode, undo/redo and many others). An important part of those functionalities are can be implemented with Elisp in one afternoon probably because they are just details and some are already available as external packages, but the changes never arrive because there are not available (practical) keybindings or because of backward compatibility. 3) The development is not focused in the first thing that a user needs when she opens emacs: provide the most comfortable and useful TEXT EDITOR. If emacs as TEXT EDITOR does not convince them (just the first try, without config, without reading the manual/tutorial/documentation), then they will not even try any other functionality. I think that you are one of the few in this list who sees the importance if attracting new users/developers. Unlike vim; emacs is not in the gnu/linux distros, it is slower and bigger... so we need to offer some advantage on the first try over the others to keep the users. For example, many people use nano just because the basic actions are in a button bar, so they don't get stocked and they can do the basic stuff quick and fast, no installation no config needed. Look at the spacemacs community and how many members are there wrapping emacs functionalities to behave like in vim... >Personally, I wish people would invest much more time and efforts in >adding new features, and would stop futzing with existing features. >For starters, the former is much more useful for our users than the >latter. Also, I see many times how a change in existing code to make >some minor improvement introduces bugs, which sometimes are more >significant than the "fixed" problem -- this is expected in a complex >stable program, and is a clear sign that changes of existing code long >since entered the area which engineers call "the limit cycle" -- >oscillations that don't converge, i.e. the overall code quality is >quasi-constant. IOW, we are wasting our own resources for little or >no gain. > I would support that the functionalities go in elpa (I say elpa because it won't need an initial configuration to be used, just list-packages and install). Because there will be big chances that some other better alternatives substitute it (ido -> helm -> avy; isearch -> swiper, etags -> gtags, vc -> magit, ace -> avy) and looking tto the past... nothing will be removed never ever from the core emacs code. Also improve the modules API and support to create packages with C as with elisp. But add the less possible functionalities in the core if they are not directly editor related (basic ones) or general enough (infrastructure / API). > >> Just give a look how many good packages are in melpa, but not in elpa > >If you are saying that those packages are in MELPA because they were >rejected to be included in Emacs or ELPA, then I'd be very surprised >to learn that this is true. I think the vast majority of those >packages started up with MELPA and their developers never tried to >submit the packages to be included in Emacs. > No, I am saying that there is a reason why they made their work, and they maintain it, but they don't spend time to put it in the official repository.