mirror of
git://git.sv.gnu.org/emacs.git
synced 2026-02-01 13:21:11 -08:00
* java/org/gnu/emacs/EmacsClipboard.java (getClipboardData): Return an AssetFileDescriptor. * java/org/gnu/emacs/EmacsContextMenu.java (onMenuItemClick): Typo corrections in commentary. * java/org/gnu/emacs/EmacsOpenActivity.java (onCreate): Raise minimum version on which to read file descriptors from ParcelFileDescriptor objects to Honeycomb. * java/org/gnu/emacs/EmacsSdk11Clipboard.java (getClipboardData): Return the asset file descriptor. * java/org/gnu/emacs/EmacsSdk8Clipboard.java (getClipboardData): Adjust return type to match. * src/android.h (struct android_parcel_file_descriptor_class): Move from androidselect.c. * src/androidselect.c (fd_class): Export function. (android_init_emacs_clipboard): Adjust signature of getClipboardData. (android_init_asset_file_descriptor, close_asset_fd) (extract_fd_offsets): New functions. (Fandroid_get_clipboard_data): Extract file descriptor and offset from the AssetFileDescriptor here, rather than in getClipboardData. (init_androidselect): Call android_init_asset_file_descriptor. * src/androidvfs.c (android_init_fd_class): Export and enable calling this function more than once.
150 lines
3.6 KiB
Java
150 lines
3.6 KiB
Java
/* Communication module for Android terminals. -*- c-file-style: "GNU" -*-
|
|
|
|
Copyright (C) 2023-2024 Free Software Foundation, Inc.
|
|
|
|
This file is part of GNU Emacs.
|
|
|
|
GNU Emacs is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or (at
|
|
your option) any later version.
|
|
|
|
GNU Emacs is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>. */
|
|
|
|
package org.gnu.emacs;
|
|
|
|
/* Importing the entire package instead of just the legacy
|
|
ClipboardManager class avoids the deprecation warning. */
|
|
|
|
import android.text.*;
|
|
|
|
import android.content.Context;
|
|
import android.content.res.AssetFileDescriptor;
|
|
|
|
import android.util.Log;
|
|
|
|
import java.io.UnsupportedEncodingException;
|
|
|
|
/* This class implements EmacsClipboard for Android 2.2 and other
|
|
similarly old systems. */
|
|
|
|
@SuppressWarnings ("deprecation")
|
|
public final class EmacsSdk8Clipboard extends EmacsClipboard
|
|
{
|
|
private static final String TAG = "EmacsSdk8Clipboard";
|
|
private ClipboardManager manager;
|
|
|
|
public
|
|
EmacsSdk8Clipboard ()
|
|
{
|
|
String what;
|
|
Context context;
|
|
|
|
what = Context.CLIPBOARD_SERVICE;
|
|
context = EmacsService.SERVICE;
|
|
manager
|
|
= (ClipboardManager) context.getSystemService (what);
|
|
}
|
|
|
|
/* Set the clipboard text to CLIPBOARD, a string in UTF-8
|
|
encoding. */
|
|
|
|
@Override
|
|
public void
|
|
setClipboard (byte[] bytes)
|
|
{
|
|
try
|
|
{
|
|
manager.setText (new String (bytes, "UTF-8"));
|
|
}
|
|
catch (UnsupportedEncodingException exception)
|
|
{
|
|
Log.w (TAG, "setClipboard: " + exception);
|
|
}
|
|
}
|
|
|
|
/* Return whether or not Emacs owns the clipboard. Value is 1 if
|
|
Emacs does, 0 if Emacs does not, and -1 if that information is
|
|
unavailable. */
|
|
|
|
@Override
|
|
public int
|
|
ownsClipboard ()
|
|
{
|
|
return -1;
|
|
}
|
|
|
|
/* Return whether or not clipboard content currently exists. */
|
|
|
|
@Override
|
|
public boolean
|
|
clipboardExists ()
|
|
{
|
|
return manager.hasText ();
|
|
}
|
|
|
|
/* Return the current content of the clipboard, as plain text, or
|
|
NULL if no content is available. */
|
|
|
|
@Override
|
|
public byte[]
|
|
getClipboard ()
|
|
{
|
|
String string;
|
|
CharSequence text;
|
|
|
|
text = manager.getText ();
|
|
|
|
if (text == null)
|
|
return null;
|
|
|
|
string = text.toString ();
|
|
|
|
try
|
|
{
|
|
return string.getBytes ("UTF-8");
|
|
}
|
|
catch (UnsupportedEncodingException exception)
|
|
{
|
|
Log.w (TAG, "getClipboard: " + exception);
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
/* Return an array of targets currently provided by the
|
|
clipboard, or NULL if there are none. */
|
|
|
|
@Override
|
|
public byte[][]
|
|
getClipboardTargets ()
|
|
{
|
|
return null;
|
|
}
|
|
|
|
/* Return the clipboard data for the given target, or NULL if it
|
|
does not exist.
|
|
|
|
Value is normally an asset file descriptor, which in turn holds
|
|
three important values: the file descriptor, the start offset of
|
|
the data, and its length; length may be
|
|
AssetFileDescriptor.UNKNOWN_LENGTH, meaning that the data extends
|
|
from that offset to the end of the file.
|
|
|
|
Do not use this function to open text targets; use `getClipboard'
|
|
for that instead, as it will handle selection data consisting
|
|
solely of a URI. */
|
|
|
|
@Override
|
|
public AssetFileDescriptor
|
|
getClipboardData (byte[] target)
|
|
{
|
|
return null;
|
|
}
|
|
};
|