unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
From: Paul Eggert <eggert@cs.ucla.edu>
To: Eli Zaretskii <eliz@gnu.org>
Cc: emacs-devel@gnu.org
Subject: Re: A better autogen.sh
Date: Wed, 16 Mar 2011 13:40:13 -0700	[thread overview]
Message-ID: <4D81202D.30804@cs.ucla.edu> (raw)
In-Reply-To: <83y64eq4ji.fsf@gnu.org>

On 03/16/2011 11:54 AM, Eli Zaretskii wrote:
> Anyone who makes changes to the build process or any files
> that are related to the build process _must_ worry about lib/, because
> without understanding how it works and how it affects the rest of the
> code it is very easy to break something,

Yes, there are practical reasons why mainstream developers need to
worry about lib/ on occasion, just as they need to worry about their C
compiler, their 'make' implementation, etc.  But the overall goal of
lib/ is to make the current platform behave like a GNU platform, so
that the rest of Emacs can be written as if it were running in a GNU
environment.  Obviously lib/ not a perfect GNU emulation, but it does
help simplify the rest of Emacs.

> without knowing that there are wrappers for system headers
> there, it is impossible to understand how certain parts of Emacs code
> work on any given platform.

Yes, but that's fine.  If one wants to *understand* how the porting
works, one obviously must look into lib/; and if one wants to port to
a non-POSIXy platform, it'll be helpful to understand lib/, at least
to some extent, as that can provide useful info on how to port to a
non-POSIXy platform.

But if one merely wants to develop Emacs proper, one can ignore lib/
(most of the time, anyway), and write mainstream code for the GNU
platform, and have it "just work" on other Unix-like platforms.  The
MS-DOS and MS-Windows code should be similar: as much as possible it
should be invisible to mainstream developers, and mainstream code
should "just work".

A simple guideline to encourage this separation of concerns is: if a
file is needed only because of MS-DOS, it should be under msdos/; and
similarly for MS-Windows and nt/.  This needn't be an ironclad rule,
but it's a good guideline to follow when possible, so that mainstream
developers are not distracted by the porting code.

> "Separated" does not mean "segregated" or "ostracized".  People who
> happen to use and build the Windows port are responsible for
> non-trivial contributions to Emacs development that are certainly no
> less than yours... They don't deserve this kind of attitude, under
> which it is okay to make their life miserable and every other day
> break the port they use

This appears to be reading more into my email than what's there (as
well as exaggerate a bit :-).  In no way has my email suggested the
pejorative connotations of "segregrated" or "ostricized", nor have I
suggested that it's OK to make anybody's life "miserable".  Let's
focus on the technical problems rather than personalizing the
discussion.




  reply	other threads:[~2011-03-16 20:40 UTC|newest]

Thread overview: 113+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-01-20 18:47 Still unable to build trunk Chong Yidong
2011-01-20 19:39 ` Jan Djärv
2011-01-20 22:16   ` Chong Yidong
2011-01-21 20:42     ` Paul Eggert
2011-01-22  1:29       ` Chong Yidong
2011-01-22  7:25         ` Paul Eggert
2011-01-22 15:03           ` Eli Zaretskii
2011-01-23 15:33             ` Jim Meyering
2011-01-23 17:00               ` Eli Zaretskii
2011-01-23 17:35                 ` Jim Meyering
2011-01-23 18:14                   ` Eli Zaretskii
2011-01-23 18:47                     ` Jim Meyering
2011-01-23 19:06                       ` Eli Zaretskii
2011-01-23 20:08                         ` Jim Meyering
2011-01-23 21:23                 ` Paul Eggert
2011-01-24  1:01                   ` Stefan Monnier
2011-01-24  1:22                     ` Miles Bader
2011-01-24  8:48                     ` Glenn Morris
2011-01-24 16:26                       ` Stefan Monnier
2011-03-08  4:22                         ` A better autogen.sh [was Re: Still unable to build trunk] Glenn Morris
2011-03-08 19:51                           ` Stefan Monnier
2011-03-10 16:10                             ` Thien-Thi Nguyen
2011-03-15 20:22                             ` A better autogen.sh Glenn Morris
2011-03-15 21:52                               ` Paul Eggert
2011-03-15 22:09                                 ` Glenn Morris
2011-03-15 22:37                                   ` Glenn Morris
2011-03-15 22:58                                   ` Paul Eggert
2011-03-16  4:05                                     ` Eli Zaretskii
2011-03-16  4:14                                       ` Glenn Morris
2011-03-16  4:17                                         ` Glenn Morris
2011-03-16  5:53                                         ` Eli Zaretskii
2011-03-16  6:39                                           ` Paul Eggert
2011-03-16  8:10                                             ` Eli Zaretskii
2011-03-16  9:08                                               ` Paul Eggert
2011-03-16 10:12                                                 ` Eli Zaretskii
2011-03-16 10:47                                                   ` joakim
2011-03-16 11:53                                                     ` Eli Zaretskii
2011-03-16 12:25                                                       ` joakim
2011-03-16 12:42                                                         ` Eli Zaretskii
2011-03-16 17:52                                                   ` Paul Eggert
2011-03-16 18:54                                                     ` Eli Zaretskii
2011-03-16 20:40                                                       ` Paul Eggert [this message]
2011-03-16 11:33                                                 ` Juanma Barranquero
2011-03-16 11:21                                               ` Juanma Barranquero
2011-03-16  6:43                                           ` Glenn Morris
2011-03-16  8:47                                             ` Eli Zaretskii
2011-03-16  9:23                                               ` Paul Eggert
2011-03-16 10:37                                                 ` Eli Zaretskii
2011-03-16 17:17                                               ` Glenn Morris
2011-03-16 17:45                                                 ` Glenn Morris
2011-03-16 18:16                                                   ` Eli Zaretskii
2011-03-16 18:20                                                     ` Glenn Morris
2011-03-16 19:13                                                       ` Eli Zaretskii
2011-03-16 18:15                                                 ` Eli Zaretskii
2011-03-16 15:34                               ` Stefan Monnier
2011-03-16 18:09                                 ` Glenn Morris
2011-03-16 19:12                                   ` Eli Zaretskii
2011-03-16 19:40                                   ` Stefan Monnier
2011-03-16 20:56                                     ` Paul Eggert
2011-03-17 20:36                                       ` Glenn Morris
2011-03-17 20:40                                         ` Eli Zaretskii
2011-03-17 20:44                                           ` Glenn Morris
2011-03-17 20:51                                             ` Eli Zaretskii
2011-03-18  2:02                                         ` Paul Eggert
2011-03-16 18:10                                 ` Eli Zaretskii
2011-03-16 19:13                                   ` Eli Zaretskii
2011-03-28 20:29                           ` A better autogen.sh [was Re: Still unable to build trunk] chad
2011-03-28 20:58                             ` A better autogen.sh Glenn Morris
2011-03-28 21:45                               ` Chad Brown
2011-03-28 21:51                                 ` Glenn Morris
2011-03-29  1:17                               ` Stefan Monnier
2011-03-29  2:21                                 ` Glenn Morris
2011-03-29  3:36                                   ` Stefan Monnier
2011-03-29  6:39                                     ` Glenn Morris
2011-03-29 12:09                                       ` Jim Meyering
2011-03-29 12:19                                         ` Andreas Schwab
2011-03-29 12:23                                           ` Jim Meyering
2011-03-29 14:13                                             ` Stephen J. Turnbull
2011-03-29 15:25                                               ` Jim Meyering
2011-03-29 16:38                                                 ` Stephen J. Turnbull
2011-03-29 18:46                                             ` chad
2011-03-30  6:15                                               ` Jim Meyering
2011-03-30 11:27                                                 ` Eli Zaretskii
2011-03-30 12:03                                                   ` Jim Meyering
2011-03-30 17:48                                                     ` Eli Zaretskii
2011-03-30 19:26                                                       ` Jim Meyering
2011-03-30 20:02                                                         ` Eli Zaretskii
2011-03-30 20:14                                                           ` Glenn Morris
2011-03-30 21:36                                                             ` Stefan Monnier
2011-03-30 21:41                                                               ` Glenn Morris
2011-03-31 14:36                                                                 ` Stefan Monnier
2011-03-28 21:57                             ` A better autogen.sh [was Re: Still unable to build trunk] Eli Zaretskii
2011-01-24 18:14                   ` Still unable to build trunk Eli Zaretskii
2011-01-24 20:58                     ` Paul Eggert
2011-01-24 21:07                       ` Andreas Schwab
2011-01-24 22:47                       ` Glenn Morris
2011-01-25  6:01                         ` Richard Stallman
2011-01-25 19:58                           ` Eli Zaretskii
2011-01-25 20:14                             ` Savannah loggerhead [was Re: Still unable to build trunk] Glenn Morris
2011-01-26  0:44                             ` Still unable to build trunk Richard Stallman
2011-01-26  3:56                               ` Eli Zaretskii
2011-01-26 12:35                       ` Lennart Borgman
2011-01-26 13:18                         ` Eli Zaretskii
2011-01-26 13:35                         ` Andy Moreton
2011-01-26 13:42                         ` Jim Meyering
2011-01-27  9:38                           ` Jim Meyering
2011-01-27 11:16                             ` Eli Zaretskii
2011-01-27 11:20                               ` Lennart Borgman
2011-01-27 11:31                                 ` Eli Zaretskii
2011-01-27 18:27                                   ` Paul Eggert
2011-01-29 11:49                                     ` Darren Hoo
2011-01-29 12:19                                       ` Darren Hoo
2011-01-29 13:04                         ` Eli Zaretskii

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://www.gnu.org/software/emacs/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4D81202D.30804@cs.ucla.edu \
    --to=eggert@cs.ucla.edu \
    --cc=eliz@gnu.org \
    --cc=emacs-devel@gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).