annotate etc/emacsclient.1 @ 59146:9bde7721ad0f

* dispextern.h: Change HAVE_CARBON to MAC_OS. (struct glyph_string): Likewise. * emacs.c (main) [MAC_OS8]: Call mac_term_init instead of mac_initialize. * fileio.c (Fnext_read_file_uses_dialog_p, Fread_file_name): Change TARGET_API_MAC_CARBON to HAVE_CARBON. * fns.c (vector): Change MAC_OSX to MAC_OS. * frame.c (x_set_frame_parameters, x_report_frame_params) (x_set_fullscreen): Remove #ifndef HAVE_CARBON. (x_set_border_width, Vdefault_frame_scroll_bars): Change HAVE_CARBON to MAC_OS. * image.c [MAC_OS]: Include sys/stat.h. [MAC_OS && !MAC_OSX]: Include sys/param.h, ImageCompression.h, and QuickTimeComponents.h. * mac.c [!MAC_OSX] (mac_wait_next_event): Add extern. [!MAC_OSX] (select): Use mac_wait_next_event. [!MAC_OSX] (run_mac_command): Change EXEC_SUFFIXES to Vexec_suffixes. [!MAC_OSX] (select, run_mac_command): Change `#ifdef TARGET_API_MAC_CARBON' to `#if TARGET_API_MAC_CARBON'. (mac_clear_font_name_table): Add extern. (Fmac_clear_font_name_table): New defun. (syms_of_mac): Defsubr it. [MAC_OSX] (SELECT_POLLING_PERIOD_USEC): New define. [MAC_OSX] (select_and_poll_event): New function. [MAC_OSX] (sys_select): Use it. [MAC_OSX && SELECT_USE_CFSOCKET] (socket_callback): New function. [MAC_OSX && SELECT_USE_CFSOCKET] (SELECT_TIMEOUT_THRESHOLD_RUNLOOP, EVENT_CLASS_SOCK): New defines. [MAC_OSX] (sys_select) [SELECT_USE_CFSOCKET]: Use CFSocket and RunLoop for simultaneously monitoring two kinds of inputs, window events and process outputs, without periodically polling. * macfns.c (mac_initialized): Remove extern. (stricmp): Put in #if 0. All callers changed to use xstricmp in xfaces.c. (strnicmp): Decrement `n' at the end of each loop, not the beginning. (check_mac): Use the term "Mac native windows" instead of "Mac OS". (check_x_display_info, x_display_info_for_name): Sync with xfns.c. (mac_get_rdb_resource): New function (from w32reg.c). (x_get_string_resource): Use it. (install_window_handler): Add extern. (mac_window): New function. (Fx_create_frame): Use it instead of make_mac_frame. Set parameter for Qfullscreen. Call x_wm_set_size_hint. (Fx_open_connection, Fx_close_connection): New defuns. (syms_of_macfns): Defsubr them. (x_create_tip_frame) [TARGET_API_MAC_CARBON]: Add kWindowNoUpdatesAttribute to the window attribute. (x_create_tip_frame) [!TARGET_API_MAC_CARBON]: Use NewCWindow. (x_create_tip_frame): Don't call ShowWindow. (Fx_show_tip): Call ShowWindow. (Fx_file_dialog): Change `#ifdef TARGET_API_MAC_CARBON' to `#if TARGET_API_MAC_CARBON'. (mac_frame_parm_handlers): Set handlers for Qfullscreen. (syms_of_macfns) [MAC_OSX]: Initialize mac_in_use to 0. * macgui.h [!MAC_OSX]: Don't include Controls.h. Include Windows.h. (Window): Typedef to WindowPtr and move outside `#if TARGET_API_MAC_CARBON'. (XSizeHints): New struct. * macterm.c (x_update_begin, x_update_end) [TARGET_API_MAC_CARBON]: Disable screen updates during update of a frame. (x_draw_glyph_string_background, x_draw_glyph_string_foreground) [MAC_OS8]: Use XDrawImageString/XDrawImageString16. (construct_mouse_click): Put in #if 0. (x_check_fullscreen, x_check_fullscreen_move): Remove decls. (x_scroll_bar_create, x_scroll_bar_handle_click): Change `#ifdef TARGET_API_MAC_CARBON' to `#if TARGET_API_MAC_CARBON'. (activate_scroll_bars, deactivate_scroll_bars) [!TARGET_API_MAC_CARBON]: Use ActivateControl/DeactivateControl. (x_make_frame_visible) [TARGET_API_MAC_CARBON]: Reposition window if the position is neither user-specified nor program-specified. (x_free_frame_resources): Free size_hints. (x_wm_set_size_hint): Allocate size_hints if needed. Set size_hints. (mac_clear_font_name_table): New function. (mac_do_list_fonts): Initialize font_name_table if needed. (x_list_fonts): Don't initialize font_name_table. Add BLOCK_INPUT around mac_do_list_fonts. (mac_unload_font): New function. (x_load_font): Add BLOCK_INPUT around XLoadQueryFont. (init_mac_drag_n_drop, mac_do_receive_drag): Enclose declarations and definitions with #if TARGET_API_MAC_CARBON. [USE_CARBON_EVENTS] (mac_handle_window_event): Add decl. (install_window_handler): Add decl. (do_window_update): Add BeginUpdate/EndUpdate for the tooltip window. Use UpdateControls. Get the rectangle that should be updated and restrict the target of expose_frame to it. (do_grow_window): Set minimum height/width according to size_hints. (do_grow_window) [TARGET_API_MAC_CARBON]: Use ResizeWindow. (do_zoom_window): Don't use x_set_window_size. [USE_CARBON_EVENTS] (mac_handle_window_event): New function. (install_window_handler): New function. [!USE_CARBON_EVENTS] (mouse_region): New variable. [!USE_CARBON_EVENTS] (mac_wait_next_event): New function. (XTread_socket) [USE_CARBON_EVENTS]: Move call to GetEventDispatcherTarget inside BLOCK_INPUT. (XTread_socket) [!USE_CARBON_EVENTS]: Use mac_wait_next_event. Update mouse_region when mouse is moved. (make_mac_frame): Remove. (make_mac_terminal_frame): Put in #ifdef MAC_OS8. Initialize mouse pointer shapes. Change values of f->left_pos and f->top_pos. Don't use make_mac_frame. Use NewCWindow. Don't call ShowWindow. (mac_initialize_display_info) [MAC_OSX]: Create mac_id_name from Vinvocation_name and Vsystem_name. (mac_make_rdb): New function (from w32term.c). (mac_term_init): Use it. Add BLOCK_INPUT. Error if display has already been opened. Don't pass argument to mac_initialize_display_info. Don't set dpyinfo->height/width. Add entries to x_display_list and x_display_name_list. (x_delete_display): New function. (mac_initialize): Don't call mac_initialize_display_info. (syms_of_macterm) [!MAC_OSX]: Don't call Fprovide. * macterm.h (check_mac): Add extern. (struct mac_output): New member size_hints. (FRAME_SIZE_HINTS): New macro. (mac_unload_font): Add extern. * xdisp.c (expose_window, expose_frame): Remove kludges for Mac. * xfaces.c (clear_font_table) [MAC_OS]: call mac_unload_font.
author Steven Tamm <steventamm@mac.com>
date Mon, 27 Dec 2004 17:27:30 +0000
parents 695cf19ef79e
children 19477c8eacc2 375f2633d815
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
25853
Dave Love <fx@gnu.org>
parents:
diff changeset
1 .TH EMACSCLIENT 1
Dave Love <fx@gnu.org>
parents:
diff changeset
2 .\" NAME should be all caps, SECTION should be 1-8, maybe w/ subsection
Dave Love <fx@gnu.org>
parents:
diff changeset
3 .\" other parms are allowed: see man(7), man(1)
Dave Love <fx@gnu.org>
parents:
diff changeset
4 .SH NAME
Dave Love <fx@gnu.org>
parents:
diff changeset
5 emacsclient \- tells a running Emacs to visit a file
Dave Love <fx@gnu.org>
parents:
diff changeset
6 .SH SYNOPSIS
Dave Love <fx@gnu.org>
parents:
diff changeset
7 .B emacsclient
Dave Love <fx@gnu.org>
parents:
diff changeset
8 .I "[options] files ..."
Dave Love <fx@gnu.org>
parents:
diff changeset
9 .SH "DESCRIPTION"
Dave Love <fx@gnu.org>
parents:
diff changeset
10 This manual page documents briefly the
Dave Love <fx@gnu.org>
parents:
diff changeset
11 .BR emacsclient
Dave Love <fx@gnu.org>
parents:
diff changeset
12 command.
Dave Love <fx@gnu.org>
parents:
diff changeset
13 This manual page was written for the Debian GNU/Linux distribution
Dave Love <fx@gnu.org>
parents:
diff changeset
14 because the original program does not have a manual page.
Dave Love <fx@gnu.org>
parents:
diff changeset
15 Instead, it has documentation in the GNU Info format; see below.
Dave Love <fx@gnu.org>
parents:
diff changeset
16 .PP
Dave Love <fx@gnu.org>
parents:
diff changeset
17 .B emacsclient
Dave Love <fx@gnu.org>
parents:
diff changeset
18 works in conjunction with the built-in server of Emacs.
Dave Love <fx@gnu.org>
parents:
diff changeset
19 .PP
47649
3b27be508d4e Add info about --eval, --display, and --alternate-editor.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37560
diff changeset
20 You typically do not call
25853
Dave Love <fx@gnu.org>
parents:
diff changeset
21 .B emacsclient
47649
3b27be508d4e Add info about --eval, --display, and --alternate-editor.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37560
diff changeset
22 directly. Instead, you set the environment variable EDITOR
25853
Dave Love <fx@gnu.org>
parents:
diff changeset
23 to
Dave Love <fx@gnu.org>
parents:
diff changeset
24 .B emacsclient
Dave Love <fx@gnu.org>
parents:
diff changeset
25 and let programs like 'vipw' or 'bug' or anything run
Dave Love <fx@gnu.org>
parents:
diff changeset
26 it for you, which will use an existing Emacs to visit the file.
Dave Love <fx@gnu.org>
parents:
diff changeset
27
Dave Love <fx@gnu.org>
parents:
diff changeset
28 For
Dave Love <fx@gnu.org>
parents:
diff changeset
29 .B emacsclient
Dave Love <fx@gnu.org>
parents:
diff changeset
30 to work, you need an already running Emacs with a server. Within Emacs, call
Dave Love <fx@gnu.org>
parents:
diff changeset
31 the function
Dave Love <fx@gnu.org>
parents:
diff changeset
32 `server-start'. (Your `.emacs' file can do this automatically if you
Dave Love <fx@gnu.org>
parents:
diff changeset
33 add the expression `(server-start)' to it.)
Dave Love <fx@gnu.org>
parents:
diff changeset
34
Dave Love <fx@gnu.org>
parents:
diff changeset
35 When you've finished editing the buffer, type `C-x #'
Dave Love <fx@gnu.org>
parents:
diff changeset
36 (`server-edit'). This saves the file and sends a message back to the
Dave Love <fx@gnu.org>
parents:
diff changeset
37 `emacsclient' program telling it to exit. The programs that use
Dave Love <fx@gnu.org>
parents:
diff changeset
38 `EDITOR' wait for the "editor" (actually, `emacsclient') to exit. `C-x
Dave Love <fx@gnu.org>
parents:
diff changeset
39 #' also checks for other pending external requests to edit various
Dave Love <fx@gnu.org>
parents:
diff changeset
40 files, and selects the next such file.
Dave Love <fx@gnu.org>
parents:
diff changeset
41
Dave Love <fx@gnu.org>
parents:
diff changeset
42 If you set the variable `server-window' to a window or a frame, `C-x
Dave Love <fx@gnu.org>
parents:
diff changeset
43 #' displays the server buffer in that window or in that frame.
Dave Love <fx@gnu.org>
parents:
diff changeset
44
Dave Love <fx@gnu.org>
parents:
diff changeset
45 .SH OPTIONS
Dave Love <fx@gnu.org>
parents:
diff changeset
46 The programs follow the usual GNU command line syntax, with long
Dave Love <fx@gnu.org>
parents:
diff changeset
47 options starting with two dashes (`-').
Dave Love <fx@gnu.org>
parents:
diff changeset
48 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
49 .B \-n, \-\-no-wait
Dave Love <fx@gnu.org>
parents:
diff changeset
50 returns
Dave Love <fx@gnu.org>
parents:
diff changeset
51 immediately without waiting for you to "finish" the buffer in Emacs.
47649
3b27be508d4e Add info about --eval, --display, and --alternate-editor.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37560
diff changeset
52 .TP
3b27be508d4e Add info about --eval, --display, and --alternate-editor.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37560
diff changeset
53 .B \-e, \-\-eval
3b27be508d4e Add info about --eval, --display, and --alternate-editor.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37560
diff changeset
54 do not visit files but instead evaluate the arguments as Emacs
3b27be508d4e Add info about --eval, --display, and --alternate-editor.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37560
diff changeset
55 Lisp expressions.
3b27be508d4e Add info about --eval, --display, and --alternate-editor.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37560
diff changeset
56 .TP
3b27be508d4e Add info about --eval, --display, and --alternate-editor.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37560
diff changeset
57 .B \-a, \-\-alternate-editor=EDITOR
3b27be508d4e Add info about --eval, --display, and --alternate-editor.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37560
diff changeset
58 if the Emacs server is not running, run the specified editor instead.
3b27be508d4e Add info about --eval, --display, and --alternate-editor.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37560
diff changeset
59 This can also be specified via the `ALTERNATE_EDITOR' environment variable.
3b27be508d4e Add info about --eval, --display, and --alternate-editor.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37560
diff changeset
60 .TP
3b27be508d4e Add info about --eval, --display, and --alternate-editor.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37560
diff changeset
61 .B \-d, \-\-display=DISPLAY
3b27be508d4e Add info about --eval, --display, and --alternate-editor.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 37560
diff changeset
62 tell the server to display the files on the given display.
25853
Dave Love <fx@gnu.org>
parents:
diff changeset
63 .SH "SEE ALSO"
Dave Love <fx@gnu.org>
parents:
diff changeset
64 The program is documented fully in
Dave Love <fx@gnu.org>
parents:
diff changeset
65 .IR "Using Emacs as a Server"
Dave Love <fx@gnu.org>
parents:
diff changeset
66 available via the Info system.
Dave Love <fx@gnu.org>
parents:
diff changeset
67 .SH BUGS
Dave Love <fx@gnu.org>
parents:
diff changeset
68 If there is no running Emacs server,
Dave Love <fx@gnu.org>
parents:
diff changeset
69 .B emacsclient
Dave Love <fx@gnu.org>
parents:
diff changeset
70 cannot launch one. I use a small Perl script instead of raw
Dave Love <fx@gnu.org>
parents:
diff changeset
71 .B emacsclient
Dave Love <fx@gnu.org>
parents:
diff changeset
72 to do it (it works only with systems which have BSD sockets, which is fine
Dave Love <fx@gnu.org>
parents:
diff changeset
73 for Debian GNU/Linux).
Dave Love <fx@gnu.org>
parents:
diff changeset
74 .SH AUTHOR
Dave Love <fx@gnu.org>
parents:
diff changeset
75 This manual page was written by Stephane Bortzmeyer <bortzmeyer@debian.org>,
Dave Love <fx@gnu.org>
parents:
diff changeset
76 for the Debian GNU/Linux system (but may be used by others).
37560
1cf7aceaccd0 Place in the public domain.
Eli Zaretskii <eliz@gnu.org>
parents: 25853
diff changeset
77 .SH COPYING
1cf7aceaccd0 Place in the public domain.
Eli Zaretskii <eliz@gnu.org>
parents: 25853
diff changeset
78 This manual page is in the public domain.
52401
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 47649
diff changeset
79
695cf19ef79e Add arch taglines
Miles Bader <miles@gnu.org>
parents: 47649
diff changeset
80 .\" arch-tag: 2b35e723-b197-4073-8752-231bc8b3d3f3