mirror of
https://github.com/TelegramMessenger/Telegram-iOS.git
synced 2026-07-05 19:28:46 +02:00
Squashed buildout of the tgcalls testbench: - CLI test tool with --mode p2p/reflector/group/group-churn, cross-version interop (--version, --version2), and quiet/summary output - Linux toolchain + Docker multi-stage build, AWS Fargate mass test harness, local parallel mass test harness with signaling loss simulation - SCTP writable gate, retransmission timer tuning, role-based handshake - InstanceV2CompatImpl (PeerConnection backend with V2Impl signaling) and SignalingTranslator for v14.0.0 interop - In-process Go/Pion SFU (ICE+DTLS+SRTP+SCTP per participant) with audio RTP forwarding, ActiveAudio/VideoSsrcs data channel broadcast, RTCP feedback path, and CGo c-archive integration - GroupInstanceReferenceImpl (PeerConnection group-call) and mixed-impl group mode (--reference-participants), with SDP munging for simulcast - H264 simulcast group video (FakeVideoTrackSource pattern generator, FakeVideoSink frame counting, --video flag, two-pass channel setup, reactive video setup from ActiveVideoSsrcs) - Group churn stress mode (--mode group-churn, --churn-cycles) - SFU stream-quality adaptation: BandwidthEstimator, LayerSelector state machine, RtxRingBuffer, simulcast SSRC rewrite - Transport-cc feedback generation, NetworkSimulator (delay/jitter/loss/ token-bucket bandwidth), --network-scenario step-down-up - CLAUDE.md updates throughout Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
202 lines
No EOL
5.5 KiB
Bash
202 lines
No EOL
5.5 KiB
Bash
#!/bin/bash
|
|
|
|
set -e
|
|
set -x
|
|
|
|
ARCH="$1"
|
|
|
|
SOURCE_DIR=$(echo "$(cd "$(dirname "$2")"; pwd -P)/$(basename "$2")")
|
|
BUILD_DIR=$(echo "$(cd "$(dirname "$3")"; pwd -P)/$(basename "$3")")
|
|
|
|
pushd "$BUILD_DIR"
|
|
|
|
set -e
|
|
devnull='> /dev/null 2>&1'
|
|
|
|
BUILD_ROOT="_iosbuild"
|
|
CONFIGURE_ARGS="--disable-docs
|
|
--disable-examples
|
|
--disable-postproc
|
|
--disable-webm-io
|
|
--disable-vp9-highbitdepth
|
|
--disable-vp9-postproc
|
|
--disable-vp9-temporal-denoising
|
|
--disable-unit-tests
|
|
--enable-realtime-only
|
|
--enable-multi-res-encoding
|
|
--size-limit=8192x8192"
|
|
DIST_DIR="_dist"
|
|
FRAMEWORK_DIR="VPX.framework"
|
|
FRAMEWORK_LIB="VPX.framework/VPX"
|
|
HEADER_DIR="${FRAMEWORK_DIR}/Headers/vpx"
|
|
SCRIPT_DIR="$SOURCE_DIR"
|
|
LIBVPX_SOURCE_DIR="$SOURCE_DIR"
|
|
|
|
|
|
ORIG_PWD="$(pwd)"
|
|
|
|
EXTRA_CONFIGURE_ARGS=""
|
|
|
|
if [ "$ARCH" = "armv7" ]; then
|
|
TARGETS="armv7-darwin-gcc"
|
|
LIPO=$(xcrun -sdk iphoneos${SDK} -find lipo)
|
|
elif [ "$ARCH" = "arm64" ]; then
|
|
TARGETS="arm64-darwin-gcc"
|
|
LIPO=$(xcrun -sdk iphoneos${SDK} -find lipo)
|
|
elif [ "$ARCH" = "sim_arm64" ]; then
|
|
TARGETS="arm64-iphonesimulator-gcc"
|
|
LIPO=$(xcrun -sdk iphoneos${SDK} -find lipo)
|
|
elif [ "$ARCH" = "macos_arm64" ]; then
|
|
TARGETS="arm64-darwin22-gcc"
|
|
LIPO=$(xcrun -sdk macosx -find lipo)
|
|
export SDKROOT=$(xcrun --sdk macosx --show-sdk-path)
|
|
elif [ "$ARCH" = "linux_arm64" ]; then
|
|
TARGETS="arm64-linux-gcc"
|
|
LIPO="cp"
|
|
EXTRA_CONFIGURE_ARGS="--enable-pic"
|
|
elif [ "$ARCH" = "linux_x86_64" ]; then
|
|
TARGETS="x86_64-linux-gcc"
|
|
LIPO="cp"
|
|
EXTRA_CONFIGURE_ARGS="--enable-pic"
|
|
elif [ "$ARCH" = "x86_64" ]; then
|
|
TARGETS="x86_64-iphonesimulator-gcc"
|
|
LIPO=$(xcrun -sdk iphoneos${SDK} -find lipo)
|
|
else
|
|
echo "Unsupported architecture $ARCH"
|
|
exit 1
|
|
fi
|
|
|
|
# Configures for the target specified by $1, and invokes make with the dist
|
|
# target using $DIST_DIR as the distribution output directory.
|
|
build_target() {
|
|
local target="$1"
|
|
local old_pwd="$(pwd)"
|
|
local target_specific_flags=""
|
|
|
|
case "${target}" in
|
|
x86-*)
|
|
target_specific_flags="--enable-pic"
|
|
;;
|
|
esac
|
|
|
|
mkdir "${target}"
|
|
cd "${target}"
|
|
eval "${LIBVPX_SOURCE_DIR}/configure" --target="${target}" \
|
|
${CONFIGURE_ARGS} ${EXTRA_CONFIGURE_ARGS} ${target_specific_flags} \
|
|
|
|
export DIST_DIR
|
|
eval make dist
|
|
cd "${old_pwd}"
|
|
}
|
|
|
|
# Returns the preprocessor symbol for the target specified by $1.
|
|
target_to_preproc_symbol() {
|
|
target="$1"
|
|
case "${target}" in
|
|
arm64-*)
|
|
echo "__aarch64__"
|
|
;;
|
|
armv7-*)
|
|
echo "__ARM_ARCH_7A__"
|
|
;;
|
|
x86_64-*)
|
|
echo "__x86_64__"
|
|
;;
|
|
*)
|
|
echo "#error ${target} unknown/unsupported"
|
|
return 1
|
|
;;
|
|
esac
|
|
}
|
|
|
|
# Create a vpx_config.h shim that, based on preprocessor settings for the
|
|
# current target CPU, includes the real vpx_config.h for the current target.
|
|
# $1 is the list of targets.
|
|
create_vpx_framework_config_shim() {
|
|
local targets="$1"
|
|
local config_file="${HEADER_DIR}/vpx_config.h"
|
|
local preproc_symbol=""
|
|
local target=""
|
|
local include_guard="VPX_FRAMEWORK_HEADERS_VPX_VPX_CONFIG_H_"
|
|
|
|
local file_header="/*
|
|
* Copyright (c) The WebM project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
/* GENERATED FILE: DO NOT EDIT! */
|
|
#ifndef ${include_guard}
|
|
#define ${include_guard}
|
|
#if defined"
|
|
|
|
printf "%s" "${file_header}" > "${config_file}"
|
|
for target in ${targets}; do
|
|
preproc_symbol=$(target_to_preproc_symbol "${target}")
|
|
printf " ${preproc_symbol}\n" >> "${config_file}"
|
|
printf "#define VPX_FRAMEWORK_TARGET \"${target}\"\n" >> "${config_file}"
|
|
printf "#include \"VPX/vpx/${target}/vpx_config.h\"\n" >> "${config_file}"
|
|
printf "#elif defined" >> "${config_file}"
|
|
mkdir "${HEADER_DIR}/${target}"
|
|
cp -p "${BUILD_ROOT}/${target}/vpx_config.h" "${HEADER_DIR}/${target}"
|
|
done
|
|
|
|
# Consume the last line of output from the loop: We don't want it.
|
|
sed -i.bak -e '$d' "${config_file}"
|
|
rm "${config_file}.bak"
|
|
|
|
printf "#endif\n\n" >> "${config_file}"
|
|
printf "#endif // ${include_guard}" >> "${config_file}"
|
|
}
|
|
|
|
# Configures and builds each target specified by $1, and then builds
|
|
# VPX.framework.
|
|
build_framework() {
|
|
local lib_list=""
|
|
local targets="$1"
|
|
local target=""
|
|
local target_dist_dir=""
|
|
|
|
# Clean up from previous build(s).
|
|
rm -rf "${BUILD_ROOT}" "${FRAMEWORK_DIR}"
|
|
|
|
# Create output dirs.
|
|
mkdir -p "${BUILD_ROOT}"
|
|
mkdir -p "${HEADER_DIR}"
|
|
|
|
cd "${BUILD_ROOT}"
|
|
|
|
for target in ${targets}; do
|
|
build_target "${target}"
|
|
target_dist_dir="${BUILD_ROOT}/${target}/${DIST_DIR}"
|
|
local suffix="a"
|
|
lib_list="${lib_list} ${target_dist_dir}/lib/libvpx.${suffix}"
|
|
done
|
|
|
|
cd "${ORIG_PWD}"
|
|
|
|
# The basic libvpx API includes are all the same; just grab the most recent
|
|
# set.
|
|
cp -p "${target_dist_dir}"/include/vpx/* "${HEADER_DIR}"
|
|
|
|
# Build the fat library.
|
|
if [ "$LIPO" = "cp" ]; then
|
|
cp ${lib_list} ${FRAMEWORK_DIR}/VPX
|
|
else
|
|
${LIPO} -create ${lib_list} -output ${FRAMEWORK_DIR}/VPX
|
|
fi
|
|
|
|
# Create the vpx_config.h shim that allows usage of vpx_config.h from
|
|
# within VPX.framework.
|
|
create_vpx_framework_config_shim "${targets}"
|
|
|
|
# Copy in vpx_version.h.
|
|
cp -p "${BUILD_ROOT}/${target}/vpx_version.h" "${HEADER_DIR}"
|
|
}
|
|
|
|
build_framework "${TARGETS}"
|
|
|
|
popd |