diff options
| author | Po Lu | 2023-01-13 15:53:08 +0800 |
|---|---|---|
| committer | Po Lu | 2023-01-13 15:53:08 +0800 |
| commit | f9732131cf3c67e24db74a3d49f256d3c189a7e3 (patch) | |
| tree | e44e097c0c4c513390f58fa0020c8662943fbac6 /java/debug.sh | |
| parent | 2fa5583d96fe78ff66d6fd41f18e54e4e20ea7d6 (diff) | |
| download | emacs-f9732131cf3c67e24db74a3d49f256d3c189a7e3.tar.gz emacs-f9732131cf3c67e24db74a3d49f256d3c189a7e3.zip | |
Update Android port
* configure.ac (ANDROID_MIN_SDK): New variable.
(DX): Remove and replace with D8.
(XCONFIGURE): Check for the minimum version of Android the cross
compiler compiles for. Generate java/AndroidManifest.xml from
java/AndroidManifest.xml.in. Allow using Zlib on Android.
* java/AndroidManifest.xml.in: New file. Use the minimum SDK
detected by configure.
* java/Makefile.in (top_srcdir, version): New variables.
(DX, D8): Replace with D8.
(ANDROID_MIN_SDK, APK_NAME): New variables.
(.PHONY):
(.PRECIOUS):
(classes.dex):
(emacs.apk): Generate $(APK_NAME) instead of `emacs.apk'.
* java/debug.sh: New option --attach-existing. Attach to an
existing Emacs instance when specified.
* java/org/gnu/emacs/EmacsActivity.java (EmacsActivity): New
field `isPaused'.
(invalidateFocus1): Fix infinite recursion.
(detachWindow): Deiconify window.
(attachWindow): Iconify the window if the activity is paused.
(onCreate): Use the ``no title bar'' theme.
(onPause, onResume): New functions.
* java/org/gnu/emacs/EmacsNative.java (sendTouchUp, sendTouchDown)
(sendTouchMove, sendWheel, sendIconified, sendDeiconified): New
functions.
* java/org/gnu/emacs/EmacsSdk7FontDriver.java (Sdk7Typeface):
(list): Remove logging for code that is mostly going to be unused.
* java/org/gnu/emacs/EmacsService.java (ringBell, queryTree)
(getScreenWidth, getScreenHeight, detectMouse): New functions.
* java/org/gnu/emacs/EmacsSurfaceView.java (EmacsSurfaceView)
(surfaceChanged, surfaceCreated, surfaceDestroyed): Add extra
debug logging. Avoid deadlock in surfaceCreated.
* java/org/gnu/emacs/EmacsView.java (EmacsView): Try very hard
to make the SurfaceView respect Z order. It didn't work.
(handleDirtyBitmap): Copy over the contents from the old bitmap.
(explicitlyDirtyBitmap): New function.
(onLayout): Don't dirty bitmap if unnecessary.
(damageRect, swapBuffers): Don't synchronize so hard.
(onTouchEvent): Call window.onTouchEvent instead.
(moveChildToBack, raise, lower): New functions.
* java/org/gnu/emacs/EmacsWindow.java (Coordinate): New
subclass.
(pointerMap, isMapped, isIconified, dontFocusOnMap)
(dontAcceptFocus): New fields.
(EmacsWindow): Don't immediately register unmapped window.
(viewLayout): Send configure event outside the lock.
(requestViewLayout): Explicitly dirty the bitmap.
(mapWindow): Register the window now. Respect dontFocusOnMap.
(unmapWindow): Unregister the window now.
(figureChange, onTouchEvent): New functions.
(onSomeKindOfMotionEvent): Handle scroll wheel events.
(reparentTo, makeInputFocus, raise, lower, getWindowGeometry)
(noticeIconified, noticeDeiconified, setDontAcceptFocus)
(setDontFocusOnMap, getDontFocusOnMap): New functions.
* java/org/gnu/emacs/EmacsWindowAttachmentManager.java
(registerWindow, detachWindow): Synchronize.
(noticeIconified, noticeDeiconified): New functions.
(copyWindows): New function.
* lisp/frame.el (frame-geometry, frame-edges)
(mouse-absolute-pixel-position, set-mouse-absolute-pixel-position)
(frame-list-z-order, frame-restack, display-mouse-p)
(display-monitor-attributes-list): Implement on Android.
* lisp/mwheel.el (mouse-wheel-down-event):
(mouse-wheel-up-event):
(mouse-wheel-left-event):
(mouse-wheel-right-event): Define on Android.
* src/android.c (struct android_emacs_service): New methods
`ringBell', `queryTree', `getScreenWidth', `getScreenHeight',
and `detectMouse'.
(struct android_event_queue, android_init_events)
(android_next_event, android_write_event): Remove write limit.
(android_file_access_p): Handle directories correcty.
(android_close): Fix coding style.
(android_fclose): New function.
(android_init_emacs_service): Initialize new methods.
(android_reparent_window): Implement function.
(android_bell, android_set_input_focus, android_raise_window)
(android_lower_window, android_query_tree, android_get_geometry)
(android_get_screen_width, android_get_screen_height)
(android_get_mm_width, android_get_mm_height, android_detect_mouse)
(android_set_dont_focus_on_map, android_set_dont_accept_focus):
New functions.
(struct android_dir): New structure.
(android_opendir, android_readdir, android_closedir): New
functions.
(emacs_abort): Implement here on Android and poke debuggerd into
generating a tombstone.
* src/android.h: Update prototypes.
* src/androidfns.c (android_set_parent_frame): New function.
(android_default_font_parameter): Use sane font size by default.
(Fx_display_pixel_width, Fx_display_pixel_height)
(Fx_display_mm_width, Fx_display_mm_height)
(Fx_display_monitor_attributes_list): Rename to start with
`android-'. Implement. Fiddle with documentation to introduce
Android specific nuances.
(Fandroid_display_monitor_attributes_list): New function.
(Fx_frame_geometry, frame_geometry): New function.
(Fandroid_frame_geometry): Implement correctly.
(Fx_frame_list_z_order): Rename to start with `android-'.
(android_frame_list_z_order, Fandroid_frame_list_z_order):
Implement.
(Fx_frame_restack): Rename to start with `android-'.
(Fandroid_frame_restack): ``Implement''.
(Fx_mouse_absolute_pixel_position): Rename to start with
`android-'.
(Fandroid_mouse_absolute_pixel_position): ``Implement''.
(Fx_set_mouse_absolute_pixel_position): Rename to start with
`android-'.
(Fandroid_set_mouse_absolute_pixel_position): ``Implement''.
(Fandroid_detect_mouse): New function.
(android_set_menu_bar_lines): Use FRAME_ANDROID_DRAWABLE when
clearing area.
(android_set_no_focus_on_map, android_set_no_accept_focus): New
functions.
(android_frame_parm_handlers): Register new frame parameter
handlers.
(syms_of_androidfns): Update appropriately.
* src/androidfont.c (androidfont_draw): Use
FRAME_ANDROID_DRAWABLE instead of FRAME_ANDROID_WINDOW.
* src/androidgui.h (enum android_event_type): New events.
(struct android_touch_event, struct android_wheel_event)
(struct android_iconify_event): New structures.
(union android_event): Add new events.
* src/androidterm.c (android_clear_frame): Use
FRAME_ANDROID_DRAWABLE instead of FRAME_ANDROID_WINDOW.
(android_flash, android_ring_bell): Implement bell ringing.
(android_toggle_invisible_pointer): Don't TODO function that
can't be implemented.
(show_back_buffer, android_flush_dirty_back_buffer_on): Check if
a buffer flip is required before doing the flip.
(android_lower_frame, android_raise_frame): Implement functions.
(android_update_tools, android_find_tool): New functions.
(handle_one_android_event): Handle new iconification, wheel and
touch events.
(android_read_socket): Implement pending-autoraise-frames.
(android_frame_up_to_date): Implement bell ringing.
(android_buffer_flipping_unblocked_hook): Check if a buffer flip
is required before doing the flip.
(android_focus_frame, android_frame_highlight)
(android_frame_unhighlight): New function.
(android_frame_rehighlight): Implement functions.
(android_iconify_frame): Always display error.
(android_set_alpha): Update commentary.
(android_free_frame_resources): Free frame touch points.
(android_scroll_run, android_flip_and_flush)
(android_clear_rectangle, android_draw_fringe_bitmap)
(android_draw_glyph_string_background, android_fill_triangle)
(android_clear_point, android_draw_relief_rect)
(android_draw_box_rect, android_draw_glyph_string_bg_rect)
(android_draw_image_foreground, android_draw_stretch_glyph_string)
(android_draw_underwave, android_draw_glyph_string_foreground)
(android_draw_composite_glyph_string_foreground)
(android_draw_glyphless_glyph_string_foreground)
(android_draw_glyph_string, android_clear_frame_area)
(android_clear_under_internal_border, android_draw_hollow_cursor)
(android_draw_bar_cursor, android_draw_vertical_window_border)
(android_draw_window_divider): Use FRAME_ANDROID_DRAWABLE
instead of FRAME_ANDROID_WINDOW for drawing operations.
* src/androidterm.h (struct android_touch_point): New structure.
(struct android_output): New fields.
(FRAME_ANDROID_NEED_BUFFER_FLIP): New macro.
* src/dired.c (emacs_readdir, open_directory)
(directory_files_internal_unwind, read_dirent)
(directory_files_internal, file_name_completion): Add
indirection over readdir and opendir. Use android variants on
Android.
* src/dispnew.c (Fopen_termscript):
* src/fileio.c (fclose_unwind): Use emacs_fclose.
(Faccess_file): Call android_file_access_p.
(file_accessible_directory_p): Append right suffix to Android
assets directory.
(do_auto_save_unwind): Use emacs_fclose.
* src/keyboard.c (lispy_function_keys): Use right function key
for page up and page down.
(Fopen_dribble_file): Use emacs_fclose.
* src/lisp.h: New prototype emacs_fclose.
* src/lread.c (close_infile_unwind): Use emacs_fclose.
* src/sfnt.c (sfnt_curve_is_flat): Fix area-squared computation.
(sfnt_prepare_raster): Compute raster width and height
consistently with outline building.
(sfnt_build_outline_edges): Use the same offsets used to set
offy and offx.
(main): Adjust debug code.
* src/sfntfont-android.c (sfntfont_android_saturate32): Delete
function.
(sfntfont_android_blend, sfntfont_android_blendrgb): Remove
unnecessary debug code.
(sfntfont_android_composite_bitmap): Prevent out of bounds
write.
(sfntfont_android_put_glyphs): Use FRAME_ANDROID_DRAWABLE.
(init_sfntfont_android): Initialize Monospace Serif font to
something sensible.
* src/sfntfont.c (sfntfont_text_extents): Clear glyph metrics
before summing up pcm.
(sfntfont_draw): Use s->font instead of s->face->font.
* src/sysdep.c (emacs_fclose): Wrap around android_fclose on
android.
* src/term.c (Fsuspend_tty):
(delete_tty): Use emacs_fclose.
* src/verbose.mk.in (AM_V_DX): Replace with D8 version.
Diffstat (limited to 'java/debug.sh')
| -rwxr-xr-x | java/debug.sh | 45 |
1 files changed, 26 insertions, 19 deletions
diff --git a/java/debug.sh b/java/debug.sh index dd710dc31af..3e3e3d9c281 100755 --- a/java/debug.sh +++ b/java/debug.sh | |||
| @@ -30,6 +30,7 @@ activity=org.gnu.emacs.EmacsActivity | |||
| 30 | gdb_port=5039 | 30 | gdb_port=5039 |
| 31 | jdb_port=64013 | 31 | jdb_port=64013 |
| 32 | jdb=no | 32 | jdb=no |
| 33 | attach_existing=no | ||
| 33 | 34 | ||
| 34 | while [ $# -gt 0 ]; do | 35 | while [ $# -gt 0 ]; do |
| 35 | case "$1" in | 36 | case "$1" in |
| @@ -48,6 +49,7 @@ while [ $# -gt 0 ]; do | |||
| 48 | echo " --port PORT run the GDB server on a specific port" | 49 | echo " --port PORT run the GDB server on a specific port" |
| 49 | echo " --jdb-port PORT run the JDB server on a specific port" | 50 | echo " --jdb-port PORT run the JDB server on a specific port" |
| 50 | echo " --jdb run JDB instead of GDB" | 51 | echo " --jdb run JDB instead of GDB" |
| 52 | echo " --attach-existing attach to an existing process" | ||
| 51 | echo " --help print this message" | 53 | echo " --help print this message" |
| 52 | echo "" | 54 | echo "" |
| 53 | echo "Available devices:" | 55 | echo "Available devices:" |
| @@ -63,6 +65,9 @@ while [ $# -gt 0 ]; do | |||
| 63 | "--port" ) | 65 | "--port" ) |
| 64 | gdb_port=$1 | 66 | gdb_port=$1 |
| 65 | ;; | 67 | ;; |
| 68 | "--attach-existing" ) | ||
| 69 | attach_existing=yes | ||
| 70 | ;; | ||
| 66 | "--" ) | 71 | "--" ) |
| 67 | shift | 72 | shift |
| 68 | gdbargs=$@ | 73 | gdbargs=$@ |
| @@ -120,30 +125,32 @@ package_pids=`awk -- '{ | |||
| 120 | print $1 | 125 | print $1 |
| 121 | }' <<< $package_pids` | 126 | }' <<< $package_pids` |
| 122 | 127 | ||
| 123 | # Finally, kill each existing process. | 128 | if [ "$attach_existing" != "yes" ]; then |
| 124 | for pid in $package_pids; do | 129 | # Finally, kill each existing process. |
| 125 | echo "Killing existing process $pid..." | 130 | for pid in $package_pids; do |
| 126 | adb -s $device shell run-as $package kill -9 $pid &> /dev/null | 131 | echo "Killing existing process $pid..." |
| 127 | done | 132 | adb -s $device shell run-as $package kill -9 $pid &> /dev/null |
| 128 | 133 | done | |
| 129 | # Now run the main activity. This must be done as the adb user and | 134 | |
| 130 | # not as the package user. | 135 | # Now run the main activity. This must be done as the adb user and |
| 131 | echo "Starting activity $activity and attaching debugger" | 136 | # not as the package user. |
| 132 | 137 | echo "Starting activity $activity and attaching debugger" | |
| 133 | # Exit if the activity could not be started. | 138 | |
| 134 | adb -s $device shell am start -D "$package/$activity" | 139 | # Exit if the activity could not be started. |
| 135 | if [ ! $? ]; then | 140 | adb -s $device shell am start -D "$package/$activity" |
| 136 | exit 1; | 141 | if [ ! $? ]; then |
| 137 | fi | 142 | exit 1; |
| 143 | fi | ||
| 138 | 144 | ||
| 139 | # Now look for processes matching the package again. | 145 | # Now look for processes matching the package again. |
| 140 | package_pids=`adb -s $device shell run-as $package ps -u $package_uid -o PID,CMD` | 146 | package_pids=`adb -s $device shell run-as $package ps -u $package_uid -o PID,CMD` |
| 141 | 147 | ||
| 142 | # Next, remove lines matching "ps" itself. | 148 | # Next, remove lines matching "ps" itself. |
| 143 | package_pids=`awk -- '{ | 149 | package_pids=`awk -- '{ |
| 144 | if (!match ($0, /(PID|ps)/)) | 150 | if (!match ($0, /(PID|ps)/)) |
| 145 | print $1 | 151 | print $1 |
| 146 | }' <<< $package_pids` | 152 | }' <<< $package_pids` |
| 153 | fi | ||
| 147 | 154 | ||
| 148 | pid=$package_pids | 155 | pid=$package_pids |
| 149 | num_pids=`wc -w <<< "$package_pids"` | 156 | num_pids=`wc -w <<< "$package_pids"` |