xref: /vim-8.2.3635/src/gui.h (revision 12ee7ff0)
1 /* vi:set ts=8 sts=4 sw=4 noet:
2  *
3  * VIM - Vi IMproved		by Bram Moolenaar
4  *				Motif support by Robert Webb
5  *
6  * Do ":help uganda"  in Vim to read copying and usage conditions.
7  * Do ":help credits" in Vim to see a list of people who contributed.
8  */
9 
10 #ifdef FEAT_GUI_MOTIF
11 # include <Xm/Xm.h>
12 #endif
13 
14 #ifdef FEAT_GUI_ATHENA
15 # include <X11/Intrinsic.h>
16 # include <X11/StringDefs.h>
17 #endif
18 
19 #ifdef FEAT_GUI_GTK
20 # ifdef VMS /* undef MIN and MAX because Intrinsic.h redefines them anyway */
21 #  ifdef MAX
22 #   undef MAX
23 #  endif
24 #  ifdef MIN
25 #   undef MIN
26 #  endif
27 # endif
28 # include <X11/Intrinsic.h>
29 # include <gtk/gtk.h>
30 #endif
31 
32 #ifdef FEAT_GUI_MAC
33 # include <Types.h>
34 /*# include <Memory.h>*/
35 # include <Quickdraw.h>
36 # include <Fonts.h>
37 # include <Events.h>
38 # include <Menus.h>
39 # if !(defined (TARGET_API_MAC_CARBON) && (TARGET_API_MAC_CARBON))
40 #  include <Windows.h>
41 # endif
42 # include <Controls.h>
43 /*# include <TextEdit.h>*/
44 # include <Dialogs.h>
45 # include <OSUtils.h>
46 /*
47 # include <ToolUtils.h>
48 # include <SegLoad.h>*/
49 #endif
50 
51 #ifdef FEAT_GUI_PHOTON
52 # include <Ph.h>
53 # include <Pt.h>
54 # include "photon/PxProto.h"
55 #endif
56 
57 /*
58  * On some systems scrolling needs to be done right away instead of in the
59  * main loop.
60  */
61 #if defined(FEAT_GUI_MSWIN) || defined(FEAT_GUI_MAC) || defined(FEAT_GUI_GTK)
62 # define USE_ON_FLY_SCROLL
63 #endif
64 
65 /*
66  * GUIs that support dropping files on a running Vim.
67  */
68 #if (defined(FEAT_DND) && defined(FEAT_GUI_GTK)) \
69 	|| defined(FEAT_GUI_MSWIN) \
70 	|| defined(FEAT_GUI_MAC)
71 # define HAVE_DROP_FILE
72 #endif
73 
74 /*
75  * This define makes menus always use a fontset.
76  * We're not sure if this code always works, thus it can be disabled.
77  */
78 #ifdef FEAT_XFONTSET
79 # define FONTSET_ALWAYS
80 #endif
81 
82 /*
83  * These macros convert between character row/column and pixel coordinates.
84  * TEXT_X   - Convert character column into X pixel coord for drawing strings.
85  * TEXT_Y   - Convert character row into Y pixel coord for drawing strings.
86  * FILL_X   - Convert character column into X pixel coord for filling the area
87  *		under the character.
88  * FILL_Y   - Convert character row into Y pixel coord for filling the area
89  *		under the character.
90  * X_2_COL  - Convert X pixel coord into character column.
91  * Y_2_ROW  - Convert Y pixel coord into character row.
92  */
93 #ifdef FEAT_GUI_MSWIN
94 # define TEXT_X(col)	((col) * gui.char_width)
95 # define TEXT_Y(row)	((row) * gui.char_height + gui.char_ascent)
96 # define FILL_X(col)	((col) * gui.char_width)
97 # define FILL_Y(row)	((row) * gui.char_height)
98 # define X_2_COL(x)	((x) / gui.char_width)
99 # define Y_2_ROW(y)	((y) / gui.char_height)
100 #else
101 # define TEXT_X(col)	((col) * gui.char_width  + gui.border_offset)
102 # define FILL_X(col)	((col) * gui.char_width  + gui.border_offset)
103 # define X_2_COL(x)	(((x) - gui.border_offset) / gui.char_width)
104 # define TEXT_Y(row)	((row) * gui.char_height + gui.char_ascent \
105 							+ gui.border_offset)
106 # define FILL_Y(row)	((row) * gui.char_height + gui.border_offset)
107 # define Y_2_ROW(y)	(((y) - gui.border_offset) / gui.char_height)
108 #endif
109 
110 /* Indices for arrays of scrollbars */
111 #define SBAR_NONE	    -1
112 #define SBAR_LEFT	    0
113 #define SBAR_RIGHT	    1
114 #define SBAR_BOTTOM	    2
115 
116 /* Orientations for scrollbars */
117 #define SBAR_VERT	    0
118 #define SBAR_HORIZ	    1
119 
120 /* Default size of scrollbar */
121 #define SB_DEFAULT_WIDTH    16
122 
123 /* Default height of the menu bar */
124 #define MENU_DEFAULT_HEIGHT 1		/* figure it out at runtime */
125 
126 /* Flags for gui_mch_outstr_nowrap() */
127 #define GUI_MON_WRAP_CURSOR	0x01	/* wrap cursor at end of line */
128 #define GUI_MON_INVERT		0x02	/* invert the characters */
129 #define GUI_MON_IS_CURSOR	0x04	/* drawing cursor */
130 #define GUI_MON_TRS_CURSOR	0x08	/* drawing transparent cursor */
131 #define GUI_MON_NOCLEAR		0x10	/* don't clear selection */
132 
133 /* Flags for gui_mch_draw_string() */
134 #define DRAW_TRANSP		0x01	/* draw with transparent bg */
135 #define DRAW_BOLD		0x02	/* draw bold text */
136 #define DRAW_UNDERL		0x04	/* draw underline text */
137 #define DRAW_UNDERC		0x08	/* draw undercurl text */
138 #if defined(FEAT_GUI_GTK)
139 # define DRAW_ITALIC		0x10	/* draw italic text */
140 #endif
141 #define DRAW_CURSOR		0x20	/* drawing block cursor (win32) */
142 #define DRAW_STRIKE		0x40	/* strikethrough */
143 
144 /* For our own tearoff menu item */
145 #define TEAR_STRING		"-->Detach"
146 #define TEAR_LEN		(9)	/* length of above string */
147 
148 /* for the toolbar */
149 #define TOOLBAR_BUTTON_HEIGHT	18
150 #define TOOLBAR_BUTTON_WIDTH	18
151 #define TOOLBAR_BORDER_HEIGHT	12  /* room above+below buttons for MSWindows */
152 
153 #ifdef FEAT_GUI_MSWIN
154 # define TABLINE_HEIGHT 22
155 #endif
156 #ifdef FEAT_GUI_MOTIF
157 # define TABLINE_HEIGHT 30
158 #endif
159 
160 #if defined(NO_CONSOLE) || defined(FEAT_GUI_GTK) || defined(FEAT_GUI_X11)
161 # define NO_CONSOLE_INPUT	/* use no_console_input() to check if there
162 				   is no console input possible */
163 #endif
164 
165 typedef struct GuiScrollbar
166 {
167     long	ident;		/* Unique identifier for each scrollbar */
168     win_T	*wp;		/* Scrollbar's window, NULL for bottom */
169     int		type;		/* one of SBAR_{LEFT,RIGHT,BOTTOM} */
170     long	value;		/* Represents top line number visible */
171 #ifdef FEAT_GUI_ATHENA
172     int		pixval;		/* pixel count of value */
173 #endif
174     long	size;		/* Size of scrollbar thumb */
175     long	max;		/* Number of lines in buffer */
176 
177     /* Values measured in characters: */
178     int		top;		/* Top of scroll bar (chars from row 0) */
179     int		height;		/* Current height of scroll bar in rows */
180     int		width;		/* Current width of scroll bar in cols */
181     int		status_height;	/* Height of status line */
182 #ifdef FEAT_GUI_X11
183     Widget	id;		/* Id of real scroll bar */
184 #endif
185 #ifdef FEAT_GUI_GTK
186     GtkWidget *id;		/* Id of real scroll bar */
187     unsigned long handler_id;   /* Id of "value_changed" signal handler */
188 #endif
189 
190 #ifdef FEAT_GUI_MSWIN
191     HWND	id;		/* Id of real scroll bar */
192     int		scroll_shift;	/* The scrollbar stuff can handle only up to
193 				   32767 lines.  When the file is longer,
194 				   scroll_shift is set to the number of shifts
195 				   to reduce the count.  */
196 #endif
197 #ifdef FEAT_GUI_MAC
198     ControlHandle id;		/* A handle to the scrollbar */
199 #endif
200 #ifdef FEAT_GUI_PHOTON
201     PtWidget_t	*id;
202 #endif
203 } scrollbar_T;
204 
205 typedef long	    guicolor_T;	/* handle for a GUI color; for X11 this should
206 				   be "Pixel", but that's an unsigned and we
207 				   need a signed value */
208 #define INVALCOLOR (guicolor_T)-11111	/* number for invalid color; on 32 bit
209 				   displays there is a tiny chance this is an
210 				   actual color */
211 #define CTERMCOLOR (guicolor_T)-11110	/* only used for cterm.bg_rgb and
212 					   cterm.fg_rgb: use cterm color */
213 
214 #ifdef FEAT_GUI_GTK
215   typedef PangoFontDescription	*GuiFont;       /* handle for a GUI font */
216   typedef PangoFontDescription  *GuiFontset;    /* handle for a GUI fontset */
217 # define NOFONT		(GuiFont)NULL
218 # define NOFONTSET	(GuiFontset)NULL
219 #else
220 # ifdef FEAT_GUI_PHOTON
221   typedef char		*GuiFont;
222   typedef char		*GuiFontset;
223 #  define NOFONT	(GuiFont)NULL
224 #  define NOFONTSET	(GuiFontset)NULL
225 # else
226 #  ifdef FEAT_GUI_X11
227   typedef XFontStruct	*GuiFont;	/* handle for a GUI font */
228   typedef XFontSet	GuiFontset;	/* handle for a GUI fontset */
229 #   define NOFONT	(GuiFont)0
230 #   define NOFONTSET	(GuiFontset)0
231 #  else
232   typedef long_u	GuiFont;	/* handle for a GUI font */
233   typedef long_u	GuiFontset;	/* handle for a GUI fontset */
234 #   define NOFONT	(GuiFont)0
235 #   define NOFONTSET	(GuiFontset)0
236 #  endif
237 # endif
238 #endif
239 
240 #ifdef VIMDLL
241 // Use spawn when GUI is starting.
242 # define GUI_MAY_SPAWN
243 
244 // Uncomment the next definition if you want to use the `:gui` command on
245 // Windows.  It uses `:mksession` to inherit the session from vim.exe to
246 // gvim.exe.  So, it doesn't work perfectly. (EXPERIMENTAL)
247 //# define EXPERIMENTAL_GUI_CMD
248 #endif
249 
250 typedef struct Gui
251 {
252     int		in_focus;	    /* Vim has input focus */
253     int		in_use;		    /* Is the GUI being used? */
254     int		starting;	    /* GUI will start in a little while */
255     int		shell_created;	    /* Has the shell been created yet? */
256     int		dying;		    /* Is vim dying? Then output to terminal */
257     int		dofork;		    /* Use fork() when GUI is starting */
258 #ifdef GUI_MAY_SPAWN
259     int		dospawn;	    /* Use spawn() when GUI is starting */
260 #endif
261     int		dragged_sb;	    /* Which scrollbar being dragged, if any? */
262     win_T	*dragged_wp;	    /* Which WIN's sb being dragged, if any? */
263     int		pointer_hidden;	    /* Is the mouse pointer hidden? */
264     int		col;		    /* Current cursor column in GUI display */
265     int		row;		    /* Current cursor row in GUI display */
266     int		cursor_col;	    /* Physical cursor column in GUI display */
267     int		cursor_row;	    /* Physical cursor row in GUI display */
268     char	cursor_is_valid;    /* There is a cursor at cursor_row/col */
269     int		num_cols;	    /* Number of columns */
270     int		num_rows;	    /* Number of rows */
271     int		scroll_region_top;  /* Top (first) line of scroll region */
272     int		scroll_region_bot;  /* Bottom (last) line of scroll region */
273     int		scroll_region_left;  /* Left (first) column of scroll region */
274     int		scroll_region_right;  /* Right (last) col. of scroll region */
275     int		highlight_mask;	    /* Highlight attribute mask */
276     int		scrollbar_width;    /* Width of vertical scrollbars */
277     int		scrollbar_height;   /* Height of horizontal scrollbar */
278     int		left_sbar_x;	    /* Calculated x coord for left scrollbar */
279     int		right_sbar_x;	    /* Calculated x coord for right scrollbar */
280 
281 #ifdef FEAT_MENU
282 # ifndef FEAT_GUI_GTK
283     int		menu_height;	    /* Height of the menu bar */
284     int		menu_width;	    /* Width of the menu bar */
285 # endif
286     char	menu_is_active;	    /* TRUE if menu is present */
287 # ifdef FEAT_GUI_ATHENA
288     char	menu_height_fixed;  /* TRUE if menu height fixed */
289 # endif
290 #endif
291 
292     scrollbar_T bottom_sbar;	    /* Bottom scrollbar */
293     int		which_scrollbars[3];/* Which scrollbar boxes are active? */
294     int		prev_wrap;	    /* For updating the horizontal scrollbar */
295     int		char_width;	    /* Width of char cell in pixels */
296     int		char_height;	    /* Height of char cell in pixels, includes
297 				       'linespace' */
298     int		char_ascent;	    /* Ascent of char in pixels */
299     int		border_width;	    /* Width of our border around text area */
300     int		border_offset;	    /* Total pixel offset for all borders */
301 
302     GuiFont	norm_font;	    /* Normal font */
303 #ifndef FEAT_GUI_GTK
304     GuiFont	bold_font;	    /* Bold font */
305     GuiFont	ital_font;	    /* Italic font */
306     GuiFont	boldital_font;	    /* Bold-Italic font */
307 #else
308     int		font_can_bold;	    /* Whether norm_font supports bold weight.
309 				     * The styled font variants are not used. */
310 #endif
311 
312 #if defined(FEAT_MENU) && !defined(FEAT_GUI_GTK)
313 # ifdef FONTSET_ALWAYS
314     GuiFontset	menu_fontset;	    /* set of fonts for multi-byte chars */
315 # else
316     GuiFont	menu_font;	    /* menu item font */
317 # endif
318 #endif
319     GuiFont	wide_font;	    /* Normal 'guifontwide' font */
320 #ifndef FEAT_GUI_GTK
321     GuiFont	wide_bold_font;	    /* Bold 'guifontwide' font */
322     GuiFont	wide_ital_font;	    /* Italic 'guifontwide' font */
323     GuiFont	wide_boldital_font; /* Bold-Italic 'guifontwide' font */
324 #endif
325 #ifdef FEAT_XFONTSET
326     GuiFontset	fontset;	    /* set of fonts for multi-byte chars */
327 #endif
328     guicolor_T	back_pixel;	    /* Color of background */
329     guicolor_T	norm_pixel;	    /* Color of normal text */
330     guicolor_T	def_back_pixel;	    /* default Color of background */
331     guicolor_T	def_norm_pixel;	    /* default Color of normal text */
332 
333 #ifdef FEAT_GUI_X11
334     char	*rsrc_menu_fg_name;	/* Color of menu & dialog foreground */
335     guicolor_T	menu_fg_pixel;		/* Same in Pixel format */
336     char	*rsrc_menu_bg_name;	/* Color of menu & dialog background */
337     guicolor_T	menu_bg_pixel;		/* Same in Pixel format */
338     char	*rsrc_scroll_fg_name;	/* Color of scrollbar foreground */
339     guicolor_T	scroll_fg_pixel;	/* Same in Pixel format */
340     char	*rsrc_scroll_bg_name;	/* Color of scrollbar background */
341     guicolor_T	scroll_bg_pixel;	/* Same in Pixel format */
342 
343 # ifdef FEAT_GUI_MOTIF
344     guicolor_T	menu_def_fg_pixel;  /* Default menu foreground */
345     guicolor_T	menu_def_bg_pixel;  /* Default menu background */
346     guicolor_T	scroll_def_fg_pixel;  /* Default scrollbar foreground */
347     guicolor_T	scroll_def_bg_pixel;  /* Default scrollbar background */
348 # endif
349     Display	*dpy;		    /* X display */
350     Window	wid;		    /* Window id of text area */
351     int		visibility;	    /* Is shell partially/fully obscured? */
352     GC		text_gc;
353     GC		back_gc;
354     GC		invert_gc;
355     Cursor	blank_pointer;	    /* Blank pointer */
356 
357     /* X Resources */
358     char_u	*rsrc_font_name;    /* Resource font name, used if 'guifont'
359 				       not set */
360     char_u	*rsrc_bold_font_name; /* Resource bold font name */
361     char_u	*rsrc_ital_font_name; /* Resource italic font name */
362     char_u	*rsrc_boldital_font_name;  /* Resource bold-italic font name */
363     char_u	*rsrc_menu_font_name;    /* Resource menu Font name */
364     Bool	rsrc_rev_video;	    /* Use reverse video? */
365 
366     char_u	*geom;		    /* Geometry, eg "80x24" */
367     Bool	color_approx;	    /* Some color was approximated */
368 #endif
369 
370 #ifdef FEAT_GUI_GTK
371 # ifndef USE_GTK3
372     int		visibility;	    /* Is shell partially/fully obscured? */
373 # endif
374     GdkCursor	*blank_pointer;	    /* Blank pointer */
375 
376     /* X Resources */
377     char_u	*geom;		    /* Geometry, eg "80x24" */
378 
379     GtkWidget	*mainwin;	    /* top level GTK window */
380     GtkWidget	*formwin;	    /* manages all the windows below */
381     GtkWidget	*drawarea;	    /* the "text" area */
382 # ifdef FEAT_MENU
383     GtkWidget	*menubar;	    /* menubar */
384 # endif
385 # ifdef FEAT_TOOLBAR
386     GtkWidget	*toolbar;	    /* toolbar */
387 # endif
388 # ifdef FEAT_GUI_GNOME
389     GtkWidget	*menubar_h;	    /* menubar handle */
390     GtkWidget	*toolbar_h;	    /* toolbar handle */
391 # endif
392 # ifdef USE_GTK3
393     GdkRGBA	*fgcolor;	    /* GDK-styled foreground color */
394     GdkRGBA	*bgcolor;	    /* GDK-styled background color */
395     GdkRGBA	*spcolor;	    /* GDK-styled special color */
396 # else
397     GdkColor	*fgcolor;	    /* GDK-styled foreground color */
398     GdkColor	*bgcolor;	    /* GDK-styled background color */
399     GdkColor	*spcolor;	    /* GDK-styled special color */
400 # endif
401 # ifdef USE_GTK3
402     cairo_surface_t *surface;       /* drawarea surface */
403     gboolean	     by_signal;     /* cause of draw operation */
404 # else
405     GdkGC	*text_gc;	    /* cached GC for normal text */
406 # endif
407     PangoContext     *text_context; /* the context used for all text */
408     PangoFont	     *ascii_font;   /* cached font for ASCII strings */
409     PangoGlyphString *ascii_glyphs; /* cached code point -> glyph map */
410 # ifdef FEAT_GUI_TABLINE
411     GtkWidget	*tabline;	    /* tab pages line handle */
412 # endif
413 
414     GtkAccelGroup *accel_group;
415     GtkWidget	*filedlg;	    /* file selection dialog */
416     char_u	*browse_fname;	    /* file name from filedlg */
417 
418     guint32	event_time;
419 #endif	/* FEAT_GUI_GTK */
420 
421 #if defined(FEAT_GUI_TABLINE) \
422 	&& (defined(FEAT_GUI_MSWIN) || defined(FEAT_GUI_MOTIF) \
423 		|| defined(FEAT_GUI_MAC))
424     int		tabline_height;
425 #endif
426 
427 #ifdef FEAT_FOOTER
428     int		footer_height;	    /* height of the message footer */
429 #endif
430 
431 #if defined(FEAT_TOOLBAR) \
432 	&& (defined(FEAT_GUI_ATHENA) || defined(FEAT_GUI_MOTIF))
433     int		toolbar_height;	    /* height of the toolbar */
434 #endif
435 
436 #ifdef FEAT_BEVAL_TIP
437     /* Tooltip properties; also used for balloon evaluation */
438     char_u	*rsrc_tooltip_font_name; /* tooltip font name */
439     char	*rsrc_tooltip_fg_name;	/* tooltip foreground color name */
440     char	*rsrc_tooltip_bg_name;	/* tooltip background color name */
441     guicolor_T	tooltip_fg_pixel;	/* tooltip foreground color */
442     guicolor_T	tooltip_bg_pixel;	/* tooltip background color */
443     XFontSet	tooltip_fontset;	/* tooltip fontset */
444 #endif
445 
446 #ifdef FEAT_GUI_MSWIN
447     GuiFont	currFont;	    /* Current font */
448     guicolor_T	currFgColor;	    /* Current foreground text color */
449     guicolor_T	currBgColor;	    /* Current background text color */
450     guicolor_T	currSpColor;	    /* Current special text color */
451 #endif
452 
453 #ifdef FEAT_GUI_MAC
454     WindowPtr	VimWindow;
455     MenuHandle	MacOSHelpMenu;	    /* Help menu provided by the MacOS */
456     int		MacOSHelpItems;	    /* Nr of help-items supplied by MacOS */
457     WindowPtr	wid;		    /* Window id of text area */
458     int		visibility;	    /* Is window partially/fully obscured? */
459 #endif
460 
461 #ifdef FEAT_GUI_PHOTON
462     PtWidget_t	*vimWindow;		/* PtWindow */
463     PtWidget_t	*vimTextArea;		/* PtRaw */
464     PtWidget_t	*vimContainer;		/* PtPanel */
465 # if defined(FEAT_MENU) || defined(FEAT_TOOLBAR)
466     PtWidget_t	*vimToolBarGroup;
467 # endif
468 # ifdef FEAT_MENU
469     PtWidget_t	*vimMenuBar;
470 # endif
471 # ifdef FEAT_TOOLBAR
472     PtWidget_t	*vimToolBar;
473     int		toolbar_height;
474 # endif
475     PhEvent_t	*event_buffer;
476 #endif
477 
478 #ifdef FEAT_XIM
479     char	*rsrc_input_method;
480     char	*rsrc_preedit_type_name;
481 #endif
482 } gui_T;
483 
484 extern gui_T gui;			/* this is defined in gui.c */
485 
486 /* definitions of available window positionings for gui_*_position_in_parent()
487  */
488 typedef enum
489 {
490     VW_POS_MOUSE,
491     VW_POS_CENTER,
492     VW_POS_TOP_CENTER
493 } gui_win_pos_T;
494 
495 #ifdef FIND_REPLACE_DIALOG
496 /*
497  * Flags used to distinguish the different contexts in which the
498  * find/replace callback may be called.
499  */
500 # define FRD_FINDNEXT	1	/* Find next in find dialog */
501 # define FRD_R_FINDNEXT	2	/* Find next in repl dialog */
502 # define FRD_REPLACE	3	/* Replace once */
503 # define FRD_REPLACEALL	4	/* Replace remaining matches */
504 # define FRD_UNDO	5	/* Undo replaced text */
505 # define FRD_TYPE_MASK   7	/* Mask for the callback type */
506 /* Flags which change the way searching is done. */
507 # define FRD_WHOLE_WORD	0x08	/* match whole word only */
508 # define FRD_MATCH_CASE	0x10	/* match case */
509 #endif
510 
511 #ifdef FEAT_GUI_GTK
512 /*
513  * Convenience macros to convert from 'encoding' to 'termencoding' and
514  * vice versa.	If no conversion is necessary the passed-in pointer is
515  * returned as is, without allocating any memory.  Thus additional _FREE()
516  * macros are provided.  The _FREE() macros also set the pointer to NULL,
517  * in order to avoid bugs due to illegal memory access only happening if
518  * 'encoding' != utf-8...
519  *
520  * Defining these macros as pure expressions looks a bit tricky but
521  * avoids depending on the context of the macro expansion.  One of the
522  * rare occasions where the comma operator comes in handy :)
523  *
524  * Note: Do NOT keep the result around when handling control back to
525  * the main Vim!  The user could change 'encoding' at any time.
526  */
527 # define CONVERT_TO_UTF8(String)				\
528     ((output_conv.vc_type == CONV_NONE || (String) == NULL)	\
529 	    ? (String)						\
530 	    : string_convert(&output_conv, (String), NULL))
531 
532 # define CONVERT_TO_UTF8_FREE(String)				\
533     ((String) = ((output_conv.vc_type == CONV_NONE)		\
534 			? (char_u *)NULL			\
535 			: (vim_free(String), (char_u *)NULL)))
536 
537 # define CONVERT_FROM_UTF8(String)				\
538     ((input_conv.vc_type == CONV_NONE || (String) == NULL)	\
539 	    ? (String)						\
540 	    : string_convert(&input_conv, (String), NULL))
541 
542 # define CONVERT_FROM_UTF8_FREE(String)				\
543     ((String) = ((input_conv.vc_type == CONV_NONE)		\
544 			? (char_u *)NULL			\
545 			: (vim_free(String), (char_u *)NULL)))
546 
547 #else
548 # define CONVERT_TO_UTF8(String) (String)
549 # define CONVERT_TO_UTF8_FREE(String) ((String) = (char_u *)NULL)
550 # define CONVERT_FROM_UTF8(String) (String)
551 # define CONVERT_FROM_UTF8_FREE(String) ((String) = (char_u *)NULL)
552 #endif /* FEAT_GUI_GTK */
553 
554 #ifdef FEAT_GUI_GTK
555 /*
556  * The second parameter of g_signal_handlers_disconnect_by_func() is supposed
557  * to be a function pointer which was passed to g_signal_connect_*() somewhere
558  * previously, and hence it must be of type GCallback, i.e., void (*)(void).
559  *
560  * Meanwhile, g_signal_handlers_disconnect_by_func() is a macro calling
561  * g_signal_handlers_disconnect_matched(), and the second parameter of the
562  * former is to be passed to the sixth parameter of the latter the type of
563  * which, however, is declared as void * in the function signature.
564  *
565  * While the ISO C Standard does not require that function pointers be
566  * interconvertible to void *, widely-used compilers such as gcc and clang
567  * do such conversion implicitly and automatically on some platforms without
568  * issuing any warning.
569  *
570  * For Solaris Studio, that is not the case.  An explicit type cast is needed
571  * to suppress warnings on that particular conversion.
572  */
573 # if defined(__SUNPRO_C) && defined(USE_GTK3)
574 #  define FUNC2GENERIC(func) (void *)(func)
575 # else
576 #  define FUNC2GENERIC(func) G_CALLBACK(func)
577 # endif
578 #endif /* FEAT_GUI_GTK */
579 
580 #if defined(UNIX) && !defined(FEAT_GUI_MAC)
581 # define GUI_MAY_FORK
582 #endif
583