diff options
Diffstat (limited to 'src/androidterm.h')
| -rw-r--r-- | src/androidterm.h | 366 |
1 files changed, 366 insertions, 0 deletions
diff --git a/src/androidterm.h b/src/androidterm.h new file mode 100644 index 00000000000..3a0c9f60555 --- /dev/null +++ b/src/androidterm.h | |||
| @@ -0,0 +1,366 @@ | |||
| 1 | /* Communication module for Android terminals. | ||
| 2 | |||
| 3 | Copyright (C) 2023 Free Software Foundation, Inc. | ||
| 4 | |||
| 5 | This file is part of GNU Emacs. | ||
| 6 | |||
| 7 | GNU Emacs is free software: you can redistribute it and/or modify | ||
| 8 | it under the terms of the GNU General Public License as published by | ||
| 9 | the Free Software Foundation, either version 3 of the License, or (at | ||
| 10 | your option) any later version. | ||
| 11 | |||
| 12 | GNU Emacs is distributed in the hope that it will be useful, | ||
| 13 | but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 14 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 15 | GNU General Public License for more details. | ||
| 16 | |||
| 17 | You should have received a copy of the GNU General Public License | ||
| 18 | along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>. */ | ||
| 19 | |||
| 20 | #ifndef _ANDROID_TERM_H_ | ||
| 21 | #define _ANDROID_TERM_H_ | ||
| 22 | |||
| 23 | #include "androidgui.h" | ||
| 24 | #include "frame.h" | ||
| 25 | #include "character.h" | ||
| 26 | #include "dispextern.h" | ||
| 27 | #include "font.h" | ||
| 28 | |||
| 29 | struct android_bitmap_record | ||
| 30 | { | ||
| 31 | /* The image backing the bitmap. */ | ||
| 32 | Emacs_Pixmap img; | ||
| 33 | |||
| 34 | /* The file from which it comes. */ | ||
| 35 | char *file; | ||
| 36 | |||
| 37 | /* The number of references to it. */ | ||
| 38 | int refcount; | ||
| 39 | |||
| 40 | /* The height and width. */ | ||
| 41 | int height, width; | ||
| 42 | }; | ||
| 43 | |||
| 44 | struct android_display_info | ||
| 45 | { | ||
| 46 | /* Chain of all struct android_display_info structures. */ | ||
| 47 | struct android_display_info *next; | ||
| 48 | |||
| 49 | /* The terminal. */ | ||
| 50 | struct terminal *terminal; | ||
| 51 | |||
| 52 | /* The root window. This field is unused. */ | ||
| 53 | Emacs_Window root_window; | ||
| 54 | |||
| 55 | /* List possibly used only for the font cache but probably used for | ||
| 56 | something else too. */ | ||
| 57 | Lisp_Object name_list_element; | ||
| 58 | |||
| 59 | /* List of predefined X colors. */ | ||
| 60 | Lisp_Object color_map; | ||
| 61 | |||
| 62 | /* DPI of the display. */ | ||
| 63 | double resx, resy; | ||
| 64 | |||
| 65 | /* Scratch GC for drawing a cursor in a non-default face. */ | ||
| 66 | struct android_gc *scratch_cursor_gc; | ||
| 67 | |||
| 68 | /* Mouse highlight information. */ | ||
| 69 | Mouse_HLInfo mouse_highlight; | ||
| 70 | |||
| 71 | /* Number of planes on this screen. Always 24. */ | ||
| 72 | int n_planes; | ||
| 73 | |||
| 74 | /* Mask of things causing the mouse to be grabbed. */ | ||
| 75 | int grabbed; | ||
| 76 | |||
| 77 | /* Minimum width over all characters in all fonts in font_table. */ | ||
| 78 | int smallest_char_width; | ||
| 79 | |||
| 80 | /* Minimum font height over all fonts in font_table. */ | ||
| 81 | int smallest_font_height; | ||
| 82 | |||
| 83 | /* The number of fonts opened for this display. */ | ||
| 84 | int n_fonts; | ||
| 85 | |||
| 86 | /* Pointer to bitmap records. */ | ||
| 87 | struct android_bitmap_record *bitmaps; | ||
| 88 | |||
| 89 | /* Allocated size of bitmaps field. */ | ||
| 90 | ptrdiff_t bitmaps_size; | ||
| 91 | |||
| 92 | /* Last used bitmap index. */ | ||
| 93 | ptrdiff_t bitmaps_last; | ||
| 94 | |||
| 95 | /* The frame currently with the input focus. */ | ||
| 96 | struct frame *focus_frame; | ||
| 97 | |||
| 98 | /* The frame which currently has the visual highlight, and should | ||
| 99 | get keyboard input. It points to the focus frame's selected | ||
| 100 | window's frame, but can differ. */ | ||
| 101 | struct frame *highlight_frame; | ||
| 102 | |||
| 103 | /* The frame waiting to be auto-raised in android_read_socket. */ | ||
| 104 | struct frame *pending_autoraise_frame; | ||
| 105 | |||
| 106 | /* The frame where the mouse was the last time a button event | ||
| 107 | happened. */ | ||
| 108 | struct frame *last_mouse_frame; | ||
| 109 | |||
| 110 | /* The frame where the mouse was the last time the mouse glyph | ||
| 111 | changed. */ | ||
| 112 | struct frame *last_mouse_glyph_frame; | ||
| 113 | |||
| 114 | /* The frame where the mouse was the last time mouse motion | ||
| 115 | happened. */ | ||
| 116 | struct frame *last_mouse_motion_frame; | ||
| 117 | |||
| 118 | /* Position where the mouse was last time we reported a motion. | ||
| 119 | This is a position on last_mouse_motion_frame. It is used in to | ||
| 120 | report the mouse position as well: see | ||
| 121 | android_mouse_position. */ | ||
| 122 | int last_mouse_motion_x, last_mouse_motion_y; | ||
| 123 | |||
| 124 | /* Where the mouse was the last time the mouse moved. */ | ||
| 125 | Emacs_Rectangle last_mouse_glyph; | ||
| 126 | }; | ||
| 127 | |||
| 128 | struct android_output | ||
| 129 | { | ||
| 130 | /* Graphics contexts for the default font. */ | ||
| 131 | struct android_gc *normal_gc, *reverse_gc, *cursor_gc; | ||
| 132 | |||
| 133 | /* The window used for this frame. */ | ||
| 134 | Emacs_Window window; | ||
| 135 | |||
| 136 | /* Unused field. */ | ||
| 137 | Emacs_Window parent_desc; | ||
| 138 | |||
| 139 | /* Default ASCII font of this frame. */ | ||
| 140 | struct font *font; | ||
| 141 | |||
| 142 | /* The baseline offset of the default ASCII font. */ | ||
| 143 | int baseline_offset; | ||
| 144 | |||
| 145 | /* If a fontset is specified for this frame instead of font, this | ||
| 146 | value contains an ID of the fontset, else -1. */ | ||
| 147 | int fontset; | ||
| 148 | |||
| 149 | /* Various colors. */ | ||
| 150 | unsigned long cursor_pixel; | ||
| 151 | unsigned long cursor_foreground_pixel; | ||
| 152 | |||
| 153 | /* Foreground color for scroll bars. A value of -1 means use the | ||
| 154 | default (black for non-toolkit scroll bars). */ | ||
| 155 | unsigned long scroll_bar_foreground_pixel; | ||
| 156 | |||
| 157 | /* Background color for scroll bars. A value of -1 means use the | ||
| 158 | default (background color of the frame for non-toolkit scroll | ||
| 159 | bars). */ | ||
| 160 | unsigned long scroll_bar_background_pixel; | ||
| 161 | |||
| 162 | /* Unused stuff (cursors). */ | ||
| 163 | Emacs_Cursor text_cursor; | ||
| 164 | Emacs_Cursor nontext_cursor; | ||
| 165 | Emacs_Cursor modeline_cursor; | ||
| 166 | Emacs_Cursor hand_cursor; | ||
| 167 | Emacs_Cursor hourglass_cursor; | ||
| 168 | Emacs_Cursor horizontal_drag_cursor; | ||
| 169 | Emacs_Cursor vertical_drag_cursor; | ||
| 170 | Emacs_Cursor current_cursor; | ||
| 171 | Emacs_Cursor left_edge_cursor; | ||
| 172 | Emacs_Cursor top_left_corner_cursor; | ||
| 173 | Emacs_Cursor top_edge_cursor; | ||
| 174 | Emacs_Cursor top_right_corner_cursor; | ||
| 175 | Emacs_Cursor right_edge_cursor; | ||
| 176 | Emacs_Cursor bottom_right_corner_cursor; | ||
| 177 | Emacs_Cursor bottom_edge_cursor; | ||
| 178 | Emacs_Cursor bottom_left_corner_cursor; | ||
| 179 | |||
| 180 | /* This is the Emacs structure for the display this frame is on. */ | ||
| 181 | struct android_display_info *display_info; | ||
| 182 | |||
| 183 | /* True if this frame was ever previously visible. */ | ||
| 184 | bool_bf has_been_visible : 1; | ||
| 185 | |||
| 186 | /* True if this frame's alpha value is the same for both the active | ||
| 187 | and inactive states. */ | ||
| 188 | bool_bf alpha_identical_p : 1; | ||
| 189 | |||
| 190 | /* Flag that indicates whether we've modified the back buffer and | ||
| 191 | need to publish our modifications to the front buffer at a | ||
| 192 | convenient time. */ | ||
| 193 | bool_bf need_buffer_flip : 1; | ||
| 194 | |||
| 195 | /* Flag that indicates whether or not the frame contents are | ||
| 196 | complete and can be safely flushed while handling async | ||
| 197 | input. */ | ||
| 198 | bool_bf complete : 1; | ||
| 199 | |||
| 200 | /* Relief GCs, colors etc. */ | ||
| 201 | struct relief { | ||
| 202 | struct android_gc *gc; | ||
| 203 | unsigned long pixel; | ||
| 204 | } black_relief, white_relief; | ||
| 205 | |||
| 206 | /* The background for which the above relief GCs were set up. | ||
| 207 | They are changed only when a different background is involved. */ | ||
| 208 | unsigned long relief_background; | ||
| 209 | }; | ||
| 210 | |||
| 211 | /* Return the Android output data for frame F. */ | ||
| 212 | #define FRAME_ANDROID_OUTPUT(f) ((f)->output_data.android) | ||
| 213 | #define FRAME_OUTPUT_DATA(f) ((f)->output_data.android) | ||
| 214 | |||
| 215 | /* Return the Android window used for displaying data in frame F. */ | ||
| 216 | #define FRAME_ANDROID_WINDOW(f) ((f)->output_data.android->window) | ||
| 217 | #define FRAME_NATIVE_WINDOW(f) ((f)->output_data.android->window) | ||
| 218 | |||
| 219 | /* Return the need-buffer-flip flag for frame F. */ | ||
| 220 | #define FRAME_ANDROID_NEED_BUFFER_FLIP(f) \ | ||
| 221 | ((f)->output_data.android->need_buffer_flip) | ||
| 222 | |||
| 223 | /* Return whether or not the frame F has been completely drawn. Used | ||
| 224 | while handling async input. */ | ||
| 225 | #define FRAME_ANDROID_COMPLETE_P(f) \ | ||
| 226 | ((f)->output_data.android->complete) | ||
| 227 | |||
| 228 | #define FRAME_FONT(f) ((f)->output_data.android->font) | ||
| 229 | #define FRAME_FONTSET(f) ((f)->output_data.android->fontset) | ||
| 230 | |||
| 231 | #define FRAME_BASELINE_OFFSET(f) \ | ||
| 232 | ((f)->output_data.android->baseline_offset) | ||
| 233 | |||
| 234 | /* This gives the android_display_info structure for the display F is | ||
| 235 | on. */ | ||
| 236 | #define FRAME_DISPLAY_INFO(f) ((f)->output_data.android->display_info) | ||
| 237 | |||
| 238 | /* Some things for X compatibility. */ | ||
| 239 | #define BLACK_PIX_DEFAULT(f) 0 | ||
| 240 | #define WHITE_PIX_DEFAULT(f) 0xffffffff | ||
| 241 | |||
| 242 | /* Android-specific scroll bar stuff. */ | ||
| 243 | |||
| 244 | /* We represent scroll bars as lisp vectors. This allows us to place | ||
| 245 | references to them in windows without worrying about whether we'll | ||
| 246 | end up with windows referring to dead scroll bars; the garbage | ||
| 247 | collector will free it when its time comes. | ||
| 248 | |||
| 249 | We use struct scroll_bar as a template for accessing fields of the | ||
| 250 | vector. */ | ||
| 251 | |||
| 252 | struct scroll_bar | ||
| 253 | { | ||
| 254 | /* These fields are shared by all vectors. */ | ||
| 255 | union vectorlike_header header; | ||
| 256 | |||
| 257 | /* The window we're a scroll bar for. */ | ||
| 258 | Lisp_Object window; | ||
| 259 | |||
| 260 | /* The next and previous in the chain of scroll bars in this frame. */ | ||
| 261 | Lisp_Object next, prev; | ||
| 262 | |||
| 263 | /* Fields after 'prev' are not traced by the GC. */ | ||
| 264 | |||
| 265 | /* The X window representing this scroll bar. */ | ||
| 266 | Emacs_Window x_window; | ||
| 267 | |||
| 268 | /* The position and size of the scroll bar in pixels, relative to the | ||
| 269 | frame. */ | ||
| 270 | int top, left, width, height; | ||
| 271 | |||
| 272 | /* The starting and ending positions of the handle, relative to the | ||
| 273 | handle area (i.e. zero is the top position, not | ||
| 274 | SCROLL_BAR_TOP_BORDER). If they're equal, that means the handle | ||
| 275 | hasn't been drawn yet. | ||
| 276 | |||
| 277 | These are not actually the locations where the beginning and end | ||
| 278 | are drawn; in order to keep handles from becoming invisible when | ||
| 279 | editing large files, we establish a minimum height by always | ||
| 280 | drawing handle bottoms VERTICAL_SCROLL_BAR_MIN_HANDLE pixels below | ||
| 281 | where they would be normally; the bottom and top are in a | ||
| 282 | different coordinate system. */ | ||
| 283 | int start, end; | ||
| 284 | |||
| 285 | /* If the scroll bar handle is currently being dragged by the user, | ||
| 286 | this is the number of pixels from the top of the handle to the | ||
| 287 | place where the user grabbed it. If the handle isn't currently | ||
| 288 | being dragged, this is -1. */ | ||
| 289 | int dragging; | ||
| 290 | |||
| 291 | /* True if the scroll bar is horizontal. */ | ||
| 292 | bool horizontal; | ||
| 293 | }; | ||
| 294 | |||
| 295 | /* Turning a lisp vector value into a pointer to a struct scroll_bar. */ | ||
| 296 | #define XSCROLL_BAR(vec) ((struct scroll_bar *) XVECTOR (vec)) | ||
| 297 | |||
| 298 | |||
| 299 | |||
| 300 | /* This is a chain of structures for all the Android displays | ||
| 301 | currently in use. There is only ever one, but the rest of Emacs is | ||
| 302 | written with systems on which there can be many in mind. */ | ||
| 303 | extern struct android_display_info *x_display_list; | ||
| 304 | |||
| 305 | |||
| 306 | |||
| 307 | /* Start of function definitions. These should be a neat subset of | ||
| 308 | the same ones in xterm.h, and come in the same order. */ | ||
| 309 | |||
| 310 | /* From androidfns.c. */ | ||
| 311 | |||
| 312 | extern void android_free_gcs (struct frame *); | ||
| 313 | extern void android_default_font_parameter (struct frame *, Lisp_Object); | ||
| 314 | |||
| 315 | /* Defined in androidterm.c. */ | ||
| 316 | |||
| 317 | extern void android_term_init (void); | ||
| 318 | extern void android_set_window_size (struct frame *, bool, int, int); | ||
| 319 | extern void android_iconify_frame (struct frame *); | ||
| 320 | extern void android_make_frame_visible (struct frame *); | ||
| 321 | extern void android_make_frame_invisible (struct frame *); | ||
| 322 | extern void android_free_frame_resources (struct frame *); | ||
| 323 | |||
| 324 | extern int android_parse_color (struct frame *, const char *, | ||
| 325 | Emacs_Color *); | ||
| 326 | extern bool android_alloc_nearest_color (struct frame *, Emacs_Color *); | ||
| 327 | extern void android_query_colors (struct frame *, Emacs_Color *, int); | ||
| 328 | extern void android_clear_under_internal_border (struct frame *); | ||
| 329 | |||
| 330 | extern void syms_of_androidterm (void); | ||
| 331 | extern void mark_androidterm (void); | ||
| 332 | |||
| 333 | /* Defined in androidfns.c. */ | ||
| 334 | |||
| 335 | extern void android_change_tab_bar_height (struct frame *, int); | ||
| 336 | extern void android_change_tool_bar_height (struct frame *, int); | ||
| 337 | extern void android_set_scroll_bar_default_width (struct frame *); | ||
| 338 | extern void android_set_scroll_bar_default_height (struct frame *); | ||
| 339 | extern bool android_defined_color (struct frame *, const char *, | ||
| 340 | Emacs_Color *, bool, bool); | ||
| 341 | extern void android_implicitly_set_name (struct frame *, Lisp_Object, | ||
| 342 | Lisp_Object); | ||
| 343 | extern void android_explicitly_set_name (struct frame *, Lisp_Object, | ||
| 344 | Lisp_Object); | ||
| 345 | |||
| 346 | extern void syms_of_androidfns (void); | ||
| 347 | |||
| 348 | /* Defined in androidfont.c. */ | ||
| 349 | |||
| 350 | extern struct font_driver androidfont_driver; | ||
| 351 | |||
| 352 | extern void init_androidfont (void); | ||
| 353 | extern void syms_of_androidfont (void); | ||
| 354 | |||
| 355 | extern void android_finalize_font_entity (struct font_entity *); | ||
| 356 | |||
| 357 | |||
| 358 | |||
| 359 | #define RGB_TO_ULONG(r, g, b) (((r) << 16) | ((g) << 8) | (b)) | ||
| 360 | #define RED_FROM_ULONG(color) (((color) >> 16) & 0xff) | ||
| 361 | #define GREEN_FROM_ULONG(color) (((color) >> 8) & 0xff) | ||
| 362 | #define BLUE_FROM_ULONG(color) ((color) & 0xff) | ||
| 363 | |||
| 364 | |||
| 365 | |||
| 366 | #endif /* _ANDROID_TERM_H_ */ | ||