Merge branch 'dev' into m_10.13.0

This commit is contained in:
xtaodada 2024-06-03 22:42:40 +08:00
commit 657aa0e9e9
Signed by: xtaodada
GPG Key ID: 4CBB3F4FA8C85659
9 changed files with 233 additions and 20 deletions

211
.gitea/workflows/debug.yml Normal file
View File

@ -0,0 +1,211 @@
name: "Debug Build"
# Controls when the action will run.
on:
push:
branches:
- dev
paths-ignore:
- '**.md'
- '.github/**'
jobs:
ffmpeg:
name: Native Build (FFmpeg)
runs-on: ndk21
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Fetch Status
run: |
sed -i 's/\/\///g' settings.gradle
git submodule status TMessagesProj/jni/ffmpeg > ffmpeg_status
git submodule status TMessagesProj/jni/libvpx > libvpx_status
- name: FFmpeg Cache
id: cache
uses: actions/cache@v4
with:
path: |
TMessagesProj/jni/ffmpeg/build
TMessagesProj/jni/libvpx/build
key: ${{ hashFiles('ffmpeg_status', 'libvpx_status', 'TMessagesProj/jni/*ffmpeg*.sh', 'TMessagesProj/jni/*libvpx*.sh', 'TMessagesProj/jni/patches/ffmpeg/*') }}
- name: Install NDK
if: steps.cache.outputs.cache-hit != 'true'
run: |
echo "sdk.dir=${ANDROID_HOME}" > local.properties
echo "ndk.dir=${ANDROID_HOME}/ndk/21.4.7075529" >> local.properties
- name: Native Build
if: steps.cache.outputs.cache-hit != 'true'
run: |
sudo apt-get install yasm -y
./run init libs libvpx
./run init libs ffmpeg
boringssl:
name: Native Build (BoringSSL)
runs-on: ndk21
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Fetch Status
run: |
sed -i 's/\/\///g' settings.gradle
git submodule status TMessagesProj/jni/boringssl > boringssl_status
- name: BoringSSL Cache
id: cache
uses: actions/cache@v4
with:
path: |
TMessagesProj/jni/boringssl/build
key: ${{ hashFiles('boringssl_status') }}
- name: Install NDK
if: steps.cache.outputs.cache-hit != 'true'
run: |
echo "sdk.dir=${ANDROID_HOME}" > local.properties
echo "ndk.dir=${ANDROID_HOME}/ndk/21.4.7075529" >> local.properties
- name: Native Build
if: steps.cache.outputs.cache-hit != 'true'
run: |
apt install golang -y
./run init action boringssl
./run init libs boringssl
native:
name: Native Build (Telegram)
runs-on: ndk21
needs:
- ffmpeg
- boringssl
strategy:
matrix:
flavor:
- armeabi-v7a
- arm64-v8a
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Fetch Status
run: |
sed -i 's/\/\///g' settings.gradle
git submodule status TMessagesProj/jni/ffmpeg > ffmpeg_status
git submodule status TMessagesProj/jni/libvpx > libvpx_status
git submodule status TMessagesProj/jni/boringssl > boringssl_status
- name: Native Cache
id: cache
uses: actions/cache@v4
with:
path: |
TMessagesProj/src/main/libs
key: ${{ hashFiles('TMessagesProj/jni/**', 'ffmpeg_status', 'boringssl_status') }}-${{ matrix.flavor }}
- name: Checkout Library
if: steps.cache.outputs.cache-hit != 'true'
run: |
git submodule update --init 'TMessagesProj/jni/*'
- name: FFmpeg Cache
uses: actions/cache@v4
if: steps.cache.outputs.cache-hit != 'true'
with:
path: |
TMessagesProj/jni/ffmpeg/build
TMessagesProj/jni/libvpx/build
key: ${{ hashFiles('ffmpeg_status', 'libvpx_status', 'TMessagesProj/jni/*ffmpeg*.sh', 'TMessagesProj/jni/*libvpx*.sh', 'TMessagesProj/jni/patches/ffmpeg/*') }}
- name: BoringSSL Cache
uses: actions/cache@v4
if: steps.cache.outputs.cache-hit != 'true'
with:
path: |
TMessagesProj/jni/boringssl/build
key: ${{ hashFiles('boringssl_status') }}
- name: Install NDK
if: steps.cache.outputs.cache-hit != 'true'
run: |
echo "sdk.dir=${ANDROID_HOME}" > local.properties
echo "ndk.dir=${ANDROID_HOME}/ndk/21.4.7075529" >> local.properties
- name: Fix BoringSSL
if: steps.cache.outputs.cache-hit != 'true'
run: |
cd TMessagesProj/jni
./patch_boringssl.sh
- name: Native Build
if: steps.cache.outputs.cache-hit != 'true'
run: |
export NATIVE_TARGET="${{ matrix.flavor }}"
./run libs native
build:
name: Gradle Build
runs-on: ndk21
needs:
- native
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Install NDK
run: |
echo "sdk.dir=${ANDROID_HOME}" > local.properties
echo "ndk.dir=${ANDROID_HOME}/ndk/21.4.7075529" >> local.properties
- name: Fetch Status
run: |
sed -i 's/\/\///g' settings.gradle
git submodule status TMessagesProj/jni/ffmpeg > ffmpeg_status
git submodule status TMessagesProj/jni/boringssl > boringssl_status
- name: Native Cache (armeabi-v7a)
uses: actions/cache@v4
with:
path: |
TMessagesProj/src/main/libs
key: ${{ hashFiles('TMessagesProj/jni/**', 'ffmpeg_status', 'boringssl_status') }}-armeabi-v7a
- name: Native Cache (arm64-v8a)
uses: actions/cache@v4
with:
path: |
TMessagesProj/src/main/libs
key: ${{ hashFiles('TMessagesProj/jni/**', 'ffmpeg_status', 'boringssl_status') }}-arm64-v8a
- name: Configure Gradle
run: |
sed -i -e "s/16384/6144/g" gradle.properties
echo "sdk.dir=${ANDROID_HOME}" >> local.properties
- name: Gradle cache
uses: actions/cache@v4
with:
path: ~/.gradle
key: gradle-${{ hashFiles('**/*.gradle') }}
- name: Debug Build
run: |
export LOCAL_PROPERTIES="${{ secrets.LOCAL_PROPERTIES }}"
./gradlew TMessagesProj:assembleRelease
APK=$(find TMessagesProj/build/outputs/apk -name '*arm64-v8a*.apk')
APK=$(dirname $APK)
echo "APK=$APK" >> $GITHUB_ENV
- uses: actions/upload-artifact@v3
with:
name: Release
path: ${{ env.APK }}
upload:
name: Upload debug
if: github.event.inputs.upload != 'y'
runs-on: ndk21
needs:
- build
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Donwload Artifacts
uses: actions/download-artifact@v3
with:
path: artifacts
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: 3.12
- name: Send to Telegram
run: |
# send release via telegram bot api
export mini64=$(find artifacts -name "*arm64-v8a.apk")
export mini32=$(find artifacts -name "*armeabi-v7a.apk")
echo $mini64
echo $mini32
python -m pip install -r bin/scripts/requirements.txt
git log -1 --pretty=format:"%s%n%n%b" > artifacts/caption.txt
python bin/scripts/upload.py ${{ secrets.HELPER_BOT_TOKEN }} ${{ secrets.HELPER_BOT_TARGET }} test

View File

@ -423,7 +423,7 @@ public class ProfileChannelCell extends FrameLayout {
if (message != null) {
if (!usersToLoad.isEmpty()) {
storage.getUsersInternal(TextUtils.join(",", usersToLoad), users);
storage.getUsersInternal(usersToLoad, users);
}
if (!chatsToLoad.isEmpty()) {
storage.getChatsInternal(TextUtils.join(",", chatsToLoad), chats);

View File

@ -9711,7 +9711,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
int maxActionBarItems = (int) (Math.ceil(displayMetrics.widthPixels / (double) AndroidUtilities.dp(54))) - 2;
isActionBarTooNarrow = maxActionBarItems < 6;
actionModeViews.add(actionMode.addItemWithWidth(nkactionbarbtn_reply, R.drawable.msg_reply, AndroidUtilities.dp(54), LocaleController.getString("Reply", R.string.Reply)));
actionModeViews.add(actionMode.addItemWithWidth(nkactionbarbtn_reply, R.drawable.menu_reply, AndroidUtilities.dp(54), LocaleController.getString("Reply", R.string.Reply)));
actionModeViews.add(actionMode.addItemWithWidth(edit, R.drawable.msg_edit, AndroidUtilities.dp(54), LocaleController.getString("Edit", R.string.Edit)));
actionModeViews.add(actionMode.addItemWithWidth(nkactionbarbtn_selectBetween, R.drawable.ic_select_between, AndroidUtilities.dp(54), LocaleController.getString("SelectBetween", R.string.SelectBetween)));
actionModeViews.add(actionMode.addItemWithWidth(copy, R.drawable.msg_copy, AndroidUtilities.dp(54), LocaleController.getString("Copy", R.string.Copy)));
@ -18581,7 +18581,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
tagItem.setVisibility(getUserConfig().isPremium() && (
(editItem != null && editItem.getVisibility() == View.VISIBLE ? 1 : 0) +
(forwardItem != null && forwardItem.getVisibility() == View.VISIBLE ? 1 : 0) +
(saveItem != null && saveItem.getVisibility() == View.VISIBLE ? 1 : 0) +
// (saveItem != null && saveItem.getVisibility() == View.VISIBLE ? 1 : 0) +
(copyItem != null && copyItem.getVisibility() == View.VISIBLE ? 1 : 0) +
(deleteItem != null && deleteItem.getVisibility() == View.VISIBLE ? 1 : 0) +
(starItem != null && starItem.getVisibility() == View.VISIBLE ? 1 : 0) +
@ -32976,7 +32976,7 @@ public class ChatActivity extends BaseFragment implements NotificationCenter.Not
searchItem.setSearchFieldText(hashtag.substring(1), false);
searchItem.setSearchFieldHint(LocaleController.getString(R.string.SearchHashtagsHint));
}
getMediaDataController().searchMessagesInChat(searchingQuery, dialog_id, mergeDialogId, classGuid, 0, threadMessageId, false, searchingUserMessages, searchingChatMessages, false, searchingReaction);
getMediaDataController().searchMessagesInChat(searchingQuery, dialog_id, mergeDialogId, classGuid, 0, threadMessageId, false, searchingUserMessages, searchingChatMessages, false, searchingReaction, searchingType);
updatePinnedMessageView(true);
hashtagSearchEmptyView.showProgress(true);
showMessagesSearchListView(true);

View File

@ -2958,7 +2958,7 @@ public class ChatActivityEnterView extends BlurredFrameLayout implements Notific
if (!hasRecordVideo || calledRecordRunnable) {
startedDraggingX = -1;
if (hasRecordVideo && isInVideoMode) {
delegate.needStartRecordVideo(1, true, 0, voiceOnce ? 0x7FFFFFFF : 0);
delegate.needStartRecordVideo(1, true, 0, voiceOnce ? 0x7FFFFFFF : 0, 0);
} else {
if (recordingAudioVideo && isInScheduleMode()) {
AlertsCreator.createScheduleDatePickerDialog(parentActivity, parentFragment.getDialogId(), (notify, scheduleDate) -> MediaController.getInstance().stopRecording(1, notify, scheduleDate, voiceOnce), () -> MediaController.getInstance().stopRecording(0, false, 0, voiceOnce), null);

View File

@ -998,7 +998,7 @@ public class DeleteMessagesBottomSheet extends BottomSheetWithRecyclerListView {
}
});
applyInCommonGroup.performAction((participant, i) -> {
applyInCommonGroup.forEachSelected((participant, i) -> {
if (participant instanceof TLRPC.User) {
boolean needBan = banOrRestrict.checkOption(participant);
boolean needDelete = banOrRestrict.checkOption(participant);

View File

@ -43,6 +43,7 @@ import org.telegram.ui.Components.RecyclerListView;
import org.telegram.ui.Components.SizeNotifierFrameLayout;
import org.telegram.ui.Components.URLSpanNoUnderline;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Locale;
@ -198,7 +199,7 @@ public abstract class BaseNekoSettingsActivity extends BaseFragment {
}
@Override
protected void drawList(Canvas blurCanvas, boolean top) {
protected void drawList(Canvas blurCanvas, boolean top, ArrayList<IViewWithInvalidateCallback> views) {
for (int j = 0; j < listView.getChildCount(); j++) {
View child = listView.getChildAt(j);
if (child.getY() < listView.blurTopPadding + AndroidUtilities.dp(100)) {

View File

@ -235,7 +235,7 @@ public class NekoEmojiSettingsActivity extends BaseNekoSettingsActivity implemen
}
@Override
public void didSelectFiles(ArrayList<String> files, String caption, ArrayList<MessageObject> fMessages, boolean notify, int scheduleDate) {
public void didSelectFiles(ArrayList<String> files, String caption, ArrayList<MessageObject> fMessages, boolean notify, int scheduleDate, long effectId, boolean invertMedia) {
ArrayList<File> filesToUpload = new ArrayList<>();
for (String file : files) {
File f = new File(file);

View File

@ -111,7 +111,7 @@ public class StickerSizePreviewMessagesCell extends LinearLayout {
messageObjects[1].replyMessageObject = messageObjects[0];
for (int a = 0; a < cells.length; a++) {
cells[a] = new ChatMessageCell(context);
cells[a] = new ChatMessageCell(context, UserConfig.selectedAccount);
cells[a].setDelegate(new ChatMessageCell.ChatMessageCellDelegate() {
});
cells[a].isChat = false;

View File

@ -32,17 +32,18 @@ def get_caption() -> str:
def get_document() -> list["InputMediaDocument"]:
return [
InputMediaDocument(
media=str(find_apk("arm64-v8a")),
thumb=get_thumb(),
),
InputMediaDocument(
media=str(find_apk("armeabi-v7a")),
thumb=get_thumb(),
caption=get_caption(),
),
]
documents = []
abis = ["arm64-v8a", "armeabi-v7a"]
for abi in abis:
if apk := find_apk(abi):
documents.append(
InputMediaDocument(
media=str(apk),
thumb=get_thumb(),
)
)
documents[-1].caption = get_caption()
return documents
def retry(func):