Mercurial > emacs
view mac/INSTALL @ 32752:923b8d6d8277
Initial check-in: changes for building Emacs under Mac OS.
2000-10-23 Andrew Choi <akochoi@i-cable.com>
* dispextern.h [macintosh]: Include macgui.h instead of macterm.h.
* dispnew.c [macintosh]: Include macterm.h.
(init_display) [macintosh]: initialization for window system.
* emacs.c (main) [macintosh]: Call syms_of_textprop,
syms_of_macfns, syms_of_ccl, syms_of_fontset, syms_of_xterm,
syms_of_search, x_term_init, and init_keyboard before calling
init_window_once. Also, call syms_of_xmenu.
* fontset.c (syms_of_fontset) [macintosh]: Set ASCII font of
default fontset to Monaco.
* frame.c [macintosh]: Include macterm.h. Remove declarations of
NewMacWindow and DisposeMacWindow.
(make_terminal_frame) [macintosh]: Call make_mac_terminal_frame
instead of calling NewMacWindow and setting fields of
f->output_data.mac directly. Call init_frame_faces.
(Fdelete_frame) [macintosh]: Remove unused code.
(Fmodify_frame_parameters) [macintosh]: Call
x_set_frame_parameters instead of mac_set_frame_parameters.
* frame.h [macintosh]: Define menu_bar_lines field in struct
frame. Define FRAME_EXTERNAL_MENU_BAR macro.
* keyboard.c [macintosh]: Include macterm.h.
(kbd_buffer_get_event) [macintosh]: Generate delete_window_event
and menu_bar_activate_event type events as for X and NT.
(make_lispy_event) [macintosh]: Construct lisp events of type
MENU_BAR_EVENT as for X and NT.
* sysdep.c [macintosh]: Remove declaration for sys_signal.
Include stdlib.h. Remove definition of Vx_bitmap_file_path.
(sys_subshell) [macintosh]: Remove definition entirely.
(init_sys_modes) [macintosh]: Do not initialize Vwindow_system and
Vwindow_system_version here. Remove initialization of
Vx_bitmap_file_path.
(read_input_waiting): Correct the number of parameters passed to
read_socket_hook.
Move all Macintosh functions to mac/mac.c.
* term.c [macintosh]: Include macterm.h.
* window.c [macintosh]: Include macterm.h.
* xdisp.c [macintosh]: Include macterm.h. Declare
set_frame_menubar and pending_menu_activation.
(echo_area_display) [macintosh]: Do not return if terminal frame
is the selected frame.
(update_menu_bar) [macintosh]: Check FRAME_EXTERNAL_MENU_BAR (f).
Allow only the selected frame to set menu bar.
(redisplay_window) [macintosh]: Obtain menu bar to redisplay by
calling FRAME_EXTERNAL_MENU_BAR (f).
(display_menu_bar) [macintosh]: Check FRAME_MAC_P (f).
* xfaces.c [macintosh]: Include macterm.h. Define x_display_info
and check_x. Declare XCreateGC. Define x_create_gc and
x_free_gc. Initialize font_sort_order.
(x_face_list_fonts) [macintosh]: Use the same code as WINDOWSNT,
but call x_list_fonts instead of w32_list_fonts.
(Finternal_face_x_get_resource) [macintosh]: Do not call
display_x_get_resource.
(prepare_face_for_display) [macintosh]: Set xgcv.font.
(realize_x_face) [macintosh]: Load the font if it is specified in
ATTRS.
(syms_of_xfaces) [macintosh]: Initialize Vscalable_fonts_allowed
to Qt.
* cus-edit.el (custom-button-face): Use 3D look for mac.
(custom-button-pressed-face): Likewise.
* faces.el (set-face-attributes-from-resources): Handle mac frames
in the same way as x and w32 frames.
(face-valid-attribute-values): Likewise.
(read-face-attribute): Likewise.
(defined-colors): Likewise.
(color-defined-p): Likewise.
(color-values): Likewise.
(display-grayscale-p): Likewise.
(face-set-after-frame-default): Likewise.
(mode-line): Same default face as for x and w32.
(tool-bar): Likewise.
* frame.el: Remove call to frame-notice-user-settings at end of
the file.
* info.el (Info-fontify-node): make underlines invisible for mac
as for x, pc, and w32 frame types.
* term/mac-win.el: New file.
author | Andrew Choi <akochoi@shaw.ca> |
---|---|
date | Sun, 22 Oct 2000 16:50:16 +0000 |
parents | |
children | 59ce5f754d90 |
line wrap: on
line source
* BUILDING EMACS ON THE MAC OS -*- outline -*- You can use either Metrowerks CodeWarrior Pro 5 or 6 or MPW-GM (Aug. 2000) to build Emacs. MPW-GM can be downloaded free of charge from Apple at http://developer.apple.com/tools/mpw-tools/ You will need MPW-GM to build the make-docfile utility and to generate the doc string file DOC. To decompress files, you can use MacGzip from http://persephone.cps.unizar.es/~spd/gzip and to untar them, you can use tar 4.0 from http://hyperarchive.lcs.mit.edu/HyperArchive/Archive/cmp/tar-40b.hqx (Optional) If you wish to fetch files from the Emacs CVS repository directly to your Mac, you can use the CVS client MacCVS, which can be downloaded from http://www.wincvs.org/ (Optional) A subset of the fonts from the GNU intlfonts-1.2 distribution converted to NFNT format can be obtained from ftp://mac-emacs.sourceforge.net/pub/mac-emacs/GNU-fonts.smi.bin * BUILDING EMACS To build Emacs in the MPW Shell, simply set the directory to ...:emacs:mac: and build the target Emacs of the make file makefile.mpw. I.e., execute the commands make Emacs -f makefile.MPW > Emacs.MakeScript Emacs.MakeScript To build Emacs using CodeWarrior, start up the CodeWarrior IDE, choose File->Import Project... and select the file emacs-cw5.mcp.xml or emacs-cw6.mcp.xml, depending on which verison of CodeWarrior used. When prompted to save the project, navigate to same directory as the file emacs-cw[56].mcp.xml, name it emacs-cw5.mcp or emacs-cw6.mcp, and save it there. Then choose Project->Make. Note that this does not build the DOC file. To do so, use MPW and build the target "Doc" in makefile.MPW. Once built, the Emacs application (Emacs CW or Emacs MPW) can be launched where it is created. To build an optimized version of Emacs in CodeWarrior, change the value in the Emacs Settings->Code Generation->Global Optimization dialog. To build a version for profiling, check the Profiler Information box in the Emacs Settings->Code Generation->PPC Processor dialog and include the Profiler PPC.Lib library. To build optimized or debugging version of Emacs in MPW, follow the comment in makefile.MPW to enable the -opt speed or -sym on option (see note below). The Mac version requires compiled Lisp files to be present in the lisp directory to run properly. It is cumbersome to bootstrap from only the Lisp source files. One way of getting the compiled Lisp files is to build Emacs once on, say, a Unix system and transfer that directory to the Mac. Note that linefeed conversion must be disabled when transferring compiled Lisp files. An alternative is to unzip and untar the archive lisp-elc.tgz. An older version of frame.elc in the archive may cause a problem when the Mac version starts up. If this is the case, simply remove or rename that file. Then once Emacs runs, you can invoke byte-recompile-directory on the lisp directory to byte-compile all out-of-date Lisp files. You may also need to run update-autoloads-from-directories on the lisp directory to bring loaddefs.el up-to-date. * NOTES Emacs should build and run on a PowerMac running Mac OS 8.1 - 9.0. You will need around 100 MB of disk space for the source files and intermediate files. It will not run on machines with more than 256 MB of physical or virtual memory. Currently there is no support for building the LEIM directory on the Mac. However, it can be built on another platform and transferred to the Mac. When Emacs is built with "-opt speed" enabled in makefile.MPW, optimization causes the functions reset_buffer_local_variables in buffer.c and syms_of_lread in lread.c to crash. Avoid this by enclosing them in the following pragmas. #pragma options opt off <function definition...> #pragma options opt reset To use the same icon as when Emacs is built on Windows NT, define GNU_ICON in mac/src/Emacs.r.