home *** CD-ROM | disk | FTP | other *** search
/ NetNews Usenet Archive 1993 #3 / NN_1993_3.iso / spool / fj / maillis / xwindow / 19714 < prev    next >
Encoding:
Internet Message Format  |  1993-01-23  |  11.4 KB

  1. Path: sparky!uunet!stanford.edu!sun-barr!sh.wide!wnoc-tyo-news!scslwide!wsgw!wsservra!daemon
  2. From: jwz@lucid.com (Jamie Zawinski)
  3. Newsgroups: fj.mail-lists.x-window
  4. Subject: Lucid Emacs 19.4 released
  5. Message-ID: <1993Jan23.024001.804@sm.sony.co.jp>
  6. Date: 23 Jan 93 02:40:01 GMT
  7. Sender: daemon@sm.sony.co.jp (The devil himself)
  8. Distribution: fj
  9. Organization: Lucid, Inc., Menlo Park, CA
  10. Lines: 245
  11. Approved: michael@sm.sony.co.jp
  12.  
  13. Date: Fri, 22 Jan 93 11:01:26 -0500
  14. Message-Id: <9301221601.AA24865@expo.lcs.mit.edu>
  15.  
  16. Lucid GNU Emacs 19.4 is now available.  This is a version of GNU Emacs derived
  17. from an early version of Emacs version 19 from the Free Software Foundation.
  18.  
  19. (If you are already a user of version 19.3, you might want to skip ahead to
  20. the section labeled "Differences Between 19.3 and 19.4".)
  21.  
  22. You can get it via anonymous FTP from labrea.Stanford.EDU (36.8.0.112).  It
  23. is currently available only by FTP.  We don't have the manpower to make tapes
  24. right now.
  25.  
  26. Log in with the user "anonymous" and "username@host" as a password (that is,
  27. your email address.)  Execute the command "cd pub/gnu/lucid/".  These are
  28. the files you will find there:
  29.  
  30.   lemacs-19.4.tar.Z
  31.     The complete source distribution.  This file is about 9 megabytes.
  32.     When untarred and uncompressed, the source distribution will take up
  33.     about 22 megs. You will need an additional 12 megs or so to compile it.
  34.  
  35.   lemacs-19.4-sun4.tar.Z
  36.     This is a ready-to-run set of Sun4 executables, and a DOC file.  If
  37.     you want to use these executables, you will still need to get the file
  38.     lemacs-19.4.tar.Z, because Emacs cannot function very well without the
  39.     lisp library online.  This file is about 2.5 megs, 4.9 megs when
  40.     unpacked, 3.6 megs of which is the Emacs executable itself (2.5 megs if
  41.     stripped.)  This version of lemacs is compiled with support for Motif
  42.     dialog boxes and XPM files.
  43.  
  44.   xpm-3.2a.tar.Z
  45.     The XPM library (optional.)
  46.  
  47. Don't forget to set "binary" mode when transferring these files.  Unpack them
  48. with some variation of the command "zcat lemacs-19.4.tar.Z | tar -vxf -".
  49.  
  50. We have created two mailing lists for discussing our Emacs.
  51.  
  52.    bug-lucid-emacs@lucid.com    For reporting all bugs in Lucid GNU Emacs,
  53.                 including bugs in the compilation and
  54.                 installation procedures.
  55.  
  56.    help-lucid-emacs@lucid.com    For random questions and conversation
  57.                 about using Lucid GNU Emacs.
  58.  
  59. To be added or removed from these mailing lists, send mail to 
  60. bug-lucid-emacs-request@lucid.com or help-lucid-emacs-request@lucid.com.
  61.  
  62. The bug-lucid-emacs and help-lucid-emacs mailing lists are archived on labrea,
  63. and are bidirectionally gatewayed into the newsgroups alt.lucid-emacs.bug and
  64. alt.lucid-emacs.help.
  65.  
  66. The bug-lucid-emacs and help-lucid-emacs mailing lists are archived on labrea.
  67.  
  68. Please do not send messages about problems with Lucid GNU Emacs to the FSF
  69. GNU Emacs newsgroups and mailing lists (help-gnu-emacs@prep.ai.mit.edu,
  70. bug-gnu-emacs@prep.ai.mit.edu, gnu.emacs.help, gnu.emacs.bug, et cetera)
  71. unless you are sure that the problem you are reporting is a problem with
  72. both versions of GNU Emacs.  People who aren't subscribed to the Lucid GNU
  73. Emacs mailing lists most likely are not interested in hearing about problems
  74. with it.
  75.  
  76.  
  77. Why Another Version of Emacs?
  78. =============================
  79.  
  80. Lucid's latest product, Energize, is a C/C++ development environment.  Rather
  81. than invent (and force our users to learn) a new user-interface, we chose to
  82. build part of our environment on top of the world's best editor, GNU Emacs.
  83. (Though our product is commercial, the work we did on GNU Emacs is free
  84. software, and is useful without having to purchase our product.)
  85.  
  86. We needed a version of Emacs with mouse-sensitive regions, multiple fonts,
  87. the ability to mark sections of a buffer as read-only, the ability to detect
  88. which parts of a buffer has been modified, and many other features.
  89.  
  90. Why Not Epoch?
  91. ==============
  92.  
  93. For our purposes, the existing version of Epoch was not sufficient; it did
  94. not allow us to put arbitrary pixmaps/icons in buffers, `undo' did not
  95. restore changes to regions, regions did not overlap and merge their
  96. attributes in the way we needed, and several other things.
  97.  
  98. We could have devoted our time to making Epoch do what we needed (and, in
  99. fact, we spent some time doing that) but, since the FSF planned to include
  100. Epoch-like features in their version 19, we decided that our efforts would 
  101. be better spent improving Emacs19 instead of Epoch.  
  102.  
  103. Our original hope was that our changes to Emacs would be incorporated into
  104. the "official" v19.  However, scheduling conflicts arose, and we found that,
  105. given the amount of work still remaining to be done, we didn't have time to
  106. merge with the FSF's code.  Consequently, we have released our work as a
  107. forked branch of Emacs, instead of delaying any longer.
  108.  
  109. Work has begun on a merger of Epoch and Lucid Emacs.  It seems likely that 
  110. the next release of Epoch will be based on Lucid Emacs instead of GNU Emacs
  111. from the FSF.  At some point, Lucid Emacs and Epoch will probably be the 
  112. same thing.
  113.  
  114. No Warranty
  115. ===========
  116.  
  117. Lucid Emacs is distributed under exactly the same terms as GNU Emacs, and
  118. thus has no warranty of any kind.
  119.  
  120. However, if you have received this version of Emacs with Energize, then it is
  121. covered by your Energize support contract.  If you have received it through
  122. some other means, then you may buy a support contract for it from Lucid.
  123. Send mail to lucid-info@lucid.com for more information about Lucid Emacs or
  124. Energize.
  125.  
  126. What's Different?
  127. =================
  128.  
  129. Lucid Emacs *currently* requires X Windows to run, though it will not be much
  130. work to make it run on dumb ttys again.  We plan to do this eventually.
  131.  
  132. We have not personally tried to compile this version of Emacs under anything
  133. but SunOS 4.1 on SparcStations, though others have successfully done so.  We
  134. are very eager to get feedback about portability problems from those who
  135. compile it on other systems.
  136.  
  137. We have reimplemented the basic input model in a more general way; instead of
  138. X input being a special-case of the normal ASCII input stream, Emacs has a
  139. concept of "input events", and ASCII characters are a subset of that.  The
  140. events that Emacs knows about are not X events, but are a generalization of
  141. them, so that Emacs can eventually be ported to different window systems.
  142.  
  143. We have reimplemented keymaps so that sequences of events can be stored into
  144. them instead of just ASCII codes; it is possible to, for example, bind 
  145. different commands to each of the chords Control-h, Control-H, Backspace,
  146. Control-Backspace, and Super-Shift-Backspace.  Key bindings, function key
  147. bindings, and mouse bindings live in the same keymaps.
  148.  
  149. Input and display of all ISO-8859-1 characters is supported.
  150.  
  151. You can have multiple X Windows ("screens" in Emacs terminology).
  152.  
  153. Our Emacs has objects called "extents" and "faces", which are roughly
  154. analogous to Epoch's "buttons," "zones," and "styles."  An extent is a region
  155. of text (a start position and an end position) and a face is a collection of
  156. textual attributes like fonts and colors.  Every extent is displayed in some
  157. "face", so changing the properties of a face immediately updates the display 
  158. of all associated extents.  Faces can be screen-local: you can have a region
  159. of text which displays with completely different attributes when its buffer
  160. is viewed from a different X window.
  161.  
  162. The display attributes of faces may be specified either in lisp or through
  163. the X resource manager.
  164.  
  165. Emacs use the MIT "Xt" toolkit instead of raw Xlib calls, which makes it be
  166. a more well-behaved X citizen (and also improves portability).  A result of
  167. this is that it is possible to include other Xt "Widgets" in the Emacs
  168. window.  Also, Emacs understands the standard Xt command-line arguments.
  169.  
  170. Emacs understands the X11 "Selection" mechanism; it's possible to define
  171. and customize selection converter functions and new selection types from 
  172. elisp, without having to recompile Emacs.
  173.  
  174. Emacs now supports the Zmacs/Lispm style of region highlighting, where the
  175. region between the point and mark is highlighted when in its "active" state.
  176.  
  177. Emacs has a menubar, whose contents are customizable from emacs-lisp.
  178. This menubar looks Motif-ish, but does not require Motif.  If you already
  179. own Motif, however, you can configure Emacs to use a *real* Motif menubar
  180. instead.  If you have OLIT ("OpenLook Intrinsics"), you can use an
  181. OpenWindows-like menubar.
  182.  
  183. Emacs can ask questions using popup dialog boxes.  Any command executed from
  184. a menu will ask yes/no questions with dialog boxes, while commands executed
  185. via the keyboard will use the minibuffer.
  186.  
  187. The initial load-path is computed at run-time, instead of at compile-time.
  188. This means that if you move the Emacs executable and associated directories
  189. to somewhere else, you don't have to recompile anything.
  190.  
  191. Emacs now supports floating-point numbers.
  192.  
  193. Emacs now knows about timers directly, instead of them being simulated by
  194. a subprocess.
  195.  
  196. Emacs understands truenames, and can be configured to notice when you are
  197. visiting two names of the same file.
  198.  
  199. If you're running on a sun SparcStation, you can specify sound files for
  200. Emacs to play instead of the default X beep.
  201.  
  202. Much more detail about the differences between Lucid Emacs and Emacs 18 can
  203. be found in the file .../etc/NEWS (accessible with ``C-h n''.)
  204.  
  205. Note that building Lucid Emacs requires an ANSI C compiler, like gcc, or
  206. Lucid's own (and the galaxy's best) Lucid C/C++.
  207.  
  208.  
  209. Major Differences Between 19.3 and 19.4
  210. =======================================
  211.  
  212. Prototypes have been added for all functions.  Emacs compiles in the strict
  213. ANSI modes of lcc and gcc, so portability should be vastly improved.
  214.  
  215. Many many many many core leaks have been plugged, especially in screen 
  216. creation and deletion.
  217.  
  218. The float support reworked to be more portable and ANSI conformant.  This
  219. resulted in these new configuration parameters: HAVE_INVERSE_HYPERBOLIC, 
  220. HAVE_CBRT, HAVE_RINT, FLOAT_CHECK_ERRNO, FLOAT_CATCH_SIGILL, 
  221. FLOAT_CHECK_DOMAIN.  Let us know if you had to change the defaults on your
  222. architecture.
  223.  
  224. The SunOS unexec has been rewritten, and now works with either static or 
  225. dynamic libraries, depending on whether -Bstatic or -Bdynamic were specified
  226. at link-time.
  227.  
  228. Small (character-sized) bitmaps can be mixed in with buffer text via the new
  229. functions set-extent-begin-glyph and set-extent-end-glyph.  (This is actually
  230. a piece of functionality that Energize has been using for a while, but we've
  231. just gotten around to making it possible to use it without Energize.  See how
  232. nice we are?  Go buy our product.)
  233.  
  234. If compiled with Motif support, one can pop up dialog boxes from emacs lisp.
  235. We encourage someone to contribute Athena an version of this code; it
  236. shouldn't be much work.  
  237.  
  238. If dialog boxes are available, then y-or-n-p and yes-or-no-p use dialog boxes
  239. instead of the minibuffer if invoked as a result of a command that was 
  240. executed from a menu instead of from the keyboard.
  241.  
  242. Multiple screen support works better; check out doc of get-screen-for-buffer.
  243.  
  244. The default binding of backspace is the same as delete.  (C-h is still help.)
  245.  
  246. A middle click while the minibuffer is active does completion if you click on 
  247. a highlighted completion, otherwise it executes the global binding of button2.
  248.  
  249. New versions of Barry Warsaw's c++-mode and syntax.c.  Font-lock-mode works
  250. with C++ mode now.
  251.  
  252. The semantics of activate-menubar-hook has changed; the functions are called
  253. with no arguments now.
  254.  
  255. `truename' no longer hacks the automounter; use directory-abbrev-alist instead.
  256.  
  257. Most minibuffer handling has been reimplemented in emacs-lisp.
  258.