Emacs
Definition
Note: Copy/Paste from http://tecfa.unige.ch/guides/emacs/pointers.html (will clean this up sometimes soon I hope - Daniel K. Schneider 19:50, 2 November 2007 (MET)
Emacs is a text editor, and much more. XEmacs provides a comprehensive environment where you can edit source code, or multiple text files, read mail or news, and even edit files remotely using FTP.
There exist many variants: The most popular one is Gnu Emaces (the almost original)
Warning: Emacs is very powerful, but since it was born before Windows (or even MS-DOS), shortcuts are not the same. Also it is geared towards speed. The typical emacs user doesn't not want time-consuming pop dialogs, but you dialog though a little minibuffer window. That's stuff you have to learn. Else forget it. When you install Emacs there is a tutorial (Hit the help button) and do it at least 10 times ;)
See also: Text editor
Specialized tips
(Some tips regarding formats discussed in this wiki)
Some essential customization
E.g. setting the default directory, aspell directory, initial buffer properties, etc.
(setq default-directory "c:/") (custom-set-variables ;; custom-set-variables was added by Custom. ;; If you edit it by hand, you could mess it up, so be careful. ;; Your init file should contain only one such instance. ;; If there is more than one, they won't work right. '(case-fold-search t) '(current-language-environment "UTF-8") '(inhibit-startup-screen t) '(initial-major-mode (quote text-mode)) '(initial-scratch-message nil) '(ispell-alternate-dictionary "c:/Program Files/Aspell/dict") '(ispell-complete-word-dict "c:/Program Files/Aspell/dict") '(ispell-program-name "c:/Program Files/Aspell/bin/aspell.exe") '(longlines-show-hard-newlines t) '(longlines-wrap-follows-window-size t) '(temporary-file-directory "c:/tmp") '(transient-mark-mode (quote identity)))
Managing packages
Can be very difficult for a beginner.
However, for older emacsen try ELPA, a friendly package manager
Howto:
- Installing it requires copy/paste a few lines of code into the *scratch* buffer, then hit CTRL-X CTRL-E
- The Package Manager is available in the Options menu. Type 'h' for help.
Try to install emacs-24 (2012). It does have an integrated package manager.
HTML
Some history
Back in time, we used to have fairly useful and productive HTML help modes. E.g. in the '90s hm-html-help-mode (or something like that) and then the PSGML mode. The latter did not support very well initial creation of a page, but could provide help for any kind of HTML/XHTML DTD (since PSGML is an SGML/XML editor mode). In later versions of Gnu Emacs, both extensions are not included by default and have to be installed and configured.
For PSGML (still one of the best DTD-based XML editors around), insert at least the following in your .emacs. There are endless other options....
(autoload 'sgml-mode "psgml" "Major mode to edit SGML files." t)
(autoload 'xml-mode "psgml" "Major mode to edit SGML files." t)
(setq sgml-set-face t
sgml-indent-data t
sgml-auto-activate-dtd t)
(defun go-bind-markup-menu-to-mouse3 ()
(define-key sgml-mode-map [mouse-3] 'sgml-tags-menu)
(define-key sgml-mode-map [shift-mouse-3] 'sgml-attrib-menu)
)
;; change key binding whenever psgml mode is invoked
(add-hook 'sgml-mode-hook 'go-bind-markup-menu-to-mouse3)
(add-hook 'xml-mode-hook 'go-bind-markup-menu-to-mouse3)
PSGML is a must have extension if you work a lot with XML DTD's of various sorts. Modern distributions of Gnu Emacs don't include PSGML since they favor the Relax (rng) schema language and make the nxml extension the default XML editor. Support for HTML isn't satisfactory, e.g. nxml-based HTML editing is much too time consuming to use unless you do some heavy configuration work. However, readon ! There is a good HTML extension that is based on nxml.
nXhtml
For Gnu emacs 23.x the best HTML add-on is probably nXhtml since it supports editing of multiple formats (JavaScript and CSS) in one single page. See also its emacswiki entry. However, it will take some time to learn how to use it. E.g. when you start with a fresh page, there is no way to simply insert a new HTML/XHTML page template.
- Download from http://ourcomments.org/Emacs/nXhtml/doc/nxhtml.html
- Watch the tutorials There is no manual, if you don't watch the tutorials, you will be lost ! (... not that much suffering for getting a good extension).
Under Windows (tested with Emacs 32.2 win 7 64bit)
- Unpack to the emacs installation directory, e.g.
c:\soft\emacs-32\site-lisp
- Add to your ~/.emacs
- This file typically sits in c:/Users/xxx/AppData/Roaming/ directory, else just open it with C-X C-F entering ~/.emacs
(load "YOUR-PATH-TO/nxhtml/autostart.el")
e.g.
(load "c:/soft/emacs-23.2/site-lisp/nxhtml/autostart.el")
- Open or a create a file with the *.html extension
- To make this extension faster, byte-compile using the nXhtml menu -> nXHTML help and setup
Under Ubuntu
- Install the JavaScript addon (optional):
sudo apt-get install js2-mode
- In the .emacs (remove it again if it appears to be broken ....)
(require 'js2-mode)
- Install this extension manually in some place, e.g. the site-lisp directory
/usr/share/emacs/site-lisp
E.g. (for a particular version). Also, add "sudo" in front of each if you are not root.
cd /usr/share/emacs/site-lisp wget http://ourcomments.org/Emacs/DL/elisp/nxhtml/zip/nxhtml-2.08-100425.zip unzip -l nxhtml-2.08-100425.zip unzip nxhtml-2.08-100425.zip
- Change the permission of this nxhtml sub-directory to you
sudo chown -R xxx:yyy nxhtml
- Change the ~/.emacs (not a really cross-emacsen and portable solution ...)
(load "/usr/share/emacs/site-lisp/nxhtml/autostart.el")
ActionScript
Install: actionscript-mode.el written by Pet Tomato. Tested by Daniel K. Schneider with GnuEmacs 21.4.1 under Ubuntu. He provides 2 files:
- actionscript-mode.el
- as-config.el (this is only an option, did not install this)
There is a different and more recent actionscript mode from Austin Haas based on David Linquists ecmascript-mode. (made for emacsw32). I use this now for emacs 22.1.1 on Ubuntu - Daniel K. Schneider 13:17, 1 November 2008 (UTC)
To install these I did the following:
- Copied the 2 *.el files to /usr/share/emacs/site-lisp
- Byte-compiled (this is not necessary)
- Inserted this in my .emacs file:
;; Actionscript stuff (autoload 'actionscript-mode "actionscript-mode" "Major mode for editing ActionScript files." t) (add-to-list 'auto-mode-alist '("\\.as[123]?$" . actionscript-mode))
XML
- See XML editor for alternatives
- DTD support
The Xemacs (default "fat") installation provides good XML/DTD support through the PSGML library.
On recent Gnu Emacsen, the PSGML library has to be installed since nXML is now the default XML mode. E.g. on Linux Ubuntu this can be done through the Synaptic Package Manager. Type M-x xml-mode to get it.
Both Emacsen will find your private (system) DTDs and also includes/supports a list of public DTDs (you can add yours in the installation by editing ).
- Relax NG (RNC) support
Use nXML mode (it is distributed with a standard recent Gnu emacs installation). Here is a short how to:
- Start with a minimal template, e.g. to edit MXML Flex code use this:
<?xml version="1.0" encoding="utf-8"?> <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"> </mx:Application>
- Type M-X nxml-mode if by default *.xml files will go into no mode or PSGML mode in your setup.
- Menu XML->Set Schema ; File
- Select the appropriate RNC file
- To insert attributes
- Put your cursor inside a begin tag and hit CTRL-Return
- Then select a tag from the *Completions* buffer with the mouse or start typing and hit SPACE to find completions.
- To insert tags:
- Put the cursor between tags
- Type "<" and hit CTRL-Return or type some stuff and hit SPACE to see completions.
- Start inserting attributes (as above) if you like
- Then either type ">" followed by "</" + CTRL-Return or enter "/>".
As you can see, this interface was made for people willing to learn keyboard strokes. It's faster than using right-click contextual menus but more challenging for some ...
- XML Schema (XSD) support
- XML Schema support doesn't exist (IMHO).
- XSLT support
- Included in Gnu Emacs through nXML mode
- Included in Xemacs through some specific XSLT mode
Mediawikis
Editing wiki code on Mediawiki's is a real pain if you got large articles to manipulate. The visual editor doesn't allow to do certain things. Over the years there have been several packages that allow editing wiki pages with Emacs and none really works to full satisfaction as of 2016/ 2017 and 2018.
Edit with Emacs (browser extension)
this is a browser extension that works both with Firefox and Chrome. Not as good as a direct emacs-mediawiki interface but almost. Tested and used with Ubuntu 16.04 and 18.04 LTS and Windows 8 and Windows 10.
It allows editing any HTML text area with emacs and therefore also wikipages.
Installation on Ubutu 16x (tested on April 2018)
- Emacs must be installed of course
- Install the edit-server package. It is available from the MELPA archive.
- In your .emacs file put the following
(require 'edit-server) (edit-server-start)
Use:
- An emacs instance must be launched
- Then click on the little grey edit button (bottom right)
The same works on Emacs 25.x on Windows 10. However after saving (CTRL-X CTRL-S) the buffer will be burried and inactive. E.g. you'd have to press the edit button again.
Tip: Even if mediwiki.el doesn't work (see below) you could still install it in order to get mediawiki-mode (syntax hightligthning)-
MediaWiki.el
As of April 2018 (also in 2017) only this seemed to work with recent emacs/MediaWiki combos. But not on my machines :(
- mediawiki.el on github
- Read the documentation on WikiEmacs (maybe not up to date)
It is also available in the MELPA package:
In the .emacs files add
(add-to-list 'package-archives '("melpa" . "http://melpa.milkbox.net/packages/") t)
Or if you want some more complex code that should be more reliable:
(require 'package)
(let* ((no-ssl (and (memq system-type '(windows-nt ms-dos))
(not (gnutls-available-p))))
(proto (if no-ssl "http" "https")))
;; Comment/uncomment these two lines to enable/disable MELPA and MELPA Stable as desired
(add-to-list 'package-archives (cons "melpa" (concat proto "://melpa.org/packages/")) t)
(add-to-list 'package-archives '("marmalade" . "http://marmalade-repo.org/packages/") t)
;;(add-to-list 'package-archives (cons "melpa-stable" (concat proto "://stable.melpa.org/packages/")) t)
(when (< emacs-major-version 24)
;; For important compatibility libraries like cl-lib
(add-to-list 'package-archives '("gnu" . (concat proto "://elpa.gnu.org/packages/")))))
(package-initialize)
Then, use menu Options -> Manage Emacs Packages and select mediawiki.
Now it gets more difficult.
Trouble with Emacs 24x on Ubuntu 16x
As of Nov 2017, I used the 2.2.3 version for Ubuntu (24.5.1) and the the 27012 version for Windows 10 (Emacs 25.3.1). Frequently, Ubuntu distributes old code. This is probably due to the complexit of package management. But it is somewhat strange that a good workaround for not working open source software is to use Windows.
Trouble with Emacs 25x on Windows 10 (and probably many older versions too).
Emacs needs a TLS library. According to several sources, the following should work:
- Get it from https://sourceforge.net/projects/ezwinports/files/
- Unzip and move the whole file structure to the emacs directory, e.g. bin/* to bin/* (maybe copying some DLLs alone also should do the trick)
... anyhow this did not work for me (Emacs 25x/Win10/April 4, 2018).
Most important Mediawiki.el commands
Acknowledgement: (Slightly Modified) summaries and templates taken from Wikiemacs
- M-x mediawiki-site
- Choose a site (say "WikEmacs") for the current session.
- [C-c C-o] (or M-x mediawiki-open)
- Open a page. To edit the main page, type "Main Page". Make your edits. (Copy and paste the page name from your web browser). However you need to define this key (see below)
- [C-x C-s] (or M-x mediawiki-save)
- Submit your modifications.
- [C-c] (or M-x mediawiki-save-and-bury)
- Submit modifications and bury the buffer.
- [C-return] (or M-x mediawiki-open-page-at-point)
- Follow or browse to a WikiLink within the wiki code.
- [M-g] (or M-x mediawiki-reload)
- Reload a page
Suggested addition (edit your .emacs file)
(define-key mediawiki-mode-map (kbd "C-c o") 'mediawiki-browse)
- [C-c o] (or M-x mediawiki-browse)
- Will display the page in the web browser
- The following commands put in markup structures.
- C-c C-f C-s inserts italics
- C-c C-f C-b inserts bold text
- C-c C-f TAB italics
- C-c C-f C-e header
- C-c C-f C-l inserts a link
- C-c C-f C-u inserts user name
- C-c C-w inserts Daniel K. Schneider 15:25, 11 October 2012 (CEST)
- <M-return> inserts enumerate type structures
- C-\ inserts itemize type structures
- C-c C-l inserts a hline
For more information:
- Type c-h m
- Read Mediawiki.el on WikiEmacs
Problems:
- Authentication expires too fast, so far I did not find a solution.
Installation
Ubuntu 12.04 LTS
Ubuntu as of sept 2012 still distributes old emacs 23.
To get emacs 24:
$ sudo add-apt-repository ppa:cassou/emacs $ sudo apt-get update $ sudo apt-get install emacs24 emacs24-el
Install packages (works much better now than previous extensions)
- Menu Options->Manage Emacs Packages
- Click on package to install and answer yes
So far, if I understand right, only official packages are there. Others, like the mediawiki editing extension, still neeed manual installation. Another caveat is that it installs on a per user basis.
Links
Manuals & Short References
- GNU Emacs
- A guided Tour of Emacs (at gnu.org)
- GNU Emacs Reference Card (attention!!! for GNU emacs) [local copy]
- DIRED Mode Reference Card (PDF) (just the directory editor for GNU emacs)
- wikiemacs A newer wiki, that should replace the one below.
- EmacsWiki Good wiki site for both Emacs and Xemacs (multi-lingual)
- XEmacs
- XEmacs Documentation, all kind of manuals in PDF
- XEMACS Emacs Reference Card (attention format POSTSCRIPT [local copy]
- XEMACS Emacs Reference Card (PDF)
En français:
Customization Links
Configuring the functionalities of XEmacs:
- The very unofficial dotemacs home: best overall site
- Robin S. Socha's XEmacs Settings : well-commented dot file collection and screen shots
- Erik Sundermann's XEmacs Customization Page: good 'starter' .emacs customization page (but a bit old!)
- Emacs keybindings Good (but very technical) document for all Emacsen
FAQ's
- XEmacs FAQ in english
- XEmacs FAQ en fran�ais
- XEmacs FAQ en fran�ais
- XEmacs mailing lists
Tutorials
On the Web you can find many mini-tutorials, there are also book chapters, etc.
- There's the XEmacs tutorial available from the Help Menu under `Basics->Tutorials', or by typing C-h t. To check whether it's available in a non-english language, type C-u C-h t TAB, type the first letters of your preferred language, then type RET.
- Emacs editing environment by Michael Stutz at IBM developer works. Complete, requires 12 hours of work. (Free) registration required.
- Emacs Beginner's Tutorial by J.D. Zawodny @ RootPrompt.org
- XEmacs Tutorial Introduction by Sarah Waterson
- Tutorial - xemacs (good, but Very short)
En français:
- GNU Emacs: tutorial (en fran�ais)
- Aller plus loin avec GNU Emacs
Specialized topics
Advanced tricks
- Quickies for Emacs (by Borkware)
Emacs programming
- Emacs Lisp information (includes pointers to general emacs resources too)
(Some) Emacs Modes
- Html helper mode
- The Emacs Package "hm--html-menus", a mode that helps editing html pages.
- PSGML Mode home page. SEE the XML page for more pointers on PSGML !!
- Using Emacs for XML documents, good IBM developerWorks article (installation, configuration, external validator)
- Java Development Environment for Emacs (JDE)
Tools / Software
- For Linux, just use the packaging system to install, e.g. Synaptic Package Manager for Ubuntu. Check out addons (search for emacs)
- Various emacs versions
- XEmacs Download Locations
- EmacsW32 An Win Gnu emacs add on (also includes emacs in the distribution)
- Gnu Emacs (probably the best and largest beast)
- Small versions
There are many ....
- Ymacs (runs as browser plugin)
Other Links
- x and emacsen stuff (some links to tips and guides, many dead links )
- XEmacs Home Page.
- Xemacs is Dead. Long Live XEmacs (Emacs vs. Xemacs 2008).