1 @c This is part of the Emacs manual.
2 @c Copyright (C) 2000, 2001, 2002, 2003, 2004,
3 @c 2005, 2006 Free Software Foundation, Inc.
4 @c See file emacs.texi for copying conditions.
5 @node Mac OS, Microsoft Windows, Antinews, Top
6 @appendix Emacs and Mac OS
10 This section briefly describes the peculiarities of using Emacs
11 under Mac OS with native window system support. For Mac OS X, Emacs
12 can be built either without window system support, with X11, or with
13 Carbon API. This section only applies to the Carbon build. For Mac
14 OS Classic, Emacs can be built with or without Carbon API, and this
15 section applies to either of them because they run on the native
18 Emacs built on Mac OS X supports most of its major features except
19 display support of PostScript images. The following features of Emacs
20 are not supported on Mac OS Classic: unexec (@code{dump-emacs}),
21 asynchronous subprocesses (@code{start-process}), and networking
22 (@code{open-network-stream}). As a result, packages such as Gnus,
23 GUD, and Comint do not work. Synchronous subprocesses
24 (@code{call-process}) are supported on non-Carbon build, but
25 specially-crafted external programs are needed. Since external
26 programs to handle commands such as @code{print-buffer} and
27 @code{diff} are not available on Mac OS Classic, they are not
28 supported. Non-Carbon build on Mac OS Classic does not support some
29 features such as file dialogs, drag-and-drop, and Unicode menus.
32 * Input: Mac Input. Keyboard and mouse input on Mac.
33 * Intl: Mac International. International character sets on Mac.
34 * Env: Mac Environment Variables. Setting environment variables for Emacs.
35 * Directories: Mac Directories. Volumes and directories on Mac.
36 * Font: Mac Font Specs. Specifying fonts on Mac.
37 * Functions: Mac Functions. Mac-specific Lisp functions.
41 @section Keyboard and Mouse Input on Mac
43 @cindex keyboard coding (Mac OS)
45 @vindex mac-control-modifier
46 @vindex mac-command-modifier
47 @vindex mac-option-modifier
48 @vindex mac-function-modifier
49 On Mac, Emacs can use @key{control}, @key{command}, @key{option}, and
50 laptop @key{function} keys as any of Emacs modifier keys except
51 @key{SHIFT} (i.e., @key{ALT}, @key{CTRL}, @key{HYPER}, @key{META}, and
52 @key{SUPER}). The assignment is controlled by the variables
53 @code{mac-control-modifier}, @code{mac-command-modifier},
54 @code{mac-option-modifier}, and @code{mac-function-modifier}. The value
55 for each of these variables can be one of the following symbols:
56 @code{alt}, @code{control}, @code{hyper}, @code{meta}, @code{super}, and
57 @code{nil} (no particular assignment). By default, the @key{control}
58 key works as @key{CTRL}, and the @key{command} key as @key{META}.
60 For the @key{option} key, if @code{mac-option-modifier} is set to
61 @code{nil}, which is the default, the key works as the normal
62 @key{option} key, i.e., dead-key processing will work. This is useful
63 for entering non-@acronym{ASCII} Latin characters directly from the
64 Mac keyboard, for example.
66 Emacs recognizes the setting in the Keyboard control panel (Mac OS
67 Classic) or the International system preference pane (Mac OS X) and
68 supports international and alternative keyboard layouts (e.g., Dvorak).
69 Selecting one of the layouts from the keyboard layout pull-down menu
70 will affect how the keys typed on the keyboard are interpreted.
72 @vindex mac-pass-command-to-system
73 @vindex mac-pass-control-to-system
74 Mac OS intercepts and handles certain key combinations (e.g.,
75 @key{command}-@key{SPC} for switching input languages). These will not
76 be passed to Emacs. One can disable this interception by setting
77 @code{mac-pass-command-to-system} or @code{mac-pass-control-to-system}
80 @vindex mac-emulate-three-button-mouse
81 Especially for one-button mice, the multiple button feature can be
82 emulated by setting @code{mac-emulate-three-button-mouse} to @code{t}
83 or @code{reverse}. If set to @code{t} (@code{reverse}, respectively),
84 pressing the mouse button with the @key{option} key is recognized as
85 the second (third) button, and that with the @key{command} key is
86 recognized as the third (second) button.
88 @vindex mac-wheel-button-is-mouse-2
89 For multi-button mice, the wheel button and the secondary button are
90 recognized as the second and the third button, respectively. If
91 @code{mac-wheel-button-is-mouse-2} is set to @code{nil}, their roles
94 @node Mac International
95 @section International Character Set Support on Mac
96 @cindex Mac Roman coding system
97 @cindex clipboard support (Mac OS)
99 Mac uses non-standard encodings for the upper 128 single-byte
100 characters. They also deviate from the ISO 2022 standard by using
101 character codes in the range 128-159. The coding systems
102 @code{mac-roman}, @code{mac-centraleurroman}, and @code{mac-cyrillic}
103 are used to represent these Mac encodings.
105 You can use input methods provided either by LEIM (@pxref{Input
106 Methods}) or Mac OS to enter international characters. To use the
107 former, see the International Character Set Support section of the
108 manual (@pxref{International}).
110 Emacs on Mac OS automatically changes the value of
111 @code{keyboard-coding-system} according to the current keyboard
112 layout. So users don't need to set it manually, and even if set, it
113 will be changed when the keyboard layout change is detected next time.
115 The Mac clipboard and the Emacs kill ring (@pxref{Killing}) are
116 synchronized by default: you can yank a piece of text and paste it
117 into another Mac application, or cut or copy one in another Mac
118 application and yank it into a Emacs buffer. This feature can be
119 disabled by setting @code{x-select-enable-clipboard} to @code{nil}.
120 One can still do copy and paste with another application from the Edit
123 On Mac, the role of the coding system for selection that is set by
124 @code{set-selection-coding-system} (@pxref{Communication Coding}) is
125 two-fold. First, it is used as a preferred coding system for the
126 traditional text flavor that does not specify any particular encodings
127 and is mainly used by applications on Mac OS Classic. Second, it
128 specifies the intermediate encoding for the UTF-16 text flavor that is
129 mainly used by applications on Mac OS X.
131 When pasting UTF-16 text data from the clipboard, it is first
132 converted to the encoding specified by the selection coding system
133 using the converter in the Mac OS system, and then decoded into the
134 Emacs internal encoding using the converter in Emacs. If the first
135 conversion failed, then the UTF-16 data is directly converted to Emacs
136 internal encoding using the converter in Emacs. Copying UTF-16 text
137 to the clipboard goes through the inverse path. The reason for this
138 two-pass decoding is to avoid subtle differences in Unicode mappings
139 between the Mac OS system and Emacs such as various kinds of hyphens,
140 and to minimize users' customization. For example, users that mainly
141 use Latin characters would prefer Greek characters to be decoded into
142 the @code{mule-unicode-0100-24ff} charset, but Japanese users would
143 prefer them to be decoded into the @code{japanese-jisx0208} charset.
144 Since the coding system for selection is automatically set according
145 to the system locale setting, users usually don't have to set it
148 The default language environment (@pxref{Language Environments}) is
149 set according to the locale setting at the startup time. On Mac OS,
150 the locale setting is consulted in the following order:
154 Environment variables @env{LC_ALL}, @env{LC_CTYPE} and @env{LANG} as
158 Preference @code{AppleLocale} that is set by default on Mac OS X 10.3
162 Preference @code{AppleLanguages} that is set by default on Mac OS X
166 Variable @code{mac-system-locale} that is derived from the system
167 language and region codes. This variable is available on all
168 supported Mac OS versions including Mac OS Classic.
171 The default values of almost all variables about coding systems are
172 also set according to the language environment. So usually you don't
173 have to customize these variables manually.
175 @node Mac Environment Variables
176 @section Environment Variables and Command Line Arguments.
177 @cindex environment variables (Mac OS)
179 On Mac OS X, when Emacs is run in a terminal, it inherits the values
180 of environment variables from the shell from which it is invoked.
181 However, when it is run from the Finder as a GUI application, it only
182 inherits environment variable values defined in the file
183 @file{~/.MacOSX/environment.plist} that affects all the applications
184 invoked from the Finder or the @command{open} command.
186 Command line arguments are specified like
189 /Applications/Emacs.app/Contents/MacOS/Emacs -g 80x25 &
193 if Emacs is installed at @file{/Applications/Emacs.app}. If Emacs is
194 invoked like this, then it also inherits the values of environment
195 variables from the shell from which it is invoked.
197 On Mac OS Classic, environment variables and command line arguments
198 for Emacs can be set by modifying the @samp{STR#} resources 128 and
199 129, respectively. A common environment variable that one may want to
202 The way to set an environment variable is by adding a string of the
210 to resource @samp{STR#} number 128 using @code{ResEdit}. To set up the
211 program to use unibyte characters exclusively, for example, add the
218 @cindex Mac Preferences
219 Although Emacs on Mac does not support X resources (@pxref{X
220 Resources}) directly, one can use the Preferences system in place of X
221 resources. For example, adding the line
224 Emacs.cursorType: bar
228 to @file{~/.Xresources} in X11 corresponds to the execution of
231 defaults write org.gnu.Emacs Emacs.cursorType bar
235 on Mac OS X. One can use boolean or numeric values as well as string
239 defaults write org.gnu.Emacs Emacs.toolBar -bool false
240 defaults write org.gnu.Emacs Emacs.lineSpacing -int 3
244 Try @kbd{M-x man RET defaults RET} for the usage of the
245 @command{defaults} command. Alternatively, if you have Developer
246 Tools installed on Mac OS X, you can use Property List Editor to edit
247 the file @file{~/Library/Preferences/org.gnu.Emacs.plist}.
250 @node Mac Directories
251 @section Volumes and Directories on Mac
252 @cindex file names (Mac OS)
254 This node applies to Mac OS Classic only.
256 The directory structure in Mac OS Classic is seen by Emacs as
259 /@var{volumename}/@var{filename}
262 So when Emacs requests a file name, doing file name completion on
263 @file{/} will display all volumes on the system. You can use @file{..}
264 to go up a directory level.
266 On Mac OS Classic, to access files and folders on the desktop, look
267 in the folder @file{Desktop Folder} in your boot volume (this folder
268 is usually invisible in the Mac @code{Finder}).
270 On Mac OS Classic, Emacs creates the Mac folder
271 @file{:Preferences:Emacs:} in the @file{System Folder} and uses it as
272 the temporary directory. Emacs maps the directory name @file{/tmp/}
273 to that. Therefore it is best to avoid naming a volume @file{tmp}.
274 If everything works correctly, the program should leave no files in it
275 when it exits. You should be able to set the environment variable
276 @code{TMPDIR} to use another directory but this folder will still be
281 @section Specifying Fonts on Mac
282 @cindex font names (Mac OS)
284 It is rare that you need to specify a font name in Emacs; usually
285 you specify face attributes instead. For example, you can use 14pt
286 Courier by customizing the default face attributes for all frames:
289 (set-face-attribute 'default nil
290 :family "courier" :height 140)
294 Alternatively, an interactive one is also available
295 (@pxref{Face Customization}).
297 But when you do need to specify a font name in Emacs on Mac, use a
298 standard X font name:
301 -@var{maker}-@var{family}-@var{weight}-@var{slant}-@var{widthtype}-@var{style}@dots{}
302 @dots{}-@var{pixels}-@var{height}-@var{horiz}-@var{vert}-@var{spacing}-@var{width}-@var{charset}
306 @xref{Font X}. Wildcards are supported as they are on X.
308 Emacs on Mac OS Classic uses QuickDraw Text routines for drawing texts
309 by default. Emacs on Mac OS X uses @acronym{ATSUI, Apple Type Services
310 for Unicode Imaging} as well as QuickDraw Text, and most of the
311 characters other than Chinese, Japanese, and Korean ones are drawn using
312 the former by default.
314 @acronym{ATSUI}-compatible fonts have maker name @code{apple} and
315 charset @code{iso10646-1}. For example, 12-point Monaco can be specified
319 -apple-monaco-medium-r-normal--12-*-*-*-*-*-iso10646-1
322 Note that it must be specified in a format containing 14 @samp{-}s
323 (e.g., not by @samp{-apple-monaco-medium-r-normal--12-*-iso10646-1}),
324 because every @acronym{ATSUI}-compatible font is a scalable one.
326 QuickDraw Text fonts have maker name @code{apple} and various charset
327 names other than @code{iso10646-1}. Native Apple fonts in Mac Roman
328 encoding has charset @code{mac-roman}. You can specify a
329 @code{mac-roman} font for @acronym{ASCII} characters like
334 '(font . "-apple-monaco-medium-r-normal--13-*-*-*-*-*-mac-roman"))
338 but that does not extend to ISO-8859-1: specifying a @code{mac-roman}
339 font for Latin-1 characters introduces wrong glyphs.
341 Native Apple Traditional Chinese, Simplified Chinese, Japanese,
342 Korean, Central European, Cyrillic, Symbol, and Dingbats fonts have
343 charsets @samp{big5-0}, @samp{gb2312.1980-0},
344 @samp{jisx0208.1983-sjis} and @samp{jisx0201.1976-0},
345 @samp{ksc5601.1989-0}, @samp{mac-centraleurroman},
346 @samp{mac-cyrillic}, @samp{mac-symbol}, and @samp{mac-dingbats},
349 The use of @code{create-fontset-from-fontset-spec} (@pxref{Defining
350 Fontsets}) for defining fontsets often results in wrong ones especially
351 when using only OS-bundled QuickDraw Text fonts. The recommended way to
352 use them is to create a fontset using
353 @code{create-fontset-from-mac-roman-font}:
356 (create-fontset-from-mac-roman-font
357 "-apple-courier-medium-r-normal--13-*-*-*-*-*-mac-roman"
362 and then optionally specifying Chinese, Japanese, or Korean font
363 families using @code{set-fontset-font}:
366 (set-fontset-font "fontset-foo"
367 'chinese-gb2312 '("song" . "gb2312.1980-0"))
370 Single-byte fonts converted from GNU fonts in BDF format, which are not
371 in the Mac Roman encoding, have foundry, family, and character sets
372 encoded in the names of their font suitcases. E.g., the font suitcase
373 @samp{ETL-Fixed-ISO8859-1} contains fonts which can be referred to by
374 the name @samp{-ETL-fixed-*-iso8859-1}.
376 @vindex mac-allow-anti-aliasing
377 Mac OS X 10.2 or later can use two types of text renderings: Quartz 2D
378 (aka Core Graphics) and QuickDraw. By default, Emacs uses the former on
379 such versions. It can be changed by setting
380 @code{mac-allow-anti-aliasing} to @code{t} (Quartz 2D) or @code{nil}
381 (QuickDraw). Both @acronym{ATSUI} and QuickDraw Text drawings are
382 affected by the value of this variable.
386 @section Mac-Specific Lisp Functions
387 @cindex Lisp functions specific to Mac OS
389 @findex do-applescript
390 The function @code{do-applescript} takes a string argument,
391 executes it as an AppleScript command, and returns the result as a
394 @findex mac-file-name-to-posix
395 @findex posix-file-name-to-mac
396 The function @code{mac-file-name-to-posix} takes a Mac file name and
397 returns the GNU or Unix equivalent. The function
398 @code{posix-file-name-to-mac} performs the opposite conversion. They
399 are useful for constructing AppleScript commands to be passed to
400 @code{do-applescript}.
402 @findex mac-set-file-creator
403 @findex mac-get-file-creator
404 @findex mac-set-file-type
405 @findex mac-get-file-type
406 The functions @code{mac-set-file-creator},
407 @code{mac-get-file-creator}, @code{mac-set-file-type}, and
408 @code{mac-get-file-type} can be used to set and get creator and file
411 @findex mac-get-preference
412 The function @code{mac-get-preference} returns the preferences value
413 converted to a Lisp object for a specified key and application.
416 arch-tag: a822c2ab-4273-4997-927e-c153bb71dcf6