diff --git a/Dockerfile b/Dockerfile index 5304826f7..0f1ea612f 100644 --- a/Dockerfile +++ b/Dockerfile @@ -2,7 +2,7 @@ FROM gradle:6.0.1-jdk8 ENV ANDROID_SDK_URL https://dl.google.com/android/repository/sdk-tools-linux-3859397.zip ENV ANDROID_API_LEVEL android-29 -ENV ANDROID_BUILD_TOOLS_VERSION 29.0.2 +ENV ANDROID_BUILD_TOOLS_VERSION 29.0.3 ENV ANDROID_HOME /usr/local/android-sdk-linux ENV ANDROID_NDK_VERSION 20.0.5594570 ENV ANDROID_VERSION 29 diff --git a/TMessagesProj/build.gradle b/TMessagesProj/build.gradle index 87d9a9ebe..5406b45f6 100644 --- a/TMessagesProj/build.gradle +++ b/TMessagesProj/build.gradle @@ -1,3 +1,5 @@ +import java.security.MessageDigest + apply plugin: 'com.android.application' repositories { @@ -21,15 +23,15 @@ dependencies { compileOnly 'org.checkerframework:checker-qual:2.5.2' compileOnly 'org.checkerframework:checker-compat-qual:2.5.0' - implementation 'com.google.firebase:firebase-messaging:20.1.0' - implementation 'com.google.firebase:firebase-config:19.1.1' + implementation 'com.google.firebase:firebase-messaging:20.1.3' + implementation 'com.google.firebase:firebase-config:19.1.3' implementation 'com.google.android.gms:play-services-maps:17.0.0' implementation 'com.google.android.gms:play-services-auth:17.0.0' implementation 'com.google.android.gms:play-services-vision:16.2.0' - implementation 'com.google.android.gms:play-services-wallet:17.0.0' implementation 'com.google.android.gms:play-services-wearable:17.0.0' implementation 'com.google.android.gms:play-services-location:17.0.0' - implementation 'net.hockeyapp.android:HockeySDK:5.2.0' + implementation "com.microsoft.appcenter:appcenter-distribute:3.1.0" + implementation "com.microsoft.appcenter:appcenter-crashes:3.1.0" implementation 'com.googlecode.mp4parser:isoparser:1.0.6' implementation 'com.stripe:stripe-android:2.0.2' implementation files('libs/libgsaverification-client.aar') @@ -37,7 +39,7 @@ dependencies { android { compileSdkVersion 29 - buildToolsVersion '29.0.2' + buildToolsVersion '29.0.3' ndkVersion "20.0.5594570" defaultConfig.applicationId = "org.telegram.messenger" @@ -283,7 +285,12 @@ android { } } - defaultConfig.versionCode = 1869 + defaultConfig.versionCode = 1908 + + def tgVoipDexFileName = "libtgvoip.dex" + def tgVoipDexClasses = ["AudioRecordJNI", "AudioTrackJNI", "NativeTgVoipDelegate", "NativeTgVoipInstance", "TgVoipNativeLoader", "Resampler", "VLog"] + def tgVoipDexClassesPath = "org/telegram/messenger/voip" + def dxUtilPath = "${sdkDirectory.path}/build-tools/${buildToolsVersion}/dx" applicationVariants.all { variant -> variant.outputs.all { output -> @@ -306,6 +313,61 @@ android { file(manifestPath).write(manifestContent) } } + + def assembleTgVoipDexTaskName = "assemble${variant.name.capitalize()}TgVoipDex" + + task "${assembleTgVoipDexTaskName}" { + doLast { + def sourceDir = (File) android.sourceSets.main.java.srcDirs[0] + def classesDir = "${buildDir}/intermediates/javac/${variant.name}/classes" + def javaDir = "${buildDir}/intermediates/java_tgvoip/${variant.name}/java" + def tgVoipDir = new File(classesDir, tgVoipDexClassesPath) + def javaVoipDirFile = new File(javaDir, tgVoipDexClassesPath) + def tgVoipDexJavaFile = new File(javaVoipDirFile, "TgVoipDex.java") + if (!javaVoipDirFile.exists()) { + javaVoipDirFile.mkdirs() + } + def assetsDirFile = new File(buildDir, "intermediates/merged_assets/${variant.name}/out") + if (!assetsDirFile.exists()) { + assetsDirFile.mkdirs() + } + def tgVoipDexFile = new File(assetsDirFile, tgVoipDexFileName) + + def classes = tgVoipDir.list(new FilenameFilter() { + @Override + boolean accept(File dir, String name) { + // handle inner and anonymous classes + return tgVoipDexClasses.any { name == "${it}.class" || name.startsWith("${it}\$") && name.endsWith(".class") } + } + }).collect { "${tgVoipDexClassesPath}/${it}" } + + // 1. create libtgvoip.dex + exec { + workingDir classesDir + commandLine([dxUtilPath, "--dex", "--output=${tgVoipDexFile}"] + classes) + } + + // 2. remove classes from the main dex + project.delete classes.collect { "${classesDir}/${it}" } + + // 3. insert checksum of libtgvoip.dex into TgVoipDex.java + def digest = MessageDigest.getInstance("SHA1") + def fileInputStream = tgVoipDexFile.newInputStream() + def buffer = new byte[4096] + def len + while ((len = fileInputStream.read(buffer)) > 0) { + digest.update(buffer, 0, len) + } + def dexChecksum = new String(Base64.getEncoder().encode(digest.digest())).trim() + tgVoipDexJavaFile.write(new String(new File(sourceDir, "${tgVoipDexClassesPath}/TgVoipDex.java").readBytes()).replace("\$CHECKSUM\$", dexChecksum)) + exec { + commandLine([findJavac(), "-d", classesDir, tgVoipDexJavaFile.absolutePath]) + } + } + } + + tasks.findByName("compile${variant.name.capitalize()}JavaWithJavac").finalizedBy(assembleTgVoipDexTaskName) + tasks.findByName("${assembleTgVoipDexTaskName}").mustRunAfter tasks.findByName("merge${variant.name.capitalize()}Assets") } variantFilter { variant -> @@ -318,7 +380,7 @@ android { defaultConfig { minSdkVersion 16 targetSdkVersion 28 - versionName "5.15.0" + versionName "6.0.0" vectorDrawables.generatedDensities = ['mdpi', 'hdpi', 'xhdpi', 'xxhdpi'] @@ -333,4 +395,31 @@ android { } } +private static File findJavaHome() { + String javaPath = System.getProperty("java.home") + if (javaPath != null) { + File javaBase = new File(javaPath) + if (javaBase.exists()) { + if (javaBase.getName().equalsIgnoreCase("jre") && new File(javaBase.getParentFile(), "bin/java").exists()) { + return javaBase.getParentFile() + } else { + return javaBase + } + } else { + return null + } + } else { + return null + } +} + +private static File findJavac() { + File javaHome = findJavaHome() + if (javaHome != null) { + return new File(javaHome, "bin/javac") + } else { + return null + } +} + apply plugin: 'com.google.gms.google-services' diff --git a/TMessagesProj/jni/Android.mk b/TMessagesProj/jni/Android.mk index 369ea4b01..20b5f76c7 100755 --- a/TMessagesProj/jni/Android.mk +++ b/TMessagesProj/jni/Android.mk @@ -95,10 +95,18 @@ endif include $(PREBUILT_STATIC_LIBRARY) +include $(CLEAR_VARS) + +TGVOIP_NATIVE_VERSION := 1.1 TGVOIP_ADDITIONAL_CFLAGS := -DTGVOIP_NO_VIDEO include $(MY_LOCAL_PATH)/libtgvoip/Android.mk LOCAL_PATH := $(MY_LOCAL_PATH) # restore local path after include +include $(CLEAR_VARS) +TGVOIP_NATIVE_VERSION := 2.1 +TGVOIP_ADDITIONAL_CFLAGS := -DTGVOIP_NO_VIDEO +include $(MY_LOCAL_PATH)/libtgvoip2/Android.mk +LOCAL_PATH := $(MY_LOCAL_PATH) # restore local path after include include $(CLEAR_VARS) LOCAL_CPPFLAGS := -Wall -std=c++14 -DANDROID -frtti -DHAVE_PTHREAD -finline-functions -ffast-math -Os @@ -351,7 +359,7 @@ LOCAL_CFLAGS += -Drestrict='' -D__EMX__ -DOPUS_BUILD -DFIXED_POINT -DUSE_ALLOCA LOCAL_CFLAGS += -DANDROID_NDK -DDISABLE_IMPORTGL -fno-strict-aliasing -fprefetch-loop-arrays -DAVOID_TABLES -DANDROID_TILE_BASED_DECODE -DANDROID_ARMV6_IDCT -ffast-math -D__STDC_CONSTANT_MACROS LOCAL_CPPFLAGS := -DBSD=1 -ffast-math -Os -funroll-loops -std=c++14 -DPACKAGE_NAME='"drinkless/org/ton"' LOCAL_LDLIBS := -ljnigraphics -llog -lz -lEGL -lGLESv2 -landroid -LOCAL_STATIC_LIBRARIES := webp sqlite lz4 rlottie tgnet swscale avformat avcodec avresample avutil voip flac +LOCAL_STATIC_LIBRARIES := webp sqlite lz4 rlottie tgnet swscale avformat avcodec avresample avutil flac LOCAL_SRC_FILES := \ ./opus/src/opus.c \ diff --git a/TMessagesProj/jni/Application.mk b/TMessagesProj/jni/Application.mk index c29d77286..3520a589b 100644 --- a/TMessagesProj/jni/Application.mk +++ b/TMessagesProj/jni/Application.mk @@ -1,3 +1,3 @@ APP_PLATFORM := android-16 NDK_TOOLCHAIN_VERSION := clang -APP_STL := c++_static \ No newline at end of file +APP_STL := c++_shared \ No newline at end of file diff --git a/TMessagesProj/jni/audio.c b/TMessagesProj/jni/audio.c index a82e5f3a0..5fb72a6d8 100644 --- a/TMessagesProj/jni/audio.c +++ b/TMessagesProj/jni/audio.c @@ -219,14 +219,15 @@ static int writeOggPage(ogg_page *page, FILE *os) { return written; } -const opus_int32 bitrate = 16000; -const opus_int32 rate = 16000; +const opus_int32 bitrate = 25000; const opus_int32 frame_size = 960; const int with_cvbr = 1; const int max_ogg_delay = 0; const int comment_padding = 512; -opus_int32 coding_rate = 16000; +opus_int32 rate = 48000; +opus_int32 coding_rate = 48000; + ogg_int32_t _packetId; OpusEncoder *_encoder = 0; uint8_t *_packet = 0; @@ -282,9 +283,12 @@ void cleanupRecorder() { memset(&og, 0, sizeof(ogg_page)); } -int initRecorder(const char *path) { +int initRecorder(const char *path, opus_int32 sampleRate) { cleanupRecorder(); - + + coding_rate = sampleRate; + rate = sampleRate; + if (!path) { return 0; } @@ -305,7 +309,6 @@ int initRecorder(const char *path) { inopt.skip = 0; comment_init(&inopt.comments, &inopt.comments_length, opus_get_version_string()); - coding_rate = 16000; if (rate != coding_rate) { LOGE("Invalid rate"); @@ -329,6 +332,7 @@ int initRecorder(const char *path) { _packet = malloc(max_frame_bytes); result = opus_encoder_ctl(_encoder, OPUS_SET_BITRATE(bitrate)); + result = opus_encoder_ctl(_encoder, OPUS_SET_COMPLEXITY(10)); if (result != OPUS_OK) { LOGE("Error OPUS_SET_BITRATE returned: %s", opus_strerror(result)); return 0; @@ -409,7 +413,6 @@ int initRecorder(const char *path) { return 1; } - int writeFrame(uint8_t *framePcmBytes, uint32_t frameByteCount) { size_t cur_frame_size = frame_size; _packetId++; @@ -493,10 +496,10 @@ int writeFrame(uint8_t *framePcmBytes, uint32_t frameByteCount) { return 1; } -JNIEXPORT jint Java_org_telegram_messenger_MediaController_startRecord(JNIEnv *env, jclass class, jstring path) { +JNIEXPORT jint Java_org_telegram_messenger_MediaController_startRecord(JNIEnv *env, jclass class, jstring path, jint sampleRate) { const char *pathStr = (*env)->GetStringUTFChars(env, path, 0); - - int32_t result = initRecorder(pathStr); + + int32_t result = initRecorder(pathStr, sampleRate); if (pathStr != 0) { (*env)->ReleaseStringUTFChars(env, path, pathStr); diff --git a/TMessagesProj/jni/image.c b/TMessagesProj/jni/image.c index 6f5a82405..f4d31e3de 100644 --- a/TMessagesProj/jni/image.c +++ b/TMessagesProj/jni/image.c @@ -742,8 +742,8 @@ JNIEXPORT void Java_org_telegram_messenger_Utilities_stackBlurBitmap(JNIEnv* env const int divsum = SQUARE((div + 1) >> 1); // Small buffers - int stack[div * 3]; - zeroClearInt(stack, div * 3); + int stack[div * 4]; + zeroClearInt(stack, div * 4); int vmin[MAX(w, h)]; zeroClearInt(vmin, MAX(w, h)); @@ -752,9 +752,11 @@ JNIEXPORT void Java_org_telegram_messenger_Utilities_stackBlurBitmap(JNIEnv* env int *r = malloc(wh * sizeof(int)); int *g = malloc(wh * sizeof(int)); int *b = malloc(wh * sizeof(int)); + int *a = malloc(wh * sizeof(int)); zeroClearInt(r, wh); zeroClearInt(g, wh); zeroClearInt(b, wh); + zeroClearInt(a, wh); const size_t dvcount = 256 * divsum; int *dv = malloc(sizeof(int) * dvcount); @@ -766,36 +768,40 @@ JNIEXPORT void Java_org_telegram_messenger_Utilities_stackBlurBitmap(JNIEnv* env // Variables int x, y; int *sir; - int routsum, goutsum, boutsum; - int rinsum, ginsum, binsum; - int rsum, gsum, bsum, p, yp; + int routsum, goutsum, boutsum, aoutsum; + int rinsum, ginsum, binsum, ainsum; + int rsum, gsum, bsum, asum, p, yp; int stackpointer; int stackstart; int rbs; int yw = 0, yi = 0; for (y = 0; y < h; y++) { - rinsum = ginsum = binsum = routsum = goutsum = boutsum = rsum = gsum = bsum = 0; + ainsum = aoutsum = asum = rinsum = ginsum = binsum = routsum = goutsum = boutsum = rsum = gsum = bsum = 0; for (i = -radius; i <= radius; i++) { - sir = &stack[(i + radius) * 3]; + sir = &stack[(i + radius) * 4]; int offset = (y * stride + (MIN(wm, MAX(i, 0))) * 4); sir[0] = pixels[offset]; sir[1] = pixels[offset + 1]; sir[2] = pixels[offset + 2]; + sir[3] = pixels[offset + 3]; rbs = r1 - abs(i); rsum += sir[0] * rbs; gsum += sir[1] * rbs; bsum += sir[2] * rbs; + asum += sir[3] * rbs; if (i > 0) { rinsum += sir[0]; ginsum += sir[1]; binsum += sir[2]; + ainsum += sir[3]; } else { routsum += sir[0]; goutsum += sir[1]; boutsum += sir[2]; + aoutsum += sir[3]; } } stackpointer = radius; @@ -804,17 +810,20 @@ JNIEXPORT void Java_org_telegram_messenger_Utilities_stackBlurBitmap(JNIEnv* env r[yi] = dv[rsum]; g[yi] = dv[gsum]; b[yi] = dv[bsum]; + a[yi] = dv[asum]; rsum -= routsum; gsum -= goutsum; bsum -= boutsum; + asum -= aoutsum; stackstart = stackpointer - radius + div; - sir = &stack[(stackstart % div) * 3]; + sir = &stack[(stackstart % div) * 4]; routsum -= sir[0]; goutsum -= sir[1]; boutsum -= sir[2]; + aoutsum -= sir[3]; if (y == 0) { vmin[x] = MIN(x + radius + 1, wm); @@ -824,24 +833,29 @@ JNIEXPORT void Java_org_telegram_messenger_Utilities_stackBlurBitmap(JNIEnv* env sir[0] = pixels[offset]; sir[1] = pixels[offset + 1]; sir[2] = pixels[offset + 2]; + sir[3] = pixels[offset + 3]; rinsum += sir[0]; ginsum += sir[1]; binsum += sir[2]; + ainsum += sir[3]; rsum += rinsum; gsum += ginsum; bsum += binsum; + asum += ainsum; stackpointer = (stackpointer + 1) % div; - sir = &stack[(stackpointer % div) * 3]; + sir = &stack[(stackpointer % div) * 4]; routsum += sir[0]; goutsum += sir[1]; boutsum += sir[2]; + aoutsum += sir[3]; rinsum -= sir[0]; ginsum -= sir[1]; binsum -= sir[2]; + ainsum -= sir[3]; yi++; } @@ -849,31 +863,35 @@ JNIEXPORT void Java_org_telegram_messenger_Utilities_stackBlurBitmap(JNIEnv* env } for (x = 0; x < w; x++) { - rinsum = ginsum = binsum = routsum = goutsum = boutsum = rsum = gsum = bsum = 0; + ainsum = aoutsum = asum = rinsum = ginsum = binsum = routsum = goutsum = boutsum = rsum = gsum = bsum = 0; yp = -radius * w; for (i = -radius; i <= radius; i++) { yi = MAX(0, yp) + x; - sir = &stack[(i + radius) * 3]; + sir = &stack[(i + radius) * 4]; sir[0] = r[yi]; sir[1] = g[yi]; sir[2] = b[yi]; + sir[3] = a[yi]; rbs = r1 - abs(i); rsum += r[yi] * rbs; gsum += g[yi] * rbs; bsum += b[yi] * rbs; + asum += a[yi] * rbs; if (i > 0) { rinsum += sir[0]; ginsum += sir[1]; binsum += sir[2]; + ainsum += sir[3]; } else { routsum += sir[0]; goutsum += sir[1]; boutsum += sir[2]; + aoutsum += sir[3]; } if (i < hm) { @@ -886,16 +904,19 @@ JNIEXPORT void Java_org_telegram_messenger_Utilities_stackBlurBitmap(JNIEnv* env pixels[offset] = dv[rsum]; pixels[offset + 1] = dv[gsum]; pixels[offset + 2] = dv[bsum]; + pixels[offset + 3] = dv[asum]; rsum -= routsum; gsum -= goutsum; bsum -= boutsum; + asum -= aoutsum; stackstart = stackpointer - radius + div; - sir = &stack[(stackstart % div) * 3]; + sir = &stack[(stackstart % div) * 4]; routsum -= sir[0]; goutsum -= sir[1]; boutsum -= sir[2]; + aoutsum -= sir[3]; if (x == 0) { vmin[y] = (MIN(y + r1, hm)) * w; @@ -905,25 +926,30 @@ JNIEXPORT void Java_org_telegram_messenger_Utilities_stackBlurBitmap(JNIEnv* env sir[0] = r[p]; sir[1] = g[p]; sir[2] = b[p]; + sir[3] = a[p]; rinsum += sir[0]; ginsum += sir[1]; binsum += sir[2]; + ainsum += sir[3]; rsum += rinsum; gsum += ginsum; bsum += binsum; + asum += ainsum; stackpointer = (stackpointer + 1) % div; - sir = &stack[stackpointer * 3]; + sir = &stack[stackpointer * 4]; routsum += sir[0]; goutsum += sir[1]; boutsum += sir[2]; + aoutsum += sir[3]; rinsum -= sir[0]; ginsum -= sir[1]; binsum -= sir[2]; + ainsum -= sir[3]; yi += w; } @@ -932,6 +958,7 @@ JNIEXPORT void Java_org_telegram_messenger_Utilities_stackBlurBitmap(JNIEnv* env free(r); free(g); free(b); + free(a); free(dv); AndroidBitmap_unlockPixels(env, bitmap); } diff --git a/TMessagesProj/jni/jni.c b/TMessagesProj/jni/jni.c index 9bd90a316..d6568b8ad 100644 --- a/TMessagesProj/jni/jni.c +++ b/TMessagesProj/jni/jni.c @@ -9,6 +9,7 @@ #include #include #include +#include #include "image.h" #include "libtgvoip/client/android/tg_voip_jni.h" @@ -35,9 +36,13 @@ jint JNI_OnLoad(JavaVM *vm, void *reserved) { if (registerNativeTgNetFunctions(vm, env) != JNI_TRUE) { return -1; } + + /* if (tgvoipOnJniLoad(vm, env) != JNI_TRUE) { + return -1; + }*/ //tonLibOnLoad(vm, env); - tgvoipRegisterNatives(env); + //tgvoipRegisterNatives(env); return JNI_VERSION_1_6; } diff --git a/TMessagesProj/jni/libtgvoip/Android.mk b/TMessagesProj/jni/libtgvoip/Android.mk index 035186892..5f224103d 100644 --- a/TMessagesProj/jni/libtgvoip/Android.mk +++ b/TMessagesProj/jni/libtgvoip/Android.mk @@ -1,13 +1,25 @@ LOCAL_PATH := $(call my-dir) -LOCAL_MODULE := voip +LOCAL_MODULE := tgvoip${TGVOIP_NATIVE_VERSION} LOCAL_CPPFLAGS := -Wall -std=c++11 -DANDROID -finline-functions -ffast-math -Os -fno-strict-aliasing -O3 -frtti -D__STDC_LIMIT_MACROS -Wno-unknown-pragmas -LOCAL_CFLAGS := -O3 -DUSE_KISS_FFT -fexceptions -DWEBRTC_APM_DEBUG_DUMP=0 -DWEBRTC_POSIX -DWEBRTC_ANDROID -D__STDC_LIMIT_MACROS -DFIXED_POINT -DWEBRTC_NS_FLOAT -LOCAL_EXPORT_LDLIBS := -llog -lOpenSLES +LOCAL_CPPFLAGS += -DBSD=1 -funroll-loops +LOCAL_CFLAGS := -O3 -DUSE_KISS_FFT -fexceptions -DWEBRTC_APM_DEBUG_DUMP=0 -DWEBRTC_POSIX -DWEBRTC_ANDROID -D__STDC_LIMIT_MACROS -DWEBRTC_NS_FLOAT +LOCAL_CFLAGS += -DNULL=0 -DSOCKLEN_T=socklen_t -DLOCALE_NOT_USED -D_LARGEFILE_SOURCE=1 -D_FILE_OFFSET_BITS=64 +LOCAL_CFLAGS += -Drestrict='' -D__EMX__ -DOPUS_BUILD -DFIXED_POINT -DUSE_ALLOCA -DHAVE_LRINT -DHAVE_LRINTF -fno-math-errno +LOCAL_LDLIBS := -llog -lOpenSLES +LOCAL_STATIC_LIBRARIES := crypto MY_DIR := libtgvoip -LOCAL_C_INCLUDES := $(LOCAL_PATH)/../opus/include $(LOCAL_PATH)/../boringssl/include/ $(LOCAL_PATH)/webrtc_dsp/ +LOCAL_C_INCLUDES := \ +$(LOCAL_PATH)/../opus/include \ +$(LOCAL_PATH)/../opus/silk \ +$(LOCAL_PATH)/../opus/silk/fixed \ +$(LOCAL_PATH)/../opus/celt \ +$(LOCAL_PATH)/../opus/ \ +$(LOCAL_PATH)/../opus/opusfile \ +$(LOCAL_PATH)/../boringssl/include/ \ +$(LOCAL_PATH)/webrtc_dsp/ ifeq ($(TARGET_ARCH_ABI),$(filter $(TARGET_ARCH_ABI),armeabi-v7a arm64-v8a)) CC_NEON := cc.neon @@ -20,6 +32,7 @@ LOCAL_CFLAGS += $(TGVOIP_ADDITIONAL_CFLAGS) LOCAL_SRC_FILES := \ ./logging.cpp \ +./TgVoip.cpp \ ./VoIPController.cpp \ ./VoIPGroupController.cpp \ ./Buffers.cpp \ @@ -50,6 +63,7 @@ LOCAL_SRC_FILES := \ ./video/ScreamCongestionController.cpp \ ./os/android/VideoSourceAndroid.cpp \ ./os/android/VideoRendererAndroid.cpp \ +./client/android/org_telegram_messenger_voip_TgVoip.cpp \ ./client/android/tg_voip_jni.cpp # WebRTC signal processing @@ -271,7 +285,6 @@ LOCAL_SRC_FILES += \ ./webrtc_dsp/common_audio/resampler/sinc_resampler.cc \ ./webrtc_dsp/common_audio/resampler/sinusoidal_linear_chirp_source.cc \ ./webrtc_dsp/common_audio/wav_file.cc \ -./webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor.c \ ./webrtc_dsp/common_audio/third_party/fft4g/fft4g.c \ ./webrtc_dsp/common_audio/audio_converter.cc \ ./webrtc_dsp/common_audio/real_fourier.cc \ @@ -289,7 +302,6 @@ LOCAL_SRC_FILES += \ ./webrtc_dsp/common_audio/signal_processing/sqrt_of_one_minus_x_squared.c \ ./webrtc_dsp/common_audio/signal_processing/downsample_fast.c \ ./webrtc_dsp/common_audio/signal_processing/splitting_filter1.c \ -./webrtc_dsp/common_audio/signal_processing/filter_ar_fast_q12.c \ ./webrtc_dsp/common_audio/signal_processing/spl_init.c \ ./webrtc_dsp/common_audio/signal_processing/lpc_to_refl_coef.c \ ./webrtc_dsp/common_audio/signal_processing/cross_correlation.c \ @@ -304,7 +316,6 @@ LOCAL_SRC_FILES += \ ./webrtc_dsp/common_audio/signal_processing/resample_fractional.c \ ./webrtc_dsp/common_audio/signal_processing/real_fft.c \ ./webrtc_dsp/common_audio/signal_processing/ilbc_specific_functions.c \ -./webrtc_dsp/common_audio/signal_processing/complex_bit_reverse.c \ ./webrtc_dsp/common_audio/signal_processing/randomization_functions.c \ ./webrtc_dsp/common_audio/signal_processing/copy_set_operations.c \ ./webrtc_dsp/common_audio/signal_processing/resample_by_2.c \ @@ -337,6 +348,11 @@ LOCAL_SRC_FILES += \ ./webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor_arm.S.neon \ ./webrtc_dsp/common_audio/signal_processing/complex_bit_reverse_arm.S.neon \ ./webrtc_dsp/common_audio/signal_processing/filter_ar_fast_q12_armv7.S.neon +else +LOCAL_SRC_FILES += \ +./webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor.c \ +./webrtc_dsp/common_audio/signal_processing/complex_bit_reverse.c \ +./webrtc_dsp/common_audio/signal_processing/filter_ar_fast_q12.c endif ifeq ($(TARGET_ARCH_ABI),$(filter $(TARGET_ARCH_ABI),x86 x86_64)) @@ -347,4 +363,198 @@ LOCAL_SRC_FILES += \ ./webrtc_dsp/common_audio/resampler/sinc_resampler_sse.cc endif -include $(BUILD_STATIC_LIBRARY) +# Opus + +LOCAL_SRC_FILES += \ +./../opus/src/opus.c \ +./../opus/src/opus_decoder.c \ +./../opus/src/opus_encoder.c \ +./../opus/src/opus_multistream.c \ +./../opus/src/opus_multistream_encoder.c \ +./../opus/src/opus_multistream_decoder.c \ +./../opus/src/repacketizer.c \ +./../opus/src/analysis.c \ +./../opus/src/mlp.c \ +./../opus/src/mlp_data.c \ +./../opus/src/opus_projection_encoder.c \ +./../opus/src/opus_projection_decoder.c \ +./../opus/src/mapping_matrix.c + +ifeq ($(TARGET_ARCH_ABI),$(filter $(TARGET_ARCH_ABI),armeabi-v7a arm64-v8a)) + LOCAL_ARM_MODE := arm + LOCAL_CPPFLAGS += -DLIBYUV_NEON + LOCAL_CFLAGS += -DLIBYUV_NEON + LOCAL_CFLAGS += -DOPUS_HAVE_RTCD -DOPUS_ARM_ASM + LOCAL_SRC_FILES += \ + ./../opus/celt/arm/celt_neon_intr.c.neon \ + ./../opus/celt/arm/pitch_neon_intr.c.neon \ + ./../opus/silk/arm/NSQ_neon.c.neon \ + ./../opus/silk/arm/arm_silk_map.c \ + ./../opus/silk/arm/LPC_inv_pred_gain_neon_intr.c.neon \ + ./../opus/silk/arm/NSQ_del_dec_neon_intr.c.neon \ + ./../opus/silk/arm/biquad_alt_neon_intr.c.neon \ + ./../opus/silk/fixed/arm/warped_autocorrelation_FIX_neon_intr.c.neon + +# LOCAL_SRC_FILES += ./../opus/celt/arm/celt_pitch_xcorr_arm-gnu.S + +else + ifeq ($(TARGET_ARCH_ABI),x86) + LOCAL_CFLAGS += -Dx86fix + LOCAL_CPPFLAGS += -Dx86fix + LOCAL_ARM_MODE := arm +# LOCAL_SRC_FILES += \ +# ./libyuv/source/row_x86.asm + +# LOCAL_SRC_FILES += \ +# ./../opus/celt/x86/celt_lpc_sse.c \ +# ./../opus/celt/x86/pitch_sse.c \ +# ./../opus/celt/x86/pitch_sse2.c \ +# ./../opus/celt/x86/pitch_sse4_1.c \ +# ./../opus/celt/x86/vq_sse2.c \ +# ./../opus/celt/x86/x86_celt_map.c \ +# ./../opus/celt/x86/x86cpu.c \ +# ./../opus/silk/fixed/x86/burg_modified_FIX_sse.c \ +# ./../opus/silk/fixed/x86/vector_ops_FIX_sse.c \ +# ./../opus/silk/x86/NSQ_del_dec_sse.c \ +# ./../opus/silk/x86/NSQ_sse.c \ +# ./../opus/silk/x86/VAD_sse.c \ +# ./../opus/silk/x86/VQ_WMat_sse.c \ +# ./../opus/silk/x86/x86_silk_map.c + endif +endif + +LOCAL_SRC_FILES += \ +./../opus/silk/CNG.c \ +./../opus/silk/code_signs.c \ +./../opus/silk/init_decoder.c \ +./../opus/silk/decode_core.c \ +./../opus/silk/decode_frame.c \ +./../opus/silk/decode_parameters.c \ +./../opus/silk/decode_indices.c \ +./../opus/silk/decode_pulses.c \ +./../opus/silk/decoder_set_fs.c \ +./../opus/silk/dec_API.c \ +./../opus/silk/enc_API.c \ +./../opus/silk/encode_indices.c \ +./../opus/silk/encode_pulses.c \ +./../opus/silk/gain_quant.c \ +./../opus/silk/interpolate.c \ +./../opus/silk/LP_variable_cutoff.c \ +./../opus/silk/NLSF_decode.c \ +./../opus/silk/NSQ.c \ +./../opus/silk/NSQ_del_dec.c \ +./../opus/silk/PLC.c \ +./../opus/silk/shell_coder.c \ +./../opus/silk/tables_gain.c \ +./../opus/silk/tables_LTP.c \ +./../opus/silk/tables_NLSF_CB_NB_MB.c \ +./../opus/silk/tables_NLSF_CB_WB.c \ +./../opus/silk/tables_other.c \ +./../opus/silk/tables_pitch_lag.c \ +./../opus/silk/tables_pulses_per_block.c \ +./../opus/silk/VAD.c \ +./../opus/silk/control_audio_bandwidth.c \ +./../opus/silk/quant_LTP_gains.c \ +./../opus/silk/VQ_WMat_EC.c \ +./../opus/silk/HP_variable_cutoff.c \ +./../opus/silk/NLSF_encode.c \ +./../opus/silk/NLSF_VQ.c \ +./../opus/silk/NLSF_unpack.c \ +./../opus/silk/NLSF_del_dec_quant.c \ +./../opus/silk/process_NLSFs.c \ +./../opus/silk/stereo_LR_to_MS.c \ +./../opus/silk/stereo_MS_to_LR.c \ +./../opus/silk/check_control_input.c \ +./../opus/silk/control_SNR.c \ +./../opus/silk/init_encoder.c \ +./../opus/silk/control_codec.c \ +./../opus/silk/A2NLSF.c \ +./../opus/silk/ana_filt_bank_1.c \ +./../opus/silk/biquad_alt.c \ +./../opus/silk/bwexpander_32.c \ +./../opus/silk/bwexpander.c \ +./../opus/silk/debug.c \ +./../opus/silk/decode_pitch.c \ +./../opus/silk/inner_prod_aligned.c \ +./../opus/silk/lin2log.c \ +./../opus/silk/log2lin.c \ +./../opus/silk/LPC_analysis_filter.c \ +./../opus/silk/LPC_inv_pred_gain.c \ +./../opus/silk/table_LSF_cos.c \ +./../opus/silk/NLSF2A.c \ +./../opus/silk/NLSF_stabilize.c \ +./../opus/silk/NLSF_VQ_weights_laroia.c \ +./../opus/silk/pitch_est_tables.c \ +./../opus/silk/resampler.c \ +./../opus/silk/resampler_down2_3.c \ +./../opus/silk/resampler_down2.c \ +./../opus/silk/resampler_private_AR2.c \ +./../opus/silk/resampler_private_down_FIR.c \ +./../opus/silk/resampler_private_IIR_FIR.c \ +./../opus/silk/resampler_private_up2_HQ.c \ +./../opus/silk/resampler_rom.c \ +./../opus/silk/sigm_Q15.c \ +./../opus/silk/sort.c \ +./../opus/silk/sum_sqr_shift.c \ +./../opus/silk/stereo_decode_pred.c \ +./../opus/silk/stereo_encode_pred.c \ +./../opus/silk/stereo_find_predictor.c \ +./../opus/silk/stereo_quant_pred.c \ +./../opus/silk/LPC_fit.c + +LOCAL_SRC_FILES += \ +./../opus/silk/fixed/LTP_analysis_filter_FIX.c \ +./../opus/silk/fixed/LTP_scale_ctrl_FIX.c \ +./../opus/silk/fixed/corrMatrix_FIX.c \ +./../opus/silk/fixed/encode_frame_FIX.c \ +./../opus/silk/fixed/find_LPC_FIX.c \ +./../opus/silk/fixed/find_LTP_FIX.c \ +./../opus/silk/fixed/find_pitch_lags_FIX.c \ +./../opus/silk/fixed/find_pred_coefs_FIX.c \ +./../opus/silk/fixed/noise_shape_analysis_FIX.c \ +./../opus/silk/fixed/process_gains_FIX.c \ +./../opus/silk/fixed/regularize_correlations_FIX.c \ +./../opus/silk/fixed/residual_energy16_FIX.c \ +./../opus/silk/fixed/residual_energy_FIX.c \ +./../opus/silk/fixed/warped_autocorrelation_FIX.c \ +./../opus/silk/fixed/apply_sine_window_FIX.c \ +./../opus/silk/fixed/autocorr_FIX.c \ +./../opus/silk/fixed/burg_modified_FIX.c \ +./../opus/silk/fixed/k2a_FIX.c \ +./../opus/silk/fixed/k2a_Q16_FIX.c \ +./../opus/silk/fixed/pitch_analysis_core_FIX.c \ +./../opus/silk/fixed/vector_ops_FIX.c \ +./../opus/silk/fixed/schur64_FIX.c \ +./../opus/silk/fixed/schur_FIX.c + +LOCAL_SRC_FILES += \ +./../opus/celt/bands.c \ +./../opus/celt/celt.c \ +./../opus/celt/celt_encoder.c \ +./../opus/celt/celt_decoder.c \ +./../opus/celt/cwrs.c \ +./../opus/celt/entcode.c \ +./../opus/celt/entdec.c \ +./../opus/celt/entenc.c \ +./../opus/celt/kiss_fft.c \ +./../opus/celt/laplace.c \ +./../opus/celt/mathops.c \ +./../opus/celt/mdct.c \ +./../opus/celt/modes.c \ +./../opus/celt/pitch.c \ +./../opus/celt/celt_lpc.c \ +./../opus/celt/quant_bands.c \ +./../opus/celt/rate.c \ +./../opus/celt/vq.c \ +./../opus/celt/arm/armcpu.c \ +./../opus/celt/arm/arm_celt_map.c + +LOCAL_SRC_FILES += \ +./../opus/ogg/bitwise.c \ +./../opus/ogg/framing.c \ +./../opus/opusfile/info.c \ +./../opus/opusfile/internal.c \ +./../opus/opusfile/opusfile.c \ +./../opus/opusfile/stream.c + +include $(BUILD_SHARED_LIBRARY) \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip/EchoCanceller.cpp b/TMessagesProj/jni/libtgvoip/EchoCanceller.cpp index d11f11062..bd8b31b26 100755 --- a/TMessagesProj/jni/libtgvoip/EchoCanceller.cpp +++ b/TMessagesProj/jni/libtgvoip/EchoCanceller.cpp @@ -96,6 +96,7 @@ EchoCanceller::~EchoCanceller(){ #ifndef TGVOIP_NO_DSP delete apm; delete audioFrame; + delete farendBufferPool; #endif } diff --git a/TMessagesProj/jni/libtgvoip/Makefile.am b/TMessagesProj/jni/libtgvoip/Makefile.am index 0d1f1b50f..03c8866a4 100644 --- a/TMessagesProj/jni/libtgvoip/Makefile.am +++ b/TMessagesProj/jni/libtgvoip/Makefile.am @@ -4,7 +4,8 @@ CFLAGS = -Wall -DHAVE_CONFIG_H -Wno-unknown-pragmas lib_LTLIBRARIES = libtgvoip.la -SRC = VoIPController.cpp \ +SRC = TgVoip.cpp \ +VoIPController.cpp \ Buffers.cpp \ CongestionControl.cpp \ EchoCanceller.cpp \ @@ -29,6 +30,7 @@ video/ScreamCongestionController.cpp \ json11.cpp TGVOIP_HDRS = \ +TgVoip.h \ VoIPController.h \ Buffers.h \ BlockingQueue.h \ diff --git a/TMessagesProj/jni/libtgvoip/Makefile.in b/TMessagesProj/jni/libtgvoip/Makefile.in index c401d281c..31b1ef4f2 100644 --- a/TMessagesProj/jni/libtgvoip/Makefile.in +++ b/TMessagesProj/jni/libtgvoip/Makefile.in @@ -808,11 +808,11 @@ am__installdirs = "$(DESTDIR)$(libdir)" \ "$(DESTDIR)$(tgvoipincludedir)" LTLIBRARIES = $(lib_LTLIBRARIES) libtgvoip_la_LIBADD = -am__libtgvoip_la_SOURCES_DIST = VoIPController.cpp Buffers.cpp \ - CongestionControl.cpp EchoCanceller.cpp JitterBuffer.cpp \ - logging.cpp MediaStreamItf.cpp MessageThread.cpp \ - NetworkSocket.cpp OpusDecoder.cpp OpusEncoder.cpp \ - PacketReassembler.cpp VoIPGroupController.cpp \ +am__libtgvoip_la_SOURCES_DIST = TgVoip.cpp VoIPController.cpp \ + Buffers.cpp CongestionControl.cpp EchoCanceller.cpp \ + JitterBuffer.cpp logging.cpp MediaStreamItf.cpp \ + MessageThread.cpp NetworkSocket.cpp OpusDecoder.cpp \ + OpusEncoder.cpp PacketReassembler.cpp VoIPGroupController.cpp \ VoIPServerConfig.cpp audio/AudioIO.cpp audio/AudioInput.cpp \ audio/AudioOutput.cpp audio/Resampler.cpp \ os/posix/NetworkSocketPosix.cpp video/VideoSource.cpp \ @@ -1421,16 +1421,16 @@ am__libtgvoip_la_SOURCES_DIST = VoIPController.cpp Buffers.cpp \ webrtc_dsp/common_audio/vad/include/webrtc_vad.h \ webrtc_dsp/common_audio/vad/vad_gmm.h \ webrtc_dsp/common_audio/vad/vad_sp.h \ - webrtc_dsp/common_audio/vad/vad_filterbank.h VoIPController.h \ - Buffers.h BlockingQueue.h PrivateDefines.h CongestionControl.h \ - EchoCanceller.h JitterBuffer.h logging.h threading.h \ - MediaStreamItf.h MessageThread.h NetworkSocket.h OpusDecoder.h \ - OpusEncoder.h PacketReassembler.h VoIPServerConfig.h \ - audio/AudioIO.h audio/AudioInput.h audio/AudioOutput.h \ - audio/Resampler.h os/posix/NetworkSocketPosix.h \ - video/VideoSource.h video/VideoRenderer.h \ - video/ScreamCongestionController.h json11.hpp utils.h \ - os/darwin/AudioInputAudioUnit.h \ + webrtc_dsp/common_audio/vad/vad_filterbank.h TgVoip.h \ + VoIPController.h Buffers.h BlockingQueue.h PrivateDefines.h \ + CongestionControl.h EchoCanceller.h JitterBuffer.h logging.h \ + threading.h MediaStreamItf.h MessageThread.h NetworkSocket.h \ + OpusDecoder.h OpusEncoder.h PacketReassembler.h \ + VoIPServerConfig.h audio/AudioIO.h audio/AudioInput.h \ + audio/AudioOutput.h audio/Resampler.h \ + os/posix/NetworkSocketPosix.h video/VideoSource.h \ + video/VideoRenderer.h video/ScreamCongestionController.h \ + json11.hpp utils.h os/darwin/AudioInputAudioUnit.h \ os/darwin/AudioOutputAudioUnit.h os/darwin/AudioUnitIO.h \ os/darwin/AudioInputAudioUnitOSX.h \ os/darwin/AudioOutputAudioUnitOSX.h os/darwin/DarwinSpecific.h \ @@ -1736,12 +1736,12 @@ am__dirstamp = $(am__leading_dot)dirstamp @ENABLE_DSP_TRUE@@TARGET_CPU_ARM_FALSE@am__objects_10 = webrtc_dsp/common_audio/signal_processing/complex_bit_reverse.lo \ @ENABLE_DSP_TRUE@@TARGET_CPU_ARM_FALSE@ webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor.lo am__objects_11 = -am__objects_12 = VoIPController.lo Buffers.lo CongestionControl.lo \ - EchoCanceller.lo JitterBuffer.lo logging.lo MediaStreamItf.lo \ - MessageThread.lo NetworkSocket.lo OpusDecoder.lo \ - OpusEncoder.lo PacketReassembler.lo VoIPGroupController.lo \ - VoIPServerConfig.lo audio/AudioIO.lo audio/AudioInput.lo \ - audio/AudioOutput.lo audio/Resampler.lo \ +am__objects_12 = TgVoip.lo VoIPController.lo Buffers.lo \ + CongestionControl.lo EchoCanceller.lo JitterBuffer.lo \ + logging.lo MediaStreamItf.lo MessageThread.lo NetworkSocket.lo \ + OpusDecoder.lo OpusEncoder.lo PacketReassembler.lo \ + VoIPGroupController.lo VoIPServerConfig.lo audio/AudioIO.lo \ + audio/AudioInput.lo audio/AudioOutput.lo audio/Resampler.lo \ os/posix/NetworkSocketPosix.lo video/VideoSource.lo \ video/VideoRenderer.lo video/ScreamCongestionController.lo \ json11.lo $(am__objects_1) $(am__objects_2) $(am__objects_3) \ @@ -1777,7 +1777,7 @@ am__depfiles_remade = ./$(DEPDIR)/Buffers.Plo \ ./$(DEPDIR)/MediaStreamItf.Plo ./$(DEPDIR)/MessageThread.Plo \ ./$(DEPDIR)/NetworkSocket.Plo ./$(DEPDIR)/OpusDecoder.Plo \ ./$(DEPDIR)/OpusEncoder.Plo ./$(DEPDIR)/PacketReassembler.Plo \ - ./$(DEPDIR)/VoIPController.Plo \ + ./$(DEPDIR)/TgVoip.Plo ./$(DEPDIR)/VoIPController.Plo \ ./$(DEPDIR)/VoIPGroupController.Plo \ ./$(DEPDIR)/VoIPServerConfig.Plo ./$(DEPDIR)/json11.Plo \ ./$(DEPDIR)/logging.Plo \ @@ -2153,8 +2153,8 @@ am__can_run_installinfo = \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac -am__nobase_tgvoipinclude_HEADERS_DIST = VoIPController.h Buffers.h \ - BlockingQueue.h PrivateDefines.h CongestionControl.h \ +am__nobase_tgvoipinclude_HEADERS_DIST = TgVoip.h VoIPController.h \ + Buffers.h BlockingQueue.h PrivateDefines.h CongestionControl.h \ EchoCanceller.h JitterBuffer.h logging.h threading.h \ MediaStreamItf.h MessageThread.h NetworkSocket.h OpusDecoder.h \ OpusEncoder.h PacketReassembler.h VoIPServerConfig.h \ @@ -2347,7 +2347,7 @@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ AUTOMAKE_OPTIONS = foreign lib_LTLIBRARIES = libtgvoip.la -SRC = VoIPController.cpp Buffers.cpp CongestionControl.cpp \ +SRC = TgVoip.cpp VoIPController.cpp Buffers.cpp CongestionControl.cpp \ EchoCanceller.cpp JitterBuffer.cpp logging.cpp \ MediaStreamItf.cpp MessageThread.cpp NetworkSocket.cpp \ OpusDecoder.cpp OpusEncoder.cpp PacketReassembler.cpp \ @@ -2359,7 +2359,7 @@ SRC = VoIPController.cpp Buffers.cpp CongestionControl.cpp \ $(am__append_10) $(am__append_12) $(am__append_14) \ $(am__append_16) $(am__append_18) $(am__append_21) \ $(am__append_22) $(am__append_23) -TGVOIP_HDRS = VoIPController.h Buffers.h BlockingQueue.h \ +TGVOIP_HDRS = TgVoip.h VoIPController.h Buffers.h BlockingQueue.h \ PrivateDefines.h CongestionControl.h EchoCanceller.h \ JitterBuffer.h logging.h threading.h MediaStreamItf.h \ MessageThread.h NetworkSocket.h OpusDecoder.h OpusEncoder.h \ @@ -3638,6 +3638,7 @@ distclean-compile: @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/OpusDecoder.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/OpusEncoder.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/PacketReassembler.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/TgVoip.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/VoIPController.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/VoIPGroupController.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/VoIPServerConfig.Plo@am__quote@ # am--include-marker @@ -4506,6 +4507,7 @@ distclean: distclean-am -rm -f ./$(DEPDIR)/OpusDecoder.Plo -rm -f ./$(DEPDIR)/OpusEncoder.Plo -rm -f ./$(DEPDIR)/PacketReassembler.Plo + -rm -f ./$(DEPDIR)/TgVoip.Plo -rm -f ./$(DEPDIR)/VoIPController.Plo -rm -f ./$(DEPDIR)/VoIPGroupController.Plo -rm -f ./$(DEPDIR)/VoIPServerConfig.Plo @@ -4869,6 +4871,7 @@ maintainer-clean: maintainer-clean-am -rm -f ./$(DEPDIR)/OpusDecoder.Plo -rm -f ./$(DEPDIR)/OpusEncoder.Plo -rm -f ./$(DEPDIR)/PacketReassembler.Plo + -rm -f ./$(DEPDIR)/TgVoip.Plo -rm -f ./$(DEPDIR)/VoIPController.Plo -rm -f ./$(DEPDIR)/VoIPGroupController.Plo -rm -f ./$(DEPDIR)/VoIPServerConfig.Plo diff --git a/TMessagesProj/jni/libtgvoip/NetworkSocket.cpp b/TMessagesProj/jni/libtgvoip/NetworkSocket.cpp index 4ee314e91..940d401a0 100755 --- a/TMessagesProj/jni/libtgvoip/NetworkSocket.cpp +++ b/TMessagesProj/jni/libtgvoip/NetworkSocket.cpp @@ -364,8 +364,8 @@ bool NetworkSocketTCPObfuscated::IsFailed(){ NetworkSocketSOCKS5Proxy::NetworkSocketSOCKS5Proxy(NetworkSocket *tcp, NetworkSocket *udp, std::string username, std::string password) : NetworkSocketWrapper(udp ? PROTO_UDP : PROTO_TCP){ this->tcp=tcp; this->udp=udp; - this->username=username; - this->password=password; + this->username=std::move(username); + this->password=std::move(password); connectedAddress=NULL; } diff --git a/TMessagesProj/jni/libtgvoip/TgVoip.cpp b/TMessagesProj/jni/libtgvoip/TgVoip.cpp new file mode 100644 index 000000000..a9b8ba90e --- /dev/null +++ b/TMessagesProj/jni/libtgvoip/TgVoip.cpp @@ -0,0 +1,433 @@ +#include "TgVoip.h" + +#include "VoIPController.h" +#include "VoIPServerConfig.h" + +#include + +#ifndef TGVOIP_USE_CUSTOM_CRYPTO +extern "C" { +#include +#include +//#include +#include +} + +void tgvoip_openssl_aes_ige_encrypt(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv){ + AES_KEY akey; + AES_set_encrypt_key(key, 32*8, &akey); + AES_ige_encrypt(in, out, length, &akey, iv, AES_ENCRYPT); +} + +void tgvoip_openssl_aes_ige_decrypt(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv){ + AES_KEY akey; + AES_set_decrypt_key(key, 32*8, &akey); + AES_ige_encrypt(in, out, length, &akey, iv, AES_DECRYPT); +} + +void tgvoip_openssl_rand_bytes(uint8_t* buffer, size_t len){ + RAND_bytes(buffer, len); +} + +void tgvoip_openssl_sha1(uint8_t* msg, size_t len, uint8_t* output){ + SHA1(msg, len, output); +} + +void tgvoip_openssl_sha256(uint8_t* msg, size_t len, uint8_t* output){ + SHA256(msg, len, output); +} + +void tgvoip_openssl_aes_ctr_encrypt(uint8_t* inout, size_t length, uint8_t* key, uint8_t* iv, uint8_t* ecount, uint32_t* num){ + AES_KEY akey; + AES_set_encrypt_key(key, 32*8, &akey); + AES_ctr128_encrypt(inout, inout, length, &akey, iv, ecount, num); +} + +void tgvoip_openssl_aes_cbc_encrypt(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv){ + AES_KEY akey; + AES_set_encrypt_key(key, 256, &akey); + AES_cbc_encrypt(in, out, length, &akey, iv, AES_ENCRYPT); +} + +void tgvoip_openssl_aes_cbc_decrypt(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv){ + AES_KEY akey; + AES_set_decrypt_key(key, 256, &akey); + AES_cbc_encrypt(in, out, length, &akey, iv, AES_DECRYPT); +} + + +tgvoip::CryptoFunctions tgvoip::VoIPController::crypto={ + tgvoip_openssl_rand_bytes, + tgvoip_openssl_sha1, + tgvoip_openssl_sha256, + tgvoip_openssl_aes_ige_encrypt, + tgvoip_openssl_aes_ige_decrypt, + tgvoip_openssl_aes_ctr_encrypt, + tgvoip_openssl_aes_cbc_encrypt, + tgvoip_openssl_aes_cbc_decrypt +}; +#else +struct TgVoipCrypto { + void (*rand_bytes)(uint8_t* buffer, size_t length); + void (*sha1)(uint8_t* msg, size_t length, uint8_t* output); + void (*sha256)(uint8_t* msg, size_t length, uint8_t* output); + void (*aes_ige_encrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); + void (*aes_ige_decrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); + void (*aes_ctr_encrypt)(uint8_t* inout, size_t length, uint8_t* key, uint8_t* iv, uint8_t* ecount, uint32_t* num); + void (*aes_cbc_encrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); + void (*aes_cbc_decrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); +}; +tgvoip::CryptoFunctions tgvoip::VoIPController::crypto; // set it yourself upon initialization +#endif + + +class TgVoipImpl : public TgVoip { +private: + tgvoip::VoIPController *controller_; + std::function onStateUpdated_; + std::function onSignalBarsUpdated_; +public: + TgVoipImpl( + std::vector const &endpoints, + TgVoipPersistentState const &persistentState, + std::unique_ptr const &proxy, + TgVoipConfig const &config, + TgVoipEncryptionKey const &encryptionKey, + TgVoipNetworkType initialNetworkType +#ifdef TGVOIP_USE_CUSTOM_CRYPTO + , + TgVoipCrypto const &crypto +#endif +#ifdef TGVOIP_USE_CALLBACK_AUDIO_IO + , + TgVoipAudioDataCallbacks const &audioDataCallbacks +#endif + ) { +#ifdef TGVOIP_USE_CUSTOM_CRYPTO + tgvoip::VoIPController::crypto.sha1 = crypto.sha1; + tgvoip::VoIPController::crypto.sha256 = crypto.sha256; + tgvoip::VoIPController::crypto.rand_bytes = crypto.rand_bytes; + tgvoip::VoIPController::crypto.aes_ige_encrypt = crypto.aes_ige_encrypt; + tgvoip::VoIPController::crypto.aes_ige_decrypt = crypto.aes_ige_decrypt; + tgvoip::VoIPController::crypto.aes_ctr_encrypt = crypto.aes_ctr_encrypt; +#endif + + controller_ = new tgvoip::VoIPController(); + controller_->implData = this; + +#ifdef TGVOIP_USE_CALLBACK_AUDIO_IO + controller_->SetAudioDataCallbacks(audioDataCallbacks.input, audioDataCallbacks.output, audioDataCallbacks.preprocessed); +#endif + + controller_->SetPersistentState(persistentState.value); + + if (proxy != nullptr) { + controller_->SetProxy(tgvoip::PROXY_SOCKS5, proxy->host, proxy->port, proxy->login, proxy->password); + } + + auto callbacks = tgvoip::VoIPController::Callbacks(); + callbacks.connectionStateChanged = &TgVoipImpl::controllerStateCallback; + callbacks.groupCallKeyReceived = nullptr; + callbacks.groupCallKeySent = nullptr; + callbacks.signalBarCountChanged = &TgVoipImpl::signalBarsCallback; + callbacks.upgradeToGroupCallRequested = nullptr; + controller_->SetCallbacks(callbacks); + + std::vector mappedEndpoints; + for (auto endpoint : endpoints) { + bool isIpv6 = false; + struct in6_addr addrIpV6; + if (inet_pton(AF_INET6, endpoint.host.c_str(), &addrIpV6)) { + isIpv6 = true; + } + + tgvoip::Endpoint::Type mappedType; + switch (endpoint.type) { + case TgVoipEndpointType::UdpRelay: + mappedType = tgvoip::Endpoint::Type::UDP_RELAY; + break; + case TgVoipEndpointType::Lan: + mappedType = tgvoip::Endpoint::Type::UDP_P2P_LAN; + break; + case TgVoipEndpointType::Inet: + mappedType = tgvoip::Endpoint::Type::UDP_P2P_INET; + break; + case TgVoipEndpointType::TcpRelay: + mappedType = tgvoip::Endpoint::Type::TCP_RELAY; + break; + default: + mappedType = tgvoip::Endpoint::Type::UDP_RELAY; + break; + } + + tgvoip::IPv4Address address(isIpv6 ? std::string() : endpoint.host); + tgvoip::IPv6Address addressv6(isIpv6 ? endpoint.host : std::string()); + + mappedEndpoints.emplace_back(endpoint.endpointId, endpoint.port, address, addressv6, mappedType, endpoint.peerTag); + } + + int mappedDataSaving; + switch (config.dataSaving) { + case TgVoipDataSaving::Mobile: + mappedDataSaving = tgvoip::DATA_SAVING_MOBILE; + break; + case TgVoipDataSaving::Always: + mappedDataSaving = tgvoip::DATA_SAVING_ALWAYS; + break; + default: + mappedDataSaving = tgvoip::DATA_SAVING_NEVER; + break; + } + + tgvoip::VoIPController::Config mappedConfig( + config.initializationTimeout, + config.receiveTimeout, + mappedDataSaving, + config.enableAEC, + config.enableNS, + config.enableAGC, + config.enableCallUpgrade + ); + mappedConfig.logFilePath = config.logPath; + mappedConfig.statsDumpFilePath = ""; + + controller_->SetConfig(mappedConfig); + + setNetworkType(initialNetworkType); + + std::vector encryptionKeyValue = encryptionKey.value; + controller_->SetEncryptionKey((char *)(encryptionKeyValue.data()), encryptionKey.isOutgoing); + controller_->SetRemoteEndpoints(mappedEndpoints, config.enableP2P, config.maxApiLayer); + + controller_->Start(); + + controller_->Connect(); + } + + ~TgVoipImpl() override = default; + + void setOnStateUpdated(std::function onStateUpdated) override { + onStateUpdated_ = onStateUpdated; + } + + void setOnSignalBarsUpdated(std::function onSignalBarsUpdated) override { + onSignalBarsUpdated_ = onSignalBarsUpdated; + } + + void setNetworkType(TgVoipNetworkType networkType) override { + int mappedType; + + switch (networkType) { + case TgVoipNetworkType::Unknown: + mappedType = tgvoip::NET_TYPE_UNKNOWN; + break; + case TgVoipNetworkType::Gprs: + mappedType = tgvoip::NET_TYPE_GPRS; + break; + case TgVoipNetworkType::Edge: + mappedType = tgvoip::NET_TYPE_EDGE; + break; + case TgVoipNetworkType::ThirdGeneration: + mappedType = tgvoip::NET_TYPE_3G; + break; + case TgVoipNetworkType::Hspa: + mappedType = tgvoip::NET_TYPE_HSPA; + break; + case TgVoipNetworkType::Lte: + mappedType = tgvoip::NET_TYPE_LTE; + break; + case TgVoipNetworkType::WiFi: + mappedType = tgvoip::NET_TYPE_WIFI; + break; + case TgVoipNetworkType::Ethernet: + mappedType = tgvoip::NET_TYPE_ETHERNET; + break; + case TgVoipNetworkType::OtherHighSpeed: + mappedType = tgvoip::NET_TYPE_OTHER_HIGH_SPEED; + break; + case TgVoipNetworkType::OtherLowSpeed: + mappedType = tgvoip::NET_TYPE_OTHER_LOW_SPEED; + break; + case TgVoipNetworkType::OtherMobile: + mappedType = tgvoip::NET_TYPE_OTHER_MOBILE; + break; + case TgVoipNetworkType::Dialup: + mappedType = tgvoip::NET_TYPE_DIALUP; + break; + default: + mappedType = tgvoip::NET_TYPE_UNKNOWN; + break; + } + + controller_->SetNetworkType(mappedType); + } + + void setMuteMicrophone(bool muteMicrophone) override { + controller_->SetMicMute(muteMicrophone); + } + + void setAudioOutputGainControlEnabled(bool enabled) override { + controller_->SetAudioOutputGainControlEnabled(enabled); + } + + void setEchoCancellationStrength(int strength) override { + controller_->SetEchoCancellationStrength(strength); + } + + std::string getLastError() override { + switch (controller_->GetLastError()) { + case tgvoip::ERROR_INCOMPATIBLE: return "ERROR_INCOMPATIBLE"; + case tgvoip::ERROR_TIMEOUT: return "ERROR_TIMEOUT"; + case tgvoip::ERROR_AUDIO_IO: return "ERROR_AUDIO_IO"; + case tgvoip::ERROR_PROXY: return "ERROR_PROXY"; + default: return "ERROR_UNKNOWN"; + } + } + + std::string getDebugInfo() override { + return controller_->GetDebugString(); + } + + int64_t getPreferredRelayId() override { + return controller_->GetPreferredRelayID(); + } + + TgVoipTrafficStats getTrafficStats() override { + tgvoip::VoIPController::TrafficStats stats; + controller_->GetStats(&stats); + return { + .bytesSentWifi = stats.bytesSentWifi, + .bytesReceivedWifi = stats.bytesRecvdWifi, + .bytesSentMobile = stats.bytesSentMobile, + .bytesReceivedMobile = stats.bytesRecvdMobile + }; + } + + TgVoipPersistentState getPersistentState() override { + return {controller_->GetPersistentState()}; + } + + TgVoipFinalState stop() override { + controller_->Stop(); + + TgVoipFinalState finalState = { + .trafficStats = getTrafficStats(), + .persistentState = getPersistentState(), + .debugLog = controller_->GetDebugLog(), + .isRatingSuggested = controller_->NeedRate() + }; + + delete controller_; + controller_ = nullptr; + + return finalState; + } + + static void controllerStateCallback(tgvoip::VoIPController *controller, int state) { + auto *self = (TgVoipImpl *) controller->implData; + if (self->onStateUpdated_) { + TgVoipState mappedState; + switch (state) { + case tgvoip::STATE_WAIT_INIT: + mappedState = TgVoipState::WaitInit; + break; + case tgvoip::STATE_WAIT_INIT_ACK: + mappedState = TgVoipState::WaitInitAck; + break; + case tgvoip::STATE_ESTABLISHED: + mappedState = TgVoipState::Estabilished; + break; + case tgvoip::STATE_FAILED: + mappedState = TgVoipState::Failed; + break; + case tgvoip::STATE_RECONNECTING: + mappedState = TgVoipState::Reconnecting; + break; + default: + mappedState = TgVoipState::Estabilished; + break; + } + + self->onStateUpdated_(mappedState); + } + } + + static void signalBarsCallback(tgvoip::VoIPController *controller, int signalBars) { + auto *self = (TgVoipImpl *) controller->implData; + if (self->onSignalBarsUpdated_) { + self->onSignalBarsUpdated_(signalBars); + } + } +}; + +std::function globalLoggingFunction; + +void __tgvoip_call_tglog(const char *format, ...){ + va_list vaArgs; + va_start(vaArgs, format); + + va_list vaCopy; + va_copy(vaCopy, vaArgs); + const int length = std::vsnprintf(nullptr, 0, format, vaCopy); + va_end(vaCopy); + + std::vector zc(length + 1); + std::vsnprintf(zc.data(), zc.size(), format, vaArgs); + va_end(vaArgs); + + if (globalLoggingFunction != nullptr) { + globalLoggingFunction(std::string(zc.data(), zc.size())); + } +} + +void TgVoip::setLoggingFunction(std::function loggingFunction) { + globalLoggingFunction = loggingFunction; +} + +void TgVoip::setGlobalServerConfig(const std::string &serverConfig) { + tgvoip::ServerConfig::GetSharedInstance()->Update(serverConfig); +} + +int TgVoip::getConnectionMaxLayer() { + return tgvoip::VoIPController::GetConnectionMaxLayer(); +} + +std::string TgVoip::getVersion() { + return tgvoip::VoIPController::GetVersion(); +} + +TgVoip *TgVoip::makeInstance( + TgVoipConfig const &config, + TgVoipPersistentState const &persistentState, + std::vector const &endpoints, + std::unique_ptr const &proxy, + TgVoipNetworkType initialNetworkType, + TgVoipEncryptionKey const &encryptionKey +#ifdef TGVOIP_USE_CUSTOM_CRYPTO + , + TgVoipCrypto const &crypto +#endif +#ifdef TGVOIP_USE_CALLBACK_AUDIO_IO + , + TgVoipAudioDataCallbacks const &audioDataCallbacks +#endif +) { + return new TgVoipImpl( + endpoints, + persistentState, + proxy, + config, + encryptionKey, + initialNetworkType +#ifdef TGVOIP_USE_CUSTOM_CRYPTO + , + crypto +#endif +#ifdef TGVOIP_USE_CALLBACK_AUDIO_IO + , + audioDataCallbacks +#endif + ); +} + +TgVoip::~TgVoip() = default; \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip/TgVoip.h b/TMessagesProj/jni/libtgvoip/TgVoip.h new file mode 100644 index 000000000..2ab571ced --- /dev/null +++ b/TMessagesProj/jni/libtgvoip/TgVoip.h @@ -0,0 +1,160 @@ +#ifndef __TGVOIP_H +#define __TGVOIP_H + +#include +#include +#include +#include + +struct TgVoipProxy { + std::string host; + uint16_t port; + std::string login; + std::string password; +}; + +enum class TgVoipEndpointType { + Inet, + Lan, + UdpRelay, + TcpRelay +}; + +struct TgVoipEndpoint { + int64_t endpointId; + std::string host; + uint16_t port; + TgVoipEndpointType type; + unsigned char peerTag[16]; +}; + +enum class TgVoipNetworkType { + Unknown, + Gprs, + Edge, + ThirdGeneration, + Hspa, + Lte, + WiFi, + Ethernet, + OtherHighSpeed, + OtherLowSpeed, + OtherMobile, + Dialup +}; + +enum class TgVoipDataSaving { + Never, + Mobile, + Always +}; + +struct TgVoipPersistentState { + std::vector value; +}; + +#ifdef TGVOIP_USE_CUSTOM_CRYPTO +struct TgVoipCrypto { + void (*rand_bytes)(uint8_t* buffer, size_t length); + void (*sha1)(uint8_t* msg, size_t length, uint8_t* output); + void (*sha256)(uint8_t* msg, size_t length, uint8_t* output); + void (*aes_ige_encrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); + void (*aes_ige_decrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); + void (*aes_ctr_encrypt)(uint8_t* inout, size_t length, uint8_t* key, uint8_t* iv, uint8_t* ecount, uint32_t* num); + void (*aes_cbc_encrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); + void (*aes_cbc_decrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); +}; +#endif + +struct TgVoipConfig { + double initializationTimeout; + double receiveTimeout; + TgVoipDataSaving dataSaving; + bool enableP2P; + bool enableAEC; + bool enableNS; + bool enableAGC; + bool enableCallUpgrade; + std::string logPath; + int maxApiLayer; +}; + +struct TgVoipEncryptionKey { + std::vector value; + bool isOutgoing; +}; + +enum class TgVoipState { + WaitInit, + WaitInitAck, + Estabilished, + Failed, + Reconnecting +}; + +struct TgVoipTrafficStats { + uint64_t bytesSentWifi; + uint64_t bytesReceivedWifi; + uint64_t bytesSentMobile; + uint64_t bytesReceivedMobile; +}; + +struct TgVoipFinalState { + TgVoipPersistentState persistentState; + std::string debugLog; + TgVoipTrafficStats trafficStats; + bool isRatingSuggested; +}; + +struct TgVoipAudioDataCallbacks { + std::function input; + std::function output; + std::function preprocessed; +}; + +class TgVoip { +protected: + TgVoip() = default; + +public: + static void setLoggingFunction(std::function loggingFunction); + static void setGlobalServerConfig(std::string const &serverConfig); + static int getConnectionMaxLayer(); + static std::string getVersion(); + static TgVoip *makeInstance( + TgVoipConfig const &config, + TgVoipPersistentState const &persistentState, + std::vector const &endpoints, + std::unique_ptr const &proxy, + TgVoipNetworkType initialNetworkType, + TgVoipEncryptionKey const &encryptionKey +#ifdef TGVOIP_USE_CUSTOM_CRYPTO + , + TgVoipCrypto const &crypto +#endif +#ifdef TGVOIP_USE_CALLBACK_AUDIO_IO + , + TgVoipAudioDataCallbacks const &audioDataCallbacks +#endif + ); + + virtual ~TgVoip(); + + virtual void setNetworkType(TgVoipNetworkType networkType) = 0; + virtual void setMuteMicrophone(bool muteMicrophone) = 0; + virtual void setAudioOutputGainControlEnabled(bool enabled) = 0; + virtual void setEchoCancellationStrength(int strength) = 0; + + virtual std::string getLastError() = 0; + virtual std::string getDebugInfo() = 0; + virtual int64_t getPreferredRelayId() = 0; + virtual TgVoipTrafficStats getTrafficStats() = 0; + virtual TgVoipPersistentState getPersistentState() = 0; + + virtual void setOnStateUpdated(std::function onStateUpdated) = 0; + virtual void setOnSignalBarsUpdated(std::function onSignalBarsUpdated) = 0; + + virtual TgVoipFinalState stop() = 0; +}; + +#endif diff --git a/TMessagesProj/jni/libtgvoip/VoIPController.cpp b/TMessagesProj/jni/libtgvoip/VoIPController.cpp index 53cf34a6c..81882f5fb 100755 --- a/TMessagesProj/jni/libtgvoip/VoIPController.cpp +++ b/TMessagesProj/jni/libtgvoip/VoIPController.cpp @@ -29,6 +29,11 @@ #include #include #include +#ifdef HAVE_CONFIG_H +#include +#else +#include +#endif inline int pad4(int x){ @@ -64,74 +69,6 @@ extern jclass jniUtilitiesClass; #include "audio/AudioIOCallback.h" #endif -#pragma mark - OpenSSL wrappers - -#ifndef TGVOIP_USE_CUSTOM_CRYPTO -extern "C" { -#include -#include -//#include -#include -} - -void tgvoip_openssl_aes_ige_encrypt(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv){ - AES_KEY akey; - AES_set_encrypt_key(key, 32*8, &akey); - AES_ige_encrypt(in, out, length, &akey, iv, AES_ENCRYPT); -} - -void tgvoip_openssl_aes_ige_decrypt(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv){ - AES_KEY akey; - AES_set_decrypt_key(key, 32*8, &akey); - AES_ige_encrypt(in, out, length, &akey, iv, AES_DECRYPT); -} - -void tgvoip_openssl_rand_bytes(uint8_t* buffer, size_t len){ - RAND_bytes(buffer, len); -} - -void tgvoip_openssl_sha1(uint8_t* msg, size_t len, uint8_t* output){ - SHA1(msg, len, output); -} - -void tgvoip_openssl_sha256(uint8_t* msg, size_t len, uint8_t* output){ - SHA256(msg, len, output); -} - -void tgvoip_openssl_aes_ctr_encrypt(uint8_t* inout, size_t length, uint8_t* key, uint8_t* iv, uint8_t* ecount, uint32_t* num){ - AES_KEY akey; - AES_set_encrypt_key(key, 32*8, &akey); - AES_ctr128_encrypt(inout, inout, length, &akey, iv, ecount, num); -} - -void tgvoip_openssl_aes_cbc_encrypt(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv){ - AES_KEY akey; - AES_set_encrypt_key(key, 256, &akey); - AES_cbc_encrypt(in, out, length, &akey, iv, AES_ENCRYPT); -} - -void tgvoip_openssl_aes_cbc_decrypt(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv){ - AES_KEY akey; - AES_set_decrypt_key(key, 256, &akey); - AES_cbc_encrypt(in, out, length, &akey, iv, AES_DECRYPT); -} - -CryptoFunctions VoIPController::crypto={ - tgvoip_openssl_rand_bytes, - tgvoip_openssl_sha1, - tgvoip_openssl_sha256, - tgvoip_openssl_aes_ige_encrypt, - tgvoip_openssl_aes_ige_decrypt, - tgvoip_openssl_aes_ctr_encrypt, - tgvoip_openssl_aes_cbc_encrypt, - tgvoip_openssl_aes_cbc_decrypt - -}; -#else -CryptoFunctions VoIPController::crypto; // set it yourself upon initialization -#endif - - extern FILE* tgvoipLogFile; #pragma mark - Public API @@ -294,6 +231,12 @@ VoIPController::~VoIPController(){ tgvoipLogFile=NULL; fclose(log); } +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) + if (preprocDecoder) { + opus_decoder_destroy(preprocDecoder); + preprocDecoder=nullptr; + } +#endif } void VoIPController::Stop(){ @@ -773,10 +716,10 @@ string VoIPController::GetCurrentAudioOutputID(){ void VoIPController::SetProxy(int protocol, string address, uint16_t port, string username, string password){ proxyProtocol=protocol; - proxyAddress=address; + proxyAddress=std::move(address); proxyPort=port; - proxyUsername=username; - proxyPassword=password; + proxyUsername=std::move(username); + proxyPassword=std::move(password); } int VoIPController::GetSignalBarsCount(){ @@ -841,9 +784,11 @@ void VoIPController::SetEchoCancellationStrength(int strength){ } #if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) -void VoIPController::SetAudioDataCallbacks(std::function input, std::function output){ +void VoIPController::SetAudioDataCallbacks(std::function input, std::function output, std::function preproc=nullptr){ audioInputDataCallback=input; audioOutputDataCallback=output; + audioPreprocDataCallback=preproc; + preprocDecoder=preprocDecoder ? preprocDecoder : opus_decoder_create(48000, 1, NULL); } #endif @@ -894,7 +839,7 @@ void VoIPController::SetConfig(const Config& cfg){ void VoIPController::SetPersistentState(vector state){ using namespace json11; - + if(state.empty()) return; string jsonErr; @@ -915,7 +860,7 @@ void VoIPController::SetPersistentState(vector state){ vector VoIPController::GetPersistentState(){ using namespace json11; - + Json::object obj=Json::object{ {"ver", 1}, }; @@ -1116,10 +1061,11 @@ void VoIPController::HandleAudioInput(unsigned char *data, size_t len, unsigned } unsentStreamPackets++; + size_t pktLength = pkt.GetLength(); PendingOutgoingPacket p{ /*.seq=*/GenerateOutSeq(), /*.type=*/PKT_STREAM_DATA, - /*.len=*/pkt.GetLength(), + /*.len=*/pktLength, /*.data=*/Buffer(move(pkt)), /*.endpoint=*/0, }; @@ -1142,10 +1088,11 @@ void VoIPController::HandleAudioInput(unsigned char *data, size_t len, unsigned pkt.WriteBytes(*ecData); } + pktLength = pkt.GetLength(); PendingOutgoingPacket p{ GenerateOutSeq(), PKT_STREAM_EC, - pkt.GetLength(), + pktLength, Buffer(move(pkt)), 0 }; @@ -1153,6 +1100,13 @@ void VoIPController::HandleAudioInput(unsigned char *data, size_t len, unsigned } audioTimestampOut+=outgoingStreams[0]->frameDuration; + +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) + if (audioPreprocDataCallback && preprocDecoder) { + int size=opus_decode(preprocDecoder, data, len, preprocBuffer, 4096, 0); + audioPreprocDataCallback(preprocBuffer, size); + } +#endif } void VoIPController::InitializeAudio(){ @@ -1324,7 +1278,7 @@ void VoIPController::WritePacketHeader(uint32_t pseq, BufferOutputStream *s, uns if(!currentExtras.empty()){ s->WriteByte(static_cast(currentExtras.size())); for(vector::iterator x=currentExtras.begin(); x!=currentExtras.end(); ++x){ - LOGV("Writing extra into header: type %u, length %lu", x->type, x->data.Length()); + LOGV("Writing extra into header: type %u, length %d", x->type, int(x->data.Length())); assert(x->data.Length()<=254); s->WriteByte(static_cast(x->data.Length()+1)); s->WriteByte(x->type); @@ -1406,7 +1360,7 @@ void VoIPController::WritePacketHeader(uint32_t pseq, BufferOutputStream *s, uns s->WriteByte(XPFLAG_HAS_EXTRA); s->WriteByte(static_cast(currentExtras.size())); for(vector::iterator x=currentExtras.begin(); x!=currentExtras.end(); ++x){ - LOGV("Writing extra into header: type %u, length %lu", x->type, x->data.Length()); + LOGV("Writing extra into header: type %u, length %d", x->type, int(x->data.Length())); assert(x->data.Length()<=254); s->WriteByte(static_cast(x->data.Length()+1)); s->WriteByte(x->type); @@ -1486,10 +1440,11 @@ void VoIPController::SendInit(){ out.WriteInt32(id); }*/ } + size_t outLength = out.GetLength(); SendOrEnqueuePacket(PendingOutgoingPacket{ /*.seq=*/initSeq, /*.type=*/PKT_INIT, - /*.len=*/out.GetLength(), + /*.len=*/outLength, /*.data=*/Buffer(move(out)), /*.endpoint=*/e.id }); @@ -1518,14 +1473,14 @@ void VoIPController::InitUDPProxy(){ ResetUdpAvailability(); return; } - + NetworkSocket* tcp=NetworkSocket::Create(PROTO_TCP); tcp->Connect(resolvedProxyAddress, proxyPort); - + vector writeSockets; vector readSockets; vector errorSockets; - + while(!tcp->IsFailed() && !tcp->IsReadyToSend()){ writeSockets.push_back(tcp); if(!NetworkSocket::Select(readSockets, writeSockets, errorSockets, selectCanceller)){ @@ -1579,12 +1534,12 @@ void VoIPController::RunRecvThread(){ udpPingTimeoutID=messageThread.Post(std::bind(&VoIPController::SendUdpPings, this), 0.0, 0.5); } while(runReceiver){ - + if(proxyProtocol==PROXY_SOCKS5 && needReInitUdpProxy){ InitUDPProxy(); needReInitUdpProxy=false; } - + packet.data=*buffer; packet.length=buffer.Length(); @@ -1595,7 +1550,7 @@ void VoIPController::RunRecvThread(){ errorSockets.push_back(realUdpSocket); if(!realUdpSocket->IsReadyToSend()) writeSockets.push_back(realUdpSocket); - + { MutexGuard m(endpointsMutex); for(pair& _e:endpoints){ @@ -2132,7 +2087,7 @@ simpleAudioBlock random_id:long random_bytes:string raw_data:string = DecryptedA } for(vector::iterator x=currentExtras.begin();x!=currentExtras.end();){ if(x->firstContainingSeq!=0 && (lastRemoteAckSeq==x->firstContainingSeq || seqgt(lastRemoteAckSeq, x->firstContainingSeq))){ - LOGV("Peer acknowledged extra type %u length %lu", x->type, x->data.Length()); + LOGV("Peer acknowledged extra type %u length %d", x->type, int(x->data.Length())); ProcessAcknowledgedOutgoingExtra(*x); x=currentExtras.erase(x); continue; @@ -2310,10 +2265,11 @@ simpleAudioBlock random_id:long random_bytes:string raw_data:string = DecryptedA out.WriteByte((unsigned char) ((*s)->enabled ? 1 : 0)); } LOGI("Sending init ack"); + size_t outLength = out.GetLength(); SendOrEnqueuePacket(PendingOutgoingPacket{ /*.seq=*/GenerateOutSeq(), /*.type=*/PKT_INIT_ACK, - /*.len=*/out.GetLength(), + /*.len=*/outLength, /*.data=*/Buffer(move(out)), /*.endpoint=*/0 }); @@ -2541,10 +2497,11 @@ simpleAudioBlock random_id:long random_bytes:string raw_data:string = DecryptedA } BufferOutputStream pkt(128); pkt.WriteInt32(pseq); + size_t pktLength = pkt.GetLength(); SendOrEnqueuePacket(PendingOutgoingPacket{ /*.seq=*/GenerateOutSeq(), /*.type=*/PKT_PONG, - /*.len=*/pkt.GetLength(), + /*.len=*/pktLength, /*.data=*/Buffer(move(pkt)), /*.endpoint=*/srcEndpoint.id, }); @@ -2799,7 +2756,7 @@ bool VoIPController::SendOrEnqueuePacket(PendingOutgoingPacket pkt, bool enqueue abort(); return false; } - + bool canSend; if(endpoint->type!=Endpoint::Type::TCP_RELAY){ @@ -3055,7 +3012,7 @@ void VoIPController::AddTCPRelays(){ relays.push_back(tcpRelay); } for(Endpoint& e:relays){ - endpoints[e.id]=move(e); + endpoints[e.id]=e; } didAddTcpRelays=true; } @@ -3206,7 +3163,7 @@ void VoIPController::SendPacketReliably(unsigned char type, unsigned char *data, void VoIPController::SendExtra(Buffer &data, unsigned char type){ MutexGuard m(queuedPacketsMutex); - LOGV("Sending extra type %u length %lu", type, data.Length()); + LOGV("Sending extra type %u length %d", type, int(data.Length())); for(vector::iterator x=currentExtras.begin();x!=currentExtras.end();++x){ if(x->type==type){ x->firstContainingSeq=0; @@ -3479,16 +3436,17 @@ void VoIPController::SendVideoFrame(const Buffer &frame, uint32_t flags, uint32_ pkt.WriteBytes(frame, offset, len); uint32_t seq=GenerateOutSeq(); + size_t pktLength = pkt.GetLength(); PendingOutgoingPacket p{ /*.seq=*/seq, /*.type=*/PKT_STREAM_DATA, - /*.len=*/pkt.GetLength(), + /*.len=*/pktLength, /*.data=*/Buffer(move(pkt)), /*.endpoint=*/0, }; unsentStreamPackets++; SendOrEnqueuePacket(move(p)); - videoCongestionControl.ProcessPacketSent(static_cast(pkt.GetLength())); + videoCongestionControl.ProcessPacketSent(static_cast(pktLength)); sentFrame.unacknowledgedPackets.push_back(seq); } MutexGuard m(sentVideoFramesMutex); @@ -3750,7 +3708,7 @@ void VoIPController::UpdateCongestion(){ wasExtraEC=true; } } - + if(avgSendLossCount>0.08){ extraEcLevel=4; }else if(avgSendLossCount>0.05){ @@ -4019,7 +3977,7 @@ Endpoint::~Endpoint(){ #pragma mark - AudioInputTester -AudioInputTester::AudioInputTester(std::string deviceID) : deviceID(deviceID){ +AudioInputTester::AudioInputTester(std::string deviceID) : deviceID(std::move(deviceID)){ io=audio::AudioIO::Create(deviceID, "default"); if(io->Failed()){ LOGE("Audio IO failed"); diff --git a/TMessagesProj/jni/libtgvoip/VoIPController.h b/TMessagesProj/jni/libtgvoip/VoIPController.h index 0f6cdcdff..0b1a4d4e7 100755 --- a/TMessagesProj/jni/libtgvoip/VoIPController.h +++ b/TMessagesProj/jni/libtgvoip/VoIPController.h @@ -402,7 +402,7 @@ namespace tgvoip{ void SetPersistentState(std::vector state); #if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) - void SetAudioDataCallbacks(std::function input, std::function output); + void SetAudioDataCallbacks(std::function input, std::function output, std::function preprocessed); #endif void SetVideoCodecSpecificData(const std::vector& data); @@ -749,6 +749,9 @@ namespace tgvoip{ #if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) std::function audioInputDataCallback; std::function audioOutputDataCallback; + std::function audioPreprocDataCallback; + ::OpusDecoder* preprocDecoder=nullptr; + int16_t preprocBuffer[4096]; #endif #if defined(__APPLE__) && defined(TARGET_OS_OSX) bool macAudioDuckingEnabled=true; diff --git a/TMessagesProj/jni/libtgvoip/audio/Resampler.cpp b/TMessagesProj/jni/libtgvoip/audio/Resampler.cpp index 076d4ca78..74583afba 100644 --- a/TMessagesProj/jni/libtgvoip/audio/Resampler.cpp +++ b/TMessagesProj/jni/libtgvoip/audio/Resampler.cpp @@ -58,7 +58,7 @@ static const int16_t hann[960]={ 0x7FDE, 0x7FE1, 0x7FE4, 0x7FE7, 0x7FEA, 0x7FED, 0x7FEF, 0x7FF1, 0x7FF3, 0x7FF5, 0x7FF7, 0x7FF9, 0x7FFA, 0x7FFB, 0x7FFC, 0x7FFD, 0x7FFE, 0x7FFE, 0x7FFF, 0x7FFF }; -#define MIN(a, b) (a +#include +#include +#include +#include +#include "org_telegram_messenger_voip_TgVoip.h" + +using namespace tgvoip; + +extern "C" int tgvoipOnJniLoad(JavaVM *vm, JNIEnv *env) { + return JNI_TRUE; +} + +#pragma mark - Helpers + +class JavaObject { +private: + JNIEnv *env; + jobject obj; + jclass clazz; + +public: + JavaObject(JNIEnv *env, jobject obj) : JavaObject(env, obj, env->GetObjectClass(obj)) { + } + + JavaObject(JNIEnv *env, jobject obj, jclass clazz) { + this->env = env; + this->obj = obj; + this->clazz = clazz; + } + + jint getIntField(const char *name) { + return env->GetIntField(obj, env->GetFieldID(clazz, name, "I")); + } + + jlong getLongField(const char *name) { + return env->GetLongField(obj, env->GetFieldID(clazz, name, "J")); + } + + jboolean getBooleanField(const char *name) { + return env->GetBooleanField(obj, env->GetFieldID(clazz, name, "Z")); + } + + jdouble getDoubleField(const char *name) { + return env->GetDoubleField(obj, env->GetFieldID(clazz, name, "D")); + } + + jbyteArray getByteArrayField(const char *name) { + return (jbyteArray) env->GetObjectField(obj, env->GetFieldID(clazz, name, "[B")); + } + + jstring getStringField(const char *name) { + return (jstring) env->GetObjectField(obj, env->GetFieldID(clazz, name, "Ljava/lang/String;")); + } +}; + +struct InstanceHolder { + TgVoip *nativeInstance; + jobject javaInstance; +}; + +jlong getInstanceHolderId(JNIEnv *env, jobject obj) { + return env->GetLongField(obj, env->GetFieldID(env->GetObjectClass(obj), "nativeInstanceId", "J")); +} + +InstanceHolder *getInstanceHolder(JNIEnv *env, jobject obj) { + return reinterpret_cast(getInstanceHolderId(env, obj)); +} + +TgVoip *getTgVoip(JNIEnv *env, jobject obj) { + return getInstanceHolder(env, obj)->nativeInstance; +} + +jint throwNewJavaException(JNIEnv *env, const char *className, const char *message) { + return env->ThrowNew(env->FindClass(className), message); +} + +jint throwNewJavaIllegalArgumentException(JNIEnv *env, const char *message) { + return throwNewJavaException(env, "java/lang/IllegalStateException", message); +} + +jbyteArray copyVectorToJavaByteArray(JNIEnv *env, const std::vector &bytes) { + unsigned int size = bytes.size(); + jbyteArray bytesArray = env->NewByteArray(size); + env->SetByteArrayRegion(bytesArray, 0, size, (jbyte *) bytes.data()); + return bytesArray; +} + +void readTgVoipPersistentState(const char *filePath, TgVoipPersistentState &tgVoipPersistentState) { + FILE *persistentStateFile = fopen(filePath, "r"); + if (persistentStateFile) { + fseek(persistentStateFile, 0, SEEK_END); + auto len = static_cast(ftell(persistentStateFile)); + fseek(persistentStateFile, 0, SEEK_SET); + if (len < 1024 * 512 && len > 0) { + auto *buffer = static_cast(malloc(len)); + fread(buffer, 1, len, persistentStateFile); + tgVoipPersistentState.value = std::vector(buffer, buffer + len); + free(buffer); + } + fclose(persistentStateFile); + } +} + +void saveTgVoipPersistentState(const char *filePath, const TgVoipPersistentState &tgVoipPersistentState) { + FILE *persistentStateFile = fopen(filePath, "w"); + if (persistentStateFile) { + fwrite(tgVoipPersistentState.value.data(), 1, tgVoipPersistentState.value.size(), persistentStateFile); + fclose(persistentStateFile); + } +} + +#pragma mark - Mappers + +TgVoipNetworkType parseTgVoipNetworkType(jint networkType) { + switch (networkType) { + case org_telegram_messenger_voip_TgVoip_NET_TYPE_GPRS: + return TgVoipNetworkType::Gprs; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_EDGE: + return TgVoipNetworkType::Edge; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_3G: + return TgVoipNetworkType::ThirdGeneration; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_HSPA: + return TgVoipNetworkType::Hspa; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_LTE: + return TgVoipNetworkType::Lte; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_WIFI: + return TgVoipNetworkType::WiFi; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_ETHERNET: + return TgVoipNetworkType::Ethernet; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_HIGH_SPEED: + return TgVoipNetworkType::OtherHighSpeed; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_LOW_SPEED: + return TgVoipNetworkType::OtherLowSpeed; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_DIALUP: + return TgVoipNetworkType::Dialup; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_MOBILE: + return TgVoipNetworkType::OtherMobile; + default: + return TgVoipNetworkType::Unknown; + } +} + +TgVoipDataSaving parseTgVoipDataSaving(JNIEnv *env, jint dataSaving) { + switch (dataSaving) { + case org_telegram_messenger_voip_TgVoip_DATA_SAVING_NEVER: + return TgVoipDataSaving::Never; + case org_telegram_messenger_voip_TgVoip_DATA_SAVING_MOBILE: + return TgVoipDataSaving::Mobile; + case org_telegram_messenger_voip_TgVoip_DATA_SAVING_ALWAYS: + return TgVoipDataSaving::Always; + case org_telegram_messenger_voip_TgVoip_DATA_SAVING_ROAMING: + throwNewJavaIllegalArgumentException(env, "DATA_SAVING_ROAMING is not supported"); + return TgVoipDataSaving::Never; + default: + throwNewJavaIllegalArgumentException(env, "Unknown data saving constant: " + dataSaving); + return TgVoipDataSaving::Never; + } +} + +void parseTgVoipConfig(JNIEnv *env, jobject config, TgVoipConfig &tgVoipConfig) { + JavaObject configObject(env, config); + tgVoipConfig.initializationTimeout = configObject.getDoubleField("initializationTimeout"); + tgVoipConfig.receiveTimeout = configObject.getDoubleField("receiveTimeout"); + tgVoipConfig.dataSaving = parseTgVoipDataSaving(env, configObject.getIntField("dataSaving")); + tgVoipConfig.enableP2P = configObject.getBooleanField("enableP2p") == JNI_TRUE; + tgVoipConfig.enableAEC = configObject.getBooleanField("enableAec") == JNI_TRUE; + tgVoipConfig.enableNS = configObject.getBooleanField("enableNs") == JNI_TRUE; + tgVoipConfig.enableAGC = configObject.getBooleanField("enableAgc") == JNI_TRUE; + tgVoipConfig.enableCallUpgrade = configObject.getBooleanField("enableCallUpgrade") == JNI_TRUE; + tgVoipConfig.logPath = jni::JavaStringToStdString(env, configObject.getStringField("logPath")); + tgVoipConfig.maxApiLayer = configObject.getIntField("maxApiLayer"); +} + +TgVoipEndpointType parseTgVoipEndpointType(JNIEnv *env, jint endpointType) { + switch (endpointType) { + case org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_INET: + return TgVoipEndpointType::Inet; + case org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_LAN: + return TgVoipEndpointType::Lan; + case org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_TCP_RELAY: + return TgVoipEndpointType::TcpRelay; + case org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_UDP_RELAY: + return TgVoipEndpointType::UdpRelay; + default: + throwNewJavaIllegalArgumentException(env, std::string("Unknown endpoint type: ").append(std::to_string(endpointType)).c_str()); + return TgVoipEndpointType::UdpRelay; + } +} + +void parseTgVoipEndpoint(JNIEnv *env, jobject endpoint, TgVoipEndpoint &tgVoipEndpoint) { + JavaObject endpointObject(env, endpoint); + tgVoipEndpoint.endpointId = endpointObject.getLongField("id"); + tgVoipEndpoint.host = jni::JavaStringToStdString(env, endpointObject.getStringField("ipv4")); + tgVoipEndpoint.port = static_cast(endpointObject.getIntField("port")); + tgVoipEndpoint.type = parseTgVoipEndpointType(env, endpointObject.getIntField("type")); + jbyteArray peerTag = endpointObject.getByteArrayField("peerTag"); + if (peerTag && env->GetArrayLength(peerTag)) { + jbyte *peerTagBytes = env->GetByteArrayElements(peerTag, nullptr); + memcpy(tgVoipEndpoint.peerTag, peerTagBytes, 16); + env->ReleaseByteArrayElements(peerTag, peerTagBytes, JNI_ABORT); + } +} + +void parseTgVoipEndpoints(JNIEnv *env, jobjectArray endpoints, std::vector &tgVoipEndpoints) { + for (int i = 0, size = env->GetArrayLength(endpoints); i < size; i++) { + TgVoipEndpoint tgVoipEndpoint; + parseTgVoipEndpoint(env, env->GetObjectArrayElement(endpoints, i), tgVoipEndpoint); + tgVoipEndpoints.push_back(tgVoipEndpoint); + } +} + +void parseTgVoipEncryptionKey(JNIEnv *env, jobject encryptionKey, TgVoipEncryptionKey &tgVoipEncryptionKey) { + JavaObject encryptionKeyObject(env, encryptionKey); + tgVoipEncryptionKey.isOutgoing = encryptionKeyObject.getBooleanField("isOutgoing") == JNI_TRUE; + jbyteArray valueByteArray = encryptionKeyObject.getByteArrayField("value"); + auto *valueBytes = (uint8_t *) env->GetByteArrayElements(valueByteArray, nullptr); + tgVoipEncryptionKey.value = std::vector(valueBytes, valueBytes + env->GetArrayLength(valueByteArray)); + env->ReleaseByteArrayElements(valueByteArray, (jbyte *) valueBytes, JNI_ABORT); +} + +void parseTgVoipProxy(JNIEnv *env, jobject proxy, std::unique_ptr &tgVoipProxy) { + if (!env->IsSameObject(proxy, nullptr)) { + JavaObject proxyObject(env, proxy); + tgVoipProxy = std::unique_ptr(new TgVoipProxy); + tgVoipProxy->host = jni::JavaStringToStdString(env, proxyObject.getStringField("host")); + tgVoipProxy->port = static_cast(proxyObject.getIntField("port")); + tgVoipProxy->login = jni::JavaStringToStdString(env, proxyObject.getStringField("login")); + tgVoipProxy->password = jni::JavaStringToStdString(env, proxyObject.getStringField("password")); + } else { + tgVoipProxy = nullptr; + } +} + +jint asJavaState(const TgVoipState &tgVoipState) { + switch (tgVoipState) { + case TgVoipState::WaitInit: + return org_telegram_messenger_voip_TgVoip_STATE_WAIT_INIT; + case TgVoipState::WaitInitAck: + return org_telegram_messenger_voip_TgVoip_STATE_WAIT_INIT_ACK; + case TgVoipState::Estabilished: + return org_telegram_messenger_voip_TgVoip_STATE_ESTABLISHED; + case TgVoipState::Failed: + return org_telegram_messenger_voip_TgVoip_STATE_FAILED; + case TgVoipState::Reconnecting: + return org_telegram_messenger_voip_TgVoip_STATE_RECONNECTING; + } +} + +jobject asJavaTrafficStats(JNIEnv *env, const TgVoipTrafficStats &trafficStats) { + jclass clazz = env->FindClass("org/telegram/messenger/voip/TgVoip$TrafficStats"); + jmethodID initMethodId = env->GetMethodID(clazz, "", "(JJJJ)V"); + return env->NewObject(clazz, initMethodId, trafficStats.bytesSentWifi, trafficStats.bytesReceivedWifi, trafficStats.bytesSentMobile, trafficStats.bytesReceivedMobile); +} + +jobject asJavaFinalState(JNIEnv *env, const TgVoipFinalState &tgVoipFinalState) { + jbyteArray persistentState = copyVectorToJavaByteArray(env, tgVoipFinalState.persistentState.value); + jstring debugLog = env->NewStringUTF(tgVoipFinalState.debugLog.c_str()); + jobject trafficStats = asJavaTrafficStats(env, tgVoipFinalState.trafficStats); + auto isRatingSuggested = static_cast(tgVoipFinalState.isRatingSuggested); + jclass finalStateClass = env->FindClass("org/telegram/messenger/voip/TgVoip$FinalState"); + jmethodID finalStateInitMethodId = env->GetMethodID(finalStateClass, "", "([BLjava/lang/String;Lorg/telegram/messenger/voip/TgVoip$TrafficStats;Z)V"); + return env->NewObject(finalStateClass, finalStateInitMethodId, persistentState, debugLog, trafficStats, isRatingSuggested); +} + +extern "C" { + + #pragma mark - Static JNI Methods + + JNIEXPORT jlong JNICALL Java_org_telegram_messenger_voip_NativeTgVoipDelegate_makeNativeInstance(JNIEnv *env, jobject obj, jobject instanceObj, jobject config, jstring persistentStateFilePath, jobjectArray endpoints, jobject proxy, jint networkType, jobject encryptionKey) { + // reading persistent state + TgVoipPersistentState tgVoipPersistentState; + readTgVoipPersistentState(jni::JavaStringToStdString(env, persistentStateFilePath).c_str(), tgVoipPersistentState); + + // parsing config + TgVoipConfig tgVoipConfig; + parseTgVoipConfig(env, config, tgVoipConfig); + + // parsing endpoints + std::vector tgVoipEndpoints; + parseTgVoipEndpoints(env, endpoints, tgVoipEndpoints); + + // parsing proxy + std::unique_ptr tgVoipProxy; + parseTgVoipProxy(env, proxy, tgVoipProxy); + + // parse encryption key + TgVoipEncryptionKey tgVoipEncryptionKey; + parseTgVoipEncryptionKey(env, encryptionKey, tgVoipEncryptionKey); + + TgVoip *tgVoip = TgVoip::makeInstance(tgVoipConfig, tgVoipPersistentState, tgVoipEndpoints, tgVoipProxy, parseTgVoipNetworkType(networkType), tgVoipEncryptionKey); + + if (env->ExceptionCheck() == JNI_TRUE) { + return 0; + } + + jobject globalRef = env->NewGlobalRef(instanceObj); + + tgVoip->setOnStateUpdated([globalRef](TgVoipState tgVoipState) { + jint state = asJavaState(tgVoipState); + jni::DoWithJNI([globalRef, state](JNIEnv *env) { + env->CallVoidMethod(globalRef, env->GetMethodID(env->GetObjectClass(globalRef), "onStateUpdated", "(I)V"), state); + }); + }); + + tgVoip->setOnSignalBarsUpdated([globalRef](int signalBars) { + jni::DoWithJNI([globalRef, signalBars](JNIEnv *env) { + env->CallVoidMethod(globalRef, env->GetMethodID(env->GetObjectClass(globalRef), "onSignalBarsUpdated", "(I)V"), signalBars); + }); + }); + + auto *instance = new InstanceHolder; + instance->nativeInstance = tgVoip; + instance->javaInstance = globalRef; + return reinterpret_cast(instance); + } + + JNIEXPORT void JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipDelegate_setGlobalServerConfig(JNIEnv *env, jobject obj, jstring serverConfigJson) { + TgVoip::setGlobalServerConfig(jni::JavaStringToStdString(env, serverConfigJson)); + } + + JNIEXPORT jint JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipDelegate_getConnectionMaxLayer(JNIEnv *env, jobject obj) { + return TgVoip::getConnectionMaxLayer(); + } + + JNIEXPORT jstring JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipDelegate_getVersion(JNIEnv *env, jobject obj) { + return env->NewStringUTF(TgVoip::getVersion().c_str()); + } + + JNIEXPORT void JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipDelegate_setBufferSize(JNIEnv *env, jobject obj, jint size) { + tgvoip::audio::AudioOutputOpenSLES::nativeBufferSize = (unsigned int) size; + tgvoip::audio::AudioInputOpenSLES::nativeBufferSize = (unsigned int) size; + } + + #pragma mark - Virtual JNI Methods + + JNIEXPORT void JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_setNetworkType(JNIEnv *env, jobject obj, jint networkType) { + getTgVoip(env, obj)->setNetworkType(parseTgVoipNetworkType(networkType)); + } + + JNIEXPORT void JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_setMuteMicrophone(JNIEnv *env, jobject obj, jboolean muteMicrophone) { + getTgVoip(env, obj)->setMuteMicrophone(muteMicrophone); + } + + JNIEXPORT void JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_setAudioOutputGainControlEnabled(JNIEnv *env, jobject obj, jboolean enabled) { + getTgVoip(env, obj)->setAudioOutputGainControlEnabled(enabled); + } + + JNIEXPORT void JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_setEchoCancellationStrength(JNIEnv *env, jobject obj, jint strength) { + getTgVoip(env, obj)->setEchoCancellationStrength(strength); + } + + JNIEXPORT jstring JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_getLastError(JNIEnv *env, jobject obj) { + return env->NewStringUTF(getTgVoip(env, obj)->getLastError().c_str()); + } + + JNIEXPORT jstring JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_getDebugInfo(JNIEnv *env, jobject obj) { + return env->NewStringUTF(getTgVoip(env, obj)->getDebugInfo().c_str()); + } + + JNIEXPORT jlong JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_getPreferredRelayId(JNIEnv *env, jobject obj) { + return getTgVoip(env, obj)->getPreferredRelayId(); + } + + JNIEXPORT jobject JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_getTrafficStats(JNIEnv *env, jobject obj) { + return asJavaTrafficStats(env, getTgVoip(env, obj)->getTrafficStats()); + } + + JNIEXPORT jbyteArray JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_getPersistentState(JNIEnv *env, jobject obj) { + return copyVectorToJavaByteArray(env, getTgVoip(env, obj)->getPersistentState().value); + } + + JNIEXPORT jobject JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_stop(JNIEnv *env, jobject obj) { + InstanceHolder *instance = getInstanceHolder(env, obj); + TgVoipFinalState tgVoipFinalState = instance->nativeInstance->stop(); + + // saving persistent state + const std::string &path = jni::JavaStringToStdString(env, JavaObject(env, obj).getStringField("persistentStateFilePath")); + saveTgVoipPersistentState(path.c_str(), tgVoipFinalState.persistentState); + + // clean + env->DeleteGlobalRef(instance->javaInstance); + delete instance->nativeInstance; + delete instance; + + return asJavaFinalState(env, tgVoipFinalState); + } +} \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip/client/android/org_telegram_messenger_voip_TgVoip.h b/TMessagesProj/jni/libtgvoip/client/android/org_telegram_messenger_voip_TgVoip.h new file mode 100644 index 000000000..ae6775a6a --- /dev/null +++ b/TMessagesProj/jni/libtgvoip/client/android/org_telegram_messenger_voip_TgVoip.h @@ -0,0 +1,63 @@ +#include + +#ifndef _Included_org_telegram_messenger_voip_TgVoip +#define _Included_org_telegram_messenger_voip_TgVoip +#ifdef __cplusplus +extern "C" { +#endif +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_UNKNOWN +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_UNKNOWN 0L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_GPRS +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_GPRS 1L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_EDGE +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_EDGE 2L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_3G +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_3G 3L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_HSPA +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_HSPA 4L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_LTE +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_LTE 5L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_WIFI +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_WIFI 6L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_ETHERNET +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_ETHERNET 7L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_HIGH_SPEED +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_HIGH_SPEED 8L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_LOW_SPEED +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_LOW_SPEED 9L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_DIALUP +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_DIALUP 10L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_MOBILE +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_MOBILE 11L +#undef org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_INET +#define org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_INET 0L +#undef org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_LAN +#define org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_LAN 1L +#undef org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_UDP_RELAY +#define org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_UDP_RELAY 2L +#undef org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_TCP_RELAY +#define org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_TCP_RELAY 3L +#undef org_telegram_messenger_voip_TgVoip_STATE_WAIT_INIT +#define org_telegram_messenger_voip_TgVoip_STATE_WAIT_INIT 1L +#undef org_telegram_messenger_voip_TgVoip_STATE_WAIT_INIT_ACK +#define org_telegram_messenger_voip_TgVoip_STATE_WAIT_INIT_ACK 2L +#undef org_telegram_messenger_voip_TgVoip_STATE_ESTABLISHED +#define org_telegram_messenger_voip_TgVoip_STATE_ESTABLISHED 3L +#undef org_telegram_messenger_voip_TgVoip_STATE_FAILED +#define org_telegram_messenger_voip_TgVoip_STATE_FAILED 4L +#undef org_telegram_messenger_voip_TgVoip_STATE_RECONNECTING +#define org_telegram_messenger_voip_TgVoip_STATE_RECONNECTING 5L +#undef org_telegram_messenger_voip_TgVoip_DATA_SAVING_NEVER +#define org_telegram_messenger_voip_TgVoip_DATA_SAVING_NEVER 0L +#undef org_telegram_messenger_voip_TgVoip_DATA_SAVING_MOBILE +#define org_telegram_messenger_voip_TgVoip_DATA_SAVING_MOBILE 1L +#undef org_telegram_messenger_voip_TgVoip_DATA_SAVING_ALWAYS +#define org_telegram_messenger_voip_TgVoip_DATA_SAVING_ALWAYS 2L +#undef org_telegram_messenger_voip_TgVoip_DATA_SAVING_ROAMING +#define org_telegram_messenger_voip_TgVoip_DATA_SAVING_ROAMING 3L +#undef org_telegram_messenger_voip_TgVoip_PEER_CAP_GROUP_CALLS +#define org_telegram_messenger_voip_TgVoip_PEER_CAP_GROUP_CALLS 1L +#ifdef __cplusplus +} +#endif +#endif diff --git a/TMessagesProj/jni/libtgvoip/client/android/tg_voip_jni.cpp b/TMessagesProj/jni/libtgvoip/client/android/tg_voip_jni.cpp index 9371e8dd1..e076649c4 100644 --- a/TMessagesProj/jni/libtgvoip/client/android/tg_voip_jni.cpp +++ b/TMessagesProj/jni/libtgvoip/client/android/tg_voip_jni.cpp @@ -21,6 +21,7 @@ #include "../../os/android/JNIUtilities.h" #include "../../PrivateDefines.h" #include "../../logging.h" +#include "../../../c_utils.h" #ifdef TGVOIP_HAS_CONFIG #include @@ -560,7 +561,20 @@ namespace tgvoip { } } -extern "C" void tgvoipRegisterNatives(JNIEnv* env){ +extern "C" int tgvoipOnJniLoad(JavaVM *vm, JNIEnv *env); + +extern "C" jint JNI_OnLoad(JavaVM *vm, void *reserved) { + JNIEnv *env = 0; + srand(time(NULL)); + + if (vm->GetEnv((void **) &env, JNI_VERSION_1_6) != JNI_OK) { + return -1; + } + + if (tgvoipOnJniLoad(vm, env) != JNI_TRUE) { + return -1; + } + jclass controller=env->FindClass(TGVOIP_PACKAGE_PATH "/VoIPController"); jclass groupController=env->FindClass(TGVOIP_PACKAGE_PATH "/VoIPGroupController"); if(env->ExceptionCheck()){ @@ -730,4 +744,6 @@ extern "C" void tgvoipRegisterNatives(JNIEnv* env){ }; env->RegisterNatives(vlog, vlogMethods, sizeof(vlogMethods)/sizeof(JNINativeMethod)); } -} + + return JNI_VERSION_1_6; +} \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip/os/android/JNIUtilities.h b/TMessagesProj/jni/libtgvoip/os/android/JNIUtilities.h index 0735e88f4..09382e01c 100644 --- a/TMessagesProj/jni/libtgvoip/os/android/JNIUtilities.h +++ b/TMessagesProj/jni/libtgvoip/os/android/JNIUtilities.h @@ -16,10 +16,15 @@ extern JavaVM* sharedJVM; namespace tgvoip{ namespace jni{ - inline void DoWithJNI(std::function f){ - JNIEnv *env=NULL; - bool didAttach=false; + inline JNIEnv *GetEnv() { + JNIEnv *env = nullptr; sharedJVM->GetEnv((void **) &env, JNI_VERSION_1_6); + return env; + } + + inline void DoWithJNI(std::function f){ + JNIEnv *env=GetEnv(); + bool didAttach=false; if(!env){ sharedJVM->AttachCurrentThread(&env, NULL); didAttach=true; @@ -59,7 +64,6 @@ namespace tgvoip{ env->ReleaseByteArrayElements(arr, elements, 0); return arr; } - } } diff --git a/TMessagesProj/jni/libtgvoip/os/darwin/AudioUnitIO.h b/TMessagesProj/jni/libtgvoip/os/darwin/AudioUnitIO.h index 981a7e95a..14351d8eb 100644 --- a/TMessagesProj/jni/libtgvoip/os/darwin/AudioUnitIO.h +++ b/TMessagesProj/jni/libtgvoip/os/darwin/AudioUnitIO.h @@ -39,7 +39,9 @@ class AudioOutputAudioUnit; std::string currentInputDevice; std::string currentOutputDevice; bool duckingEnabled=true; +#ifndef TGVOIP_NO_OSX_PRIVATE_API bool actualDuckingEnabled=true; +#endif // TGVOIP_NO_OSX_PRIVATE_API AudioDeviceID currentOutputDeviceID; #endif AudioComponentInstance unit; diff --git a/TMessagesProj/jni/libtgvoip/os/linux/AudioPulse.cpp b/TMessagesProj/jni/libtgvoip/os/linux/AudioPulse.cpp index 701d85155..f02ece864 100644 --- a/TMessagesProj/jni/libtgvoip/os/linux/AudioPulse.cpp +++ b/TMessagesProj/jni/libtgvoip/os/linux/AudioPulse.cpp @@ -193,7 +193,7 @@ AudioPulse::AudioPulse(std::string inputDevice, std::string outputDevice){ isLocked=false; output=new AudioOutputPulse(context, mainloop, outputDevice); - input=new AudioInputPulse(context, mainloop, outputDevice); + input=new AudioInputPulse(context, mainloop, inputDevice); } AudioPulse::~AudioPulse(){ diff --git a/TMessagesProj/jni/libtgvoip2/.gitignore b/TMessagesProj/jni/libtgvoip2/.gitignore new file mode 100644 index 000000000..e8739ba32 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/.gitignore @@ -0,0 +1,26 @@ +.DS_Store +bin +.idea +build +*/Debug/* +*/Release/* + +# Build results +[Dd]ebug/ +[Dd]ebugPublic/ +[Rr]elease/ +[Rr]eleases/ +[Pp]review/ +[Pp]roduction/ +x64/ +x86/ +bld/ +[Bb]in/ +[Oo]bj/ +DerivedData/ + +# Visual Studio 2015 cache/options directory +.vs/ + +xcuserdata/ +autom4te.cache/ \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/Android.mk b/TMessagesProj/jni/libtgvoip2/Android.mk new file mode 100644 index 000000000..52a2c437e --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/Android.mk @@ -0,0 +1,560 @@ +LOCAL_PATH := $(call my-dir) + +LOCAL_MODULE := tgvoip${TGVOIP_NATIVE_VERSION} +LOCAL_CPPFLAGS := -Wall -std=c++11 -DANDROID -finline-functions -ffast-math -Os -fno-strict-aliasing -O3 -frtti -D__STDC_LIMIT_MACROS -Wno-unknown-pragmas +LOCAL_CPPFLAGS += -DBSD=1 -funroll-loops +LOCAL_CFLAGS := -O3 -DUSE_KISS_FFT -fexceptions -DWEBRTC_APM_DEBUG_DUMP=0 -DWEBRTC_POSIX -DWEBRTC_ANDROID -D__STDC_LIMIT_MACROS -DWEBRTC_NS_FLOAT +LOCAL_CFLAGS += -DNULL=0 -DSOCKLEN_T=socklen_t -DLOCALE_NOT_USED -D_LARGEFILE_SOURCE=1 -D_FILE_OFFSET_BITS=64 +LOCAL_CFLAGS += -Drestrict='' -D__EMX__ -DOPUS_BUILD -DFIXED_POINT -DUSE_ALLOCA -DHAVE_LRINT -DHAVE_LRINTF -fno-math-errno +LOCAL_LDLIBS := -llog -lOpenSLES +LOCAL_STATIC_LIBRARIES := crypto + +MY_DIR := libtgvoip2 + +LOCAL_C_INCLUDES := \ +$(LOCAL_PATH)/../opus/include \ +$(LOCAL_PATH)/../opus/silk \ +$(LOCAL_PATH)/../opus/silk/fixed \ +$(LOCAL_PATH)/../opus/celt \ +$(LOCAL_PATH)/../opus/ \ +$(LOCAL_PATH)/../opus/opusfile \ +$(LOCAL_PATH)/../boringssl/include/ \ +$(LOCAL_PATH)/webrtc_dsp/ + +ifeq ($(TARGET_ARCH_ABI),$(filter $(TARGET_ARCH_ABI),armeabi-v7a arm64-v8a)) +CC_NEON := cc.neon +LOCAL_CFLAGS += -DWEBRTC_HAS_NEON +else +CC_NEON := cc +endif + +LOCAL_CFLAGS += $(TGVOIP_ADDITIONAL_CFLAGS) + +LOCAL_SRC_FILES := \ +./logging.cpp \ +./TgVoip.cpp \ +./VoIPController.cpp \ +./VoIPGroupController.cpp \ +./Buffers.cpp \ +./BlockingQueue.cpp \ +./audio/AudioInput.cpp \ +./os/android/AudioInputOpenSLES.cpp \ +./MediaStreamItf.cpp \ +./audio/AudioOutput.cpp \ +./OpusEncoder.cpp \ +./os/android/AudioOutputOpenSLES.cpp \ +./JitterBuffer.cpp \ +./OpusDecoder.cpp \ +./os/android/OpenSLEngineWrapper.cpp \ +./os/android/AudioInputAndroid.cpp \ +./os/android/AudioOutputAndroid.cpp \ +./EchoCanceller.cpp \ +./CongestionControl.cpp \ +./VoIPServerConfig.cpp \ +./audio/Resampler.cpp \ +./NetworkSocket.cpp \ +./os/posix/NetworkSocketPosix.cpp \ +./PacketReassembler.cpp \ +./MessageThread.cpp \ +./json11.cpp \ +./audio/AudioIO.cpp \ +./video/VideoRenderer.cpp \ +./video/VideoSource.cpp \ +./video/ScreamCongestionController.cpp \ +./os/android/VideoSourceAndroid.cpp \ +./os/android/VideoRendererAndroid.cpp \ +./client/android/org_telegram_messenger_voip_TgVoip.cpp \ +./client/android/tg_voip_jni.cpp + +# WebRTC signal processing + +LOCAL_SRC_FILES += \ +./webrtc_dsp/system_wrappers/source/field_trial.cc \ +./webrtc_dsp/system_wrappers/source/metrics.cc \ +./webrtc_dsp/system_wrappers/source/cpu_features.cc \ +./webrtc_dsp/absl/strings/internal/memutil.cc \ +./webrtc_dsp/absl/strings/string_view.cc \ +./webrtc_dsp/absl/strings/ascii.cc \ +./webrtc_dsp/absl/types/bad_optional_access.cc \ +./webrtc_dsp/absl/types/optional.cc \ +./webrtc_dsp/absl/base/internal/raw_logging.cc \ +./webrtc_dsp/absl/base/internal/throw_delegate.cc \ +./webrtc_dsp/rtc_base/race_checker.cc \ +./webrtc_dsp/rtc_base/strings/string_builder.cc \ +./webrtc_dsp/rtc_base/memory/aligned_malloc.cc \ +./webrtc_dsp/rtc_base/timeutils.cc \ +./webrtc_dsp/rtc_base/platform_file.cc \ +./webrtc_dsp/rtc_base/string_to_number.cc \ +./webrtc_dsp/rtc_base/thread_checker_impl.cc \ +./webrtc_dsp/rtc_base/stringencode.cc \ +./webrtc_dsp/rtc_base/stringutils.cc \ +./webrtc_dsp/rtc_base/checks.cc \ +./webrtc_dsp/rtc_base/platform_thread.cc \ +./webrtc_dsp/rtc_base/criticalsection.cc \ +./webrtc_dsp/rtc_base/platform_thread_types.cc \ +./webrtc_dsp/rtc_base/event.cc \ +./webrtc_dsp/rtc_base/event_tracer.cc \ +./webrtc_dsp/rtc_base/logging_webrtc.cc \ +./webrtc_dsp/third_party/rnnoise/src/rnn_vad_weights.cc \ +./webrtc_dsp/third_party/rnnoise/src/kiss_fft.cc \ +./webrtc_dsp/api/audio/audio_frame.cc \ +./webrtc_dsp/api/audio/echo_canceller3_config.cc \ +./webrtc_dsp/api/audio/echo_canceller3_factory.cc \ +./webrtc_dsp/modules/third_party/fft/fft.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_estimator.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb16_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_gain_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines_logist.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filterbanks.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/transform.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_filter.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode_lpc_swb.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filter_functions.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/decode.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lattice.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/intialize.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_gain_swb_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/bandwidth_estimator.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_analysis.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines_hist.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/entropy_coding.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac_vad.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/crc.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb12_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/decode_bwe.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/spectrum_ar_model_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_lag_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac.c \ +./webrtc_dsp/modules/audio_processing/rms_level.cc \ +./webrtc_dsp/modules/audio_processing/echo_detector/normalized_covariance_estimator.cc \ +./webrtc_dsp/modules/audio_processing/echo_detector/moving_max.cc \ +./webrtc_dsp/modules/audio_processing/echo_detector/circular_buffer.cc \ +./webrtc_dsp/modules/audio_processing/echo_detector/mean_variance_estimator.cc \ +./webrtc_dsp/modules/audio_processing/splitting_filter.cc \ +./webrtc_dsp/modules/audio_processing/gain_control_impl.cc \ +./webrtc_dsp/modules/audio_processing/ns/nsx_core.c \ +./webrtc_dsp/modules/audio_processing/ns/noise_suppression_x.c \ +./webrtc_dsp/modules/audio_processing/ns/nsx_core_c.c \ +./webrtc_dsp/modules/audio_processing/ns/ns_core.c \ +./webrtc_dsp/modules/audio_processing/ns/noise_suppression.c \ +./webrtc_dsp/modules/audio_processing/audio_buffer.cc \ +./webrtc_dsp/modules/audio_processing/typing_detection.cc \ +./webrtc_dsp/modules/audio_processing/include/audio_processing_statistics.cc \ +./webrtc_dsp/modules/audio_processing/include/audio_generator_factory.cc \ +./webrtc_dsp/modules/audio_processing/include/aec_dump.cc \ +./webrtc_dsp/modules/audio_processing/include/audio_processing.cc \ +./webrtc_dsp/modules/audio_processing/include/config.cc \ +./webrtc_dsp/modules/audio_processing/agc2/interpolated_gain_curve.cc \ +./webrtc_dsp/modules/audio_processing/agc2/agc2_common.cc \ +./webrtc_dsp/modules/audio_processing/agc2/gain_applier.cc \ +./webrtc_dsp/modules/audio_processing/agc2/adaptive_agc.cc \ +./webrtc_dsp/modules/audio_processing/agc2/adaptive_digital_gain_applier.cc \ +./webrtc_dsp/modules/audio_processing/agc2/limiter.cc \ +./webrtc_dsp/modules/audio_processing/agc2/saturation_protector.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features_internal.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/rnn.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search_internal.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/features_extraction.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/fft_util.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/lp_residual.cc \ +./webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator_agc.cc \ +./webrtc_dsp/modules/audio_processing/agc2/vector_float_frame.cc \ +./webrtc_dsp/modules/audio_processing/agc2/noise_level_estimator.cc \ +./webrtc_dsp/modules/audio_processing/agc2/agc2_testing_common.cc \ +./webrtc_dsp/modules/audio_processing/agc2/fixed_digital_level_estimator.cc \ +./webrtc_dsp/modules/audio_processing/agc2/fixed_gain_controller.cc \ +./webrtc_dsp/modules/audio_processing/agc2/vad_with_level.cc \ +./webrtc_dsp/modules/audio_processing/agc2/limiter_db_gain_curve.cc \ +./webrtc_dsp/modules/audio_processing/agc2/down_sampler.cc \ +./webrtc_dsp/modules/audio_processing/agc2/signal_classifier.cc \ +./webrtc_dsp/modules/audio_processing/agc2/noise_spectrum_estimator.cc \ +./webrtc_dsp/modules/audio_processing/agc2/compute_interpolated_gain_curve.cc \ +./webrtc_dsp/modules/audio_processing/agc2/biquad_filter.cc \ +./webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator.cc \ +./webrtc_dsp/modules/audio_processing/transient/moving_moments.cc \ +./webrtc_dsp/modules/audio_processing/transient/wpd_tree.cc \ +./webrtc_dsp/modules/audio_processing/transient/wpd_node.cc \ +./webrtc_dsp/modules/audio_processing/transient/transient_suppressor.cc \ +./webrtc_dsp/modules/audio_processing/transient/transient_detector.cc \ +./webrtc_dsp/modules/audio_processing/low_cut_filter.cc \ +./webrtc_dsp/modules/audio_processing/level_estimator_impl.cc \ +./webrtc_dsp/modules/audio_processing/three_band_filter_bank.cc \ +./webrtc_dsp/modules/audio_processing/aec/echo_cancellation.cc \ +./webrtc_dsp/modules/audio_processing/aec/aec_resampler.cc \ +./webrtc_dsp/modules/audio_processing/aec/aec_core.cc \ +./webrtc_dsp/modules/audio_processing/voice_detection_impl.cc \ +./webrtc_dsp/modules/audio_processing/echo_cancellation_impl.cc \ +./webrtc_dsp/modules/audio_processing/gain_control_for_experimental_agc.cc \ +./webrtc_dsp/modules/audio_processing/agc/agc.cc \ +./webrtc_dsp/modules/audio_processing/agc/loudness_histogram.cc \ +./webrtc_dsp/modules/audio_processing/agc/agc_manager_direct.cc \ +./webrtc_dsp/modules/audio_processing/agc/legacy/analog_agc.c \ +./webrtc_dsp/modules/audio_processing/agc/legacy/digital_agc.c \ +./webrtc_dsp/modules/audio_processing/agc/utility.cc \ +./webrtc_dsp/modules/audio_processing/audio_processing_impl.cc \ +./webrtc_dsp/modules/audio_processing/audio_generator/file_audio_generator.cc \ +./webrtc_dsp/modules/audio_processing/gain_controller2.cc \ +./webrtc_dsp/modules/audio_processing/residual_echo_detector.cc \ +./webrtc_dsp/modules/audio_processing/noise_suppression_impl.cc \ +./webrtc_dsp/modules/audio_processing/aecm/aecm_core.cc \ +./webrtc_dsp/modules/audio_processing/aecm/aecm_core_c.cc \ +./webrtc_dsp/modules/audio_processing/aecm/echo_control_mobile.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_reverb_model.cc \ +./webrtc_dsp/modules/audio_processing/aec3/reverb_model_fallback.cc \ +./webrtc_dsp/modules/audio_processing/aec3/echo_remover_metrics.cc \ +./webrtc_dsp/modules/audio_processing/aec3/matched_filter_lag_aggregator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer2.cc \ +./webrtc_dsp/modules/audio_processing/aec3/echo_path_variability.cc \ +./webrtc_dsp/modules/audio_processing/aec3/frame_blocker.cc \ +./webrtc_dsp/modules/audio_processing/aec3/subtractor.cc \ +./webrtc_dsp/modules/audio_processing/aec3/aec3_fft.cc \ +./webrtc_dsp/modules/audio_processing/aec3/fullband_erle_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/suppression_filter.$(CC_NEON) \ +./webrtc_dsp/modules/audio_processing/aec3/block_processor.cc \ +./webrtc_dsp/modules/audio_processing/aec3/subband_erle_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller_metrics.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/vector_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/erl_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/aec_state.cc \ +./webrtc_dsp/modules/audio_processing/aec3/adaptive_fir_filter.$(CC_NEON) \ +./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller.cc \ +./webrtc_dsp/modules/audio_processing/aec3/skew_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/echo_path_delay_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/block_framer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/erle_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/reverb_model.cc \ +./webrtc_dsp/modules/audio_processing/aec3/cascaded_biquad_filter.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/subtractor_output.cc \ +./webrtc_dsp/modules/audio_processing/aec3/stationarity_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_signal_analyzer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/subtractor_output_analyzer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/suppression_gain.$(CC_NEON) \ +./webrtc_dsp/modules/audio_processing/aec3/echo_audibility.cc \ +./webrtc_dsp/modules/audio_processing/aec3/block_processor_metrics.cc \ +./webrtc_dsp/modules/audio_processing/aec3/moving_average.cc \ +./webrtc_dsp/modules/audio_processing/aec3/reverb_model_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/aec3_common.cc \ +./webrtc_dsp/modules/audio_processing/aec3/residual_echo_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/matched_filter.$(CC_NEON) \ +./webrtc_dsp/modules/audio_processing/aec3/reverb_decay_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller2.cc \ +./webrtc_dsp/modules/audio_processing/aec3/suppression_gain_limiter.cc \ +./webrtc_dsp/modules/audio_processing/aec3/main_filter_update_gain.cc \ +./webrtc_dsp/modules/audio_processing/aec3/echo_remover.cc \ +./webrtc_dsp/modules/audio_processing/aec3/downsampled_render_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/matrix_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/block_processor2.cc \ +./webrtc_dsp/modules/audio_processing/aec3/echo_canceller3.cc \ +./webrtc_dsp/modules/audio_processing/aec3/block_delay_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/fft_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/comfort_noise_generator.$(CC_NEON) \ +./webrtc_dsp/modules/audio_processing/aec3/shadow_filter_update_gain.cc \ +./webrtc_dsp/modules/audio_processing/aec3/filter_analyzer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/reverb_frequency_response.cc \ +./webrtc_dsp/modules/audio_processing/aec3/decimator.cc \ +./webrtc_dsp/modules/audio_processing/echo_control_mobile_impl.cc \ +./webrtc_dsp/modules/audio_processing/logging/apm_data_dumper.cc \ +./webrtc_dsp/modules/audio_processing/vad/voice_activity_detector.cc \ +./webrtc_dsp/modules/audio_processing/vad/standalone_vad.cc \ +./webrtc_dsp/modules/audio_processing/vad/pitch_internal.cc \ +./webrtc_dsp/modules/audio_processing/vad/vad_circular_buffer.cc \ +./webrtc_dsp/modules/audio_processing/vad/vad_audio_proc.cc \ +./webrtc_dsp/modules/audio_processing/vad/pole_zero_filter.cc \ +./webrtc_dsp/modules/audio_processing/vad/pitch_based_vad.cc \ +./webrtc_dsp/modules/audio_processing/vad/gmm.cc \ +./webrtc_dsp/modules/audio_processing/utility/ooura_fft.cc \ +./webrtc_dsp/modules/audio_processing/utility/delay_estimator_wrapper.cc \ +./webrtc_dsp/modules/audio_processing/utility/delay_estimator.cc \ +./webrtc_dsp/modules/audio_processing/utility/block_mean_calculator.cc \ +./webrtc_dsp/common_audio/window_generator.cc \ +./webrtc_dsp/common_audio/channel_buffer.cc \ +./webrtc_dsp/common_audio/fir_filter_factory.cc \ +./webrtc_dsp/common_audio/wav_header.cc \ +./webrtc_dsp/common_audio/real_fourier_ooura.cc \ +./webrtc_dsp/common_audio/audio_util.cc \ +./webrtc_dsp/common_audio/resampler/push_sinc_resampler.cc \ +./webrtc_dsp/common_audio/resampler/resampler.cc \ +./webrtc_dsp/common_audio/resampler/push_resampler.cc \ +./webrtc_dsp/common_audio/resampler/sinc_resampler.cc \ +./webrtc_dsp/common_audio/resampler/sinusoidal_linear_chirp_source.cc \ +./webrtc_dsp/common_audio/wav_file.cc \ +./webrtc_dsp/common_audio/third_party/fft4g/fft4g.c \ +./webrtc_dsp/common_audio/audio_converter.cc \ +./webrtc_dsp/common_audio/real_fourier.cc \ +./webrtc_dsp/common_audio/sparse_fir_filter.cc \ +./webrtc_dsp/common_audio/smoothing_filter.cc \ +./webrtc_dsp/common_audio/fir_filter_c.cc \ +./webrtc_dsp/common_audio/ring_buffer.c \ +./webrtc_dsp/common_audio/signal_processing/complex_fft.c \ +./webrtc_dsp/common_audio/signal_processing/filter_ma_fast_q12.c \ +./webrtc_dsp/common_audio/signal_processing/levinson_durbin.c \ +./webrtc_dsp/common_audio/signal_processing/dot_product_with_scale.cc \ +./webrtc_dsp/common_audio/signal_processing/auto_corr_to_refl_coef.c \ +./webrtc_dsp/common_audio/signal_processing/resample_by_2_internal.c \ +./webrtc_dsp/common_audio/signal_processing/energy.c \ +./webrtc_dsp/common_audio/signal_processing/sqrt_of_one_minus_x_squared.c \ +./webrtc_dsp/common_audio/signal_processing/downsample_fast.c \ +./webrtc_dsp/common_audio/signal_processing/splitting_filter1.c \ +./webrtc_dsp/common_audio/signal_processing/spl_init.c \ +./webrtc_dsp/common_audio/signal_processing/lpc_to_refl_coef.c \ +./webrtc_dsp/common_audio/signal_processing/cross_correlation.c \ +./webrtc_dsp/common_audio/signal_processing/division_operations.c \ +./webrtc_dsp/common_audio/signal_processing/auto_correlation.c \ +./webrtc_dsp/common_audio/signal_processing/get_scaling_square.c \ +./webrtc_dsp/common_audio/signal_processing/resample.c \ +./webrtc_dsp/common_audio/signal_processing/min_max_operations.c \ +./webrtc_dsp/common_audio/signal_processing/refl_coef_to_lpc.c \ +./webrtc_dsp/common_audio/signal_processing/filter_ar.c \ +./webrtc_dsp/common_audio/signal_processing/vector_scaling_operations.c \ +./webrtc_dsp/common_audio/signal_processing/resample_fractional.c \ +./webrtc_dsp/common_audio/signal_processing/real_fft.c \ +./webrtc_dsp/common_audio/signal_processing/ilbc_specific_functions.c \ +./webrtc_dsp/common_audio/signal_processing/randomization_functions.c \ +./webrtc_dsp/common_audio/signal_processing/copy_set_operations.c \ +./webrtc_dsp/common_audio/signal_processing/resample_by_2.c \ +./webrtc_dsp/common_audio/signal_processing/get_hanning_window.c \ +./webrtc_dsp/common_audio/signal_processing/resample_48khz.c \ +./webrtc_dsp/common_audio/signal_processing/spl_inl.c \ +./webrtc_dsp/common_audio/signal_processing/spl_sqrt.c \ +./webrtc_dsp/common_audio/vad/vad_sp.c \ +./webrtc_dsp/common_audio/vad/vad.cc \ +./webrtc_dsp/common_audio/vad/webrtc_vad.c \ +./webrtc_dsp/common_audio/vad/vad_filterbank.c \ +./webrtc_dsp/common_audio/vad/vad_core.c \ +./webrtc_dsp/common_audio/vad/vad_gmm.c + +ifeq ($(TARGET_ARCH_ABI),$(filter $(TARGET_ARCH_ABI),armeabi-v7a arm64-v8a)) +LOCAL_SRC_FILES += \ +./webrtc_dsp/modules/audio_processing/ns/nsx_core_neon.c.neon \ +./webrtc_dsp/modules/audio_processing/aec/aec_core_neon.cc.neon \ +./webrtc_dsp/modules/audio_processing/aecm/aecm_core_neon.cc.neon \ +./webrtc_dsp/modules/audio_processing/utility/ooura_fft_neon.cc.neon \ +./webrtc_dsp/common_audio/fir_filter_neon.cc.neon \ +./webrtc_dsp/common_audio/resampler/sinc_resampler_neon.cc.neon \ +./webrtc_dsp/common_audio/signal_processing/downsample_fast_neon.c.neon \ +./webrtc_dsp/common_audio/signal_processing/min_max_operations_neon.c.neon \ +./webrtc_dsp/common_audio/signal_processing/cross_correlation_neon.c.neon +endif + +ifeq ($(TARGET_ARCH_ABI),armeabi-v7a) +LOCAL_SRC_FILES += \ +./webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor_arm.S.neon \ +./webrtc_dsp/common_audio/signal_processing/complex_bit_reverse_arm.S.neon \ +./webrtc_dsp/common_audio/signal_processing/filter_ar_fast_q12_armv7.S.neon +else +LOCAL_SRC_FILES += \ +./webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor.c \ +./webrtc_dsp/common_audio/signal_processing/complex_bit_reverse.c \ +./webrtc_dsp/common_audio/signal_processing/filter_ar_fast_q12.c +endif + +ifeq ($(TARGET_ARCH_ABI),$(filter $(TARGET_ARCH_ABI),x86 x86_64)) +LOCAL_SRC_FILES += \ +./webrtc_dsp/modules/audio_processing/aec/aec_core_sse2.cc \ +./webrtc_dsp/modules/audio_processing/utility/ooura_fft_sse2.cc \ +./webrtc_dsp/common_audio/fir_filter_sse.cc \ +./webrtc_dsp/common_audio/resampler/sinc_resampler_sse.cc +endif + +# Opus + +LOCAL_SRC_FILES += \ +./../opus/src/opus.c \ +./../opus/src/opus_decoder.c \ +./../opus/src/opus_encoder.c \ +./../opus/src/opus_multistream.c \ +./../opus/src/opus_multistream_encoder.c \ +./../opus/src/opus_multistream_decoder.c \ +./../opus/src/repacketizer.c \ +./../opus/src/analysis.c \ +./../opus/src/mlp.c \ +./../opus/src/mlp_data.c \ +./../opus/src/opus_projection_encoder.c \ +./../opus/src/opus_projection_decoder.c \ +./../opus/src/mapping_matrix.c + +ifeq ($(TARGET_ARCH_ABI),$(filter $(TARGET_ARCH_ABI),armeabi-v7a arm64-v8a)) + LOCAL_ARM_MODE := arm + LOCAL_CPPFLAGS += -DLIBYUV_NEON + LOCAL_CFLAGS += -DLIBYUV_NEON + LOCAL_CFLAGS += -DOPUS_HAVE_RTCD -DOPUS_ARM_ASM + LOCAL_SRC_FILES += \ + ./../opus/celt/arm/celt_neon_intr.c.neon \ + ./../opus/celt/arm/pitch_neon_intr.c.neon \ + ./../opus/silk/arm/NSQ_neon.c.neon \ + ./../opus/silk/arm/arm_silk_map.c \ + ./../opus/silk/arm/LPC_inv_pred_gain_neon_intr.c.neon \ + ./../opus/silk/arm/NSQ_del_dec_neon_intr.c.neon \ + ./../opus/silk/arm/biquad_alt_neon_intr.c.neon \ + ./../opus/silk/fixed/arm/warped_autocorrelation_FIX_neon_intr.c.neon + +# LOCAL_SRC_FILES += ./../opus/celt/arm/celt_pitch_xcorr_arm-gnu.S + +else + ifeq ($(TARGET_ARCH_ABI),x86) + LOCAL_CFLAGS += -Dx86fix + LOCAL_CPPFLAGS += -Dx86fix + LOCAL_ARM_MODE := arm +# LOCAL_SRC_FILES += \ +# ./libyuv/source/row_x86.asm + +# LOCAL_SRC_FILES += \ +# ./../opus/celt/x86/celt_lpc_sse.c \ +# ./../opus/celt/x86/pitch_sse.c \ +# ./../opus/celt/x86/pitch_sse2.c \ +# ./../opus/celt/x86/pitch_sse4_1.c \ +# ./../opus/celt/x86/vq_sse2.c \ +# ./../opus/celt/x86/x86_celt_map.c \ +# ./../opus/celt/x86/x86cpu.c \ +# ./../opus/silk/fixed/x86/burg_modified_FIX_sse.c \ +# ./../opus/silk/fixed/x86/vector_ops_FIX_sse.c \ +# ./../opus/silk/x86/NSQ_del_dec_sse.c \ +# ./../opus/silk/x86/NSQ_sse.c \ +# ./../opus/silk/x86/VAD_sse.c \ +# ./../opus/silk/x86/VQ_WMat_sse.c \ +# ./../opus/silk/x86/x86_silk_map.c + endif +endif + +LOCAL_SRC_FILES += \ +./../opus/silk/CNG.c \ +./../opus/silk/code_signs.c \ +./../opus/silk/init_decoder.c \ +./../opus/silk/decode_core.c \ +./../opus/silk/decode_frame.c \ +./../opus/silk/decode_parameters.c \ +./../opus/silk/decode_indices.c \ +./../opus/silk/decode_pulses.c \ +./../opus/silk/decoder_set_fs.c \ +./../opus/silk/dec_API.c \ +./../opus/silk/enc_API.c \ +./../opus/silk/encode_indices.c \ +./../opus/silk/encode_pulses.c \ +./../opus/silk/gain_quant.c \ +./../opus/silk/interpolate.c \ +./../opus/silk/LP_variable_cutoff.c \ +./../opus/silk/NLSF_decode.c \ +./../opus/silk/NSQ.c \ +./../opus/silk/NSQ_del_dec.c \ +./../opus/silk/PLC.c \ +./../opus/silk/shell_coder.c \ +./../opus/silk/tables_gain.c \ +./../opus/silk/tables_LTP.c \ +./../opus/silk/tables_NLSF_CB_NB_MB.c \ +./../opus/silk/tables_NLSF_CB_WB.c \ +./../opus/silk/tables_other.c \ +./../opus/silk/tables_pitch_lag.c \ +./../opus/silk/tables_pulses_per_block.c \ +./../opus/silk/VAD.c \ +./../opus/silk/control_audio_bandwidth.c \ +./../opus/silk/quant_LTP_gains.c \ +./../opus/silk/VQ_WMat_EC.c \ +./../opus/silk/HP_variable_cutoff.c \ +./../opus/silk/NLSF_encode.c \ +./../opus/silk/NLSF_VQ.c \ +./../opus/silk/NLSF_unpack.c \ +./../opus/silk/NLSF_del_dec_quant.c \ +./../opus/silk/process_NLSFs.c \ +./../opus/silk/stereo_LR_to_MS.c \ +./../opus/silk/stereo_MS_to_LR.c \ +./../opus/silk/check_control_input.c \ +./../opus/silk/control_SNR.c \ +./../opus/silk/init_encoder.c \ +./../opus/silk/control_codec.c \ +./../opus/silk/A2NLSF.c \ +./../opus/silk/ana_filt_bank_1.c \ +./../opus/silk/biquad_alt.c \ +./../opus/silk/bwexpander_32.c \ +./../opus/silk/bwexpander.c \ +./../opus/silk/debug.c \ +./../opus/silk/decode_pitch.c \ +./../opus/silk/inner_prod_aligned.c \ +./../opus/silk/lin2log.c \ +./../opus/silk/log2lin.c \ +./../opus/silk/LPC_analysis_filter.c \ +./../opus/silk/LPC_inv_pred_gain.c \ +./../opus/silk/table_LSF_cos.c \ +./../opus/silk/NLSF2A.c \ +./../opus/silk/NLSF_stabilize.c \ +./../opus/silk/NLSF_VQ_weights_laroia.c \ +./../opus/silk/pitch_est_tables.c \ +./../opus/silk/resampler.c \ +./../opus/silk/resampler_down2_3.c \ +./../opus/silk/resampler_down2.c \ +./../opus/silk/resampler_private_AR2.c \ +./../opus/silk/resampler_private_down_FIR.c \ +./../opus/silk/resampler_private_IIR_FIR.c \ +./../opus/silk/resampler_private_up2_HQ.c \ +./../opus/silk/resampler_rom.c \ +./../opus/silk/sigm_Q15.c \ +./../opus/silk/sort.c \ +./../opus/silk/sum_sqr_shift.c \ +./../opus/silk/stereo_decode_pred.c \ +./../opus/silk/stereo_encode_pred.c \ +./../opus/silk/stereo_find_predictor.c \ +./../opus/silk/stereo_quant_pred.c \ +./../opus/silk/LPC_fit.c + +LOCAL_SRC_FILES += \ +./../opus/silk/fixed/LTP_analysis_filter_FIX.c \ +./../opus/silk/fixed/LTP_scale_ctrl_FIX.c \ +./../opus/silk/fixed/corrMatrix_FIX.c \ +./../opus/silk/fixed/encode_frame_FIX.c \ +./../opus/silk/fixed/find_LPC_FIX.c \ +./../opus/silk/fixed/find_LTP_FIX.c \ +./../opus/silk/fixed/find_pitch_lags_FIX.c \ +./../opus/silk/fixed/find_pred_coefs_FIX.c \ +./../opus/silk/fixed/noise_shape_analysis_FIX.c \ +./../opus/silk/fixed/process_gains_FIX.c \ +./../opus/silk/fixed/regularize_correlations_FIX.c \ +./../opus/silk/fixed/residual_energy16_FIX.c \ +./../opus/silk/fixed/residual_energy_FIX.c \ +./../opus/silk/fixed/warped_autocorrelation_FIX.c \ +./../opus/silk/fixed/apply_sine_window_FIX.c \ +./../opus/silk/fixed/autocorr_FIX.c \ +./../opus/silk/fixed/burg_modified_FIX.c \ +./../opus/silk/fixed/k2a_FIX.c \ +./../opus/silk/fixed/k2a_Q16_FIX.c \ +./../opus/silk/fixed/pitch_analysis_core_FIX.c \ +./../opus/silk/fixed/vector_ops_FIX.c \ +./../opus/silk/fixed/schur64_FIX.c \ +./../opus/silk/fixed/schur_FIX.c + +LOCAL_SRC_FILES += \ +./../opus/celt/bands.c \ +./../opus/celt/celt.c \ +./../opus/celt/celt_encoder.c \ +./../opus/celt/celt_decoder.c \ +./../opus/celt/cwrs.c \ +./../opus/celt/entcode.c \ +./../opus/celt/entdec.c \ +./../opus/celt/entenc.c \ +./../opus/celt/kiss_fft.c \ +./../opus/celt/laplace.c \ +./../opus/celt/mathops.c \ +./../opus/celt/mdct.c \ +./../opus/celt/modes.c \ +./../opus/celt/pitch.c \ +./../opus/celt/celt_lpc.c \ +./../opus/celt/quant_bands.c \ +./../opus/celt/rate.c \ +./../opus/celt/vq.c \ +./../opus/celt/arm/armcpu.c \ +./../opus/celt/arm/arm_celt_map.c + +LOCAL_SRC_FILES += \ +./../opus/ogg/bitwise.c \ +./../opus/ogg/framing.c \ +./../opus/opusfile/info.c \ +./../opus/opusfile/internal.c \ +./../opus/opusfile/opusfile.c \ +./../opus/opusfile/stream.c + +include $(BUILD_SHARED_LIBRARY) \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/BlockingQueue.cpp b/TMessagesProj/jni/libtgvoip2/BlockingQueue.cpp new file mode 100644 index 000000000..4a02d4762 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/BlockingQueue.cpp @@ -0,0 +1,10 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "BlockingQueue.h" + +using namespace tgvoip; + diff --git a/TMessagesProj/jni/libtgvoip2/BlockingQueue.h b/TMessagesProj/jni/libtgvoip2/BlockingQueue.h new file mode 100644 index 000000000..c391aea80 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/BlockingQueue.h @@ -0,0 +1,92 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_BLOCKINGQUEUE_H +#define LIBTGVOIP_BLOCKINGQUEUE_H + +#include +#include +#include "threading.h" +#include "utils.h" + +namespace tgvoip{ + +using namespace std; + +template +class BlockingQueue{ +public: + TGVOIP_DISALLOW_COPY_AND_ASSIGN(BlockingQueue); + BlockingQueue(size_t capacity) : semaphore(capacity, 0){ + this->capacity=capacity; + overflowCallback=NULL; + }; + + ~BlockingQueue(){ + semaphore.Release(); + } + + void Put(T thing){ + MutexGuard sync(mutex); + queue.push_back(std::move(thing)); + bool didOverflow=false; + while(queue.size()>capacity){ + didOverflow=true; + if(overflowCallback){ + overflowCallback(std::move(queue.front())); + queue.pop_front(); + }else{ + abort(); + } + } + if(!didOverflow) + semaphore.Release(); + } + + T GetBlocking(){ + semaphore.Acquire(); + MutexGuard sync(mutex); + return GetInternal(); + } + + T Get(){ + MutexGuard sync(mutex); + if(queue.size()>0) + semaphore.Acquire(); + return GetInternal(); + } + + size_t Size(){ + return queue.size(); + } + + void PrepareDealloc(){ + + } + + void SetOverflowCallback(void (*overflowCallback)(T)){ + this->overflowCallback=overflowCallback; + } + +private: + T GetInternal(){ + //if(queue.size()==0) + // return NULL; + T r=std::move(queue.front()); + queue.pop_front(); + return r; + } + + std::list queue; + size_t capacity; + //tgvoip_lock_t lock; + Semaphore semaphore; + Mutex mutex; + void (*overflowCallback)(T); +}; +} + +#endif //LIBTGVOIP_BLOCKINGQUEUE_H diff --git a/TMessagesProj/jni/libtgvoip2/Buffers.cpp b/TMessagesProj/jni/libtgvoip2/Buffers.cpp new file mode 100644 index 000000000..33c2ce648 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/Buffers.cpp @@ -0,0 +1,237 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "Buffers.h" +#include +#include +#include +#include +#include +#include "logging.h" + +using namespace tgvoip; + +#pragma mark - BufferInputStream + +BufferInputStream::BufferInputStream(const unsigned char* data, size_t length){ + this->buffer=data; + this->length=length; + offset=0; +} + +BufferInputStream::BufferInputStream(const Buffer &buffer){ + this->buffer=*buffer; + this->length=buffer.Length(); + offset=0; +} + +BufferInputStream::~BufferInputStream(){ + +} + + +void BufferInputStream::Seek(size_t offset){ + if(offset>length){ + throw std::out_of_range("Not enough bytes in buffer"); + } + this->offset=offset; +} + +size_t BufferInputStream::GetLength(){ + return length; +} + +size_t BufferInputStream::GetOffset(){ + return offset; +} + +size_t BufferInputStream::Remaining(){ + return length-offset; +} + +unsigned char BufferInputStream::ReadByte(){ + EnsureEnoughRemaining(1); + return (unsigned char)buffer[offset++]; +} + +int32_t BufferInputStream::ReadInt32(){ + EnsureEnoughRemaining(4); + int32_t res=((int32_t)buffer[offset] & 0xFF) | + (((int32_t)buffer[offset+1] & 0xFF) << 8) | + (((int32_t)buffer[offset+2] & 0xFF) << 16) | + (((int32_t)buffer[offset+3] & 0xFF) << 24); + offset+=4; + return res; +} + +int64_t BufferInputStream::ReadInt64(){ + EnsureEnoughRemaining(8); + int64_t res=((int64_t)buffer[offset] & 0xFF) | + (((int64_t)buffer[offset+1] & 0xFF) << 8) | + (((int64_t)buffer[offset+2] & 0xFF) << 16) | + (((int64_t)buffer[offset+3] & 0xFF) << 24) | + (((int64_t)buffer[offset+4] & 0xFF) << 32) | + (((int64_t)buffer[offset+5] & 0xFF) << 40) | + (((int64_t)buffer[offset+6] & 0xFF) << 48) | + (((int64_t)buffer[offset+7] & 0xFF) << 56); + offset+=8; + return res; +} + +int16_t BufferInputStream::ReadInt16(){ + EnsureEnoughRemaining(2); + int16_t res=(uint16_t)buffer[offset] | ((uint16_t)buffer[offset+1] << 8); + offset+=2; + return res; +} + + +int32_t BufferInputStream::ReadTlLength(){ + unsigned char l=ReadByte(); + if(l<254) + return l; + assert(length-offset>=3); + EnsureEnoughRemaining(3); + int32_t res=((int32_t)buffer[offset] & 0xFF) | + (((int32_t)buffer[offset+1] & 0xFF) << 8) | + (((int32_t)buffer[offset+2] & 0xFF) << 16); + offset+=3; + return res; +} + +void BufferInputStream::ReadBytes(unsigned char *to, size_t count){ + EnsureEnoughRemaining(count); + memcpy(to, buffer+offset, count); + offset+=count; +} + +void BufferInputStream::ReadBytes(Buffer &to){ + ReadBytes(*to, to.Length()); +} + +BufferInputStream BufferInputStream::GetPartBuffer(size_t length, bool advance){ + EnsureEnoughRemaining(length); + BufferInputStream s=BufferInputStream(buffer+offset, length); + if(advance) + offset+=length; + return s; +} + +void BufferInputStream::EnsureEnoughRemaining(size_t need){ + if(length-offsetsize=size; + bufferProvided=false; +} + +BufferOutputStream::BufferOutputStream(unsigned char *buffer, size_t size){ + this->buffer=buffer; + this->size=size; + offset=0; + bufferProvided=true; +} + +BufferOutputStream::~BufferOutputStream(){ + if(!bufferProvided && buffer) + free(buffer); +} + +void BufferOutputStream::WriteByte(unsigned char byte){ + this->ExpandBufferIfNeeded(1); + buffer[offset++]=byte; +} + +void BufferOutputStream::WriteInt32(int32_t i){ + this->ExpandBufferIfNeeded(4); + buffer[offset+3]=(unsigned char)((i >> 24) & 0xFF); + buffer[offset+2]=(unsigned char)((i >> 16) & 0xFF); + buffer[offset+1]=(unsigned char)((i >> 8) & 0xFF); + buffer[offset]=(unsigned char)(i & 0xFF); + offset+=4; +} + +void BufferOutputStream::WriteInt64(int64_t i){ + this->ExpandBufferIfNeeded(8); + buffer[offset+7]=(unsigned char)((i >> 56) & 0xFF); + buffer[offset+6]=(unsigned char)((i >> 48) & 0xFF); + buffer[offset+5]=(unsigned char)((i >> 40) & 0xFF); + buffer[offset+4]=(unsigned char)((i >> 32) & 0xFF); + buffer[offset+3]=(unsigned char)((i >> 24) & 0xFF); + buffer[offset+2]=(unsigned char)((i >> 16) & 0xFF); + buffer[offset+1]=(unsigned char)((i >> 8) & 0xFF); + buffer[offset]=(unsigned char)(i & 0xFF); + offset+=8; +} + +void BufferOutputStream::WriteInt16(int16_t i){ + this->ExpandBufferIfNeeded(2); + buffer[offset+1]=(unsigned char)((i >> 8) & 0xFF); + buffer[offset]=(unsigned char)(i & 0xFF); + offset+=2; +} + +void BufferOutputStream::WriteBytes(const unsigned char *bytes, size_t count){ + this->ExpandBufferIfNeeded(count); + memcpy(buffer+offset, bytes, count); + offset+=count; +} + +void BufferOutputStream::WriteBytes(const Buffer &buffer){ + WriteBytes(*buffer, buffer.Length()); +} + +void BufferOutputStream::WriteBytes(const Buffer &buffer, size_t offset, size_t count){ + if(offset+count>buffer.Length()) + throw std::out_of_range("offset out of buffer bounds"); + WriteBytes(*buffer+offset, count); +} + +unsigned char *BufferOutputStream::GetBuffer(){ + return buffer; +} + +size_t BufferOutputStream::GetLength(){ + return offset; +} + +void BufferOutputStream::ExpandBufferIfNeeded(size_t need) { + if (offset + need > size) { + if (bufferProvided) { + throw std::out_of_range("buffer overflow"); + } + unsigned char* new_buffer; + need = std::max(need, size_t{1024}); + new_buffer = reinterpret_cast(std::realloc(buffer, size + need)); + if (new_buffer == NULL) { + std::free(buffer); + buffer = NULL; + throw std::bad_alloc(); + } + buffer = new_buffer; + size += need; + } +} + + +void BufferOutputStream::Reset(){ + offset=0; +} + +void BufferOutputStream::Rewind(size_t numBytes){ + if(numBytes>offset) + throw std::out_of_range("buffer underflow"); + offset-=numBytes; +} diff --git a/TMessagesProj/jni/libtgvoip2/Buffers.h b/TMessagesProj/jni/libtgvoip2/Buffers.h new file mode 100644 index 000000000..b2a47c2f6 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/Buffers.h @@ -0,0 +1,357 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_BUFFERINPUTSTREAM_H +#define LIBTGVOIP_BUFFERINPUTSTREAM_H + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include "threading.h" +#include "utils.h" + +namespace tgvoip{ + class Buffer; + + class BufferInputStream{ + + public: + BufferInputStream(const unsigned char* data, size_t length); + BufferInputStream(const Buffer& buffer); + ~BufferInputStream(); + void Seek(size_t offset); + size_t GetLength(); + size_t GetOffset(); + size_t Remaining(); + unsigned char ReadByte(); + int64_t ReadInt64(); + int32_t ReadInt32(); + int16_t ReadInt16(); + int32_t ReadTlLength(); + void ReadBytes(unsigned char* to, size_t count); + void ReadBytes(Buffer& to); + BufferInputStream GetPartBuffer(size_t length, bool advance); + + private: + void EnsureEnoughRemaining(size_t need); + const unsigned char* buffer; + size_t length; + size_t offset; + }; + + class BufferOutputStream{ + friend class Buffer; + public: + TGVOIP_DISALLOW_COPY_AND_ASSIGN(BufferOutputStream); + BufferOutputStream(size_t size); + BufferOutputStream(unsigned char* buffer, size_t size); + ~BufferOutputStream(); + void WriteByte(unsigned char byte); + void WriteInt64(int64_t i); + void WriteInt32(int32_t i); + void WriteInt16(int16_t i); + void WriteBytes(const unsigned char* bytes, size_t count); + void WriteBytes(const Buffer& buffer); + void WriteBytes(const Buffer& buffer, size_t offset, size_t count); + unsigned char* GetBuffer(); + size_t GetLength(); + void Reset(); + void Rewind(size_t numBytes); + + BufferOutputStream& operator=(BufferOutputStream&& other){ + if(this!=&other){ + if(!bufferProvided && buffer) + free(buffer); + buffer=other.buffer; + offset=other.offset; + size=other.size; + bufferProvided=other.bufferProvided; + other.buffer=NULL; + } + return *this; + } + + private: + void ExpandBufferIfNeeded(size_t need); + unsigned char* buffer=NULL; + size_t size; + size_t offset; + bool bufferProvided; + }; + + class Buffer{ + public: + Buffer(size_t capacity){ + if(capacity>0){ + data=(unsigned char *) malloc(capacity); + if(!data) + throw std::bad_alloc(); + }else{ + data=NULL; + } + length=capacity; + }; + TGVOIP_DISALLOW_COPY_AND_ASSIGN(Buffer); // use Buffer::CopyOf to copy contents explicitly + Buffer(Buffer&& other) noexcept { + data=other.data; + length=other.length; + freeFn=other.freeFn; + reallocFn=other.reallocFn; + other.data=NULL; + }; + Buffer(BufferOutputStream&& stream){ + data=stream.buffer; + length=stream.offset; + stream.buffer=NULL; + } + Buffer(){ + data=NULL; + length=0; + } + ~Buffer(){ + if(data){ + if(freeFn) + freeFn(data); + else + free(data); + } + data=NULL; + length=0; + }; + Buffer& operator=(Buffer&& other){ + if(this!=&other){ + if(data){ + if(freeFn) + freeFn(data); + else + free(data); + } + data=other.data; + length=other.length; + freeFn=other.freeFn; + reallocFn=other.reallocFn; + other.data=NULL; + other.length=0; + } + return *this; + } + unsigned char& operator[](size_t i){ + if(i>=length) + throw std::out_of_range(""); + return data[i]; + } + const unsigned char& operator[](size_t i) const{ + if(i>=length) + throw std::out_of_range(""); + return data[i]; + } + unsigned char* operator*(){ + return data; + } + const unsigned char* operator*() const{ + return data; + } + void CopyFrom(const Buffer& other, size_t count, size_t srcOffset=0, size_t dstOffset=0){ + if(!other.data) + throw std::invalid_argument("CopyFrom can't copy from NULL"); + if(other.lengthother.Length()) + throw std::out_of_range("offset+length out of bounds"); + Buffer buf(length); + buf.CopyFrom(other, length, offset); + return buf; + } + static Buffer Wrap(unsigned char* data, size_t size, std::function freeFn, std::function reallocFn){ + Buffer b=Buffer(); + b.data=data; + b.length=size; + b.freeFn=freeFn; + b.reallocFn=reallocFn; + return b; + } + private: + unsigned char* data; + size_t length; + std::function freeFn; + std::function reallocFn; + }; + + template class HistoricBuffer{ + public: + HistoricBuffer(){ + std::fill(data.begin(), data.end(), (T)0); + } + + AVG_T Average() const { + AVG_T avg=(AVG_T)0; + for(T i:data){ + avg+=i; + } + return avg/(AVG_T)size; + } + + AVG_T Average(size_t firstN) const { + AVG_T avg=(AVG_T)0; + for(size_t i=0;i::max(); + for(T i:data){ + if(i::min(); + for(T i:data){ + if(i>max) + max=i; + } + return max; + } + + void Reset(){ + std::fill(data.begin(), data.end(), (T)0); + offset=0; + } + + T operator[](size_t i) const { + assert(i data; + ptrdiff_t offset=0; + }; + + template class BufferPool{ + public: + TGVOIP_DISALLOW_COPY_AND_ASSIGN(BufferPool); + BufferPool(){ + bufferStart=(unsigned char*)malloc(bufSize*bufCount); + if(!bufferStart) + throw std::bad_alloc(); + }; + ~BufferPool(){ + assert(usedBuffers.none()); + free(bufferStart); + }; + Buffer Get(){ + auto freeFn=[this](void* _buf){ + assert(_buf!=NULL); + unsigned char* buf=(unsigned char*)_buf; + size_t offset=buf-bufferStart; + assert(offset%bufSize==0); + size_t index=offset/bufSize; + assert(indexvoid*{ + if(newSize>bufSize) + throw std::invalid_argument("newSize>bufferSize"); + return buf; + }; + MutexGuard m(mutex); + for(size_t i=0;i usedBuffers; + unsigned char* bufferStart; + Mutex mutex; + }; +} + +#endif //LIBTGVOIP_BUFFERINPUTSTREAM_H diff --git a/TMessagesProj/jni/libtgvoip2/CongestionControl.cpp b/TMessagesProj/jni/libtgvoip2/CongestionControl.cpp new file mode 100644 index 000000000..b381bae59 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/CongestionControl.cpp @@ -0,0 +1,148 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "CongestionControl.h" +#include "VoIPController.h" +#include "logging.h" +#include "VoIPServerConfig.h" +#include "PrivateDefines.h" +#include +#include + +using namespace tgvoip; + +CongestionControl::CongestionControl(){ + memset(inflightPackets, 0, sizeof(inflightPackets)); + tmpRtt=0; + tmpRttCount=0; + lastSentSeq=0; + lastActionTime=0; + lastActionRtt=0; + stateTransitionTime=0; + inflightDataSize=0; + lossCount=0; + cwnd=(size_t) ServerConfig::GetSharedInstance()->GetInt("audio_congestion_window", 1024); +} + +CongestionControl::~CongestionControl(){ +} + +size_t CongestionControl::GetAcknowledgedDataSize(){ + return 0; +} + +double CongestionControl::GetAverageRTT(){ + return rttHistory.NonZeroAverage(); +} + +size_t CongestionControl::GetInflightDataSize(){ + return inflightHistory.Average(); +} + + +size_t CongestionControl::GetCongestionWindow(){ + return cwnd; +} + +double CongestionControl::GetMinimumRTT(){ + return rttHistory.Min(); +} + +void CongestionControl::PacketAcknowledged(uint32_t seq){ + for(int i=0;i<100;i++){ + if(inflightPackets[i].seq==seq && inflightPackets[i].sendTime>0){ + tmpRtt+=(VoIPController::GetCurrentTime()-inflightPackets[i].sendTime); + tmpRttCount++; + inflightPackets[i].sendTime=0; + inflightDataSize-=inflightPackets[i].size; + break; + } + } +} + +void CongestionControl::PacketSent(uint32_t seq, size_t size){ + if(!seqgt(seq, lastSentSeq) || seq==lastSentSeq){ + LOGW("Duplicate outgoing seq %u", seq); + return; + } + lastSentSeq=seq; + double smallestSendTime=INFINITY; + tgvoip_congestionctl_packet_t* slot=NULL; + int i; + for(i=0;i<100;i++){ + if(inflightPackets[i].sendTime==0){ + slot=&inflightPackets[i]; + break; + } + if(smallestSendTime>inflightPackets[i].sendTime){ + slot=&inflightPackets[i]; + smallestSendTime=slot->sendTime; + } + } + assert(slot!=NULL); + if(slot->sendTime>0){ + inflightDataSize-=slot->size; + lossCount++; + LOGD("Packet with seq %u was not acknowledged", slot->seq); + } + slot->seq=seq; + slot->size=size; + slot->sendTime=VoIPController::GetCurrentTime(); + inflightDataSize+=size; +} + +void CongestionControl::PacketLost(uint32_t seq){ + for(int i=0;i<100;i++){ + if(inflightPackets[i].seq==seq && inflightPackets[i].sendTime>0){ + inflightPackets[i].sendTime=0; + inflightDataSize-=inflightPackets[i].size; + lossCount++; + break; + } + } +} + +void CongestionControl::Tick(){ + tickCount++; + if(tmpRttCount>0){ + rttHistory.Add(tmpRtt/tmpRttCount); + tmpRtt=0; + tmpRttCount=0; + } + int i; + for(i=0;i<100;i++){ + if(inflightPackets[i].sendTime!=0 && VoIPController::GetCurrentTime()-inflightPackets[i].sendTime>2){ + inflightPackets[i].sendTime=0; + inflightDataSize-=inflightPackets[i].size; + lossCount++; + LOGD("Packet with seq %u was not acknowledged", inflightPackets[i].seq); + } + } + inflightHistory.Add(inflightDataSize); +} + + +int CongestionControl::GetBandwidthControlAction(){ + if(VoIPController::GetCurrentTime()-lastActionTime<1) + return TGVOIP_CONCTL_ACT_NONE; + size_t inflightAvg=GetInflightDataSize(); + size_t max=cwnd+cwnd/10; + size_t min=cwnd-cwnd/10; + if(inflightAvgmax){ + lastActionTime=VoIPController::GetCurrentTime(); + return TGVOIP_CONCTL_ACT_DECREASE; + } + return TGVOIP_CONCTL_ACT_NONE; +} + + +uint32_t CongestionControl::GetSendLossCount(){ + return lossCount; +} diff --git a/TMessagesProj/jni/libtgvoip2/CongestionControl.h b/TMessagesProj/jni/libtgvoip2/CongestionControl.h new file mode 100644 index 000000000..17c2ea533 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/CongestionControl.h @@ -0,0 +1,63 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_CONGESTIONCONTROL_H +#define LIBTGVOIP_CONGESTIONCONTROL_H + +#include +#include +#include "threading.h" +#include "Buffers.h" + +#define TGVOIP_CONCTL_ACT_INCREASE 1 +#define TGVOIP_CONCTL_ACT_DECREASE 2 +#define TGVOIP_CONCTL_ACT_NONE 0 + +namespace tgvoip{ + +struct tgvoip_congestionctl_packet_t{ + uint32_t seq; + double sendTime; + size_t size; +}; +typedef struct tgvoip_congestionctl_packet_t tgvoip_congestionctl_packet_t; + +class CongestionControl{ +public: + CongestionControl(); + ~CongestionControl(); + + void PacketSent(uint32_t seq, size_t size); + void PacketLost(uint32_t seq); + void PacketAcknowledged(uint32_t seq); + + double GetAverageRTT(); + double GetMinimumRTT(); + size_t GetInflightDataSize(); + size_t GetCongestionWindow(); + size_t GetAcknowledgedDataSize(); + void Tick(); + int GetBandwidthControlAction(); + uint32_t GetSendLossCount(); + +private: + HistoricBuffer rttHistory; + HistoricBuffer inflightHistory; + tgvoip_congestionctl_packet_t inflightPackets[100]; + uint32_t lossCount; + double tmpRtt; + double lastActionTime; + double lastActionRtt; + double stateTransitionTime; + int tmpRttCount; + uint32_t lastSentSeq; + uint32_t tickCount; + size_t inflightDataSize; + size_t cwnd; +}; +} + +#endif //LIBTGVOIP_CONGESTIONCONTROL_H diff --git a/TMessagesProj/jni/libtgvoip2/EchoCanceller.cpp b/TMessagesProj/jni/libtgvoip2/EchoCanceller.cpp new file mode 100644 index 000000000..d14f762e2 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/EchoCanceller.cpp @@ -0,0 +1,248 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef TGVOIP_NO_DSP +#include "webrtc_dsp/modules/audio_processing/include/audio_processing.h" +#include "webrtc_dsp/api/audio/audio_frame.h" +#endif + +#include "EchoCanceller.h" +#include "audio/AudioOutput.h" +#include "audio/AudioInput.h" +#include "logging.h" +#include "VoIPServerConfig.h" +#include +#include +#include + +using namespace tgvoip; + +EchoCanceller::EchoCanceller(bool enableAEC, bool enableNS, bool enableAGC){ +#ifndef TGVOIP_NO_DSP + this->enableAEC=enableAEC; + this->enableAGC=enableAGC; + this->enableNS=enableNS; + isOn=true; + + webrtc::Config extraConfig; +#ifdef TGVOIP_USE_DESKTOP_DSP + extraConfig.Set(new webrtc::DelayAgnostic(true)); +#endif + + apm=webrtc::AudioProcessingBuilder().Create(extraConfig); + + webrtc::AudioProcessing::Config config; + config.echo_canceller.enabled = enableAEC; +#ifndef TGVOIP_USE_DESKTOP_DSP + config.echo_canceller.mobile_mode = true; +#else + config.echo_canceller.mobile_mode = false; +#endif + config.high_pass_filter.enabled = enableAEC; + config.gain_controller2.enabled = enableAGC; + apm->ApplyConfig(config); + + webrtc::NoiseSuppression::Level nsLevel; +#ifdef __APPLE__ + switch(ServerConfig::GetSharedInstance()->GetInt("webrtc_ns_level_vpio", 0)){ +#else + switch(ServerConfig::GetSharedInstance()->GetInt("webrtc_ns_level", 2)){ +#endif + case 0: + nsLevel=webrtc::NoiseSuppression::Level::kLow; + break; + case 1: + nsLevel=webrtc::NoiseSuppression::Level::kModerate; + break; + case 3: + nsLevel=webrtc::NoiseSuppression::Level::kVeryHigh; + break; + case 2: + default: + nsLevel=webrtc::NoiseSuppression::Level::kHigh; + break; + } + apm->noise_suppression()->set_level(nsLevel); + apm->noise_suppression()->Enable(enableNS); + if(enableAGC){ + apm->gain_control()->set_mode(webrtc::GainControl::Mode::kAdaptiveDigital); + apm->gain_control()->set_target_level_dbfs(ServerConfig::GetSharedInstance()->GetInt("webrtc_agc_target_level", 9)); + apm->gain_control()->enable_limiter(ServerConfig::GetSharedInstance()->GetBoolean("webrtc_agc_enable_limiter", true)); + apm->gain_control()->set_compression_gain_db(ServerConfig::GetSharedInstance()->GetInt("webrtc_agc_compression_gain", 20)); + } + apm->voice_detection()->set_likelihood(webrtc::VoiceDetection::Likelihood::kVeryLowLikelihood); + + audioFrame=new webrtc::AudioFrame(); + audioFrame->samples_per_channel_=480; + audioFrame->sample_rate_hz_=48000; + audioFrame->num_channels_=1; + + farendQueue=new BlockingQueue(11); + running=true; + bufferFarendThread=new Thread(std::bind(&EchoCanceller::RunBufferFarendThread, this)); + bufferFarendThread->SetName("VoipECBufferFarEnd"); + bufferFarendThread->Start(); + +#else + this->enableAEC=this->enableAGC=enableAGC=this->enableNS=enableNS=false; + isOn=true; +#endif +} + +EchoCanceller::~EchoCanceller(){ +#ifndef TGVOIP_NO_DSP + farendQueue->Put(Buffer()); + bufferFarendThread->Join(); + delete bufferFarendThread; + delete farendQueue; + delete audioFrame; + delete apm; +#endif +} + +void EchoCanceller::Start(){ + +} + +void EchoCanceller::Stop(){ + +} + + +void EchoCanceller::SpeakerOutCallback(unsigned char* data, size_t len){ + if(len!=960*2 || !enableAEC || !isOn) + return; +#ifndef TGVOIP_NO_DSP + try{ + Buffer buf=farendBufferPool.Get(); + buf.CopyFrom(data, 0, 960*2); + farendQueue->Put(std::move(buf)); + }catch(std::bad_alloc& x){ + LOGW("Echo canceller can't keep up with real time"); + } +#endif +} + +#ifndef TGVOIP_NO_DSP +void EchoCanceller::RunBufferFarendThread(){ + webrtc::AudioFrame frame; + frame.num_channels_=1; + frame.sample_rate_hz_=48000; + frame.samples_per_channel_=480; + while(running){ + Buffer buf=farendQueue->GetBlocking(); + if(buf.IsEmpty()){ + LOGI("Echo canceller buffer farend thread exiting"); + return; + } + int16_t* samplesIn=(int16_t*)*buf; + memcpy(frame.mutable_data(), samplesIn, 480*2); + apm->ProcessReverseStream(&frame); + memcpy(frame.mutable_data(), samplesIn+480, 480*2); + apm->ProcessReverseStream(&frame); + didBufferFarend=true; + } +} +#endif + +void EchoCanceller::Enable(bool enabled){ + isOn=enabled; +} + +void EchoCanceller::ProcessInput(int16_t* inOut, size_t numSamples, bool& hasVoice){ +#ifndef TGVOIP_NO_DSP + if(!isOn || (!enableAEC && !enableAGC && !enableNS)){ + return; + } + int delay=audio::AudioInput::GetEstimatedDelay()+audio::AudioOutput::GetEstimatedDelay(); + assert(numSamples==960); + + memcpy(audioFrame->mutable_data(), inOut, 480*2); + if(enableAEC) + apm->set_stream_delay_ms(delay); + apm->ProcessStream(audioFrame); + if(enableVAD) + hasVoice=apm->voice_detection()->stream_has_voice(); + memcpy(inOut, audioFrame->data(), 480*2); + memcpy(audioFrame->mutable_data(), inOut+480, 480*2); + if(enableAEC) + apm->set_stream_delay_ms(delay); + apm->ProcessStream(audioFrame); + if(enableVAD){ + hasVoice=hasVoice || apm->voice_detection()->stream_has_voice(); + } + memcpy(inOut+480, audioFrame->data(), 480*2); +#endif +} + +void EchoCanceller::SetAECStrength(int strength){ +#ifndef TGVOIP_NO_DSP + /*if(aec){ +#ifndef TGVOIP_USE_DESKTOP_DSP + AecmConfig cfg; + cfg.cngMode=AecmFalse; + cfg.echoMode=(int16_t) strength; + WebRtcAecm_set_config(aec, cfg); +#endif + }*/ +#endif +} + +void EchoCanceller::SetVoiceDetectionEnabled(bool enabled){ + enableVAD=enabled; +#ifndef TGVOIP_NO_DSP + apm->voice_detection()->Enable(enabled); +#endif +} + +using namespace tgvoip::effects; + +AudioEffect::~AudioEffect(){ + +} + +void AudioEffect::SetPassThrough(bool passThrough){ + this->passThrough=passThrough; +} + +Volume::Volume(){ + +} + +Volume::~Volume(){ + +} + +void Volume::Process(int16_t* inOut, size_t numSamples){ + if(level==1.0f || passThrough){ + return; + } + for(size_t i=0;i32767.0f) + inOut[i]=INT16_MAX; + else if(sample<-32768.0f) + inOut[i]=INT16_MIN; + else + inOut[i]=(int16_t)sample; + } +} + +void Volume::SetLevel(float level){ + this->level=level; + float db; + if(level<1.0f) + db=-50.0f*(1.0f-level); + else if(level>1.0f && level<=2.0f) + db=10.0f*(level-1.0f); + else + db=0.0f; + multiplier=expf(db/20.0f * logf(10.0f)); +} + +float Volume::GetLevel(){ + return level; +} diff --git a/TMessagesProj/jni/libtgvoip2/EchoCanceller.h b/TMessagesProj/jni/libtgvoip2/EchoCanceller.h new file mode 100644 index 000000000..5deb617a9 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/EchoCanceller.h @@ -0,0 +1,83 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_ECHOCANCELLER_H +#define LIBTGVOIP_ECHOCANCELLER_H + +#include "threading.h" +#include "Buffers.h" +#include "BlockingQueue.h" +#include "MediaStreamItf.h" +#include "utils.h" + +namespace webrtc{ + class AudioProcessing; + class AudioFrame; +} + +namespace tgvoip{ +class EchoCanceller{ + +public: + TGVOIP_DISALLOW_COPY_AND_ASSIGN(EchoCanceller); + EchoCanceller(bool enableAEC, bool enableNS, bool enableAGC); + virtual ~EchoCanceller(); + virtual void Start(); + virtual void Stop(); + void SpeakerOutCallback(unsigned char* data, size_t len); + void Enable(bool enabled); + void ProcessInput(int16_t* inOut, size_t numSamples, bool& hasVoice); + void SetAECStrength(int strength); + void SetVoiceDetectionEnabled(bool enabled); + +private: + bool enableAEC; + bool enableAGC; + bool enableNS; + bool enableVAD=false; + bool isOn; +#ifndef TGVOIP_NO_DSP + webrtc::AudioProcessing* apm=NULL; + webrtc::AudioFrame* audioFrame=NULL; + void RunBufferFarendThread(); + bool didBufferFarend; + Thread* bufferFarendThread; + BlockingQueue* farendQueue; + BufferPool<960*2, 10> farendBufferPool; + bool running; +#endif +}; + +namespace effects{ + +class AudioEffect{ +public: + virtual ~AudioEffect()=0; + virtual void Process(int16_t* inOut, size_t numSamples)=0; + virtual void SetPassThrough(bool passThrough); +protected: + bool passThrough=false; +}; + +class Volume : public AudioEffect{ +public: + Volume(); + virtual ~Volume(); + virtual void Process(int16_t* inOut, size_t numSamples); + /** + * Level is (0.0, 2.0] + */ + void SetLevel(float level); + float GetLevel(); +private: + float level=1.0f; + float multiplier=1.0f; +}; + +} +} + +#endif //LIBTGVOIP_ECHOCANCELLER_H diff --git a/TMessagesProj/jni/libtgvoip2/Info.plist b/TMessagesProj/jni/libtgvoip2/Info.plist new file mode 100644 index 000000000..fbe1e6b31 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/Info.plist @@ -0,0 +1,24 @@ + + + + + CFBundleDevelopmentRegion + en + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + FMWK + CFBundleShortVersionString + 1.0 + CFBundleVersion + $(CURRENT_PROJECT_VERSION) + NSPrincipalClass + + + diff --git a/TMessagesProj/jni/libtgvoip2/JitterBuffer.cpp b/TMessagesProj/jni/libtgvoip2/JitterBuffer.cpp new file mode 100644 index 000000000..7f967335a --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/JitterBuffer.cpp @@ -0,0 +1,455 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "VoIPController.h" +#include "JitterBuffer.h" +#include "logging.h" +#include "VoIPServerConfig.h" +#include + +using namespace tgvoip; + +JitterBuffer::JitterBuffer(MediaStreamItf *out, uint32_t step){ + if(out) + out->SetCallback(JitterBuffer::CallbackOut, this); + this->step=step; + memset(slots, 0, sizeof(jitter_packet_t)*JITTER_SLOT_COUNT); + if(step<30){ + minMinDelay=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_min_delay_20", 6); + maxMinDelay=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_max_delay_20", 25); + maxUsedSlots=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_max_slots_20", 50); + }else if(step<50){ + minMinDelay=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_min_delay_40", 4); + maxMinDelay=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_max_delay_40", 15); + maxUsedSlots=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_max_slots_40", 30); + }else{ + minMinDelay=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_min_delay_60", 2); + maxMinDelay=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_max_delay_60", 10); + maxUsedSlots=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_max_slots_60", 20); + } + lossesToReset=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_losses_to_reset", 20); + resyncThreshold=ServerConfig::GetSharedInstance()->GetDouble("jitter_resync_threshold", 1.0); +#ifdef TGVOIP_DUMP_JITTER_STATS +#ifdef TGVOIP_JITTER_DUMP_FILE + dump=fopen(TGVOIP_JITTER_DUMP_FILE, "w"); +#elif defined(__ANDROID__) + dump=fopen("/sdcard/tgvoip_jitter_dump.txt", "w"); +#else + dump=fopen("tgvoip_jitter_dump.txt", "w"); +#endif + tgvoip_log_file_write_header(dump); + fprintf(dump, "PTS\tRTS\tNumInBuf\tAJitter\tADelay\tTDelay\n"); +#endif + Reset(); +} + +JitterBuffer::~JitterBuffer(){ + Reset(); +} + +void JitterBuffer::SetMinPacketCount(uint32_t count){ + LOGI("jitter: set min packet count %u", count); + minDelay=count; + minMinDelay=count; + //Reset(); +} + +int JitterBuffer::GetMinPacketCount(){ + return (int)minDelay; +} + +size_t JitterBuffer::CallbackIn(unsigned char *data, size_t len, void *param){ + //((JitterBuffer*)param)->HandleInput(data, len); + return 0; +} + +size_t JitterBuffer::CallbackOut(unsigned char *data, size_t len, void *param){ + return 0; //((JitterBuffer*)param)->HandleOutput(data, len, 0, NULL); +} + +void JitterBuffer::HandleInput(unsigned char *data, size_t len, uint32_t timestamp, bool isEC){ + MutexGuard m(mutex); + jitter_packet_t pkt; + pkt.size=len; + pkt.buffer=Buffer::Wrap(data, len, [](void*){}, [](void* a, size_t)->void*{return a;}); + pkt.timestamp=timestamp; + pkt.isEC=isEC; + PutInternal(&pkt, !isEC); + //LOGV("in, ts=%d, ec=%d", timestamp, isEC); + +} + +void JitterBuffer::Reset(){ + wasReset=true; + needBuffering=true; + lastPutTimestamp=0; + int i; + for(i=0;ivoid*{return a;}); + pkt.size=len; + MutexGuard m(mutex); + if(first){ + first=false; + unsigned int delay=GetCurrentDelay(); + if(GetCurrentDelay()>5){ + LOGW("jitter: delay too big upon start (%u), dropping packets", delay); + while(delay>GetMinPacketCount()){ + for(int i=0;isizesize)); + }else{ + if(pkt) { + pkt->size = slots[i].size; + pkt->timestamp = slots[i].timestamp; + pkt->buffer.CopyFrom(slots[i].buffer, slots[i].size); + pkt->isEC=slots[i].isEC; + } + } + slots[i].buffer=Buffer(); + if(offset==0) + Advance(); + lostCount=0; + needBuffering=false; + return JR_OK; + } + + LOGV("jitter: found no packet for timestamp %lld (last put = %d, lost = %d)", (long long int)timestampToGet, lastPutTimestamp, lostCount); + + if(advance) + Advance(); + + if(!needBuffering){ + lostCount++; + if(offset==0){ + lostPackets++; + lostSinceReset++; + } + if(lostCount>=lossesToReset || (gotSinceReset>minDelay*25 && lostSinceReset>gotSinceReset/2)){ + LOGW("jitter: lost %d packets in a row, resetting", lostCount); + //minDelay++; + dontIncMinDelay=16; + dontDecMinDelay+=128; + if(GetCurrentDelay()size>JITTER_SLOT_SIZE){ + LOGE("The packet is too big to fit into the jitter buffer"); + return; + } + + int i; + for(i=0;itimestamp){ + //LOGV("Found existing packet for timestamp %u, overwrite %d", pkt->timestamp, overwriteExisting); + if(overwriteExisting){ + slots[i].buffer.CopyFrom(pkt->buffer, pkt->size); + slots[i].size=pkt->size; + slots[i].isEC=pkt->isEC; + } + return; + } + } + gotSinceReset++; + if(wasReset){ + wasReset=false; + outstandingDelayChange=0; + nextTimestamp=(int64_t)(((int64_t)pkt->timestamp)-step*minDelay); + first=true; + LOGI("jitter: resyncing, next timestamp = %lld (step=%d, minDelay=%f)", (long long int)nextTimestamp, step, double(minDelay)); + } + + for(i=0;itimestamp-slots[i].timestamptimestamp-closestTime){ + closestTime=slots[i].timestamp; + prevTime=slots[i].recvTime; + } + }*/ + double time=VoIPController::GetCurrentTime(); + if(expectNextAtTime!=0){ + double dev=expectNextAtTime-time; + //LOGV("packet dev %f", dev); + deviationHistory.Add(dev); + expectNextAtTime+=step/1000.0; + }else{ + expectNextAtTime=time+step/1000.0; + } + + if(pkt->timestamptimestamp); + latePacketCount++; + lostPackets--; + }else if(pkt->timestamptimestamp); + latePacketCount++; + return; + } + + if(pkt->timestamp>lastPutTimestamp) + lastPutTimestamp=pkt->timestamp; + + for(i=0;i=maxUsedSlots){ + int toRemove=JITTER_SLOT_COUNT; + uint32_t bestTimestamp=0xFFFFFFFF; + for(i=0;itimestamp; + slots[i].size=pkt->size; + slots[i].buffer=bufferPool.Get(); + slots[i].recvTimeDiff=time-prevRecvTime; + slots[i].isEC=pkt->isEC; + slots[i].buffer.CopyFrom(pkt->buffer, pkt->size); +#ifdef TGVOIP_DUMP_JITTER_STATS + fprintf(dump, "%u\t%.03f\t%d\t%.03f\t%.03f\t%.03f\n", pkt->timestamp, time, GetCurrentDelay(), lastMeasuredJitter, lastMeasuredDelay, minDelay); +#endif + prevRecvTime=time; +} + + +void JitterBuffer::Advance(){ + nextTimestamp+=step; +} + + +unsigned int JitterBuffer::GetCurrentDelay(){ + unsigned int delay=0; + int i; + for(i=0;i=resyncThreshold){ + LOGV("resyncing: avgLate16=%f, resyncThreshold=%f", avgLate16, resyncThreshold); + wasReset=true; + } + + if(absolutelyNoLatePackets){ + if(dontDecMinDelay>0) + dontDecMinDelay--; + } + + delayHistory.Add(GetCurrentDelay()); + avgDelay=delayHistory.Average(32); + + double stddev=0; + double avgdev=deviationHistory.Average(); + for(i=0;i<64;i++){ + double d=(deviationHistory[i]-avgdev); + stddev+=(d*d); + } + stddev=sqrt(stddev/64); + uint32_t stddevDelay=(uint32_t)ceil(stddev*2*1000/step); + if(stddevDelaymaxMinDelay) + stddevDelay=maxMinDelay; + if(stddevDelay!=minDelay){ + int32_t diff=(int32_t)(stddevDelay-minDelay); + if(diff>0){ + dontDecMinDelay=100; + } + if(diff<-1) + diff=-1; + if(diff>1) + diff=1; + if((diff>0 && dontIncMinDelay==0) || (diff<0 && dontDecMinDelay==0)){ + //nextTimestamp+=diff*(int32_t)step; + minDelay.store(minDelay + diff); + outstandingDelayChange+=diff*60; + dontChangeDelay+=32; + //LOGD("new delay from stddev %f", minDelay); + if(diff<0){ + dontDecMinDelay+=25; + } + if(diff>0){ + dontIncMinDelay=25; + } + } + } + lastMeasuredJitter=stddev; + lastMeasuredDelay=stddevDelay; + //LOGV("stddev=%.3f, avg=%.3f, ndelay=%d, dontDec=%u", stddev, avgdev, stddevDelay, dontDecMinDelay); + if(dontChangeDelay==0){ + if(avgDelay>minDelay+0.5){ + outstandingDelayChange-=avgDelay>minDelay+2 ? 60 : 20; + dontChangeDelay+=10; + }else if(avgDelay0) + dontChangeDelay--; + + //LOGV("jitter: avg delay=%d, delay=%d, late16=%.1f, dontDecMinDelay=%d", avgDelay, delayHistory[0], avgLate16, dontDecMinDelay); + /*if(!adjustingDelay) { + if (((minDelay==1 ? (avgDelay>=3) : (avgDelay>=minDelay/2)) && delayHistory[0]>minDelay && avgLate16<=0.1 && absolutelyNoLatePackets && dontDecMinDelay<32 && min>minDelay)) { + LOGI("jitter: need adjust"); + adjustingDelay=true; + } + }else{ + if(!absolutelyNoLatePackets){ + LOGI("jitter: done adjusting because we're losing packets"); + adjustingDelay=false; + }else if(tickCount%5==0){ + LOGD("jitter: removing a packet to reduce delay"); + GetInternal(NULL, 0); + expectNextAtTime=0; + if(GetCurrentDelay()<=minDelay || min<=minDelay){ + adjustingDelay = false; + LOGI("jitter: done adjusting"); + } + } + }*/ + + tickCount++; + +} + + +void JitterBuffer::GetAverageLateCount(double *out){ + double avgLate64=lateHistory.Average(), avgLate32=lateHistory.Average(32), avgLate16=lateHistory.Average(16); + out[0]=avgLate16; + out[1]=avgLate32; + out[2]=avgLate64; +} + + +int JitterBuffer::GetAndResetLostPacketCount(){ + MutexGuard m(mutex); + int r=lostPackets; + lostPackets=0; + return r; +} + +double JitterBuffer::GetLastMeasuredJitter(){ + return lastMeasuredJitter; +} + +double JitterBuffer::GetLastMeasuredDelay(){ + return lastMeasuredDelay; +} + +double JitterBuffer::GetAverageDelay(){ + return avgDelay; +} diff --git a/TMessagesProj/jni/libtgvoip2/JitterBuffer.h b/TMessagesProj/jni/libtgvoip2/JitterBuffer.h new file mode 100644 index 000000000..e0daf46f2 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/JitterBuffer.h @@ -0,0 +1,98 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_JITTERBUFFER_H +#define LIBTGVOIP_JITTERBUFFER_H + +#include +#include +#include +#include +#include "MediaStreamItf.h" +#include "BlockingQueue.h" +#include "Buffers.h" +#include "threading.h" + +#define JITTER_SLOT_COUNT 64 +#define JITTER_SLOT_SIZE 1024 +#define JR_OK 1 +#define JR_MISSING 2 +#define JR_BUFFERING 3 + + +namespace tgvoip{ +class JitterBuffer{ +public: + JitterBuffer(MediaStreamItf* out, uint32_t step); + ~JitterBuffer(); + void SetMinPacketCount(uint32_t count); + int GetMinPacketCount(); + unsigned int GetCurrentDelay(); + double GetAverageDelay(); + void Reset(); + void HandleInput(unsigned char* data, size_t len, uint32_t timestamp, bool isEC); + size_t HandleOutput(unsigned char* buffer, size_t len, int offsetInSteps, bool advance, int& playbackScaledDuration, bool& isEC); + void Tick(); + void GetAverageLateCount(double* out); + int GetAndResetLostPacketCount(); + double GetLastMeasuredJitter(); + double GetLastMeasuredDelay(); + +private: + struct jitter_packet_t{ + Buffer buffer=Buffer(); + size_t size; + uint32_t timestamp; + bool isEC; + double recvTimeDiff; + }; + static size_t CallbackIn(unsigned char* data, size_t len, void* param); + static size_t CallbackOut(unsigned char* data, size_t len, void* param); + void PutInternal(jitter_packet_t* pkt, bool overwriteExisting); + int GetInternal(jitter_packet_t* pkt, int offset, bool advance); + void Advance(); + + BufferPool bufferPool; + Mutex mutex; + jitter_packet_t slots[JITTER_SLOT_COUNT]; + int64_t nextTimestamp=0; + uint32_t step; + std::atomic minDelay{6}; + uint32_t minMinDelay; + uint32_t maxMinDelay; + uint32_t maxUsedSlots; + uint32_t lastPutTimestamp; + uint32_t lossesToReset; + double resyncThreshold; + unsigned int lostCount=0; + unsigned int lostSinceReset=0; + unsigned int gotSinceReset=0; + bool wasReset=true; + bool needBuffering=true; + HistoricBuffer delayHistory; + HistoricBuffer lateHistory; + bool adjustingDelay=false; + unsigned int tickCount=0; + unsigned int latePacketCount=0; + unsigned int dontIncMinDelay=0; + unsigned int dontDecMinDelay=0; + int lostPackets=0; + double prevRecvTime=0; + double expectNextAtTime=0; + HistoricBuffer deviationHistory; + double lastMeasuredJitter=0; + double lastMeasuredDelay=0; + int outstandingDelayChange=0; + unsigned int dontChangeDelay=0; + double avgDelay=0; + bool first=true; +#ifdef TGVOIP_DUMP_JITTER_STATS + FILE* dump; +#endif +}; +} + +#endif //LIBTGVOIP_JITTERBUFFER_H diff --git a/TMessagesProj/jni/libtgvoip2/Makefile.am b/TMessagesProj/jni/libtgvoip2/Makefile.am new file mode 100644 index 000000000..55ecb87b9 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/Makefile.am @@ -0,0 +1,769 @@ +AUTOMAKE_OPTIONS = foreign + +CFLAGS = -Wall -DHAVE_CONFIG_H -Wno-unknown-pragmas + +lib_LTLIBRARIES = libtgvoip.la + +SRC = TgVoip.cpp \ +VoIPController.cpp \ +Buffers.cpp \ +CongestionControl.cpp \ +EchoCanceller.cpp \ +JitterBuffer.cpp \ +logging.cpp \ +MediaStreamItf.cpp \ +MessageThread.cpp \ +NetworkSocket.cpp \ +OpusDecoder.cpp \ +OpusEncoder.cpp \ +PacketReassembler.cpp \ +VoIPGroupController.cpp \ +VoIPServerConfig.cpp \ +audio/AudioIO.cpp \ +audio/AudioInput.cpp \ +audio/AudioOutput.cpp \ +audio/Resampler.cpp \ +os/posix/NetworkSocketPosix.cpp \ +video/VideoSource.cpp \ +video/VideoRenderer.cpp \ +video/VideoPacketSender.cpp \ +video/VideoFEC.cpp \ +video/ScreamCongestionController.cpp \ +json11.cpp + +TGVOIP_HDRS = \ +TgVoip.h \ +VoIPController.h \ +Buffers.h \ +BlockingQueue.h \ +PrivateDefines.h \ +CongestionControl.h \ +EchoCanceller.h \ +JitterBuffer.h \ +logging.h \ +threading.h \ +MediaStreamItf.h \ +MessageThread.h \ +NetworkSocket.h \ +OpusDecoder.h \ +OpusEncoder.h \ +PacketReassembler.h \ +VoIPServerConfig.h \ +audio/AudioIO.h \ +audio/AudioInput.h \ +audio/AudioOutput.h \ +audio/Resampler.h \ +os/posix/NetworkSocketPosix.h \ +video/VideoSource.h \ +video/VideoPacketSender.h \ +video/VideoFEC.h \ +video/VideoRenderer.h \ +video/ScreamCongestionController.h \ +json11.hpp \ +utils.h + +if TARGET_OS_OSX + +SRC += \ +os/darwin/AudioInputAudioUnit.cpp \ +os/darwin/AudioOutputAudioUnit.cpp \ +os/darwin/AudioUnitIO.cpp \ +os/darwin/AudioInputAudioUnitOSX.cpp \ +os/darwin/AudioOutputAudioUnitOSX.cpp \ +os/darwin/DarwinSpecific.mm \ +os/darwin/SampleBufferDisplayLayerRenderer.mm \ +os/darwin/TGVVideoRenderer.mm \ +os/darwin/TGVVideoSource.mm \ +os/darwin/VideoToolboxEncoderSource.mm + +TGVOIP_HDRS += \ +os/darwin/AudioInputAudioUnit.h \ +os/darwin/AudioOutputAudioUnit.h \ +os/darwin/AudioUnitIO.h \ +os/darwin/AudioInputAudioUnitOSX.h \ +os/darwin/AudioOutputAudioUnitOSX.h \ +os/darwin/DarwinSpecific.h \ +os/darwin/SampleBufferDisplayLayerRenderer.h \ +os/darwin/TGVVideoRenderer.h \ +os/darwin/TGVVideoSource.h \ +os/darwin/VideoToolboxEncoderSource.h + +LDFLAGS += -framework Foundation -framework CoreFoundation -framework CoreAudio -framework AudioToolbox -framework VideoToolbox -framework CoreMedia -framework CoreVideo + +else +# Linux-specific + +if WITH_ALSA +SRC += \ +os/linux/AudioInputALSA.cpp \ +os/linux/AudioOutputALSA.cpp +TGVOIP_HDRS += \ +os/linux/AudioInputALSA.h \ +os/linux/AudioOutputALSA.h +endif + +if WITH_PULSE +SRC += \ +os/linux/AudioOutputPulse.cpp \ +os/linux/AudioInputPulse.cpp \ +os/linux/AudioPulse.cpp +TGVOIP_HDRS += \ +os/linux/AudioOutputPulse.h \ +os/linux/AudioInputPulse.h \ +os/linux/AudioPulse.h \ +os/linux/PulseFunctions.h +endif +endif + +if ENABLE_DSP +CFLAGS += -DWEBRTC_POSIX -DWEBRTC_APM_DEBUG_DUMP=0 -DWEBRTC_NS_FLOAT -I$(top_srcdir)/webrtc_dsp +CCASFLAGS += -I$(top_srcdir)/webrtc_dsp + +SRC += \ +./webrtc_dsp/system_wrappers/source/field_trial.cc \ +./webrtc_dsp/system_wrappers/source/metrics.cc \ +./webrtc_dsp/system_wrappers/source/cpu_features.cc \ +./webrtc_dsp/absl/strings/internal/memutil.cc \ +./webrtc_dsp/absl/strings/string_view.cc \ +./webrtc_dsp/absl/strings/ascii.cc \ +./webrtc_dsp/absl/types/bad_optional_access.cc \ +./webrtc_dsp/absl/types/optional.cc \ +./webrtc_dsp/absl/base/internal/raw_logging.cc \ +./webrtc_dsp/absl/base/internal/throw_delegate.cc \ +./webrtc_dsp/rtc_base/race_checker.cc \ +./webrtc_dsp/rtc_base/strings/string_builder.cc \ +./webrtc_dsp/rtc_base/memory/aligned_malloc.cc \ +./webrtc_dsp/rtc_base/timeutils.cc \ +./webrtc_dsp/rtc_base/platform_file.cc \ +./webrtc_dsp/rtc_base/string_to_number.cc \ +./webrtc_dsp/rtc_base/thread_checker_impl.cc \ +./webrtc_dsp/rtc_base/stringencode.cc \ +./webrtc_dsp/rtc_base/stringutils.cc \ +./webrtc_dsp/rtc_base/checks.cc \ +./webrtc_dsp/rtc_base/platform_thread.cc \ +./webrtc_dsp/rtc_base/logging_webrtc.cc \ +./webrtc_dsp/rtc_base/criticalsection.cc \ +./webrtc_dsp/rtc_base/platform_thread_types.cc \ +./webrtc_dsp/rtc_base/event.cc \ +./webrtc_dsp/rtc_base/event_tracer.cc \ +./webrtc_dsp/third_party/rnnoise/src/rnn_vad_weights.cc \ +./webrtc_dsp/third_party/rnnoise/src/kiss_fft.cc \ +./webrtc_dsp/api/audio/audio_frame.cc \ +./webrtc_dsp/api/audio/echo_canceller3_config.cc \ +./webrtc_dsp/api/audio/echo_canceller3_factory.cc \ +./webrtc_dsp/modules/third_party/fft/fft.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_estimator.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb16_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_gain_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines_logist.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filterbanks.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/transform.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_filter.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode_lpc_swb.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filter_functions.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/decode.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lattice.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/intialize.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_gain_swb_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/bandwidth_estimator.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_analysis.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines_hist.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/entropy_coding.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac_vad.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/crc.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb12_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/decode_bwe.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/spectrum_ar_model_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_lag_tables.c \ +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac.c \ +./webrtc_dsp/modules/audio_processing/rms_level.cc \ +./webrtc_dsp/modules/audio_processing/echo_detector/normalized_covariance_estimator.cc \ +./webrtc_dsp/modules/audio_processing/echo_detector/moving_max.cc \ +./webrtc_dsp/modules/audio_processing/echo_detector/circular_buffer.cc \ +./webrtc_dsp/modules/audio_processing/echo_detector/mean_variance_estimator.cc \ +./webrtc_dsp/modules/audio_processing/splitting_filter.cc \ +./webrtc_dsp/modules/audio_processing/gain_control_impl.cc \ +./webrtc_dsp/modules/audio_processing/ns/nsx_core.c \ +./webrtc_dsp/modules/audio_processing/ns/noise_suppression_x.c \ +./webrtc_dsp/modules/audio_processing/ns/nsx_core_c.c \ +./webrtc_dsp/modules/audio_processing/ns/ns_core.c \ +./webrtc_dsp/modules/audio_processing/ns/noise_suppression.c \ +./webrtc_dsp/modules/audio_processing/audio_buffer.cc \ +./webrtc_dsp/modules/audio_processing/typing_detection.cc \ +./webrtc_dsp/modules/audio_processing/include/audio_processing_statistics.cc \ +./webrtc_dsp/modules/audio_processing/include/audio_generator_factory.cc \ +./webrtc_dsp/modules/audio_processing/include/aec_dump.cc \ +./webrtc_dsp/modules/audio_processing/include/audio_processing.cc \ +./webrtc_dsp/modules/audio_processing/include/config.cc \ +./webrtc_dsp/modules/audio_processing/agc2/interpolated_gain_curve.cc \ +./webrtc_dsp/modules/audio_processing/agc2/agc2_common.cc \ +./webrtc_dsp/modules/audio_processing/agc2/gain_applier.cc \ +./webrtc_dsp/modules/audio_processing/agc2/adaptive_agc.cc \ +./webrtc_dsp/modules/audio_processing/agc2/adaptive_digital_gain_applier.cc \ +./webrtc_dsp/modules/audio_processing/agc2/limiter.cc \ +./webrtc_dsp/modules/audio_processing/agc2/saturation_protector.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features_internal.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/rnn.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search_internal.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/features_extraction.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/fft_util.cc \ +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/lp_residual.cc \ +./webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator_agc.cc \ +./webrtc_dsp/modules/audio_processing/agc2/vector_float_frame.cc \ +./webrtc_dsp/modules/audio_processing/agc2/noise_level_estimator.cc \ +./webrtc_dsp/modules/audio_processing/agc2/agc2_testing_common.cc \ +./webrtc_dsp/modules/audio_processing/agc2/fixed_digital_level_estimator.cc \ +./webrtc_dsp/modules/audio_processing/agc2/fixed_gain_controller.cc \ +./webrtc_dsp/modules/audio_processing/agc2/vad_with_level.cc \ +./webrtc_dsp/modules/audio_processing/agc2/limiter_db_gain_curve.cc \ +./webrtc_dsp/modules/audio_processing/agc2/down_sampler.cc \ +./webrtc_dsp/modules/audio_processing/agc2/signal_classifier.cc \ +./webrtc_dsp/modules/audio_processing/agc2/noise_spectrum_estimator.cc \ +./webrtc_dsp/modules/audio_processing/agc2/compute_interpolated_gain_curve.cc \ +./webrtc_dsp/modules/audio_processing/agc2/biquad_filter.cc \ +./webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator.cc \ +./webrtc_dsp/modules/audio_processing/transient/moving_moments.cc \ +./webrtc_dsp/modules/audio_processing/transient/wpd_tree.cc \ +./webrtc_dsp/modules/audio_processing/transient/wpd_node.cc \ +./webrtc_dsp/modules/audio_processing/transient/transient_suppressor.cc \ +./webrtc_dsp/modules/audio_processing/transient/transient_detector.cc \ +./webrtc_dsp/modules/audio_processing/low_cut_filter.cc \ +./webrtc_dsp/modules/audio_processing/level_estimator_impl.cc \ +./webrtc_dsp/modules/audio_processing/three_band_filter_bank.cc \ +./webrtc_dsp/modules/audio_processing/aec/echo_cancellation.cc \ +./webrtc_dsp/modules/audio_processing/aec/aec_resampler.cc \ +./webrtc_dsp/modules/audio_processing/aec/aec_core.cc \ +./webrtc_dsp/modules/audio_processing/voice_detection_impl.cc \ +./webrtc_dsp/modules/audio_processing/echo_cancellation_impl.cc \ +./webrtc_dsp/modules/audio_processing/gain_control_for_experimental_agc.cc \ +./webrtc_dsp/modules/audio_processing/agc/agc.cc \ +./webrtc_dsp/modules/audio_processing/agc/loudness_histogram.cc \ +./webrtc_dsp/modules/audio_processing/agc/agc_manager_direct.cc \ +./webrtc_dsp/modules/audio_processing/agc/legacy/analog_agc.c \ +./webrtc_dsp/modules/audio_processing/agc/legacy/digital_agc.c \ +./webrtc_dsp/modules/audio_processing/agc/utility.cc \ +./webrtc_dsp/modules/audio_processing/audio_processing_impl.cc \ +./webrtc_dsp/modules/audio_processing/audio_generator/file_audio_generator.cc \ +./webrtc_dsp/modules/audio_processing/gain_controller2.cc \ +./webrtc_dsp/modules/audio_processing/residual_echo_detector.cc \ +./webrtc_dsp/modules/audio_processing/noise_suppression_impl.cc \ +./webrtc_dsp/modules/audio_processing/aecm/aecm_core.cc \ +./webrtc_dsp/modules/audio_processing/aecm/aecm_core_c.cc \ +./webrtc_dsp/modules/audio_processing/aecm/echo_control_mobile.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_reverb_model.cc \ +./webrtc_dsp/modules/audio_processing/aec3/reverb_model_fallback.cc \ +./webrtc_dsp/modules/audio_processing/aec3/echo_remover_metrics.cc \ +./webrtc_dsp/modules/audio_processing/aec3/matched_filter_lag_aggregator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer2.cc \ +./webrtc_dsp/modules/audio_processing/aec3/echo_path_variability.cc \ +./webrtc_dsp/modules/audio_processing/aec3/frame_blocker.cc \ +./webrtc_dsp/modules/audio_processing/aec3/subtractor.cc \ +./webrtc_dsp/modules/audio_processing/aec3/aec3_fft.cc \ +./webrtc_dsp/modules/audio_processing/aec3/fullband_erle_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/suppression_filter.cc \ +./webrtc_dsp/modules/audio_processing/aec3/block_processor.cc \ +./webrtc_dsp/modules/audio_processing/aec3/subband_erle_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller_metrics.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/vector_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/erl_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/aec_state.cc \ +./webrtc_dsp/modules/audio_processing/aec3/adaptive_fir_filter.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller.cc \ +./webrtc_dsp/modules/audio_processing/aec3/skew_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/echo_path_delay_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/block_framer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/erle_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/reverb_model.cc \ +./webrtc_dsp/modules/audio_processing/aec3/cascaded_biquad_filter.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/subtractor_output.cc \ +./webrtc_dsp/modules/audio_processing/aec3/stationarity_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_signal_analyzer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/subtractor_output_analyzer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/suppression_gain.cc \ +./webrtc_dsp/modules/audio_processing/aec3/echo_audibility.cc \ +./webrtc_dsp/modules/audio_processing/aec3/block_processor_metrics.cc \ +./webrtc_dsp/modules/audio_processing/aec3/moving_average.cc \ +./webrtc_dsp/modules/audio_processing/aec3/reverb_model_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/aec3_common.cc \ +./webrtc_dsp/modules/audio_processing/aec3/residual_echo_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/matched_filter.cc \ +./webrtc_dsp/modules/audio_processing/aec3/reverb_decay_estimator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller2.cc \ +./webrtc_dsp/modules/audio_processing/aec3/suppression_gain_limiter.cc \ +./webrtc_dsp/modules/audio_processing/aec3/main_filter_update_gain.cc \ +./webrtc_dsp/modules/audio_processing/aec3/echo_remover.cc \ +./webrtc_dsp/modules/audio_processing/aec3/downsampled_render_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/matrix_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/block_processor2.cc \ +./webrtc_dsp/modules/audio_processing/aec3/echo_canceller3.cc \ +./webrtc_dsp/modules/audio_processing/aec3/block_delay_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/fft_buffer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/comfort_noise_generator.cc \ +./webrtc_dsp/modules/audio_processing/aec3/shadow_filter_update_gain.cc \ +./webrtc_dsp/modules/audio_processing/aec3/filter_analyzer.cc \ +./webrtc_dsp/modules/audio_processing/aec3/reverb_frequency_response.cc \ +./webrtc_dsp/modules/audio_processing/aec3/decimator.cc \ +./webrtc_dsp/modules/audio_processing/echo_control_mobile_impl.cc \ +./webrtc_dsp/modules/audio_processing/logging/apm_data_dumper.cc \ +./webrtc_dsp/modules/audio_processing/vad/voice_activity_detector.cc \ +./webrtc_dsp/modules/audio_processing/vad/standalone_vad.cc \ +./webrtc_dsp/modules/audio_processing/vad/pitch_internal.cc \ +./webrtc_dsp/modules/audio_processing/vad/vad_circular_buffer.cc \ +./webrtc_dsp/modules/audio_processing/vad/vad_audio_proc.cc \ +./webrtc_dsp/modules/audio_processing/vad/pole_zero_filter.cc \ +./webrtc_dsp/modules/audio_processing/vad/pitch_based_vad.cc \ +./webrtc_dsp/modules/audio_processing/vad/gmm.cc \ +./webrtc_dsp/modules/audio_processing/utility/ooura_fft.cc \ +./webrtc_dsp/modules/audio_processing/utility/delay_estimator_wrapper.cc \ +./webrtc_dsp/modules/audio_processing/utility/delay_estimator.cc \ +./webrtc_dsp/modules/audio_processing/utility/block_mean_calculator.cc \ +./webrtc_dsp/common_audio/window_generator.cc \ +./webrtc_dsp/common_audio/channel_buffer.cc \ +./webrtc_dsp/common_audio/fir_filter_factory.cc \ +./webrtc_dsp/common_audio/wav_header.cc \ +./webrtc_dsp/common_audio/real_fourier_ooura.cc \ +./webrtc_dsp/common_audio/audio_util.cc \ +./webrtc_dsp/common_audio/fir_filter_sse.cc \ +./webrtc_dsp/common_audio/resampler/push_sinc_resampler.cc \ +./webrtc_dsp/common_audio/resampler/resampler.cc \ +./webrtc_dsp/common_audio/resampler/sinc_resampler_sse.cc \ +./webrtc_dsp/common_audio/resampler/push_resampler.cc \ +./webrtc_dsp/common_audio/resampler/sinc_resampler.cc \ +./webrtc_dsp/common_audio/resampler/sinusoidal_linear_chirp_source.cc \ +./webrtc_dsp/common_audio/wav_file.cc \ +./webrtc_dsp/common_audio/third_party/fft4g/fft4g.c \ +./webrtc_dsp/common_audio/audio_converter.cc \ +./webrtc_dsp/common_audio/real_fourier.cc \ +./webrtc_dsp/common_audio/sparse_fir_filter.cc \ +./webrtc_dsp/common_audio/smoothing_filter.cc \ +./webrtc_dsp/common_audio/fir_filter_c.cc \ +./webrtc_dsp/common_audio/ring_buffer.c \ +./webrtc_dsp/common_audio/signal_processing/complex_fft.c \ +./webrtc_dsp/common_audio/signal_processing/filter_ma_fast_q12.c \ +./webrtc_dsp/common_audio/signal_processing/splitting_filter1.c \ +./webrtc_dsp/common_audio/signal_processing/levinson_durbin.c \ +./webrtc_dsp/common_audio/signal_processing/dot_product_with_scale.cc \ +./webrtc_dsp/common_audio/signal_processing/auto_corr_to_refl_coef.c \ +./webrtc_dsp/common_audio/signal_processing/resample_by_2_internal.c \ +./webrtc_dsp/common_audio/signal_processing/energy.c \ +./webrtc_dsp/common_audio/signal_processing/sqrt_of_one_minus_x_squared.c \ +./webrtc_dsp/common_audio/signal_processing/downsample_fast.c \ +./webrtc_dsp/common_audio/signal_processing/filter_ar_fast_q12.c \ +./webrtc_dsp/common_audio/signal_processing/spl_init.c \ +./webrtc_dsp/common_audio/signal_processing/lpc_to_refl_coef.c \ +./webrtc_dsp/common_audio/signal_processing/cross_correlation.c \ +./webrtc_dsp/common_audio/signal_processing/division_operations.c \ +./webrtc_dsp/common_audio/signal_processing/auto_correlation.c \ +./webrtc_dsp/common_audio/signal_processing/get_scaling_square.c \ +./webrtc_dsp/common_audio/signal_processing/resample.c \ +./webrtc_dsp/common_audio/signal_processing/min_max_operations.c \ +./webrtc_dsp/common_audio/signal_processing/refl_coef_to_lpc.c \ +./webrtc_dsp/common_audio/signal_processing/filter_ar.c \ +./webrtc_dsp/common_audio/signal_processing/vector_scaling_operations.c \ +./webrtc_dsp/common_audio/signal_processing/resample_fractional.c \ +./webrtc_dsp/common_audio/signal_processing/real_fft.c \ +./webrtc_dsp/common_audio/signal_processing/ilbc_specific_functions.c \ +./webrtc_dsp/common_audio/signal_processing/randomization_functions.c \ +./webrtc_dsp/common_audio/signal_processing/copy_set_operations.c \ +./webrtc_dsp/common_audio/signal_processing/resample_by_2.c \ +./webrtc_dsp/common_audio/signal_processing/get_hanning_window.c \ +./webrtc_dsp/common_audio/signal_processing/resample_48khz.c \ +./webrtc_dsp/common_audio/signal_processing/spl_inl.c \ +./webrtc_dsp/common_audio/signal_processing/spl_sqrt.c \ +./webrtc_dsp/common_audio/vad/vad_sp.c \ +./webrtc_dsp/common_audio/vad/vad.cc \ +./webrtc_dsp/common_audio/vad/webrtc_vad.c \ +./webrtc_dsp/common_audio/vad/vad_filterbank.c \ +./webrtc_dsp/common_audio/vad/vad_core.c \ +./webrtc_dsp/common_audio/vad/vad_gmm.c + +if TARGET_OS_OSX +CFLAGS += -DWEBRTC_MAC +SRC += \ +webrtc_dsp/rtc_base/logging_mac.mm \ +webrtc_dsp/rtc_base/logging_mac.h +else +CFLAGS += -DWEBRTC_LINUX +endif + +if TARGET_CPU_X86 +SRC += \ +webrtc_dsp/modules/audio_processing/aec/aec_core_sse2.cc \ +webrtc_dsp/modules/audio_processing/utility/ooura_fft_sse2.cc +endif + +if ENABLE_AUDIO_CALLBACK +CFLAGS += -DTGVOIP_USE_CALLBACK_AUDIO_IO +SRC += \ +audio/AudioIOCallback.cpp +TGVOIP_HDRS += \ +audio/AudioIOCallback.h +endif + +if TARGET_CPU_ARM +SRC += \ +webrtc_dsp/common_audio/signal_processing/complex_bit_reverse_arm.S \ +webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor_arm.S +if TARGET_CPU_ARMV7 +CFLAGS += -mfpu=neon -mfloat-abi=hard +CCASFLAGS += -mfpu=neon -mfloat-abi=hard +SRC += \ +webrtc_dsp/common_audio/signal_processing/cross_correlation_neon.c \ +webrtc_dsp/common_audio/signal_processing/downsample_fast_neon.c \ +webrtc_dsp/common_audio/signal_processing/min_max_operations_neon.c \ +webrtc_dsp/modules/audio_processing/aec/aec_core_neon.cc \ +webrtc_dsp/modules/audio_processing/aecm/aecm_core_neon.cc \ +webrtc_dsp/modules/audio_processing/ns/nsx_core_neon.c \ +webrtc_dsp/modules/audio_processing/utility/ooura_fft_neon.cc +# webrtc_dsp/common_audio/signal_processing/filter_ar_fast_q12_armv7.S +endif +else +SRC += \ +webrtc_dsp/common_audio/signal_processing/complex_bit_reverse.c \ +webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor.c +endif + +# headers +SRC += \ +webrtc_dsp/system_wrappers/include/field_trial.h \ +webrtc_dsp/system_wrappers/include/cpu_features_wrapper.h \ +webrtc_dsp/system_wrappers/include/asm_defines.h \ +webrtc_dsp/system_wrappers/include/metrics.h \ +webrtc_dsp/system_wrappers/include/compile_assert_c.h \ +webrtc_dsp/typedefs.h \ +webrtc_dsp/absl/strings/internal/memutil.h \ +webrtc_dsp/absl/strings/ascii.h \ +webrtc_dsp/absl/strings/string_view.h \ +webrtc_dsp/absl/types/optional.h \ +webrtc_dsp/absl/types/bad_optional_access.h \ +webrtc_dsp/absl/memory/memory.h \ +webrtc_dsp/absl/meta/type_traits.h \ +webrtc_dsp/absl/algorithm/algorithm.h \ +webrtc_dsp/absl/container/inlined_vector.h \ +webrtc_dsp/absl/base/policy_checks.h \ +webrtc_dsp/absl/base/port.h \ +webrtc_dsp/absl/base/config.h \ +webrtc_dsp/absl/base/internal/invoke.h \ +webrtc_dsp/absl/base/internal/inline_variable.h \ +webrtc_dsp/absl/base/internal/atomic_hook.h \ +webrtc_dsp/absl/base/internal/identity.h \ +webrtc_dsp/absl/base/internal/raw_logging.h \ +webrtc_dsp/absl/base/internal/throw_delegate.h \ +webrtc_dsp/absl/base/attributes.h \ +webrtc_dsp/absl/base/macros.h \ +webrtc_dsp/absl/base/optimization.h \ +webrtc_dsp/absl/base/log_severity.h \ +webrtc_dsp/absl/utility/utility.h \ +webrtc_dsp/rtc_base/string_to_number.h \ +webrtc_dsp/rtc_base/constructormagic.h \ +webrtc_dsp/rtc_base/strings/string_builder.h \ +webrtc_dsp/rtc_base/event_tracer.h \ +webrtc_dsp/rtc_base/stringencode.h \ +webrtc_dsp/rtc_base/memory/aligned_malloc.h \ +webrtc_dsp/rtc_base/event.h \ +webrtc_dsp/rtc_base/ignore_wundef.h \ +webrtc_dsp/rtc_base/stringutils.h \ +webrtc_dsp/rtc_base/arraysize.h \ +webrtc_dsp/rtc_base/swap_queue.h \ +webrtc_dsp/rtc_base/trace_event.h \ +webrtc_dsp/rtc_base/checks.h \ +webrtc_dsp/rtc_base/deprecation.h \ +webrtc_dsp/rtc_base/sanitizer.h \ +webrtc_dsp/rtc_base/scoped_ref_ptr.h \ +webrtc_dsp/rtc_base/logging.h \ +webrtc_dsp/rtc_base/timeutils.h \ +webrtc_dsp/rtc_base/atomicops.h \ +webrtc_dsp/rtc_base/numerics/safe_minmax.h \ +webrtc_dsp/rtc_base/numerics/safe_conversions.h \ +webrtc_dsp/rtc_base/numerics/safe_conversions_impl.h \ +webrtc_dsp/rtc_base/numerics/safe_compare.h \ +webrtc_dsp/rtc_base/system/unused.h \ +webrtc_dsp/rtc_base/system/inline.h \ +webrtc_dsp/rtc_base/system/ignore_warnings.h \ +webrtc_dsp/rtc_base/system/asm_defines.h \ +webrtc_dsp/rtc_base/system/rtc_export.h \ +webrtc_dsp/rtc_base/system/arch.h \ +webrtc_dsp/rtc_base/platform_thread.h \ +webrtc_dsp/rtc_base/platform_thread_types.h \ +webrtc_dsp/rtc_base/protobuf_utils.h \ +webrtc_dsp/rtc_base/thread_annotations.h \ +webrtc_dsp/rtc_base/gtest_prod_util.h \ +webrtc_dsp/rtc_base/function_view.h \ +webrtc_dsp/rtc_base/criticalsection.h \ +webrtc_dsp/rtc_base/refcount.h \ +webrtc_dsp/rtc_base/thread_checker_impl.h \ +webrtc_dsp/rtc_base/compile_assert_c.h \ +webrtc_dsp/rtc_base/type_traits.h \ +webrtc_dsp/rtc_base/platform_file.h \ +webrtc_dsp/rtc_base/refcounter.h \ +webrtc_dsp/rtc_base/thread_checker.h \ +webrtc_dsp/rtc_base/race_checker.h \ +webrtc_dsp/rtc_base/refcountedobject.h \ +webrtc_dsp/third_party/rnnoise/src/rnn_activations.h \ +webrtc_dsp/third_party/rnnoise/src/kiss_fft.h \ +webrtc_dsp/third_party/rnnoise/src/rnn_vad_weights.h \ +webrtc_dsp/api/audio/echo_canceller3_config.h \ +webrtc_dsp/api/audio/echo_control.h \ +webrtc_dsp/api/audio/audio_frame.h \ +webrtc_dsp/api/audio/echo_canceller3_factory.h \ +webrtc_dsp/api/array_view.h \ +webrtc_dsp/modules/third_party/fft/fft.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/bandwidth_info.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/include/isac.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/os_specific_inline.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/entropy_coding.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac_vad.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/settings.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb12_tables.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/crc.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac_float_type.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_lag_tables.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/spectrum_ar_model_tables.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/codec.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_gain_tables.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb16_tables.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_estimator.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/structs.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filter_functions.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode_lpc_swb.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_filter.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_analysis.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/bandwidth_estimator.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_gain_swb_tables.h \ +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_tables.h \ +webrtc_dsp/modules/audio_processing/echo_detector/moving_max.h \ +webrtc_dsp/modules/audio_processing/echo_detector/circular_buffer.h \ +webrtc_dsp/modules/audio_processing/echo_detector/normalized_covariance_estimator.h \ +webrtc_dsp/modules/audio_processing/echo_detector/mean_variance_estimator.h \ +webrtc_dsp/modules/audio_processing/gain_control_for_experimental_agc.h \ +webrtc_dsp/modules/audio_processing/rms_level.h \ +webrtc_dsp/modules/audio_processing/ns/ns_core.h \ +webrtc_dsp/modules/audio_processing/ns/defines.h \ +webrtc_dsp/modules/audio_processing/ns/noise_suppression.h \ +webrtc_dsp/modules/audio_processing/ns/nsx_core.h \ +webrtc_dsp/modules/audio_processing/ns/windows_private.h \ +webrtc_dsp/modules/audio_processing/ns/noise_suppression_x.h \ +webrtc_dsp/modules/audio_processing/ns/nsx_defines.h \ +webrtc_dsp/modules/audio_processing/residual_echo_detector.h \ +webrtc_dsp/modules/audio_processing/audio_processing_impl.h \ +webrtc_dsp/modules/audio_processing/render_queue_item_verifier.h \ +webrtc_dsp/modules/audio_processing/include/audio_generator.h \ +webrtc_dsp/modules/audio_processing/include/config.h \ +webrtc_dsp/modules/audio_processing/include/audio_frame_view.h \ +webrtc_dsp/modules/audio_processing/include/mock_audio_processing.h \ +webrtc_dsp/modules/audio_processing/include/gain_control.h \ +webrtc_dsp/modules/audio_processing/include/audio_generator_factory.h \ +webrtc_dsp/modules/audio_processing/include/aec_dump.h \ +webrtc_dsp/modules/audio_processing/include/audio_processing_statistics.h \ +webrtc_dsp/modules/audio_processing/include/audio_processing.h \ +webrtc_dsp/modules/audio_processing/agc2/interpolated_gain_curve.h \ +webrtc_dsp/modules/audio_processing/agc2/biquad_filter.h \ +webrtc_dsp/modules/audio_processing/agc2/agc2_testing_common.h \ +webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator.h \ +webrtc_dsp/modules/audio_processing/agc2/signal_classifier.h \ +webrtc_dsp/modules/audio_processing/agc2/vector_float_frame.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/sequence_buffer.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/rnn.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/test_utils.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_info.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/lp_residual.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/ring_buffer.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/symmetric_matrix_buffer.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/features_extraction.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/common.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features_internal.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/fft_util.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search_internal.h \ +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search.h \ +webrtc_dsp/modules/audio_processing/agc2/fixed_gain_controller.h \ +webrtc_dsp/modules/audio_processing/agc2/down_sampler.h \ +webrtc_dsp/modules/audio_processing/agc2/saturation_protector.h \ +webrtc_dsp/modules/audio_processing/agc2/agc2_common.h \ +webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator_agc.h \ +webrtc_dsp/modules/audio_processing/agc2/adaptive_digital_gain_applier.h \ +webrtc_dsp/modules/audio_processing/agc2/vad_with_level.h \ +webrtc_dsp/modules/audio_processing/agc2/limiter_db_gain_curve.h \ +webrtc_dsp/modules/audio_processing/agc2/fixed_digital_level_estimator.h \ +webrtc_dsp/modules/audio_processing/agc2/adaptive_agc.h \ +webrtc_dsp/modules/audio_processing/agc2/gain_applier.h \ +webrtc_dsp/modules/audio_processing/agc2/noise_level_estimator.h \ +webrtc_dsp/modules/audio_processing/agc2/compute_interpolated_gain_curve.h \ +webrtc_dsp/modules/audio_processing/agc2/noise_spectrum_estimator.h \ +webrtc_dsp/modules/audio_processing/agc2/limiter.h \ +webrtc_dsp/modules/audio_processing/transient/transient_detector.h \ +webrtc_dsp/modules/audio_processing/transient/transient_suppressor.h \ +webrtc_dsp/modules/audio_processing/transient/daubechies_8_wavelet_coeffs.h \ +webrtc_dsp/modules/audio_processing/transient/common.h \ +webrtc_dsp/modules/audio_processing/transient/wpd_node.h \ +webrtc_dsp/modules/audio_processing/transient/moving_moments.h \ +webrtc_dsp/modules/audio_processing/transient/wpd_tree.h \ +webrtc_dsp/modules/audio_processing/transient/dyadic_decimator.h \ +webrtc_dsp/modules/audio_processing/noise_suppression_impl.h \ +webrtc_dsp/modules/audio_processing/aec/aec_resampler.h \ +webrtc_dsp/modules/audio_processing/aec/echo_cancellation.h \ +webrtc_dsp/modules/audio_processing/aec/aec_core.h \ +webrtc_dsp/modules/audio_processing/aec/aec_core_optimized_methods.h \ +webrtc_dsp/modules/audio_processing/aec/aec_common.h \ +webrtc_dsp/modules/audio_processing/voice_detection_impl.h \ +webrtc_dsp/modules/audio_processing/agc/legacy/analog_agc.h \ +webrtc_dsp/modules/audio_processing/agc/legacy/gain_control.h \ +webrtc_dsp/modules/audio_processing/agc/legacy/digital_agc.h \ +webrtc_dsp/modules/audio_processing/agc/mock_agc.h \ +webrtc_dsp/modules/audio_processing/agc/loudness_histogram.h \ +webrtc_dsp/modules/audio_processing/agc/gain_map_internal.h \ +webrtc_dsp/modules/audio_processing/agc/utility.h \ +webrtc_dsp/modules/audio_processing/agc/agc_manager_direct.h \ +webrtc_dsp/modules/audio_processing/agc/agc.h \ +webrtc_dsp/modules/audio_processing/common.h \ +webrtc_dsp/modules/audio_processing/audio_buffer.h \ +webrtc_dsp/modules/audio_processing/echo_control_mobile_impl.h \ +webrtc_dsp/modules/audio_processing/splitting_filter.h \ +webrtc_dsp/modules/audio_processing/low_cut_filter.h \ +webrtc_dsp/modules/audio_processing/audio_generator/file_audio_generator.h \ +webrtc_dsp/modules/audio_processing/three_band_filter_bank.h \ +webrtc_dsp/modules/audio_processing/echo_cancellation_impl.h \ +webrtc_dsp/modules/audio_processing/level_estimator_impl.h \ +webrtc_dsp/modules/audio_processing/gain_controller2.h \ +webrtc_dsp/modules/audio_processing/aecm/aecm_core.h \ +webrtc_dsp/modules/audio_processing/aecm/aecm_defines.h \ +webrtc_dsp/modules/audio_processing/aecm/echo_control_mobile.h \ +webrtc_dsp/modules/audio_processing/aec3/downsampled_render_buffer.h \ +webrtc_dsp/modules/audio_processing/aec3/subtractor_output_analyzer.h \ +webrtc_dsp/modules/audio_processing/aec3/residual_echo_estimator.h \ +webrtc_dsp/modules/audio_processing/aec3/shadow_filter_update_gain.h \ +webrtc_dsp/modules/audio_processing/aec3/aec_state.h \ +webrtc_dsp/modules/audio_processing/aec3/suppression_filter.h \ +webrtc_dsp/modules/audio_processing/aec3/block_delay_buffer.h \ +webrtc_dsp/modules/audio_processing/aec3/adaptive_fir_filter.h \ +webrtc_dsp/modules/audio_processing/aec3/cascaded_biquad_filter.h \ +webrtc_dsp/modules/audio_processing/aec3/matched_filter.h \ +webrtc_dsp/modules/audio_processing/aec3/subtractor_output.h \ +webrtc_dsp/modules/audio_processing/aec3/render_signal_analyzer.h \ +webrtc_dsp/modules/audio_processing/aec3/aec3_fft.h \ +webrtc_dsp/modules/audio_processing/aec3/echo_remover_metrics.h \ +webrtc_dsp/modules/audio_processing/aec3/filter_analyzer.h \ +webrtc_dsp/modules/audio_processing/aec3/subtractor.h \ +webrtc_dsp/modules/audio_processing/aec3/echo_path_delay_estimator.h \ +webrtc_dsp/modules/audio_processing/aec3/block_processor_metrics.h \ +webrtc_dsp/modules/audio_processing/aec3/fft_data.h \ +webrtc_dsp/modules/audio_processing/aec3/render_delay_controller_metrics.h \ +webrtc_dsp/modules/audio_processing/aec3/comfort_noise_generator.h \ +webrtc_dsp/modules/audio_processing/aec3/erl_estimator.h \ +webrtc_dsp/modules/audio_processing/aec3/echo_remover.h \ +webrtc_dsp/modules/audio_processing/aec3/matrix_buffer.h \ +webrtc_dsp/modules/audio_processing/aec3/reverb_model_estimator.h \ +webrtc_dsp/modules/audio_processing/aec3/echo_path_variability.h \ +webrtc_dsp/modules/audio_processing/aec3/moving_average.h \ +webrtc_dsp/modules/audio_processing/aec3/render_reverb_model.h \ +webrtc_dsp/modules/audio_processing/aec3/render_delay_controller.h \ +webrtc_dsp/modules/audio_processing/aec3/suppression_gain.h \ +webrtc_dsp/modules/audio_processing/aec3/erle_estimator.h \ +webrtc_dsp/modules/audio_processing/aec3/subband_erle_estimator.h \ +webrtc_dsp/modules/audio_processing/aec3/block_processor.h \ +webrtc_dsp/modules/audio_processing/aec3/fullband_erle_estimator.h \ +webrtc_dsp/modules/audio_processing/aec3/stationarity_estimator.h \ +webrtc_dsp/modules/audio_processing/aec3/echo_canceller3.h \ +webrtc_dsp/modules/audio_processing/aec3/skew_estimator.h \ +webrtc_dsp/modules/audio_processing/aec3/render_buffer.h \ +webrtc_dsp/modules/audio_processing/aec3/reverb_model_fallback.h \ +webrtc_dsp/modules/audio_processing/aec3/vector_buffer.h \ +webrtc_dsp/modules/audio_processing/aec3/reverb_frequency_response.h \ +webrtc_dsp/modules/audio_processing/aec3/echo_audibility.h \ +webrtc_dsp/modules/audio_processing/aec3/fft_buffer.h \ +webrtc_dsp/modules/audio_processing/aec3/aec3_common.h \ +webrtc_dsp/modules/audio_processing/aec3/vector_math.h \ +webrtc_dsp/modules/audio_processing/aec3/decimator.h \ +webrtc_dsp/modules/audio_processing/aec3/frame_blocker.h \ +webrtc_dsp/modules/audio_processing/aec3/block_framer.h \ +webrtc_dsp/modules/audio_processing/aec3/suppression_gain_limiter.h \ +webrtc_dsp/modules/audio_processing/aec3/delay_estimate.h \ +webrtc_dsp/modules/audio_processing/aec3/reverb_model.h \ +webrtc_dsp/modules/audio_processing/aec3/main_filter_update_gain.h \ +webrtc_dsp/modules/audio_processing/aec3/matched_filter_lag_aggregator.h \ +webrtc_dsp/modules/audio_processing/aec3/reverb_decay_estimator.h \ +webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer.h \ +webrtc_dsp/modules/audio_processing/gain_control_impl.h \ +webrtc_dsp/modules/audio_processing/typing_detection.h \ +webrtc_dsp/modules/audio_processing/logging/apm_data_dumper.h \ +webrtc_dsp/modules/audio_processing/vad/vad_audio_proc_internal.h \ +webrtc_dsp/modules/audio_processing/vad/vad_circular_buffer.h \ +webrtc_dsp/modules/audio_processing/vad/pitch_based_vad.h \ +webrtc_dsp/modules/audio_processing/vad/pole_zero_filter.h \ +webrtc_dsp/modules/audio_processing/vad/gmm.h \ +webrtc_dsp/modules/audio_processing/vad/common.h \ +webrtc_dsp/modules/audio_processing/vad/vad_audio_proc.h \ +webrtc_dsp/modules/audio_processing/vad/voice_gmm_tables.h \ +webrtc_dsp/modules/audio_processing/vad/noise_gmm_tables.h \ +webrtc_dsp/modules/audio_processing/vad/pitch_internal.h \ +webrtc_dsp/modules/audio_processing/vad/standalone_vad.h \ +webrtc_dsp/modules/audio_processing/vad/voice_activity_detector.h \ +webrtc_dsp/modules/audio_processing/utility/ooura_fft_tables_neon_sse2.h \ +webrtc_dsp/modules/audio_processing/utility/delay_estimator_internal.h \ +webrtc_dsp/modules/audio_processing/utility/ooura_fft.h \ +webrtc_dsp/modules/audio_processing/utility/block_mean_calculator.h \ +webrtc_dsp/modules/audio_processing/utility/delay_estimator.h \ +webrtc_dsp/modules/audio_processing/utility/ooura_fft_tables_common.h \ +webrtc_dsp/modules/audio_processing/utility/delay_estimator_wrapper.h \ +webrtc_dsp/common_audio/mocks/mock_smoothing_filter.h \ +webrtc_dsp/common_audio/wav_file.h \ +webrtc_dsp/common_audio/sparse_fir_filter.h \ +webrtc_dsp/common_audio/fir_filter_sse.h \ +webrtc_dsp/common_audio/window_generator.h \ +webrtc_dsp/common_audio/ring_buffer.h \ +webrtc_dsp/common_audio/fir_filter.h \ +webrtc_dsp/common_audio/include/audio_util.h \ +webrtc_dsp/common_audio/real_fourier_ooura.h \ +webrtc_dsp/common_audio/smoothing_filter.h \ +webrtc_dsp/common_audio/resampler/sinc_resampler.h \ +webrtc_dsp/common_audio/resampler/include/push_resampler.h \ +webrtc_dsp/common_audio/resampler/include/resampler.h \ +webrtc_dsp/common_audio/resampler/push_sinc_resampler.h \ +webrtc_dsp/common_audio/resampler/sinusoidal_linear_chirp_source.h \ +webrtc_dsp/common_audio/fir_filter_factory.h \ +webrtc_dsp/common_audio/audio_converter.h \ +webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor.h \ +webrtc_dsp/common_audio/third_party/fft4g/fft4g.h \ +webrtc_dsp/common_audio/channel_buffer.h \ +webrtc_dsp/common_audio/real_fourier.h \ +webrtc_dsp/common_audio/fir_filter_neon.h \ +webrtc_dsp/common_audio/fir_filter_c.h \ +webrtc_dsp/common_audio/signal_processing/complex_fft_tables.h \ +webrtc_dsp/common_audio/signal_processing/include/signal_processing_library.h \ +webrtc_dsp/common_audio/signal_processing/include/real_fft.h \ +webrtc_dsp/common_audio/signal_processing/include/spl_inl.h \ +webrtc_dsp/common_audio/signal_processing/include/spl_inl_armv7.h \ +webrtc_dsp/common_audio/signal_processing/dot_product_with_scale.h \ +webrtc_dsp/common_audio/signal_processing/resample_by_2_internal.h \ +webrtc_dsp/common_audio/wav_header.h \ +webrtc_dsp/common_audio/vad/vad_core.h \ +webrtc_dsp/common_audio/vad/include/vad.h \ +webrtc_dsp/common_audio/vad/include/webrtc_vad.h \ +webrtc_dsp/common_audio/vad/vad_gmm.h \ +webrtc_dsp/common_audio/vad/vad_sp.h \ +webrtc_dsp/common_audio/vad/vad_filterbank.h + +else +CFLAGS += -DTGVOIP_NO_DSP +endif + +libtgvoip_la_LDFLAGS = -version-number @LIBTGVOIP_MAJOR_VERSION@:@LIBTGVOIP_MINOR_VERSION@:@LIBTGVOIP_PATCH_VERSION@ +libtgvoip_la_SOURCES = $(SRC) $(TGVOIP_HDRS) +tgvoipincludedir = $(includedir)/tgvoip +nobase_tgvoipinclude_HEADERS = $(TGVOIP_HDRS) + +pkgconfig_DATA = tgvoip.pc + +CXXFLAGS += -std=gnu++0x $(CFLAGS) +if TARGET_OS_OSX +OBJCFLAGS = $(CFLAGS) +OBJCXXFLAGS += -std=gnu++0x $(CFLAGS) +endif diff --git a/TMessagesProj/jni/libtgvoip2/Makefile.in b/TMessagesProj/jni/libtgvoip2/Makefile.in new file mode 100644 index 000000000..445ad2545 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/Makefile.in @@ -0,0 +1,5242 @@ +# Makefile.in generated by automake 1.16.1 from Makefile.am. +# @configure_input@ + +# Copyright (C) 1994-2018 Free Software Foundation, Inc. + +# This Makefile.in is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +@SET_MAKE@ + + +VPATH = @srcdir@ +am__is_gnu_make = { \ + if test -z '$(MAKELEVEL)'; then \ + false; \ + elif test -n '$(MAKE_HOST)'; then \ + true; \ + elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ + true; \ + else \ + false; \ + fi; \ +} +am__make_running_with_option = \ + case $${target_option-} in \ + ?) ;; \ + *) echo "am__make_running_with_option: internal error: invalid" \ + "target option '$${target_option-}' specified" >&2; \ + exit 1;; \ + esac; \ + has_opt=no; \ + sane_makeflags=$$MAKEFLAGS; \ + if $(am__is_gnu_make); then \ + sane_makeflags=$$MFLAGS; \ + else \ + case $$MAKEFLAGS in \ + *\\[\ \ ]*) \ + bs=\\; \ + sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ + | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ + esac; \ + fi; \ + skip_next=no; \ + strip_trailopt () \ + { \ + flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ + }; \ + for flg in $$sane_makeflags; do \ + test $$skip_next = yes && { skip_next=no; continue; }; \ + case $$flg in \ + *=*|--*) continue;; \ + -*I) strip_trailopt 'I'; skip_next=yes;; \ + -*I?*) strip_trailopt 'I';; \ + -*O) strip_trailopt 'O'; skip_next=yes;; \ + -*O?*) strip_trailopt 'O';; \ + -*l) strip_trailopt 'l'; skip_next=yes;; \ + -*l?*) strip_trailopt 'l';; \ + -[dEDm]) skip_next=yes;; \ + -[JT]) skip_next=yes;; \ + esac; \ + case $$flg in \ + *$$target_option*) has_opt=yes; break;; \ + esac; \ + done; \ + test $$has_opt = yes +am__make_dryrun = (target_option=n; $(am__make_running_with_option)) +am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) +pkgdatadir = $(datadir)/@PACKAGE@ +pkgincludedir = $(includedir)/@PACKAGE@ +pkglibdir = $(libdir)/@PACKAGE@ +pkglibexecdir = $(libexecdir)/@PACKAGE@ +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd +install_sh_DATA = $(install_sh) -c -m 644 +install_sh_PROGRAM = $(install_sh) -c +install_sh_SCRIPT = $(install_sh) -c +INSTALL_HEADER = $(INSTALL_DATA) +transform = $(program_transform_name) +NORMAL_INSTALL = : +PRE_INSTALL = : +POST_INSTALL = : +NORMAL_UNINSTALL = : +PRE_UNINSTALL = : +POST_UNINSTALL = : +build_triplet = @build@ +host_triplet = @host@ +@TARGET_OS_OSX_TRUE@am__append_1 = \ +@TARGET_OS_OSX_TRUE@os/darwin/AudioInputAudioUnit.cpp \ +@TARGET_OS_OSX_TRUE@os/darwin/AudioOutputAudioUnit.cpp \ +@TARGET_OS_OSX_TRUE@os/darwin/AudioUnitIO.cpp \ +@TARGET_OS_OSX_TRUE@os/darwin/AudioInputAudioUnitOSX.cpp \ +@TARGET_OS_OSX_TRUE@os/darwin/AudioOutputAudioUnitOSX.cpp \ +@TARGET_OS_OSX_TRUE@os/darwin/DarwinSpecific.mm \ +@TARGET_OS_OSX_TRUE@os/darwin/SampleBufferDisplayLayerRenderer.mm \ +@TARGET_OS_OSX_TRUE@os/darwin/TGVVideoRenderer.mm \ +@TARGET_OS_OSX_TRUE@os/darwin/TGVVideoSource.mm \ +@TARGET_OS_OSX_TRUE@os/darwin/VideoToolboxEncoderSource.mm + +@TARGET_OS_OSX_TRUE@am__append_2 = \ +@TARGET_OS_OSX_TRUE@os/darwin/AudioInputAudioUnit.h \ +@TARGET_OS_OSX_TRUE@os/darwin/AudioOutputAudioUnit.h \ +@TARGET_OS_OSX_TRUE@os/darwin/AudioUnitIO.h \ +@TARGET_OS_OSX_TRUE@os/darwin/AudioInputAudioUnitOSX.h \ +@TARGET_OS_OSX_TRUE@os/darwin/AudioOutputAudioUnitOSX.h \ +@TARGET_OS_OSX_TRUE@os/darwin/DarwinSpecific.h \ +@TARGET_OS_OSX_TRUE@os/darwin/SampleBufferDisplayLayerRenderer.h \ +@TARGET_OS_OSX_TRUE@os/darwin/TGVVideoRenderer.h \ +@TARGET_OS_OSX_TRUE@os/darwin/TGVVideoSource.h \ +@TARGET_OS_OSX_TRUE@os/darwin/VideoToolboxEncoderSource.h + +@TARGET_OS_OSX_TRUE@am__append_3 = -framework Foundation -framework CoreFoundation -framework CoreAudio -framework AudioToolbox -framework VideoToolbox -framework CoreMedia -framework CoreVideo + +# Linux-specific +@TARGET_OS_OSX_FALSE@@WITH_ALSA_TRUE@am__append_4 = \ +@TARGET_OS_OSX_FALSE@@WITH_ALSA_TRUE@os/linux/AudioInputALSA.cpp \ +@TARGET_OS_OSX_FALSE@@WITH_ALSA_TRUE@os/linux/AudioOutputALSA.cpp + +@TARGET_OS_OSX_FALSE@@WITH_ALSA_TRUE@am__append_5 = \ +@TARGET_OS_OSX_FALSE@@WITH_ALSA_TRUE@os/linux/AudioInputALSA.h \ +@TARGET_OS_OSX_FALSE@@WITH_ALSA_TRUE@os/linux/AudioOutputALSA.h + +@TARGET_OS_OSX_FALSE@@WITH_PULSE_TRUE@am__append_6 = \ +@TARGET_OS_OSX_FALSE@@WITH_PULSE_TRUE@os/linux/AudioOutputPulse.cpp \ +@TARGET_OS_OSX_FALSE@@WITH_PULSE_TRUE@os/linux/AudioInputPulse.cpp \ +@TARGET_OS_OSX_FALSE@@WITH_PULSE_TRUE@os/linux/AudioPulse.cpp + +@TARGET_OS_OSX_FALSE@@WITH_PULSE_TRUE@am__append_7 = \ +@TARGET_OS_OSX_FALSE@@WITH_PULSE_TRUE@os/linux/AudioOutputPulse.h \ +@TARGET_OS_OSX_FALSE@@WITH_PULSE_TRUE@os/linux/AudioInputPulse.h \ +@TARGET_OS_OSX_FALSE@@WITH_PULSE_TRUE@os/linux/AudioPulse.h \ +@TARGET_OS_OSX_FALSE@@WITH_PULSE_TRUE@os/linux/PulseFunctions.h + +@ENABLE_DSP_TRUE@am__append_8 = -DWEBRTC_POSIX -DWEBRTC_APM_DEBUG_DUMP=0 -DWEBRTC_NS_FLOAT -I$(top_srcdir)/webrtc_dsp +@ENABLE_DSP_TRUE@am__append_9 = -I$(top_srcdir)/webrtc_dsp +@ENABLE_DSP_TRUE@am__append_10 = \ +@ENABLE_DSP_TRUE@./webrtc_dsp/system_wrappers/source/field_trial.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/system_wrappers/source/metrics.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/system_wrappers/source/cpu_features.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/absl/strings/internal/memutil.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/absl/strings/string_view.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/absl/strings/ascii.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/absl/types/bad_optional_access.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/absl/types/optional.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/absl/base/internal/raw_logging.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/absl/base/internal/throw_delegate.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/race_checker.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/strings/string_builder.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/memory/aligned_malloc.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/timeutils.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/platform_file.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/string_to_number.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/thread_checker_impl.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/stringencode.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/stringutils.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/checks.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/platform_thread.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/logging_webrtc.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/criticalsection.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/platform_thread_types.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/event.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/rtc_base/event_tracer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/third_party/rnnoise/src/rnn_vad_weights.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/third_party/rnnoise/src/kiss_fft.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/api/audio/audio_frame.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/api/audio/echo_canceller3_config.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/api/audio/echo_canceller3_factory.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/third_party/fft/fft.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_estimator.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb16_tables.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_gain_tables.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines_logist.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filterbanks.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/transform.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_filter.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode_lpc_swb.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filter_functions.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/decode.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lattice.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/intialize.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_tables.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_gain_swb_tables.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/bandwidth_estimator.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_analysis.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines_hist.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/entropy_coding.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac_vad.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/crc.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb12_tables.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/decode_bwe.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/spectrum_ar_model_tables.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_lag_tables.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/rms_level.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/echo_detector/normalized_covariance_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/echo_detector/moving_max.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/echo_detector/circular_buffer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/echo_detector/mean_variance_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/splitting_filter.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/gain_control_impl.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/ns/nsx_core.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/ns/noise_suppression_x.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/ns/nsx_core_c.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/ns/ns_core.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/ns/noise_suppression.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/audio_buffer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/typing_detection.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/include/audio_processing_statistics.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/include/audio_generator_factory.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/include/aec_dump.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/include/audio_processing.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/include/config.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/interpolated_gain_curve.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/agc2_common.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/gain_applier.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/adaptive_agc.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/adaptive_digital_gain_applier.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/limiter.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/saturation_protector.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features_internal.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/rnn.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search_internal.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/features_extraction.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/fft_util.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/lp_residual.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator_agc.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/vector_float_frame.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/noise_level_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/agc2_testing_common.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/fixed_digital_level_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/fixed_gain_controller.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/vad_with_level.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/limiter_db_gain_curve.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/down_sampler.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/signal_classifier.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/noise_spectrum_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/compute_interpolated_gain_curve.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/biquad_filter.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/transient/moving_moments.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/transient/wpd_tree.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/transient/wpd_node.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/transient/transient_suppressor.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/transient/transient_detector.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/low_cut_filter.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/level_estimator_impl.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/three_band_filter_bank.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec/echo_cancellation.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec/aec_resampler.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec/aec_core.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/voice_detection_impl.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/echo_cancellation_impl.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/gain_control_for_experimental_agc.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc/agc.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc/loudness_histogram.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc/agc_manager_direct.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc/legacy/analog_agc.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc/legacy/digital_agc.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/agc/utility.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/audio_processing_impl.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/audio_generator/file_audio_generator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/gain_controller2.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/residual_echo_detector.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/noise_suppression_impl.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aecm/aecm_core.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aecm/aecm_core_c.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aecm/echo_control_mobile.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/render_reverb_model.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/reverb_model_fallback.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/echo_remover_metrics.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/matched_filter_lag_aggregator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer2.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/echo_path_variability.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/frame_blocker.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/subtractor.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/aec3_fft.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/fullband_erle_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/suppression_filter.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/block_processor.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/subband_erle_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller_metrics.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/vector_buffer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/erl_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/aec_state.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/adaptive_fir_filter.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/skew_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/echo_path_delay_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/block_framer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/erle_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/reverb_model.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/cascaded_biquad_filter.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/render_buffer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/subtractor_output.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/stationarity_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/render_signal_analyzer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/subtractor_output_analyzer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/suppression_gain.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/echo_audibility.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/block_processor_metrics.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/moving_average.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/reverb_model_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/aec3_common.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/residual_echo_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/matched_filter.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/reverb_decay_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller2.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/suppression_gain_limiter.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/main_filter_update_gain.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/echo_remover.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/downsampled_render_buffer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/matrix_buffer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/block_processor2.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/echo_canceller3.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/block_delay_buffer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/fft_buffer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/comfort_noise_generator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/shadow_filter_update_gain.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/filter_analyzer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/reverb_frequency_response.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/aec3/decimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/echo_control_mobile_impl.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/logging/apm_data_dumper.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/vad/voice_activity_detector.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/vad/standalone_vad.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/vad/pitch_internal.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/vad/vad_circular_buffer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/vad/vad_audio_proc.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/vad/pole_zero_filter.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/vad/pitch_based_vad.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/vad/gmm.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/utility/ooura_fft.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/utility/delay_estimator_wrapper.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/utility/delay_estimator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/modules/audio_processing/utility/block_mean_calculator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/window_generator.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/channel_buffer.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/fir_filter_factory.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/wav_header.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/real_fourier_ooura.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/audio_util.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/fir_filter_sse.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/resampler/push_sinc_resampler.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/resampler/resampler.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/resampler/sinc_resampler_sse.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/resampler/push_resampler.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/resampler/sinc_resampler.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/resampler/sinusoidal_linear_chirp_source.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/wav_file.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/third_party/fft4g/fft4g.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/audio_converter.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/real_fourier.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/sparse_fir_filter.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/smoothing_filter.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/fir_filter_c.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/ring_buffer.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/complex_fft.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/filter_ma_fast_q12.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/splitting_filter1.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/levinson_durbin.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/dot_product_with_scale.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/auto_corr_to_refl_coef.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/resample_by_2_internal.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/energy.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/sqrt_of_one_minus_x_squared.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/downsample_fast.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/filter_ar_fast_q12.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/spl_init.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/lpc_to_refl_coef.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/cross_correlation.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/division_operations.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/auto_correlation.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/get_scaling_square.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/resample.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/min_max_operations.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/refl_coef_to_lpc.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/filter_ar.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/vector_scaling_operations.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/resample_fractional.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/real_fft.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/ilbc_specific_functions.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/randomization_functions.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/copy_set_operations.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/resample_by_2.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/get_hanning_window.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/resample_48khz.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/spl_inl.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/signal_processing/spl_sqrt.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/vad/vad_sp.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/vad/vad.cc \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/vad/webrtc_vad.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/vad/vad_filterbank.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/vad/vad_core.c \ +@ENABLE_DSP_TRUE@./webrtc_dsp/common_audio/vad/vad_gmm.c + +@ENABLE_DSP_TRUE@@TARGET_OS_OSX_TRUE@am__append_11 = -DWEBRTC_MAC +@ENABLE_DSP_TRUE@@TARGET_OS_OSX_TRUE@am__append_12 = \ +@ENABLE_DSP_TRUE@@TARGET_OS_OSX_TRUE@webrtc_dsp/rtc_base/logging_mac.mm \ +@ENABLE_DSP_TRUE@@TARGET_OS_OSX_TRUE@webrtc_dsp/rtc_base/logging_mac.h + +@ENABLE_DSP_TRUE@@TARGET_OS_OSX_FALSE@am__append_13 = -DWEBRTC_LINUX +@ENABLE_DSP_TRUE@@TARGET_CPU_X86_TRUE@am__append_14 = \ +@ENABLE_DSP_TRUE@@TARGET_CPU_X86_TRUE@webrtc_dsp/modules/audio_processing/aec/aec_core_sse2.cc \ +@ENABLE_DSP_TRUE@@TARGET_CPU_X86_TRUE@webrtc_dsp/modules/audio_processing/utility/ooura_fft_sse2.cc + +@ENABLE_AUDIO_CALLBACK_TRUE@@ENABLE_DSP_TRUE@am__append_15 = -DTGVOIP_USE_CALLBACK_AUDIO_IO +@ENABLE_AUDIO_CALLBACK_TRUE@@ENABLE_DSP_TRUE@am__append_16 = \ +@ENABLE_AUDIO_CALLBACK_TRUE@@ENABLE_DSP_TRUE@audio/AudioIOCallback.cpp + +@ENABLE_AUDIO_CALLBACK_TRUE@@ENABLE_DSP_TRUE@am__append_17 = \ +@ENABLE_AUDIO_CALLBACK_TRUE@@ENABLE_DSP_TRUE@audio/AudioIOCallback.h + +@ENABLE_DSP_TRUE@@TARGET_CPU_ARM_TRUE@am__append_18 = \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARM_TRUE@webrtc_dsp/common_audio/signal_processing/complex_bit_reverse_arm.S \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARM_TRUE@webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor_arm.S + +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@am__append_19 = -mfpu=neon -mfloat-abi=hard +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@am__append_20 = -mfpu=neon -mfloat-abi=hard +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@am__append_21 = \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@webrtc_dsp/common_audio/signal_processing/cross_correlation_neon.c \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@webrtc_dsp/common_audio/signal_processing/downsample_fast_neon.c \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@webrtc_dsp/common_audio/signal_processing/min_max_operations_neon.c \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@webrtc_dsp/modules/audio_processing/aec/aec_core_neon.cc \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@webrtc_dsp/modules/audio_processing/aecm/aecm_core_neon.cc \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@webrtc_dsp/modules/audio_processing/ns/nsx_core_neon.c \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@webrtc_dsp/modules/audio_processing/utility/ooura_fft_neon.cc + +# webrtc_dsp/common_audio/signal_processing/filter_ar_fast_q12_armv7.S +@ENABLE_DSP_TRUE@@TARGET_CPU_ARM_FALSE@am__append_22 = \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARM_FALSE@webrtc_dsp/common_audio/signal_processing/complex_bit_reverse.c \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARM_FALSE@webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor.c + + +# headers +@ENABLE_DSP_TRUE@am__append_23 = \ +@ENABLE_DSP_TRUE@webrtc_dsp/system_wrappers/include/field_trial.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/system_wrappers/include/cpu_features_wrapper.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/system_wrappers/include/asm_defines.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/system_wrappers/include/metrics.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/system_wrappers/include/compile_assert_c.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/typedefs.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/strings/internal/memutil.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/strings/ascii.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/strings/string_view.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/types/optional.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/types/bad_optional_access.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/memory/memory.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/meta/type_traits.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/algorithm/algorithm.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/container/inlined_vector.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/base/policy_checks.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/base/port.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/base/config.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/base/internal/invoke.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/base/internal/inline_variable.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/base/internal/atomic_hook.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/base/internal/identity.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/base/internal/raw_logging.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/base/internal/throw_delegate.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/base/attributes.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/base/macros.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/base/optimization.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/base/log_severity.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/absl/utility/utility.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/string_to_number.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/constructormagic.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/strings/string_builder.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/event_tracer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/stringencode.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/memory/aligned_malloc.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/event.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/ignore_wundef.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/stringutils.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/arraysize.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/swap_queue.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/trace_event.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/checks.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/deprecation.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/sanitizer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/scoped_ref_ptr.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/logging.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/timeutils.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/atomicops.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/numerics/safe_minmax.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/numerics/safe_conversions.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/numerics/safe_conversions_impl.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/numerics/safe_compare.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/system/unused.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/system/inline.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/system/ignore_warnings.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/system/asm_defines.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/system/rtc_export.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/system/arch.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/platform_thread.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/platform_thread_types.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/protobuf_utils.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/thread_annotations.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/gtest_prod_util.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/function_view.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/criticalsection.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/refcount.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/thread_checker_impl.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/compile_assert_c.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/type_traits.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/platform_file.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/refcounter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/thread_checker.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/race_checker.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/rtc_base/refcountedobject.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/third_party/rnnoise/src/rnn_activations.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/third_party/rnnoise/src/kiss_fft.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/third_party/rnnoise/src/rnn_vad_weights.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/api/audio/echo_canceller3_config.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/api/audio/echo_control.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/api/audio/audio_frame.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/api/audio/echo_canceller3_factory.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/api/array_view.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/third_party/fft/fft.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/bandwidth_info.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/include/isac.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/os_specific_inline.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/entropy_coding.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac_vad.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/settings.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb12_tables.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/crc.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac_float_type.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_lag_tables.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/spectrum_ar_model_tables.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/codec.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_gain_tables.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb16_tables.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/structs.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filter_functions.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode_lpc_swb.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_filter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_analysis.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/bandwidth_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_gain_swb_tables.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_tables.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/echo_detector/moving_max.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/echo_detector/circular_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/echo_detector/normalized_covariance_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/echo_detector/mean_variance_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/gain_control_for_experimental_agc.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/rms_level.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/ns/ns_core.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/ns/defines.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/ns/noise_suppression.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/ns/nsx_core.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/ns/windows_private.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/ns/noise_suppression_x.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/ns/nsx_defines.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/residual_echo_detector.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/audio_processing_impl.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/render_queue_item_verifier.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/include/audio_generator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/include/config.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/include/audio_frame_view.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/include/mock_audio_processing.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/include/gain_control.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/include/audio_generator_factory.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/include/aec_dump.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/include/audio_processing_statistics.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/include/audio_processing.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/interpolated_gain_curve.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/biquad_filter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/agc2_testing_common.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/signal_classifier.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/vector_float_frame.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/sequence_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/rnn.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/test_utils.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_info.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/lp_residual.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/ring_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/symmetric_matrix_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/features_extraction.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/common.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features_internal.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/fft_util.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search_internal.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/fixed_gain_controller.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/down_sampler.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/saturation_protector.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/agc2_common.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator_agc.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/adaptive_digital_gain_applier.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/vad_with_level.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/limiter_db_gain_curve.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/fixed_digital_level_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/adaptive_agc.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/gain_applier.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/noise_level_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/compute_interpolated_gain_curve.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/noise_spectrum_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc2/limiter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/transient/transient_detector.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/transient/transient_suppressor.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/transient/daubechies_8_wavelet_coeffs.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/transient/common.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/transient/wpd_node.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/transient/moving_moments.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/transient/wpd_tree.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/transient/dyadic_decimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/noise_suppression_impl.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec/aec_resampler.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec/echo_cancellation.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec/aec_core.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec/aec_core_optimized_methods.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec/aec_common.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/voice_detection_impl.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc/legacy/analog_agc.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc/legacy/gain_control.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc/legacy/digital_agc.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc/mock_agc.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc/loudness_histogram.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc/gain_map_internal.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc/utility.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc/agc_manager_direct.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/agc/agc.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/common.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/audio_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/echo_control_mobile_impl.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/splitting_filter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/low_cut_filter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/audio_generator/file_audio_generator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/three_band_filter_bank.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/echo_cancellation_impl.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/level_estimator_impl.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/gain_controller2.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aecm/aecm_core.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aecm/aecm_defines.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aecm/echo_control_mobile.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/downsampled_render_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/subtractor_output_analyzer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/residual_echo_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/shadow_filter_update_gain.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/aec_state.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/suppression_filter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/block_delay_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/adaptive_fir_filter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/cascaded_biquad_filter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/matched_filter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/subtractor_output.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/render_signal_analyzer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/aec3_fft.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/echo_remover_metrics.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/filter_analyzer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/subtractor.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/echo_path_delay_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/block_processor_metrics.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/fft_data.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/render_delay_controller_metrics.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/comfort_noise_generator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/erl_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/echo_remover.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/matrix_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/reverb_model_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/echo_path_variability.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/moving_average.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/render_reverb_model.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/render_delay_controller.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/suppression_gain.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/erle_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/subband_erle_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/block_processor.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/fullband_erle_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/stationarity_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/echo_canceller3.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/skew_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/render_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/reverb_model_fallback.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/vector_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/reverb_frequency_response.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/echo_audibility.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/fft_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/aec3_common.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/vector_math.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/decimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/frame_blocker.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/block_framer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/suppression_gain_limiter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/delay_estimate.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/reverb_model.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/main_filter_update_gain.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/matched_filter_lag_aggregator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/reverb_decay_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/gain_control_impl.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/typing_detection.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/logging/apm_data_dumper.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/vad/vad_audio_proc_internal.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/vad/vad_circular_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/vad/pitch_based_vad.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/vad/pole_zero_filter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/vad/gmm.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/vad/common.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/vad/vad_audio_proc.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/vad/voice_gmm_tables.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/vad/noise_gmm_tables.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/vad/pitch_internal.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/vad/standalone_vad.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/vad/voice_activity_detector.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/utility/ooura_fft_tables_neon_sse2.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/utility/delay_estimator_internal.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/utility/ooura_fft.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/utility/block_mean_calculator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/utility/delay_estimator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/utility/ooura_fft_tables_common.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/modules/audio_processing/utility/delay_estimator_wrapper.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/mocks/mock_smoothing_filter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/wav_file.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/sparse_fir_filter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/fir_filter_sse.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/window_generator.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/ring_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/fir_filter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/include/audio_util.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/real_fourier_ooura.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/smoothing_filter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/resampler/sinc_resampler.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/resampler/include/push_resampler.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/resampler/include/resampler.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/resampler/push_sinc_resampler.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/resampler/sinusoidal_linear_chirp_source.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/fir_filter_factory.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/audio_converter.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/third_party/fft4g/fft4g.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/channel_buffer.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/real_fourier.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/fir_filter_neon.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/fir_filter_c.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/signal_processing/complex_fft_tables.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/signal_processing/include/signal_processing_library.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/signal_processing/include/real_fft.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/signal_processing/include/spl_inl.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/signal_processing/include/spl_inl_armv7.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/signal_processing/dot_product_with_scale.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/signal_processing/resample_by_2_internal.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/wav_header.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/vad/vad_core.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/vad/include/vad.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/vad/include/webrtc_vad.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/vad/vad_gmm.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/vad/vad_sp.h \ +@ENABLE_DSP_TRUE@webrtc_dsp/common_audio/vad/vad_filterbank.h + +@ENABLE_DSP_FALSE@am__append_24 = -DTGVOIP_NO_DSP +@TARGET_OS_OSX_TRUE@am__append_25 = -std=gnu++0x $(CFLAGS) +subdir = . +ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 +am__aclocal_m4_deps = $(top_srcdir)/configure.ac +am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ + $(ACLOCAL_M4) +DIST_COMMON = $(srcdir)/Makefile.am $(top_srcdir)/configure \ + $(am__configure_deps) $(am__nobase_tgvoipinclude_HEADERS_DIST) \ + $(am__DIST_COMMON) +am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \ + configure.lineno config.status.lineno +mkinstalldirs = $(install_sh) -d +CONFIG_HEADER = config.h +CONFIG_CLEAN_FILES = +CONFIG_CLEAN_VPATH_FILES = +am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; +am__vpath_adj = case $$p in \ + $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ + *) f=$$p;; \ + esac; +am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; +am__install_max = 40 +am__nobase_strip_setup = \ + srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` +am__nobase_strip = \ + for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" +am__nobase_list = $(am__nobase_strip_setup); \ + for p in $$list; do echo "$$p $$p"; done | \ + sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ + $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ + if (++n[$$2] == $(am__install_max)) \ + { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ + END { for (dir in files) print dir, files[dir] }' +am__base_list = \ + sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ + sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' +am__uninstall_files_from_dir = { \ + test -z "$$files" \ + || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ + || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ + $(am__cd) "$$dir" && rm -f $$files; }; \ + } +am__installdirs = "$(DESTDIR)$(libdir)" \ + "$(DESTDIR)$(tgvoipincludedir)" +LTLIBRARIES = $(lib_LTLIBRARIES) +libtgvoip_la_LIBADD = +am__libtgvoip_la_SOURCES_DIST = TgVoip.cpp VoIPController.cpp \ + Buffers.cpp CongestionControl.cpp EchoCanceller.cpp \ + JitterBuffer.cpp logging.cpp MediaStreamItf.cpp \ + MessageThread.cpp NetworkSocket.cpp OpusDecoder.cpp \ + OpusEncoder.cpp PacketReassembler.cpp VoIPGroupController.cpp \ + VoIPServerConfig.cpp audio/AudioIO.cpp audio/AudioInput.cpp \ + audio/AudioOutput.cpp audio/Resampler.cpp \ + os/posix/NetworkSocketPosix.cpp video/VideoSource.cpp \ + video/VideoRenderer.cpp video/VideoPacketSender.cpp \ + video/VideoFEC.cpp video/ScreamCongestionController.cpp \ + json11.cpp os/darwin/AudioInputAudioUnit.cpp \ + os/darwin/AudioOutputAudioUnit.cpp os/darwin/AudioUnitIO.cpp \ + os/darwin/AudioInputAudioUnitOSX.cpp \ + os/darwin/AudioOutputAudioUnitOSX.cpp \ + os/darwin/DarwinSpecific.mm \ + os/darwin/SampleBufferDisplayLayerRenderer.mm \ + os/darwin/TGVVideoRenderer.mm os/darwin/TGVVideoSource.mm \ + os/darwin/VideoToolboxEncoderSource.mm \ + os/linux/AudioInputALSA.cpp os/linux/AudioOutputALSA.cpp \ + os/linux/AudioOutputPulse.cpp os/linux/AudioInputPulse.cpp \ + os/linux/AudioPulse.cpp \ + ./webrtc_dsp/system_wrappers/source/field_trial.cc \ + ./webrtc_dsp/system_wrappers/source/metrics.cc \ + ./webrtc_dsp/system_wrappers/source/cpu_features.cc \ + ./webrtc_dsp/absl/strings/internal/memutil.cc \ + ./webrtc_dsp/absl/strings/string_view.cc \ + ./webrtc_dsp/absl/strings/ascii.cc \ + ./webrtc_dsp/absl/types/bad_optional_access.cc \ + ./webrtc_dsp/absl/types/optional.cc \ + ./webrtc_dsp/absl/base/internal/raw_logging.cc \ + ./webrtc_dsp/absl/base/internal/throw_delegate.cc \ + ./webrtc_dsp/rtc_base/race_checker.cc \ + ./webrtc_dsp/rtc_base/strings/string_builder.cc \ + ./webrtc_dsp/rtc_base/memory/aligned_malloc.cc \ + ./webrtc_dsp/rtc_base/timeutils.cc \ + ./webrtc_dsp/rtc_base/platform_file.cc \ + ./webrtc_dsp/rtc_base/string_to_number.cc \ + ./webrtc_dsp/rtc_base/thread_checker_impl.cc \ + ./webrtc_dsp/rtc_base/stringencode.cc \ + ./webrtc_dsp/rtc_base/stringutils.cc \ + ./webrtc_dsp/rtc_base/checks.cc \ + ./webrtc_dsp/rtc_base/platform_thread.cc \ + ./webrtc_dsp/rtc_base/logging_webrtc.cc \ + ./webrtc_dsp/rtc_base/criticalsection.cc \ + ./webrtc_dsp/rtc_base/platform_thread_types.cc \ + ./webrtc_dsp/rtc_base/event.cc \ + ./webrtc_dsp/rtc_base/event_tracer.cc \ + ./webrtc_dsp/third_party/rnnoise/src/rnn_vad_weights.cc \ + ./webrtc_dsp/third_party/rnnoise/src/kiss_fft.cc \ + ./webrtc_dsp/api/audio/audio_frame.cc \ + ./webrtc_dsp/api/audio/echo_canceller3_config.cc \ + ./webrtc_dsp/api/audio/echo_canceller3_factory.cc \ + ./webrtc_dsp/modules/third_party/fft/fft.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_estimator.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb16_tables.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_gain_tables.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines_logist.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filterbanks.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/transform.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_filter.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode_lpc_swb.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filter_functions.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/decode.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lattice.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/intialize.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_tables.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_gain_swb_tables.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/bandwidth_estimator.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_analysis.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines_hist.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/entropy_coding.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac_vad.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/crc.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb12_tables.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/decode_bwe.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/spectrum_ar_model_tables.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_lag_tables.c \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac.c \ + ./webrtc_dsp/modules/audio_processing/rms_level.cc \ + ./webrtc_dsp/modules/audio_processing/echo_detector/normalized_covariance_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/echo_detector/moving_max.cc \ + ./webrtc_dsp/modules/audio_processing/echo_detector/circular_buffer.cc \ + ./webrtc_dsp/modules/audio_processing/echo_detector/mean_variance_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/splitting_filter.cc \ + ./webrtc_dsp/modules/audio_processing/gain_control_impl.cc \ + ./webrtc_dsp/modules/audio_processing/ns/nsx_core.c \ + ./webrtc_dsp/modules/audio_processing/ns/noise_suppression_x.c \ + ./webrtc_dsp/modules/audio_processing/ns/nsx_core_c.c \ + ./webrtc_dsp/modules/audio_processing/ns/ns_core.c \ + ./webrtc_dsp/modules/audio_processing/ns/noise_suppression.c \ + ./webrtc_dsp/modules/audio_processing/audio_buffer.cc \ + ./webrtc_dsp/modules/audio_processing/typing_detection.cc \ + ./webrtc_dsp/modules/audio_processing/include/audio_processing_statistics.cc \ + ./webrtc_dsp/modules/audio_processing/include/audio_generator_factory.cc \ + ./webrtc_dsp/modules/audio_processing/include/aec_dump.cc \ + ./webrtc_dsp/modules/audio_processing/include/audio_processing.cc \ + ./webrtc_dsp/modules/audio_processing/include/config.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/interpolated_gain_curve.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/agc2_common.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/gain_applier.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/adaptive_agc.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/adaptive_digital_gain_applier.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/limiter.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/saturation_protector.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features_internal.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/rnn.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search_internal.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/features_extraction.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/fft_util.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/lp_residual.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator_agc.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/vector_float_frame.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/noise_level_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/agc2_testing_common.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/fixed_digital_level_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/fixed_gain_controller.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/vad_with_level.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/limiter_db_gain_curve.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/down_sampler.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/signal_classifier.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/noise_spectrum_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/compute_interpolated_gain_curve.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/biquad_filter.cc \ + ./webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/transient/moving_moments.cc \ + ./webrtc_dsp/modules/audio_processing/transient/wpd_tree.cc \ + ./webrtc_dsp/modules/audio_processing/transient/wpd_node.cc \ + ./webrtc_dsp/modules/audio_processing/transient/transient_suppressor.cc \ + ./webrtc_dsp/modules/audio_processing/transient/transient_detector.cc \ + ./webrtc_dsp/modules/audio_processing/low_cut_filter.cc \ + ./webrtc_dsp/modules/audio_processing/level_estimator_impl.cc \ + ./webrtc_dsp/modules/audio_processing/three_band_filter_bank.cc \ + ./webrtc_dsp/modules/audio_processing/aec/echo_cancellation.cc \ + ./webrtc_dsp/modules/audio_processing/aec/aec_resampler.cc \ + ./webrtc_dsp/modules/audio_processing/aec/aec_core.cc \ + ./webrtc_dsp/modules/audio_processing/voice_detection_impl.cc \ + ./webrtc_dsp/modules/audio_processing/echo_cancellation_impl.cc \ + ./webrtc_dsp/modules/audio_processing/gain_control_for_experimental_agc.cc \ + ./webrtc_dsp/modules/audio_processing/agc/agc.cc \ + ./webrtc_dsp/modules/audio_processing/agc/loudness_histogram.cc \ + ./webrtc_dsp/modules/audio_processing/agc/agc_manager_direct.cc \ + ./webrtc_dsp/modules/audio_processing/agc/legacy/analog_agc.c \ + ./webrtc_dsp/modules/audio_processing/agc/legacy/digital_agc.c \ + ./webrtc_dsp/modules/audio_processing/agc/utility.cc \ + ./webrtc_dsp/modules/audio_processing/audio_processing_impl.cc \ + ./webrtc_dsp/modules/audio_processing/audio_generator/file_audio_generator.cc \ + ./webrtc_dsp/modules/audio_processing/gain_controller2.cc \ + ./webrtc_dsp/modules/audio_processing/residual_echo_detector.cc \ + ./webrtc_dsp/modules/audio_processing/noise_suppression_impl.cc \ + ./webrtc_dsp/modules/audio_processing/aecm/aecm_core.cc \ + ./webrtc_dsp/modules/audio_processing/aecm/aecm_core_c.cc \ + ./webrtc_dsp/modules/audio_processing/aecm/echo_control_mobile.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/render_reverb_model.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/reverb_model_fallback.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/echo_remover_metrics.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/matched_filter_lag_aggregator.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer2.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/echo_path_variability.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/frame_blocker.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/subtractor.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/aec3_fft.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/fullband_erle_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/suppression_filter.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/block_processor.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/subband_erle_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller_metrics.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/vector_buffer.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/erl_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/aec_state.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/adaptive_fir_filter.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/skew_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/echo_path_delay_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/block_framer.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/erle_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/reverb_model.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/cascaded_biquad_filter.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/render_buffer.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/subtractor_output.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/stationarity_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/render_signal_analyzer.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/subtractor_output_analyzer.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/suppression_gain.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/echo_audibility.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/block_processor_metrics.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/moving_average.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/reverb_model_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/aec3_common.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/residual_echo_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/matched_filter.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/reverb_decay_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller2.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/suppression_gain_limiter.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/main_filter_update_gain.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/echo_remover.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/downsampled_render_buffer.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/matrix_buffer.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/block_processor2.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/echo_canceller3.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/block_delay_buffer.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/fft_buffer.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/comfort_noise_generator.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/shadow_filter_update_gain.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/filter_analyzer.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/reverb_frequency_response.cc \ + ./webrtc_dsp/modules/audio_processing/aec3/decimator.cc \ + ./webrtc_dsp/modules/audio_processing/echo_control_mobile_impl.cc \ + ./webrtc_dsp/modules/audio_processing/logging/apm_data_dumper.cc \ + ./webrtc_dsp/modules/audio_processing/vad/voice_activity_detector.cc \ + ./webrtc_dsp/modules/audio_processing/vad/standalone_vad.cc \ + ./webrtc_dsp/modules/audio_processing/vad/pitch_internal.cc \ + ./webrtc_dsp/modules/audio_processing/vad/vad_circular_buffer.cc \ + ./webrtc_dsp/modules/audio_processing/vad/vad_audio_proc.cc \ + ./webrtc_dsp/modules/audio_processing/vad/pole_zero_filter.cc \ + ./webrtc_dsp/modules/audio_processing/vad/pitch_based_vad.cc \ + ./webrtc_dsp/modules/audio_processing/vad/gmm.cc \ + ./webrtc_dsp/modules/audio_processing/utility/ooura_fft.cc \ + ./webrtc_dsp/modules/audio_processing/utility/delay_estimator_wrapper.cc \ + ./webrtc_dsp/modules/audio_processing/utility/delay_estimator.cc \ + ./webrtc_dsp/modules/audio_processing/utility/block_mean_calculator.cc \ + ./webrtc_dsp/common_audio/window_generator.cc \ + ./webrtc_dsp/common_audio/channel_buffer.cc \ + ./webrtc_dsp/common_audio/fir_filter_factory.cc \ + ./webrtc_dsp/common_audio/wav_header.cc \ + ./webrtc_dsp/common_audio/real_fourier_ooura.cc \ + ./webrtc_dsp/common_audio/audio_util.cc \ + ./webrtc_dsp/common_audio/fir_filter_sse.cc \ + ./webrtc_dsp/common_audio/resampler/push_sinc_resampler.cc \ + ./webrtc_dsp/common_audio/resampler/resampler.cc \ + ./webrtc_dsp/common_audio/resampler/sinc_resampler_sse.cc \ + ./webrtc_dsp/common_audio/resampler/push_resampler.cc \ + ./webrtc_dsp/common_audio/resampler/sinc_resampler.cc \ + ./webrtc_dsp/common_audio/resampler/sinusoidal_linear_chirp_source.cc \ + ./webrtc_dsp/common_audio/wav_file.cc \ + ./webrtc_dsp/common_audio/third_party/fft4g/fft4g.c \ + ./webrtc_dsp/common_audio/audio_converter.cc \ + ./webrtc_dsp/common_audio/real_fourier.cc \ + ./webrtc_dsp/common_audio/sparse_fir_filter.cc \ + ./webrtc_dsp/common_audio/smoothing_filter.cc \ + ./webrtc_dsp/common_audio/fir_filter_c.cc \ + ./webrtc_dsp/common_audio/ring_buffer.c \ + ./webrtc_dsp/common_audio/signal_processing/complex_fft.c \ + ./webrtc_dsp/common_audio/signal_processing/filter_ma_fast_q12.c \ + ./webrtc_dsp/common_audio/signal_processing/splitting_filter1.c \ + ./webrtc_dsp/common_audio/signal_processing/levinson_durbin.c \ + ./webrtc_dsp/common_audio/signal_processing/dot_product_with_scale.cc \ + ./webrtc_dsp/common_audio/signal_processing/auto_corr_to_refl_coef.c \ + ./webrtc_dsp/common_audio/signal_processing/resample_by_2_internal.c \ + ./webrtc_dsp/common_audio/signal_processing/energy.c \ + ./webrtc_dsp/common_audio/signal_processing/sqrt_of_one_minus_x_squared.c \ + ./webrtc_dsp/common_audio/signal_processing/downsample_fast.c \ + ./webrtc_dsp/common_audio/signal_processing/filter_ar_fast_q12.c \ + ./webrtc_dsp/common_audio/signal_processing/spl_init.c \ + ./webrtc_dsp/common_audio/signal_processing/lpc_to_refl_coef.c \ + ./webrtc_dsp/common_audio/signal_processing/cross_correlation.c \ + ./webrtc_dsp/common_audio/signal_processing/division_operations.c \ + ./webrtc_dsp/common_audio/signal_processing/auto_correlation.c \ + ./webrtc_dsp/common_audio/signal_processing/get_scaling_square.c \ + ./webrtc_dsp/common_audio/signal_processing/resample.c \ + ./webrtc_dsp/common_audio/signal_processing/min_max_operations.c \ + ./webrtc_dsp/common_audio/signal_processing/refl_coef_to_lpc.c \ + ./webrtc_dsp/common_audio/signal_processing/filter_ar.c \ + ./webrtc_dsp/common_audio/signal_processing/vector_scaling_operations.c \ + ./webrtc_dsp/common_audio/signal_processing/resample_fractional.c \ + ./webrtc_dsp/common_audio/signal_processing/real_fft.c \ + ./webrtc_dsp/common_audio/signal_processing/ilbc_specific_functions.c \ + ./webrtc_dsp/common_audio/signal_processing/randomization_functions.c \ + ./webrtc_dsp/common_audio/signal_processing/copy_set_operations.c \ + ./webrtc_dsp/common_audio/signal_processing/resample_by_2.c \ + ./webrtc_dsp/common_audio/signal_processing/get_hanning_window.c \ + ./webrtc_dsp/common_audio/signal_processing/resample_48khz.c \ + ./webrtc_dsp/common_audio/signal_processing/spl_inl.c \ + ./webrtc_dsp/common_audio/signal_processing/spl_sqrt.c \ + ./webrtc_dsp/common_audio/vad/vad_sp.c \ + ./webrtc_dsp/common_audio/vad/vad.cc \ + ./webrtc_dsp/common_audio/vad/webrtc_vad.c \ + ./webrtc_dsp/common_audio/vad/vad_filterbank.c \ + ./webrtc_dsp/common_audio/vad/vad_core.c \ + ./webrtc_dsp/common_audio/vad/vad_gmm.c \ + webrtc_dsp/rtc_base/logging_mac.mm \ + webrtc_dsp/rtc_base/logging_mac.h \ + webrtc_dsp/modules/audio_processing/aec/aec_core_sse2.cc \ + webrtc_dsp/modules/audio_processing/utility/ooura_fft_sse2.cc \ + audio/AudioIOCallback.cpp \ + webrtc_dsp/common_audio/signal_processing/complex_bit_reverse_arm.S \ + webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor_arm.S \ + webrtc_dsp/common_audio/signal_processing/cross_correlation_neon.c \ + webrtc_dsp/common_audio/signal_processing/downsample_fast_neon.c \ + webrtc_dsp/common_audio/signal_processing/min_max_operations_neon.c \ + webrtc_dsp/modules/audio_processing/aec/aec_core_neon.cc \ + webrtc_dsp/modules/audio_processing/aecm/aecm_core_neon.cc \ + webrtc_dsp/modules/audio_processing/ns/nsx_core_neon.c \ + webrtc_dsp/modules/audio_processing/utility/ooura_fft_neon.cc \ + webrtc_dsp/common_audio/signal_processing/complex_bit_reverse.c \ + webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor.c \ + webrtc_dsp/system_wrappers/include/field_trial.h \ + webrtc_dsp/system_wrappers/include/cpu_features_wrapper.h \ + webrtc_dsp/system_wrappers/include/asm_defines.h \ + webrtc_dsp/system_wrappers/include/metrics.h \ + webrtc_dsp/system_wrappers/include/compile_assert_c.h \ + webrtc_dsp/typedefs.h \ + webrtc_dsp/absl/strings/internal/memutil.h \ + webrtc_dsp/absl/strings/ascii.h \ + webrtc_dsp/absl/strings/string_view.h \ + webrtc_dsp/absl/types/optional.h \ + webrtc_dsp/absl/types/bad_optional_access.h \ + webrtc_dsp/absl/memory/memory.h \ + webrtc_dsp/absl/meta/type_traits.h \ + webrtc_dsp/absl/algorithm/algorithm.h \ + webrtc_dsp/absl/container/inlined_vector.h \ + webrtc_dsp/absl/base/policy_checks.h \ + webrtc_dsp/absl/base/port.h webrtc_dsp/absl/base/config.h \ + webrtc_dsp/absl/base/internal/invoke.h \ + webrtc_dsp/absl/base/internal/inline_variable.h \ + webrtc_dsp/absl/base/internal/atomic_hook.h \ + webrtc_dsp/absl/base/internal/identity.h \ + webrtc_dsp/absl/base/internal/raw_logging.h \ + webrtc_dsp/absl/base/internal/throw_delegate.h \ + webrtc_dsp/absl/base/attributes.h \ + webrtc_dsp/absl/base/macros.h \ + webrtc_dsp/absl/base/optimization.h \ + webrtc_dsp/absl/base/log_severity.h \ + webrtc_dsp/absl/utility/utility.h \ + webrtc_dsp/rtc_base/string_to_number.h \ + webrtc_dsp/rtc_base/constructormagic.h \ + webrtc_dsp/rtc_base/strings/string_builder.h \ + webrtc_dsp/rtc_base/event_tracer.h \ + webrtc_dsp/rtc_base/stringencode.h \ + webrtc_dsp/rtc_base/memory/aligned_malloc.h \ + webrtc_dsp/rtc_base/event.h \ + webrtc_dsp/rtc_base/ignore_wundef.h \ + webrtc_dsp/rtc_base/stringutils.h \ + webrtc_dsp/rtc_base/arraysize.h \ + webrtc_dsp/rtc_base/swap_queue.h \ + webrtc_dsp/rtc_base/trace_event.h webrtc_dsp/rtc_base/checks.h \ + webrtc_dsp/rtc_base/deprecation.h \ + webrtc_dsp/rtc_base/sanitizer.h \ + webrtc_dsp/rtc_base/scoped_ref_ptr.h \ + webrtc_dsp/rtc_base/logging.h webrtc_dsp/rtc_base/timeutils.h \ + webrtc_dsp/rtc_base/atomicops.h \ + webrtc_dsp/rtc_base/numerics/safe_minmax.h \ + webrtc_dsp/rtc_base/numerics/safe_conversions.h \ + webrtc_dsp/rtc_base/numerics/safe_conversions_impl.h \ + webrtc_dsp/rtc_base/numerics/safe_compare.h \ + webrtc_dsp/rtc_base/system/unused.h \ + webrtc_dsp/rtc_base/system/inline.h \ + webrtc_dsp/rtc_base/system/ignore_warnings.h \ + webrtc_dsp/rtc_base/system/asm_defines.h \ + webrtc_dsp/rtc_base/system/rtc_export.h \ + webrtc_dsp/rtc_base/system/arch.h \ + webrtc_dsp/rtc_base/platform_thread.h \ + webrtc_dsp/rtc_base/platform_thread_types.h \ + webrtc_dsp/rtc_base/protobuf_utils.h \ + webrtc_dsp/rtc_base/thread_annotations.h \ + webrtc_dsp/rtc_base/gtest_prod_util.h \ + webrtc_dsp/rtc_base/function_view.h \ + webrtc_dsp/rtc_base/criticalsection.h \ + webrtc_dsp/rtc_base/refcount.h \ + webrtc_dsp/rtc_base/thread_checker_impl.h \ + webrtc_dsp/rtc_base/compile_assert_c.h \ + webrtc_dsp/rtc_base/type_traits.h \ + webrtc_dsp/rtc_base/platform_file.h \ + webrtc_dsp/rtc_base/refcounter.h \ + webrtc_dsp/rtc_base/thread_checker.h \ + webrtc_dsp/rtc_base/race_checker.h \ + webrtc_dsp/rtc_base/refcountedobject.h \ + webrtc_dsp/third_party/rnnoise/src/rnn_activations.h \ + webrtc_dsp/third_party/rnnoise/src/kiss_fft.h \ + webrtc_dsp/third_party/rnnoise/src/rnn_vad_weights.h \ + webrtc_dsp/api/audio/echo_canceller3_config.h \ + webrtc_dsp/api/audio/echo_control.h \ + webrtc_dsp/api/audio/audio_frame.h \ + webrtc_dsp/api/audio/echo_canceller3_factory.h \ + webrtc_dsp/api/array_view.h \ + webrtc_dsp/modules/third_party/fft/fft.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/bandwidth_info.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/include/isac.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/os_specific_inline.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/entropy_coding.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac_vad.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/settings.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb12_tables.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/crc.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac_float_type.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_lag_tables.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/spectrum_ar_model_tables.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/codec.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_gain_tables.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb16_tables.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_estimator.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/structs.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filter_functions.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode_lpc_swb.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_filter.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_analysis.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/bandwidth_estimator.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_gain_swb_tables.h \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_tables.h \ + webrtc_dsp/modules/audio_processing/echo_detector/moving_max.h \ + webrtc_dsp/modules/audio_processing/echo_detector/circular_buffer.h \ + webrtc_dsp/modules/audio_processing/echo_detector/normalized_covariance_estimator.h \ + webrtc_dsp/modules/audio_processing/echo_detector/mean_variance_estimator.h \ + webrtc_dsp/modules/audio_processing/gain_control_for_experimental_agc.h \ + webrtc_dsp/modules/audio_processing/rms_level.h \ + webrtc_dsp/modules/audio_processing/ns/ns_core.h \ + webrtc_dsp/modules/audio_processing/ns/defines.h \ + webrtc_dsp/modules/audio_processing/ns/noise_suppression.h \ + webrtc_dsp/modules/audio_processing/ns/nsx_core.h \ + webrtc_dsp/modules/audio_processing/ns/windows_private.h \ + webrtc_dsp/modules/audio_processing/ns/noise_suppression_x.h \ + webrtc_dsp/modules/audio_processing/ns/nsx_defines.h \ + webrtc_dsp/modules/audio_processing/residual_echo_detector.h \ + webrtc_dsp/modules/audio_processing/audio_processing_impl.h \ + webrtc_dsp/modules/audio_processing/render_queue_item_verifier.h \ + webrtc_dsp/modules/audio_processing/include/audio_generator.h \ + webrtc_dsp/modules/audio_processing/include/config.h \ + webrtc_dsp/modules/audio_processing/include/audio_frame_view.h \ + webrtc_dsp/modules/audio_processing/include/mock_audio_processing.h \ + webrtc_dsp/modules/audio_processing/include/gain_control.h \ + webrtc_dsp/modules/audio_processing/include/audio_generator_factory.h \ + webrtc_dsp/modules/audio_processing/include/aec_dump.h \ + webrtc_dsp/modules/audio_processing/include/audio_processing_statistics.h \ + webrtc_dsp/modules/audio_processing/include/audio_processing.h \ + webrtc_dsp/modules/audio_processing/agc2/interpolated_gain_curve.h \ + webrtc_dsp/modules/audio_processing/agc2/biquad_filter.h \ + webrtc_dsp/modules/audio_processing/agc2/agc2_testing_common.h \ + webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator.h \ + webrtc_dsp/modules/audio_processing/agc2/signal_classifier.h \ + webrtc_dsp/modules/audio_processing/agc2/vector_float_frame.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/sequence_buffer.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/rnn.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/test_utils.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_info.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/lp_residual.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/ring_buffer.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/symmetric_matrix_buffer.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/features_extraction.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/common.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features_internal.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/fft_util.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search_internal.h \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search.h \ + webrtc_dsp/modules/audio_processing/agc2/fixed_gain_controller.h \ + webrtc_dsp/modules/audio_processing/agc2/down_sampler.h \ + webrtc_dsp/modules/audio_processing/agc2/saturation_protector.h \ + webrtc_dsp/modules/audio_processing/agc2/agc2_common.h \ + webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator_agc.h \ + webrtc_dsp/modules/audio_processing/agc2/adaptive_digital_gain_applier.h \ + webrtc_dsp/modules/audio_processing/agc2/vad_with_level.h \ + webrtc_dsp/modules/audio_processing/agc2/limiter_db_gain_curve.h \ + webrtc_dsp/modules/audio_processing/agc2/fixed_digital_level_estimator.h \ + webrtc_dsp/modules/audio_processing/agc2/adaptive_agc.h \ + webrtc_dsp/modules/audio_processing/agc2/gain_applier.h \ + webrtc_dsp/modules/audio_processing/agc2/noise_level_estimator.h \ + webrtc_dsp/modules/audio_processing/agc2/compute_interpolated_gain_curve.h \ + webrtc_dsp/modules/audio_processing/agc2/noise_spectrum_estimator.h \ + webrtc_dsp/modules/audio_processing/agc2/limiter.h \ + webrtc_dsp/modules/audio_processing/transient/transient_detector.h \ + webrtc_dsp/modules/audio_processing/transient/transient_suppressor.h \ + webrtc_dsp/modules/audio_processing/transient/daubechies_8_wavelet_coeffs.h \ + webrtc_dsp/modules/audio_processing/transient/common.h \ + webrtc_dsp/modules/audio_processing/transient/wpd_node.h \ + webrtc_dsp/modules/audio_processing/transient/moving_moments.h \ + webrtc_dsp/modules/audio_processing/transient/wpd_tree.h \ + webrtc_dsp/modules/audio_processing/transient/dyadic_decimator.h \ + webrtc_dsp/modules/audio_processing/noise_suppression_impl.h \ + webrtc_dsp/modules/audio_processing/aec/aec_resampler.h \ + webrtc_dsp/modules/audio_processing/aec/echo_cancellation.h \ + webrtc_dsp/modules/audio_processing/aec/aec_core.h \ + webrtc_dsp/modules/audio_processing/aec/aec_core_optimized_methods.h \ + webrtc_dsp/modules/audio_processing/aec/aec_common.h \ + webrtc_dsp/modules/audio_processing/voice_detection_impl.h \ + webrtc_dsp/modules/audio_processing/agc/legacy/analog_agc.h \ + webrtc_dsp/modules/audio_processing/agc/legacy/gain_control.h \ + webrtc_dsp/modules/audio_processing/agc/legacy/digital_agc.h \ + webrtc_dsp/modules/audio_processing/agc/mock_agc.h \ + webrtc_dsp/modules/audio_processing/agc/loudness_histogram.h \ + webrtc_dsp/modules/audio_processing/agc/gain_map_internal.h \ + webrtc_dsp/modules/audio_processing/agc/utility.h \ + webrtc_dsp/modules/audio_processing/agc/agc_manager_direct.h \ + webrtc_dsp/modules/audio_processing/agc/agc.h \ + webrtc_dsp/modules/audio_processing/common.h \ + webrtc_dsp/modules/audio_processing/audio_buffer.h \ + webrtc_dsp/modules/audio_processing/echo_control_mobile_impl.h \ + webrtc_dsp/modules/audio_processing/splitting_filter.h \ + webrtc_dsp/modules/audio_processing/low_cut_filter.h \ + webrtc_dsp/modules/audio_processing/audio_generator/file_audio_generator.h \ + webrtc_dsp/modules/audio_processing/three_band_filter_bank.h \ + webrtc_dsp/modules/audio_processing/echo_cancellation_impl.h \ + webrtc_dsp/modules/audio_processing/level_estimator_impl.h \ + webrtc_dsp/modules/audio_processing/gain_controller2.h \ + webrtc_dsp/modules/audio_processing/aecm/aecm_core.h \ + webrtc_dsp/modules/audio_processing/aecm/aecm_defines.h \ + webrtc_dsp/modules/audio_processing/aecm/echo_control_mobile.h \ + webrtc_dsp/modules/audio_processing/aec3/downsampled_render_buffer.h \ + webrtc_dsp/modules/audio_processing/aec3/subtractor_output_analyzer.h \ + webrtc_dsp/modules/audio_processing/aec3/residual_echo_estimator.h \ + webrtc_dsp/modules/audio_processing/aec3/shadow_filter_update_gain.h \ + webrtc_dsp/modules/audio_processing/aec3/aec_state.h \ + webrtc_dsp/modules/audio_processing/aec3/suppression_filter.h \ + webrtc_dsp/modules/audio_processing/aec3/block_delay_buffer.h \ + webrtc_dsp/modules/audio_processing/aec3/adaptive_fir_filter.h \ + webrtc_dsp/modules/audio_processing/aec3/cascaded_biquad_filter.h \ + webrtc_dsp/modules/audio_processing/aec3/matched_filter.h \ + webrtc_dsp/modules/audio_processing/aec3/subtractor_output.h \ + webrtc_dsp/modules/audio_processing/aec3/render_signal_analyzer.h \ + webrtc_dsp/modules/audio_processing/aec3/aec3_fft.h \ + webrtc_dsp/modules/audio_processing/aec3/echo_remover_metrics.h \ + webrtc_dsp/modules/audio_processing/aec3/filter_analyzer.h \ + webrtc_dsp/modules/audio_processing/aec3/subtractor.h \ + webrtc_dsp/modules/audio_processing/aec3/echo_path_delay_estimator.h \ + webrtc_dsp/modules/audio_processing/aec3/block_processor_metrics.h \ + webrtc_dsp/modules/audio_processing/aec3/fft_data.h \ + webrtc_dsp/modules/audio_processing/aec3/render_delay_controller_metrics.h \ + webrtc_dsp/modules/audio_processing/aec3/comfort_noise_generator.h \ + webrtc_dsp/modules/audio_processing/aec3/erl_estimator.h \ + webrtc_dsp/modules/audio_processing/aec3/echo_remover.h \ + webrtc_dsp/modules/audio_processing/aec3/matrix_buffer.h \ + webrtc_dsp/modules/audio_processing/aec3/reverb_model_estimator.h \ + webrtc_dsp/modules/audio_processing/aec3/echo_path_variability.h \ + webrtc_dsp/modules/audio_processing/aec3/moving_average.h \ + webrtc_dsp/modules/audio_processing/aec3/render_reverb_model.h \ + webrtc_dsp/modules/audio_processing/aec3/render_delay_controller.h \ + webrtc_dsp/modules/audio_processing/aec3/suppression_gain.h \ + webrtc_dsp/modules/audio_processing/aec3/erle_estimator.h \ + webrtc_dsp/modules/audio_processing/aec3/subband_erle_estimator.h \ + webrtc_dsp/modules/audio_processing/aec3/block_processor.h \ + webrtc_dsp/modules/audio_processing/aec3/fullband_erle_estimator.h \ + webrtc_dsp/modules/audio_processing/aec3/stationarity_estimator.h \ + webrtc_dsp/modules/audio_processing/aec3/echo_canceller3.h \ + webrtc_dsp/modules/audio_processing/aec3/skew_estimator.h \ + webrtc_dsp/modules/audio_processing/aec3/render_buffer.h \ + webrtc_dsp/modules/audio_processing/aec3/reverb_model_fallback.h \ + webrtc_dsp/modules/audio_processing/aec3/vector_buffer.h \ + webrtc_dsp/modules/audio_processing/aec3/reverb_frequency_response.h \ + webrtc_dsp/modules/audio_processing/aec3/echo_audibility.h \ + webrtc_dsp/modules/audio_processing/aec3/fft_buffer.h \ + webrtc_dsp/modules/audio_processing/aec3/aec3_common.h \ + webrtc_dsp/modules/audio_processing/aec3/vector_math.h \ + webrtc_dsp/modules/audio_processing/aec3/decimator.h \ + webrtc_dsp/modules/audio_processing/aec3/frame_blocker.h \ + webrtc_dsp/modules/audio_processing/aec3/block_framer.h \ + webrtc_dsp/modules/audio_processing/aec3/suppression_gain_limiter.h \ + webrtc_dsp/modules/audio_processing/aec3/delay_estimate.h \ + webrtc_dsp/modules/audio_processing/aec3/reverb_model.h \ + webrtc_dsp/modules/audio_processing/aec3/main_filter_update_gain.h \ + webrtc_dsp/modules/audio_processing/aec3/matched_filter_lag_aggregator.h \ + webrtc_dsp/modules/audio_processing/aec3/reverb_decay_estimator.h \ + webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer.h \ + webrtc_dsp/modules/audio_processing/gain_control_impl.h \ + webrtc_dsp/modules/audio_processing/typing_detection.h \ + webrtc_dsp/modules/audio_processing/logging/apm_data_dumper.h \ + webrtc_dsp/modules/audio_processing/vad/vad_audio_proc_internal.h \ + webrtc_dsp/modules/audio_processing/vad/vad_circular_buffer.h \ + webrtc_dsp/modules/audio_processing/vad/pitch_based_vad.h \ + webrtc_dsp/modules/audio_processing/vad/pole_zero_filter.h \ + webrtc_dsp/modules/audio_processing/vad/gmm.h \ + webrtc_dsp/modules/audio_processing/vad/common.h \ + webrtc_dsp/modules/audio_processing/vad/vad_audio_proc.h \ + webrtc_dsp/modules/audio_processing/vad/voice_gmm_tables.h \ + webrtc_dsp/modules/audio_processing/vad/noise_gmm_tables.h \ + webrtc_dsp/modules/audio_processing/vad/pitch_internal.h \ + webrtc_dsp/modules/audio_processing/vad/standalone_vad.h \ + webrtc_dsp/modules/audio_processing/vad/voice_activity_detector.h \ + webrtc_dsp/modules/audio_processing/utility/ooura_fft_tables_neon_sse2.h \ + webrtc_dsp/modules/audio_processing/utility/delay_estimator_internal.h \ + webrtc_dsp/modules/audio_processing/utility/ooura_fft.h \ + webrtc_dsp/modules/audio_processing/utility/block_mean_calculator.h \ + webrtc_dsp/modules/audio_processing/utility/delay_estimator.h \ + webrtc_dsp/modules/audio_processing/utility/ooura_fft_tables_common.h \ + webrtc_dsp/modules/audio_processing/utility/delay_estimator_wrapper.h \ + webrtc_dsp/common_audio/mocks/mock_smoothing_filter.h \ + webrtc_dsp/common_audio/wav_file.h \ + webrtc_dsp/common_audio/sparse_fir_filter.h \ + webrtc_dsp/common_audio/fir_filter_sse.h \ + webrtc_dsp/common_audio/window_generator.h \ + webrtc_dsp/common_audio/ring_buffer.h \ + webrtc_dsp/common_audio/fir_filter.h \ + webrtc_dsp/common_audio/include/audio_util.h \ + webrtc_dsp/common_audio/real_fourier_ooura.h \ + webrtc_dsp/common_audio/smoothing_filter.h \ + webrtc_dsp/common_audio/resampler/sinc_resampler.h \ + webrtc_dsp/common_audio/resampler/include/push_resampler.h \ + webrtc_dsp/common_audio/resampler/include/resampler.h \ + webrtc_dsp/common_audio/resampler/push_sinc_resampler.h \ + webrtc_dsp/common_audio/resampler/sinusoidal_linear_chirp_source.h \ + webrtc_dsp/common_audio/fir_filter_factory.h \ + webrtc_dsp/common_audio/audio_converter.h \ + webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor.h \ + webrtc_dsp/common_audio/third_party/fft4g/fft4g.h \ + webrtc_dsp/common_audio/channel_buffer.h \ + webrtc_dsp/common_audio/real_fourier.h \ + webrtc_dsp/common_audio/fir_filter_neon.h \ + webrtc_dsp/common_audio/fir_filter_c.h \ + webrtc_dsp/common_audio/signal_processing/complex_fft_tables.h \ + webrtc_dsp/common_audio/signal_processing/include/signal_processing_library.h \ + webrtc_dsp/common_audio/signal_processing/include/real_fft.h \ + webrtc_dsp/common_audio/signal_processing/include/spl_inl.h \ + webrtc_dsp/common_audio/signal_processing/include/spl_inl_armv7.h \ + webrtc_dsp/common_audio/signal_processing/dot_product_with_scale.h \ + webrtc_dsp/common_audio/signal_processing/resample_by_2_internal.h \ + webrtc_dsp/common_audio/wav_header.h \ + webrtc_dsp/common_audio/vad/vad_core.h \ + webrtc_dsp/common_audio/vad/include/vad.h \ + webrtc_dsp/common_audio/vad/include/webrtc_vad.h \ + webrtc_dsp/common_audio/vad/vad_gmm.h \ + webrtc_dsp/common_audio/vad/vad_sp.h \ + webrtc_dsp/common_audio/vad/vad_filterbank.h TgVoip.h \ + VoIPController.h Buffers.h BlockingQueue.h PrivateDefines.h \ + CongestionControl.h EchoCanceller.h JitterBuffer.h logging.h \ + threading.h MediaStreamItf.h MessageThread.h NetworkSocket.h \ + OpusDecoder.h OpusEncoder.h PacketReassembler.h \ + VoIPServerConfig.h audio/AudioIO.h audio/AudioInput.h \ + audio/AudioOutput.h audio/Resampler.h \ + os/posix/NetworkSocketPosix.h video/VideoSource.h \ + video/VideoRenderer.h video/ScreamCongestionController.h \ + json11.hpp utils.h os/darwin/AudioInputAudioUnit.h \ + os/darwin/AudioOutputAudioUnit.h os/darwin/AudioUnitIO.h \ + os/darwin/AudioInputAudioUnitOSX.h \ + os/darwin/AudioOutputAudioUnitOSX.h os/darwin/DarwinSpecific.h \ + os/darwin/SampleBufferDisplayLayerRenderer.h \ + os/darwin/TGVVideoRenderer.h os/darwin/TGVVideoSource.h \ + os/darwin/VideoToolboxEncoderSource.h \ + os/linux/AudioInputALSA.h os/linux/AudioOutputALSA.h \ + os/linux/AudioOutputPulse.h os/linux/AudioInputPulse.h \ + os/linux/AudioPulse.h os/linux/PulseFunctions.h \ + audio/AudioIOCallback.h +am__dirstamp = $(am__leading_dot)dirstamp +@TARGET_OS_OSX_TRUE@am__objects_1 = os/darwin/AudioInputAudioUnit.lo \ +@TARGET_OS_OSX_TRUE@ os/darwin/AudioOutputAudioUnit.lo \ +@TARGET_OS_OSX_TRUE@ os/darwin/AudioUnitIO.lo \ +@TARGET_OS_OSX_TRUE@ os/darwin/AudioInputAudioUnitOSX.lo \ +@TARGET_OS_OSX_TRUE@ os/darwin/AudioOutputAudioUnitOSX.lo \ +@TARGET_OS_OSX_TRUE@ os/darwin/DarwinSpecific.lo \ +@TARGET_OS_OSX_TRUE@ os/darwin/SampleBufferDisplayLayerRenderer.lo \ +@TARGET_OS_OSX_TRUE@ os/darwin/TGVVideoRenderer.lo \ +@TARGET_OS_OSX_TRUE@ os/darwin/TGVVideoSource.lo \ +@TARGET_OS_OSX_TRUE@ os/darwin/VideoToolboxEncoderSource.lo +@TARGET_OS_OSX_FALSE@@WITH_ALSA_TRUE@am__objects_2 = os/linux/AudioInputALSA.lo \ +@TARGET_OS_OSX_FALSE@@WITH_ALSA_TRUE@ os/linux/AudioOutputALSA.lo +@TARGET_OS_OSX_FALSE@@WITH_PULSE_TRUE@am__objects_3 = os/linux/AudioOutputPulse.lo \ +@TARGET_OS_OSX_FALSE@@WITH_PULSE_TRUE@ os/linux/AudioInputPulse.lo \ +@TARGET_OS_OSX_FALSE@@WITH_PULSE_TRUE@ os/linux/AudioPulse.lo +@ENABLE_DSP_TRUE@am__objects_4 = ./webrtc_dsp/system_wrappers/source/field_trial.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/system_wrappers/source/metrics.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/system_wrappers/source/cpu_features.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/absl/strings/internal/memutil.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/absl/strings/string_view.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/absl/strings/ascii.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/absl/types/bad_optional_access.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/absl/types/optional.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/absl/base/internal/raw_logging.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/absl/base/internal/throw_delegate.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/race_checker.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/strings/string_builder.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/memory/aligned_malloc.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/timeutils.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/platform_file.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/string_to_number.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/thread_checker_impl.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/stringencode.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/stringutils.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/checks.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/platform_thread.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/logging_webrtc.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/criticalsection.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/platform_thread_types.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/event.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/rtc_base/event_tracer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/third_party/rnnoise/src/rnn_vad_weights.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/third_party/rnnoise/src/kiss_fft.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/api/audio/audio_frame.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/api/audio/echo_canceller3_config.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/api/audio/echo_canceller3_factory.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/third_party/fft/fft.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb16_tables.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_gain_tables.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines_logist.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filterbanks.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/transform.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_filter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode_lpc_swb.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filter_functions.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/decode.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lattice.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/intialize.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_tables.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_gain_swb_tables.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/bandwidth_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_analysis.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines_hist.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/entropy_coding.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac_vad.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/crc.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb12_tables.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/decode_bwe.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/spectrum_ar_model_tables.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_lag_tables.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/rms_level.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/echo_detector/normalized_covariance_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/echo_detector/moving_max.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/echo_detector/circular_buffer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/echo_detector/mean_variance_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/splitting_filter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/gain_control_impl.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/ns/nsx_core.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/ns/noise_suppression_x.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/ns/nsx_core_c.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/ns/ns_core.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/ns/noise_suppression.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/audio_buffer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/typing_detection.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/include/audio_processing_statistics.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/include/audio_generator_factory.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/include/aec_dump.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/include/audio_processing.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/include/config.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/interpolated_gain_curve.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/agc2_common.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/gain_applier.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/adaptive_agc.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/adaptive_digital_gain_applier.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/limiter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/saturation_protector.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features_internal.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/rnn.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search_internal.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/features_extraction.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/fft_util.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/lp_residual.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator_agc.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/vector_float_frame.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/noise_level_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/agc2_testing_common.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/fixed_digital_level_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/fixed_gain_controller.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/vad_with_level.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/limiter_db_gain_curve.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/down_sampler.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/signal_classifier.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/noise_spectrum_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/compute_interpolated_gain_curve.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/biquad_filter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/transient/moving_moments.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/transient/wpd_tree.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/transient/wpd_node.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/transient/transient_suppressor.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/transient/transient_detector.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/low_cut_filter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/level_estimator_impl.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/three_band_filter_bank.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec/echo_cancellation.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec/aec_resampler.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec/aec_core.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/voice_detection_impl.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/echo_cancellation_impl.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/gain_control_for_experimental_agc.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc/agc.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc/loudness_histogram.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc/agc_manager_direct.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc/legacy/analog_agc.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc/legacy/digital_agc.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/agc/utility.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/audio_processing_impl.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/audio_generator/file_audio_generator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/gain_controller2.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/residual_echo_detector.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/noise_suppression_impl.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aecm/aecm_core.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aecm/aecm_core_c.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aecm/echo_control_mobile.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/render_reverb_model.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/reverb_model_fallback.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/echo_remover_metrics.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/matched_filter_lag_aggregator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer2.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/echo_path_variability.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/frame_blocker.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/subtractor.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/aec3_fft.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/fullband_erle_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/suppression_filter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/block_processor.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/subband_erle_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller_metrics.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/vector_buffer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/erl_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/aec_state.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/adaptive_fir_filter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/skew_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/echo_path_delay_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/block_framer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/erle_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/reverb_model.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/cascaded_biquad_filter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/render_buffer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/subtractor_output.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/stationarity_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/render_signal_analyzer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/subtractor_output_analyzer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/suppression_gain.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/echo_audibility.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/block_processor_metrics.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/moving_average.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/reverb_model_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/aec3_common.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/residual_echo_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/matched_filter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/reverb_decay_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller2.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/suppression_gain_limiter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/main_filter_update_gain.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/echo_remover.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/downsampled_render_buffer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/matrix_buffer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/block_processor2.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/echo_canceller3.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/block_delay_buffer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/fft_buffer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/comfort_noise_generator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/shadow_filter_update_gain.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/filter_analyzer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/reverb_frequency_response.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/aec3/decimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/echo_control_mobile_impl.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/logging/apm_data_dumper.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/vad/voice_activity_detector.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/vad/standalone_vad.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/vad/pitch_internal.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/vad/vad_circular_buffer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/vad/vad_audio_proc.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/vad/pole_zero_filter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/vad/pitch_based_vad.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/vad/gmm.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/utility/ooura_fft.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/utility/delay_estimator_wrapper.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/utility/delay_estimator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/modules/audio_processing/utility/block_mean_calculator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/window_generator.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/channel_buffer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/fir_filter_factory.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/wav_header.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/real_fourier_ooura.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/audio_util.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/fir_filter_sse.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/resampler/push_sinc_resampler.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/resampler/resampler.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/resampler/sinc_resampler_sse.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/resampler/push_resampler.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/resampler/sinc_resampler.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/resampler/sinusoidal_linear_chirp_source.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/wav_file.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/third_party/fft4g/fft4g.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/audio_converter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/real_fourier.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/sparse_fir_filter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/smoothing_filter.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/fir_filter_c.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/ring_buffer.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/complex_fft.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/filter_ma_fast_q12.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/splitting_filter1.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/levinson_durbin.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/dot_product_with_scale.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/auto_corr_to_refl_coef.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/resample_by_2_internal.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/energy.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/sqrt_of_one_minus_x_squared.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/downsample_fast.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/filter_ar_fast_q12.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/spl_init.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/lpc_to_refl_coef.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/cross_correlation.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/division_operations.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/auto_correlation.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/get_scaling_square.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/resample.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/min_max_operations.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/refl_coef_to_lpc.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/filter_ar.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/vector_scaling_operations.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/resample_fractional.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/real_fft.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/ilbc_specific_functions.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/randomization_functions.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/copy_set_operations.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/resample_by_2.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/get_hanning_window.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/resample_48khz.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/spl_inl.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/signal_processing/spl_sqrt.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/vad/vad_sp.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/vad/vad.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/vad/webrtc_vad.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/vad/vad_filterbank.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/vad/vad_core.lo \ +@ENABLE_DSP_TRUE@ ./webrtc_dsp/common_audio/vad/vad_gmm.lo +@ENABLE_DSP_TRUE@@TARGET_OS_OSX_TRUE@am__objects_5 = webrtc_dsp/rtc_base/logging_mac.lo +@ENABLE_DSP_TRUE@@TARGET_CPU_X86_TRUE@am__objects_6 = webrtc_dsp/modules/audio_processing/aec/aec_core_sse2.lo \ +@ENABLE_DSP_TRUE@@TARGET_CPU_X86_TRUE@ webrtc_dsp/modules/audio_processing/utility/ooura_fft_sse2.lo +@ENABLE_AUDIO_CALLBACK_TRUE@@ENABLE_DSP_TRUE@am__objects_7 = audio/AudioIOCallback.lo +@ENABLE_DSP_TRUE@@TARGET_CPU_ARM_TRUE@am__objects_8 = webrtc_dsp/common_audio/signal_processing/complex_bit_reverse_arm.lo \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARM_TRUE@ webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor_arm.lo +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@am__objects_9 = webrtc_dsp/common_audio/signal_processing/cross_correlation_neon.lo \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@ webrtc_dsp/common_audio/signal_processing/downsample_fast_neon.lo \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@ webrtc_dsp/common_audio/signal_processing/min_max_operations_neon.lo \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@ webrtc_dsp/modules/audio_processing/aec/aec_core_neon.lo \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@ webrtc_dsp/modules/audio_processing/aecm/aecm_core_neon.lo \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@ webrtc_dsp/modules/audio_processing/ns/nsx_core_neon.lo \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARMV7_TRUE@@TARGET_CPU_ARM_TRUE@ webrtc_dsp/modules/audio_processing/utility/ooura_fft_neon.lo +@ENABLE_DSP_TRUE@@TARGET_CPU_ARM_FALSE@am__objects_10 = webrtc_dsp/common_audio/signal_processing/complex_bit_reverse.lo \ +@ENABLE_DSP_TRUE@@TARGET_CPU_ARM_FALSE@ webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor.lo +am__objects_11 = +am__objects_12 = TgVoip.lo VoIPController.lo Buffers.lo \ + CongestionControl.lo EchoCanceller.lo JitterBuffer.lo \ + logging.lo MediaStreamItf.lo MessageThread.lo NetworkSocket.lo \ + OpusDecoder.lo OpusEncoder.lo PacketReassembler.lo \ + VoIPGroupController.lo VoIPServerConfig.lo audio/AudioIO.lo \ + audio/AudioInput.lo audio/AudioOutput.lo audio/Resampler.lo \ + os/posix/NetworkSocketPosix.lo video/VideoSource.lo \ + video/VideoRenderer.lo video/VideoPacketSender.lo \ + video/VideoFEC.lo video/ScreamCongestionController.lo \ + json11.lo $(am__objects_1) $(am__objects_2) $(am__objects_3) \ + $(am__objects_4) $(am__objects_5) $(am__objects_6) \ + $(am__objects_7) $(am__objects_8) $(am__objects_9) \ + $(am__objects_10) $(am__objects_11) +am__objects_13 = $(am__objects_11) $(am__objects_11) $(am__objects_11) \ + $(am__objects_11) +am_libtgvoip_la_OBJECTS = $(am__objects_12) $(am__objects_13) +libtgvoip_la_OBJECTS = $(am_libtgvoip_la_OBJECTS) +AM_V_lt = $(am__v_lt_@AM_V@) +am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) +am__v_lt_0 = --silent +am__v_lt_1 = +AM_V_P = $(am__v_P_@AM_V@) +am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) +am__v_P_0 = false +am__v_P_1 = : +AM_V_GEN = $(am__v_GEN_@AM_V@) +am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) +am__v_GEN_0 = @echo " GEN " $@; +am__v_GEN_1 = +AM_V_at = $(am__v_at_@AM_V@) +am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) +am__v_at_0 = @ +am__v_at_1 = +DEFAULT_INCLUDES = -I.@am__isrc@ +depcomp = $(SHELL) $(top_srcdir)/depcomp +am__maybe_remake_depfiles = depfiles +am__depfiles_remade = ./$(DEPDIR)/Buffers.Plo \ + ./$(DEPDIR)/CongestionControl.Plo \ + ./$(DEPDIR)/EchoCanceller.Plo ./$(DEPDIR)/JitterBuffer.Plo \ + ./$(DEPDIR)/MediaStreamItf.Plo ./$(DEPDIR)/MessageThread.Plo \ + ./$(DEPDIR)/NetworkSocket.Plo ./$(DEPDIR)/OpusDecoder.Plo \ + ./$(DEPDIR)/OpusEncoder.Plo ./$(DEPDIR)/PacketReassembler.Plo \ + ./$(DEPDIR)/TgVoip.Plo ./$(DEPDIR)/VoIPController.Plo \ + ./$(DEPDIR)/VoIPGroupController.Plo \ + ./$(DEPDIR)/VoIPServerConfig.Plo ./$(DEPDIR)/json11.Plo \ + ./$(DEPDIR)/logging.Plo \ + ./webrtc_dsp/absl/base/internal/$(DEPDIR)/raw_logging.Plo \ + ./webrtc_dsp/absl/base/internal/$(DEPDIR)/throw_delegate.Plo \ + ./webrtc_dsp/absl/strings/$(DEPDIR)/ascii.Plo \ + ./webrtc_dsp/absl/strings/$(DEPDIR)/string_view.Plo \ + ./webrtc_dsp/absl/strings/internal/$(DEPDIR)/memutil.Plo \ + ./webrtc_dsp/absl/types/$(DEPDIR)/bad_optional_access.Plo \ + ./webrtc_dsp/absl/types/$(DEPDIR)/optional.Plo \ + ./webrtc_dsp/api/audio/$(DEPDIR)/audio_frame.Plo \ + ./webrtc_dsp/api/audio/$(DEPDIR)/echo_canceller3_config.Plo \ + ./webrtc_dsp/api/audio/$(DEPDIR)/echo_canceller3_factory.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/audio_converter.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/audio_util.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/channel_buffer.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/fir_filter_c.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/fir_filter_factory.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/fir_filter_sse.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/real_fourier.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/real_fourier_ooura.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/ring_buffer.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/smoothing_filter.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/sparse_fir_filter.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/wav_file.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/wav_header.Plo \ + ./webrtc_dsp/common_audio/$(DEPDIR)/window_generator.Plo \ + ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/push_resampler.Plo \ + ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/push_sinc_resampler.Plo \ + ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/resampler.Plo \ + ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/sinc_resampler.Plo \ + ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/sinc_resampler_sse.Plo \ + ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/sinusoidal_linear_chirp_source.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/auto_corr_to_refl_coef.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/auto_correlation.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/complex_fft.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/copy_set_operations.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/cross_correlation.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/division_operations.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/dot_product_with_scale.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/downsample_fast.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/energy.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/filter_ar.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/filter_ar_fast_q12.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/filter_ma_fast_q12.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/get_hanning_window.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/get_scaling_square.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/ilbc_specific_functions.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/levinson_durbin.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/lpc_to_refl_coef.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/min_max_operations.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/randomization_functions.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/real_fft.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/refl_coef_to_lpc.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_48khz.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_by_2.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_by_2_internal.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_fractional.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/spl_init.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/spl_inl.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/spl_sqrt.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/splitting_filter1.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/sqrt_of_one_minus_x_squared.Plo \ + ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/vector_scaling_operations.Plo \ + ./webrtc_dsp/common_audio/third_party/fft4g/$(DEPDIR)/fft4g.Plo \ + ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad.Plo \ + ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_core.Plo \ + ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_filterbank.Plo \ + ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_gmm.Plo \ + ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_sp.Plo \ + ./webrtc_dsp/common_audio/vad/$(DEPDIR)/webrtc_vad.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/arith_routines.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/arith_routines_hist.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/arith_routines_logist.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/bandwidth_estimator.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/crc.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/decode.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/decode_bwe.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/encode.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/encode_lpc_swb.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/entropy_coding.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/filter_functions.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/filterbanks.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/intialize.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/isac.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/isac_vad.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lattice.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_analysis.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_gain_swb_tables.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_shape_swb12_tables.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_shape_swb16_tables.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_tables.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_estimator.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_filter.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_gain_tables.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_lag_tables.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/spectrum_ar_model_tables.Plo \ + ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/transform.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/audio_buffer.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/audio_processing_impl.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/echo_cancellation_impl.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/echo_control_mobile_impl.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/gain_control_for_experimental_agc.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/gain_control_impl.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/gain_controller2.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/level_estimator_impl.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/low_cut_filter.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/noise_suppression_impl.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/residual_echo_detector.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/rms_level.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/splitting_filter.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/three_band_filter_bank.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/typing_detection.Plo \ + ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/voice_detection_impl.Plo \ + ./webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_core.Plo \ + ./webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_resampler.Plo \ + ./webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/echo_cancellation.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/adaptive_fir_filter.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/aec3_common.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/aec3_fft.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/aec_state.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_delay_buffer.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_framer.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_processor.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_processor2.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_processor_metrics.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/cascaded_biquad_filter.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/comfort_noise_generator.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/decimator.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/downsampled_render_buffer.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_audibility.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_canceller3.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_path_delay_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_path_variability.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_remover.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_remover_metrics.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/erl_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/erle_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/fft_buffer.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/filter_analyzer.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/frame_blocker.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/fullband_erle_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/main_filter_update_gain.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/matched_filter.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/matched_filter_lag_aggregator.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/matrix_buffer.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/moving_average.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_buffer.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_buffer.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_buffer2.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_controller.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_controller2.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_controller_metrics.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_reverb_model.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_signal_analyzer.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/residual_echo_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_decay_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_frequency_response.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_model.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_model_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_model_fallback.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/shadow_filter_update_gain.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/skew_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/stationarity_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subband_erle_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subtractor.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subtractor_output.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subtractor_output_analyzer.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/suppression_filter.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/suppression_gain.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/suppression_gain_limiter.Plo \ + ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/vector_buffer.Plo \ + ./webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/aecm_core.Plo \ + ./webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/aecm_core_c.Plo \ + ./webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/echo_control_mobile.Plo \ + ./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/agc.Plo \ + ./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/agc_manager_direct.Plo \ + ./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/loudness_histogram.Plo \ + ./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/utility.Plo \ + ./webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR)/analog_agc.Plo \ + ./webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR)/digital_agc.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_agc.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_digital_gain_applier.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_mode_level_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_mode_level_estimator_agc.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/agc2_common.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/agc2_testing_common.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/biquad_filter.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/compute_interpolated_gain_curve.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/down_sampler.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/fixed_digital_level_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/fixed_gain_controller.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/gain_applier.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/interpolated_gain_curve.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/limiter.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/limiter_db_gain_curve.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/noise_level_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/noise_spectrum_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/saturation_protector.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/signal_classifier.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/vad_with_level.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/vector_float_frame.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/features_extraction.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/fft_util.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/lp_residual.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/pitch_search.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/pitch_search_internal.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/rnn.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/spectral_features.Plo \ + ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/spectral_features_internal.Plo \ + ./webrtc_dsp/modules/audio_processing/audio_generator/$(DEPDIR)/file_audio_generator.Plo \ + ./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/circular_buffer.Plo \ + ./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/mean_variance_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/moving_max.Plo \ + ./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/normalized_covariance_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/aec_dump.Plo \ + ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/audio_generator_factory.Plo \ + ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/audio_processing.Plo \ + ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/audio_processing_statistics.Plo \ + ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/config.Plo \ + ./webrtc_dsp/modules/audio_processing/logging/$(DEPDIR)/apm_data_dumper.Plo \ + ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/noise_suppression.Plo \ + ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/noise_suppression_x.Plo \ + ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/ns_core.Plo \ + ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/nsx_core.Plo \ + ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/nsx_core_c.Plo \ + ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/moving_moments.Plo \ + ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/transient_detector.Plo \ + ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/transient_suppressor.Plo \ + ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/wpd_node.Plo \ + ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/wpd_tree.Plo \ + ./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/block_mean_calculator.Plo \ + ./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/delay_estimator.Plo \ + ./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/delay_estimator_wrapper.Plo \ + ./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/ooura_fft.Plo \ + ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/gmm.Plo \ + ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/pitch_based_vad.Plo \ + ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/pitch_internal.Plo \ + ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/pole_zero_filter.Plo \ + ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/standalone_vad.Plo \ + ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/vad_audio_proc.Plo \ + ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/vad_circular_buffer.Plo \ + ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/voice_activity_detector.Plo \ + ./webrtc_dsp/modules/third_party/fft/$(DEPDIR)/fft.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/checks.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/criticalsection.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/event.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/event_tracer.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/logging_webrtc.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/platform_file.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/platform_thread.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/platform_thread_types.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/race_checker.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/string_to_number.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/stringencode.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/stringutils.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/thread_checker_impl.Plo \ + ./webrtc_dsp/rtc_base/$(DEPDIR)/timeutils.Plo \ + ./webrtc_dsp/rtc_base/memory/$(DEPDIR)/aligned_malloc.Plo \ + ./webrtc_dsp/rtc_base/strings/$(DEPDIR)/string_builder.Plo \ + ./webrtc_dsp/system_wrappers/source/$(DEPDIR)/cpu_features.Plo \ + ./webrtc_dsp/system_wrappers/source/$(DEPDIR)/field_trial.Plo \ + ./webrtc_dsp/system_wrappers/source/$(DEPDIR)/metrics.Plo \ + ./webrtc_dsp/third_party/rnnoise/src/$(DEPDIR)/kiss_fft.Plo \ + ./webrtc_dsp/third_party/rnnoise/src/$(DEPDIR)/rnn_vad_weights.Plo \ + audio/$(DEPDIR)/AudioIO.Plo \ + audio/$(DEPDIR)/AudioIOCallback.Plo \ + audio/$(DEPDIR)/AudioInput.Plo audio/$(DEPDIR)/AudioOutput.Plo \ + audio/$(DEPDIR)/Resampler.Plo \ + os/darwin/$(DEPDIR)/AudioInputAudioUnit.Plo \ + os/darwin/$(DEPDIR)/AudioInputAudioUnitOSX.Plo \ + os/darwin/$(DEPDIR)/AudioOutputAudioUnit.Plo \ + os/darwin/$(DEPDIR)/AudioOutputAudioUnitOSX.Plo \ + os/darwin/$(DEPDIR)/AudioUnitIO.Plo \ + os/darwin/$(DEPDIR)/DarwinSpecific.Plo \ + os/darwin/$(DEPDIR)/SampleBufferDisplayLayerRenderer.Plo \ + os/darwin/$(DEPDIR)/TGVVideoRenderer.Plo \ + os/darwin/$(DEPDIR)/TGVVideoSource.Plo \ + os/darwin/$(DEPDIR)/VideoToolboxEncoderSource.Plo \ + os/linux/$(DEPDIR)/AudioInputALSA.Plo \ + os/linux/$(DEPDIR)/AudioInputPulse.Plo \ + os/linux/$(DEPDIR)/AudioOutputALSA.Plo \ + os/linux/$(DEPDIR)/AudioOutputPulse.Plo \ + os/linux/$(DEPDIR)/AudioPulse.Plo \ + os/posix/$(DEPDIR)/NetworkSocketPosix.Plo \ + video/$(DEPDIR)/ScreamCongestionController.Plo \ + video/$(DEPDIR)/VideoFEC.Plo \ + video/$(DEPDIR)/VideoPacketSender.Plo \ + video/$(DEPDIR)/VideoRenderer.Plo \ + video/$(DEPDIR)/VideoSource.Plo \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/complex_bit_reverse.Plo \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/complex_bit_reverse_arm.Plo \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/cross_correlation_neon.Plo \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/downsample_fast_neon.Plo \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/min_max_operations_neon.Plo \ + webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR)/spl_sqrt_floor.Plo \ + webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR)/spl_sqrt_floor_arm.Plo \ + webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_core_neon.Plo \ + webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_core_sse2.Plo \ + webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/aecm_core_neon.Plo \ + webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/nsx_core_neon.Plo \ + webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/ooura_fft_neon.Plo \ + webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/ooura_fft_sse2.Plo \ + webrtc_dsp/rtc_base/$(DEPDIR)/logging_mac.Plo +am__mv = mv -f +CPPASCOMPILE = $(CCAS) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ + $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CCASFLAGS) $(CCASFLAGS) +LTCPPASCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ + $(LIBTOOLFLAGS) --mode=compile $(CCAS) $(DEFS) \ + $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ + $(AM_CCASFLAGS) $(CCASFLAGS) +AM_V_CPPAS = $(am__v_CPPAS_@AM_V@) +am__v_CPPAS_ = $(am__v_CPPAS_@AM_DEFAULT_V@) +am__v_CPPAS_0 = @echo " CPPAS " $@; +am__v_CPPAS_1 = +COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ + $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) +LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ + $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ + $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ + $(AM_CFLAGS) $(CFLAGS) +AM_V_CC = $(am__v_CC_@AM_V@) +am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) +am__v_CC_0 = @echo " CC " $@; +am__v_CC_1 = +CCLD = $(CC) +LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ + $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ + $(AM_LDFLAGS) $(LDFLAGS) -o $@ +AM_V_CCLD = $(am__v_CCLD_@AM_V@) +am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) +am__v_CCLD_0 = @echo " CCLD " $@; +am__v_CCLD_1 = +CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ + $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) +LTCXXCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CXX $(AM_LIBTOOLFLAGS) \ + $(LIBTOOLFLAGS) --mode=compile $(CXX) $(DEFS) \ + $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ + $(AM_CXXFLAGS) $(CXXFLAGS) +AM_V_CXX = $(am__v_CXX_@AM_V@) +am__v_CXX_ = $(am__v_CXX_@AM_DEFAULT_V@) +am__v_CXX_0 = @echo " CXX " $@; +am__v_CXX_1 = +CXXLD = $(CXX) +CXXLINK = $(LIBTOOL) $(AM_V_lt) --tag=CXX $(AM_LIBTOOLFLAGS) \ + $(LIBTOOLFLAGS) --mode=link $(CXXLD) $(AM_CXXFLAGS) \ + $(CXXFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@ +AM_V_CXXLD = $(am__v_CXXLD_@AM_V@) +am__v_CXXLD_ = $(am__v_CXXLD_@AM_DEFAULT_V@) +am__v_CXXLD_0 = @echo " CXXLD " $@; +am__v_CXXLD_1 = +OBJCXXCOMPILE = $(OBJCXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ + $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_OBJCXXFLAGS) $(OBJCXXFLAGS) +LTOBJCXXCOMPILE = $(LIBTOOL) $(AM_V_lt) $(AM_LIBTOOLFLAGS) \ + $(LIBTOOLFLAGS) --mode=compile $(OBJCXX) $(DEFS) \ + $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ + $(AM_OBJCXXFLAGS) $(OBJCXXFLAGS) +AM_V_OBJCXX = $(am__v_OBJCXX_@AM_V@) +am__v_OBJCXX_ = $(am__v_OBJCXX_@AM_DEFAULT_V@) +am__v_OBJCXX_0 = @echo " OBJCXX " $@; +am__v_OBJCXX_1 = +OBJCXXLD = $(OBJCXX) +OBJCXXLINK = $(LIBTOOL) $(AM_V_lt) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) \ + --mode=link $(OBJCXXLD) $(AM_OBJCXXFLAGS) $(OBJCXXFLAGS) \ + $(AM_LDFLAGS) $(LDFLAGS) -o $@ +AM_V_OBJCXXLD = $(am__v_OBJCXXLD_@AM_V@) +am__v_OBJCXXLD_ = $(am__v_OBJCXXLD_@AM_DEFAULT_V@) +am__v_OBJCXXLD_0 = @echo " OBJCXXLD" $@; +am__v_OBJCXXLD_1 = +SOURCES = $(libtgvoip_la_SOURCES) +DIST_SOURCES = $(am__libtgvoip_la_SOURCES_DIST) +am__can_run_installinfo = \ + case $$AM_UPDATE_INFO_DIR in \ + n|no|NO) false;; \ + *) (install-info --version) >/dev/null 2>&1;; \ + esac +am__nobase_tgvoipinclude_HEADERS_DIST = TgVoip.h VoIPController.h \ + Buffers.h BlockingQueue.h PrivateDefines.h CongestionControl.h \ + EchoCanceller.h JitterBuffer.h logging.h threading.h \ + MediaStreamItf.h MessageThread.h NetworkSocket.h OpusDecoder.h \ + OpusEncoder.h PacketReassembler.h VoIPServerConfig.h \ + audio/AudioIO.h audio/AudioInput.h audio/AudioOutput.h \ + audio/Resampler.h os/posix/NetworkSocketPosix.h \ + video/VideoSource.h video/VideoPacketSender.h video/VideoFEC.h \ + video/VideoRenderer.h video/ScreamCongestionController.h \ + json11.hpp utils.h os/darwin/AudioInputAudioUnit.h \ + os/darwin/AudioOutputAudioUnit.h os/darwin/AudioUnitIO.h \ + os/darwin/AudioInputAudioUnitOSX.h \ + os/darwin/AudioOutputAudioUnitOSX.h os/darwin/DarwinSpecific.h \ + os/darwin/SampleBufferDisplayLayerRenderer.h \ + os/darwin/TGVVideoRenderer.h os/darwin/TGVVideoSource.h \ + os/darwin/VideoToolboxEncoderSource.h \ + os/linux/AudioInputALSA.h os/linux/AudioOutputALSA.h \ + os/linux/AudioOutputPulse.h os/linux/AudioInputPulse.h \ + os/linux/AudioPulse.h os/linux/PulseFunctions.h \ + audio/AudioIOCallback.h +HEADERS = $(nobase_tgvoipinclude_HEADERS) +am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) \ + $(LISP)config.h.in +# Read a list of newline-separated strings from the standard input, +# and print each of them once, without duplicates. Input order is +# *not* preserved. +am__uniquify_input = $(AWK) '\ + BEGIN { nonempty = 0; } \ + { items[$$0] = 1; nonempty = 1; } \ + END { if (nonempty) { for (i in items) print i; }; } \ +' +# Make sure the list of sources is unique. This is necessary because, +# e.g., the same source file might be shared among _SOURCES variables +# for different programs/libraries. +am__define_uniq_tagged_files = \ + list='$(am__tagged_files)'; \ + unique=`for i in $$list; do \ + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ + done | $(am__uniquify_input)` +ETAGS = etags +CTAGS = ctags +CSCOPE = cscope +AM_RECURSIVE_TARGETS = cscope +am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/config.h.in compile \ + config.guess config.sub depcomp install-sh ltmain.sh missing +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) +distdir = $(PACKAGE)-$(VERSION) +top_distdir = $(distdir) +am__remove_distdir = \ + if test -d "$(distdir)"; then \ + find "$(distdir)" -type d ! -perm -200 -exec chmod u+w {} ';' \ + && rm -rf "$(distdir)" \ + || { sleep 5 && rm -rf "$(distdir)"; }; \ + else :; fi +am__post_remove_distdir = $(am__remove_distdir) +DIST_ARCHIVES = $(distdir).tar.gz +GZIP_ENV = --best +DIST_TARGETS = dist-gzip +distuninstallcheck_listfiles = find . -type f -print +am__distuninstallcheck_listfiles = $(distuninstallcheck_listfiles) \ + | sed 's|^\./|$(prefix)/|' | grep -v '$(infodir)/dir$$' +distcleancheck_listfiles = find . -type f -print +ACLOCAL = @ACLOCAL@ +ALLOCA = @ALLOCA@ +AMTAR = @AMTAR@ +AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ +AR = @AR@ +AUTOCONF = @AUTOCONF@ +AUTOHEADER = @AUTOHEADER@ +AUTOMAKE = @AUTOMAKE@ +AWK = @AWK@ +CC = @CC@ +CCAS = @CCAS@ +CCASDEPMODE = @CCASDEPMODE@ +CCASFLAGS = @CCASFLAGS@ $(am__append_9) $(am__append_20) +CCDEPMODE = @CCDEPMODE@ +CFLAGS = -Wall -DHAVE_CONFIG_H -Wno-unknown-pragmas $(am__append_8) \ + $(am__append_11) $(am__append_13) $(am__append_15) \ + $(am__append_19) $(am__append_24) +CPP = @CPP@ +CPPFLAGS = @CPPFLAGS@ +CXX = @CXX@ +CXXCPP = @CXXCPP@ +CXXDEPMODE = @CXXDEPMODE@ +CXXFLAGS = @CXXFLAGS@ -std=gnu++0x $(CFLAGS) +CYGPATH_W = @CYGPATH_W@ +DEFS = @DEFS@ +DEPDIR = @DEPDIR@ +DLLTOOL = @DLLTOOL@ +DSYMUTIL = @DSYMUTIL@ +DUMPBIN = @DUMPBIN@ +ECHO_C = @ECHO_C@ +ECHO_N = @ECHO_N@ +ECHO_T = @ECHO_T@ +EGREP = @EGREP@ +EXEEXT = @EXEEXT@ +FGREP = @FGREP@ +GREP = @GREP@ +INSTALL = @INSTALL@ +INSTALL_DATA = @INSTALL_DATA@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ +INSTALL_SCRIPT = @INSTALL_SCRIPT@ +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ +LD = @LD@ +LDFLAGS = @LDFLAGS@ $(am__append_3) +LIBOBJS = @LIBOBJS@ +LIBS = @LIBS@ +LIBTOOL = @LIBTOOL@ +LIPO = @LIPO@ +LN_S = @LN_S@ +LTLIBOBJS = @LTLIBOBJS@ +LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ +MAKEINFO = @MAKEINFO@ +MANIFEST_TOOL = @MANIFEST_TOOL@ +MKDIR_P = @MKDIR_P@ +NM = @NM@ +NMEDIT = @NMEDIT@ +OBJCXX = @OBJCXX@ +OBJCXXDEPMODE = @OBJCXXDEPMODE@ +OBJCXXFLAGS = @OBJCXXFLAGS@ $(am__append_25) +OBJDUMP = @OBJDUMP@ +OBJEXT = @OBJEXT@ +OTOOL = @OTOOL@ +OTOOL64 = @OTOOL64@ +PACKAGE = @PACKAGE@ +PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ +PACKAGE_NAME = @PACKAGE_NAME@ +PACKAGE_STRING = @PACKAGE_STRING@ +PACKAGE_TARNAME = @PACKAGE_TARNAME@ +PACKAGE_URL = @PACKAGE_URL@ +PACKAGE_VERSION = @PACKAGE_VERSION@ +PATH_SEPARATOR = @PATH_SEPARATOR@ +RANLIB = @RANLIB@ +SED = @SED@ +SET_MAKE = @SET_MAKE@ +SHELL = @SHELL@ +STRIP = @STRIP@ +VERSION = @VERSION@ +abs_builddir = @abs_builddir@ +abs_srcdir = @abs_srcdir@ +abs_top_builddir = @abs_top_builddir@ +abs_top_srcdir = @abs_top_srcdir@ +ac_ct_AR = @ac_ct_AR@ +ac_ct_CC = @ac_ct_CC@ +ac_ct_CXX = @ac_ct_CXX@ +ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ +ac_ct_OBJCXX = @ac_ct_OBJCXX@ +am__include = @am__include@ +am__leading_dot = @am__leading_dot@ +am__quote = @am__quote@ +am__tar = @am__tar@ +am__untar = @am__untar@ +bindir = @bindir@ +build = @build@ +build_alias = @build_alias@ +build_cpu = @build_cpu@ +build_os = @build_os@ +build_vendor = @build_vendor@ +builddir = @builddir@ +datadir = @datadir@ +datarootdir = @datarootdir@ +docdir = @docdir@ +dvidir = @dvidir@ +exec_prefix = @exec_prefix@ +host = @host@ +host_alias = @host_alias@ +host_cpu = @host_cpu@ +host_os = @host_os@ +host_vendor = @host_vendor@ +htmldir = @htmldir@ +includedir = @includedir@ +infodir = @infodir@ +install_sh = @install_sh@ +libdir = @libdir@ +libexecdir = @libexecdir@ +localedir = @localedir@ +localstatedir = @localstatedir@ +mandir = @mandir@ +mkdir_p = @mkdir_p@ +oldincludedir = @oldincludedir@ +pdfdir = @pdfdir@ +prefix = @prefix@ +program_transform_name = @program_transform_name@ +psdir = @psdir@ +sbindir = @sbindir@ +sharedstatedir = @sharedstatedir@ +srcdir = @srcdir@ +sysconfdir = @sysconfdir@ +target_alias = @target_alias@ +top_build_prefix = @top_build_prefix@ +top_builddir = @top_builddir@ +top_srcdir = @top_srcdir@ +AUTOMAKE_OPTIONS = foreign +lib_LTLIBRARIES = libtgvoip.la +SRC = TgVoip.cpp VoIPController.cpp Buffers.cpp CongestionControl.cpp \ + EchoCanceller.cpp JitterBuffer.cpp logging.cpp \ + MediaStreamItf.cpp MessageThread.cpp NetworkSocket.cpp \ + OpusDecoder.cpp OpusEncoder.cpp PacketReassembler.cpp \ + VoIPGroupController.cpp VoIPServerConfig.cpp audio/AudioIO.cpp \ + audio/AudioInput.cpp audio/AudioOutput.cpp audio/Resampler.cpp \ + os/posix/NetworkSocketPosix.cpp video/VideoSource.cpp \ + video/VideoRenderer.cpp video/VideoPacketSender.cpp \ + video/VideoFEC.cpp video/ScreamCongestionController.cpp \ + json11.cpp $(am__append_1) $(am__append_4) $(am__append_6) \ + $(am__append_10) $(am__append_12) $(am__append_14) \ + $(am__append_16) $(am__append_18) $(am__append_21) \ + $(am__append_22) $(am__append_23) +TGVOIP_HDRS = TgVoip.h VoIPController.h Buffers.h BlockingQueue.h \ + PrivateDefines.h CongestionControl.h EchoCanceller.h \ + JitterBuffer.h logging.h threading.h MediaStreamItf.h \ + MessageThread.h NetworkSocket.h OpusDecoder.h OpusEncoder.h \ + PacketReassembler.h VoIPServerConfig.h audio/AudioIO.h \ + audio/AudioInput.h audio/AudioOutput.h audio/Resampler.h \ + os/posix/NetworkSocketPosix.h video/VideoSource.h \ + video/VideoPacketSender.h video/VideoFEC.h \ + video/VideoRenderer.h video/ScreamCongestionController.h \ + json11.hpp utils.h $(am__append_2) $(am__append_5) \ + $(am__append_7) $(am__append_17) +libtgvoip_la_SOURCES = $(SRC) $(TGVOIP_HDRS) +tgvoipincludedir = $(includedir)/tgvoip +nobase_tgvoipinclude_HEADERS = $(TGVOIP_HDRS) +@TARGET_OS_OSX_TRUE@OBJCFLAGS = $(CFLAGS) +all: config.h + $(MAKE) $(AM_MAKEFLAGS) all-am + +.SUFFIXES: +.SUFFIXES: .S .c .cc .cpp .lo .mm .o .obj +am--refresh: Makefile + @: +$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) + @for dep in $?; do \ + case '$(am__configure_deps)' in \ + *$$dep*) \ + echo ' cd $(srcdir) && $(AUTOMAKE) --foreign'; \ + $(am__cd) $(srcdir) && $(AUTOMAKE) --foreign \ + && exit 0; \ + exit 1;; \ + esac; \ + done; \ + echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign Makefile'; \ + $(am__cd) $(top_srcdir) && \ + $(AUTOMAKE) --foreign Makefile +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status + @case '$?' in \ + *config.status*) \ + echo ' $(SHELL) ./config.status'; \ + $(SHELL) ./config.status;; \ + *) \ + echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles)'; \ + cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles);; \ + esac; + +$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) + $(SHELL) ./config.status --recheck + +$(top_srcdir)/configure: $(am__configure_deps) + $(am__cd) $(srcdir) && $(AUTOCONF) +$(ACLOCAL_M4): $(am__aclocal_m4_deps) + $(am__cd) $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS) +$(am__aclocal_m4_deps): + +config.h: stamp-h1 + @test -f $@ || rm -f stamp-h1 + @test -f $@ || $(MAKE) $(AM_MAKEFLAGS) stamp-h1 + +stamp-h1: $(srcdir)/config.h.in $(top_builddir)/config.status + @rm -f stamp-h1 + cd $(top_builddir) && $(SHELL) ./config.status config.h +$(srcdir)/config.h.in: $(am__configure_deps) + ($(am__cd) $(top_srcdir) && $(AUTOHEADER)) + rm -f stamp-h1 + touch $@ + +distclean-hdr: + -rm -f config.h stamp-h1 + +install-libLTLIBRARIES: $(lib_LTLIBRARIES) + @$(NORMAL_INSTALL) + @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ + list2=; for p in $$list; do \ + if test -f $$p; then \ + list2="$$list2 $$p"; \ + else :; fi; \ + done; \ + test -z "$$list2" || { \ + echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \ + $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \ + echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \ + $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \ + } + +uninstall-libLTLIBRARIES: + @$(NORMAL_UNINSTALL) + @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ + for p in $$list; do \ + $(am__strip_dir) \ + echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \ + $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \ + done + +clean-libLTLIBRARIES: + -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) + @list='$(lib_LTLIBRARIES)'; \ + locs=`for p in $$list; do echo $$p; done | \ + sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ + sort -u`; \ + test -z "$$locs" || { \ + echo rm -f $${locs}; \ + rm -f $${locs}; \ + } +audio/$(am__dirstamp): + @$(MKDIR_P) audio + @: > audio/$(am__dirstamp) +audio/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) audio/$(DEPDIR) + @: > audio/$(DEPDIR)/$(am__dirstamp) +audio/AudioIO.lo: audio/$(am__dirstamp) \ + audio/$(DEPDIR)/$(am__dirstamp) +audio/AudioInput.lo: audio/$(am__dirstamp) \ + audio/$(DEPDIR)/$(am__dirstamp) +audio/AudioOutput.lo: audio/$(am__dirstamp) \ + audio/$(DEPDIR)/$(am__dirstamp) +audio/Resampler.lo: audio/$(am__dirstamp) \ + audio/$(DEPDIR)/$(am__dirstamp) +os/posix/$(am__dirstamp): + @$(MKDIR_P) os/posix + @: > os/posix/$(am__dirstamp) +os/posix/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) os/posix/$(DEPDIR) + @: > os/posix/$(DEPDIR)/$(am__dirstamp) +os/posix/NetworkSocketPosix.lo: os/posix/$(am__dirstamp) \ + os/posix/$(DEPDIR)/$(am__dirstamp) +video/$(am__dirstamp): + @$(MKDIR_P) video + @: > video/$(am__dirstamp) +video/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) video/$(DEPDIR) + @: > video/$(DEPDIR)/$(am__dirstamp) +video/VideoSource.lo: video/$(am__dirstamp) \ + video/$(DEPDIR)/$(am__dirstamp) +video/VideoRenderer.lo: video/$(am__dirstamp) \ + video/$(DEPDIR)/$(am__dirstamp) +video/VideoPacketSender.lo: video/$(am__dirstamp) \ + video/$(DEPDIR)/$(am__dirstamp) +video/VideoFEC.lo: video/$(am__dirstamp) \ + video/$(DEPDIR)/$(am__dirstamp) +video/ScreamCongestionController.lo: video/$(am__dirstamp) \ + video/$(DEPDIR)/$(am__dirstamp) +os/darwin/$(am__dirstamp): + @$(MKDIR_P) os/darwin + @: > os/darwin/$(am__dirstamp) +os/darwin/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) os/darwin/$(DEPDIR) + @: > os/darwin/$(DEPDIR)/$(am__dirstamp) +os/darwin/AudioInputAudioUnit.lo: os/darwin/$(am__dirstamp) \ + os/darwin/$(DEPDIR)/$(am__dirstamp) +os/darwin/AudioOutputAudioUnit.lo: os/darwin/$(am__dirstamp) \ + os/darwin/$(DEPDIR)/$(am__dirstamp) +os/darwin/AudioUnitIO.lo: os/darwin/$(am__dirstamp) \ + os/darwin/$(DEPDIR)/$(am__dirstamp) +os/darwin/AudioInputAudioUnitOSX.lo: os/darwin/$(am__dirstamp) \ + os/darwin/$(DEPDIR)/$(am__dirstamp) +os/darwin/AudioOutputAudioUnitOSX.lo: os/darwin/$(am__dirstamp) \ + os/darwin/$(DEPDIR)/$(am__dirstamp) +os/darwin/DarwinSpecific.lo: os/darwin/$(am__dirstamp) \ + os/darwin/$(DEPDIR)/$(am__dirstamp) +os/darwin/SampleBufferDisplayLayerRenderer.lo: \ + os/darwin/$(am__dirstamp) os/darwin/$(DEPDIR)/$(am__dirstamp) +os/darwin/TGVVideoRenderer.lo: os/darwin/$(am__dirstamp) \ + os/darwin/$(DEPDIR)/$(am__dirstamp) +os/darwin/TGVVideoSource.lo: os/darwin/$(am__dirstamp) \ + os/darwin/$(DEPDIR)/$(am__dirstamp) +os/darwin/VideoToolboxEncoderSource.lo: os/darwin/$(am__dirstamp) \ + os/darwin/$(DEPDIR)/$(am__dirstamp) +os/linux/$(am__dirstamp): + @$(MKDIR_P) os/linux + @: > os/linux/$(am__dirstamp) +os/linux/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) os/linux/$(DEPDIR) + @: > os/linux/$(DEPDIR)/$(am__dirstamp) +os/linux/AudioInputALSA.lo: os/linux/$(am__dirstamp) \ + os/linux/$(DEPDIR)/$(am__dirstamp) +os/linux/AudioOutputALSA.lo: os/linux/$(am__dirstamp) \ + os/linux/$(DEPDIR)/$(am__dirstamp) +os/linux/AudioOutputPulse.lo: os/linux/$(am__dirstamp) \ + os/linux/$(DEPDIR)/$(am__dirstamp) +os/linux/AudioInputPulse.lo: os/linux/$(am__dirstamp) \ + os/linux/$(DEPDIR)/$(am__dirstamp) +os/linux/AudioPulse.lo: os/linux/$(am__dirstamp) \ + os/linux/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/system_wrappers/source/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/system_wrappers/source + @: > webrtc_dsp/system_wrappers/source/$(am__dirstamp) +webrtc_dsp/system_wrappers/source/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/system_wrappers/source/$(DEPDIR) + @: > webrtc_dsp/system_wrappers/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/system_wrappers/source/field_trial.lo: \ + webrtc_dsp/system_wrappers/source/$(am__dirstamp) \ + webrtc_dsp/system_wrappers/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/system_wrappers/source/metrics.lo: \ + webrtc_dsp/system_wrappers/source/$(am__dirstamp) \ + webrtc_dsp/system_wrappers/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/system_wrappers/source/cpu_features.lo: \ + webrtc_dsp/system_wrappers/source/$(am__dirstamp) \ + webrtc_dsp/system_wrappers/source/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/absl/strings/internal/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/absl/strings/internal + @: > webrtc_dsp/absl/strings/internal/$(am__dirstamp) +webrtc_dsp/absl/strings/internal/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/absl/strings/internal/$(DEPDIR) + @: > webrtc_dsp/absl/strings/internal/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/absl/strings/internal/memutil.lo: \ + webrtc_dsp/absl/strings/internal/$(am__dirstamp) \ + webrtc_dsp/absl/strings/internal/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/absl/strings/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/absl/strings + @: > webrtc_dsp/absl/strings/$(am__dirstamp) +webrtc_dsp/absl/strings/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/absl/strings/$(DEPDIR) + @: > webrtc_dsp/absl/strings/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/absl/strings/string_view.lo: \ + webrtc_dsp/absl/strings/$(am__dirstamp) \ + webrtc_dsp/absl/strings/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/absl/strings/ascii.lo: \ + webrtc_dsp/absl/strings/$(am__dirstamp) \ + webrtc_dsp/absl/strings/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/absl/types/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/absl/types + @: > webrtc_dsp/absl/types/$(am__dirstamp) +webrtc_dsp/absl/types/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/absl/types/$(DEPDIR) + @: > webrtc_dsp/absl/types/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/absl/types/bad_optional_access.lo: \ + webrtc_dsp/absl/types/$(am__dirstamp) \ + webrtc_dsp/absl/types/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/absl/types/optional.lo: \ + webrtc_dsp/absl/types/$(am__dirstamp) \ + webrtc_dsp/absl/types/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/absl/base/internal/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/absl/base/internal + @: > webrtc_dsp/absl/base/internal/$(am__dirstamp) +webrtc_dsp/absl/base/internal/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/absl/base/internal/$(DEPDIR) + @: > webrtc_dsp/absl/base/internal/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/absl/base/internal/raw_logging.lo: \ + webrtc_dsp/absl/base/internal/$(am__dirstamp) \ + webrtc_dsp/absl/base/internal/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/absl/base/internal/throw_delegate.lo: \ + webrtc_dsp/absl/base/internal/$(am__dirstamp) \ + webrtc_dsp/absl/base/internal/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/rtc_base/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/rtc_base + @: > webrtc_dsp/rtc_base/$(am__dirstamp) +webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/rtc_base/$(DEPDIR) + @: > webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/race_checker.lo: \ + webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/rtc_base/strings/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/rtc_base/strings + @: > webrtc_dsp/rtc_base/strings/$(am__dirstamp) +webrtc_dsp/rtc_base/strings/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/rtc_base/strings/$(DEPDIR) + @: > webrtc_dsp/rtc_base/strings/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/strings/string_builder.lo: \ + webrtc_dsp/rtc_base/strings/$(am__dirstamp) \ + webrtc_dsp/rtc_base/strings/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/rtc_base/memory/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/rtc_base/memory + @: > webrtc_dsp/rtc_base/memory/$(am__dirstamp) +webrtc_dsp/rtc_base/memory/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/rtc_base/memory/$(DEPDIR) + @: > webrtc_dsp/rtc_base/memory/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/memory/aligned_malloc.lo: \ + webrtc_dsp/rtc_base/memory/$(am__dirstamp) \ + webrtc_dsp/rtc_base/memory/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/timeutils.lo: \ + webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/platform_file.lo: \ + webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/string_to_number.lo: \ + webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/thread_checker_impl.lo: \ + webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/stringencode.lo: \ + webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/stringutils.lo: \ + webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/checks.lo: webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/platform_thread.lo: \ + webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/logging_webrtc.lo: \ + webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/criticalsection.lo: \ + webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/platform_thread_types.lo: \ + webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/event.lo: webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/rtc_base/event_tracer.lo: \ + webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/third_party/rnnoise/src/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/third_party/rnnoise/src + @: > webrtc_dsp/third_party/rnnoise/src/$(am__dirstamp) +webrtc_dsp/third_party/rnnoise/src/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/third_party/rnnoise/src/$(DEPDIR) + @: > webrtc_dsp/third_party/rnnoise/src/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/third_party/rnnoise/src/rnn_vad_weights.lo: \ + webrtc_dsp/third_party/rnnoise/src/$(am__dirstamp) \ + webrtc_dsp/third_party/rnnoise/src/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/third_party/rnnoise/src/kiss_fft.lo: \ + webrtc_dsp/third_party/rnnoise/src/$(am__dirstamp) \ + webrtc_dsp/third_party/rnnoise/src/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/api/audio/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/api/audio + @: > webrtc_dsp/api/audio/$(am__dirstamp) +webrtc_dsp/api/audio/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/api/audio/$(DEPDIR) + @: > webrtc_dsp/api/audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/api/audio/audio_frame.lo: \ + webrtc_dsp/api/audio/$(am__dirstamp) \ + webrtc_dsp/api/audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/api/audio/echo_canceller3_config.lo: \ + webrtc_dsp/api/audio/$(am__dirstamp) \ + webrtc_dsp/api/audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/api/audio/echo_canceller3_factory.lo: \ + webrtc_dsp/api/audio/$(am__dirstamp) \ + webrtc_dsp/api/audio/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/third_party/fft/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/third_party/fft + @: > webrtc_dsp/modules/third_party/fft/$(am__dirstamp) +webrtc_dsp/modules/third_party/fft/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/third_party/fft/$(DEPDIR) + @: > webrtc_dsp/modules/third_party/fft/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/third_party/fft/fft.lo: \ + webrtc_dsp/modules/third_party/fft/$(am__dirstamp) \ + webrtc_dsp/modules/third_party/fft/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source + @: > webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) +webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR) + @: > webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_estimator.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb16_tables.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_gain_tables.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines_logist.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filterbanks.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/transform.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_filter.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode_lpc_swb.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/filter_functions.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/decode.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lattice.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/intialize.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_tables.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_gain_swb_tables.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/bandwidth_estimator.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/encode.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_analysis.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines_hist.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/entropy_coding.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac_vad.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/arith_routines.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/crc.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/lpc_shape_swb12_tables.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/decode_bwe.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/spectrum_ar_model_tables.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/pitch_lag_tables.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/isac.lo: webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) \ + webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing + @: > webrtc_dsp/modules/audio_processing/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/rms_level.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/echo_detector/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/echo_detector + @: > webrtc_dsp/modules/audio_processing/echo_detector/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/echo_detector/normalized_covariance_estimator.lo: webrtc_dsp/modules/audio_processing/echo_detector/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/echo_detector/moving_max.lo: webrtc_dsp/modules/audio_processing/echo_detector/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/echo_detector/circular_buffer.lo: webrtc_dsp/modules/audio_processing/echo_detector/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/echo_detector/mean_variance_estimator.lo: webrtc_dsp/modules/audio_processing/echo_detector/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/splitting_filter.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/gain_control_impl.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/ns/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/ns + @: > webrtc_dsp/modules/audio_processing/ns/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/ns/nsx_core.lo: \ + webrtc_dsp/modules/audio_processing/ns/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/ns/noise_suppression_x.lo: \ + webrtc_dsp/modules/audio_processing/ns/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/ns/nsx_core_c.lo: \ + webrtc_dsp/modules/audio_processing/ns/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/ns/ns_core.lo: \ + webrtc_dsp/modules/audio_processing/ns/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/ns/noise_suppression.lo: \ + webrtc_dsp/modules/audio_processing/ns/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/audio_buffer.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/typing_detection.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/include/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/include + @: > webrtc_dsp/modules/audio_processing/include/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/include/audio_processing_statistics.lo: \ + webrtc_dsp/modules/audio_processing/include/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/include/audio_generator_factory.lo: \ + webrtc_dsp/modules/audio_processing/include/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/include/aec_dump.lo: \ + webrtc_dsp/modules/audio_processing/include/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/include/audio_processing.lo: \ + webrtc_dsp/modules/audio_processing/include/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/include/config.lo: \ + webrtc_dsp/modules/audio_processing/include/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/agc2 + @: > webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/interpolated_gain_curve.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/agc2_common.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/gain_applier.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/adaptive_agc.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/adaptive_digital_gain_applier.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/limiter.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/saturation_protector.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad + @: > webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features_internal.lo: webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/rnn.lo: webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search_internal.lo: webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/spectral_features.lo: webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/pitch_search.lo: webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/features_extraction.lo: webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/fft_util.lo: webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/lp_residual.lo: webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator_agc.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/vector_float_frame.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/noise_level_estimator.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/agc2_testing_common.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/fixed_digital_level_estimator.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/fixed_gain_controller.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/vad_with_level.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/limiter_db_gain_curve.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/down_sampler.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/signal_classifier.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/noise_spectrum_estimator.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/compute_interpolated_gain_curve.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/biquad_filter.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc2/adaptive_mode_level_estimator.lo: \ + webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/transient/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/transient + @: > webrtc_dsp/modules/audio_processing/transient/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/transient/moving_moments.lo: \ + webrtc_dsp/modules/audio_processing/transient/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/transient/wpd_tree.lo: \ + webrtc_dsp/modules/audio_processing/transient/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/transient/wpd_node.lo: \ + webrtc_dsp/modules/audio_processing/transient/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/transient/transient_suppressor.lo: \ + webrtc_dsp/modules/audio_processing/transient/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/transient/transient_detector.lo: \ + webrtc_dsp/modules/audio_processing/transient/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/low_cut_filter.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/level_estimator_impl.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/three_band_filter_bank.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/aec/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/aec + @: > webrtc_dsp/modules/audio_processing/aec/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/aec/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec/echo_cancellation.lo: \ + webrtc_dsp/modules/audio_processing/aec/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec/aec_resampler.lo: \ + webrtc_dsp/modules/audio_processing/aec/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec/aec_core.lo: \ + webrtc_dsp/modules/audio_processing/aec/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/voice_detection_impl.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/echo_cancellation_impl.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/gain_control_for_experimental_agc.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/agc/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/agc + @: > webrtc_dsp/modules/audio_processing/agc/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc/agc.lo: \ + webrtc_dsp/modules/audio_processing/agc/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc/loudness_histogram.lo: \ + webrtc_dsp/modules/audio_processing/agc/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc/agc_manager_direct.lo: \ + webrtc_dsp/modules/audio_processing/agc/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/agc/legacy/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/agc/legacy + @: > webrtc_dsp/modules/audio_processing/agc/legacy/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc/legacy/analog_agc.lo: webrtc_dsp/modules/audio_processing/agc/legacy/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc/legacy/digital_agc.lo: webrtc_dsp/modules/audio_processing/agc/legacy/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/agc/utility.lo: \ + webrtc_dsp/modules/audio_processing/agc/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/audio_processing_impl.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/audio_generator/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/audio_generator + @: > webrtc_dsp/modules/audio_processing/audio_generator/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/audio_generator/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/audio_generator/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/audio_generator/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/audio_generator/file_audio_generator.lo: webrtc_dsp/modules/audio_processing/audio_generator/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/audio_generator/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/gain_controller2.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/residual_echo_detector.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/noise_suppression_impl.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/aecm/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/aecm + @: > webrtc_dsp/modules/audio_processing/aecm/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aecm/aecm_core.lo: \ + webrtc_dsp/modules/audio_processing/aecm/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aecm/aecm_core_c.lo: \ + webrtc_dsp/modules/audio_processing/aecm/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aecm/echo_control_mobile.lo: \ + webrtc_dsp/modules/audio_processing/aecm/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/aec3 + @: > webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/render_reverb_model.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/reverb_model_fallback.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/echo_remover_metrics.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/matched_filter_lag_aggregator.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer2.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/echo_path_variability.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/frame_blocker.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/subtractor.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/aec3_fft.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/fullband_erle_estimator.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/suppression_filter.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/block_processor.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/subband_erle_estimator.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller_metrics.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/render_delay_buffer.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/vector_buffer.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/erl_estimator.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/aec_state.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/adaptive_fir_filter.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/skew_estimator.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/echo_path_delay_estimator.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/block_framer.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/erle_estimator.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/reverb_model.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/cascaded_biquad_filter.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/render_buffer.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/subtractor_output.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/stationarity_estimator.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/render_signal_analyzer.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/subtractor_output_analyzer.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/suppression_gain.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/echo_audibility.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/block_processor_metrics.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/moving_average.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/reverb_model_estimator.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/aec3_common.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/residual_echo_estimator.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/matched_filter.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/reverb_decay_estimator.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/render_delay_controller2.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/suppression_gain_limiter.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/main_filter_update_gain.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/echo_remover.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/downsampled_render_buffer.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/matrix_buffer.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/block_processor2.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/echo_canceller3.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/block_delay_buffer.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/fft_buffer.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/comfort_noise_generator.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/shadow_filter_update_gain.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/filter_analyzer.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/reverb_frequency_response.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/aec3/decimator.lo: \ + webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/echo_control_mobile_impl.lo: \ + webrtc_dsp/modules/audio_processing/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/logging/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/logging + @: > webrtc_dsp/modules/audio_processing/logging/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/logging/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/logging/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/logging/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/logging/apm_data_dumper.lo: \ + webrtc_dsp/modules/audio_processing/logging/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/logging/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/vad/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/vad + @: > webrtc_dsp/modules/audio_processing/vad/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/vad/voice_activity_detector.lo: \ + webrtc_dsp/modules/audio_processing/vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/vad/standalone_vad.lo: \ + webrtc_dsp/modules/audio_processing/vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/vad/pitch_internal.lo: \ + webrtc_dsp/modules/audio_processing/vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/vad/vad_circular_buffer.lo: \ + webrtc_dsp/modules/audio_processing/vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/vad/vad_audio_proc.lo: \ + webrtc_dsp/modules/audio_processing/vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/vad/pole_zero_filter.lo: \ + webrtc_dsp/modules/audio_processing/vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/vad/pitch_based_vad.lo: \ + webrtc_dsp/modules/audio_processing/vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/vad/gmm.lo: \ + webrtc_dsp/modules/audio_processing/vad/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/utility/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/utility + @: > webrtc_dsp/modules/audio_processing/utility/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR) + @: > webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/utility/ooura_fft.lo: \ + webrtc_dsp/modules/audio_processing/utility/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/utility/delay_estimator_wrapper.lo: \ + webrtc_dsp/modules/audio_processing/utility/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/utility/delay_estimator.lo: \ + webrtc_dsp/modules/audio_processing/utility/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/modules/audio_processing/utility/block_mean_calculator.lo: \ + webrtc_dsp/modules/audio_processing/utility/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/common_audio/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/common_audio + @: > webrtc_dsp/common_audio/$(am__dirstamp) +webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/common_audio/$(DEPDIR) + @: > webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/window_generator.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/channel_buffer.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/fir_filter_factory.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/wav_header.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/real_fourier_ooura.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/audio_util.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/fir_filter_sse.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/common_audio/resampler/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/common_audio/resampler + @: > webrtc_dsp/common_audio/resampler/$(am__dirstamp) +webrtc_dsp/common_audio/resampler/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/common_audio/resampler/$(DEPDIR) + @: > webrtc_dsp/common_audio/resampler/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/resampler/push_sinc_resampler.lo: \ + webrtc_dsp/common_audio/resampler/$(am__dirstamp) \ + webrtc_dsp/common_audio/resampler/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/resampler/resampler.lo: \ + webrtc_dsp/common_audio/resampler/$(am__dirstamp) \ + webrtc_dsp/common_audio/resampler/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/resampler/sinc_resampler_sse.lo: \ + webrtc_dsp/common_audio/resampler/$(am__dirstamp) \ + webrtc_dsp/common_audio/resampler/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/resampler/push_resampler.lo: \ + webrtc_dsp/common_audio/resampler/$(am__dirstamp) \ + webrtc_dsp/common_audio/resampler/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/resampler/sinc_resampler.lo: \ + webrtc_dsp/common_audio/resampler/$(am__dirstamp) \ + webrtc_dsp/common_audio/resampler/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/resampler/sinusoidal_linear_chirp_source.lo: \ + webrtc_dsp/common_audio/resampler/$(am__dirstamp) \ + webrtc_dsp/common_audio/resampler/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/wav_file.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/common_audio/third_party/fft4g/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/common_audio/third_party/fft4g + @: > webrtc_dsp/common_audio/third_party/fft4g/$(am__dirstamp) +webrtc_dsp/common_audio/third_party/fft4g/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/common_audio/third_party/fft4g/$(DEPDIR) + @: > webrtc_dsp/common_audio/third_party/fft4g/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/third_party/fft4g/fft4g.lo: \ + webrtc_dsp/common_audio/third_party/fft4g/$(am__dirstamp) \ + webrtc_dsp/common_audio/third_party/fft4g/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/audio_converter.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/real_fourier.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/sparse_fir_filter.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/smoothing_filter.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/fir_filter_c.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/ring_buffer.lo: \ + webrtc_dsp/common_audio/$(am__dirstamp) \ + webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/common_audio/signal_processing/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/common_audio/signal_processing + @: > webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) +webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR) + @: > webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/complex_fft.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/filter_ma_fast_q12.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/splitting_filter1.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/levinson_durbin.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/dot_product_with_scale.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/auto_corr_to_refl_coef.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/resample_by_2_internal.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/energy.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/sqrt_of_one_minus_x_squared.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/downsample_fast.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/filter_ar_fast_q12.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/spl_init.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/lpc_to_refl_coef.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/cross_correlation.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/division_operations.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/auto_correlation.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/get_scaling_square.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/resample.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/min_max_operations.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/refl_coef_to_lpc.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/filter_ar.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/vector_scaling_operations.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/resample_fractional.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/real_fft.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/ilbc_specific_functions.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/randomization_functions.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/copy_set_operations.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/resample_by_2.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/get_hanning_window.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/resample_48khz.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/spl_inl.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/signal_processing/spl_sqrt.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/common_audio/vad/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/common_audio/vad + @: > webrtc_dsp/common_audio/vad/$(am__dirstamp) +webrtc_dsp/common_audio/vad/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) ./webrtc_dsp/common_audio/vad/$(DEPDIR) + @: > webrtc_dsp/common_audio/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/vad/vad_sp.lo: \ + webrtc_dsp/common_audio/vad/$(am__dirstamp) \ + webrtc_dsp/common_audio/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/vad/vad.lo: \ + webrtc_dsp/common_audio/vad/$(am__dirstamp) \ + webrtc_dsp/common_audio/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/vad/webrtc_vad.lo: \ + webrtc_dsp/common_audio/vad/$(am__dirstamp) \ + webrtc_dsp/common_audio/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/vad/vad_filterbank.lo: \ + webrtc_dsp/common_audio/vad/$(am__dirstamp) \ + webrtc_dsp/common_audio/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/vad/vad_core.lo: \ + webrtc_dsp/common_audio/vad/$(am__dirstamp) \ + webrtc_dsp/common_audio/vad/$(DEPDIR)/$(am__dirstamp) +./webrtc_dsp/common_audio/vad/vad_gmm.lo: \ + webrtc_dsp/common_audio/vad/$(am__dirstamp) \ + webrtc_dsp/common_audio/vad/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/rtc_base/logging_mac.lo: \ + webrtc_dsp/rtc_base/$(am__dirstamp) \ + webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/aec/aec_core_sse2.lo: \ + webrtc_dsp/modules/audio_processing/aec/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/utility/ooura_fft_sse2.lo: \ + webrtc_dsp/modules/audio_processing/utility/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/$(am__dirstamp) +audio/AudioIOCallback.lo: audio/$(am__dirstamp) \ + audio/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/common_audio/signal_processing/complex_bit_reverse_arm.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(am__dirstamp): + @$(MKDIR_P) webrtc_dsp/common_audio/third_party/spl_sqrt_floor + @: > webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(am__dirstamp) +webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR)/$(am__dirstamp): + @$(MKDIR_P) webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR) + @: > webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor_arm.lo: webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(am__dirstamp) \ + webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/common_audio/signal_processing/cross_correlation_neon.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/common_audio/signal_processing/downsample_fast_neon.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/common_audio/signal_processing/min_max_operations_neon.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/aec/aec_core_neon.lo: \ + webrtc_dsp/modules/audio_processing/aec/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/aecm/aecm_core_neon.lo: \ + webrtc_dsp/modules/audio_processing/aecm/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/ns/nsx_core_neon.lo: \ + webrtc_dsp/modules/audio_processing/ns/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/modules/audio_processing/utility/ooura_fft_neon.lo: \ + webrtc_dsp/modules/audio_processing/utility/$(am__dirstamp) \ + webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/common_audio/signal_processing/complex_bit_reverse.lo: \ + webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) \ + webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) +webrtc_dsp/common_audio/third_party/spl_sqrt_floor/spl_sqrt_floor.lo: webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(am__dirstamp) \ + webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR)/$(am__dirstamp) + +libtgvoip.la: $(libtgvoip_la_OBJECTS) $(libtgvoip_la_DEPENDENCIES) $(EXTRA_libtgvoip_la_DEPENDENCIES) + $(AM_V_OBJCXXLD)$(OBJCXXLINK) -rpath $(libdir) $(libtgvoip_la_OBJECTS) $(libtgvoip_la_LIBADD) $(LIBS) + +mostlyclean-compile: + -rm -f *.$(OBJEXT) + -rm -f ./webrtc_dsp/absl/base/internal/*.$(OBJEXT) + -rm -f ./webrtc_dsp/absl/base/internal/*.lo + -rm -f ./webrtc_dsp/absl/strings/*.$(OBJEXT) + -rm -f ./webrtc_dsp/absl/strings/*.lo + -rm -f ./webrtc_dsp/absl/strings/internal/*.$(OBJEXT) + -rm -f ./webrtc_dsp/absl/strings/internal/*.lo + -rm -f ./webrtc_dsp/absl/types/*.$(OBJEXT) + -rm -f ./webrtc_dsp/absl/types/*.lo + -rm -f ./webrtc_dsp/api/audio/*.$(OBJEXT) + -rm -f ./webrtc_dsp/api/audio/*.lo + -rm -f ./webrtc_dsp/common_audio/*.$(OBJEXT) + -rm -f ./webrtc_dsp/common_audio/*.lo + -rm -f ./webrtc_dsp/common_audio/resampler/*.$(OBJEXT) + -rm -f ./webrtc_dsp/common_audio/resampler/*.lo + -rm -f ./webrtc_dsp/common_audio/signal_processing/*.$(OBJEXT) + -rm -f ./webrtc_dsp/common_audio/signal_processing/*.lo + -rm -f ./webrtc_dsp/common_audio/third_party/fft4g/*.$(OBJEXT) + -rm -f ./webrtc_dsp/common_audio/third_party/fft4g/*.lo + -rm -f ./webrtc_dsp/common_audio/vad/*.$(OBJEXT) + -rm -f ./webrtc_dsp/common_audio/vad/*.lo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/aec/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/aec/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/aecm/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/aecm/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/agc/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/legacy/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/agc/legacy/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/audio_generator/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/audio_generator/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/echo_detector/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/echo_detector/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/include/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/include/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/logging/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/logging/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/ns/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/ns/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/transient/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/transient/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/utility/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/utility/*.lo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/audio_processing/vad/*.lo + -rm -f ./webrtc_dsp/modules/third_party/fft/*.$(OBJEXT) + -rm -f ./webrtc_dsp/modules/third_party/fft/*.lo + -rm -f ./webrtc_dsp/rtc_base/*.$(OBJEXT) + -rm -f ./webrtc_dsp/rtc_base/*.lo + -rm -f ./webrtc_dsp/rtc_base/memory/*.$(OBJEXT) + -rm -f ./webrtc_dsp/rtc_base/memory/*.lo + -rm -f ./webrtc_dsp/rtc_base/strings/*.$(OBJEXT) + -rm -f ./webrtc_dsp/rtc_base/strings/*.lo + -rm -f ./webrtc_dsp/system_wrappers/source/*.$(OBJEXT) + -rm -f ./webrtc_dsp/system_wrappers/source/*.lo + -rm -f ./webrtc_dsp/third_party/rnnoise/src/*.$(OBJEXT) + -rm -f ./webrtc_dsp/third_party/rnnoise/src/*.lo + -rm -f audio/*.$(OBJEXT) + -rm -f audio/*.lo + -rm -f os/darwin/*.$(OBJEXT) + -rm -f os/darwin/*.lo + -rm -f os/linux/*.$(OBJEXT) + -rm -f os/linux/*.lo + -rm -f os/posix/*.$(OBJEXT) + -rm -f os/posix/*.lo + -rm -f video/*.$(OBJEXT) + -rm -f video/*.lo + -rm -f webrtc_dsp/common_audio/signal_processing/*.$(OBJEXT) + -rm -f webrtc_dsp/common_audio/signal_processing/*.lo + -rm -f webrtc_dsp/common_audio/third_party/spl_sqrt_floor/*.$(OBJEXT) + -rm -f webrtc_dsp/common_audio/third_party/spl_sqrt_floor/*.lo + -rm -f webrtc_dsp/modules/audio_processing/aec/*.$(OBJEXT) + -rm -f webrtc_dsp/modules/audio_processing/aec/*.lo + -rm -f webrtc_dsp/modules/audio_processing/aecm/*.$(OBJEXT) + -rm -f webrtc_dsp/modules/audio_processing/aecm/*.lo + -rm -f webrtc_dsp/modules/audio_processing/ns/*.$(OBJEXT) + -rm -f webrtc_dsp/modules/audio_processing/ns/*.lo + -rm -f webrtc_dsp/modules/audio_processing/utility/*.$(OBJEXT) + -rm -f webrtc_dsp/modules/audio_processing/utility/*.lo + -rm -f webrtc_dsp/rtc_base/*.$(OBJEXT) + -rm -f webrtc_dsp/rtc_base/*.lo + +distclean-compile: + -rm -f *.tab.c + +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/Buffers.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/CongestionControl.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/EchoCanceller.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/JitterBuffer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MediaStreamItf.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/MessageThread.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/NetworkSocket.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/OpusDecoder.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/OpusEncoder.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/PacketReassembler.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/TgVoip.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/VoIPController.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/VoIPGroupController.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/VoIPServerConfig.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/json11.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/logging.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/absl/base/internal/$(DEPDIR)/raw_logging.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/absl/base/internal/$(DEPDIR)/throw_delegate.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/absl/strings/$(DEPDIR)/ascii.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/absl/strings/$(DEPDIR)/string_view.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/absl/strings/internal/$(DEPDIR)/memutil.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/absl/types/$(DEPDIR)/bad_optional_access.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/absl/types/$(DEPDIR)/optional.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/api/audio/$(DEPDIR)/audio_frame.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/api/audio/$(DEPDIR)/echo_canceller3_config.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/api/audio/$(DEPDIR)/echo_canceller3_factory.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/audio_converter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/audio_util.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/channel_buffer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/fir_filter_c.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/fir_filter_factory.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/fir_filter_sse.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/real_fourier.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/real_fourier_ooura.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/ring_buffer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/smoothing_filter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/sparse_fir_filter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/wav_file.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/wav_header.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/$(DEPDIR)/window_generator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/resampler/$(DEPDIR)/push_resampler.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/resampler/$(DEPDIR)/push_sinc_resampler.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/resampler/$(DEPDIR)/resampler.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/resampler/$(DEPDIR)/sinc_resampler.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/resampler/$(DEPDIR)/sinc_resampler_sse.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/resampler/$(DEPDIR)/sinusoidal_linear_chirp_source.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/auto_corr_to_refl_coef.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/auto_correlation.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/complex_fft.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/copy_set_operations.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/cross_correlation.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/division_operations.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/dot_product_with_scale.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/downsample_fast.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/energy.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/filter_ar.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/filter_ar_fast_q12.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/filter_ma_fast_q12.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/get_hanning_window.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/get_scaling_square.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/ilbc_specific_functions.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/levinson_durbin.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/lpc_to_refl_coef.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/min_max_operations.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/randomization_functions.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/real_fft.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/refl_coef_to_lpc.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_48khz.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_by_2.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_by_2_internal.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_fractional.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/spl_init.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/spl_inl.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/spl_sqrt.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/splitting_filter1.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/sqrt_of_one_minus_x_squared.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/vector_scaling_operations.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/third_party/fft4g/$(DEPDIR)/fft4g.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_core.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_filterbank.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_gmm.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_sp.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/common_audio/vad/$(DEPDIR)/webrtc_vad.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/arith_routines.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/arith_routines_hist.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/arith_routines_logist.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/bandwidth_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/crc.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/decode.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/decode_bwe.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/encode.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/encode_lpc_swb.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/entropy_coding.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/filter_functions.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/filterbanks.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/intialize.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/isac.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/isac_vad.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lattice.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_analysis.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_gain_swb_tables.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_shape_swb12_tables.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_shape_swb16_tables.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_tables.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_filter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_gain_tables.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_lag_tables.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/spectrum_ar_model_tables.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/transform.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/audio_buffer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/audio_processing_impl.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/echo_cancellation_impl.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/echo_control_mobile_impl.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/gain_control_for_experimental_agc.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/gain_control_impl.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/gain_controller2.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/level_estimator_impl.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/low_cut_filter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/noise_suppression_impl.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/residual_echo_detector.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/rms_level.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/splitting_filter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/three_band_filter_bank.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/typing_detection.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/$(DEPDIR)/voice_detection_impl.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_core.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_resampler.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/echo_cancellation.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/adaptive_fir_filter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/aec3_common.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/aec3_fft.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/aec_state.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_delay_buffer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_framer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_processor.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_processor2.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_processor_metrics.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/cascaded_biquad_filter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/comfort_noise_generator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/decimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/downsampled_render_buffer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_audibility.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_canceller3.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_path_delay_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_path_variability.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_remover.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_remover_metrics.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/erl_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/erle_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/fft_buffer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/filter_analyzer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/frame_blocker.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/fullband_erle_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/main_filter_update_gain.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/matched_filter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/matched_filter_lag_aggregator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/matrix_buffer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/moving_average.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_buffer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_buffer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_buffer2.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_controller.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_controller2.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_controller_metrics.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_reverb_model.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_signal_analyzer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/residual_echo_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_decay_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_frequency_response.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_model.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_model_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_model_fallback.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/shadow_filter_update_gain.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/skew_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/stationarity_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subband_erle_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subtractor.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subtractor_output.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subtractor_output_analyzer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/suppression_filter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/suppression_gain.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/suppression_gain_limiter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/vector_buffer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/aecm_core.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/aecm_core_c.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/echo_control_mobile.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/agc.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/agc_manager_direct.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/loudness_histogram.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/utility.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR)/analog_agc.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR)/digital_agc.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_agc.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_digital_gain_applier.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_mode_level_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_mode_level_estimator_agc.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/agc2_common.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/agc2_testing_common.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/biquad_filter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/compute_interpolated_gain_curve.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/down_sampler.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/fixed_digital_level_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/fixed_gain_controller.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/gain_applier.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/interpolated_gain_curve.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/limiter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/limiter_db_gain_curve.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/noise_level_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/noise_spectrum_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/saturation_protector.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/signal_classifier.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/vad_with_level.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/vector_float_frame.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/features_extraction.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/fft_util.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/lp_residual.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/pitch_search.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/pitch_search_internal.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/rnn.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/spectral_features.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/spectral_features_internal.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/audio_generator/$(DEPDIR)/file_audio_generator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/circular_buffer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/mean_variance_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/moving_max.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/normalized_covariance_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/aec_dump.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/audio_generator_factory.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/audio_processing.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/audio_processing_statistics.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/config.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/logging/$(DEPDIR)/apm_data_dumper.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/noise_suppression.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/noise_suppression_x.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/ns_core.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/nsx_core.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/nsx_core_c.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/moving_moments.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/transient_detector.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/transient_suppressor.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/wpd_node.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/wpd_tree.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/block_mean_calculator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/delay_estimator.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/delay_estimator_wrapper.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/ooura_fft.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/gmm.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/pitch_based_vad.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/pitch_internal.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/pole_zero_filter.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/standalone_vad.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/vad_audio_proc.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/vad_circular_buffer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/voice_activity_detector.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/modules/third_party/fft/$(DEPDIR)/fft.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/checks.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/criticalsection.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/event.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/event_tracer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/logging_webrtc.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/platform_file.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/platform_thread.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/platform_thread_types.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/race_checker.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/string_to_number.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/stringencode.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/stringutils.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/thread_checker_impl.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/$(DEPDIR)/timeutils.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/memory/$(DEPDIR)/aligned_malloc.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/rtc_base/strings/$(DEPDIR)/string_builder.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/system_wrappers/source/$(DEPDIR)/cpu_features.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/system_wrappers/source/$(DEPDIR)/field_trial.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/system_wrappers/source/$(DEPDIR)/metrics.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/third_party/rnnoise/src/$(DEPDIR)/kiss_fft.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@./webrtc_dsp/third_party/rnnoise/src/$(DEPDIR)/rnn_vad_weights.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@audio/$(DEPDIR)/AudioIO.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@audio/$(DEPDIR)/AudioIOCallback.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@audio/$(DEPDIR)/AudioInput.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@audio/$(DEPDIR)/AudioOutput.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@audio/$(DEPDIR)/Resampler.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/darwin/$(DEPDIR)/AudioInputAudioUnit.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/darwin/$(DEPDIR)/AudioInputAudioUnitOSX.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/darwin/$(DEPDIR)/AudioOutputAudioUnit.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/darwin/$(DEPDIR)/AudioOutputAudioUnitOSX.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/darwin/$(DEPDIR)/AudioUnitIO.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/darwin/$(DEPDIR)/DarwinSpecific.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/darwin/$(DEPDIR)/SampleBufferDisplayLayerRenderer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/darwin/$(DEPDIR)/TGVVideoRenderer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/darwin/$(DEPDIR)/TGVVideoSource.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/darwin/$(DEPDIR)/VideoToolboxEncoderSource.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/linux/$(DEPDIR)/AudioInputALSA.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/linux/$(DEPDIR)/AudioInputPulse.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/linux/$(DEPDIR)/AudioOutputALSA.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/linux/$(DEPDIR)/AudioOutputPulse.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/linux/$(DEPDIR)/AudioPulse.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@os/posix/$(DEPDIR)/NetworkSocketPosix.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@video/$(DEPDIR)/ScreamCongestionController.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@video/$(DEPDIR)/VideoFEC.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@video/$(DEPDIR)/VideoPacketSender.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@video/$(DEPDIR)/VideoRenderer.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@video/$(DEPDIR)/VideoSource.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/complex_bit_reverse.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/complex_bit_reverse_arm.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/cross_correlation_neon.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/downsample_fast_neon.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/min_max_operations_neon.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR)/spl_sqrt_floor.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR)/spl_sqrt_floor_arm.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_core_neon.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_core_sse2.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/aecm_core_neon.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/nsx_core_neon.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/ooura_fft_neon.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/ooura_fft_sse2.Plo@am__quote@ # am--include-marker +@AMDEP_TRUE@@am__include@ @am__quote@webrtc_dsp/rtc_base/$(DEPDIR)/logging_mac.Plo@am__quote@ # am--include-marker + +$(am__depfiles_remade): + @$(MKDIR_P) $(@D) + @echo '# dummy' >$@-t && $(am__mv) $@-t $@ + +am--depfiles: $(am__depfiles_remade) + +.S.o: +@am__fastdepCCAS_TRUE@ $(AM_V_CPPAS)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ +@am__fastdepCCAS_TRUE@ $(CPPASCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ +@am__fastdepCCAS_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po +@AMDEP_TRUE@@am__fastdepCCAS_FALSE@ $(AM_V_CPPAS)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCCAS_FALSE@ DEPDIR=$(DEPDIR) $(CCASDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCCAS_FALSE@ $(AM_V_CPPAS@am__nodep@)$(CPPASCOMPILE) -c -o $@ $< + +.S.obj: +@am__fastdepCCAS_TRUE@ $(AM_V_CPPAS)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ +@am__fastdepCCAS_TRUE@ $(CPPASCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ +@am__fastdepCCAS_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po +@AMDEP_TRUE@@am__fastdepCCAS_FALSE@ $(AM_V_CPPAS)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCCAS_FALSE@ DEPDIR=$(DEPDIR) $(CCASDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCCAS_FALSE@ $(AM_V_CPPAS@am__nodep@)$(CPPASCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` + +.S.lo: +@am__fastdepCCAS_TRUE@ $(AM_V_CPPAS)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ +@am__fastdepCCAS_TRUE@ $(LTCPPASCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ +@am__fastdepCCAS_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo +@AMDEP_TRUE@@am__fastdepCCAS_FALSE@ $(AM_V_CPPAS)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCCAS_FALSE@ DEPDIR=$(DEPDIR) $(CCASDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCCAS_FALSE@ $(AM_V_CPPAS@am__nodep@)$(LTCPPASCOMPILE) -c -o $@ $< + +.c.o: +@am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ +@am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ +@am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po +@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< + +.c.obj: +@am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ +@am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ +@am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po +@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` + +.c.lo: +@am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ +@am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ +@am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo +@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< + +.cc.o: +@am__fastdepCXX_TRUE@ $(AM_V_CXX)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ +@am__fastdepCXX_TRUE@ $(CXXCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ +@am__fastdepCXX_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(AM_V_CXX)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@ $(AM_V_CXX@am__nodep@)$(CXXCOMPILE) -c -o $@ $< + +.cc.obj: +@am__fastdepCXX_TRUE@ $(AM_V_CXX)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ +@am__fastdepCXX_TRUE@ $(CXXCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ +@am__fastdepCXX_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(AM_V_CXX)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@ $(AM_V_CXX@am__nodep@)$(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` + +.cc.lo: +@am__fastdepCXX_TRUE@ $(AM_V_CXX)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ +@am__fastdepCXX_TRUE@ $(LTCXXCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ +@am__fastdepCXX_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo +@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(AM_V_CXX)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@ $(AM_V_CXX@am__nodep@)$(LTCXXCOMPILE) -c -o $@ $< + +.cpp.o: +@am__fastdepCXX_TRUE@ $(AM_V_CXX)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ +@am__fastdepCXX_TRUE@ $(CXXCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ +@am__fastdepCXX_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(AM_V_CXX)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@ $(AM_V_CXX@am__nodep@)$(CXXCOMPILE) -c -o $@ $< + +.cpp.obj: +@am__fastdepCXX_TRUE@ $(AM_V_CXX)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ +@am__fastdepCXX_TRUE@ $(CXXCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ +@am__fastdepCXX_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(AM_V_CXX)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@ $(AM_V_CXX@am__nodep@)$(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` + +.cpp.lo: +@am__fastdepCXX_TRUE@ $(AM_V_CXX)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ +@am__fastdepCXX_TRUE@ $(LTCXXCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ +@am__fastdepCXX_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo +@AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(AM_V_CXX)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@ $(AM_V_CXX@am__nodep@)$(LTCXXCOMPILE) -c -o $@ $< + +.mm.o: +@am__fastdepOBJCXX_TRUE@ $(AM_V_OBJCXX)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ +@am__fastdepOBJCXX_TRUE@ $(OBJCXXCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ +@am__fastdepOBJCXX_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po +@AMDEP_TRUE@@am__fastdepOBJCXX_FALSE@ $(AM_V_OBJCXX)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepOBJCXX_FALSE@ DEPDIR=$(DEPDIR) $(OBJCXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepOBJCXX_FALSE@ $(AM_V_OBJCXX@am__nodep@)$(OBJCXXCOMPILE) -c -o $@ $< + +.mm.obj: +@am__fastdepOBJCXX_TRUE@ $(AM_V_OBJCXX)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ +@am__fastdepOBJCXX_TRUE@ $(OBJCXXCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ +@am__fastdepOBJCXX_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po +@AMDEP_TRUE@@am__fastdepOBJCXX_FALSE@ $(AM_V_OBJCXX)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepOBJCXX_FALSE@ DEPDIR=$(DEPDIR) $(OBJCXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepOBJCXX_FALSE@ $(AM_V_OBJCXX@am__nodep@)$(OBJCXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` + +.mm.lo: +@am__fastdepOBJCXX_TRUE@ $(AM_V_OBJCXX)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\ +@am__fastdepOBJCXX_TRUE@ $(LTOBJCXXCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ +@am__fastdepOBJCXX_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo +@AMDEP_TRUE@@am__fastdepOBJCXX_FALSE@ $(AM_V_OBJCXX)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepOBJCXX_FALSE@ DEPDIR=$(DEPDIR) $(OBJCXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepOBJCXX_FALSE@ $(AM_V_OBJCXX@am__nodep@)$(LTOBJCXXCOMPILE) -c -o $@ $< + +mostlyclean-libtool: + -rm -f *.lo + +clean-libtool: + -rm -rf .libs _libs + -rm -rf ./webrtc_dsp/absl/base/internal/.libs ./webrtc_dsp/absl/base/internal/_libs + -rm -rf ./webrtc_dsp/absl/strings/.libs ./webrtc_dsp/absl/strings/_libs + -rm -rf ./webrtc_dsp/absl/strings/internal/.libs ./webrtc_dsp/absl/strings/internal/_libs + -rm -rf ./webrtc_dsp/absl/types/.libs ./webrtc_dsp/absl/types/_libs + -rm -rf ./webrtc_dsp/api/audio/.libs ./webrtc_dsp/api/audio/_libs + -rm -rf ./webrtc_dsp/common_audio/.libs ./webrtc_dsp/common_audio/_libs + -rm -rf ./webrtc_dsp/common_audio/resampler/.libs ./webrtc_dsp/common_audio/resampler/_libs + -rm -rf ./webrtc_dsp/common_audio/signal_processing/.libs ./webrtc_dsp/common_audio/signal_processing/_libs + -rm -rf ./webrtc_dsp/common_audio/third_party/fft4g/.libs ./webrtc_dsp/common_audio/third_party/fft4g/_libs + -rm -rf ./webrtc_dsp/common_audio/vad/.libs ./webrtc_dsp/common_audio/vad/_libs + -rm -rf ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/.libs ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/.libs ./webrtc_dsp/modules/audio_processing/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/aec/.libs ./webrtc_dsp/modules/audio_processing/aec/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/aec3/.libs ./webrtc_dsp/modules/audio_processing/aec3/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/aecm/.libs ./webrtc_dsp/modules/audio_processing/aecm/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/agc/.libs ./webrtc_dsp/modules/audio_processing/agc/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/agc/legacy/.libs ./webrtc_dsp/modules/audio_processing/agc/legacy/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/agc2/.libs ./webrtc_dsp/modules/audio_processing/agc2/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/.libs ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/audio_generator/.libs ./webrtc_dsp/modules/audio_processing/audio_generator/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/echo_detector/.libs ./webrtc_dsp/modules/audio_processing/echo_detector/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/include/.libs ./webrtc_dsp/modules/audio_processing/include/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/logging/.libs ./webrtc_dsp/modules/audio_processing/logging/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/ns/.libs ./webrtc_dsp/modules/audio_processing/ns/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/transient/.libs ./webrtc_dsp/modules/audio_processing/transient/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/utility/.libs ./webrtc_dsp/modules/audio_processing/utility/_libs + -rm -rf ./webrtc_dsp/modules/audio_processing/vad/.libs ./webrtc_dsp/modules/audio_processing/vad/_libs + -rm -rf ./webrtc_dsp/modules/third_party/fft/.libs ./webrtc_dsp/modules/third_party/fft/_libs + -rm -rf ./webrtc_dsp/rtc_base/.libs ./webrtc_dsp/rtc_base/_libs + -rm -rf ./webrtc_dsp/rtc_base/memory/.libs ./webrtc_dsp/rtc_base/memory/_libs + -rm -rf ./webrtc_dsp/rtc_base/strings/.libs ./webrtc_dsp/rtc_base/strings/_libs + -rm -rf ./webrtc_dsp/system_wrappers/source/.libs ./webrtc_dsp/system_wrappers/source/_libs + -rm -rf ./webrtc_dsp/third_party/rnnoise/src/.libs ./webrtc_dsp/third_party/rnnoise/src/_libs + -rm -rf audio/.libs audio/_libs + -rm -rf os/darwin/.libs os/darwin/_libs + -rm -rf os/linux/.libs os/linux/_libs + -rm -rf os/posix/.libs os/posix/_libs + -rm -rf video/.libs video/_libs + -rm -rf webrtc_dsp/common_audio/signal_processing/.libs webrtc_dsp/common_audio/signal_processing/_libs + -rm -rf webrtc_dsp/common_audio/third_party/spl_sqrt_floor/.libs webrtc_dsp/common_audio/third_party/spl_sqrt_floor/_libs + -rm -rf webrtc_dsp/modules/audio_processing/aec/.libs webrtc_dsp/modules/audio_processing/aec/_libs + -rm -rf webrtc_dsp/modules/audio_processing/aecm/.libs webrtc_dsp/modules/audio_processing/aecm/_libs + -rm -rf webrtc_dsp/modules/audio_processing/ns/.libs webrtc_dsp/modules/audio_processing/ns/_libs + -rm -rf webrtc_dsp/modules/audio_processing/utility/.libs webrtc_dsp/modules/audio_processing/utility/_libs + -rm -rf webrtc_dsp/rtc_base/.libs webrtc_dsp/rtc_base/_libs + +distclean-libtool: + -rm -f libtool config.lt +install-nobase_tgvoipincludeHEADERS: $(nobase_tgvoipinclude_HEADERS) + @$(NORMAL_INSTALL) + @list='$(nobase_tgvoipinclude_HEADERS)'; test -n "$(tgvoipincludedir)" || list=; \ + if test -n "$$list"; then \ + echo " $(MKDIR_P) '$(DESTDIR)$(tgvoipincludedir)'"; \ + $(MKDIR_P) "$(DESTDIR)$(tgvoipincludedir)" || exit 1; \ + fi; \ + $(am__nobase_list) | while read dir files; do \ + xfiles=; for file in $$files; do \ + if test -f "$$file"; then xfiles="$$xfiles $$file"; \ + else xfiles="$$xfiles $(srcdir)/$$file"; fi; done; \ + test -z "$$xfiles" || { \ + test "x$$dir" = x. || { \ + echo " $(MKDIR_P) '$(DESTDIR)$(tgvoipincludedir)/$$dir'"; \ + $(MKDIR_P) "$(DESTDIR)$(tgvoipincludedir)/$$dir"; }; \ + echo " $(INSTALL_HEADER) $$xfiles '$(DESTDIR)$(tgvoipincludedir)/$$dir'"; \ + $(INSTALL_HEADER) $$xfiles "$(DESTDIR)$(tgvoipincludedir)/$$dir" || exit $$?; }; \ + done + +uninstall-nobase_tgvoipincludeHEADERS: + @$(NORMAL_UNINSTALL) + @list='$(nobase_tgvoipinclude_HEADERS)'; test -n "$(tgvoipincludedir)" || list=; \ + $(am__nobase_strip_setup); files=`$(am__nobase_strip)`; \ + dir='$(DESTDIR)$(tgvoipincludedir)'; $(am__uninstall_files_from_dir) + +ID: $(am__tagged_files) + $(am__define_uniq_tagged_files); mkid -fID $$unique +tags: tags-am +TAGS: tags + +tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) + set x; \ + here=`pwd`; \ + $(am__define_uniq_tagged_files); \ + shift; \ + if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ + test -n "$$unique" || unique=$$empty_fix; \ + if test $$# -gt 0; then \ + $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ + "$$@" $$unique; \ + else \ + $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ + $$unique; \ + fi; \ + fi +ctags: ctags-am + +CTAGS: ctags +ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) + $(am__define_uniq_tagged_files); \ + test -z "$(CTAGS_ARGS)$$unique" \ + || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ + $$unique + +GTAGS: + here=`$(am__cd) $(top_builddir) && pwd` \ + && $(am__cd) $(top_srcdir) \ + && gtags -i $(GTAGS_ARGS) "$$here" +cscope: cscope.files + test ! -s cscope.files \ + || $(CSCOPE) -b -q $(AM_CSCOPEFLAGS) $(CSCOPEFLAGS) -i cscope.files $(CSCOPE_ARGS) +clean-cscope: + -rm -f cscope.files +cscope.files: clean-cscope cscopelist +cscopelist: cscopelist-am + +cscopelist-am: $(am__tagged_files) + list='$(am__tagged_files)'; \ + case "$(srcdir)" in \ + [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ + *) sdir=$(subdir)/$(srcdir) ;; \ + esac; \ + for i in $$list; do \ + if test -f "$$i"; then \ + echo "$(subdir)/$$i"; \ + else \ + echo "$$sdir/$$i"; \ + fi; \ + done >> $(top_builddir)/cscope.files + +distclean-tags: + -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags + -rm -f cscope.out cscope.in.out cscope.po.out cscope.files + +distdir: $(BUILT_SOURCES) + $(MAKE) $(AM_MAKEFLAGS) distdir-am + +distdir-am: $(DISTFILES) + $(am__remove_distdir) + test -d "$(distdir)" || mkdir "$(distdir)" + @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ + topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ + list='$(DISTFILES)'; \ + dist_files=`for file in $$list; do echo $$file; done | \ + sed -e "s|^$$srcdirstrip/||;t" \ + -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ + case $$dist_files in \ + */*) $(MKDIR_P) `echo "$$dist_files" | \ + sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ + sort -u` ;; \ + esac; \ + for file in $$dist_files; do \ + if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ + if test -d $$d/$$file; then \ + dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ + if test -d "$(distdir)/$$file"; then \ + find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ + fi; \ + if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ + cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ + find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ + fi; \ + cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ + else \ + test -f "$(distdir)/$$file" \ + || cp -p $$d/$$file "$(distdir)/$$file" \ + || exit 1; \ + fi; \ + done + -test -n "$(am__skip_mode_fix)" \ + || find "$(distdir)" -type d ! -perm -755 \ + -exec chmod u+rwx,go+rx {} \; -o \ + ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \ + ! -type d ! -perm -400 -exec chmod a+r {} \; -o \ + ! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \ + || chmod -R a+r "$(distdir)" +dist-gzip: distdir + tardir=$(distdir) && $(am__tar) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).tar.gz + $(am__post_remove_distdir) + +dist-bzip2: distdir + tardir=$(distdir) && $(am__tar) | BZIP2=$${BZIP2--9} bzip2 -c >$(distdir).tar.bz2 + $(am__post_remove_distdir) + +dist-lzip: distdir + tardir=$(distdir) && $(am__tar) | lzip -c $${LZIP_OPT--9} >$(distdir).tar.lz + $(am__post_remove_distdir) + +dist-xz: distdir + tardir=$(distdir) && $(am__tar) | XZ_OPT=$${XZ_OPT--e} xz -c >$(distdir).tar.xz + $(am__post_remove_distdir) + +dist-tarZ: distdir + @echo WARNING: "Support for distribution archives compressed with" \ + "legacy program 'compress' is deprecated." >&2 + @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 + tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z + $(am__post_remove_distdir) + +dist-shar: distdir + @echo WARNING: "Support for shar distribution archives is" \ + "deprecated." >&2 + @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 + shar $(distdir) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).shar.gz + $(am__post_remove_distdir) + +dist-zip: distdir + -rm -f $(distdir).zip + zip -rq $(distdir).zip $(distdir) + $(am__post_remove_distdir) + +dist dist-all: + $(MAKE) $(AM_MAKEFLAGS) $(DIST_TARGETS) am__post_remove_distdir='@:' + $(am__post_remove_distdir) + +# This target untars the dist file and tries a VPATH configuration. Then +# it guarantees that the distribution is self-contained by making another +# tarfile. +distcheck: dist + case '$(DIST_ARCHIVES)' in \ + *.tar.gz*) \ + eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).tar.gz | $(am__untar) ;;\ + *.tar.bz2*) \ + bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\ + *.tar.lz*) \ + lzip -dc $(distdir).tar.lz | $(am__untar) ;;\ + *.tar.xz*) \ + xz -dc $(distdir).tar.xz | $(am__untar) ;;\ + *.tar.Z*) \ + uncompress -c $(distdir).tar.Z | $(am__untar) ;;\ + *.shar.gz*) \ + eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).shar.gz | unshar ;;\ + *.zip*) \ + unzip $(distdir).zip ;;\ + esac + chmod -R a-w $(distdir) + chmod u+w $(distdir) + mkdir $(distdir)/_build $(distdir)/_build/sub $(distdir)/_inst + chmod a-w $(distdir) + test -d $(distdir)/_build || exit 0; \ + dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \ + && dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \ + && am__cwd=`pwd` \ + && $(am__cd) $(distdir)/_build/sub \ + && ../../configure \ + $(AM_DISTCHECK_CONFIGURE_FLAGS) \ + $(DISTCHECK_CONFIGURE_FLAGS) \ + --srcdir=../.. --prefix="$$dc_install_base" \ + && $(MAKE) $(AM_MAKEFLAGS) \ + && $(MAKE) $(AM_MAKEFLAGS) dvi \ + && $(MAKE) $(AM_MAKEFLAGS) check \ + && $(MAKE) $(AM_MAKEFLAGS) install \ + && $(MAKE) $(AM_MAKEFLAGS) installcheck \ + && $(MAKE) $(AM_MAKEFLAGS) uninstall \ + && $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \ + distuninstallcheck \ + && chmod -R a-w "$$dc_install_base" \ + && ({ \ + (cd ../.. && umask 077 && mkdir "$$dc_destdir") \ + && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \ + && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \ + && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \ + distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \ + } || { rm -rf "$$dc_destdir"; exit 1; }) \ + && rm -rf "$$dc_destdir" \ + && $(MAKE) $(AM_MAKEFLAGS) dist \ + && rm -rf $(DIST_ARCHIVES) \ + && $(MAKE) $(AM_MAKEFLAGS) distcleancheck \ + && cd "$$am__cwd" \ + || exit 1 + $(am__post_remove_distdir) + @(echo "$(distdir) archives ready for distribution: "; \ + list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \ + sed -e 1h -e 1s/./=/g -e 1p -e 1x -e '$$p' -e '$$x' +distuninstallcheck: + @test -n '$(distuninstallcheck_dir)' || { \ + echo 'ERROR: trying to run $@ with an empty' \ + '$$(distuninstallcheck_dir)' >&2; \ + exit 1; \ + }; \ + $(am__cd) '$(distuninstallcheck_dir)' || { \ + echo 'ERROR: cannot chdir into $(distuninstallcheck_dir)' >&2; \ + exit 1; \ + }; \ + test `$(am__distuninstallcheck_listfiles) | wc -l` -eq 0 \ + || { echo "ERROR: files left after uninstall:" ; \ + if test -n "$(DESTDIR)"; then \ + echo " (check DESTDIR support)"; \ + fi ; \ + $(distuninstallcheck_listfiles) ; \ + exit 1; } >&2 +distcleancheck: distclean + @if test '$(srcdir)' = . ; then \ + echo "ERROR: distcleancheck can only run from a VPATH build" ; \ + exit 1 ; \ + fi + @test `$(distcleancheck_listfiles) | wc -l` -eq 0 \ + || { echo "ERROR: files left in build directory after distclean:" ; \ + $(distcleancheck_listfiles) ; \ + exit 1; } >&2 +check-am: all-am +check: check-am +all-am: Makefile $(LTLIBRARIES) $(HEADERS) config.h +installdirs: + for dir in "$(DESTDIR)$(libdir)" "$(DESTDIR)$(tgvoipincludedir)"; do \ + test -z "$$dir" || $(MKDIR_P) "$$dir"; \ + done +install: install-am +install-exec: install-exec-am +install-data: install-data-am +uninstall: uninstall-am + +install-am: all-am + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am + +installcheck: installcheck-am +install-strip: + if test -z '$(STRIP)'; then \ + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ + install; \ + else \ + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ + install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ + "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ + fi +mostlyclean-generic: + +clean-generic: + +distclean-generic: + -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) + -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) + -rm -f audio/$(DEPDIR)/$(am__dirstamp) + -rm -f audio/$(am__dirstamp) + -rm -f os/darwin/$(DEPDIR)/$(am__dirstamp) + -rm -f os/darwin/$(am__dirstamp) + -rm -f os/linux/$(DEPDIR)/$(am__dirstamp) + -rm -f os/linux/$(am__dirstamp) + -rm -f os/posix/$(DEPDIR)/$(am__dirstamp) + -rm -f os/posix/$(am__dirstamp) + -rm -f video/$(DEPDIR)/$(am__dirstamp) + -rm -f video/$(am__dirstamp) + -rm -f webrtc_dsp/absl/base/internal/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/absl/base/internal/$(am__dirstamp) + -rm -f webrtc_dsp/absl/strings/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/absl/strings/$(am__dirstamp) + -rm -f webrtc_dsp/absl/strings/internal/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/absl/strings/internal/$(am__dirstamp) + -rm -f webrtc_dsp/absl/types/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/absl/types/$(am__dirstamp) + -rm -f webrtc_dsp/api/audio/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/api/audio/$(am__dirstamp) + -rm -f webrtc_dsp/common_audio/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/common_audio/$(am__dirstamp) + -rm -f webrtc_dsp/common_audio/resampler/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/common_audio/resampler/$(am__dirstamp) + -rm -f webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/common_audio/signal_processing/$(am__dirstamp) + -rm -f webrtc_dsp/common_audio/third_party/fft4g/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/common_audio/third_party/fft4g/$(am__dirstamp) + -rm -f webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(am__dirstamp) + -rm -f webrtc_dsp/common_audio/vad/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/common_audio/vad/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/aec/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/aec3/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/aecm/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/agc/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/agc/legacy/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/agc2/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/audio_generator/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/audio_generator/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/echo_detector/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/include/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/logging/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/logging/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/ns/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/transient/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/utility/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/audio_processing/vad/$(am__dirstamp) + -rm -f webrtc_dsp/modules/third_party/fft/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/modules/third_party/fft/$(am__dirstamp) + -rm -f webrtc_dsp/rtc_base/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/rtc_base/$(am__dirstamp) + -rm -f webrtc_dsp/rtc_base/memory/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/rtc_base/memory/$(am__dirstamp) + -rm -f webrtc_dsp/rtc_base/strings/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/rtc_base/strings/$(am__dirstamp) + -rm -f webrtc_dsp/system_wrappers/source/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/system_wrappers/source/$(am__dirstamp) + -rm -f webrtc_dsp/third_party/rnnoise/src/$(DEPDIR)/$(am__dirstamp) + -rm -f webrtc_dsp/third_party/rnnoise/src/$(am__dirstamp) + +maintainer-clean-generic: + @echo "This command is intended for maintainers to use" + @echo "it deletes files that may require special tools to rebuild." +clean: clean-am + +clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ + mostlyclean-am + +distclean: distclean-am + -rm -f $(am__CONFIG_DISTCLEAN_FILES) + -rm -f ./$(DEPDIR)/Buffers.Plo + -rm -f ./$(DEPDIR)/CongestionControl.Plo + -rm -f ./$(DEPDIR)/EchoCanceller.Plo + -rm -f ./$(DEPDIR)/JitterBuffer.Plo + -rm -f ./$(DEPDIR)/MediaStreamItf.Plo + -rm -f ./$(DEPDIR)/MessageThread.Plo + -rm -f ./$(DEPDIR)/NetworkSocket.Plo + -rm -f ./$(DEPDIR)/OpusDecoder.Plo + -rm -f ./$(DEPDIR)/OpusEncoder.Plo + -rm -f ./$(DEPDIR)/PacketReassembler.Plo + -rm -f ./$(DEPDIR)/TgVoip.Plo + -rm -f ./$(DEPDIR)/VoIPController.Plo + -rm -f ./$(DEPDIR)/VoIPGroupController.Plo + -rm -f ./$(DEPDIR)/VoIPServerConfig.Plo + -rm -f ./$(DEPDIR)/json11.Plo + -rm -f ./$(DEPDIR)/logging.Plo + -rm -f ./webrtc_dsp/absl/base/internal/$(DEPDIR)/raw_logging.Plo + -rm -f ./webrtc_dsp/absl/base/internal/$(DEPDIR)/throw_delegate.Plo + -rm -f ./webrtc_dsp/absl/strings/$(DEPDIR)/ascii.Plo + -rm -f ./webrtc_dsp/absl/strings/$(DEPDIR)/string_view.Plo + -rm -f ./webrtc_dsp/absl/strings/internal/$(DEPDIR)/memutil.Plo + -rm -f ./webrtc_dsp/absl/types/$(DEPDIR)/bad_optional_access.Plo + -rm -f ./webrtc_dsp/absl/types/$(DEPDIR)/optional.Plo + -rm -f ./webrtc_dsp/api/audio/$(DEPDIR)/audio_frame.Plo + -rm -f ./webrtc_dsp/api/audio/$(DEPDIR)/echo_canceller3_config.Plo + -rm -f ./webrtc_dsp/api/audio/$(DEPDIR)/echo_canceller3_factory.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/audio_converter.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/audio_util.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/channel_buffer.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/fir_filter_c.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/fir_filter_factory.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/fir_filter_sse.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/real_fourier.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/real_fourier_ooura.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/ring_buffer.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/smoothing_filter.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/sparse_fir_filter.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/wav_file.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/wav_header.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/window_generator.Plo + -rm -f ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/push_resampler.Plo + -rm -f ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/push_sinc_resampler.Plo + -rm -f ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/resampler.Plo + -rm -f ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/sinc_resampler.Plo + -rm -f ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/sinc_resampler_sse.Plo + -rm -f ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/sinusoidal_linear_chirp_source.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/auto_corr_to_refl_coef.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/auto_correlation.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/complex_fft.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/copy_set_operations.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/cross_correlation.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/division_operations.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/dot_product_with_scale.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/downsample_fast.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/energy.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/filter_ar.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/filter_ar_fast_q12.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/filter_ma_fast_q12.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/get_hanning_window.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/get_scaling_square.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/ilbc_specific_functions.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/levinson_durbin.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/lpc_to_refl_coef.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/min_max_operations.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/randomization_functions.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/real_fft.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/refl_coef_to_lpc.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_48khz.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_by_2.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_by_2_internal.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_fractional.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/spl_init.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/spl_inl.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/spl_sqrt.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/splitting_filter1.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/sqrt_of_one_minus_x_squared.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/vector_scaling_operations.Plo + -rm -f ./webrtc_dsp/common_audio/third_party/fft4g/$(DEPDIR)/fft4g.Plo + -rm -f ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad.Plo + -rm -f ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_core.Plo + -rm -f ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_filterbank.Plo + -rm -f ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_gmm.Plo + -rm -f ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_sp.Plo + -rm -f ./webrtc_dsp/common_audio/vad/$(DEPDIR)/webrtc_vad.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/arith_routines.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/arith_routines_hist.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/arith_routines_logist.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/bandwidth_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/crc.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/decode.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/decode_bwe.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/encode.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/encode_lpc_swb.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/entropy_coding.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/filter_functions.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/filterbanks.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/intialize.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/isac.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/isac_vad.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lattice.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_analysis.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_gain_swb_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_shape_swb12_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_shape_swb16_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_gain_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_lag_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/spectrum_ar_model_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/transform.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/audio_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/audio_processing_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/echo_cancellation_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/echo_control_mobile_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/gain_control_for_experimental_agc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/gain_control_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/gain_controller2.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/level_estimator_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/low_cut_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/noise_suppression_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/residual_echo_detector.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/rms_level.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/splitting_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/three_band_filter_bank.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/typing_detection.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/voice_detection_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_core.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_resampler.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/echo_cancellation.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/adaptive_fir_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/aec3_common.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/aec3_fft.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/aec_state.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_delay_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_framer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_processor.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_processor2.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_processor_metrics.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/cascaded_biquad_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/comfort_noise_generator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/decimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/downsampled_render_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_audibility.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_canceller3.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_path_delay_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_path_variability.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_remover.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_remover_metrics.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/erl_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/erle_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/fft_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/filter_analyzer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/frame_blocker.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/fullband_erle_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/main_filter_update_gain.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/matched_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/matched_filter_lag_aggregator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/matrix_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/moving_average.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_buffer2.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_controller.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_controller2.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_controller_metrics.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_reverb_model.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_signal_analyzer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/residual_echo_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_decay_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_frequency_response.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_model.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_model_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_model_fallback.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/shadow_filter_update_gain.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/skew_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/stationarity_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subband_erle_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subtractor.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subtractor_output.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subtractor_output_analyzer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/suppression_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/suppression_gain.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/suppression_gain_limiter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/vector_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/aecm_core.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/aecm_core_c.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/echo_control_mobile.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/agc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/agc_manager_direct.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/loudness_histogram.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/utility.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR)/analog_agc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR)/digital_agc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_agc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_digital_gain_applier.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_mode_level_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_mode_level_estimator_agc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/agc2_common.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/agc2_testing_common.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/biquad_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/compute_interpolated_gain_curve.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/down_sampler.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/fixed_digital_level_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/fixed_gain_controller.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/gain_applier.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/interpolated_gain_curve.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/limiter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/limiter_db_gain_curve.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/noise_level_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/noise_spectrum_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/saturation_protector.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/signal_classifier.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/vad_with_level.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/vector_float_frame.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/features_extraction.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/fft_util.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/lp_residual.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/pitch_search.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/pitch_search_internal.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/rnn.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/spectral_features.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/spectral_features_internal.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/audio_generator/$(DEPDIR)/file_audio_generator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/circular_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/mean_variance_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/moving_max.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/normalized_covariance_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/aec_dump.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/audio_generator_factory.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/audio_processing.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/audio_processing_statistics.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/config.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/logging/$(DEPDIR)/apm_data_dumper.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/noise_suppression.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/noise_suppression_x.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/ns_core.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/nsx_core.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/nsx_core_c.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/moving_moments.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/transient_detector.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/transient_suppressor.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/wpd_node.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/wpd_tree.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/block_mean_calculator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/delay_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/delay_estimator_wrapper.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/ooura_fft.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/gmm.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/pitch_based_vad.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/pitch_internal.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/pole_zero_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/standalone_vad.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/vad_audio_proc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/vad_circular_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/voice_activity_detector.Plo + -rm -f ./webrtc_dsp/modules/third_party/fft/$(DEPDIR)/fft.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/checks.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/criticalsection.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/event.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/event_tracer.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/logging_webrtc.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/platform_file.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/platform_thread.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/platform_thread_types.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/race_checker.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/string_to_number.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/stringencode.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/stringutils.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/thread_checker_impl.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/timeutils.Plo + -rm -f ./webrtc_dsp/rtc_base/memory/$(DEPDIR)/aligned_malloc.Plo + -rm -f ./webrtc_dsp/rtc_base/strings/$(DEPDIR)/string_builder.Plo + -rm -f ./webrtc_dsp/system_wrappers/source/$(DEPDIR)/cpu_features.Plo + -rm -f ./webrtc_dsp/system_wrappers/source/$(DEPDIR)/field_trial.Plo + -rm -f ./webrtc_dsp/system_wrappers/source/$(DEPDIR)/metrics.Plo + -rm -f ./webrtc_dsp/third_party/rnnoise/src/$(DEPDIR)/kiss_fft.Plo + -rm -f ./webrtc_dsp/third_party/rnnoise/src/$(DEPDIR)/rnn_vad_weights.Plo + -rm -f audio/$(DEPDIR)/AudioIO.Plo + -rm -f audio/$(DEPDIR)/AudioIOCallback.Plo + -rm -f audio/$(DEPDIR)/AudioInput.Plo + -rm -f audio/$(DEPDIR)/AudioOutput.Plo + -rm -f audio/$(DEPDIR)/Resampler.Plo + -rm -f os/darwin/$(DEPDIR)/AudioInputAudioUnit.Plo + -rm -f os/darwin/$(DEPDIR)/AudioInputAudioUnitOSX.Plo + -rm -f os/darwin/$(DEPDIR)/AudioOutputAudioUnit.Plo + -rm -f os/darwin/$(DEPDIR)/AudioOutputAudioUnitOSX.Plo + -rm -f os/darwin/$(DEPDIR)/AudioUnitIO.Plo + -rm -f os/darwin/$(DEPDIR)/DarwinSpecific.Plo + -rm -f os/darwin/$(DEPDIR)/SampleBufferDisplayLayerRenderer.Plo + -rm -f os/darwin/$(DEPDIR)/TGVVideoRenderer.Plo + -rm -f os/darwin/$(DEPDIR)/TGVVideoSource.Plo + -rm -f os/darwin/$(DEPDIR)/VideoToolboxEncoderSource.Plo + -rm -f os/linux/$(DEPDIR)/AudioInputALSA.Plo + -rm -f os/linux/$(DEPDIR)/AudioInputPulse.Plo + -rm -f os/linux/$(DEPDIR)/AudioOutputALSA.Plo + -rm -f os/linux/$(DEPDIR)/AudioOutputPulse.Plo + -rm -f os/linux/$(DEPDIR)/AudioPulse.Plo + -rm -f os/posix/$(DEPDIR)/NetworkSocketPosix.Plo + -rm -f video/$(DEPDIR)/ScreamCongestionController.Plo + -rm -f video/$(DEPDIR)/VideoFEC.Plo + -rm -f video/$(DEPDIR)/VideoPacketSender.Plo + -rm -f video/$(DEPDIR)/VideoRenderer.Plo + -rm -f video/$(DEPDIR)/VideoSource.Plo + -rm -f webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/complex_bit_reverse.Plo + -rm -f webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/complex_bit_reverse_arm.Plo + -rm -f webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/cross_correlation_neon.Plo + -rm -f webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/downsample_fast_neon.Plo + -rm -f webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/min_max_operations_neon.Plo + -rm -f webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR)/spl_sqrt_floor.Plo + -rm -f webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR)/spl_sqrt_floor_arm.Plo + -rm -f webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_core_neon.Plo + -rm -f webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_core_sse2.Plo + -rm -f webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/aecm_core_neon.Plo + -rm -f webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/nsx_core_neon.Plo + -rm -f webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/ooura_fft_neon.Plo + -rm -f webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/ooura_fft_sse2.Plo + -rm -f webrtc_dsp/rtc_base/$(DEPDIR)/logging_mac.Plo + -rm -f Makefile +distclean-am: clean-am distclean-compile distclean-generic \ + distclean-hdr distclean-libtool distclean-tags + +dvi: dvi-am + +dvi-am: + +html: html-am + +html-am: + +info: info-am + +info-am: + +install-data-am: install-nobase_tgvoipincludeHEADERS + +install-dvi: install-dvi-am + +install-dvi-am: + +install-exec-am: install-libLTLIBRARIES + +install-html: install-html-am + +install-html-am: + +install-info: install-info-am + +install-info-am: + +install-man: + +install-pdf: install-pdf-am + +install-pdf-am: + +install-ps: install-ps-am + +install-ps-am: + +installcheck-am: + +maintainer-clean: maintainer-clean-am + -rm -f $(am__CONFIG_DISTCLEAN_FILES) + -rm -rf $(top_srcdir)/autom4te.cache + -rm -f ./$(DEPDIR)/Buffers.Plo + -rm -f ./$(DEPDIR)/CongestionControl.Plo + -rm -f ./$(DEPDIR)/EchoCanceller.Plo + -rm -f ./$(DEPDIR)/JitterBuffer.Plo + -rm -f ./$(DEPDIR)/MediaStreamItf.Plo + -rm -f ./$(DEPDIR)/MessageThread.Plo + -rm -f ./$(DEPDIR)/NetworkSocket.Plo + -rm -f ./$(DEPDIR)/OpusDecoder.Plo + -rm -f ./$(DEPDIR)/OpusEncoder.Plo + -rm -f ./$(DEPDIR)/PacketReassembler.Plo + -rm -f ./$(DEPDIR)/TgVoip.Plo + -rm -f ./$(DEPDIR)/VoIPController.Plo + -rm -f ./$(DEPDIR)/VoIPGroupController.Plo + -rm -f ./$(DEPDIR)/VoIPServerConfig.Plo + -rm -f ./$(DEPDIR)/json11.Plo + -rm -f ./$(DEPDIR)/logging.Plo + -rm -f ./webrtc_dsp/absl/base/internal/$(DEPDIR)/raw_logging.Plo + -rm -f ./webrtc_dsp/absl/base/internal/$(DEPDIR)/throw_delegate.Plo + -rm -f ./webrtc_dsp/absl/strings/$(DEPDIR)/ascii.Plo + -rm -f ./webrtc_dsp/absl/strings/$(DEPDIR)/string_view.Plo + -rm -f ./webrtc_dsp/absl/strings/internal/$(DEPDIR)/memutil.Plo + -rm -f ./webrtc_dsp/absl/types/$(DEPDIR)/bad_optional_access.Plo + -rm -f ./webrtc_dsp/absl/types/$(DEPDIR)/optional.Plo + -rm -f ./webrtc_dsp/api/audio/$(DEPDIR)/audio_frame.Plo + -rm -f ./webrtc_dsp/api/audio/$(DEPDIR)/echo_canceller3_config.Plo + -rm -f ./webrtc_dsp/api/audio/$(DEPDIR)/echo_canceller3_factory.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/audio_converter.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/audio_util.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/channel_buffer.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/fir_filter_c.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/fir_filter_factory.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/fir_filter_sse.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/real_fourier.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/real_fourier_ooura.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/ring_buffer.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/smoothing_filter.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/sparse_fir_filter.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/wav_file.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/wav_header.Plo + -rm -f ./webrtc_dsp/common_audio/$(DEPDIR)/window_generator.Plo + -rm -f ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/push_resampler.Plo + -rm -f ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/push_sinc_resampler.Plo + -rm -f ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/resampler.Plo + -rm -f ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/sinc_resampler.Plo + -rm -f ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/sinc_resampler_sse.Plo + -rm -f ./webrtc_dsp/common_audio/resampler/$(DEPDIR)/sinusoidal_linear_chirp_source.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/auto_corr_to_refl_coef.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/auto_correlation.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/complex_fft.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/copy_set_operations.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/cross_correlation.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/division_operations.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/dot_product_with_scale.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/downsample_fast.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/energy.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/filter_ar.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/filter_ar_fast_q12.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/filter_ma_fast_q12.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/get_hanning_window.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/get_scaling_square.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/ilbc_specific_functions.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/levinson_durbin.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/lpc_to_refl_coef.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/min_max_operations.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/randomization_functions.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/real_fft.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/refl_coef_to_lpc.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_48khz.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_by_2.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_by_2_internal.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/resample_fractional.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/spl_init.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/spl_inl.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/spl_sqrt.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/splitting_filter1.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/sqrt_of_one_minus_x_squared.Plo + -rm -f ./webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/vector_scaling_operations.Plo + -rm -f ./webrtc_dsp/common_audio/third_party/fft4g/$(DEPDIR)/fft4g.Plo + -rm -f ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad.Plo + -rm -f ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_core.Plo + -rm -f ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_filterbank.Plo + -rm -f ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_gmm.Plo + -rm -f ./webrtc_dsp/common_audio/vad/$(DEPDIR)/vad_sp.Plo + -rm -f ./webrtc_dsp/common_audio/vad/$(DEPDIR)/webrtc_vad.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/arith_routines.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/arith_routines_hist.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/arith_routines_logist.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/bandwidth_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/crc.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/decode.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/decode_bwe.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/encode.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/encode_lpc_swb.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/entropy_coding.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/filter_functions.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/filterbanks.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/intialize.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/isac.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/isac_vad.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lattice.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_analysis.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_gain_swb_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_shape_swb12_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_shape_swb16_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/lpc_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_gain_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/pitch_lag_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/spectrum_ar_model_tables.Plo + -rm -f ./webrtc_dsp/modules/audio_coding/codecs/isac/main/source/$(DEPDIR)/transform.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/audio_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/audio_processing_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/echo_cancellation_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/echo_control_mobile_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/gain_control_for_experimental_agc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/gain_control_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/gain_controller2.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/level_estimator_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/low_cut_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/noise_suppression_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/residual_echo_detector.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/rms_level.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/splitting_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/three_band_filter_bank.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/typing_detection.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/$(DEPDIR)/voice_detection_impl.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_core.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_resampler.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/echo_cancellation.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/adaptive_fir_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/aec3_common.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/aec3_fft.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/aec_state.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_delay_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_framer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_processor.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_processor2.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/block_processor_metrics.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/cascaded_biquad_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/comfort_noise_generator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/decimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/downsampled_render_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_audibility.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_canceller3.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_path_delay_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_path_variability.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_remover.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/echo_remover_metrics.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/erl_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/erle_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/fft_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/filter_analyzer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/frame_blocker.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/fullband_erle_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/main_filter_update_gain.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/matched_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/matched_filter_lag_aggregator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/matrix_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/moving_average.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_buffer2.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_controller.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_controller2.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_delay_controller_metrics.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_reverb_model.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/render_signal_analyzer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/residual_echo_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_decay_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_frequency_response.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_model.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_model_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/reverb_model_fallback.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/shadow_filter_update_gain.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/skew_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/stationarity_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subband_erle_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subtractor.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subtractor_output.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/subtractor_output_analyzer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/suppression_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/suppression_gain.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/suppression_gain_limiter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aec3/$(DEPDIR)/vector_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/aecm_core.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/aecm_core_c.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/echo_control_mobile.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/agc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/agc_manager_direct.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/loudness_histogram.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/$(DEPDIR)/utility.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR)/analog_agc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc/legacy/$(DEPDIR)/digital_agc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_agc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_digital_gain_applier.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_mode_level_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/adaptive_mode_level_estimator_agc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/agc2_common.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/agc2_testing_common.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/biquad_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/compute_interpolated_gain_curve.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/down_sampler.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/fixed_digital_level_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/fixed_gain_controller.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/gain_applier.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/interpolated_gain_curve.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/limiter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/limiter_db_gain_curve.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/noise_level_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/noise_spectrum_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/saturation_protector.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/signal_classifier.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/vad_with_level.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/$(DEPDIR)/vector_float_frame.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/features_extraction.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/fft_util.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/lp_residual.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/pitch_search.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/pitch_search_internal.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/rnn.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/spectral_features.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/agc2/rnn_vad/$(DEPDIR)/spectral_features_internal.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/audio_generator/$(DEPDIR)/file_audio_generator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/circular_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/mean_variance_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/moving_max.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/echo_detector/$(DEPDIR)/normalized_covariance_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/aec_dump.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/audio_generator_factory.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/audio_processing.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/audio_processing_statistics.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/include/$(DEPDIR)/config.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/logging/$(DEPDIR)/apm_data_dumper.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/noise_suppression.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/noise_suppression_x.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/ns_core.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/nsx_core.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/nsx_core_c.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/moving_moments.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/transient_detector.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/transient_suppressor.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/wpd_node.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/transient/$(DEPDIR)/wpd_tree.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/block_mean_calculator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/delay_estimator.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/delay_estimator_wrapper.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/ooura_fft.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/gmm.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/pitch_based_vad.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/pitch_internal.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/pole_zero_filter.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/standalone_vad.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/vad_audio_proc.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/vad_circular_buffer.Plo + -rm -f ./webrtc_dsp/modules/audio_processing/vad/$(DEPDIR)/voice_activity_detector.Plo + -rm -f ./webrtc_dsp/modules/third_party/fft/$(DEPDIR)/fft.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/checks.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/criticalsection.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/event.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/event_tracer.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/logging_webrtc.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/platform_file.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/platform_thread.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/platform_thread_types.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/race_checker.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/string_to_number.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/stringencode.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/stringutils.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/thread_checker_impl.Plo + -rm -f ./webrtc_dsp/rtc_base/$(DEPDIR)/timeutils.Plo + -rm -f ./webrtc_dsp/rtc_base/memory/$(DEPDIR)/aligned_malloc.Plo + -rm -f ./webrtc_dsp/rtc_base/strings/$(DEPDIR)/string_builder.Plo + -rm -f ./webrtc_dsp/system_wrappers/source/$(DEPDIR)/cpu_features.Plo + -rm -f ./webrtc_dsp/system_wrappers/source/$(DEPDIR)/field_trial.Plo + -rm -f ./webrtc_dsp/system_wrappers/source/$(DEPDIR)/metrics.Plo + -rm -f ./webrtc_dsp/third_party/rnnoise/src/$(DEPDIR)/kiss_fft.Plo + -rm -f ./webrtc_dsp/third_party/rnnoise/src/$(DEPDIR)/rnn_vad_weights.Plo + -rm -f audio/$(DEPDIR)/AudioIO.Plo + -rm -f audio/$(DEPDIR)/AudioIOCallback.Plo + -rm -f audio/$(DEPDIR)/AudioInput.Plo + -rm -f audio/$(DEPDIR)/AudioOutput.Plo + -rm -f audio/$(DEPDIR)/Resampler.Plo + -rm -f os/darwin/$(DEPDIR)/AudioInputAudioUnit.Plo + -rm -f os/darwin/$(DEPDIR)/AudioInputAudioUnitOSX.Plo + -rm -f os/darwin/$(DEPDIR)/AudioOutputAudioUnit.Plo + -rm -f os/darwin/$(DEPDIR)/AudioOutputAudioUnitOSX.Plo + -rm -f os/darwin/$(DEPDIR)/AudioUnitIO.Plo + -rm -f os/darwin/$(DEPDIR)/DarwinSpecific.Plo + -rm -f os/darwin/$(DEPDIR)/SampleBufferDisplayLayerRenderer.Plo + -rm -f os/darwin/$(DEPDIR)/TGVVideoRenderer.Plo + -rm -f os/darwin/$(DEPDIR)/TGVVideoSource.Plo + -rm -f os/darwin/$(DEPDIR)/VideoToolboxEncoderSource.Plo + -rm -f os/linux/$(DEPDIR)/AudioInputALSA.Plo + -rm -f os/linux/$(DEPDIR)/AudioInputPulse.Plo + -rm -f os/linux/$(DEPDIR)/AudioOutputALSA.Plo + -rm -f os/linux/$(DEPDIR)/AudioOutputPulse.Plo + -rm -f os/linux/$(DEPDIR)/AudioPulse.Plo + -rm -f os/posix/$(DEPDIR)/NetworkSocketPosix.Plo + -rm -f video/$(DEPDIR)/ScreamCongestionController.Plo + -rm -f video/$(DEPDIR)/VideoFEC.Plo + -rm -f video/$(DEPDIR)/VideoPacketSender.Plo + -rm -f video/$(DEPDIR)/VideoRenderer.Plo + -rm -f video/$(DEPDIR)/VideoSource.Plo + -rm -f webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/complex_bit_reverse.Plo + -rm -f webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/complex_bit_reverse_arm.Plo + -rm -f webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/cross_correlation_neon.Plo + -rm -f webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/downsample_fast_neon.Plo + -rm -f webrtc_dsp/common_audio/signal_processing/$(DEPDIR)/min_max_operations_neon.Plo + -rm -f webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR)/spl_sqrt_floor.Plo + -rm -f webrtc_dsp/common_audio/third_party/spl_sqrt_floor/$(DEPDIR)/spl_sqrt_floor_arm.Plo + -rm -f webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_core_neon.Plo + -rm -f webrtc_dsp/modules/audio_processing/aec/$(DEPDIR)/aec_core_sse2.Plo + -rm -f webrtc_dsp/modules/audio_processing/aecm/$(DEPDIR)/aecm_core_neon.Plo + -rm -f webrtc_dsp/modules/audio_processing/ns/$(DEPDIR)/nsx_core_neon.Plo + -rm -f webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/ooura_fft_neon.Plo + -rm -f webrtc_dsp/modules/audio_processing/utility/$(DEPDIR)/ooura_fft_sse2.Plo + -rm -f webrtc_dsp/rtc_base/$(DEPDIR)/logging_mac.Plo + -rm -f Makefile +maintainer-clean-am: distclean-am maintainer-clean-generic + +mostlyclean: mostlyclean-am + +mostlyclean-am: mostlyclean-compile mostlyclean-generic \ + mostlyclean-libtool + +pdf: pdf-am + +pdf-am: + +ps: ps-am + +ps-am: + +uninstall-am: uninstall-libLTLIBRARIES \ + uninstall-nobase_tgvoipincludeHEADERS + +.MAKE: all install-am install-strip + +.PHONY: CTAGS GTAGS TAGS all all-am am--depfiles am--refresh check \ + check-am clean clean-cscope clean-generic clean-libLTLIBRARIES \ + clean-libtool cscope cscopelist-am ctags ctags-am dist \ + dist-all dist-bzip2 dist-gzip dist-lzip dist-shar dist-tarZ \ + dist-xz dist-zip distcheck distclean distclean-compile \ + distclean-generic distclean-hdr distclean-libtool \ + distclean-tags distcleancheck distdir distuninstallcheck dvi \ + dvi-am html html-am info info-am install install-am \ + install-data install-data-am install-dvi install-dvi-am \ + install-exec install-exec-am install-html install-html-am \ + install-info install-info-am install-libLTLIBRARIES \ + install-man install-nobase_tgvoipincludeHEADERS install-pdf \ + install-pdf-am install-ps install-ps-am install-strip \ + installcheck installcheck-am installdirs maintainer-clean \ + maintainer-clean-generic mostlyclean mostlyclean-compile \ + mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ + tags tags-am uninstall uninstall-am uninstall-libLTLIBRARIES \ + uninstall-nobase_tgvoipincludeHEADERS + +.PRECIOUS: Makefile + + +# Tell versions [3.59,3.63) of GNU make to not export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/TMessagesProj/jni/libtgvoip2/MediaStreamItf.cpp b/TMessagesProj/jni/libtgvoip2/MediaStreamItf.cpp new file mode 100644 index 000000000..f4dddfc02 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/MediaStreamItf.cpp @@ -0,0 +1,211 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "logging.h" +#include "MediaStreamItf.h" +#include "EchoCanceller.h" +#include +#include +#include +#include + +using namespace tgvoip; + +void MediaStreamItf::SetCallback(size_t (*f)(unsigned char *, size_t, void*), void* param){ + std::lock_guard lock(m_callback); + callback=f; + callbackParam=param; +} + +size_t MediaStreamItf::InvokeCallback(unsigned char *data, size_t length){ + std::lock_guard lock(m_callback); + if(callback) + return (*callback)(data, length, callbackParam); + return 0; +} + +AudioMixer::AudioMixer() : processedQueue(16), semaphore(16, 0){ + running=false; +} + +AudioMixer::~AudioMixer(){ +} + +void AudioMixer::SetOutput(MediaStreamItf* output){ + output->SetCallback(OutputCallback, this); +} + +void AudioMixer::Start(){ + assert(!running); + running=true; + thread=new Thread(std::bind(&AudioMixer::RunThread, this)); + thread->SetName("AudioMixer"); + thread->Start(); +} + +void AudioMixer::Stop(){ + if(!running){ + LOGE("Tried to stop AudioMixer that wasn't started"); + return; + } + running=false; + semaphore.Release(); + thread->Join(); + delete thread; + thread=NULL; +} + +void AudioMixer::DoCallback(unsigned char *data, size_t length){ + //memset(data, 0, 960*2); + //LOGD("audio mixer callback, %d inputs", inputs.size()); + if(processedQueue.Size()==0) + semaphore.Release(2); + else + semaphore.Release(); + Buffer buf=processedQueue.GetBlocking(); + memcpy(data, *buf, 960*2); +} + +size_t AudioMixer::OutputCallback(unsigned char *data, size_t length, void *arg){ + ((AudioMixer*)arg)->DoCallback(data, length); + return 960*2; +} + +void AudioMixer::AddInput(std::shared_ptr input){ + MutexGuard m(inputsMutex); + MixerInput in; + in.multiplier=1; + in.source=input; + inputs.push_back(in); +} + +void AudioMixer::RemoveInput(std::shared_ptr input){ + MutexGuard m(inputsMutex); + for(std::vector::iterator i=inputs.begin();i!=inputs.end();++i){ + if(i->source==input){ + inputs.erase(i); + return; + } + } +} + +void AudioMixer::SetInputVolume(std::shared_ptr input, float volumeDB){ + MutexGuard m(inputsMutex); + for(std::vector::iterator i=inputs.begin();i!=inputs.end();++i){ + if(i->source==input){ + if(volumeDB==-INFINITY) + i->multiplier=0; + else + i->multiplier=expf(volumeDB/20.0f * logf(10.0f)); + return; + } + } +} + +void AudioMixer::RunThread(){ + LOGV("AudioMixer thread started"); + while(running){ + semaphore.Acquire(); + if(!running) + break; + + try{ + Buffer data=bufferPool.Get(); + //LOGV("Audio mixer processing a frame"); + MutexGuard m(inputsMutex); + int16_t *buf=reinterpret_cast(*data); + int16_t input[960]; + float out[960]; + memset(out, 0, 960*4); + int usedInputs=0; + for(std::vector::iterator in=inputs.begin(); in!=inputs.end(); ++in){ + size_t res=in->source->InvokeCallback(reinterpret_cast(input), 960*2); + if(!res || in->multiplier==0){ + //LOGV("AudioMixer: skipping silent packet"); + continue; + } + usedInputs++; + float k=in->multiplier; + if(k!=1){ + for(size_t i=0; i<960; i++){ + out[i]+=(float) input[i]*k; + } + }else{ + for(size_t i=0; i<960; i++){ + out[i]+=(float) input[i]; + } + } + } + if(usedInputs>0){ + for(size_t i=0; i<960; i++){ + if(out[i]>32767.0f) + buf[i]=INT16_MAX; + else if(out[i]<-32768.0f) + buf[i]=INT16_MIN; + else + buf[i]=(int16_t) out[i]; + } + }else{ + memset(*data, 0, 960*2); + } + if(echoCanceller) + echoCanceller->SpeakerOutCallback(*data, 960*2); + processedQueue.Put(std::move(data)); + }catch(std::bad_alloc& x){ + LOGE("AudioMixer: no buffers left"); + continue; + } + } + LOGI("======== audio mixer thread exiting ========="); +} + +void AudioMixer::SetEchoCanceller(EchoCanceller *aec){ + echoCanceller=aec; +} + +AudioLevelMeter::AudioLevelMeter(){ + absMax=0; + count=0; + currentLevel=0; + currentLevelFullRange=0; +} + +float AudioLevelMeter::GetLevel(){ + return currentLevel/9.0f; +} + +void AudioLevelMeter::Update(int16_t *samples, size_t count){ + // Number of bars on the indicator. + // Note that the number of elements is specified because we are indexing it + // in the range of 0-32 + const int8_t permutation[33]={0,1,2,3,4,4,5,5,5,5,6,6,6,6,6,7,7,7,7,8,8,8,9,9,9,9,9,9,9,9,9,9,9}; + int16_t absValue=0; + for(unsigned int k=0;kabsValue) + absValue=absolute; + } + + if(absValue>absMax) + absMax = absValue; + // Update level approximately 10 times per second + if (this->count++==10){ + currentLevelFullRange=absMax; + this->count=0; + // Highest value for a int16_t is 0x7fff = 32767 + // Divide with 1000 to get in the range of 0-32 which is the range of + // the permutation vector + int32_t position=absMax/1000; + // Make it less likely that the bar stays at position 0. I.e. only if + // its in the range 0-250 (instead of 0-1000) + /*if ((position==0) && (absMax>250)){ + position=1; + }*/ + currentLevel=permutation[position]; + // Decay the absolute maximum (divide by 4) + absMax >>= 2; + } +} diff --git a/TMessagesProj/jni/libtgvoip2/MediaStreamItf.h b/TMessagesProj/jni/libtgvoip2/MediaStreamItf.h new file mode 100644 index 000000000..adfe401c3 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/MediaStreamItf.h @@ -0,0 +1,91 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_MEDIASTREAMINPUT_H +#define LIBTGVOIP_MEDIASTREAMINPUT_H + +#include +#include +#include +#include +#include +#include "threading.h" +#include "BlockingQueue.h" +#include "Buffers.h" + +namespace tgvoip{ + + class EchoCanceller; + +class MediaStreamItf { +public: + virtual void Start() = 0; + virtual void Stop() = 0; + void SetCallback(size_t (*f)(unsigned char*, size_t, void*), void* param); + +//protected: + size_t InvokeCallback(unsigned char* data, size_t length); + + virtual ~MediaStreamItf() = default; +private: + size_t (*callback)(unsigned char*, size_t, void*) = NULL; + std::mutex m_callback; + void* callbackParam; +}; + + class AudioMixer : public MediaStreamItf{ + public: + AudioMixer(); + virtual ~AudioMixer(); + void SetOutput(MediaStreamItf* output); + virtual void Start(); + virtual void Stop(); + void AddInput(std::shared_ptr input); + void RemoveInput(std::shared_ptr input); + void SetInputVolume(std::shared_ptr input, float volumeDB); + void SetEchoCanceller(EchoCanceller* aec); + private: + void RunThread(); + struct MixerInput{ + std::shared_ptr source; + float multiplier; + }; + Mutex inputsMutex; + void DoCallback(unsigned char* data, size_t length); + static size_t OutputCallback(unsigned char* data, size_t length, void* arg); + std::vector inputs; + Thread* thread; + BufferPool<960*2, 16> bufferPool; + BlockingQueue processedQueue; + Semaphore semaphore; + EchoCanceller* echoCanceller; + bool running; + }; + + class CallbackWrapper : public MediaStreamItf{ + public: + CallbackWrapper(){}; + virtual ~CallbackWrapper(){}; + virtual void Start(){}; + virtual void Stop(){}; + + }; + + class AudioLevelMeter{ + public: + AudioLevelMeter(); + float GetLevel(); + void Update(int16_t* samples, size_t count); + private: + int16_t absMax; + int16_t count; + int8_t currentLevel; + int16_t currentLevelFullRange; + }; +}; + + +#endif //LIBTGVOIP_MEDIASTREAMINPUT_H diff --git a/TMessagesProj/jni/libtgvoip2/MessageThread.cpp b/TMessagesProj/jni/libtgvoip2/MessageThread.cpp new file mode 100644 index 000000000..73acc909b --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/MessageThread.cpp @@ -0,0 +1,182 @@ +// +// Created by Grishka on 17.06.2018. +// + +#include +#include +#include +#include +#include + +#ifndef _WIN32 +#include +#endif + +#include "MessageThread.h" +#include "VoIPController.h" +#include "logging.h" + +using namespace tgvoip; + +MessageThread::MessageThread() : Thread(std::bind(&MessageThread::Run, this)){ + running=true; + SetName("MessageThread"); + +#ifdef _WIN32 +#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY!=WINAPI_FAMILY_PHONE_APP + event=CreateEvent(NULL, false, false, NULL); +#else + event=CreateEventEx(NULL, NULL, 0, EVENT_ALL_ACCESS); +#endif +#else + pthread_cond_init(&cond, NULL); +#endif +} + +MessageThread::~MessageThread(){ + Stop(); +#ifdef _WIN32 + CloseHandle(event); +#else + pthread_cond_destroy(&cond); +#endif +} + +void MessageThread::Stop(){ + if(running){ + running=false; +#ifdef _WIN32 + SetEvent(event); +#else + pthread_cond_signal(&cond); +#endif + Join(); + } +} + +void MessageThread::Run(){ + queueMutex.Lock(); + while(running){ + double currentTime=VoIPController::GetCurrentTime(); + double waitTimeout; + { + MutexGuard _m(queueAccessMutex); + waitTimeout=queue.empty() ? DBL_MAX : (queue[0].deliverAt-currentTime); + } + //LOGW("MessageThread wait timeout %f", waitTimeout); + if(waitTimeout>0.0){ +#ifdef _WIN32 + queueMutex.Unlock(); + DWORD actualWaitTimeout=waitTimeout==DBL_MAX ? INFINITE : ((DWORD)round(waitTimeout*1000.0)); +#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY!=WINAPI_FAMILY_PHONE_APP + WaitForSingleObject(event, actualWaitTimeout); +#else + WaitForSingleObjectEx(event, actualWaitTimeout, false); +#endif + // we don't really care if a context switch happens here and anything gets added to the queue by another thread + // since any new no-delay messages will get delivered on this iteration anyway + queueMutex.Lock(); +#else + if(waitTimeout!=DBL_MAX){ + struct timeval now; + struct timespec timeout; + gettimeofday(&now, NULL); + waitTimeout+=now.tv_sec; + waitTimeout+=(now.tv_usec/1000000.0); + timeout.tv_sec=(time_t)(floor(waitTimeout)); + timeout.tv_nsec=(long)((waitTimeout-floor(waitTimeout))*1000000000.0); + pthread_cond_timedwait(&cond, queueMutex.NativeHandle(), &timeout); + }else{ + pthread_cond_wait(&cond, queueMutex.NativeHandle()); + } +#endif + } + if(!running){ + queueMutex.Unlock(); + return; + } + currentTime=VoIPController::GetCurrentTime(); + std::vector msgsToDeliverNow; + { + MutexGuard _m(queueAccessMutex); + for(std::vector::iterator m=queue.begin();m!=queue.end();){ + if(m->deliverAt==0.0 || currentTime>=m->deliverAt){ + msgsToDeliverNow.push_back(*m); + m=queue.erase(m); + continue; + } + ++m; + } + } + + for(Message& m:msgsToDeliverNow){ + //LOGI("MessageThread delivering %u", m.msg); + cancelCurrent=false; + if(m.deliverAt==0.0) + m.deliverAt=VoIPController::GetCurrentTime(); + if(m.func!=nullptr){ + m.func(); + } + if(!cancelCurrent && m.interval>0.0){ + m.deliverAt+=m.interval; + InsertMessageInternal(m); + } + } + + } + queueMutex.Unlock(); +} + +uint32_t MessageThread::Post(std::function func, double delay, double interval){ + assert(delay>=0); + //LOGI("MessageThread post [function] delay %f", delay); + double currentTime=VoIPController::GetCurrentTime(); + Message m{lastMessageID++, delay==0.0 ? 0.0 : (currentTime+delay), interval, func}; + InsertMessageInternal(m); + if(!IsCurrent()){ +#ifdef _WIN32 + SetEvent(event); +#else + pthread_cond_signal(&cond); +#endif + } + return m.id; +} + +void MessageThread::InsertMessageInternal(MessageThread::Message &m){ + MutexGuard _m(queueAccessMutex); + if(queue.empty()){ + queue.push_back(m); + }else{ + if(queue[0].deliverAt>m.deliverAt){ + queue.insert(queue.begin(), m); + }else{ + std::vector::iterator insertAfter=queue.begin(); + for(; insertAfter!=queue.end(); ++insertAfter){ + std::vector::iterator next=std::next(insertAfter); + if(next==queue.end() || (next->deliverAt>m.deliverAt && insertAfter->deliverAt<=m.deliverAt)){ + queue.insert(next, m); + break; + } + } + } + } +} + +void MessageThread::Cancel(uint32_t id){ + MutexGuard _m(queueAccessMutex); + + for(std::vector::iterator m=queue.begin();m!=queue.end();){ + if(m->id==id){ + m=queue.erase(m); + }else{ + ++m; + } + } + +} + +void MessageThread::CancelSelf(){ + assert(IsCurrent()); + cancelCurrent=true; +} diff --git a/TMessagesProj/jni/libtgvoip2/MessageThread.h b/TMessagesProj/jni/libtgvoip2/MessageThread.h new file mode 100644 index 000000000..d81870abe --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/MessageThread.h @@ -0,0 +1,54 @@ +// +// Created by Grishka on 17.06.2018. +// + +#ifndef LIBTGVOIP_MESSAGETHREAD_H +#define LIBTGVOIP_MESSAGETHREAD_H + +#include "threading.h" +#include "utils.h" +#include +#include +#include + +namespace tgvoip{ + class MessageThread : public Thread{ + public: + TGVOIP_DISALLOW_COPY_AND_ASSIGN(MessageThread); + MessageThread(); + virtual ~MessageThread(); + uint32_t Post(std::function func, double delay=0, double interval=0); + void Cancel(uint32_t id); + void CancelSelf(); + void Stop(); + + enum{ + INVALID_ID=0 + }; + private: + struct Message{ + uint32_t id; + double deliverAt; + double interval; + std::function func; + }; + + void Run(); + void InsertMessageInternal(Message& m); + + std::atomic running; + std::vector queue; + Mutex queueMutex; + Mutex queueAccessMutex; + uint32_t lastMessageID=1; + bool cancelCurrent=false; + +#ifdef _WIN32 + HANDLE event; +#else + pthread_cond_t cond; +#endif + }; +} + +#endif //LIBTGVOIP_MESSAGETHREAD_H diff --git a/TMessagesProj/jni/libtgvoip2/NetworkSocket.cpp b/TMessagesProj/jni/libtgvoip2/NetworkSocket.cpp new file mode 100644 index 000000000..53567da70 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/NetworkSocket.cpp @@ -0,0 +1,650 @@ +// +// Created by Grishka on 29.03.17. +// + +#include +#include +#include +#include +#if defined(_WIN32) +#include +#include "os/windows/NetworkSocketWinsock.h" +#else +#include "os/posix/NetworkSocketPosix.h" +#endif +#include "logging.h" +#include "VoIPServerConfig.h" +#include "VoIPController.h" +#include "Buffers.h" +#include "NetworkSocket.h" + +#define MIN_UDP_PORT 16384 +#define MAX_UDP_PORT 32768 + +using namespace tgvoip; + +NetworkSocket::NetworkSocket(NetworkProtocol protocol) : protocol(protocol){ + ipv6Timeout=ServerConfig::GetSharedInstance()->GetDouble("nat64_fallback_timeout", 3); + failed=false; +} + +NetworkSocket::~NetworkSocket(){ + +} + +std::string NetworkSocket::GetLocalInterfaceInfo(NetworkAddress *inet4addr, NetworkAddress *inet6addr){ + std::string r="not implemented"; + return r; +} + +uint16_t NetworkSocket::GenerateLocalPort(){ + uint16_t rnd; + VoIPController::crypto.rand_bytes(reinterpret_cast(&rnd), 2); + return (uint16_t) ((rnd%(MAX_UDP_PORT-MIN_UDP_PORT))+MIN_UDP_PORT); +} + +void NetworkSocket::SetMaxPriority(){ +} + +bool NetworkSocket::IsFailed(){ + return failed; +} + +NetworkSocket *NetworkSocket::Create(NetworkProtocol protocol){ +#ifndef _WIN32 + return new NetworkSocketPosix(protocol); +#else + return new NetworkSocketWinsock(protocol); +#endif +} + +NetworkAddress NetworkSocket::ResolveDomainName(std::string name){ +#ifndef _WIN32 + return NetworkSocketPosix::ResolveDomainName(name); +#else + return NetworkSocketWinsock::ResolveDomainName(name); +#endif +} + +void NetworkSocket::GenerateTCPO2States(unsigned char* buffer, TCPO2State* recvState, TCPO2State* sendState){ + memset(recvState, 0, sizeof(TCPO2State)); + memset(sendState, 0, sizeof(TCPO2State)); + unsigned char nonce[64]; + uint32_t *first = reinterpret_cast(nonce), *second = first + 1; + uint32_t first1 = 0x44414548U, first2 = 0x54534f50U, first3 = 0x20544547U, first4 = 0x20544547U, first5 = 0xeeeeeeeeU; + uint32_t second1 = 0; + do { + VoIPController::crypto.rand_bytes(nonce, sizeof(nonce)); + } while (*first == first1 || *first == first2 || *first == first3 || *first == first4 || *first == first5 || *second == second1 || *reinterpret_cast(nonce) == 0xef); + + // prepare encryption key/iv + memcpy(sendState->key, nonce + 8, 32); + memcpy(sendState->iv, nonce + 8 + 32, 16); + + // prepare decryption key/iv + char reversed[48]; + memcpy(reversed, nonce + 8, sizeof(reversed)); + std::reverse(reversed, reversed + sizeof(reversed)); + memcpy(recvState->key, reversed, 32); + memcpy(recvState->iv, reversed + 32, 16); + + // write protocol identifier + *reinterpret_cast(nonce + 56) = 0xefefefefU; + memcpy(buffer, nonce, 56); + EncryptForTCPO2(nonce, sizeof(nonce), sendState); + memcpy(buffer+56, nonce+56, 8); +} + +void NetworkSocket::EncryptForTCPO2(unsigned char *buffer, size_t len, TCPO2State *state){ + VoIPController::crypto.aes_ctr_encrypt(buffer, len, state->key, state->iv, state->ecount, &state->num); +} + +size_t NetworkSocket::Receive(unsigned char *buffer, size_t len){ + NetworkPacket pkt=Receive(len); + if(pkt.IsEmpty()) + return 0; + size_t actualLen=std::min(len, pkt.data.Length()); + memcpy(buffer, *pkt.data, actualLen); + return actualLen; +} + +bool NetworkAddress::operator==(const NetworkAddress &other) const{ + if(isIPv6!=other.isIPv6) + return false; + if(!isIPv6){ + return addr.ipv4==other.addr.ipv4; + } + return memcmp(addr.ipv6, other.addr.ipv6, 16)==0; +} + +bool NetworkAddress::operator!=(const NetworkAddress &other) const{ + return !(*this == other); +} + +std::string NetworkAddress::ToString() const{ + if(isIPv6){ +#ifndef _WIN32 + return NetworkSocketPosix::V6AddressToString(addr.ipv6); +#else + return NetworkSocketWinsock::V6AddressToString(addr.ipv6); +#endif + }else{ +#ifndef _WIN32 + return NetworkSocketPosix::V4AddressToString(addr.ipv4); +#else + return NetworkSocketWinsock::V4AddressToString(addr.ipv4); +#endif + } +} + +bool NetworkAddress::IsEmpty() const{ + if(isIPv6){ + const uint64_t* a=reinterpret_cast(addr.ipv6); + return a[0]==0LL && a[1]==0LL; + } + return addr.ipv4==0; +} + +bool NetworkAddress::PrefixMatches(const unsigned int prefix, const NetworkAddress &other) const{ + if(isIPv6!=other.isIPv6) + return false; + if(!isIPv6){ + uint32_t mask=0xFFFFFFFF << (32-prefix); + return (addr.ipv4 & mask) == (other.addr.ipv4 & mask); + } + return false; +} + +NetworkAddress NetworkAddress::Empty(){ + NetworkAddress addr; + addr.isIPv6=false; + addr.addr.ipv4=0; + return addr; +} + +NetworkAddress NetworkAddress::IPv4(std::string str){ + NetworkAddress addr; + addr.isIPv6=false; +#ifndef _WIN32 + addr.addr.ipv4=NetworkSocketPosix::StringToV4Address(str); +#else + addr.addr.ipv4=NetworkSocketWinsock::StringToV4Address(str); +#endif + return addr; +} + +NetworkAddress NetworkAddress::IPv4(uint32_t addr){ + NetworkAddress a; + a.isIPv6=false; + a.addr.ipv4=addr; + return a; +} + +NetworkAddress NetworkAddress::IPv6(std::string str){ + NetworkAddress addr; + addr.isIPv6=false; +#ifndef _WIN32 + NetworkSocketPosix::StringToV6Address(str, addr.addr.ipv6); +#else + NetworkSocketWinsock::StringToV6Address(str, addr.addr.ipv6); +#endif + return addr; +} + +NetworkAddress NetworkAddress::IPv6(const uint8_t addr[16]){ + NetworkAddress a; + a.isIPv6=true; + memcpy(a.addr.ipv6, addr, 16); + return a; +} + +bool NetworkSocket::Select(std::vector &readFds, std::vector &writeFds, std::vector &errorFds, SocketSelectCanceller *canceller){ +#ifndef _WIN32 + return NetworkSocketPosix::Select(readFds, writeFds, errorFds, canceller); +#else + return NetworkSocketWinsock::Select(readFds, writeFds, errorFds, canceller); +#endif +} + +SocketSelectCanceller::~SocketSelectCanceller(){ + +} + +SocketSelectCanceller *SocketSelectCanceller::Create(){ +#ifndef _WIN32 + return new SocketSelectCancellerPosix(); +#else + return new SocketSelectCancellerWin32(); +#endif +} + + + +NetworkSocketTCPObfuscated::NetworkSocketTCPObfuscated(NetworkSocket *wrapped) : NetworkSocketWrapper(NetworkProtocol::TCP){ + this->wrapped=wrapped; +} + +NetworkSocketTCPObfuscated::~NetworkSocketTCPObfuscated(){ + if(wrapped) + delete wrapped; +} + +NetworkSocket *NetworkSocketTCPObfuscated::GetWrapped(){ + return wrapped; +} + +void NetworkSocketTCPObfuscated::InitConnection(){ + Buffer buf(64); + GenerateTCPO2States(*buf, &recvState, &sendState); + wrapped->Send(NetworkPacket{ + std::move(buf), + NetworkAddress::Empty(), + 0, + NetworkProtocol::TCP + }); +} + +void NetworkSocketTCPObfuscated::Send(NetworkPacket packet){ + BufferOutputStream os(packet.data.Length()+4); + size_t len=packet.data.Length()/4; + if(len<0x7F){ + os.WriteByte((unsigned char)len); + }else{ + os.WriteByte(0x7F); + os.WriteByte((unsigned char)(len & 0xFF)); + os.WriteByte((unsigned char)((len >> 8) & 0xFF)); + os.WriteByte((unsigned char)((len >> 16) & 0xFF)); + } + os.WriteBytes(packet.data); + EncryptForTCPO2(os.GetBuffer(), os.GetLength(), &sendState); + wrapped->Send(NetworkPacket{ + Buffer(std::move(os)), + NetworkAddress::Empty(), + 0, + NetworkProtocol::TCP + }); + //LOGD("Sent %u bytes", os.GetLength()); +} + +bool NetworkSocketTCPObfuscated::OnReadyToSend(){ + LOGV("TCPO socket ready to send"); + if(!initialized){ + LOGV("Initializing TCPO2 connection"); + initialized=true; + InitConnection(); + readyToSend=true; + return false; + } + return wrapped->OnReadyToSend(); +} + +NetworkPacket NetworkSocketTCPObfuscated::Receive(size_t maxLen){ + unsigned char len1; + size_t packetLen=0; + size_t offset=0; + size_t len; + len=wrapped->Receive(&len1, 1); + if(len<=0){ + return NetworkPacket::Empty(); + } + EncryptForTCPO2(&len1, 1, &recvState); + + if(len1<0x7F){ + packetLen=(size_t)len1*4; + }else{ + unsigned char len2[3]; + len=wrapped->Receive(len2, 3); + if(len<=0){ + return NetworkPacket::Empty(); + } + EncryptForTCPO2(len2, 3, &recvState); + packetLen=((size_t)len2[0] | ((size_t)len2[1] << 8) | ((size_t)len2[2] << 16))*4; + } + + if(packetLen>1500){ + LOGW("packet too big to fit into buffer (%u vs %u)", (unsigned int)packetLen, (unsigned int)1500); + return NetworkPacket::Empty(); + } + Buffer buf(packetLen); + + while(offsetReceive(*buf, packetLen-offset); + if(len<=0){ + return NetworkPacket::Empty(); + } + offset+=len; + } + EncryptForTCPO2(*buf, packetLen, &recvState); + return NetworkPacket{ + std::move(buf), + wrapped->GetConnectedAddress(), + wrapped->GetConnectedPort(), + NetworkProtocol::TCP + }; +} + +void NetworkSocketTCPObfuscated::Open(){ + +} + +void NetworkSocketTCPObfuscated::Close(){ + wrapped->Close(); +} + +void NetworkSocketTCPObfuscated::Connect(const NetworkAddress address, uint16_t port){ + wrapped->Connect(address, port); +} + +bool NetworkSocketTCPObfuscated::IsFailed(){ + return wrapped->IsFailed(); +} + +NetworkSocketSOCKS5Proxy::NetworkSocketSOCKS5Proxy(NetworkSocket *tcp, NetworkSocket *udp, std::string username, std::string password) : NetworkSocketWrapper(udp ? NetworkProtocol::UDP : NetworkProtocol::TCP){ + this->tcp=tcp; + this->udp=udp; + this->username=username; + this->password=password; +} + +NetworkSocketSOCKS5Proxy::~NetworkSocketSOCKS5Proxy(){ + delete tcp; +} + +void NetworkSocketSOCKS5Proxy::Send(NetworkPacket packet){ + if(protocol==NetworkProtocol::TCP){ + tcp->Send(std::move(packet)); + }else if(protocol==NetworkProtocol::UDP){ + BufferOutputStream out(1500); + out.WriteInt16(0); // RSV + out.WriteByte(0); // FRAG + if(!packet.address.isIPv6){ + out.WriteByte(1); // ATYP (IPv4) + out.WriteInt32(packet.address.addr.ipv4); + }else{ + out.WriteByte(4); // ATYP (IPv6) + out.WriteBytes(packet.address.addr.ipv6, 16); + } + out.WriteInt16(htons(packet.port)); + out.WriteBytes(packet.data); + udp->Send(NetworkPacket{ + Buffer(std::move(out)), + connectedAddress, + connectedPort, + NetworkProtocol::UDP + }); + } +} + +NetworkPacket NetworkSocketSOCKS5Proxy::Receive(size_t maxLen){ + if(protocol==NetworkProtocol::TCP){ + NetworkPacket packet=tcp->Receive(); + packet.address=connectedAddress; + packet.port=connectedPort; + return packet; + }else{ + NetworkPacket p=udp->Receive(); + if(!p.IsEmpty() && p.address==connectedAddress && p.port==connectedPort){ + BufferInputStream in(p.data); + in.ReadInt16(); // RSV + in.ReadByte(); // FRAG + unsigned char atyp=in.ReadByte(); + NetworkAddress address=NetworkAddress::Empty(); + if(atyp==1){ // IPv4 + address=NetworkAddress::IPv4((uint32_t) in.ReadInt32()); + }else if(atyp==4){ // IPv6 + unsigned char addr[16]; + in.ReadBytes(addr, 16); + address=NetworkAddress::IPv6(addr); + } + return NetworkPacket{ + Buffer::CopyOf(p.data, in.GetOffset(), in.Remaining()), + address, + htons(in.ReadInt16()), + protocol + }; + } + } + return NetworkPacket::Empty(); +} + +void NetworkSocketSOCKS5Proxy::Open(){ + +} + +void NetworkSocketSOCKS5Proxy::Close(){ + tcp->Close(); +} + +void NetworkSocketSOCKS5Proxy::Connect(const NetworkAddress address, uint16_t port){ + connectedAddress=address; + connectedPort=port; +} + +NetworkSocket *NetworkSocketSOCKS5Proxy::GetWrapped(){ + return protocol==NetworkProtocol::TCP ? tcp : udp; +} + +void NetworkSocketSOCKS5Proxy::InitConnection(){ +} + +bool NetworkSocketSOCKS5Proxy::IsFailed(){ + return NetworkSocket::IsFailed() || tcp->IsFailed(); +} + +NetworkAddress NetworkSocketSOCKS5Proxy::GetConnectedAddress(){ + return connectedAddress; +} + +uint16_t NetworkSocketSOCKS5Proxy::GetConnectedPort(){ + return connectedPort; +} + +bool NetworkSocketSOCKS5Proxy::OnReadyToSend(){ + //LOGV("on ready to send, state=%d", state); + if(state==ConnectionState::Initial){ + BufferOutputStream p(16); + p.WriteByte(5); // VER + if(!username.empty()){ + p.WriteByte(2); // NMETHODS + p.WriteByte(0); // no auth + p.WriteByte(2); // user/pass + }else{ + p.WriteByte(1); // NMETHODS + p.WriteByte(0); // no auth + } + tcp->Send(NetworkPacket{ + Buffer(std::move(p)), + NetworkAddress::Empty(), + 0, + NetworkProtocol::TCP + }); + state=ConnectionState::WaitingForAuthMethod; + return false; + } + return udp ? udp->OnReadyToSend() : tcp->OnReadyToSend(); +} + +bool NetworkSocketSOCKS5Proxy::OnReadyToReceive(){ + //LOGV("on ready to receive state=%d", state); + unsigned char buf[1024]; + if(state==ConnectionState::WaitingForAuthMethod){ + size_t l=tcp->Receive(buf, sizeof(buf)); + if(l<2 || tcp->IsFailed()){ + failed=true; + return false; + } + BufferInputStream in(buf, l); + unsigned char ver=in.ReadByte(); + unsigned char chosenMethod=in.ReadByte(); + LOGV("socks5: VER=%02X, METHOD=%02X", ver, chosenMethod); + if(ver!=5){ + LOGW("socks5: incorrect VER in response"); + failed=true; + return false; + } + if(chosenMethod==0){ + // connected, no further auth needed + SendConnectionCommand(); + }else if(chosenMethod==2 && !username.empty()){ + BufferOutputStream p(512); + p.WriteByte(1); // VER + p.WriteByte((unsigned char)(username.length()>255 ? 255 : username.length())); // ULEN + p.WriteBytes((unsigned char*)username.c_str(), username.length()>255 ? 255 : username.length()); // UNAME + p.WriteByte((unsigned char)(password.length()>255 ? 255 : password.length())); // PLEN + p.WriteBytes((unsigned char*)password.c_str(), password.length()>255 ? 255 : password.length()); // PASSWD + tcp->Send(NetworkPacket{ + Buffer(std::move(p)), + NetworkAddress::Empty(), + 0, + NetworkProtocol::TCP + }); + state=ConnectionState::WaitingForAuthResult; + }else{ + LOGW("socks5: unsupported auth method"); + failed=true; + return false; + } + return false; + }else if(state==ConnectionState::WaitingForAuthResult){ + size_t l=tcp->Receive(buf, sizeof(buf)); + if(l<2 || tcp->IsFailed()){ + failed=true; + return false; + } + BufferInputStream in(buf, l); + uint8_t ver=in.ReadByte(); + unsigned char status=in.ReadByte(); + LOGV("socks5: auth response VER=%02X, STATUS=%02X", ver, status); + if(ver!=1){ + LOGW("socks5: auth response VER is incorrect"); + failed=true; + return false; + } + if(status!=0){ + LOGW("socks5: username/password auth failed"); + failed=true; + return false; + } + LOGV("socks5: authentication succeeded"); + SendConnectionCommand(); + return false; + }else if(state==ConnectionState::WaitingForCommandResult){ + size_t l=tcp->Receive(buf, sizeof(buf)); + if(protocol==NetworkProtocol::TCP){ + if(l<2 || tcp->IsFailed()){ + LOGW("socks5: connect failed") + failed=true; + return false; + } + BufferInputStream in(buf, l); + unsigned char ver=in.ReadByte(); + if(ver!=5){ + LOGW("socks5: connect: wrong ver in response"); + failed=true; + return false; + } + unsigned char rep=in.ReadByte(); + if(rep!=0){ + LOGW("socks5: connect: failed with error %02X", rep); + failed=true; + return false; + } + LOGV("socks5: connect succeeded"); + state=ConnectionState::Connected; + tcp=new NetworkSocketTCPObfuscated(tcp); + readyToSend=true; + return tcp->OnReadyToSend(); + }else if(protocol==NetworkProtocol::UDP){ + if(l<2 || tcp->IsFailed()){ + LOGW("socks5: udp associate failed"); + failed=true; + return false; + } + try{ + BufferInputStream in(buf, l); + unsigned char ver=in.ReadByte(); + unsigned char rep=in.ReadByte(); + if(ver!=5){ + LOGW("socks5: udp associate: wrong ver in response"); + failed=true; + return false; + } + if(rep!=0){ + LOGW("socks5: udp associate failed with error %02X", rep); + failed=true; + return false; + } + in.ReadByte(); // RSV + unsigned char atyp=in.ReadByte(); + if(atyp==1){ + uint32_t addr=(uint32_t) in.ReadInt32(); + connectedAddress=NetworkAddress::IPv4(addr); + }else if(atyp==3){ + unsigned char len=in.ReadByte(); + char domain[256]; + memset(domain, 0, sizeof(domain)); + in.ReadBytes((unsigned char*)domain, len); + LOGD("address type is domain, address=%s", domain); + connectedAddress=ResolveDomainName(std::string(domain)); + if(connectedAddress.IsEmpty()){ + LOGW("socks5: failed to resolve domain name '%s'", domain); + failed=true; + return false; + } + }else if(atyp==4){ + unsigned char addr[16]; + in.ReadBytes(addr, 16); + connectedAddress=NetworkAddress::IPv6(addr); + }else{ + LOGW("socks5: unknown address type %d", atyp); + failed=true; + return false; + } + connectedPort=(uint16_t)ntohs(in.ReadInt16()); + state=ConnectionState::Connected; + readyToSend=true; + LOGV("socks5: udp associate successful, given endpoint %s:%d", connectedAddress.ToString().c_str(), connectedPort); + }catch(std::out_of_range& x){ + LOGW("socks5: udp associate response parse failed"); + failed=true; + } + } + } + return udp ? udp->OnReadyToReceive() : tcp->OnReadyToReceive(); +} + +void NetworkSocketSOCKS5Proxy::SendConnectionCommand(){ + BufferOutputStream out(1024); + if(protocol==NetworkProtocol::TCP){ + out.WriteByte(5); // VER + out.WriteByte(1); // CMD (CONNECT) + out.WriteByte(0); // RSV + if(!connectedAddress.isIPv6){ + out.WriteByte(1); // ATYP (IPv4) + out.WriteInt32(connectedAddress.addr.ipv4); + }else{ + out.WriteByte(4); // ATYP (IPv6) + out.WriteBytes((unsigned char*)connectedAddress.addr.ipv6, 16); + } + out.WriteInt16(htons(connectedPort)); // DST.PORT + }else if(protocol==NetworkProtocol::UDP){ + LOGV("Sending udp associate"); + out.WriteByte(5); // VER + out.WriteByte(3); // CMD (UDP ASSOCIATE) + out.WriteByte(0); // RSV + out.WriteByte(1); // ATYP (IPv4) + out.WriteInt32(0); // DST.ADDR + out.WriteInt16(0); // DST.PORT + } + tcp->Send(NetworkPacket{ + Buffer(std::move(out)), + NetworkAddress::Empty(), + 0, + NetworkProtocol::TCP + }); + state=ConnectionState::WaitingForCommandResult; +} + +bool NetworkSocketSOCKS5Proxy::NeedSelectForSending(){ + return state==ConnectionState::Initial || state==ConnectionState::Connected; +} diff --git a/TMessagesProj/jni/libtgvoip2/NetworkSocket.h b/TMessagesProj/jni/libtgvoip2/NetworkSocket.h new file mode 100644 index 000000000..58dfab3ba --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/NetworkSocket.h @@ -0,0 +1,201 @@ +// +// Created by Grishka on 29.03.17. +// + +#ifndef LIBTGVOIP_NETWORKSOCKET_H +#define LIBTGVOIP_NETWORKSOCKET_H + +#include +#include +#include +#include +#include +#include "utils.h" +#include "Buffers.h" + +namespace tgvoip { + + enum class NetworkProtocol{ + UDP=0, + TCP + }; + + struct TCPO2State{ + unsigned char key[32]; + unsigned char iv[16]; + unsigned char ecount[16]; + uint32_t num; + }; + + class NetworkAddress{ + public: + virtual std::string ToString() const; + bool operator==(const NetworkAddress& other) const; + bool operator!=(const NetworkAddress& other) const; + virtual ~NetworkAddress()=default; + virtual bool IsEmpty() const; + virtual bool PrefixMatches(const unsigned int prefix, const NetworkAddress& other) const; + + static NetworkAddress Empty(); + static NetworkAddress IPv4(std::string str); + static NetworkAddress IPv4(uint32_t addr); + static NetworkAddress IPv6(std::string str); + static NetworkAddress IPv6(const uint8_t addr[16]); + + bool isIPv6=false; + union{ + uint32_t ipv4; + uint8_t ipv6[16]; + } addr; + + private: + NetworkAddress(){}; + }; + + struct NetworkPacket{ + TGVOIP_MOVE_ONLY(NetworkPacket); + Buffer data; + NetworkAddress address; + uint16_t port; + NetworkProtocol protocol; + + static NetworkPacket Empty(){ + return NetworkPacket{Buffer(), NetworkAddress::Empty(), 0, NetworkProtocol::UDP}; + } + + bool IsEmpty(){ + return data.IsEmpty() || (protocol==NetworkProtocol::UDP && (port==0 || address.IsEmpty())); + } + }; + + class SocketSelectCanceller{ + public: + virtual ~SocketSelectCanceller(); + virtual void CancelSelect()=0; + static SocketSelectCanceller* Create(); + }; + + class NetworkSocket{ + public: + friend class NetworkSocketPosix; + friend class NetworkSocketWinsock; + + TGVOIP_DISALLOW_COPY_AND_ASSIGN(NetworkSocket); + NetworkSocket(NetworkProtocol protocol); + virtual ~NetworkSocket(); + virtual void Send(NetworkPacket packet)=0; + virtual NetworkPacket Receive(size_t maxLen=0)=0; + size_t Receive(unsigned char* buffer, size_t len); + virtual void Open()=0; + virtual void Close()=0; + virtual uint16_t GetLocalPort(){ return 0; }; + virtual void Connect(const NetworkAddress address, uint16_t port)=0; + virtual std::string GetLocalInterfaceInfo(NetworkAddress* inet4addr, NetworkAddress* inet6addr); + virtual void OnActiveInterfaceChanged(){}; + virtual NetworkAddress GetConnectedAddress(){ return NetworkAddress::Empty(); }; + virtual uint16_t GetConnectedPort(){ return 0; }; + virtual void SetTimeouts(int sendTimeout, int recvTimeout){}; + + virtual bool IsFailed(); + virtual bool IsReadyToSend(){ + return readyToSend; + } + virtual bool OnReadyToSend(){ readyToSend=true; return true; }; + virtual bool OnReadyToReceive(){ return true; }; + void SetTimeout(double timeout){ + this->timeout=timeout; + }; + + static NetworkSocket* Create(NetworkProtocol protocol); + static NetworkAddress ResolveDomainName(std::string name); + static bool Select(std::vector& readFds, std::vector& writeFds, std::vector& errorFds, SocketSelectCanceller* canceller); + + protected: + virtual uint16_t GenerateLocalPort(); + virtual void SetMaxPriority(); + + static void GenerateTCPO2States(unsigned char* buffer, TCPO2State* recvState, TCPO2State* sendState); + static void EncryptForTCPO2(unsigned char* buffer, size_t len, TCPO2State* state); + double ipv6Timeout; + unsigned char nat64Prefix[12]; + std::atomic failed; + bool readyToSend=false; + double lastSuccessfulOperationTime=0.0; + double timeout=0.0; + NetworkProtocol protocol; + }; + + class NetworkSocketWrapper : public NetworkSocket{ + public: + NetworkSocketWrapper(NetworkProtocol protocol) : NetworkSocket(protocol){}; + virtual ~NetworkSocketWrapper(){}; + virtual NetworkSocket* GetWrapped()=0; + virtual void InitConnection()=0; + virtual void SetNonBlocking(bool){}; + }; + + class NetworkSocketTCPObfuscated : public NetworkSocketWrapper{ + public: + NetworkSocketTCPObfuscated(NetworkSocket* wrapped); + virtual ~NetworkSocketTCPObfuscated(); + virtual NetworkSocket* GetWrapped(); + virtual void InitConnection(); + virtual void Send(NetworkPacket packet) override; + virtual NetworkPacket Receive(size_t maxLen) override; + virtual void Open(); + virtual void Close(); + virtual void Connect(const NetworkAddress address, uint16_t port); + virtual bool OnReadyToSend(); + + virtual bool IsFailed(); + virtual bool IsReadyToSend(){ + return readyToSend && wrapped->IsReadyToSend(); + }; + + private: + NetworkSocket* wrapped; + TCPO2State recvState; + TCPO2State sendState; + bool initialized=false; + }; + + class NetworkSocketSOCKS5Proxy : public NetworkSocketWrapper{ + public: + NetworkSocketSOCKS5Proxy(NetworkSocket* tcp, NetworkSocket* udp, std::string username, std::string password); + virtual ~NetworkSocketSOCKS5Proxy(); + virtual void Send(NetworkPacket packet) override; + virtual NetworkPacket Receive(size_t maxLen) override; + virtual void Open() override; + virtual void Close(); + virtual void Connect(const NetworkAddress address, uint16_t port); + virtual NetworkSocket *GetWrapped(); + virtual void InitConnection(); + virtual bool IsFailed(); + virtual NetworkAddress GetConnectedAddress(); + virtual uint16_t GetConnectedPort(); + virtual bool OnReadyToSend(); + virtual bool OnReadyToReceive(); + + bool NeedSelectForSending(); + + private: + void SendConnectionCommand(); + enum ConnectionState{ + Initial, + WaitingForAuthMethod, + WaitingForAuthResult, + WaitingForCommandResult, + Connected + }; + NetworkSocket* tcp; + NetworkSocket* udp; + std::string username; + std::string password; + NetworkAddress connectedAddress=NetworkAddress::Empty(); + uint16_t connectedPort; + ConnectionState state=ConnectionState::Initial; + }; + +} + +#endif //LIBTGVOIP_NETWORKSOCKET_H diff --git a/TMessagesProj/jni/libtgvoip2/OpusDecoder.cpp b/TMessagesProj/jni/libtgvoip2/OpusDecoder.cpp new file mode 100644 index 000000000..effd8e6c5 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/OpusDecoder.cpp @@ -0,0 +1,287 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "OpusDecoder.h" +#include "audio/Resampler.h" +#include "logging.h" +#include +#include +#include +#if defined HAVE_CONFIG_H || defined TGVOIP_USE_INSTALLED_OPUS +#include +#else +#include "opus.h" +#endif + +#include "VoIPController.h" + +#define PACKET_SIZE (960 * 2) + +using namespace tgvoip; + +tgvoip::OpusDecoder::OpusDecoder(const std::shared_ptr& dst, bool isAsync, bool needEC) { + dst->SetCallback(OpusDecoder::Callback, this); + Initialize(isAsync, needEC); +} + +tgvoip::OpusDecoder::OpusDecoder(const std::unique_ptr& dst, bool isAsync, bool needEC) { + dst->SetCallback(OpusDecoder::Callback, this); + Initialize(isAsync, needEC); +} + +tgvoip::OpusDecoder::OpusDecoder(MediaStreamItf* dst, bool isAsync, bool needEC) { + dst->SetCallback(OpusDecoder::Callback, this); + Initialize(isAsync, needEC); +} + +void tgvoip::OpusDecoder::Initialize(bool isAsync, bool needEC) { + async = isAsync; + if (async) { + decodedQueue = new BlockingQueue(33); + semaphore = new Semaphore(32, 0); + } else { + decodedQueue = NULL; + semaphore = NULL; + } + dec=opus_decoder_create(48000, 1, NULL); + if (needEC) + ecDec = opus_decoder_create(48000, 1, NULL); + else + ecDec = NULL; + // todo buffer = reinterpret_cast(aligned_alloc(2, 8192)); + buffer=(unsigned char *) malloc(8192); + lastDecoded = NULL; + outputBufferSize = 0; + echoCanceller = NULL; + frameDuration = 20; + consecutiveLostPackets = 0; + enableDTX = false; + silentPacketCount = 0; + levelMeter = NULL; + nextLen = 0; + running = false; + remainingDataLen = 0; + processedBuffer = NULL; + prevWasEC = false; + prevLastSample = 0; +} + +tgvoip::OpusDecoder::~OpusDecoder() { + opus_decoder_destroy(dec); + if (ecDec) + opus_decoder_destroy(ecDec); + free(buffer); + if (decodedQueue) + delete decodedQueue; + if (semaphore) + delete semaphore; +} + + +void tgvoip::OpusDecoder::SetEchoCanceller(EchoCanceller* canceller) { + echoCanceller = canceller; +} + +size_t tgvoip::OpusDecoder::Callback(unsigned char* data, size_t len, void* param) { + return (reinterpret_cast(param)->HandleCallback(data, len)); +} + +size_t tgvoip::OpusDecoder::HandleCallback(unsigned char* data, size_t len) { + if (async) { + if (!running) { + memset(data, 0, len); + return 0; + } + if (outputBufferSize == 0) { + outputBufferSize = len; + int packetsNeeded; + if (len > PACKET_SIZE) + packetsNeeded = len / PACKET_SIZE; + else + packetsNeeded = 1; + packetsNeeded *= 2; + semaphore->Release(packetsNeeded); + } + assert(outputBufferSize == len && "output buffer size is supposed to be the same throughout callbacks"); + if (len == PACKET_SIZE) { + Buffer lastDecoded=decodedQueue->GetBlocking(); + if (lastDecoded.IsEmpty()) + return 0; + memcpy(data, *lastDecoded, PACKET_SIZE); + semaphore->Release(); + if (silentPacketCount > 0) { + silentPacketCount--; + if (levelMeter) + levelMeter->Update(reinterpret_cast(data), 0); + return 0; + } + if (echoCanceller) { + echoCanceller->SpeakerOutCallback(data, PACKET_SIZE); + } + } else { + LOGE("Opus decoder buffer length != 960 samples"); + abort(); + } + } else { + if (remainingDataLen == 0 && silentPacketCount == 0) { + int duration = DecodeNextFrame(); + remainingDataLen = static_cast(duration) / 20 * 960 * 2; + } + if (silentPacketCount > 0 || remainingDataLen == 0 || !processedBuffer){ + if (silentPacketCount > 0) + silentPacketCount--; + memset(data, 0, 960 * 2); + if (levelMeter) + levelMeter->Update(reinterpret_cast(data), 0); + return 0; + } + memcpy(data, processedBuffer, 960 * 2); + remainingDataLen -= 960 * 2; + if (remainingDataLen > 0) { + memmove(processedBuffer, processedBuffer + 960 * 2, remainingDataLen); + } + } + if (levelMeter) + levelMeter->Update(reinterpret_cast(data), len / 2); + return len; +} + + +void tgvoip::OpusDecoder::Start() { + if (!async) + return; + running = true; + thread = new Thread(std::bind(&tgvoip::OpusDecoder::RunThread, this)); + thread->SetName("opus_decoder"); + thread->SetMaxPriority(); + thread->Start(); +} + +void tgvoip::OpusDecoder::Stop() { + if (!running || !async) + return; + running = false; + semaphore->Release(); + thread->Join(); + delete thread; +} + +void tgvoip::OpusDecoder::RunThread() { + LOGI("decoder: packets per frame %d", packetsPerFrame); + while(running) { + int playbackDuration = DecodeNextFrame(); + for (int i = 0; i < playbackDuration / 20; i++) { + semaphore->Acquire(); + if (!running) { + LOGI("==== decoder exiting ===="); + return; + } + try { + Buffer buf=bufferPool.Get(); + if (remainingDataLen > 0) { + for (effects::AudioEffect*& effect:postProcEffects) { + effect->Process(reinterpret_cast(processedBuffer+(PACKET_SIZE * i)), 960); + } + buf.CopyFrom(processedBuffer + (PACKET_SIZE * i), 0, PACKET_SIZE); + } else { + //LOGE("Error decoding, result=%d", size); + memset(*buf, 0, PACKET_SIZE); + } + decodedQueue->Put(std::move(buf)); + } catch (const std::bad_alloc&) { + LOGW("decoder: no buffers left!"); + } + } + } +} + +int tgvoip::OpusDecoder::DecodeNextFrame() { + int playbackDuration = 0; + bool isEC = false; + size_t len = jitterBuffer->HandleOutput(buffer, 8192, 0, true, playbackDuration, isEC); + bool fec = false; + if (!len) { + fec = true; + len = jitterBuffer->HandleOutput(buffer, 8192, 0, false, playbackDuration, isEC); + //if(len) + // LOGV("Trying FEC..."); + } + int size; + if (len) { + size = opus_decode(isEC ? ecDec : dec, buffer, len, reinterpret_cast(decodeBuffer), packetsPerFrame * 960, fec ? 1 : 0); + consecutiveLostPackets = 0; + if (prevWasEC != isEC && size) { + // It turns out the waveforms generated by the PLC feature are also great to help smooth out the + // otherwise audible transition between the frames from different decoders. Those are basically an extrapolation + // of the previous successfully decoded data -- which is exactly what we need here. + size = opus_decode(prevWasEC ? ecDec : dec, NULL, 0, reinterpret_cast(nextBuffer), packetsPerFrame * 960, 0); + if (size) { + int16_t* plcSamples = reinterpret_cast(nextBuffer); + int16_t* samples = reinterpret_cast(decodeBuffer); + constexpr float coeffs[] = {0.999802f, 0.995062f, 0.984031f, 0.966778f, 0.943413f, 0.914084f, 0.878975f, 0.838309f, 0.792344f, 0.741368f, + 0.685706f, 0.625708f, 0.561754f, 0.494249f, 0.423619f, 0.350311f, 0.274788f, 0.197527f, 0.119018f, 0.039757f}; + for (int i = 0; i < 20; i++) { + samples[i] = static_cast(round(plcSamples[i] * coeffs[i] + samples[i] * (1.f - coeffs[i]))); + } + } + } + prevWasEC = isEC; + prevLastSample = decodeBuffer[size - 1]; + } else { // do packet loss concealment + consecutiveLostPackets++; + if (consecutiveLostPackets > 2 && enableDTX) { + silentPacketCount += packetsPerFrame; + size = packetsPerFrame * 960; + } else { + size = opus_decode(prevWasEC ? ecDec : dec, NULL, 0, reinterpret_cast(decodeBuffer), packetsPerFrame * 960, 0); + //LOGV("PLC"); + } + } + if (size < 0) + LOGW("decoder: opus_decode error %d", size); + remainingDataLen = size; + if (playbackDuration == 80) { + processedBuffer = buffer; + audio::Resampler::Rescale60To80(reinterpret_cast(decodeBuffer), + reinterpret_cast(processedBuffer)); + } else if (playbackDuration == 40) { + processedBuffer = buffer; + audio::Resampler::Rescale60To40(reinterpret_cast(decodeBuffer), + reinterpret_cast(processedBuffer)); + } else { + processedBuffer = decodeBuffer; + } + return playbackDuration; +} + + +void tgvoip::OpusDecoder::SetFrameDuration(uint32_t duration) { + frameDuration = duration; + packetsPerFrame = frameDuration / 20; +} + + +void tgvoip::OpusDecoder::SetJitterBuffer(std::shared_ptr jitterBuffer) { + this->jitterBuffer = jitterBuffer; +} + +void tgvoip::OpusDecoder::SetDTX(bool enable) { + enableDTX = enable; +} + +void tgvoip::OpusDecoder::SetLevelMeter(AudioLevelMeter* levelMeter) { + this->levelMeter = levelMeter; +} + +void tgvoip::OpusDecoder::AddAudioEffect(effects::AudioEffect* effect) { + postProcEffects.push_back(effect); +} + +void tgvoip::OpusDecoder::RemoveAudioEffect(effects::AudioEffect *effect) { + std::vector::iterator it = std::find(postProcEffects.begin(), postProcEffects.end(), effect); + if (it != postProcEffects.end()) + postProcEffects.erase(it); +} diff --git a/TMessagesProj/jni/libtgvoip2/OpusDecoder.h b/TMessagesProj/jni/libtgvoip2/OpusDecoder.h new file mode 100644 index 000000000..9b2bf9c2d --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/OpusDecoder.h @@ -0,0 +1,81 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_OPUSDECODER_H +#define LIBTGVOIP_OPUSDECODER_H + + +#include "MediaStreamItf.h" +#include "threading.h" +#include "BlockingQueue.h" +#include "Buffers.h" +#include "EchoCanceller.h" +#include "JitterBuffer.h" +#include "utils.h" +#include +#include +#include +#include + +struct OpusDecoder; + +namespace tgvoip{ +class OpusDecoder { +public: + TGVOIP_DISALLOW_COPY_AND_ASSIGN(OpusDecoder); + virtual void Start(); + + virtual void Stop(); + + OpusDecoder(const std::shared_ptr& dst, bool isAsync, bool needEC); + OpusDecoder(const std::unique_ptr& dst, bool isAsync, bool needEC); + OpusDecoder(MediaStreamItf* dst, bool isAsync, bool needEC); + virtual ~OpusDecoder(); + size_t HandleCallback(unsigned char* data, size_t len); + void SetEchoCanceller(EchoCanceller* canceller); + void SetFrameDuration(uint32_t duration); + void SetJitterBuffer(std::shared_ptr jitterBuffer); + void SetDTX(bool enable); + void SetLevelMeter(AudioLevelMeter* levelMeter); + void AddAudioEffect(effects::AudioEffect* effect); + void RemoveAudioEffect(effects::AudioEffect* effect); + +private: + void Initialize(bool isAsync, bool needEC); + static size_t Callback(unsigned char* data, size_t len, void* param); + void RunThread(); + int DecodeNextFrame(); + ::OpusDecoder* dec; + ::OpusDecoder* ecDec; + BlockingQueue* decodedQueue; + BufferPool<960*2, 32> bufferPool; + unsigned char* buffer; + unsigned char* lastDecoded; + unsigned char* processedBuffer; + size_t outputBufferSize; + std::atomic running; + Thread* thread; + Semaphore* semaphore; + uint32_t frameDuration; + EchoCanceller* echoCanceller; + std::shared_ptr jitterBuffer; + AudioLevelMeter* levelMeter; + int consecutiveLostPackets; + bool enableDTX; + size_t silentPacketCount; + std::vector postProcEffects; + std::atomic async; + alignas(2) unsigned char nextBuffer[8192]; + alignas(2) unsigned char decodeBuffer[8192]; + size_t nextLen; + unsigned int packetsPerFrame; + ptrdiff_t remainingDataLen; + bool prevWasEC; + int16_t prevLastSample; +}; +} + +#endif //LIBTGVOIP_OPUSDECODER_H diff --git a/TMessagesProj/jni/libtgvoip2/OpusEncoder.cpp b/TMessagesProj/jni/libtgvoip2/OpusEncoder.cpp new file mode 100644 index 000000000..008cbc19b --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/OpusEncoder.cpp @@ -0,0 +1,265 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "OpusEncoder.h" +#include +#include +#include "logging.h" +#include "VoIPServerConfig.h" +#if defined HAVE_CONFIG_H || defined TGVOIP_USE_INSTALLED_OPUS +#include +#else +#include "opus.h" +#endif + +namespace{ + int serverConfigValueToBandwidth(int config){ + switch(config){ + case 0: + return OPUS_BANDWIDTH_NARROWBAND; + case 1: + return OPUS_BANDWIDTH_MEDIUMBAND; + case 2: + return OPUS_BANDWIDTH_WIDEBAND; + case 3: + return OPUS_BANDWIDTH_SUPERWIDEBAND; + case 4: + default: + return OPUS_BANDWIDTH_FULLBAND; + } + } +} + +tgvoip::OpusEncoder::OpusEncoder(MediaStreamItf *source, bool needSecondary):queue(10){ + this->source=source; + source->SetCallback(tgvoip::OpusEncoder::Callback, this); + enc=opus_encoder_create(48000, 1, OPUS_APPLICATION_VOIP, NULL); + opus_encoder_ctl(enc, OPUS_SET_COMPLEXITY(10)); + opus_encoder_ctl(enc, OPUS_SET_PACKET_LOSS_PERC(1)); + opus_encoder_ctl(enc, OPUS_SET_INBAND_FEC(1)); + opus_encoder_ctl(enc, OPUS_SET_SIGNAL(OPUS_SIGNAL_VOICE)); + opus_encoder_ctl(enc, OPUS_SET_BANDWIDTH(OPUS_AUTO)); + requestedBitrate=20000; + currentBitrate=0; + running=false; + echoCanceller=NULL; + complexity=10; + frameDuration=20; + levelMeter=NULL; + vadNoVoiceBitrate=static_cast(ServerConfig::GetSharedInstance()->GetInt("audio_vad_no_voice_bitrate", 6000)); + vadModeVoiceBandwidth=serverConfigValueToBandwidth(ServerConfig::GetSharedInstance()->GetInt("audio_vad_bandwidth", 3)); + vadModeNoVoiceBandwidth=serverConfigValueToBandwidth(ServerConfig::GetSharedInstance()->GetInt("audio_vad_no_voice_bandwidth", 0)); + secondaryEnabledBandwidth=serverConfigValueToBandwidth(ServerConfig::GetSharedInstance()->GetInt("audio_extra_ec_bandwidth", 2)); + secondaryEncoderEnabled=false; + + if(needSecondary){ + secondaryEncoder=opus_encoder_create(48000, 1, OPUS_APPLICATION_VOIP, NULL); + opus_encoder_ctl(secondaryEncoder, OPUS_SET_COMPLEXITY(10)); + opus_encoder_ctl(secondaryEncoder, OPUS_SET_SIGNAL(OPUS_SIGNAL_VOICE)); + opus_encoder_ctl(secondaryEncoder, OPUS_SET_BITRATE(8000)); + }else{ + secondaryEncoder=NULL; + } +} + +tgvoip::OpusEncoder::~OpusEncoder(){ + opus_encoder_destroy(enc); + if(secondaryEncoder) + opus_encoder_destroy(secondaryEncoder); +} + +void tgvoip::OpusEncoder::Start(){ + if(running) + return; + running=true; + thread=new Thread(std::bind(&tgvoip::OpusEncoder::RunThread, this)); + thread->SetName("OpusEncoder"); + thread->SetMaxPriority(); + thread->Start(); +} + +void tgvoip::OpusEncoder::Stop(){ + if(!running) + return; + running=false; + queue.Put(Buffer()); + thread->Join(); + delete thread; +} + + +void tgvoip::OpusEncoder::SetBitrate(uint32_t bitrate){ + requestedBitrate=bitrate; +} + +void tgvoip::OpusEncoder::Encode(int16_t* data, size_t len){ + if(requestedBitrate!=currentBitrate){ + opus_encoder_ctl(enc, OPUS_SET_BITRATE(requestedBitrate)); + currentBitrate=requestedBitrate; + LOGV("opus_encoder: setting bitrate to %u", currentBitrate); + } + if(levelMeter) + levelMeter->Update(data, len); + if(secondaryEncoderEnabled!=wasSecondaryEncoderEnabled){ + wasSecondaryEncoderEnabled=secondaryEncoderEnabled; + } + int32_t r=opus_encode(enc, data, static_cast(len), buffer, 4096); +// int bw; +// opus_encoder_ctl(enc, OPUS_GET_BANDWIDTH(&bw)); +// LOGV("Opus bandwidth: %d", bw); + if(r<=0){ + LOGE("Error encoding: %d", r); + }else if(r==1){ + LOGW("DTX"); + }else if(running){ + //LOGV("Packet size = %d", r); + int32_t secondaryLen=0; + unsigned char secondaryBuffer[128]; + if(secondaryEncoderEnabled && secondaryEncoder){ + secondaryLen=opus_encode(secondaryEncoder, data, static_cast(len), secondaryBuffer, sizeof(secondaryBuffer)); + //LOGV("secondaryLen %d", secondaryLen); + } + InvokeCallback(buffer, (size_t)r, secondaryBuffer, (size_t)secondaryLen); + } +} + +size_t tgvoip::OpusEncoder::Callback(unsigned char *data, size_t len, void* param){ + assert(len==960*2); + OpusEncoder* e=(OpusEncoder*)param; + try{ + Buffer buf=e->bufferPool.Get(); + buf.CopyFrom(data, 0, 960*2); + e->queue.Put(std::move(buf)); + }catch(std::bad_alloc& x){ + LOGW("opus_encoder: no buffer slots left"); + if(e->complexity>1){ + e->complexity--; + opus_encoder_ctl(e->enc, OPUS_SET_COMPLEXITY(e->complexity)); + } + } + return 0; +} + + +uint32_t tgvoip::OpusEncoder::GetBitrate(){ + return requestedBitrate; +} + +void tgvoip::OpusEncoder::SetEchoCanceller(EchoCanceller* aec){ + echoCanceller=aec; +} + +void tgvoip::OpusEncoder::RunThread(){ + uint32_t bufferedCount=0; + uint32_t packetsPerFrame=frameDuration/20; + LOGV("starting encoder, packets per frame=%d", packetsPerFrame); + int16_t* frame; + if(packetsPerFrame>1) + frame=(int16_t*) malloc(960*2*packetsPerFrame); + else + frame=NULL; + bool frameHasVoice=false; + bool wasVadMode=false; + while(running){ + Buffer _packet=queue.GetBlocking(); + if(!_packet.IsEmpty()){ + int16_t* packet=(int16_t*)*_packet; + bool hasVoice=true; + if(echoCanceller) + echoCanceller->ProcessInput(packet, 960, hasVoice); + if(!postProcEffects.empty()){ + for(effects::AudioEffect* effect:postProcEffects){ + effect->Process(packet, 960); + } + } + if(packetsPerFrame==1){ + Encode(packet, 960); + }else{ + memcpy(frame+(960*bufferedCount), packet, 960*2); + frameHasVoice=frameHasVoice || hasVoice; + bufferedCount++; + if(bufferedCount==packetsPerFrame){ + if(vadMode){ + if(frameHasVoice){ + opus_encoder_ctl(enc, OPUS_SET_BITRATE(currentBitrate)); + if(secondaryEncoder){ + opus_encoder_ctl(secondaryEncoder, OPUS_SET_BITRATE(currentBitrate)); + } + }else{ + opus_encoder_ctl(enc, OPUS_SET_BITRATE(vadNoVoiceBitrate)); + if(secondaryEncoder){ + opus_encoder_ctl(secondaryEncoder, OPUS_SET_BITRATE(vadNoVoiceBitrate)); + } + } + wasVadMode=true; + }else if(wasVadMode){ + wasVadMode=false; + opus_encoder_ctl(enc, OPUS_SET_BITRATE(currentBitrate)); + if(secondaryEncoder){ + opus_encoder_ctl(secondaryEncoder, OPUS_SET_BITRATE(currentBitrate)); + } + } + Encode(frame, 960*packetsPerFrame); + bufferedCount=0; + frameHasVoice=false; + } + } + }else{ + break; + } + } + if(frame) + free(frame); +} + + +void tgvoip::OpusEncoder::SetOutputFrameDuration(uint32_t duration){ + frameDuration=duration; +} + + +void tgvoip::OpusEncoder::SetPacketLoss(int percent){ + packetLossPercent=std::min(20, percent); + opus_encoder_ctl(enc, OPUS_SET_PACKET_LOSS_PERC(packetLossPercent)); + opus_encoder_ctl(enc, OPUS_SET_INBAND_FEC(percent>0 && !secondaryEncoderEnabled ? 1 : 0)); +} + +int tgvoip::OpusEncoder::GetPacketLoss(){ + return packetLossPercent; +} + +void tgvoip::OpusEncoder::SetDTX(bool enable){ + opus_encoder_ctl(enc, OPUS_SET_DTX(enable ? 1 : 0)); +} + +void tgvoip::OpusEncoder::SetLevelMeter(tgvoip::AudioLevelMeter *levelMeter){ + this->levelMeter=levelMeter; +} + +void tgvoip::OpusEncoder::SetCallback(std::function f){ + callback=f; +} + +void tgvoip::OpusEncoder::InvokeCallback(unsigned char *data, size_t length, unsigned char *secondaryData, size_t secondaryLength){ + callback(data, length, secondaryData, secondaryLength); +} + +void tgvoip::OpusEncoder::SetSecondaryEncoderEnabled(bool enabled){ + secondaryEncoderEnabled=enabled; +} + +void tgvoip::OpusEncoder::SetVadMode(bool vad){ + vadMode=vad; +} +void tgvoip::OpusEncoder::AddAudioEffect(effects::AudioEffect *effect){ + postProcEffects.push_back(effect); +} + +void tgvoip::OpusEncoder::RemoveAudioEffect(effects::AudioEffect *effect){ + std::vector::iterator i=std::find(postProcEffects.begin(), postProcEffects.end(), effect); + if(i!=postProcEffects.end()) + postProcEffects.erase(i); +} diff --git a/TMessagesProj/jni/libtgvoip2/OpusEncoder.h b/TMessagesProj/jni/libtgvoip2/OpusEncoder.h new file mode 100644 index 000000000..5226abba2 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/OpusEncoder.h @@ -0,0 +1,82 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_OPUSENCODER_H +#define LIBTGVOIP_OPUSENCODER_H + + +#include "MediaStreamItf.h" +#include "threading.h" +#include "BlockingQueue.h" +#include "Buffers.h" +#include "EchoCanceller.h" +#include "utils.h" + +#include +#include + +struct OpusEncoder; + +namespace tgvoip{ +class OpusEncoder{ +public: + TGVOIP_DISALLOW_COPY_AND_ASSIGN(OpusEncoder); + OpusEncoder(MediaStreamItf* source, bool needSecondary); + virtual ~OpusEncoder(); + virtual void Start(); + virtual void Stop(); + void SetBitrate(uint32_t bitrate); + void SetEchoCanceller(EchoCanceller* aec); + void SetOutputFrameDuration(uint32_t duration); + void SetPacketLoss(int percent); + int GetPacketLoss(); + uint32_t GetBitrate(); + void SetDTX(bool enable); + void SetLevelMeter(AudioLevelMeter* levelMeter); + void SetCallback(std::function callback); + void SetSecondaryEncoderEnabled(bool enabled); + void SetVadMode(bool vad); + void AddAudioEffect(effects::AudioEffect* effect); + void RemoveAudioEffect(effects::AudioEffect* effect); + int GetComplexity(){ + return complexity; + } + +private: + static size_t Callback(unsigned char* data, size_t len, void* param); + void RunThread(); + void Encode(int16_t* data, size_t len); + void InvokeCallback(unsigned char* data, size_t length, unsigned char* secondaryData, size_t secondaryLength); + MediaStreamItf* source; + ::OpusEncoder* enc; + ::OpusEncoder* secondaryEncoder; + unsigned char buffer[4096]; + std::atomic requestedBitrate; + uint32_t currentBitrate; + Thread* thread; + BlockingQueue queue; + BufferPool<960*2, 10> bufferPool; + EchoCanceller* echoCanceller; + std::atomic complexity; + std::atomic running; + uint32_t frameDuration; + int packetLossPercent; + AudioLevelMeter* levelMeter; + std::atomic secondaryEncoderEnabled; + bool vadMode=false; + uint32_t vadNoVoiceBitrate; + std::vector postProcEffects; + int secondaryEnabledBandwidth; + int vadModeVoiceBandwidth; + int vadModeNoVoiceBandwidth; + + bool wasSecondaryEncoderEnabled=false; + + std::function callback; +}; +} + +#endif //LIBTGVOIP_OPUSENCODER_H diff --git a/TMessagesProj/jni/libtgvoip2/PacketReassembler.cpp b/TMessagesProj/jni/libtgvoip2/PacketReassembler.cpp new file mode 100644 index 000000000..f47c44be0 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/PacketReassembler.cpp @@ -0,0 +1,226 @@ +// +// Created by Grishka on 19.03.2018. +// + +#include "PacketReassembler.h" +#include "logging.h" +#include "PrivateDefines.h" +#include "video/VideoFEC.h" + +#include +#include + +#define NUM_OLD_PACKETS 3 +#define NUM_FEC_PACKETS 10 + +using namespace tgvoip; +using namespace tgvoip::video; + +PacketReassembler::PacketReassembler(){ +} + +PacketReassembler::~PacketReassembler(){ +} + +void PacketReassembler::Reset(){ + +} + +void PacketReassembler::AddFragment(Buffer pkt, unsigned int fragmentIndex, unsigned int fragmentCount, uint32_t pts, uint8_t _fseq, bool keyframe, uint16_t rotation){ + for(std::unique_ptr& packet:packets){ + if(packet->timestamp==pts){ + if(fragmentCount!=packet->partCount){ + LOGE("Received fragment total count %u inconsistent with previous %u", fragmentCount, packet->partCount); + return; + } + if(fragmentIndex>=packet->partCount){ + LOGE("Received fragment index %u is greater than total %u", fragmentIndex, fragmentCount); + return; + } + packet->AddFragment(std::move(pkt), fragmentIndex); + return; + } + } + uint32_t fseq=(lastFrameSeq & 0xFFFFFF00) | (uint32_t)_fseq; + if((uint8_t)lastFrameSeq>_fseq) + fseq+=256; + //LOGV("fseq: %u", (unsigned int)fseq); + + /*if(pts3 && fseq=fragmentCount){ + LOGE("Received fragment index %u is out of bounds %u", fragmentIndex, fragmentCount); + return; + } + if(fragmentCount>255){ + LOGE("Received fragment total count too big %u", fragmentCount); + return; + } + + maxTimestamp=std::max(maxTimestamp, pts); + + packets.push_back(std::unique_ptr(new Packet(fseq, pts, fragmentCount, 0, keyframe, rotation))); + packets[packets.size()-1]->AddFragment(std::move(pkt), fragmentIndex); + while(packets.size()>3){ + std::unique_ptr& _old=packets[0]; + if(_old->receivedPartCount==_old->partCount){ + std::unique_ptr old=std::move(packets[0]); + packets.erase(packets.begin()); + + Buffer buffer=old->Reassemble(); + callback(std::move(buffer), old->seq, old->isKeyframe, old->rotation); + oldPackets.push_back(std::move(old)); + while(oldPackets.size()>NUM_OLD_PACKETS) + oldPackets.erase(oldPackets.begin()); + }else{ + LOGW("Packet %u not reassembled (%u of %u)", packets[0]->seq, packets[0]->receivedPartCount, packets[0]->partCount); + if(packets[0]->partCount-packets[0]->receivedPartCount==1 && !waitingForFEC){ + bool found=false; + for(FecPacket& fec:fecPackets){ + if(packets[0]->seq<=fec.seq && packets[0]->seq>fec.seq-fec.prevFrameCount){ + LOGI("Found FEC packet: %u %u", fec.seq, fec.prevFrameCount); + found=true; + TryDecodeFEC(fec); + packets.erase(packets.begin()); + break; + } + } + if(!found){ + waitingForFEC=true; + break; + } + }else{ + waitingForFEC=false; + LOGE("unrecoverable packet loss"); + std::unique_ptr old=std::move(packets[0]); + packets.erase(packets.begin()); + oldPackets.push_back(std::move(old)); + while(oldPackets.size()>NUM_OLD_PACKETS) + oldPackets.erase(oldPackets.begin()); + } + } + } + + lastFrameSeq=fseq; +} + +void PacketReassembler::AddFEC(Buffer data, uint8_t _fseq, unsigned int frameCount, unsigned int fecScheme){ + uint32_t fseq=(lastFrameSeq & 0xFFFFFF00) | (uint32_t)_fseq; + std::ostringstream _s; + for(unsigned int i=0;iseq<=fec.seq && packets[0]->seq>fec.seq-fec.prevFrameCount){ + LOGI("Found FEC packet: %u %u", fec.seq, fec.prevFrameCount); + TryDecodeFEC(fec); + packets.erase(packets.begin()); + waitingForFEC=false; + } + } + fecPackets.push_back(std::move(fec)); + while(fecPackets.size()>NUM_FEC_PACKETS) + fecPackets.erase(fecPackets.begin()); +} + +void PacketReassembler::SetCallback(std::function callback){ + this->callback=callback; +} + +bool PacketReassembler::TryDecodeFEC(PacketReassembler::FecPacket &fec){ + /*LOGI("Decoding FEC"); + + std::vector packetsForRecovery; + for(std::unique_ptr& p:oldPackets){ + if(p->seq<=fec.seq && p->seq>fec.seq-fec.prevFrameCount){ + LOGD("Adding frame %u from old", p->seq); + for(uint32_t i=0;ipartCount;i++){ + packetsForRecovery.push_back(iparts.size() ? Buffer::CopyOf(p->parts[i]) : Buffer()); + } + } + } + + for(std::unique_ptr& p:packets){ + if(p->seq<=fec.seq && p->seq>fec.seq-fec.prevFrameCount){ + LOGD("Adding frame %u from pending", p->seq); + for(uint32_t i=0;ipartCount;i++){ + //LOGV("[%u] size %u", i, p.parts[i].Length()); + packetsForRecovery.push_back(iparts.size() ? Buffer::CopyOf(p->parts[i]) : Buffer()); + } + } + } + + if(fec.fecScheme==FEC_SCHEME_XOR){ + Buffer recovered=ParityFEC::Decode(packetsForRecovery, fec.data); + LOGI("Recovered packet size %u", (unsigned int)recovered.Length()); + if(!recovered.IsEmpty()){ + std::unique_ptr& pkt=packets[0]; + if(pkt->parts.size()partCount){ + pkt->parts.push_back(std::move(recovered)); + }else{ + for(Buffer &b:pkt->parts){ + if(b.IsEmpty()){ + b=std::move(recovered); + break; + } + } + } + pkt->receivedPartCount++; + callback(pkt->Reassemble(), pkt->seq, pkt->isKeyframe, pkt->rotation); + } + }*/ + + return false; +} + +#pragma mark - Packet + +void PacketReassembler::Packet::AddFragment(Buffer pkt, uint32_t fragmentIndex){ + //LOGV("Add fragment %u/%u to packet %u", fragmentIndex, partCount, timestamp); + if(parts.size()==fragmentIndex){ + parts.push_back(std::move(pkt)); + //LOGV("add1"); + }else if(parts.size()>fragmentIndex){ + assert(parts[fragmentIndex].IsEmpty()); + parts[fragmentIndex]=std::move(pkt); + //LOGV("add2"); + }else{ + while(parts.size()=receivedPartCount); + if(parts.size() +#include +#include +#include + +#include "Buffers.h" +#include "logging.h" + +namespace tgvoip { + class PacketReassembler{ + public: + PacketReassembler(); + virtual ~PacketReassembler(); + + void Reset(); + void AddFragment(Buffer pkt, unsigned int fragmentIndex, unsigned int fragmentCount, uint32_t pts, uint8_t fseq, bool keyframe, uint16_t rotation); + void AddFEC(Buffer data, uint8_t fseq, unsigned int frameCount, unsigned int fecScheme); + void SetCallback(std::function callback); + + private: + struct Packet{ + uint32_t seq; + uint32_t timestamp; + uint32_t partCount; + uint32_t receivedPartCount; + bool isKeyframe; + uint16_t rotation; + std::vector parts; + + Packet(uint32_t seq, uint32_t timestamp, uint32_t partCount, uint32_t receivedPartCount, bool keyframe, uint16_t rotation) + :seq(seq), timestamp(timestamp), partCount(partCount), receivedPartCount(receivedPartCount), isKeyframe(keyframe), rotation(rotation){ + + } + + void AddFragment(Buffer pkt, uint32_t fragmentIndex); + Buffer Reassemble(); + }; + struct FecPacket{ + uint32_t seq; + uint32_t prevFrameCount; + uint32_t fecScheme; + Buffer data; + }; + + bool TryDecodeFEC(FecPacket& fec); + + std::function callback; + std::vector> packets; + std::vector> oldPackets; // for FEC + std::vector fecPackets; + uint32_t maxTimestamp=0; + uint32_t lastFrameSeq=0; + bool waitingForFEC=false; + }; +} + +#endif //TGVOIP_PACKETREASSEMBLER_H diff --git a/TMessagesProj/jni/libtgvoip2/PacketSender.h b/TMessagesProj/jni/libtgvoip2/PacketSender.h new file mode 100644 index 000000000..10bc76f31 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/PacketSender.h @@ -0,0 +1,64 @@ +// +// Created by Grishka on 19/03/2019. +// + +#ifndef LIBTGVOIP_PACKETSENDER_H +#define LIBTGVOIP_PACKETSENDER_H + +#include "VoIPController.h" +#include +#include + +namespace tgvoip{ + class PacketSender{ + public: + PacketSender(VoIPController* controller) : controller(controller) {}; + virtual ~PacketSender(){}; + virtual void PacketAcknowledged(uint32_t seq, double sendTime, double ackTime, uint8_t type, uint32_t size)=0; + virtual void PacketLost(uint32_t seq, uint8_t type, uint32_t size)=0; + + protected: + void SendExtra(Buffer& data, unsigned char type){ + controller->SendExtra(data, type); + } + + void IncrementUnsentStreamPackets(){ + controller->unsentStreamPackets++; + } + + uint32_t SendPacket(VoIPController::PendingOutgoingPacket pkt){ + uint32_t seq=controller->GenerateOutSeq(); + pkt.seq=seq; + controller->SendOrEnqueuePacket(std::move(pkt), true, this); + return seq; + } + + double GetConnectionInitTime(){ + return controller->connectionInitTime; + } + + const HistoricBuffer& RTTHistory(){ + return controller->rttHistory; + } + + MessageThread& GetMessageThread(){ + return controller->messageThread; + } + + const VoIPController::ProtocolInfo& GetProtocolInfo(){ + return controller->protocolInfo; + } + + void SendStreamFlags(VoIPController::Stream& stm){ + controller->SendStreamFlags(stm); + } + + const VoIPController::Config& GetConfig(){ + return controller->config; + } + + VoIPController* controller; + }; +} + +#endif //LIBTGVOIP_PACKETSENDER_H diff --git a/TMessagesProj/jni/libtgvoip2/PrivateDefines.h b/TMessagesProj/jni/libtgvoip2/PrivateDefines.h new file mode 100644 index 000000000..7a4c35a2b --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/PrivateDefines.h @@ -0,0 +1,142 @@ +// +// Created by Grishka on 20.04.2018. +// + +#ifndef TGVOIP_PRIVATEDEFINES_H +#define TGVOIP_PRIVATEDEFINES_H + +#define PKT_INIT 1 +#define PKT_INIT_ACK 2 +#define PKT_STREAM_STATE 3 +#define PKT_STREAM_DATA 4 +#define PKT_UPDATE_STREAMS 5 +#define PKT_PING 6 +#define PKT_PONG 7 +#define PKT_STREAM_DATA_X2 8 +#define PKT_STREAM_DATA_X3 9 +#define PKT_LAN_ENDPOINT 10 +#define PKT_NETWORK_CHANGED 11 +#define PKT_SWITCH_PREF_RELAY 12 +#define PKT_SWITCH_TO_P2P 13 +#define PKT_NOP 14 +//#define PKT_GROUP_CALL_KEY 15 // replaced with 'extra' in 2.1 (protocol v6) +//#define PKT_REQUEST_GROUP 16 +#define PKT_STREAM_EC 17 + +#define IS_MOBILE_NETWORK(x) (x==NET_TYPE_GPRS || x==NET_TYPE_EDGE || x==NET_TYPE_3G || x==NET_TYPE_HSPA || x==NET_TYPE_LTE || x==NET_TYPE_OTHER_MOBILE) + +#define PROTOCOL_NAME 0x50567247 // "GrVP" in little endian (reversed here) +#define PROTOCOL_VERSION 9 +#define MIN_PROTOCOL_VERSION 3 + +#define STREAM_DATA_FLAG_LEN16 0x40 +#define STREAM_DATA_FLAG_HAS_MORE_FLAGS 0x80 +// Since the data can't be larger than the MTU anyway, +// 5 top bits of data length are allocated for these flags +#define STREAM_DATA_XFLAG_KEYFRAME (1 << 15) +#define STREAM_DATA_XFLAG_FRAGMENTED (1 << 14) +#define STREAM_DATA_XFLAG_EXTRA_FEC (1 << 13) + +#define STREAM_TYPE_AUDIO 1 +#define STREAM_TYPE_VIDEO 2 + +#define FOURCC(a,b,c,d) ((uint32_t)d | ((uint32_t)c << 8) | ((uint32_t)b << 16) | ((uint32_t)a << 24)) +#define PRINT_FOURCC(x) (char)(x >> 24), (char)(x >> 16), (char)(x >> 8), (char)x + +#define CODEC_OPUS_OLD 1 +#define CODEC_OPUS FOURCC('O','P','U','S') + +#define CODEC_AVC FOURCC('A','V','C',' ') +#define CODEC_HEVC FOURCC('H','E','V','C') +#define CODEC_VP8 FOURCC('V','P','8','0') +#define CODEC_VP9 FOURCC('V','P','9','0') +#define CODEC_AV1 FOURCC('A','V','0','1') + +#define DEFAULT_MTU 1100 + +/*flags:# voice_call_id:flags.2?int128 in_seq_no:flags.4?int out_seq_no:flags.4?int + * recent_received_mask:flags.5?int proto:flags.3?int extra:flags.1?string raw_data:flags.0?string*/ +#define PFLAG_HAS_DATA 1 +#define PFLAG_HAS_EXTRA 2 +#define PFLAG_HAS_CALL_ID 4 +#define PFLAG_HAS_PROTO 8 +#define PFLAG_HAS_SEQ 16 +#define PFLAG_HAS_RECENT_RECV 32 +#define PFLAG_HAS_SENDER_TAG_HASH 64 + +#define XPFLAG_HAS_EXTRA 1 +#define XPFLAG_HAS_RECV_TS 2 + +#define EXTRA_TYPE_STREAM_FLAGS 1 +#define EXTRA_TYPE_STREAM_CSD 2 +#define EXTRA_TYPE_LAN_ENDPOINT 3 +#define EXTRA_TYPE_NETWORK_CHANGED 4 +#define EXTRA_TYPE_GROUP_CALL_KEY 5 +#define EXTRA_TYPE_REQUEST_GROUP 6 +#define EXTRA_TYPE_IPV6_ENDPOINT 7 + +#define STREAM_FLAG_ENABLED 1 +#define STREAM_FLAG_DTX 2 +#define STREAM_FLAG_EXTRA_EC 4 +#define STREAM_FLAG_PAUSED 8 + +#define STREAM_RFLAG_SUPPORTED 1 + +#define INIT_FLAG_DATA_SAVING_ENABLED 1 +#define INIT_FLAG_GROUP_CALLS_SUPPORTED 2 +#define INIT_FLAG_VIDEO_SEND_SUPPORTED 4 +#define INIT_FLAG_VIDEO_RECV_SUPPORTED 8 + +#define INIT_VIDEO_RES_NONE 0 +#define INIT_VIDEO_RES_240 1 +#define INIT_VIDEO_RES_360 2 +#define INIT_VIDEO_RES_480 3 +#define INIT_VIDEO_RES_720 4 +#define INIT_VIDEO_RES_1080 5 +#define INIT_VIDEO_RES_1440 6 +#define INIT_VIDEO_RES_4K 7 + +#define TLID_DECRYPTED_AUDIO_BLOCK 0xDBF948C1 +#define TLID_SIMPLE_AUDIO_BLOCK 0xCC0D0E76 +#define TLID_UDP_REFLECTOR_PEER_INFO 0x27D9371C +#define TLID_UDP_REFLECTOR_PEER_INFO_IPV6 0x83fc73b1 +#define TLID_UDP_REFLECTOR_SELF_INFO 0xc01572c7 +#define TLID_UDP_REFLECTOR_REQUEST_PACKETS_INFO 0x1a06fc96 +#define TLID_UDP_REFLECTOR_LAST_PACKETS_INFO 0x0e107305 +#define TLID_VECTOR 0x1cb5c415 +#define PAD4(x) (4-(x+(x<=253 ? 1 : 0))%4) + +#define MAX_RECENT_PACKETS 128 + +#define SHA1_LENGTH 20 +#define SHA256_LENGTH 32 + +#ifdef _MSC_VER +#define MSC_STACK_FALLBACK(a, b) (b) +#else +#define MSC_STACK_FALLBACK(a, b) (a) +#endif + +#define SEQ_MAX 0xFFFFFFFF + +inline bool seqgt(uint32_t s1, uint32_t s2){ + return ((s1>s2) && (s1-s2<=SEQ_MAX/2)) || ((s1SEQ_MAX/2)); +} + +#define NEED_RATE_FLAG_SHITTY_INTERNET_MODE 1 +#define NEED_RATE_FLAG_UDP_NA 2 +#define NEED_RATE_FLAG_UDP_BAD 4 +#define NEED_RATE_FLAG_RECONNECTING 8 + +#define VIDEO_FRAME_FLAG_KEYFRAME 1 + +#define VIDEO_ROTATION_MASK 3 +#define VIDEO_ROTATION_0 0 +#define VIDEO_ROTATION_90 1 +#define VIDEO_ROTATION_180 2 +#define VIDEO_ROTATION_270 3 + +#define FEC_SCHEME_XOR 1 +#define FEC_SCHEME_CM256 2 + +#endif //TGVOIP_PRIVATEDEFINES_H diff --git a/TMessagesProj/jni/libtgvoip2/TgVoip.cpp b/TMessagesProj/jni/libtgvoip2/TgVoip.cpp new file mode 100644 index 000000000..87e4fc40a --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/TgVoip.cpp @@ -0,0 +1,426 @@ +#include + +#include "TgVoip.h" + +#include "VoIPController.h" +#include "VoIPServerConfig.h" + +#include + +#ifndef TGVOIP_USE_CUSTOM_CRYPTO +extern "C" { +#include +#include +//#include +#include +} + +void tgvoip_openssl_aes_ige_encrypt(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv){ + AES_KEY akey; + AES_set_encrypt_key(key, 32*8, &akey); + AES_ige_encrypt(in, out, length, &akey, iv, AES_ENCRYPT); +} + +void tgvoip_openssl_aes_ige_decrypt(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv){ + AES_KEY akey; + AES_set_decrypt_key(key, 32*8, &akey); + AES_ige_encrypt(in, out, length, &akey, iv, AES_DECRYPT); +} + +void tgvoip_openssl_rand_bytes(uint8_t* buffer, size_t len){ + RAND_bytes(buffer, len); +} + +void tgvoip_openssl_sha1(uint8_t* msg, size_t len, uint8_t* output){ + SHA1(msg, len, output); +} + +void tgvoip_openssl_sha256(uint8_t* msg, size_t len, uint8_t* output){ + SHA256(msg, len, output); +} + +void tgvoip_openssl_aes_ctr_encrypt(uint8_t* inout, size_t length, uint8_t* key, uint8_t* iv, uint8_t* ecount, uint32_t* num){ + AES_KEY akey; + AES_set_encrypt_key(key, 32*8, &akey); + AES_ctr128_encrypt(inout, inout, length, &akey, iv, ecount, num); +} + +void tgvoip_openssl_aes_cbc_encrypt(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv){ + AES_KEY akey; + AES_set_encrypt_key(key, 256, &akey); + AES_cbc_encrypt(in, out, length, &akey, iv, AES_ENCRYPT); +} + +void tgvoip_openssl_aes_cbc_decrypt(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv){ + AES_KEY akey; + AES_set_decrypt_key(key, 256, &akey); + AES_cbc_encrypt(in, out, length, &akey, iv, AES_DECRYPT); +} + +tgvoip::CryptoFunctions tgvoip::VoIPController::crypto={ + tgvoip_openssl_rand_bytes, + tgvoip_openssl_sha1, + tgvoip_openssl_sha256, + tgvoip_openssl_aes_ige_encrypt, + tgvoip_openssl_aes_ige_decrypt, + tgvoip_openssl_aes_ctr_encrypt, + tgvoip_openssl_aes_cbc_encrypt, + tgvoip_openssl_aes_cbc_decrypt +}; +#endif + + +class TgVoipImpl : public TgVoip { +public: + TgVoipImpl( + std::vector const &endpoints, + TgVoipPersistentState const &persistentState, + std::unique_ptr const &proxy, + TgVoipConfig const &config, + TgVoipEncryptionKey const &encryptionKey, + TgVoipNetworkType initialNetworkType +#ifdef TGVOIP_USE_CUSTOM_CRYPTO + , + TgVoipCrypto const &crypto +#endif +#ifdef TGVOIP_USE_CALLBACK_AUDIO_IO + , + TgVoipAudioDataCallbacks const &audioDataCallbacks +#endif + ) { +#ifdef TGVOIP_USE_CUSTOM_CRYPTO + tgvoip::VoIPController::crypto.sha1 = crypto.sha1; + tgvoip::VoIPController::crypto.sha256 = crypto.sha256; + tgvoip::VoIPController::crypto.rand_bytes = crypto.rand_bytes; + tgvoip::VoIPController::crypto.aes_ige_encrypt = crypto.aes_ige_encrypt; + tgvoip::VoIPController::crypto.aes_ige_decrypt = crypto.aes_ige_decrypt; + tgvoip::VoIPController::crypto.aes_ctr_encrypt = crypto.aes_ctr_encrypt; +#endif + + controller_ = new tgvoip::VoIPController(); + controller_->implData = this; + +#ifdef TGVOIP_USE_CALLBACK_AUDIO_IO + controller_->SetAudioDataCallbacks(audioDataCallbacks.input, audioDataCallbacks.output, audioDataCallbacks.preprocessed); +#endif + + controller_->SetPersistentState(persistentState.value); + + if (proxy != nullptr) { + controller_->SetProxy(tgvoip::PROXY_SOCKS5, proxy->host, proxy->port, proxy->login, proxy->password); + } + + auto callbacks = tgvoip::VoIPController::Callbacks(); + callbacks.connectionStateChanged = &TgVoipImpl::controllerStateCallback; + callbacks.groupCallKeyReceived = nullptr; + callbacks.groupCallKeySent = nullptr; + callbacks.signalBarCountChanged = &TgVoipImpl::signalBarsCallback; + callbacks.upgradeToGroupCallRequested = nullptr; + controller_->SetCallbacks(callbacks); + + std::vector mappedEndpoints; + for (auto endpoint : endpoints) { + tgvoip::Endpoint::Type mappedType; + switch (endpoint.type) { + case TgVoipEndpointType::UdpRelay: + mappedType = tgvoip::Endpoint::Type::UDP_RELAY; + break; + case TgVoipEndpointType::Lan: + mappedType = tgvoip::Endpoint::Type::UDP_P2P_LAN; + break; + case TgVoipEndpointType::Inet: + mappedType = tgvoip::Endpoint::Type::UDP_P2P_INET; + break; + case TgVoipEndpointType::TcpRelay: + mappedType = tgvoip::Endpoint::Type::TCP_RELAY; + break; + default: + mappedType = tgvoip::Endpoint::Type::UDP_RELAY; + break; + } + + tgvoip::IPv4Address address(endpoint.host.ipv4); + tgvoip::IPv6Address addressv6(endpoint.host.ipv6); + + mappedEndpoints.emplace_back(endpoint.endpointId, endpoint.port, address, addressv6, mappedType, endpoint.peerTag); + } + + int mappedDataSaving; + switch (config.dataSaving) { + case TgVoipDataSaving::Mobile: + mappedDataSaving = tgvoip::DATA_SAVING_MOBILE; + break; + case TgVoipDataSaving::Always: + mappedDataSaving = tgvoip::DATA_SAVING_ALWAYS; + break; + default: + mappedDataSaving = tgvoip::DATA_SAVING_NEVER; + break; + } + + tgvoip::VoIPController::Config mappedConfig( + config.initializationTimeout, + config.receiveTimeout, + mappedDataSaving, + config.enableAEC, + config.enableNS, + config.enableAGC, + config.enableCallUpgrade + ); + mappedConfig.logFilePath = config.logPath; + mappedConfig.statsDumpFilePath = {}; + + controller_->SetConfig(mappedConfig); + + setNetworkType(initialNetworkType); + + std::vector encryptionKeyValue = encryptionKey.value; + controller_->SetEncryptionKey(reinterpret_cast(encryptionKeyValue.data()), encryptionKey.isOutgoing); + controller_->SetRemoteEndpoints(mappedEndpoints, config.enableP2P, config.maxApiLayer); + + controller_->Start(); + + controller_->Connect(); + } + + ~TgVoipImpl() { + + } + + void setOnStateUpdated(std::function onStateUpdated) { + std::lock_guard lock(m_onStateUpdated); + onStateUpdated_ = onStateUpdated; + } + + void setOnSignalBarsUpdated(std::function onSignalBarsUpdated) { + std::lock_guard lock(m_onSignalBarsUpdated); + onSignalBarsUpdated_ = onSignalBarsUpdated; + } + + void setNetworkType(TgVoipNetworkType networkType) override { + int mappedType; + + switch (networkType) { + case TgVoipNetworkType::Unknown: + mappedType = tgvoip::NET_TYPE_UNKNOWN; + break; + case TgVoipNetworkType::Gprs: + mappedType = tgvoip::NET_TYPE_GPRS; + break; + case TgVoipNetworkType::Edge: + mappedType = tgvoip::NET_TYPE_EDGE; + break; + case TgVoipNetworkType::ThirdGeneration: + mappedType = tgvoip::NET_TYPE_3G; + break; + case TgVoipNetworkType::Hspa: + mappedType = tgvoip::NET_TYPE_HSPA; + break; + case TgVoipNetworkType::Lte: + mappedType = tgvoip::NET_TYPE_LTE; + break; + case TgVoipNetworkType::WiFi: + mappedType = tgvoip::NET_TYPE_WIFI; + break; + case TgVoipNetworkType::Ethernet: + mappedType = tgvoip::NET_TYPE_ETHERNET; + break; + case TgVoipNetworkType::OtherHighSpeed: + mappedType = tgvoip::NET_TYPE_OTHER_HIGH_SPEED; + break; + case TgVoipNetworkType::OtherLowSpeed: + mappedType = tgvoip::NET_TYPE_OTHER_LOW_SPEED; + break; + case TgVoipNetworkType::OtherMobile: + mappedType = tgvoip::NET_TYPE_OTHER_MOBILE; + break; + case TgVoipNetworkType::Dialup: + mappedType = tgvoip::NET_TYPE_DIALUP; + break; + default: + mappedType = tgvoip::NET_TYPE_UNKNOWN; + break; + } + + controller_->SetNetworkType(mappedType); + } + + void setMuteMicrophone(bool muteMicrophone) override { + controller_->SetMicMute(muteMicrophone); + } + + void setAudioOutputGainControlEnabled(bool enabled) override { + controller_->SetAudioOutputGainControlEnabled(enabled); + } + + void setEchoCancellationStrength(int strength) override { + controller_->SetEchoCancellationStrength(strength); + } + + std::string getLastError() override { + switch (controller_->GetLastError()) { + case tgvoip::ERROR_INCOMPATIBLE: return "ERROR_INCOMPATIBLE"; + case tgvoip::ERROR_TIMEOUT: return "ERROR_TIMEOUT"; + case tgvoip::ERROR_AUDIO_IO: return "ERROR_AUDIO_IO"; + case tgvoip::ERROR_PROXY: return "ERROR_PROXY"; + default: return "ERROR_UNKNOWN"; + } + } + + std::string getDebugInfo() override { + return controller_->GetDebugString(); + } + + int64_t getPreferredRelayId() override { + return controller_->GetPreferredRelayID(); + } + + TgVoipTrafficStats getTrafficStats() override { + tgvoip::VoIPController::TrafficStats stats; + controller_->GetStats(&stats); + return { + .bytesSentWifi = stats.bytesSentWifi, + .bytesReceivedWifi = stats.bytesRecvdWifi, + .bytesSentMobile = stats.bytesSentMobile, + .bytesReceivedMobile = stats.bytesRecvdMobile + }; + } + + TgVoipPersistentState getPersistentState() override { + return {controller_->GetPersistentState()}; + } + + TgVoipFinalState stop() override { + controller_->Stop(); + + TgVoipFinalState finalState = { + .persistentState = getPersistentState(), + .debugLog = controller_->GetDebugLog(), + .trafficStats = getTrafficStats(), + .isRatingSuggested = controller_->NeedRate() + }; + + delete controller_; + controller_ = nullptr; + + return finalState; + } + + static void controllerStateCallback(tgvoip::VoIPController* controller, int state) { + TgVoipImpl* self = reinterpret_cast(controller->implData); + std::lock_guard lock(self->m_onStateUpdated); + + if (self->onStateUpdated_) { + TgVoipState mappedState; + switch (state) { + case tgvoip::STATE_WAIT_INIT: + mappedState = TgVoipState::WaitInit; + break; + case tgvoip::STATE_WAIT_INIT_ACK: + mappedState = TgVoipState::WaitInitAck; + break; + case tgvoip::STATE_ESTABLISHED: + mappedState = TgVoipState::Estabilished; + break; + case tgvoip::STATE_FAILED: + mappedState = TgVoipState::Failed; + break; + case tgvoip::STATE_RECONNECTING: + mappedState = TgVoipState::Reconnecting; + break; + default: + mappedState = TgVoipState::Estabilished; + break; + } + + self->onStateUpdated_(mappedState); + } + } + + static void signalBarsCallback(tgvoip::VoIPController* controller, int signalBars) { + TgVoipImpl* self = reinterpret_cast(controller->implData); + std::lock_guard lock(self->m_onSignalBarsUpdated); + + if (self->onSignalBarsUpdated_) { + self->onSignalBarsUpdated_(signalBars); + } + } + +private: + tgvoip::VoIPController *controller_; + std::function onStateUpdated_; + std::function onSignalBarsUpdated_; + std::mutex m_onStateUpdated, m_onSignalBarsUpdated; +}; + +std::function globalLoggingFunction; + +void __tgvoip_call_tglog(const char *format, ...){ + va_list vaArgs; + va_start(vaArgs, format); + + va_list vaCopy; + va_copy(vaCopy, vaArgs); + const int length = std::vsnprintf(nullptr, 0, format, vaCopy); + va_end(vaCopy); + + std::vector zc(length + 1); + std::vsnprintf(zc.data(), zc.size(), format, vaArgs); + va_end(vaArgs); + + if (globalLoggingFunction != nullptr) { + globalLoggingFunction(std::string(zc.data(), zc.size())); + } +} + +void TgVoip::setLoggingFunction(std::function loggingFunction) { + globalLoggingFunction = loggingFunction; +} + +void TgVoip::setGlobalServerConfig(const std::string &serverConfig) { + tgvoip::ServerConfig::GetSharedInstance()->Update(serverConfig); +} + +int TgVoip::getConnectionMaxLayer() { + return tgvoip::VoIPController::GetConnectionMaxLayer(); +} + +std::string TgVoip::getVersion() { + return tgvoip::VoIPController::GetVersion(); +} + +TgVoip *TgVoip::makeInstance( + TgVoipConfig const &config, + TgVoipPersistentState const &persistentState, + std::vector const &endpoints, + std::unique_ptr const &proxy, + TgVoipNetworkType initialNetworkType, + TgVoipEncryptionKey const &encryptionKey +#ifdef TGVOIP_USE_CUSTOM_CRYPTO + , + TgVoipCrypto const &crypto +#endif +#ifdef TGVOIP_USE_CALLBACK_AUDIO_IO + , + TgVoipAudioDataCallbacks const &audioDataCallbacks +#endif +) { + return new TgVoipImpl( + endpoints, + persistentState, + proxy, + config, + encryptionKey, + initialNetworkType +#ifdef TGVOIP_USE_CUSTOM_CRYPTO + , + crypto +#endif +#ifdef TGVOIP_USE_CALLBACK_AUDIO_IO + , + audioDataCallbacks +#endif + ); +} + +TgVoip::~TgVoip() = default; diff --git a/TMessagesProj/jni/libtgvoip2/TgVoip.h b/TMessagesProj/jni/libtgvoip2/TgVoip.h new file mode 100644 index 000000000..d57f9b139 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/TgVoip.h @@ -0,0 +1,169 @@ +#ifndef __TGVOIP_H +#define __TGVOIP_H + +#include +#include +#include +#include + +struct TgVoipProxy { + std::string host; + uint16_t port; + std::string login; + std::string password; +}; + +enum class TgVoipEndpointType { + Inet, + Lan, + UdpRelay, + TcpRelay +}; + +struct TgVoipEdpointHost { + std::string ipv4; + std::string ipv6; +}; + +struct TgVoipEndpoint { + int64_t endpointId; + TgVoipEdpointHost host; + uint16_t port; + TgVoipEndpointType type; + unsigned char peerTag[16]; +}; + +enum class TgVoipNetworkType { + Unknown, + Gprs, + Edge, + ThirdGeneration, + Hspa, + Lte, + WiFi, + Ethernet, + OtherHighSpeed, + OtherLowSpeed, + OtherMobile, + Dialup +}; + +enum class TgVoipDataSaving { + Never, + Mobile, + Always +}; + +struct TgVoipPersistentState { + std::vector value; +}; + +#ifdef TGVOIP_USE_CUSTOM_CRYPTO +struct TgVoipCrypto { + void (*rand_bytes)(uint8_t* buffer, size_t length); + void (*sha1)(uint8_t* msg, size_t length, uint8_t* output); + void (*sha256)(uint8_t* msg, size_t length, uint8_t* output); + void (*aes_ige_encrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); + void (*aes_ige_decrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); + void (*aes_ctr_encrypt)(uint8_t* inout, size_t length, uint8_t* key, uint8_t* iv, uint8_t* ecount, uint32_t* num); + void (*aes_cbc_encrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); + void (*aes_cbc_decrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); +}; +#endif + +struct TgVoipConfig { + double initializationTimeout; + double receiveTimeout; + TgVoipDataSaving dataSaving; + bool enableP2P; + bool enableAEC; + bool enableNS; + bool enableAGC; + bool enableCallUpgrade; +#ifndef _WIN32 + std::string logPath; +#else + std::wstring logPath; +#endif + int maxApiLayer; +}; + +struct TgVoipEncryptionKey { + std::vector value; + bool isOutgoing; +}; + +enum class TgVoipState { + WaitInit, + WaitInitAck, + Estabilished, + Failed, + Reconnecting +}; + +struct TgVoipTrafficStats { + uint64_t bytesSentWifi; + uint64_t bytesReceivedWifi; + uint64_t bytesSentMobile; + uint64_t bytesReceivedMobile; +}; + +struct TgVoipFinalState { + TgVoipPersistentState persistentState; + std::string debugLog; + TgVoipTrafficStats trafficStats; + bool isRatingSuggested; +}; + +struct TgVoipAudioDataCallbacks { + std::function input; + std::function output; + std::function preprocessed; +}; + +class TgVoip { +protected: + TgVoip() = default; + +public: + static void setLoggingFunction(std::function loggingFunction); + static void setGlobalServerConfig(std::string const &serverConfig); + static int getConnectionMaxLayer(); + static std::string getVersion(); + static TgVoip *makeInstance( + TgVoipConfig const &config, + TgVoipPersistentState const &persistentState, + std::vector const &endpoints, + std::unique_ptr const &proxy, + TgVoipNetworkType initialNetworkType, + TgVoipEncryptionKey const &encryptionKey +#ifdef TGVOIP_USE_CUSTOM_CRYPTO + , + TgVoipCrypto const &crypto +#endif +#ifdef TGVOIP_USE_CALLBACK_AUDIO_IO + , + TgVoipAudioDataCallbacks const &audioDataCallbacks +#endif + ); + + virtual ~TgVoip(); + + virtual void setNetworkType(TgVoipNetworkType networkType) = 0; + virtual void setMuteMicrophone(bool muteMicrophone) = 0; + virtual void setAudioOutputGainControlEnabled(bool enabled) = 0; + virtual void setEchoCancellationStrength(int strength) = 0; + + virtual std::string getLastError() = 0; + virtual std::string getDebugInfo() = 0; + virtual int64_t getPreferredRelayId() = 0; + virtual TgVoipTrafficStats getTrafficStats() = 0; + virtual TgVoipPersistentState getPersistentState() = 0; + + virtual void setOnStateUpdated(std::function onStateUpdated) = 0; + virtual void setOnSignalBarsUpdated(std::function onSignalBarsUpdated) = 0; + + virtual TgVoipFinalState stop() = 0; +}; + +#endif diff --git a/TMessagesProj/jni/libtgvoip2/UNLICENSE b/TMessagesProj/jni/libtgvoip2/UNLICENSE new file mode 100644 index 000000000..00d2e135a --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/UNLICENSE @@ -0,0 +1,24 @@ +This is free and unencumbered software released into the public domain. + +Anyone is free to copy, modify, publish, use, compile, sell, or +distribute this software, either in source code form or as a compiled +binary, for any purpose, commercial or non-commercial, and by any +means. + +In jurisdictions that recognize copyright laws, the author or authors +of this software dedicate any and all copyright interest in the +software to the public domain. We make this dedication for the benefit +of the public at large and to the detriment of our heirs and +successors. We intend this dedication to be an overt act of +relinquishment in perpetuity of all present and future rights to this +software under copyright law. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR +OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, +ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +OTHER DEALINGS IN THE SOFTWARE. + +For more information, please refer to \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/VoIPController.cpp b/TMessagesProj/jni/libtgvoip2/VoIPController.cpp new file mode 100644 index 000000000..1255d5c92 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/VoIPController.cpp @@ -0,0 +1,3992 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef _WIN32 +#include +#include +#endif +#include +#include +#include +#include "VoIPController.h" +#include "logging.h" +#include "threading.h" +#include "Buffers.h" +#include "OpusEncoder.h" +#include "OpusDecoder.h" +#include "VoIPServerConfig.h" +#include "PrivateDefines.h" +#include "json11.hpp" +#include "PacketSender.h" +#include "video/VideoPacketSender.h" +#include +#include +#include +#include +#include +#include +#include +#include +#include +#if defined HAVE_CONFIG_H || defined TGVOIP_USE_INSTALLED_OPUS +#include +#else +#include "opus.h" +#endif + +inline int pad4(int x){ + int r=PAD4(x); + if(r==4) + return 0; + return r; +} + + +using namespace tgvoip; +// using namespace std; // Already used in BlockingQueue.h. + +#ifdef __APPLE__ +#include "os/darwin/AudioUnitIO.h" +#include +double VoIPController::machTimebase=0; +uint64_t VoIPController::machTimestart=0; +#endif + +#ifdef _WIN32 +int64_t VoIPController::win32TimeScale = 0; +bool VoIPController::didInitWin32TimeScale = false; +#endif + +#ifdef __ANDROID__ +#include "os/android/JNIUtilities.h" +#include "os/android/AudioInputAndroid.h" +#include "NetworkSocket.h" + +extern jclass jniUtilitiesClass; +#endif + +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) +#include "audio/AudioIOCallback.h" +#endif + +#define ENFORCE_MSG_THREAD assert(messageThread.IsCurrent()) + +extern FILE* tgvoipLogFile; + +#pragma mark - Public API + +VoIPController::VoIPController() : activeNetItfName(""), + currentAudioInput("default"), + currentAudioOutput("default"), + proxyAddress(""), + proxyUsername(""), + proxyPassword(""), + rawSendQueue(64){ + seq=1; + lastRemoteSeq=0; + state=STATE_WAIT_INIT; + audioInput=NULL; + audioOutput=NULL; + encoder=NULL; + audioOutStarted=false; + audioTimestampIn=0; + audioTimestampOut=0; + stopping=false; + memset(&stats, 0, sizeof(TrafficStats)); + lastRemoteAckSeq=0; + lastSentSeq=0; + recvLossCount=0; + packetsReceived=0; + waitingForAcks=false; + networkType=NET_TYPE_UNKNOWN; + echoCanceller=NULL; + dontSendPackets=0; + micMuted=false; + waitingForRelayPeerInfo=false; + allowP2p=true; + dataSavingMode=false; + publicEndpointsReqTime=0; + connectionInitTime=0; + lastRecvPacketTime=0; + dataSavingRequestedByPeer=false; + peerVersion=0; + conctl=new CongestionControl(); + prevSendLossCount=0; + receivedInit=false; + receivedInitAck=false; + statsDump=NULL; + useTCP=false; + useUDP=true; + didAddTcpRelays=false; + udpPingCount=0; + lastUdpPingTime=0; + + proxyProtocol=PROXY_NONE; + proxyPort=0; + + selectCanceller=SocketSelectCanceller::Create(); + udpSocket=NetworkSocket::Create(NetworkProtocol::UDP); + realUdpSocket=udpSocket; + udpConnectivityState=UDP_UNKNOWN; + echoCancellationStrength=1; + + peerCapabilities=0; + callbacks={0}; + didReceiveGroupCallKey=false; + didReceiveGroupCallKeyAck=false; + didSendGroupCallKey=false; + didSendUpgradeRequest=false; + didInvokeUpgradeCallback=false; + + connectionMaxLayer=0; + useMTProto2=false; + setCurrentEndpointToTCP=false; + useIPv6=false; + peerIPv6Available=false; + shittyInternetMode=false; + didAddIPv6Relays=false; + didSendIPv6Endpoint=false; + unsentStreamPackets.store(0); + runReceiver=false; + + sendThread=NULL; + recvThread=NULL; + + maxAudioBitrate=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("audio_max_bitrate", 20000); + maxAudioBitrateGPRS=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("audio_max_bitrate_gprs", 8000); + maxAudioBitrateEDGE=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("audio_max_bitrate_edge", 16000); + maxAudioBitrateSaving=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("audio_max_bitrate_saving", 8000); + initAudioBitrate=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("audio_init_bitrate", 16000); + initAudioBitrateGPRS=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("audio_init_bitrate_gprs", 8000); + initAudioBitrateEDGE=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("audio_init_bitrate_edge", 8000); + initAudioBitrateSaving=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("audio_init_bitrate_saving", 8000); + audioBitrateStepIncr=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("audio_bitrate_step_incr", 1000); + audioBitrateStepDecr=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("audio_bitrate_step_decr", 1000); + minAudioBitrate=(uint32_t) ServerConfig::GetSharedInstance()->GetInt("audio_min_bitrate", 8000); + relaySwitchThreshold=ServerConfig::GetSharedInstance()->GetDouble("relay_switch_threshold", 0.8); + p2pToRelaySwitchThreshold=ServerConfig::GetSharedInstance()->GetDouble("p2p_to_relay_switch_threshold", 0.6); + relayToP2pSwitchThreshold=ServerConfig::GetSharedInstance()->GetDouble("relay_to_p2p_switch_threshold", 0.8); + reconnectingTimeout=ServerConfig::GetSharedInstance()->GetDouble("reconnecting_state_timeout", 2.0); + needRateFlags=static_cast(ServerConfig::GetSharedInstance()->GetInt("rate_flags", 0xFFFFFFFF)); + rateMaxAcceptableRTT=ServerConfig::GetSharedInstance()->GetDouble("rate_min_rtt", 0.6); + rateMaxAcceptableSendLoss=ServerConfig::GetSharedInstance()->GetDouble("rate_min_send_loss", 0.2); + packetLossToEnableExtraEC=ServerConfig::GetSharedInstance()->GetDouble("packet_loss_for_extra_ec", 0.02); + maxUnsentStreamPackets=static_cast(ServerConfig::GetSharedInstance()->GetInt("max_unsent_stream_packets", 2)); + unackNopThreshold=static_cast(ServerConfig::GetSharedInstance()->GetInt("unack_nop_threshold", 10)); + +#ifdef __APPLE__ + machTimestart=0; +#endif + + shared_ptr stm=make_shared(); + stm->id=1; + stm->type=STREAM_TYPE_AUDIO; + stm->codec=CODEC_OPUS; + stm->enabled=1; + stm->frameDuration=60; + outgoingStreams.push_back(stm); + +} + +VoIPController::~VoIPController(){ + LOGD("Entered VoIPController::~VoIPController"); + if(!stopping){ + LOGE("!!!!!!!!!!!!!!!!!!!! CALL controller->Stop() BEFORE DELETING THE CONTROLLER OBJECT !!!!!!!!!!!!!!!!!!!!!!!1"); + abort(); + } + LOGD("before close socket"); + if(udpSocket) + delete udpSocket; + if(udpSocket!=realUdpSocket) + delete realUdpSocket; + LOGD("before delete audioIO"); + if(audioIO){ + delete audioIO; + audioInput=NULL; + audioOutput=NULL; + } + for(vector>::iterator _stm=incomingStreams.begin();_stm!=incomingStreams.end();++_stm){ + shared_ptr stm=*_stm; + LOGD("before stop decoder"); + if(stm->decoder){ + stm->decoder->Stop(); + } + } + LOGD("before delete encoder"); + if(encoder){ + encoder->Stop(); + delete encoder; + } + LOGD("before delete echo canceller"); + if(echoCanceller){ + echoCanceller->Stop(); + delete echoCanceller; + } + delete conctl; + if(statsDump) + fclose(statsDump); + delete selectCanceller; + LOGD("Left VoIPController::~VoIPController"); + if(tgvoipLogFile){ + FILE* log=tgvoipLogFile; + tgvoipLogFile=NULL; + fclose(log); + } +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) + if (preprocDecoder) { + opus_decoder_destroy(preprocDecoder); + preprocDecoder=nullptr; + } +#endif +} + +void VoIPController::Stop(){ + LOGD("Entered VoIPController::Stop"); + stopping=true; + runReceiver=false; + LOGD("before shutdown socket"); + if(udpSocket) + udpSocket->Close(); + if(realUdpSocket!=udpSocket) + realUdpSocket->Close(); + selectCanceller->CancelSelect(); + //Buffer emptyBuf(0); + //PendingOutgoingPacket emptyPacket{0, 0, 0, move(emptyBuf), 0}; + //sendQueue->Put(move(emptyPacket)); + rawSendQueue.Put(RawPendingOutgoingPacket{NetworkPacket::Empty(), nullptr}); + LOGD("before join sendThread"); + if(sendThread){ + sendThread->Join(); + delete sendThread; + } + LOGD("before join recvThread"); + if(recvThread){ + recvThread->Join(); + delete recvThread; + } + LOGD("before stop messageThread"); + messageThread.Stop(); + { + LOGD("Before stop audio I/O"); + MutexGuard m(audioIOMutex); + if(audioInput){ + audioInput->Stop(); + audioInput->SetCallback(NULL, NULL); + } + if(audioOutput){ + audioOutput->Stop(); + audioOutput->SetCallback(NULL, NULL); + } + } + if(videoPacketSender){ + LOGD("before delete video packet sender"); + delete videoPacketSender; + videoPacketSender=NULL; + } + LOGD("Left VoIPController::Stop [need rate = %d]", (int)needRate); +} + +bool VoIPController::NeedRate(){ + return needRate && ServerConfig::GetSharedInstance()->GetBoolean("bad_call_rating", false); +} + +void VoIPController::SetRemoteEndpoints(vector endpoints, bool allowP2p, int32_t connectionMaxLayer){ + LOGW("Set remote endpoints, allowP2P=%d, connectionMaxLayer=%u", allowP2p ? 1 : 0, connectionMaxLayer); + assert(!runReceiver); + preferredRelay=0; + + this->endpoints.clear(); + didAddTcpRelays=false; + useTCP=true; + for(vector::iterator itrtr=endpoints.begin();itrtr!=endpoints.end();++itrtr){ + if(this->endpoints.find(itrtr->id)!=this->endpoints.end()) + LOGE("Endpoint IDs are not unique!"); + this->endpoints[itrtr->id]=*itrtr; + if(currentEndpoint==0) + currentEndpoint=itrtr->id; + if(itrtr->type==Endpoint::Type::TCP_RELAY) + didAddTcpRelays=true; + if(itrtr->type==Endpoint::Type::UDP_RELAY) + useTCP=false; + LOGV("Adding endpoint: %s:%d, %s", itrtr->address.ToString().c_str(), itrtr->port, itrtr->type==Endpoint::Type::UDP_RELAY ? "UDP" : "TCP"); + } + preferredRelay=currentEndpoint; + this->allowP2p=allowP2p; + this->connectionMaxLayer=connectionMaxLayer; + if(connectionMaxLayer>=74){ + useMTProto2=true; + } + AddIPv6Relays(); +} + +void VoIPController::Start(){ + LOGW("Starting voip controller"); + udpSocket->Open(); + if(udpSocket->IsFailed()){ + SetState(STATE_FAILED); + return; + } + + runReceiver=true; + recvThread=new Thread(bind(&VoIPController::RunRecvThread, this)); + recvThread->SetName("VoipRecv"); + recvThread->Start(); + + messageThread.Start(); +} + + +void VoIPController::Connect(){ + assert(state!=STATE_WAIT_INIT_ACK); + connectionInitTime=GetCurrentTime(); + if(config.initTimeout==0.0){ + LOGE("Init timeout is 0 -- did you forget to set config?"); + config.initTimeout=30.0; + } + + //InitializeTimers(); + //SendInit(); + sendThread=new Thread(bind(&VoIPController::RunSendThread, this)); + sendThread->SetName("VoipSend"); + sendThread->Start(); +} + +void VoIPController::SetEncryptionKey(char *key, bool isOutgoing){ + memcpy(encryptionKey, key, 256); + uint8_t sha1[SHA1_LENGTH]; + crypto.sha1((uint8_t*) encryptionKey, 256, sha1); + memcpy(keyFingerprint, sha1+(SHA1_LENGTH-8), 8); + uint8_t sha256[SHA256_LENGTH]; + crypto.sha256((uint8_t*) encryptionKey, 256, sha256); + memcpy(callID, sha256+(SHA256_LENGTH-16), 16); + this->isOutgoing=isOutgoing; +} + +void VoIPController::SetNetworkType(int type){ + networkType=type; + UpdateDataSavingState(); + UpdateAudioBitrateLimit(); + myIPv6=NetworkAddress::Empty(); + string itfName=udpSocket->GetLocalInterfaceInfo(NULL, &myIPv6); + LOGI("set network type: %s, active interface %s", NetworkTypeToString(type).c_str(), itfName.c_str()); + LOGI("Local IPv6 address: %s", myIPv6.ToString().c_str()); + if(IS_MOBILE_NETWORK(networkType)){ + CellularCarrierInfo carrier=GetCarrierInfo(); + if(!carrier.name.empty()){ + LOGI("Carrier: %s [%s; mcc=%s, mnc=%s]", carrier.name.c_str(), carrier.countryCode.c_str(), carrier.mcc.c_str(), carrier.mnc.c_str()); + } + } + if(itfName!=activeNetItfName){ + udpSocket->OnActiveInterfaceChanged(); + LOGI("Active network interface changed: %s -> %s", activeNetItfName.c_str(), itfName.c_str()); + bool isFirstChange=activeNetItfName.length()==0 && state!=STATE_ESTABLISHED && state!=STATE_RECONNECTING; + activeNetItfName=itfName; + if(isFirstChange) + return; + messageThread.Post([this]{ + wasNetworkHandover=true; + if(currentEndpoint){ + const Endpoint &_currentEndpoint=endpoints.at(currentEndpoint); + const Endpoint &_preferredRelay=endpoints.at(preferredRelay); + if(_currentEndpoint.type!=Endpoint::Type::UDP_RELAY){ + if(_preferredRelay.type==Endpoint::Type::UDP_RELAY) + currentEndpoint=preferredRelay; + MutexGuard m(endpointsMutex); + constexpr int64_t lanID=(int64_t) (FOURCC('L', 'A', 'N', '4')) << 32; + endpoints.erase(lanID); + for(pair &e:endpoints){ + Endpoint &endpoint=e.second; + if(endpoint.type==Endpoint::Type::UDP_RELAY && useTCP){ + useTCP=false; + if(_preferredRelay.type==Endpoint::Type::TCP_RELAY){ + preferredRelay=currentEndpoint=endpoint.id; + } + }else if(endpoint.type==Endpoint::Type::TCP_RELAY && endpoint.socket){ + endpoint.socket->Close(); + //delete endpoint.socket; + //endpoint.socket=NULL; + } + //if(endpoint->type==Endpoint::Type::UDP_P2P_INET){ + endpoint.averageRTT=0; + endpoint.rtts.Reset(); + //} + } + } + } + lastUdpPingTime=0; + if(proxyProtocol==PROXY_SOCKS5) + InitUDPProxy(); + if(allowP2p && currentEndpoint){ + SendPublicEndpointsRequest(); + } + BufferOutputStream s(4); + s.WriteInt32(dataSavingMode ? INIT_FLAG_DATA_SAVING_ENABLED : 0); + if(peerVersion<6){ + SendPacketReliably(PKT_NETWORK_CHANGED, s.GetBuffer(), s.GetLength(), 1, 20); + }else{ + Buffer buf(move(s)); + SendExtra(buf, EXTRA_TYPE_NETWORK_CHANGED); + } + needReInitUdpProxy=true; + selectCanceller->CancelSelect(); + didSendIPv6Endpoint=false; + + AddIPv6Relays(); + ResetUdpAvailability(); + ResetEndpointPingStats(); + }); + + } +} + +double VoIPController::GetAverageRTT(){ + ENFORCE_MSG_THREAD; + + if(lastSentSeq>=lastRemoteAckSeq){ + uint32_t diff=lastSentSeq-lastRemoteAckSeq; + //LOGV("rtt diff=%u", diff); + if(diff<32){ + double res=0; + int count=0; + for(std::vector::iterator itr=recentOutgoingPackets.begin();itr!=recentOutgoingPackets.end();++itr){ + if(itr->ackTime>0){ + res+=(itr->ackTime-itr->sendTime); + count++; + } + } + if(count>0) + res/=count; + return res; + } + } + return 999; +} + +void VoIPController::SetMicMute(bool mute){ + if(micMuted==mute) + return; + micMuted=mute; + if(audioInput){ + if(mute) + audioInput->Stop(); + else + audioInput->Start(); + if(!audioInput->IsInitialized()){ + lastError=ERROR_AUDIO_IO; + SetState(STATE_FAILED); + return; + } + } + if(echoCanceller) + echoCanceller->Enable(!mute); + if(state==STATE_ESTABLISHED){ + messageThread.Post([this]{ + for(shared_ptr &s:outgoingStreams){ + if(s->type==STREAM_TYPE_AUDIO){ + s->enabled=!micMuted; + if(peerVersion<6){ + unsigned char buf[2]; + buf[0]=s->id; + buf[1]=(char) (micMuted ? 0 : 1); + SendPacketReliably(PKT_STREAM_STATE, buf, 2, .5f, 20); + }else{ + SendStreamFlags(*s); + } + } + } + }); + } +} + +string VoIPController::GetDebugString(){ + string r="Remote endpoints: \n"; + char buffer[2048]; + MutexGuard m(endpointsMutex); + for(pair& _e:endpoints){ + Endpoint& endpoint=_e.second; + const char* type; + switch(endpoint.type){ + case Endpoint::Type::UDP_P2P_INET: + type="UDP_P2P_INET"; + break; + case Endpoint::Type::UDP_P2P_LAN: + type="UDP_P2P_LAN"; + break; + case Endpoint::Type::UDP_RELAY: + type="UDP_RELAY"; + break; + case Endpoint::Type::TCP_RELAY: + type="TCP_RELAY"; + break; + default: + type="UNKNOWN"; + break; + } + snprintf(buffer, sizeof(buffer), "%s:%u %dms %d 0x%" PRIx64 " [%s%s]\n", endpoint.address.IsEmpty() ? ("["+endpoint.v6address.ToString()+"]").c_str() : endpoint.address.ToString().c_str(), endpoint.port, (int)(endpoint.averageRTT*1000), endpoint.udpPongCount, (uint64_t)endpoint.id, type, currentEndpoint==endpoint.id ? ", IN_USE" : ""); + r+=buffer; + } + if(shittyInternetMode){ + snprintf(buffer, sizeof(buffer), "ShittyInternetMode: level %d\n", extraEcLevel); + r+=buffer; + } + double avgLate[3]; + shared_ptr stm=GetStreamByType(STREAM_TYPE_AUDIO, false); + shared_ptr jitterBuffer; + if(stm) + jitterBuffer=stm->jitterBuffer; + if(jitterBuffer) + jitterBuffer->GetAverageLateCount(avgLate); + else + memset(avgLate, 0, 3*sizeof(double)); + snprintf(buffer, sizeof(buffer), + "Jitter buffer: %d/%.2f | %.1f, %.1f, %.1f\n" + "RTT avg/min: %d/%d\n" + "Congestion window: %d/%d bytes\n" + "Key fingerprint: %02hhX%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX%s\n" + "Last sent/ack'd seq: %u/%u\n" + "Last recvd seq: %u\n" + "Send/recv losses: %u/%u (%d%%)\n" + "Audio bitrate: %d kbit\n" + "Outgoing queue: %u\n" + // "Packet grouping: %d\n" + "Frame size out/in: %d/%d\n" + "Bytes sent/recvd: %llu/%llu", + jitterBuffer ? jitterBuffer->GetMinPacketCount() : 0, jitterBuffer ? jitterBuffer->GetAverageDelay() : 0, avgLate[0], avgLate[1], avgLate[2], + // (int)(GetAverageRTT()*1000), 0, + (int)(conctl->GetAverageRTT()*1000), (int)(conctl->GetMinimumRTT()*1000), + int(conctl->GetInflightDataSize()), int(conctl->GetCongestionWindow()), + keyFingerprint[0],keyFingerprint[1],keyFingerprint[2],keyFingerprint[3],keyFingerprint[4],keyFingerprint[5],keyFingerprint[6],keyFingerprint[7], + useMTProto2 ? " (MTProto2.0)" : "", + lastSentSeq, lastRemoteAckSeq, lastRemoteSeq, + sendLosses, recvLossCount, encoder ? encoder->GetPacketLoss() : 0, + encoder ? (encoder->GetBitrate()/1000) : 0, + static_cast(unsentStreamPackets), +// audioPacketGrouping, + outgoingStreams[0]->frameDuration, incomingStreams.size()>0 ? incomingStreams[0]->frameDuration : 0, + (long long unsigned int)(stats.bytesSentMobile+stats.bytesSentWifi), + (long long unsigned int)(stats.bytesRecvdMobile+stats.bytesRecvdWifi)); + r+=buffer; + + if(config.enableVideoSend){ + shared_ptr vstm=GetStreamByType(STREAM_TYPE_VIDEO, true); + if(vstm && vstm->enabled && videoPacketSender){ + snprintf(buffer, sizeof(buffer), "\nVideo out: %ux%u '%c%c%c%c' %u kbit", vstm->width, vstm->height, PRINT_FOURCC(vstm->codec), videoPacketSender->GetBitrate()); + r+=buffer; + } + } + if(!peerVideoDecoders.empty()){ + r+="\nPeer codecs: "; + for(uint32_t codec:peerVideoDecoders){ + snprintf(buffer, sizeof(buffer), "'%c%c%c%c' ", PRINT_FOURCC(codec)); + r+=buffer; + } + } + if(config.enableVideoReceive){ + shared_ptr vstm=GetStreamByType(STREAM_TYPE_VIDEO, false); + if(vstm && vstm->enabled){ + snprintf(buffer, sizeof(buffer), "\nVideo in: %ux%u '%c%c%c%c'", vstm->width, vstm->height, PRINT_FOURCC(vstm->codec)); + r+=buffer; + } + } + + return r; +} + +const char* VoIPController::GetVersion(){ + return LIBTGVOIP_VERSION; +} + + +int64_t VoIPController::GetPreferredRelayID(){ + return preferredRelay; +} + + +int VoIPController::GetLastError(){ + return lastError; +} + + +void VoIPController::GetStats(TrafficStats *stats){ + memcpy(stats, &this->stats, sizeof(TrafficStats)); +} + +string VoIPController::GetDebugLog(){ + map network{ + {"type", NetworkTypeToString(networkType)} + }; + if(IS_MOBILE_NETWORK(networkType)){ + CellularCarrierInfo carrier=GetCarrierInfo(); + if(!carrier.name.empty()){ + network["carrier"]=carrier.name; + network["country"]=carrier.countryCode; + network["mcc"]=carrier.mcc; + network["mnc"]=carrier.mnc; + } + }else if(networkType==NET_TYPE_WIFI){ +#ifdef __ANDROID__ + jni::DoWithJNI([&](JNIEnv* env){ + jmethodID getWifiInfoMethod=env->GetStaticMethodID(jniUtilitiesClass, "getWifiInfo", "()[I"); + jintArray res=static_cast(env->CallStaticObjectMethod(jniUtilitiesClass, getWifiInfoMethod)); + if(res){ + jint* wifiInfo=env->GetIntArrayElements(res, NULL); + network["rssi"]=wifiInfo[0]; + network["link_speed"]=wifiInfo[1]; + env->ReleaseIntArrayElements(res, wifiInfo, JNI_ABORT); + } + }); +#endif + } + /*vector lpkts; + for(DebugLoggedPacket& lpkt:debugLoggedPackets){ + lpkts.push_back(json11::Json::array{lpkt.timestamp, lpkt.seq, lpkt.length}); + } + return json11::Json(json11::Json::object{ + {"log_type", "out_packet_stats"}, + {"libtgvoip_version", LIBTGVOIP_VERSION}, + {"network", network}, + {"protocol_version", std::min(peerVersion, PROTOCOL_VERSION)}, + {"total_losses", json11::Json::object{ + {"s", (int32_t)conctl->GetSendLossCount()}, + {"r", (int32_t)recvLossCount} + }}, + {"call_duration", GetCurrentTime()-connectionInitTime}, + {"out_packet_stats", lpkts} + }).dump();*/ + + vector _endpoints; + for(pair& _e:endpoints){ + Endpoint& e=_e.second; + string type; + map je{ + {"rtt", (int)(e.averageRTT*1000.0)} + }; + int64_t id=0; + if(e.type==Endpoint::Type::UDP_RELAY){ + je["type"]=e.IsIPv6Only() ? "udp_relay6" : "udp_relay"; + id=e.CleanID(); + if(e.totalUdpPings==0) + je["udp_pings"]=0.0; + else + je["udp_pings"]=(double)e.totalUdpPingReplies/(double)e.totalUdpPings; + je["self_rtt"]=(int)(e.selfRtts.Average()*1000.0); + }else if(e.type==Endpoint::Type::TCP_RELAY){ + je["type"]=e.IsIPv6Only() ? "tcp_relay6" : "tcp_relay"; + id=e.CleanID(); + }else if(e.type==Endpoint::Type::UDP_P2P_INET){ + je["type"]=e.IsIPv6Only() ? "p2p_inet6" : "p2p_inet"; + }else if(e.type==Endpoint::Type::UDP_P2P_LAN){ + je["type"]="p2p_lan"; + } + if(preferredRelay==e.id && wasEstablished) + je["pref"]=true; + if(id){ + ostringstream s; + s << id; + je["id"]=s.str(); + } + _endpoints.push_back(je); + } + + string p2pType="none"; + Endpoint& cur=endpoints[currentEndpoint]; + if(cur.type==Endpoint::Type::UDP_P2P_INET) + p2pType=cur.IsIPv6Only() ? "inet6" : "inet"; + else if(cur.type==Endpoint::Type::UDP_P2P_LAN) + p2pType="lan"; + + vector problems; + if(lastError==ERROR_TIMEOUT) + problems.push_back("timeout"); + if(wasReconnecting) + problems.push_back("reconnecting"); + if(wasExtraEC) + problems.push_back("extra_ec"); + if(wasEncoderLaggy) + problems.push_back("encoder_lag"); + if(!wasEstablished) + problems.push_back("not_inited"); + if(wasNetworkHandover) + problems.push_back("network_handover"); + + return json11::Json(json11::Json::object{ + {"log_type", "call_stats"}, + {"libtgvoip_version", LIBTGVOIP_VERSION}, + {"network", network}, + {"protocol_version", std::min(peerVersion, PROTOCOL_VERSION)}, + {"udp_avail", udpConnectivityState==UDP_AVAILABLE}, + {"tcp_used", useTCP}, + {"p2p_type", p2pType}, + {"packet_stats", json11::Json::object{ + {"out", (int)seq}, + {"in", (int)packetsReceived}, + {"lost_out", (int)conctl->GetSendLossCount()}, + {"lost_in", (int)recvLossCount} + }}, + {"endpoints", _endpoints}, + {"problems", problems} + }).dump(); +} + +vector VoIPController::EnumerateAudioInputs(){ + vector devs; + audio::AudioInput::EnumerateDevices(devs); + return devs; +} + +vector VoIPController::EnumerateAudioOutputs(){ + vector devs; + audio::AudioOutput::EnumerateDevices(devs); + return devs; +} + +void VoIPController::SetCurrentAudioInput(string id){ + currentAudioInput=id; + if(audioInput) + audioInput->SetCurrentDevice(id); +} + +void VoIPController::SetCurrentAudioOutput(string id){ + currentAudioOutput=id; + if(audioOutput) + audioOutput->SetCurrentDevice(id); +} + +string VoIPController::GetCurrentAudioInputID(){ + return currentAudioInput; +} + +string VoIPController::GetCurrentAudioOutputID(){ + return currentAudioOutput; +} + +void VoIPController::SetProxy(int protocol, string address, uint16_t port, string username, string password){ + proxyProtocol=protocol; + proxyAddress=std::move(address); + proxyPort=port; + proxyUsername=std::move(username); + proxyPassword=std::move(password); +} + +int VoIPController::GetSignalBarsCount(){ + return signalBarsHistory.NonZeroAverage(); +} + +void VoIPController::SetCallbacks(VoIPController::Callbacks callbacks){ + this->callbacks=callbacks; + if(callbacks.connectionStateChanged) + callbacks.connectionStateChanged(this, state); +} + +void VoIPController::SetAudioOutputGainControlEnabled(bool enabled){ + LOGD("New output AGC state: %d", enabled); +} + +uint32_t VoIPController::GetPeerCapabilities(){ + return peerCapabilities; +} + +void VoIPController::SendGroupCallKey(unsigned char *key){ + Buffer buf(256); + buf.CopyFrom(key, 0, 256); + shared_ptr keyPtr=make_shared(move(buf)); + messageThread.Post([this, keyPtr]{ + if(!(peerCapabilities & TGVOIP_PEER_CAP_GROUP_CALLS)){ + LOGE("Tried to send group call key but peer isn't capable of them"); + return; + } + if(didSendGroupCallKey){ + LOGE("Tried to send a group call key repeatedly"); + return; + } + if(!isOutgoing){ + LOGE("You aren't supposed to send group call key in an incoming call, use VoIPController::RequestCallUpgrade() instead"); + return; + } + didSendGroupCallKey=true; + SendExtra(*keyPtr, EXTRA_TYPE_GROUP_CALL_KEY); + }); +} + +void VoIPController::RequestCallUpgrade(){ + messageThread.Post([this]{ + if(!(peerCapabilities & TGVOIP_PEER_CAP_GROUP_CALLS)){ + LOGE("Tried to send group call key but peer isn't capable of them"); + return; + } + if(didSendUpgradeRequest){ + LOGE("Tried to send upgrade request repeatedly"); + return; + } + if(isOutgoing){ + LOGE("You aren't supposed to send an upgrade request in an outgoing call, generate an encryption key and use VoIPController::SendGroupCallKey instead"); + return; + } + didSendUpgradeRequest=true; + Buffer empty(0); + SendExtra(empty, EXTRA_TYPE_REQUEST_GROUP); + }); +} + +void VoIPController::SetEchoCancellationStrength(int strength){ + echoCancellationStrength=strength; + if(echoCanceller) + echoCanceller->SetAECStrength(strength); +} + +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) +void VoIPController::SetAudioDataCallbacks(std::function input, std::function output, std::function preproc=nullptr){ + audioInputDataCallback=input; + audioOutputDataCallback=output; + audioPreprocDataCallback=preproc; + preprocDecoder=preprocDecoder ? preprocDecoder : opus_decoder_create(48000, 1, NULL); +} +#endif + +int VoIPController::GetConnectionState(){ + return state; +} + +void VoIPController::SetConfig(const Config& cfg){ + config=cfg; + if(tgvoipLogFile){ + fclose(tgvoipLogFile); + tgvoipLogFile=NULL; + } + if(!config.logFilePath.empty()){ +#ifndef _WIN32 + tgvoipLogFile=fopen(config.logFilePath.c_str(), "a"); +#else + if(_wfopen_s(&tgvoipLogFile, config.logFilePath.c_str(), L"a")!=0){ + tgvoipLogFile=NULL; + } +#endif + tgvoip_log_file_write_header(tgvoipLogFile); + }else{ + tgvoipLogFile=NULL; + } + if(statsDump){ + fclose(statsDump); + statsDump=NULL; + } + if(!config.statsDumpFilePath.empty()){ +#ifndef _WIN32 + statsDump=fopen(config.statsDumpFilePath.c_str(), "w"); +#else + if(_wfopen_s(&statsDump, config.statsDumpFilePath.c_str(), L"w")!=0){ + statsDump=NULL; + } +#endif + if(statsDump) + fprintf(statsDump, "Time\tRTT\tLRSeq\tLSSeq\tLASeq\tLostR\tLostS\tCWnd\tBitrate\tLoss%%\tJitter\tJDelay\tAJDelay\n"); + //else + // LOGW("Failed to open stats dump file %s for writing", config.statsDumpFilePath.c_str()); + }else{ + statsDump=NULL; + } + UpdateDataSavingState(); + UpdateAudioBitrateLimit(); +} + +void VoIPController::SetPersistentState(vector state){ + using namespace json11; + + if(state.empty()) + return; + string jsonErr; + string json=string(state.begin(), state.end()); + Json _obj=Json::parse(json, jsonErr); + if(!jsonErr.empty()){ + LOGE("Error parsing persistable state: %s", jsonErr.c_str()); + return; + } + Json::object obj=_obj.object_items(); + if(obj.find("proxy")!=obj.end()){ + Json::object proxy=obj["proxy"].object_items(); + lastTestedProxyServer=proxy["server"].string_value(); + proxySupportsUDP=proxy["udp"].bool_value(); + proxySupportsTCP=proxy["tcp"].bool_value(); + } +} + +vector VoIPController::GetPersistentState(){ + using namespace json11; + + Json::object obj=Json::object{ + {"ver", 1}, + }; + if(proxyProtocol==PROXY_SOCKS5){ + char pbuf[128]; + snprintf(pbuf, sizeof(pbuf), "%s:%u", proxyAddress.c_str(), proxyPort); + obj.insert({"proxy", Json::object{ + {"server", string(pbuf)}, + {"udp", proxySupportsUDP}, + {"tcp", proxySupportsTCP} + }}); + } + string _jstr=Json(obj).dump(); + const char* jstr=_jstr.c_str(); + return vector(jstr, jstr+strlen(jstr)); +} + +void VoIPController::SetOutputVolume(float level){ + outputVolume.SetLevel(level); +} + +void VoIPController::SetInputVolume(float level){ + inputVolume.SetLevel(level); +} + +#if defined(__APPLE__) && TARGET_OS_OSX +void VoIPController::SetAudioOutputDuckingEnabled(bool enabled){ + macAudioDuckingEnabled=enabled; + audio::AudioUnitIO* osxAudio=dynamic_cast(audioIO); + if(osxAudio){ + osxAudio->SetDuckingEnabled(enabled); + } +} +#endif + +#pragma mark - Internal intialization + +void VoIPController::InitializeTimers(){ + initTimeoutID=messageThread.Post([this]{ + LOGW("Init timeout, disconnecting"); + lastError=ERROR_TIMEOUT; + SetState(STATE_FAILED); + }, config.initTimeout); + + if(!config.statsDumpFilePath.empty()){ + messageThread.Post([this]{ + if(statsDump && incomingStreams.size()==1){ + shared_ptr& jitterBuffer=incomingStreams[0]->jitterBuffer; + //fprintf(statsDump, "Time\tRTT\tLISeq\tLASeq\tCWnd\tBitrate\tJitter\tJDelay\tAJDelay\n"); + fprintf(statsDump, "%.3f\t%.3f\t%d\t%d\t%d\t%d\t%d\t%d\t%d\t%d\t%.3f\t%.3f\t%.3f\n", + GetCurrentTime()-connectionInitTime, + endpoints.at(currentEndpoint).rtts[0], + lastRemoteSeq, + (uint32_t)seq, + lastRemoteAckSeq, + recvLossCount, + conctl ? conctl->GetSendLossCount() : 0, + conctl ? (int)conctl->GetInflightDataSize() : 0, + encoder ? encoder->GetBitrate() : 0, + encoder ? encoder->GetPacketLoss() : 0, + jitterBuffer ? jitterBuffer->GetLastMeasuredJitter() : 0, + jitterBuffer ? jitterBuffer->GetLastMeasuredDelay()*0.06 : 0, + jitterBuffer ? jitterBuffer->GetAverageDelay()*0.06 : 0); + } + }, 0.1, 0.1); + } + + messageThread.Post(std::bind(&VoIPController::SendRelayPings, this), 0.0, 2.0); +} + +void VoIPController::RunSendThread(){ + InitializeAudio(); + InitializeTimers(); + messageThread.Post(bind(&VoIPController::SendInit, this)); + + while(true){ + RawPendingOutgoingPacket pkt=rawSendQueue.GetBlocking(); + if(pkt.packet.IsEmpty()) + break; + + if(IS_MOBILE_NETWORK(networkType)) + stats.bytesSentMobile+=(uint64_t)pkt.packet.data.Length(); + else + stats.bytesSentWifi+=(uint64_t)pkt.packet.data.Length(); + if(pkt.packet.protocol==NetworkProtocol::TCP){ + if(pkt.socket && !pkt.socket->IsFailed()){ + pkt.socket->Send(std::move(pkt.packet)); + } + }else{ + udpSocket->Send(std::move(pkt.packet)); + } + } + + LOGI("=== send thread exiting ==="); +} + +#pragma mark - Miscellaneous + +void VoIPController::SetState(int state){ + this->state=state; + LOGV("Call state changed to %d", state); + stateChangeTime=GetCurrentTime(); + messageThread.Post([this, state]{ + if(callbacks.connectionStateChanged) + callbacks.connectionStateChanged(this, state); + }); + if(state==STATE_ESTABLISHED){ + SetMicMute(micMuted); + if(!wasEstablished){ + wasEstablished=true; + messageThread.Post(std::bind(&VoIPController::UpdateRTT, this), 0.1, 0.5); + messageThread.Post(std::bind(&VoIPController::UpdateAudioBitrate, this), 0.0, 0.3); + messageThread.Post(std::bind(&VoIPController::UpdateCongestion, this), 0.0, 1.0); + messageThread.Post(std::bind(&VoIPController::UpdateSignalBars, this), 1.0, 1.0); + messageThread.Post(std::bind(&VoIPController::TickJitterBufferAndCongestionControl, this), 0.0, 0.1); + } + } +} + +void VoIPController::SendStreamFlags(Stream& stream){ + ENFORCE_MSG_THREAD; + + BufferOutputStream s(5); + s.WriteByte(stream.id); + uint32_t flags=0; + if(stream.enabled) + flags|=STREAM_FLAG_ENABLED; + if(stream.extraECEnabled) + flags|=STREAM_FLAG_EXTRA_EC; + if(stream.paused) + flags|=STREAM_FLAG_PAUSED; + s.WriteInt32(flags); + LOGV("My stream state: id %u flags %u", (unsigned int)stream.id, (unsigned int)flags); + Buffer buf(move(s)); + SendExtra(buf, EXTRA_TYPE_STREAM_FLAGS); +} + +shared_ptr VoIPController::GetStreamByType(int type, bool outgoing){ + shared_ptr s; + for(shared_ptr& ss:(outgoing ? outgoingStreams : incomingStreams)){ + if(ss->type==type) + return ss; + } + return s; +} + +shared_ptr VoIPController::GetStreamByID(unsigned char id, bool outgoing){ + shared_ptr s; + for(shared_ptr& ss:(outgoing ? outgoingStreams : incomingStreams)){ + if(ss->id==id) + return ss; + } + return s; +} + +CellularCarrierInfo VoIPController::GetCarrierInfo(){ +#if defined(__APPLE__) && TARGET_OS_IOS + return DarwinSpecific::GetCarrierInfo(); +#elif defined(__ANDROID__) + CellularCarrierInfo carrier; + jni::DoWithJNI([&carrier](JNIEnv* env){ + jmethodID getCarrierInfoMethod=env->GetStaticMethodID(jniUtilitiesClass, "getCarrierInfo", "()[Ljava/lang/String;"); + jobjectArray jinfo=(jobjectArray) env->CallStaticObjectMethod(jniUtilitiesClass, getCarrierInfoMethod); + if(jinfo && env->GetArrayLength(jinfo)==4){ + carrier.name=jni::JavaStringToStdString(env, (jstring)env->GetObjectArrayElement(jinfo, 0)); + carrier.countryCode=jni::JavaStringToStdString(env, (jstring)env->GetObjectArrayElement(jinfo, 1)); + carrier.mcc=jni::JavaStringToStdString(env, (jstring)env->GetObjectArrayElement(jinfo, 2)); + carrier.mnc=jni::JavaStringToStdString(env, (jstring)env->GetObjectArrayElement(jinfo, 3)); + }else{ + LOGW("Failed to get carrier info"); + } + }); + return carrier; +#else + return CellularCarrierInfo(); +#endif +} + +#pragma mark - Audio I/O + +void VoIPController::HandleAudioInput(unsigned char *data, size_t len, unsigned char* secondaryData, size_t secondaryLen){ + if(stopping) + return; + + // TODO make an AudioPacketSender + + Buffer dataBuf=outgoingAudioBufferPool.Get(); + Buffer secondaryDataBuf=secondaryLen && secondaryData ? outgoingAudioBufferPool.Get() : Buffer(); + dataBuf.CopyFrom(data, 0, len); + if(secondaryLen && secondaryData){ + secondaryDataBuf.CopyFrom(secondaryData, 0, secondaryLen); + } + shared_ptr dataBufPtr=make_shared(move(dataBuf)); + shared_ptr secondaryDataBufPtr=make_shared(move(secondaryDataBuf)); + + messageThread.Post([this, dataBufPtr, secondaryDataBufPtr, len, secondaryLen](){ + unsentStreamPacketsHistory.Add(static_cast(unsentStreamPackets)); + if(unsentStreamPacketsHistory.Average()>=maxUnsentStreamPackets && !videoPacketSender){ + LOGW("Resetting stalled send queue"); + sendQueue.clear(); + unsentStreamPacketsHistory.Reset(); + unsentStreamPackets=0; + } + if(waitingForAcks || dontSendPackets>0 || ((unsigned int) unsentStreamPackets>=maxUnsentStreamPackets /*&& endpoints[currentEndpoint].type==Endpoint::Type::TCP_RELAY*/)){ + LOGV("waiting for queue, dropping outgoing audio packet, %d %d %d [%d]", (unsigned int) unsentStreamPackets, waitingForAcks, dontSendPackets, maxUnsentStreamPackets); + return; + } + //LOGV("Audio packet size %u", (unsigned int)len); + if(!receivedInitAck) + return; + + BufferOutputStream pkt(1500); + + bool hasExtraFEC=peerVersion>=7 && secondaryLen && shittyInternetMode; + unsigned char flags=(unsigned char) (len>255 || hasExtraFEC ? STREAM_DATA_FLAG_LEN16 : 0); + pkt.WriteByte((unsigned char) (1 | flags)); // streamID + flags + if(len>255 || hasExtraFEC){ + int16_t lenAndFlags=static_cast(len); + if(hasExtraFEC) + lenAndFlags|=STREAM_DATA_XFLAG_EXTRA_FEC; + pkt.WriteInt16(lenAndFlags); + }else{ + pkt.WriteByte((unsigned char) len); + } + pkt.WriteInt32(audioTimestampOut); + pkt.WriteBytes(*dataBufPtr, 0, len); + + if(hasExtraFEC){ + pkt.WriteByte((unsigned char) std::min((int) ecAudioPackets.size(), extraEcLevel)); + for(vector::iterator ecData=ecAudioPackets.begin()+std::max(0, (int) ecAudioPackets.size()-extraEcLevel); ecData!=ecAudioPackets.end(); ++ecData){ + pkt.WriteByte((unsigned char) ecData->Length()); + pkt.WriteBytes(*ecData); + } + Buffer ecBuf(secondaryLen); + ecBuf.CopyFrom(**secondaryDataBufPtr, 0, secondaryLen); + ecAudioPackets.push_back(move(ecBuf)); + while(ecAudioPackets.size()>4) + ecAudioPackets.erase(ecAudioPackets.begin()); + } + + unsentStreamPackets++; + PendingOutgoingPacket p{ + /*.seq=*/GenerateOutSeq(), + /*.type=*/PKT_STREAM_DATA, + /*.len=*/pkt.GetLength(), + /*.data=*/Buffer(move(pkt)), + /*.endpoint=*/0, + }; + + conctl->PacketSent(p.seq, p.len); + + SendOrEnqueuePacket(move(p)); + if(peerVersion<7 && secondaryLen && shittyInternetMode){ + Buffer ecBuf(secondaryLen); + ecBuf.CopyFrom(*secondaryDataBufPtr, 0, secondaryLen); + ecAudioPackets.push_back(move(ecBuf)); + while(ecAudioPackets.size()>4) + ecAudioPackets.erase(ecAudioPackets.begin()); + pkt=BufferOutputStream(1500); + pkt.WriteByte(outgoingStreams[0]->id); + pkt.WriteInt32(audioTimestampOut); + pkt.WriteByte((unsigned char) std::min((int) ecAudioPackets.size(), extraEcLevel)); + for(vector::iterator ecData=ecAudioPackets.begin()+std::max(0, (int) ecAudioPackets.size()-extraEcLevel); ecData!=ecAudioPackets.end(); ++ecData){ + pkt.WriteByte((unsigned char) ecData->Length()); + pkt.WriteBytes(*ecData); + } + + PendingOutgoingPacket p{ + GenerateOutSeq(), + PKT_STREAM_EC, + pkt.GetLength(), + Buffer(move(pkt)), + 0 + }; + SendOrEnqueuePacket(move(p)); + } + + audioTimestampOut+=outgoingStreams[0]->frameDuration; + }); + +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) + if (audioPreprocDataCallback && preprocDecoder) { + int size=opus_decode(preprocDecoder, data, len, preprocBuffer, 4096, 0); + audioPreprocDataCallback(preprocBuffer, size); + } +#endif +} + +void VoIPController::InitializeAudio(){ + double t=GetCurrentTime(); + shared_ptr outgoingAudioStream=GetStreamByType(STREAM_TYPE_AUDIO, true); + LOGI("before create audio io"); + audioIO=audio::AudioIO::Create(currentAudioInput, currentAudioOutput); + audioInput=audioIO->GetInput(); + audioOutput=audioIO->GetOutput(); +#ifdef __ANDROID__ + audio::AudioInputAndroid* androidInput=dynamic_cast(audioInput); + if(androidInput){ + unsigned int effects=androidInput->GetEnabledEffects(); + if(!(effects & audio::AudioInputAndroid::EFFECT_AEC)){ + config.enableAEC=true; + LOGI("Forcing software AEC because built-in is not good"); + } + if(!(effects & audio::AudioInputAndroid::EFFECT_NS)){ + config.enableNS=true; + LOGI("Forcing software NS because built-in is not good"); + } + } +#elif defined(__APPLE__) && TARGET_OS_OSX + SetAudioOutputDuckingEnabled(macAudioDuckingEnabled); +#endif + LOGI("AEC: %d NS: %d AGC: %d", config.enableAEC, config.enableNS, config.enableAGC); + echoCanceller=new EchoCanceller(config.enableAEC, config.enableNS, config.enableAGC); + encoder=new OpusEncoder(audioInput, true); + encoder->SetCallback(bind(&VoIPController::HandleAudioInput, this, placeholders::_1, placeholders::_2, placeholders::_3, placeholders::_4)); + encoder->SetOutputFrameDuration(outgoingAudioStream->frameDuration); + encoder->SetEchoCanceller(echoCanceller); + encoder->SetSecondaryEncoderEnabled(false); + if(config.enableVolumeControl){ + encoder->AddAudioEffect(&inputVolume); + } + +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) + dynamic_cast(audioInput)->SetDataCallback(audioInputDataCallback); + dynamic_cast(audioOutput)->SetDataCallback(audioOutputDataCallback); +#endif + + if(!audioOutput->IsInitialized()){ + LOGE("Error initializing audio playback"); + lastError=ERROR_AUDIO_IO; + + SetState(STATE_FAILED); + return; + } + UpdateAudioBitrateLimit(); + LOGI("Audio initialization took %f seconds", GetCurrentTime()-t); +} + +void VoIPController::StartAudio(){ + OnAudioOutputReady(); + + encoder->Start(); + if(!micMuted){ + audioInput->Start(); + if(!audioInput->IsInitialized()){ + LOGE("Error initializing audio capture"); + lastError=ERROR_AUDIO_IO; + + SetState(STATE_FAILED); + return; + } + } +} + +void VoIPController::OnAudioOutputReady(){ + LOGI("Audio I/O ready"); + shared_ptr& stm=incomingStreams[0]; + stm->decoder=make_shared(audioOutput, true, peerVersion>=6); + stm->decoder->SetEchoCanceller(echoCanceller); + if(config.enableVolumeControl){ + stm->decoder->AddAudioEffect(&outputVolume); + } + stm->decoder->SetJitterBuffer(stm->jitterBuffer); + stm->decoder->SetFrameDuration(stm->frameDuration); + stm->decoder->Start(); +} + +void VoIPController::UpdateAudioOutputState(){ + bool areAnyAudioStreamsEnabled=false; + for(vector>::iterator s=incomingStreams.begin();s!=incomingStreams.end();++s){ + if((*s)->type==STREAM_TYPE_AUDIO && (*s)->enabled) + areAnyAudioStreamsEnabled=true; + } + if(audioOutput){ + LOGV("New audio output state: %d", areAnyAudioStreamsEnabled); + if(audioOutput->IsPlaying()!=areAnyAudioStreamsEnabled){ + if(areAnyAudioStreamsEnabled) + audioOutput->Start(); + else + audioOutput->Stop(); + } + } +} + +#pragma mark - Bandwidth management + +void VoIPController::UpdateAudioBitrateLimit(){ + if(encoder){ + if(dataSavingMode || dataSavingRequestedByPeer){ + maxBitrate=maxAudioBitrateSaving; + encoder->SetBitrate(initAudioBitrateSaving); + }else if(networkType==NET_TYPE_GPRS){ + maxBitrate=maxAudioBitrateGPRS; + encoder->SetBitrate(initAudioBitrateGPRS); + }else if(networkType==NET_TYPE_EDGE){ + maxBitrate=maxAudioBitrateEDGE; + encoder->SetBitrate(initAudioBitrateEDGE); + }else{ + maxBitrate=maxAudioBitrate; + encoder->SetBitrate(initAudioBitrate); + } + encoder->SetVadMode(dataSavingMode || dataSavingRequestedByPeer); + if(echoCanceller) + echoCanceller->SetVoiceDetectionEnabled(dataSavingMode || dataSavingRequestedByPeer); + } +} + +void VoIPController::UpdateDataSavingState(){ + if(config.dataSaving==DATA_SAVING_ALWAYS){ + dataSavingMode=true; + }else if(config.dataSaving==DATA_SAVING_MOBILE){ + dataSavingMode=networkType==NET_TYPE_GPRS || networkType==NET_TYPE_EDGE || + networkType==NET_TYPE_3G || networkType==NET_TYPE_HSPA || networkType==NET_TYPE_LTE || networkType==NET_TYPE_OTHER_MOBILE; + }else{ + dataSavingMode=false; + } + LOGI("update data saving mode, config %d, enabled %d, reqd by peer %d", config.dataSaving, dataSavingMode, dataSavingRequestedByPeer); +} + +#pragma mark - Networking & crypto + +uint32_t VoIPController::GenerateOutSeq(){ + return seq++; +} + +void VoIPController::WritePacketHeader(uint32_t pseq, BufferOutputStream *s, unsigned char type, uint32_t length, PacketSender* source){ + uint32_t acks=0; + int i; + for(i=0;i<32;i++){ + if(find(recentIncomingPackets.begin(), recentIncomingPackets.end(), lastRemoteSeq-(i+1))!=recentIncomingPackets.end()){ + acks |= (1 << (31-i)); + } + } + + if(peerVersion>=8 || (!peerVersion && connectionMaxLayer>=92)){ + s->WriteByte(type); + s->WriteInt32(lastRemoteSeq); + s->WriteInt32(pseq); + s->WriteInt32(acks); + unsigned char flags; + if(currentExtras.empty()){ + flags=0; + }else{ + flags=XPFLAG_HAS_EXTRA; + } + + shared_ptr videoStream=GetStreamByType(STREAM_TYPE_VIDEO, false); + if(peerVersion>=9 && videoStream && videoStream->enabled) + flags |= XPFLAG_HAS_RECV_TS; + + s->WriteByte(flags); + + if(!currentExtras.empty()){ + s->WriteByte(static_cast(currentExtras.size())); + for(vector::iterator x=currentExtras.begin(); x!=currentExtras.end(); ++x){ + LOGV("Writing extra into header: type %u, length %d", x->type, int(x->data.Length())); + assert(x->data.Length()<=254); + s->WriteByte(static_cast(x->data.Length()+1)); + s->WriteByte(x->type); + s->WriteBytes(*x->data, x->data.Length()); + if(x->firstContainingSeq==0) + x->firstContainingSeq=pseq; + } + } + if(peerVersion>=9 && videoStream && videoStream->enabled){ + s->WriteInt32((uint32_t)((lastRecvPacketTime-connectionInitTime)*1000.0)); + } + }else{ + if(state==STATE_WAIT_INIT || state==STATE_WAIT_INIT_ACK){ + s->WriteInt32(TLID_DECRYPTED_AUDIO_BLOCK); + int64_t randomID; + crypto.rand_bytes((uint8_t *) &randomID, 8); + s->WriteInt64(randomID); + unsigned char randBytes[7]; + crypto.rand_bytes(randBytes, 7); + s->WriteByte(7); + s->WriteBytes(randBytes, 7); + uint32_t pflags=PFLAG_HAS_RECENT_RECV | PFLAG_HAS_SEQ; + if(length>0) + pflags|=PFLAG_HAS_DATA; + if(state==STATE_WAIT_INIT || state==STATE_WAIT_INIT_ACK){ + pflags|=PFLAG_HAS_CALL_ID | PFLAG_HAS_PROTO; + } + pflags|=((uint32_t) type) << 24; + s->WriteInt32(pflags); + + if(pflags & PFLAG_HAS_CALL_ID){ + s->WriteBytes(callID, 16); + } + s->WriteInt32(lastRemoteSeq); + s->WriteInt32(pseq); + s->WriteInt32(acks); + if(pflags & PFLAG_HAS_PROTO){ + s->WriteInt32(PROTOCOL_NAME); + } + if(length>0){ + if(length<=253){ + s->WriteByte((unsigned char) length); + }else{ + s->WriteByte(254); + s->WriteByte((unsigned char) (length & 0xFF)); + s->WriteByte((unsigned char) ((length >> 8) & 0xFF)); + s->WriteByte((unsigned char) ((length >> 16) & 0xFF)); + } + } + }else{ + s->WriteInt32(TLID_SIMPLE_AUDIO_BLOCK); + int64_t randomID; + crypto.rand_bytes((uint8_t *) &randomID, 8); + s->WriteInt64(randomID); + unsigned char randBytes[7]; + crypto.rand_bytes(randBytes, 7); + s->WriteByte(7); + s->WriteBytes(randBytes, 7); + uint32_t lenWithHeader=length+13; + if(lenWithHeader>0){ + if(lenWithHeader<=253){ + s->WriteByte((unsigned char) lenWithHeader); + }else{ + s->WriteByte(254); + s->WriteByte((unsigned char) (lenWithHeader & 0xFF)); + s->WriteByte((unsigned char) ((lenWithHeader >> 8) & 0xFF)); + s->WriteByte((unsigned char) ((lenWithHeader >> 16) & 0xFF)); + } + } + s->WriteByte(type); + s->WriteInt32(lastRemoteSeq); + s->WriteInt32(pseq); + s->WriteInt32(acks); + if(peerVersion>=6){ + if(currentExtras.empty()){ + s->WriteByte(0); + }else{ + s->WriteByte(XPFLAG_HAS_EXTRA); + s->WriteByte(static_cast(currentExtras.size())); + for(vector::iterator x=currentExtras.begin(); x!=currentExtras.end(); ++x){ + LOGV("Writing extra into header: type %u, length %d", x->type, int(x->data.Length())); + assert(x->data.Length()<=254); + s->WriteByte(static_cast(x->data.Length()+1)); + s->WriteByte(x->type); + s->WriteBytes(*x->data, x->data.Length()); + if(x->firstContainingSeq==0) + x->firstContainingSeq=pseq; + } + } + } + } + } + + + unacknowledgedIncomingPacketCount=0; + recentOutgoingPackets.push_back(RecentOutgoingPacket{ + pseq, + 0, + GetCurrentTime(), + 0, + type, + length, + source, + false + }); + while(recentOutgoingPackets.size()>MAX_RECENT_PACKETS){ + recentOutgoingPackets.erase(recentOutgoingPackets.begin()); + } + lastSentSeq=pseq; + //LOGI("packet header size %d", s->GetLength()); +} + + + +void VoIPController::SendInit(){ + ENFORCE_MSG_THREAD; + + uint32_t initSeq=GenerateOutSeq(); + for(pair& _e:endpoints){ + Endpoint& e=_e.second; + if(e.type==Endpoint::Type::TCP_RELAY && !useTCP) + continue; + BufferOutputStream out(1024); + out.WriteInt32(PROTOCOL_VERSION); + out.WriteInt32(MIN_PROTOCOL_VERSION); + uint32_t flags=0; + if(config.enableCallUpgrade) + flags|=INIT_FLAG_GROUP_CALLS_SUPPORTED; + if(config.enableVideoReceive) + flags|=INIT_FLAG_VIDEO_RECV_SUPPORTED; + if(config.enableVideoSend) + flags|=INIT_FLAG_VIDEO_SEND_SUPPORTED; + if(dataSavingMode) + flags|=INIT_FLAG_DATA_SAVING_ENABLED; + out.WriteInt32(flags); + if(connectionMaxLayer<74){ + out.WriteByte(2); // audio codecs count + out.WriteByte(CODEC_OPUS_OLD); + out.WriteByte(0); + out.WriteByte(0); + out.WriteByte(0); + out.WriteInt32(CODEC_OPUS); + out.WriteByte(0); // video codecs count (decode) + out.WriteByte(0); // video codecs count (encode) + }else{ + out.WriteByte(1); + out.WriteInt32(CODEC_OPUS); + vector decoders=config.enableVideoReceive ? video::VideoRenderer::GetAvailableDecoders() : vector(); + vector encoders=config.enableVideoSend ? video::VideoSource::GetAvailableEncoders() : vector(); + out.WriteByte((unsigned char)decoders.size()); + for(uint32_t id:decoders){ + out.WriteInt32(id); + } + if(connectionMaxLayer>=92) + out.WriteByte((unsigned char)video::VideoRenderer::GetMaximumResolution()); + else + out.WriteByte(0); + } + SendOrEnqueuePacket(PendingOutgoingPacket{ + /*.seq=*/initSeq, + /*.type=*/PKT_INIT, + /*.len=*/out.GetLength(), + /*.data=*/Buffer(move(out)), + /*.endpoint=*/e.id + }); + } + + if(state==STATE_WAIT_INIT) + SetState(STATE_WAIT_INIT_ACK); + messageThread.Post([this]{ + if(state==STATE_WAIT_INIT_ACK){ + SendInit(); + } + }, 0.5); +} + +void VoIPController::InitUDPProxy(){ + if(realUdpSocket!=udpSocket){ + udpSocket->Close(); + delete udpSocket; + udpSocket=realUdpSocket; + } + char sbuf[128]; + snprintf(sbuf, sizeof(sbuf), "%s:%u", proxyAddress.c_str(), proxyPort); + string proxyHostPort(sbuf); + if(proxyHostPort==lastTestedProxyServer && !proxySupportsUDP){ + LOGI("Proxy does not support UDP - using UDP directly instead"); + messageThread.Post(bind(&VoIPController::ResetUdpAvailability, this)); + return; + } + + NetworkSocket* tcp=NetworkSocket::Create(NetworkProtocol::TCP); + tcp->Connect(resolvedProxyAddress, proxyPort); + + vector writeSockets; + vector readSockets; + vector errorSockets; + + while(!tcp->IsFailed() && !tcp->IsReadyToSend()){ + writeSockets.push_back(tcp); + if(!NetworkSocket::Select(readSockets, writeSockets, errorSockets, selectCanceller)){ + LOGW("Select canceled while waiting for proxy control socket to connect"); + delete tcp; + return; + } + } + LOGV("UDP proxy control socket ready to send"); + NetworkSocketSOCKS5Proxy* udpProxy=new NetworkSocketSOCKS5Proxy(tcp, realUdpSocket, proxyUsername, proxyPassword); + udpProxy->OnReadyToSend(); + writeSockets.clear(); + while(!udpProxy->IsFailed() && !tcp->IsFailed() && !udpProxy->IsReadyToSend()){ + readSockets.clear(); + errorSockets.clear(); + readSockets.push_back(tcp); + errorSockets.push_back(tcp); + if(!NetworkSocket::Select(readSockets, writeSockets, errorSockets, selectCanceller)){ + LOGW("Select canceled while waiting for UDP proxy to initialize"); + delete udpProxy; + return; + } + if(!readSockets.empty()) + udpProxy->OnReadyToReceive(); + } + LOGV("UDP proxy initialized"); + + if(udpProxy->IsFailed()){ + udpProxy->Close(); + delete udpProxy; + proxySupportsUDP=false; + }else{ + udpSocket=udpProxy; + } + messageThread.Post(bind(&VoIPController::ResetUdpAvailability, this)); +} + +void VoIPController::RunRecvThread(){ + LOGI("Receive thread starting"); + if(proxyProtocol==PROXY_SOCKS5){ + resolvedProxyAddress=NetworkSocket::ResolveDomainName(proxyAddress); + if(resolvedProxyAddress.IsEmpty()){ + LOGW("Error resolving proxy address %s", proxyAddress.c_str()); + SetState(STATE_FAILED); + return; + } + }else{ + udpConnectivityState=UDP_PING_PENDING; + udpPingTimeoutID=messageThread.Post(std::bind(&VoIPController::SendUdpPings, this), 0.0, 0.5); + } + while(runReceiver){ + + if(proxyProtocol==PROXY_SOCKS5 && needReInitUdpProxy){ + InitUDPProxy(); + needReInitUdpProxy=false; + } + + vector readSockets; + vector errorSockets; + vector writeSockets; + readSockets.push_back(udpSocket); + errorSockets.push_back(realUdpSocket); + if(!realUdpSocket->IsReadyToSend()) + writeSockets.push_back(realUdpSocket); + + { + MutexGuard m(endpointsMutex); + for(pair& _e:endpoints){ + const Endpoint& e=_e.second; + if(e.type==Endpoint::Type::TCP_RELAY){ + if(e.socket){ + readSockets.push_back(&*e.socket); + errorSockets.push_back(&*e.socket); + if(!e.socket->IsReadyToSend()){ + NetworkSocketSOCKS5Proxy* proxy=dynamic_cast(&*e.socket); + if(!proxy || proxy->NeedSelectForSending()) + writeSockets.push_back(&*e.socket); + } + } + } + } + } + + { + bool selRes=NetworkSocket::Select(readSockets, writeSockets, errorSockets, selectCanceller); + if(!selRes){ + LOGV("Select canceled"); + continue; + } + } + if(!runReceiver) + return; + + if(!errorSockets.empty()){ + if(find(errorSockets.begin(), errorSockets.end(), realUdpSocket)!=errorSockets.end()){ + LOGW("UDP socket failed"); + SetState(STATE_FAILED); + return; + } + MutexGuard m(endpointsMutex); + for(NetworkSocket*& socket:errorSockets){ + for(pair& _e:endpoints){ + Endpoint& e=_e.second; + if(e.socket && &*e.socket==socket){ + e.socket->Close(); + e.socket.reset(); + LOGI("Closing failed TCP socket for %s:%u", e.GetAddress().ToString().c_str(), e.port); + } + } + } + continue; + } + + for(NetworkSocket*& socket:readSockets){ + //while(packet.length){ + NetworkPacket packet=socket->Receive(); + if(packet.address.IsEmpty()){ + LOGE("Packet has null address. This shouldn't happen."); + continue; + } + if(packet.data.IsEmpty()){ + LOGE("Packet has zero length."); + continue; + } + //LOGV("Received %d bytes from %s:%d at %.5lf", len, packet.address->ToString().c_str(), packet.port, GetCurrentTime()); + messageThread.Post(bind(&VoIPController::NetworkPacketReceived, this, make_shared(move(packet)))); + } + + if(!writeSockets.empty()){ + messageThread.Post(bind(&VoIPController::TrySendQueuedPackets, this)); + } + } + LOGI("=== recv thread exiting ==="); +} + +void VoIPController::TrySendQueuedPackets(){ + ENFORCE_MSG_THREAD; + + for(vector::iterator opkt=sendQueue.begin();opkt!=sendQueue.end();){ + Endpoint* endpoint=GetEndpointForPacket(*opkt); + if(!endpoint){ + opkt=sendQueue.erase(opkt); + LOGE("SendQueue contained packet for nonexistent endpoint"); + continue; + } + bool canSend; + if(endpoint->type!=Endpoint::Type::TCP_RELAY) + canSend=realUdpSocket->IsReadyToSend(); + else + canSend=endpoint->socket && endpoint->socket->IsReadyToSend(); + if(canSend){ + LOGI("Sending queued packet"); + SendOrEnqueuePacket(move(*opkt), false); + opkt=sendQueue.erase(opkt); + }else{ + ++opkt; + } + } +} + +bool VoIPController::WasOutgoingPacketAcknowledged(uint32_t seq){ + RecentOutgoingPacket* pkt=GetRecentOutgoingPacket(seq); + if(!pkt) + return false; + return pkt->ackTime!=0.0; +} + +VoIPController::RecentOutgoingPacket *VoIPController::GetRecentOutgoingPacket(uint32_t seq){ + for(RecentOutgoingPacket& opkt:recentOutgoingPackets){ + if(opkt.seq==seq){ + return &opkt; + } + } + return NULL; +} + +void VoIPController::NetworkPacketReceived(shared_ptr _packet){ + ENFORCE_MSG_THREAD; + + NetworkPacket& packet=*_packet; + + int64_t srcEndpointID=0; + + if(!packet.address.isIPv6){ + for(pair& _e:endpoints){ + const Endpoint& e=_e.second; + if(e.address==packet.address && e.port==packet.port){ + if((e.type!=Endpoint::Type::TCP_RELAY && packet.protocol==NetworkProtocol::UDP) || (e.type==Endpoint::Type::TCP_RELAY && packet.protocol==NetworkProtocol::TCP)){ + srcEndpointID=e.id; + break; + } + } + } + if(!srcEndpointID && packet.protocol==NetworkProtocol::UDP){ + try{ + Endpoint &p2p=GetEndpointByType(Endpoint::Type::UDP_P2P_INET); + if(p2p.rtts[0]==0.0 && p2p.address.PrefixMatches(24, packet.address)){ + LOGD("Packet source matches p2p endpoint partially: %s:%u", packet.address.ToString().c_str(), packet.port); + srcEndpointID=p2p.id; + } + }catch(out_of_range& ex){} + } + }else{ + for(pair &_e:endpoints){ + const Endpoint& e=_e.second; + if(e.v6address==packet.address && e.port==packet.port && e.IsIPv6Only()){ + if((e.type!=Endpoint::Type::TCP_RELAY && packet.protocol==NetworkProtocol::UDP) || (e.type==Endpoint::Type::TCP_RELAY && packet.protocol==NetworkProtocol::TCP)){ + srcEndpointID=e.id; + break; + } + } + } + } + + if(!srcEndpointID){ + LOGW("Received a packet from unknown source %s:%u", packet.address.ToString().c_str(), packet.port); + return; + } + /*if(len<=0){ + //LOGW("error receiving: %d / %s", errno, strerror(errno)); + continue; + }*/ + if(IS_MOBILE_NETWORK(networkType)) + stats.bytesRecvdMobile+=(uint64_t) packet.data.Length(); + else + stats.bytesRecvdWifi+=(uint64_t) packet.data.Length(); + try{ + ProcessIncomingPacket(packet, endpoints.at(srcEndpointID)); + }catch(out_of_range& x){ + LOGW("Error parsing packet: %s", x.what()); + } +} + +void VoIPController::ProcessIncomingPacket(NetworkPacket &packet, Endpoint& srcEndpoint){ + ENFORCE_MSG_THREAD; + + unsigned char *buffer=*packet.data; + size_t len=packet.data.Length(); + BufferInputStream in(packet.data); + bool hasPeerTag=false; + if(peerVersion<9 || srcEndpoint.type==Endpoint::Type::UDP_RELAY || srcEndpoint.type==Endpoint::Type::TCP_RELAY){ + if(memcmp(buffer, srcEndpoint.type==Endpoint::Type::UDP_RELAY || srcEndpoint.type==Endpoint::Type::TCP_RELAY ? (void *) srcEndpoint.peerTag : (void *) callID, 16)!=0){ + LOGW("Received packet has wrong peerTag"); + return; + } + in.Seek(16); + hasPeerTag=true; + } + if(in.Remaining()>=16 && (srcEndpoint.type==Endpoint::Type::UDP_RELAY || srcEndpoint.type==Endpoint::Type::TCP_RELAY) + && *reinterpret_cast(buffer+16)==0xFFFFFFFFFFFFFFFFLL && *reinterpret_cast(buffer+24)==0xFFFFFFFF){ + // relay special request response + in.Seek(16+12); + uint32_t tlid=(uint32_t) in.ReadInt32(); + + if(tlid==TLID_UDP_REFLECTOR_SELF_INFO){ + if(srcEndpoint.type==Endpoint::Type::UDP_RELAY /*&& udpConnectivityState==UDP_PING_SENT*/ && in.Remaining()>=32){ + int32_t date=in.ReadInt32(); + int64_t queryID=in.ReadInt64(); + unsigned char myIP[16]; + in.ReadBytes(myIP, 16); + int32_t myPort=in.ReadInt32(); + //udpConnectivityState=UDP_AVAILABLE; + double selfRTT=0.0; + srcEndpoint.udpPongCount++; + srcEndpoint.totalUdpPingReplies++; + if(srcEndpoint.udpPingTimes.find(queryID)!=srcEndpoint.udpPingTimes.end()){ + double sendTime=srcEndpoint.udpPingTimes[queryID]; + srcEndpoint.udpPingTimes.erase(queryID); + srcEndpoint.selfRtts.Add(selfRTT=GetCurrentTime()-sendTime); + } + LOGV("Received UDP ping reply from %s:%d: date=%d, queryID=%ld, my IP=%s, my port=%d, selfRTT=%f", srcEndpoint.address.ToString().c_str(), srcEndpoint.port, date, (long int) queryID, NetworkAddress::IPv4(*reinterpret_cast(myIP+12)).ToString().c_str(), myPort, selfRTT); + if(srcEndpoint.IsIPv6Only() && !didSendIPv6Endpoint){ + NetworkAddress realAddr=NetworkAddress::IPv6(myIP); + if(realAddr==myIPv6){ + LOGI("Public IPv6 matches local address"); + useIPv6=true; + if(allowP2p){ + didSendIPv6Endpoint=true; + BufferOutputStream o(18); + o.WriteBytes(myIP, 16); + o.WriteInt16(udpSocket->GetLocalPort()); + Buffer b(move(o)); + SendExtra(b, EXTRA_TYPE_IPV6_ENDPOINT); + } + } + } + } + }else if(tlid==TLID_UDP_REFLECTOR_PEER_INFO){ + if(in.Remaining()>=16){ + uint32_t myAddr=(uint32_t) in.ReadInt32(); + uint32_t myPort=(uint32_t) in.ReadInt32(); + uint32_t peerAddr=(uint32_t) in.ReadInt32(); + uint32_t peerPort=(uint32_t) in.ReadInt32(); + + constexpr int64_t p2pID=(int64_t) (FOURCC('P', '2', 'P', '4')) << 32; + constexpr int64_t lanID=(int64_t) (FOURCC('L', 'A', 'N', '4')) << 32; + + if(currentEndpoint==p2pID || currentEndpoint==lanID) + currentEndpoint=preferredRelay; + + if(endpoints.find(lanID)!=endpoints.end()){ + MutexGuard m(endpointsMutex); + endpoints.erase(lanID); + } + + unsigned char peerTag[16]; + LOGW("Received reflector peer info, my=%s:%u, peer=%s:%u", NetworkAddress::IPv4(myAddr).ToString().c_str(), myPort, NetworkAddress::IPv4(peerAddr).ToString().c_str(), peerPort); + if(waitingForRelayPeerInfo){ + Endpoint p2p(p2pID, (uint16_t) peerPort, NetworkAddress::IPv4(peerAddr), NetworkAddress::Empty(), Endpoint::Type::UDP_P2P_INET, peerTag); + { + MutexGuard m(endpointsMutex); + endpoints[p2pID]=p2p; + } + if(myAddr==peerAddr){ + LOGW("Detected LAN"); + NetworkAddress lanAddr=NetworkAddress::IPv4(0); + udpSocket->GetLocalInterfaceInfo(&lanAddr, NULL); + + BufferOutputStream pkt(8); + pkt.WriteInt32(lanAddr.addr.ipv4); + pkt.WriteInt32(udpSocket->GetLocalPort()); + if(peerVersion<6){ + SendPacketReliably(PKT_LAN_ENDPOINT, pkt.GetBuffer(), pkt.GetLength(), 0.5, 10); + }else{ + Buffer buf(move(pkt)); + SendExtra(buf, EXTRA_TYPE_LAN_ENDPOINT); + } + } + waitingForRelayPeerInfo=false; + } + } + }else{ + LOGV("Received relay response with unknown tl id: 0x%08X", tlid); + } + return; + } + if(in.Remaining()<40){ + LOGV("Received packet is too small"); + return; + } + + bool retryWith2=false; + size_t innerLen=0; + bool shortFormat=peerVersion>=8 || (!peerVersion && connectionMaxLayer>=92); + + if(!useMTProto2){ + unsigned char fingerprint[8], msgHash[16]; + in.ReadBytes(fingerprint, 8); + in.ReadBytes(msgHash, 16); + unsigned char key[32], iv[32]; + KDF(msgHash, isOutgoing ? 8 : 0, key, iv); + unsigned char aesOut[MSC_STACK_FALLBACK(in.Remaining(), 1500)]; + if(in.Remaining()>sizeof(aesOut)) + return; + crypto.aes_ige_decrypt((unsigned char *) buffer+in.GetOffset(), aesOut, in.Remaining(), key, iv); + BufferInputStream _in(aesOut, in.Remaining()); + unsigned char sha[SHA1_LENGTH]; + uint32_t _len=(uint32_t) _in.ReadInt32(); + if(_len>_in.Remaining()) + _len=(uint32_t) _in.Remaining(); + crypto.sha1((uint8_t *) (aesOut), static_cast(_len)+4, sha); + if(memcmp(msgHash, sha+(SHA1_LENGTH-16), 16)!=0){ + LOGW("Received packet has wrong hash after decryption"); + if(state==STATE_WAIT_INIT || state==STATE_WAIT_INIT_ACK) + retryWith2=true; + else + return; + }else{ + memcpy(buffer+in.GetOffset(), aesOut, in.Remaining()); + in.ReadInt32(); + } + } + + if(useMTProto2 || retryWith2){ + if(hasPeerTag) + in.Seek(16); // peer tag + + unsigned char fingerprint[8], msgKey[16]; + if(!shortFormat){ + in.ReadBytes(fingerprint, 8); + if(memcmp(fingerprint, keyFingerprint, 8)!=0){ + LOGW("Received packet has wrong key fingerprint"); + return; + } + } + in.ReadBytes(msgKey, 16); + + unsigned char decrypted[1500]; + unsigned char aesKey[32], aesIv[32]; + KDF2(msgKey, isOutgoing ? 8 : 0, aesKey, aesIv); + size_t decryptedLen=in.Remaining(); + if(decryptedLen>sizeof(decrypted)) + return; + if(decryptedLen%16!=0){ + LOGW("wrong decrypted length"); + return; + } + + crypto.aes_ige_decrypt(*packet.data+in.GetOffset(), decrypted, decryptedLen, aesKey, aesIv); + + in=BufferInputStream(decrypted, decryptedLen); + //LOGD("received packet length: %d", in.ReadInt32()); + size_t sizeSize=shortFormat ? 0 : 4; + + BufferOutputStream buf(decryptedLen+32); + size_t x=isOutgoing ? 8 : 0; + buf.WriteBytes(encryptionKey+88+x, 32); + buf.WriteBytes(decrypted+sizeSize, decryptedLen-sizeSize); + unsigned char msgKeyLarge[32]; + crypto.sha256(buf.GetBuffer(), buf.GetLength(), msgKeyLarge); + + if(memcmp(msgKey, msgKeyLarge+8, 16)!=0){ + LOGW("Received packet has wrong hash"); + return; + } + + innerLen=(uint32_t) (shortFormat ? in.ReadInt16() : in.ReadInt32()); + if(innerLen>decryptedLen-sizeSize){ + LOGW("Received packet has wrong inner length (%d with total of %u)", (int) innerLen, (unsigned int) decryptedLen); + return; + } + if(decryptedLen-innerLen<(shortFormat ? 16 : 12)){ + LOGW("Received packet has too little padding (%u)", (unsigned int) (decryptedLen-innerLen)); + return; + } + memcpy(buffer, decrypted+(shortFormat ? 2 : 4), innerLen); + in=BufferInputStream(buffer, (size_t) innerLen); + if(retryWith2){ + LOGD("Successfully decrypted packet in MTProto2.0 fallback, upgrading"); + useMTProto2=true; + } + } + + lastRecvPacketTime=GetCurrentTime(); + + if(state==STATE_RECONNECTING){ + LOGI("Received a valid packet while reconnecting - setting state to established"); + SetState(STATE_ESTABLISHED); + } + + if(srcEndpoint.type==Endpoint::Type::UDP_P2P_INET && !srcEndpoint.IsIPv6Only()){ + if(srcEndpoint.port!=packet.port || srcEndpoint.address!=packet.address){ + if(!packet.address.isIPv6){ + LOGI("Incoming packet was decrypted successfully, changing P2P endpoint to %s:%u", packet.address.ToString().c_str(), packet.port); + srcEndpoint.address=packet.address; + srcEndpoint.port=packet.port; + } + } + } + + /*decryptedAudioBlock random_id:long random_bytes:string flags:# voice_call_id:flags.2?int128 in_seq_no:flags.4?int out_seq_no:flags.4?int + * recent_received_mask:flags.5?int proto:flags.3?int extra:flags.1?string raw_data:flags.0?string = DecryptedAudioBlock +simpleAudioBlock random_id:long random_bytes:string raw_data:string = DecryptedAudioBlock; +*/ + uint32_t ackId, pseq, acks; + unsigned char type, pflags; + size_t packetInnerLen=0; + if(shortFormat){ + type=in.ReadByte(); + ackId=(uint32_t) in.ReadInt32(); + pseq=(uint32_t) in.ReadInt32(); + acks=(uint32_t) in.ReadInt32(); + pflags=in.ReadByte(); + packetInnerLen=innerLen-14; + }else{ + uint32_t tlid=(uint32_t) in.ReadInt32(); + if(tlid==TLID_DECRYPTED_AUDIO_BLOCK){ + in.ReadInt64(); // random id + uint32_t randLen=(uint32_t) in.ReadTlLength(); + in.Seek(in.GetOffset()+randLen+pad4(randLen)); + uint32_t flags=(uint32_t) in.ReadInt32(); + type=(unsigned char) ((flags >> 24) & 0xFF); + if(!(flags & PFLAG_HAS_SEQ && flags & PFLAG_HAS_RECENT_RECV)){ + LOGW("Received packet doesn't have PFLAG_HAS_SEQ, PFLAG_HAS_RECENT_RECV, or both"); + + return; + } + if(flags & PFLAG_HAS_CALL_ID){ + unsigned char pktCallID[16]; + in.ReadBytes(pktCallID, 16); + if(memcmp(pktCallID, callID, 16)!=0){ + LOGW("Received packet has wrong call id"); + + lastError=ERROR_UNKNOWN; + SetState(STATE_FAILED); + return; + } + } + ackId=(uint32_t) in.ReadInt32(); + pseq=(uint32_t) in.ReadInt32(); + acks=(uint32_t) in.ReadInt32(); + if(flags & PFLAG_HAS_PROTO){ + uint32_t proto=(uint32_t) in.ReadInt32(); + if(proto!=PROTOCOL_NAME){ + LOGW("Received packet uses wrong protocol"); + + lastError=ERROR_INCOMPATIBLE; + SetState(STATE_FAILED); + return; + } + } + if(flags & PFLAG_HAS_EXTRA){ + uint32_t extraLen=(uint32_t) in.ReadTlLength(); + in.Seek(in.GetOffset()+extraLen+pad4(extraLen)); + } + if(flags & PFLAG_HAS_DATA){ + packetInnerLen=in.ReadTlLength(); + } + pflags=0; + }else if(tlid==TLID_SIMPLE_AUDIO_BLOCK){ + in.ReadInt64(); // random id + uint32_t randLen=(uint32_t) in.ReadTlLength(); + in.Seek(in.GetOffset()+randLen+pad4(randLen)); + packetInnerLen=in.ReadTlLength(); + type=in.ReadByte(); + ackId=(uint32_t) in.ReadInt32(); + pseq=(uint32_t) in.ReadInt32(); + acks=(uint32_t) in.ReadInt32(); + if(peerVersion>=6) + pflags=in.ReadByte(); + else + pflags=0; + }else{ + LOGW("Received a packet of unknown type %08X", tlid); + + return; + } + } + packetsReceived++; + + if(seqgt(pseq, lastRemoteSeq-MAX_RECENT_PACKETS)){ + if(find(recentIncomingPackets.begin(), recentIncomingPackets.end(), pseq)!=recentIncomingPackets.end()){ + LOGW("Received duplicated packet for seq %u", pseq); + return; + } + recentIncomingPackets.push_back(pseq); + while(recentIncomingPackets.size()>MAX_RECENT_PACKETS) + recentIncomingPackets.erase(recentIncomingPackets.begin()); + if(seqgt(pseq, lastRemoteSeq)) + lastRemoteSeq=pseq; + }else{ + LOGW("Packet %u is out of order and too late", pseq); + return; + } + + if(pflags & XPFLAG_HAS_EXTRA){ + unsigned char extraCount=in.ReadByte(); + for(int i=0;i(in.ReadInt32()); + } + if(seqgt(ackId, lastRemoteAckSeq)){ + + if(waitingForAcks && lastRemoteAckSeq>=firstSentPing){ + rttHistory.Reset(); + waitingForAcks=false; + dontSendPackets=10; + messageThread.Post([this]{ + dontSendPackets=0; + }, 1.0); + LOGI("resuming sending"); + } + vector peerAcks; + lastRemoteAckSeq=ackId; + conctl->PacketAcknowledged(ackId); + peerAcks.push_back(ackId); + for(unsigned int i=0;i<32;i++){ + if((acks >> (31-i)) & 1){ + peerAcks.push_back(ackId-(i+1)); + } + } + + for(RecentOutgoingPacket& opkt:recentOutgoingPackets){ + if(opkt.ackTime!=0.0) + continue; + if(find(peerAcks.begin(), peerAcks.end(), opkt.seq)!=peerAcks.end()){ + opkt.ackTime=GetCurrentTime(); + if(opkt.lost){ + LOGW("acknowledged lost packet %u", opkt.seq); + sendLosses--; + } + if(opkt.sender && !opkt.lost){ // don't report lost packets as acknowledged to PacketSenders + opkt.sender->PacketAcknowledged(opkt.seq, opkt.sendTime, recvTS/1000.0f, opkt.type, opkt.size); + } + + // TODO move this to a PacketSender + conctl->PacketAcknowledged(opkt.seq); + } + } + + if(peerVersion<6){ + for(unsigned int i=0; i=0 && remoteAcksIndex<32 ? remoteAcks[remoteAcksIndex] : -1); + if(seqgt(lastRemoteAckSeq, qp.seqs[j]) && remoteAcksIndex>=0 && remoteAcksIndex<32){ + for(RecentOutgoingPacket &opkt:recentOutgoingPackets){ + if(opkt.seq==qp.seqs[j] && opkt.ackTime>0){ + LOGD("did ack seq %u, removing", qp.seqs[j]); + didAck=true; + break; + } + } + if(didAck) + break; + } + } + if(didAck){ + queuedPackets.erase(queuedPackets.begin()+i); + i--; + continue; + } + } + }else{ + for(vector::iterator x=currentExtras.begin(); x!=currentExtras.end();){ + if(x->firstContainingSeq!=0 && (lastRemoteAckSeq==x->firstContainingSeq || seqgt(lastRemoteAckSeq, x->firstContainingSeq))){ + LOGV("Peer acknowledged extra type %u length %u", x->type, (unsigned int)x->data.Length()); + ProcessAcknowledgedOutgoingExtra(*x); + x=currentExtras.erase(x); + continue; + } + ++x; + } + } + } + + Endpoint* _currentEndpoint=&endpoints.at(currentEndpoint); + if(srcEndpoint.id!=currentEndpoint && (srcEndpoint.type==Endpoint::Type::UDP_RELAY || srcEndpoint.type==Endpoint::Type::TCP_RELAY) && ((_currentEndpoint->type!=Endpoint::Type::UDP_RELAY && _currentEndpoint->type!=Endpoint::Type::TCP_RELAY) || _currentEndpoint->averageRTT==0)){ + if(seqgt(lastSentSeq-32, lastRemoteAckSeq)){ + currentEndpoint=srcEndpoint.id; + _currentEndpoint=&srcEndpoint; + LOGI("Peer network address probably changed, switching to relay"); + if(allowP2p) + SendPublicEndpointsRequest(); + } + } + + + if(config.logPacketStats){ + DebugLoggedPacket dpkt={ + static_cast(pseq), + GetCurrentTime()-connectionInitTime, + static_cast(packet.data.Length()) + }; + debugLoggedPackets.push_back(dpkt); + if(debugLoggedPackets.size()>=2500){ + debugLoggedPackets.erase(debugLoggedPackets.begin(), debugLoggedPackets.begin()+500); + } + } + + unacknowledgedIncomingPacketCount++; + if(unacknowledgedIncomingPacketCount>unackNopThreshold){ + //LOGV("Sending nop packet as ack"); + SendNopPacket(); + } + +#ifdef LOG_PACKETS + LOGV("Received: from=%s:%u, seq=%u, length=%u, type=%s", srcEndpoint.GetAddress().ToString().c_str(), srcEndpoint.port, pseq, (unsigned int)packet.data.Length(), GetPacketTypeString(type).c_str()); +#endif + + //LOGV("acks: %u -> %.2lf, %.2lf, %.2lf, %.2lf, %.2lf, %.2lf, %.2lf, %.2lf", lastRemoteAckSeq, remoteAcks[0], remoteAcks[1], remoteAcks[2], remoteAcks[3], remoteAcks[4], remoteAcks[5], remoteAcks[6], remoteAcks[7]); + //LOGD("recv: %u -> %.2lf, %.2lf, %.2lf, %.2lf, %.2lf, %.2lf, %.2lf, %.2lf", lastRemoteSeq, recvPacketTimes[0], recvPacketTimes[1], recvPacketTimes[2], recvPacketTimes[3], recvPacketTimes[4], recvPacketTimes[5], recvPacketTimes[6], recvPacketTimes[7]); + //LOGI("RTT = %.3lf", GetAverageRTT()); + //LOGV("Packet %u type is %d", pseq, type); + if(type==PKT_INIT){ + LOGD("Received init"); + uint32_t ver=(uint32_t)in.ReadInt32(); + if(!receivedInit) + peerVersion=ver; + LOGI("Peer version is %d", peerVersion); + uint32_t minVer=(uint32_t) in.ReadInt32(); + if(minVer>PROTOCOL_VERSION || peerVersion(in.ReadInt32()); + peerVideoDecoders.push_back(id); + char* _id=reinterpret_cast(&id); + LOGD("%c%c%c%c", _id[3], _id[2], _id[1], _id[0]); + } + protocolInfo.maxVideoResolution=in.ReadByte(); + + SetupOutgoingVideoStream(); + } + + BufferOutputStream out(1024); + + out.WriteInt32(PROTOCOL_VERSION); + out.WriteInt32(MIN_PROTOCOL_VERSION); + + out.WriteByte((unsigned char) outgoingStreams.size()); + for(vector>::iterator s=outgoingStreams.begin(); s!=outgoingStreams.end(); ++s){ + out.WriteByte((*s)->id); + out.WriteByte((*s)->type); + if(peerVersion<5) + out.WriteByte((unsigned char) ((*s)->codec==CODEC_OPUS ? CODEC_OPUS_OLD : 0)); + else + out.WriteInt32((*s)->codec); + out.WriteInt16((*s)->frameDuration); + out.WriteByte((unsigned char) ((*s)->enabled ? 1 : 0)); + } + LOGI("Sending init ack"); + size_t outLength = out.GetLength(); + SendOrEnqueuePacket(PendingOutgoingPacket{ + /*.seq=*/GenerateOutSeq(), + /*.type=*/PKT_INIT_ACK, + /*.len=*/outLength, + /*.data=*/Buffer(move(out)), + /*.endpoint=*/0 + }); + if(!receivedInit){ + receivedInit=true; + if((srcEndpoint.type==Endpoint::Type::UDP_RELAY && udpConnectivityState!=UDP_BAD && udpConnectivityState!=UDP_NOT_AVAILABLE) || srcEndpoint.type==Endpoint::Type::TCP_RELAY){ + currentEndpoint=srcEndpoint.id; + if(srcEndpoint.type==Endpoint::Type::UDP_RELAY || (useTCP && srcEndpoint.type==Endpoint::Type::TCP_RELAY)) + preferredRelay=srcEndpoint.id; + } + } + if(!audioStarted && receivedInitAck){ + StartAudio(); + audioStarted=true; + } + } + if(type==PKT_INIT_ACK){ + LOGD("Received init ack"); + + if(!receivedInitAck){ + receivedInitAck=true; + + messageThread.Cancel(initTimeoutID); + initTimeoutID=MessageThread::INVALID_ID; + + if(packetInnerLen>10){ + peerVersion=in.ReadInt32(); + uint32_t minVer=(uint32_t) in.ReadInt32(); + if(minVer>PROTOCOL_VERSION || peerVersion incomingAudioStream=NULL; + for(i=0; i stm=make_shared(); + stm->id=in.ReadByte(); + stm->type=in.ReadByte(); + if(peerVersion<5){ + unsigned char codec=in.ReadByte(); + if(codec==CODEC_OPUS_OLD) + stm->codec=CODEC_OPUS; + }else{ + stm->codec=(uint32_t) in.ReadInt32(); + } + in.ReadInt16(); + stm->frameDuration=60; + stm->enabled=in.ReadByte()==1; + if(stm->type==STREAM_TYPE_VIDEO && peerVersion<9){ + LOGV("Skipping video stream for old protocol version"); + continue; + } + if(stm->type==STREAM_TYPE_AUDIO){ + stm->jitterBuffer=make_shared(nullptr, stm->frameDuration); + if(stm->frameDuration>50) + stm->jitterBuffer->SetMinPacketCount((uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_initial_delay_60", 2)); + else if(stm->frameDuration>30) + stm->jitterBuffer->SetMinPacketCount((uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_initial_delay_40", 4)); + else + stm->jitterBuffer->SetMinPacketCount((uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_initial_delay_20", 6)); + stm->decoder=NULL; + }else if(stm->type==STREAM_TYPE_VIDEO){ + if(!stm->packetReassembler){ + stm->packetReassembler=make_shared(); + stm->packetReassembler->SetCallback(bind(&VoIPController::ProcessIncomingVideoFrame, this, placeholders::_1, placeholders::_2, placeholders::_3, placeholders::_4)); + } + }else{ + LOGW("Unknown incoming stream type: %d", stm->type); + continue; + } + incomingStreams.push_back(stm); + if(stm->type==STREAM_TYPE_AUDIO && !incomingAudioStream) + incomingAudioStream=stm; + } + if(!incomingAudioStream) + return; + + if(peerVersion>=5 && !useMTProto2){ + useMTProto2=true; + LOGD("MTProto2 wasn't initially enabled for whatever reason but peer supports it; upgrading"); + } + + if(!audioStarted && receivedInit){ + StartAudio(); + audioStarted=true; + } + messageThread.Post([this]{ + if(state==STATE_WAIT_INIT_ACK){ + SetState(STATE_ESTABLISHED); + } + }, ServerConfig::GetSharedInstance()->GetDouble("established_delay_if_no_stream_data", 1.5)); + if(allowP2p) + SendPublicEndpointsRequest(); + } + } + if(type==PKT_STREAM_DATA || type==PKT_STREAM_DATA_X2 || type==PKT_STREAM_DATA_X3){ + if(!receivedFirstStreamPacket){ + receivedFirstStreamPacket=true; + if(state!=STATE_ESTABLISHED && receivedInitAck){ + messageThread.Post([this](){ + SetState(STATE_ESTABLISHED); + }, .5); + LOGW("First audio packet - setting state to ESTABLISHED"); + } + } + int count; + switch(type){ + case PKT_STREAM_DATA_X2: + count=2; + break; + case PKT_STREAM_DATA_X3: + count=3; + break; + case PKT_STREAM_DATA: + default: + count=1; + break; + } + int i; + if(srcEndpoint.type==Endpoint::Type::UDP_RELAY && srcEndpoint.id!=peerPreferredRelay){ + peerPreferredRelay=srcEndpoint.id; + } + for(i=0;iStart(); + audioOutStarted=true; + } + bool fragmented=static_cast(sdlen & STREAM_DATA_XFLAG_FRAGMENTED); + bool extraFEC=static_cast(sdlen & STREAM_DATA_XFLAG_EXTRA_FEC); + bool keyframe=static_cast(sdlen & STREAM_DATA_XFLAG_KEYFRAME); + if(fragmented){ + fragmentIndex=in.ReadByte(); + fragmentCount=in.ReadByte(); + } + sdlen&=0x7FF; + if(in.GetOffset()+sdlen>len){ + return; + } + shared_ptr stm; + for(shared_ptr& ss:incomingStreams){ + if(ss->id==streamID){ + stm=ss; + break; + } + } + if(stm && stm->type==STREAM_TYPE_AUDIO){ + if(stm->jitterBuffer){ + stm->jitterBuffer->HandleInput((unsigned char *) (buffer+in.GetOffset()), sdlen, pts, false); + if(extraFEC){ + in.Seek(in.GetOffset()+sdlen); + unsigned int fecCount=in.ReadByte(); + for(unsigned int j=0;jjitterBuffer->HandleInput(data, dlen, pts-(fecCount-j)*stm->frameDuration, true); + } + } + } + }else if(stm && stm->type==STREAM_TYPE_VIDEO){ + if(stm->packetReassembler){ + uint8_t frameSeq=in.ReadByte(); + Buffer pdata(sdlen); + uint16_t rotation=0; + if(fragmentIndex==0){ + unsigned char _rotation=in.ReadByte() & (unsigned char)VIDEO_ROTATION_MASK; + switch(_rotation){ + case VIDEO_ROTATION_0: + rotation=0; + break; + case VIDEO_ROTATION_90: + rotation=90; + break; + case VIDEO_ROTATION_180: + rotation=180; + break; + case VIDEO_ROTATION_270: + rotation=270; + break; + default: // unreachable on sane CPUs + abort(); + } + //if(rotation!=stm->rotation){ + // stm->rotation=rotation; + // LOGI("Video rotation: %u", rotation); + //} + } + pdata.CopyFrom(buffer+in.GetOffset(), 0, sdlen); + stm->packetReassembler->AddFragment(std::move(pdata), fragmentIndex, fragmentCount, pts, frameSeq, keyframe, rotation); + } + //LOGV("Received video fragment %u of %u", fragmentIndex, fragmentCount); + }else{ + LOGW("received packet for unknown stream %u", (unsigned int)streamID); + } + if(i=4){ + uint32_t pingSeq=(uint32_t) in.ReadInt32(); +#ifdef LOG_PACKETS + LOGD("Received pong for ping in seq %u", pingSeq); +#endif + if(pingSeq==srcEndpoint.lastPingSeq){ + srcEndpoint.rtts.Add(GetCurrentTime()-srcEndpoint.lastPingTime); + srcEndpoint.averageRTT=srcEndpoint.rtts.NonZeroAverage(); + LOGD("Current RTT via %s: %.3f, average: %.3f", packet.address.ToString().c_str(), srcEndpoint.rtts[0], srcEndpoint.averageRTT); + if(srcEndpoint.averageRTT>rateMaxAcceptableRTT) + needRate=true; + } + } + } + if(type==PKT_STREAM_STATE){ + unsigned char id=in.ReadByte(); + unsigned char enabled=in.ReadByte(); + LOGV("Peer stream state: id %u flags %u", (int)id, (int)enabled); + for(vector>::iterator s=incomingStreams.begin();s!=incomingStreams.end();++s){ + if((*s)->id==id){ + (*s)->enabled=enabled==1; + UpdateAudioOutputState(); + break; + } + } + } + if(type==PKT_LAN_ENDPOINT){ + LOGV("received lan endpoint"); + uint32_t peerAddr=(uint32_t) in.ReadInt32(); + uint16_t peerPort=(uint16_t) in.ReadInt32(); + constexpr int64_t lanID=(int64_t)(FOURCC('L','A','N','4')) << 32; + unsigned char peerTag[16]; + Endpoint lan(lanID, peerPort, NetworkAddress::IPv4(peerAddr), NetworkAddress::Empty(), Endpoint::Type::UDP_P2P_LAN, peerTag); + + if(currentEndpoint==lanID) + currentEndpoint=preferredRelay; + + MutexGuard m(endpointsMutex); + endpoints[lanID]=lan; + } + if(type==PKT_NETWORK_CHANGED && _currentEndpoint->type!=Endpoint::Type::UDP_RELAY && _currentEndpoint->type!=Endpoint::Type::TCP_RELAY){ + currentEndpoint=preferredRelay; + if(allowP2p) + SendPublicEndpointsRequest(); + if(peerVersion>=2){ + uint32_t flags=(uint32_t) in.ReadInt32(); + dataSavingRequestedByPeer=(flags & INIT_FLAG_DATA_SAVING_ENABLED)==INIT_FLAG_DATA_SAVING_ENABLED; + UpdateDataSavingState(); + UpdateAudioBitrateLimit(); + ResetEndpointPingStats(); + } + } + if(type==PKT_STREAM_EC){ + unsigned char streamID=in.ReadByte(); + if(peerVersion<7){ + uint32_t lastTimestamp=(uint32_t) in.ReadInt32(); + unsigned char count=in.ReadByte(); + for(shared_ptr &stm:incomingStreams){ + if(stm->id==streamID){ + for(unsigned int i=0; ijitterBuffer){ + stm->jitterBuffer->HandleInput(data, dlen, lastTimestamp-(count-i-1)*stm->frameDuration, true); + } + } + break; + } + } + }else{ + shared_ptr stm=GetStreamByID(streamID, false); + if(!stm){ + LOGW("Received FEC packet for unknown stream %u", streamID); + return; + } + if(stm->type!=STREAM_TYPE_VIDEO){ + LOGW("Received FEC packet for non-video stream %u", streamID); + return; + } + if(!stm->packetReassembler) + return; + + uint8_t fseq=in.ReadByte(); + unsigned char fecScheme=in.ReadByte(); + unsigned char prevFrameCount=in.ReadByte(); + uint16_t fecLen=(uint16_t)in.ReadInt16(); + if(fecLen>in.Remaining()) + return; + + Buffer fecData(fecLen); + in.ReadBytes(fecData); + + stm->packetReassembler->AddFEC(std::move(fecData), fseq, prevFrameCount, fecScheme); + } + } +} + +void VoIPController::ProcessExtraData(Buffer &data){ + BufferInputStream in(*data, data.Length()); + unsigned char type=in.ReadByte(); + unsigned char fullHash[SHA1_LENGTH]; + crypto.sha1(*data, data.Length(), fullHash); + uint64_t hash=*reinterpret_cast(fullHash); + if(lastReceivedExtrasByType[type]==hash){ + return; + } + LOGE("ProcessExtraData"); + lastReceivedExtrasByType[type]=hash; + if(type==EXTRA_TYPE_STREAM_FLAGS){ + unsigned char id=in.ReadByte(); + uint32_t flags=static_cast(in.ReadInt32()); + LOGV("Peer stream state: id %u flags %u", (unsigned int)id, (unsigned int)flags); + for(shared_ptr& s:incomingStreams){ + if(s->id==id){ + bool prevEnabled=s->enabled; + bool prevPaused=s->paused; + s->enabled=(flags & STREAM_FLAG_ENABLED)==STREAM_FLAG_ENABLED; + s->paused=(flags & STREAM_FLAG_PAUSED)==STREAM_FLAG_PAUSED; + if(flags & STREAM_FLAG_EXTRA_EC){ + if(!s->extraECEnabled){ + s->extraECEnabled=true; + if(s->jitterBuffer) + s->jitterBuffer->SetMinPacketCount(4); + } + }else{ + if(s->extraECEnabled){ + s->extraECEnabled=false; + if(s->jitterBuffer) + s->jitterBuffer->SetMinPacketCount(2); + } + } + if(prevEnabled!=s->enabled && s->type==STREAM_TYPE_VIDEO && videoRenderer) + videoRenderer->SetStreamEnabled(s->enabled); + if(prevPaused!=s->paused && s->type==STREAM_TYPE_VIDEO && videoRenderer) + videoRenderer->SetStreamPaused(s->paused); + UpdateAudioOutputState(); + break; + } + } + }else if(type==EXTRA_TYPE_STREAM_CSD){ + LOGI("Received codec specific data"); + /* + os.WriteByte(stream.id); + os.WriteByte(static_cast(stream.codecSpecificData.size())); + for(Buffer& b:stream.codecSpecificData){ + assert(b.Length()<255); + os.WriteByte(static_cast(b.Length())); + os.WriteBytes(b); + } + Buffer buf(move(os)); + SendExtra(buf, EXTRA_TYPE_STREAM_CSD); + */ + unsigned char streamID=in.ReadByte(); + for(shared_ptr& stm:incomingStreams){ + if(stm->id==streamID){ + stm->codecSpecificData.clear(); + stm->csdIsValid=false; + stm->width=static_cast(in.ReadInt16()); + stm->height=static_cast(in.ReadInt16()); + size_t count=(size_t)in.ReadByte(); + for(size_t i=0;icodecSpecificData.push_back(move(csd)); + } + break; + } + } + }else if(type==EXTRA_TYPE_LAN_ENDPOINT){ + if(!allowP2p) + return; + LOGV("received lan endpoint (extra)"); + uint32_t peerAddr=(uint32_t) in.ReadInt32(); + uint16_t peerPort=(uint16_t) in.ReadInt32(); + constexpr int64_t lanID=(int64_t)(FOURCC('L','A','N','4')) << 32; + if(currentEndpoint==lanID) + currentEndpoint=preferredRelay; + + unsigned char peerTag[16]; + Endpoint lan(lanID, peerPort, NetworkAddress::IPv4(peerAddr), NetworkAddress::Empty(), Endpoint::Type::UDP_P2P_LAN, peerTag); + MutexGuard m(endpointsMutex); + endpoints[lanID]=lan; + }else if(type==EXTRA_TYPE_NETWORK_CHANGED){ + LOGI("Peer network changed"); + wasNetworkHandover=true; + const Endpoint& _currentEndpoint=endpoints.at(currentEndpoint); + if(_currentEndpoint.type!=Endpoint::Type::UDP_RELAY && _currentEndpoint.type!=Endpoint::Type::TCP_RELAY) + currentEndpoint=preferredRelay; + if(allowP2p) + SendPublicEndpointsRequest(); + uint32_t flags=(uint32_t) in.ReadInt32(); + dataSavingRequestedByPeer=(flags & INIT_FLAG_DATA_SAVING_ENABLED)==INIT_FLAG_DATA_SAVING_ENABLED; + UpdateDataSavingState(); + UpdateAudioBitrateLimit(); + ResetEndpointPingStats(); + }else if(type==EXTRA_TYPE_GROUP_CALL_KEY){ + if(!didReceiveGroupCallKey && !didSendGroupCallKey){ + unsigned char groupKey[256]; + in.ReadBytes(groupKey, 256); + messageThread.Post([this, &groupKey]{ + if(callbacks.groupCallKeyReceived) + callbacks.groupCallKeyReceived(this, groupKey); + }); + didReceiveGroupCallKey=true; + } + }else if(type==EXTRA_TYPE_REQUEST_GROUP){ + if(!didInvokeUpgradeCallback){ + messageThread.Post([this]{ + if(callbacks.upgradeToGroupCallRequested) + callbacks.upgradeToGroupCallRequested(this); + }); + didInvokeUpgradeCallback=true; + } + }else if(type==EXTRA_TYPE_IPV6_ENDPOINT){ + if(!allowP2p) + return; + unsigned char _addr[16]; + in.ReadBytes(_addr, 16); + NetworkAddress addr=NetworkAddress::IPv6(_addr); + uint16_t port=static_cast(in.ReadInt16()); + peerIPv6Available=true; + LOGV("Received peer IPv6 endpoint [%s]:%u", addr.ToString().c_str(), port); + + constexpr int64_t p2pID=(int64_t)(FOURCC('P','2','P','6')) << 32; + + Endpoint ep; + ep.type=Endpoint::Type::UDP_P2P_INET; + ep.port=port; + ep.v6address=addr; + ep.id=p2pID; + endpoints[p2pID]=ep; + if(!myIPv6.IsEmpty()) + currentEndpoint=p2pID; + } +} + +void VoIPController::ProcessAcknowledgedOutgoingExtra(UnacknowledgedExtraData &extra){ + if(extra.type==EXTRA_TYPE_GROUP_CALL_KEY){ + if(!didReceiveGroupCallKeyAck){ + didReceiveGroupCallKeyAck=true; + messageThread.Post([this]{ + if(callbacks.groupCallKeySent) + callbacks.groupCallKeySent(this); + }); + } + } +} + +Endpoint& VoIPController::GetRemoteEndpoint(){ + return endpoints.at(currentEndpoint); +} + +Endpoint* VoIPController::GetEndpointForPacket(const PendingOutgoingPacket& pkt){ + Endpoint* endpoint=NULL; + if(pkt.endpoint){ + try{ + endpoint=&endpoints.at(pkt.endpoint); + }catch(out_of_range& x){ + LOGW("Unable to send packet via nonexistent endpoint %" PRIu64, pkt.endpoint); + return NULL; + } + } + if(!endpoint) + endpoint=&endpoints.at(currentEndpoint); + return endpoint; +} + +bool VoIPController::SendOrEnqueuePacket(PendingOutgoingPacket pkt, bool enqueue, PacketSender* source){ + ENFORCE_MSG_THREAD; + + Endpoint* endpoint=GetEndpointForPacket(pkt); + if(!endpoint){ + abort(); + return false; + } + + bool canSend; + if(endpoint->type!=Endpoint::Type::TCP_RELAY){ + canSend=realUdpSocket->IsReadyToSend(); + }else{ + if(!endpoint->socket){ + LOGV("Connecting to %s:%u", endpoint->GetAddress().ToString().c_str(), endpoint->port); + if(proxyProtocol==PROXY_NONE){ + endpoint->socket=make_shared(NetworkSocket::Create(NetworkProtocol::TCP)); + endpoint->socket->Connect(endpoint->GetAddress(), endpoint->port); + }else if(proxyProtocol==PROXY_SOCKS5){ + NetworkSocket* tcp=NetworkSocket::Create(NetworkProtocol::TCP); + tcp->Connect(resolvedProxyAddress, proxyPort); + shared_ptr proxy=make_shared(tcp, nullptr, proxyUsername, proxyPassword); + endpoint->socket=proxy; + endpoint->socket->Connect(endpoint->GetAddress(), endpoint->port); + } + selectCanceller->CancelSelect(); + } + canSend=endpoint->socket && endpoint->socket->IsReadyToSend(); + } + if(!canSend){ + if(enqueue){ + LOGW("Not ready to send - enqueueing"); + sendQueue.push_back(move(pkt)); + } + return false; + } + if((endpoint->type==Endpoint::Type::TCP_RELAY && useTCP) || (endpoint->type!=Endpoint::Type::TCP_RELAY && useUDP)){ + //BufferOutputStream p(buf, sizeof(buf)); + BufferOutputStream p(1500); + WritePacketHeader(pkt.seq, &p, pkt.type, (uint32_t)pkt.len, source); + p.WriteBytes(pkt.data); + SendPacket(p.GetBuffer(), p.GetLength(), *endpoint, pkt); + if(pkt.type==PKT_STREAM_DATA){ + unsentStreamPackets--; + } + } + return true; +} + +void VoIPController::SendPacket(unsigned char *data, size_t len, Endpoint& ep, PendingOutgoingPacket& srcPacket){ + if(stopping) + return; + if(ep.type==Endpoint::Type::TCP_RELAY && !useTCP) + return; + BufferOutputStream out(len+128); + if(ep.type==Endpoint::Type::UDP_RELAY || ep.type==Endpoint::Type::TCP_RELAY) + out.WriteBytes((unsigned char*)ep.peerTag, 16); + else if(peerVersion<9) + out.WriteBytes(callID, 16); + if(len>0){ + if(useMTProto2){ + BufferOutputStream inner(len+128); + size_t sizeSize; + if(peerVersion>=8 || (!peerVersion && connectionMaxLayer>=92)){ + inner.WriteInt16((uint16_t) len); + sizeSize=0; + }else{ + inner.WriteInt32((uint32_t) len); + out.WriteBytes(keyFingerprint, 8); + sizeSize=4; + } + inner.WriteBytes(data, len); + + size_t padLen=16-inner.GetLength()%16; + if(padLen<16) + padLen+=16; + unsigned char padding[32]; + crypto.rand_bytes((uint8_t *) padding, padLen); + inner.WriteBytes(padding, padLen); + assert(inner.GetLength()%16==0); + + unsigned char key[32], iv[32], msgKey[16]; + BufferOutputStream buf(len+32); + size_t x=isOutgoing ? 0 : 8; + buf.WriteBytes(encryptionKey+88+x, 32); + buf.WriteBytes(inner.GetBuffer()+sizeSize, inner.GetLength()-sizeSize); + unsigned char msgKeyLarge[32]; + crypto.sha256(buf.GetBuffer(), buf.GetLength(), msgKeyLarge); + memcpy(msgKey, msgKeyLarge+8, 16); + KDF2(msgKey, isOutgoing ? 0 : 8, key, iv); + out.WriteBytes(msgKey, 16); + //LOGV("<- MSG KEY: %08x %08x %08x %08x, hashed %u", *reinterpret_cast(msgKey), *reinterpret_cast(msgKey+4), *reinterpret_cast(msgKey+8), *reinterpret_cast(msgKey+12), inner.GetLength()-4); + + unsigned char aesOut[MSC_STACK_FALLBACK(inner.GetLength(), 1500)]; + crypto.aes_ige_encrypt(inner.GetBuffer(), aesOut, inner.GetLength(), key, iv); + out.WriteBytes(aesOut, inner.GetLength()); + }else{ + BufferOutputStream inner(len+128); + inner.WriteInt32((int32_t)len); + inner.WriteBytes(data, len); + if(inner.GetLength()%16!=0){ + size_t padLen=16-inner.GetLength()%16; + unsigned char padding[16]; + crypto.rand_bytes((uint8_t *) padding, padLen); + inner.WriteBytes(padding, padLen); + } + assert(inner.GetLength()%16==0); + unsigned char key[32], iv[32], msgHash[SHA1_LENGTH]; + crypto.sha1((uint8_t *) inner.GetBuffer(), len+4, msgHash); + out.WriteBytes(keyFingerprint, 8); + out.WriteBytes((msgHash+(SHA1_LENGTH-16)), 16); + KDF(msgHash+(SHA1_LENGTH-16), isOutgoing ? 0 : 8, key, iv); + unsigned char aesOut[MSC_STACK_FALLBACK(inner.GetLength(), 1500)]; + crypto.aes_ige_encrypt(inner.GetBuffer(), aesOut, inner.GetLength(), key, iv); + out.WriteBytes(aesOut, inner.GetLength()); + } + } + //LOGV("Sending %d bytes to %s:%d", out.GetLength(), ep.address.ToString().c_str(), ep.port); +#ifdef LOG_PACKETS + LOGV("Sending: to=%s:%u, seq=%u, length=%u, type=%s", ep.GetAddress().ToString().c_str(), ep.port, srcPacket.seq, (unsigned int)out.GetLength(), GetPacketTypeString(srcPacket.type).c_str()); +#endif + + + /*ActuallySendPacket(NetworkPacket{ + Buffer(std::move(out)), + ep.GetAddress(), + ep.port, + ep.type==Endpoint::Type::TCP_RELAY ? NetworkProtocol::TCP : NetworkProtocol::UDP + }, ep);*/ + rawSendQueue.Put(RawPendingOutgoingPacket{ + NetworkPacket{ + Buffer(std::move(out)), + ep.GetAddress(), + ep.port, + ep.type==Endpoint::Type::TCP_RELAY ? NetworkProtocol::TCP : NetworkProtocol::UDP + }, + ep.type==Endpoint::Type::TCP_RELAY ? ep.socket : nullptr + }); +} + +void VoIPController::ActuallySendPacket(NetworkPacket pkt, Endpoint& ep){ + //LOGI("Sending packet of %d bytes", pkt.length); + if(IS_MOBILE_NETWORK(networkType)) + stats.bytesSentMobile+=(uint64_t)pkt.data.Length(); + else + stats.bytesSentWifi+=(uint64_t)pkt.data.Length(); + if(ep.type==Endpoint::Type::TCP_RELAY){ + if(ep.socket && !ep.socket->IsFailed()){ + ep.socket->Send(std::move(pkt)); + } + }else{ + udpSocket->Send(std::move(pkt)); + } +} + + +std::string VoIPController::NetworkTypeToString(int type){ + switch(type){ + case NET_TYPE_WIFI: + return "wifi"; + case NET_TYPE_GPRS: + return "gprs"; + case NET_TYPE_EDGE: + return "edge"; + case NET_TYPE_3G: + return "3g"; + case NET_TYPE_HSPA: + return "hspa"; + case NET_TYPE_LTE: + return "lte"; + case NET_TYPE_ETHERNET: + return "ethernet"; + case NET_TYPE_OTHER_HIGH_SPEED: + return "other_high_speed"; + case NET_TYPE_OTHER_LOW_SPEED: + return "other_low_speed"; + case NET_TYPE_DIALUP: + return "dialup"; + case NET_TYPE_OTHER_MOBILE: + return "other_mobile"; + default: + return "unknown"; + } +} + +std::string VoIPController::GetPacketTypeString(unsigned char type){ + switch(type){ + case PKT_INIT: + return "init"; + case PKT_INIT_ACK: + return "init_ack"; + case PKT_STREAM_STATE: + return "stream_state"; + case PKT_STREAM_DATA: + return "stream_data"; + case PKT_PING: + return "ping"; + case PKT_PONG: + return "pong"; + case PKT_LAN_ENDPOINT: + return "lan_endpoint"; + case PKT_NETWORK_CHANGED: + return "network_changed"; + case PKT_NOP: + return "nop"; + case PKT_STREAM_EC: + return "stream_ec"; + } + char buf[255]; + snprintf(buf, sizeof(buf), "unknown(%u)", type); + return string(buf); +} + +void VoIPController::AddIPv6Relays(){ + + if(!myIPv6.IsEmpty() && !didAddIPv6Relays){ + unordered_map> endpointsByAddress; + for(pair& _e:endpoints){ + Endpoint& e=_e.second; + if((e.type==Endpoint::Type::UDP_RELAY || e.type==Endpoint::Type::TCP_RELAY) && !e.v6address.IsEmpty() && !e.address.IsEmpty()){ + endpointsByAddress[e.v6address.ToString()].push_back(e); + } + } + MutexGuard m(endpointsMutex); + for(pair>& addr:endpointsByAddress){ + for(Endpoint& e:addr.second){ + didAddIPv6Relays=true; + e.address=NetworkAddress::Empty(); + e.id=e.id ^ ((int64_t)(FOURCC('I','P','v','6')) << 32); + e.averageRTT=0; + e.lastPingSeq=0; + e.lastPingTime=0; + e.rtts.Reset(); + e.udpPongCount=0; + endpoints[e.id]=e; + LOGD("Adding IPv6-only endpoint [%s]:%u", e.v6address.ToString().c_str(), e.port); + } + } + } +} + +void VoIPController::AddTCPRelays(){ + + if(!didAddTcpRelays){ + bool wasSetCurrentToTCP=setCurrentEndpointToTCP; + LOGV("Adding TCP relays"); + vector relays; + for(pair &_e:endpoints){ + Endpoint& e=_e.second; + if(e.type!=Endpoint::Type::UDP_RELAY) + continue; + if(wasSetCurrentToTCP && !useUDP){ + e.rtts.Reset(); + e.averageRTT=0; + e.lastPingSeq=0; + } + Endpoint tcpRelay(e); + tcpRelay.type=Endpoint::Type::TCP_RELAY; + tcpRelay.averageRTT=0; + tcpRelay.lastPingSeq=0; + tcpRelay.lastPingTime=0; + tcpRelay.rtts.Reset(); + tcpRelay.udpPongCount=0; + tcpRelay.id=tcpRelay.id ^ ((int64_t) (FOURCC('T', 'C', 'P', 0)) << 32); + if(setCurrentEndpointToTCP && endpoints.at(currentEndpoint).type!=Endpoint::Type::TCP_RELAY){ + LOGV("Setting current endpoint to TCP"); + setCurrentEndpointToTCP=false; + currentEndpoint=tcpRelay.id; + preferredRelay=tcpRelay.id; + } + relays.push_back(tcpRelay); + } + MutexGuard m(endpointsMutex); + for(Endpoint& e:relays){ + endpoints[e.id]=e; + } + didAddTcpRelays=true; + } +} + +#if defined(__APPLE__) +static void initMachTimestart() { + mach_timebase_info_data_t tb = { 0, 0 }; + mach_timebase_info(&tb); + VoIPController::machTimebase = tb.numer; + VoIPController::machTimebase /= tb.denom; + VoIPController::machTimestart = mach_absolute_time(); +} +#endif + +double VoIPController::GetCurrentTime(){ +#if defined(__linux__) + struct timespec ts; + clock_gettime(CLOCK_MONOTONIC, &ts); + return ts.tv_sec+(double)ts.tv_nsec/1000000000.0; +#elif defined(__APPLE__) + static pthread_once_t token = PTHREAD_ONCE_INIT; + pthread_once(&token, &initMachTimestart); + return (mach_absolute_time() - machTimestart) * machTimebase / 1000000000.0f; +#elif defined(_WIN32) + if(!didInitWin32TimeScale){ + LARGE_INTEGER scale; + QueryPerformanceFrequency(&scale); + win32TimeScale=scale.QuadPart; + didInitWin32TimeScale=true; + } + LARGE_INTEGER t; + QueryPerformanceCounter(&t); + return (double)t.QuadPart/(double)win32TimeScale; +#endif +} + + + +void VoIPController::KDF(unsigned char* msgKey, size_t x, unsigned char* aesKey, unsigned char* aesIv){ + uint8_t sA[SHA1_LENGTH], sB[SHA1_LENGTH], sC[SHA1_LENGTH], sD[SHA1_LENGTH]; + BufferOutputStream buf(128); + buf.WriteBytes(msgKey, 16); + buf.WriteBytes(encryptionKey+x, 32); + crypto.sha1(buf.GetBuffer(), buf.GetLength(), sA); + buf.Reset(); + buf.WriteBytes(encryptionKey+32+x, 16); + buf.WriteBytes(msgKey, 16); + buf.WriteBytes(encryptionKey+48+x, 16); + crypto.sha1(buf.GetBuffer(), buf.GetLength(), sB); + buf.Reset(); + buf.WriteBytes(encryptionKey+64+x, 32); + buf.WriteBytes(msgKey, 16); + crypto.sha1(buf.GetBuffer(), buf.GetLength(), sC); + buf.Reset(); + buf.WriteBytes(msgKey, 16); + buf.WriteBytes(encryptionKey+96+x, 32); + crypto.sha1(buf.GetBuffer(), buf.GetLength(), sD); + buf.Reset(); + buf.WriteBytes(sA, 8); + buf.WriteBytes(sB+8, 12); + buf.WriteBytes(sC+4, 12); + assert(buf.GetLength()==32); + memcpy(aesKey, buf.GetBuffer(), 32); + buf.Reset(); + buf.WriteBytes(sA+8, 12); + buf.WriteBytes(sB, 8); + buf.WriteBytes(sC+16, 4); + buf.WriteBytes(sD, 8); + assert(buf.GetLength()==32); + memcpy(aesIv, buf.GetBuffer(), 32); +} + +void VoIPController::KDF2(unsigned char* msgKey, size_t x, unsigned char *aesKey, unsigned char *aesIv){ + uint8_t sA[32], sB[32]; + BufferOutputStream buf(128); + buf.WriteBytes(msgKey, 16); + buf.WriteBytes(encryptionKey+x, 36); + crypto.sha256(buf.GetBuffer(), buf.GetLength(), sA); + buf.Reset(); + buf.WriteBytes(encryptionKey+40+x, 36); + buf.WriteBytes(msgKey, 16); + crypto.sha256(buf.GetBuffer(), buf.GetLength(), sB); + buf.Reset(); + buf.WriteBytes(sA, 8); + buf.WriteBytes(sB+8, 16); + buf.WriteBytes(sA+24, 8); + memcpy(aesKey, buf.GetBuffer(), 32); + buf.Reset(); + buf.WriteBytes(sB, 8); + buf.WriteBytes(sA+8, 16); + buf.WriteBytes(sB+24, 8); + memcpy(aesIv, buf.GetBuffer(), 32); +} + + +void VoIPController::SendPublicEndpointsRequest(const Endpoint& relay){ + if(!useUDP) + return; + LOGD("Sending public endpoints request to %s:%d", relay.address.ToString().c_str(), relay.port); + publicEndpointsReqTime=GetCurrentTime(); + waitingForRelayPeerInfo=true; + Buffer buf(32); + memcpy(*buf, relay.peerTag, 16); + memset(*buf+16, 0xFF, 16); + udpSocket->Send(NetworkPacket{ + std::move(buf), + relay.address, + relay.port, + NetworkProtocol::UDP + }); +} + +Endpoint& VoIPController::GetEndpointByType(int type){ + if(type==Endpoint::Type::UDP_RELAY && preferredRelay) + return endpoints.at(preferredRelay); + for(pair& e:endpoints){ + if(e.second.type==type) + return e.second; + } + throw out_of_range("no endpoint"); +} + + +void VoIPController::SendPacketReliably(unsigned char type, unsigned char *data, size_t len, double retryInterval, double timeout){ + ENFORCE_MSG_THREAD; + + LOGD("Send reliably, type=%u, len=%u, retry=%.3f, timeout=%.3f", type, unsigned(len), retryInterval, timeout); + QueuedPacket pkt; + if(data){ + Buffer b(len); + b.CopyFrom(data, 0, len); + pkt.data=move(b); + } + pkt.type=type; + pkt.retryInterval=retryInterval; + pkt.timeout=timeout; + pkt.firstSentTime=0; + pkt.lastSentTime=0; + queuedPackets.push_back(move(pkt)); + messageThread.Post(std::bind(&VoIPController::UpdateQueuedPackets, this)); + if(timeout>0.0){ + messageThread.Post(std::bind(&VoIPController::UpdateQueuedPackets, this), timeout); + } +} + +void VoIPController::SendExtra(Buffer &data, unsigned char type){ + ENFORCE_MSG_THREAD; + + LOGV("Sending extra type %u length %u", type, (unsigned int)data.Length()); + for(vector::iterator x=currentExtras.begin();x!=currentExtras.end();++x){ + if(x->type==type){ + x->firstContainingSeq=0; + x->data=move(data); + return; + } + } + UnacknowledgedExtraData xd={type, move(data), 0}; + currentExtras.push_back(move(xd)); +} + + + + + +void VoIPController::DebugCtl(int request, int param){ + +} + +void VoIPController::SendUdpPing(Endpoint& endpoint){ + if(endpoint.type!=Endpoint::Type::UDP_RELAY) + return; + BufferOutputStream p(1024); + p.WriteBytes(endpoint.peerTag, 16); + p.WriteInt32(-1); + p.WriteInt32(-1); + p.WriteInt32(-1); + p.WriteInt32(-2); + int64_t id; + crypto.rand_bytes(reinterpret_cast(&id), 8); + p.WriteInt64(id); + endpoint.udpPingTimes[id]=GetCurrentTime(); + udpSocket->Send(NetworkPacket{ + Buffer(std::move(p)), + endpoint.GetAddress(), + endpoint.port, + NetworkProtocol::UDP + }); + endpoint.totalUdpPings++; + LOGV("Sending UDP ping to %s:%d, id %" PRId64, endpoint.GetAddress().ToString().c_str(), endpoint.port, id); +} + + +void VoIPController::ResetUdpAvailability(){ + ENFORCE_MSG_THREAD; + + LOGI("Resetting UDP availability"); + if(udpPingTimeoutID!=MessageThread::INVALID_ID){ + messageThread.Cancel(udpPingTimeoutID); + } + { + for(pair& e:endpoints){ + e.second.udpPongCount=0; + e.second.udpPingTimes.clear(); + } + } + udpPingCount=0; + udpConnectivityState=UDP_PING_PENDING; + udpPingTimeoutID=messageThread.Post(std::bind(&VoIPController::SendUdpPings, this), 0.0, 0.5); +} + +void VoIPController::ResetEndpointPingStats(){ + ENFORCE_MSG_THREAD; + + for(pair& e:endpoints){ + e.second.averageRTT=0.0; + e.second.rtts.Reset(); + } +} + + + +#pragma mark - Video + + +void VoIPController::SetVideoSource(video::VideoSource *source){ + /*shared_ptr stm=GetStreamByType(STREAM_TYPE_VIDEO, true); + if(!stm){ + LOGE("Can't set video source when there is no outgoing video stream"); + return; + } + + if(source){ + if(!stm->enabled){ + stm->enabled=true; + messageThread.Post([this, stm]{SendStreamFlags(*stm);}); + } + + if(!videoPacketSender) + videoPacketSender=new video::VideoPacketSender(this, source, stm); + else + videoPacketSender->SetSource(source); + + }else{ + if(stm->enabled){ + stm->enabled=false; + messageThread.Post([this, stm]{SendStreamFlags(*stm);}); + } + if(videoPacketSender){ + videoPacketSender->SetSource(NULL); + } + }*/ +} + +void VoIPController::SetVideoRenderer(video::VideoRenderer *renderer){ + videoRenderer=renderer; +} + +void VoIPController::SetVideoCodecSpecificData(const std::vector& data){ + outgoingStreams[1]->codecSpecificData.clear(); + for(const Buffer& csd:data){ + outgoingStreams[1]->codecSpecificData.push_back(Buffer::CopyOf(csd)); + } + LOGI("Set outgoing video stream CSD"); +} + +void VoIPController::SendVideoFrame(const Buffer &frame, uint32_t flags, uint32_t rotation){ + //LOGI("Send video frame %u flags %u", (unsigned int)frame.Length(), flags); + shared_ptr stm=GetStreamByType(STREAM_TYPE_VIDEO, true); + if(stm){ + } +} + + +void VoIPController::ProcessIncomingVideoFrame(Buffer frame, uint32_t pts, bool keyframe, uint16_t rotation){ + //LOGI("Incoming video frame size %u pts %u", (unsigned int)frame.Length(), pts); + if(frame.Length()==0){ + LOGE("EMPTY FRAME"); + } + if(videoRenderer){ + shared_ptr stm=GetStreamByType(STREAM_TYPE_VIDEO, false); + size_t offset=0; + if(keyframe){ + BufferInputStream in(frame); + uint16_t width=(uint16_t)in.ReadInt16(); + uint16_t height=(uint16_t)in.ReadInt16(); + uint8_t sizeAndFlag=in.ReadByte(); + int size=sizeAndFlag & 0x0F; + bool reset=(sizeAndFlag & 0x80)==0x80; + if(reset || !stm->csdIsValid || stm->width!=width || stm->height!=height){ + stm->width=width; + stm->height=height; + stm->codecSpecificData.clear(); + for(int i=0; icodecSpecificData.push_back(move(b)); + } + stm->csdIsValid=false; + }else{ + for(int i=0; icsdIsValid && stm->width && stm->height){ + videoRenderer->Reset(stm->codec, stm->width, stm->height, stm->codecSpecificData); + stm->csdIsValid=true; + } + if(lastReceivedVideoFrameNumber==UINT32_MAX || lastReceivedVideoFrameNumber==pts-1 || keyframe){ + lastReceivedVideoFrameNumber=pts; + //LOGV("3 before decode %u", (unsigned int)frame.Length()); + if(stm->rotation!=rotation){ + stm->rotation=rotation; + videoRenderer->SetRotation(rotation); + } + if(offset==0){ + videoRenderer->DecodeAndDisplay(move(frame), pts); + }else{ + videoRenderer->DecodeAndDisplay(Buffer::CopyOf(frame, offset, frame.Length()-offset), pts); + } + }else{ + LOGW("Skipping non-keyframe after packet loss..."); + } + } +} + +void VoIPController::SetupOutgoingVideoStream(){ + vector myEncoders=video::VideoSource::GetAvailableEncoders(); + shared_ptr vstm=make_shared(); + vstm->id=2; + vstm->type=STREAM_TYPE_VIDEO; + + if(find(myEncoders.begin(), myEncoders.end(), CODEC_HEVC)!=myEncoders.end() && find(peerVideoDecoders.begin(), peerVideoDecoders.end(), CODEC_HEVC)!=peerVideoDecoders.end()){ + vstm->codec=CODEC_HEVC; + }else if(find(myEncoders.begin(), myEncoders.end(), CODEC_AVC)!=myEncoders.end() && find(peerVideoDecoders.begin(), peerVideoDecoders.end(), CODEC_AVC)!=peerVideoDecoders.end()){ + vstm->codec=CODEC_AVC; + }else if(find(myEncoders.begin(), myEncoders.end(), CODEC_VP8)!=myEncoders.end() && find(peerVideoDecoders.begin(), peerVideoDecoders.end(), CODEC_VP8)!=peerVideoDecoders.end()){ + vstm->codec=CODEC_VP8; + }else{ + LOGW("Can't setup outgoing video stream: no codecs in common"); + return; + } + + vstm->enabled=false; + outgoingStreams.push_back(vstm); +} + +#pragma mark - Timer methods + +void VoIPController::SendUdpPings(){ + LOGW("Send udp pings"); + ENFORCE_MSG_THREAD; + + for(pair& e:endpoints){ + if(e.second.type==Endpoint::Type::UDP_RELAY){ + SendUdpPing(e.second); + } + } + if(udpConnectivityState==UDP_UNKNOWN || udpConnectivityState==UDP_PING_PENDING) + udpConnectivityState=UDP_PING_SENT; + udpPingCount++; + if(udpPingCount==4 || udpPingCount==10){ + messageThread.CancelSelf(); + udpPingTimeoutID=messageThread.Post(std::bind(&VoIPController::EvaluateUdpPingResults, this), 1.0); + } +} + +void VoIPController::EvaluateUdpPingResults(){ + double avgPongs=0; + int count=0; + for(pair& _e:endpoints){ + Endpoint& e=_e.second; + if(e.type==Endpoint::Type::UDP_RELAY){ + if(e.udpPongCount>0){ + avgPongs+=(double) e.udpPongCount; + count++; + } + } + } + if(count>0) + avgPongs/=(double)count; + else + avgPongs=0.0; + LOGI("UDP ping reply count: %.2f", avgPongs); + if(avgPongs==0.0 && proxyProtocol==PROXY_SOCKS5 && udpSocket!=realUdpSocket){ + LOGI("Proxy does not let UDP through, closing proxy connection and using UDP directly"); + NetworkSocket* proxySocket=udpSocket; + proxySocket->Close(); + udpSocket=realUdpSocket; + selectCanceller->CancelSelect(); + delete proxySocket; + proxySupportsUDP=false; + ResetUdpAvailability(); + return; + } + bool configUseTCP=ServerConfig::GetSharedInstance()->GetBoolean("use_tcp", true); + if(configUseTCP){ + if(avgPongs==0.0 || (udpConnectivityState==UDP_BAD && avgPongs<7.0)){ + if(needRateFlags & NEED_RATE_FLAG_UDP_NA) + needRate=true; + udpConnectivityState=UDP_NOT_AVAILABLE; + useTCP=true; + useUDP=avgPongs>1.0; + if(endpoints.at(currentEndpoint).type!=Endpoint::Type::TCP_RELAY) + setCurrentEndpointToTCP=true; + AddTCPRelays(); + waitingForRelayPeerInfo=false; + }else if(avgPongs<3.0){ + if(needRateFlags & NEED_RATE_FLAG_UDP_BAD) + needRate=true; + udpConnectivityState=UDP_BAD; + useTCP=true; + setCurrentEndpointToTCP=true; + AddTCPRelays(); + udpPingTimeoutID=messageThread.Post(std::bind(&VoIPController::SendUdpPings, this), 0.5, 0.5); + }else{ + udpPingTimeoutID=MessageThread::INVALID_ID; + udpConnectivityState=UDP_AVAILABLE; + } + }else{ + udpPingTimeoutID=MessageThread::INVALID_ID; + udpConnectivityState=UDP_NOT_AVAILABLE; + } +} + +void VoIPController::SendRelayPings(){ + ENFORCE_MSG_THREAD; + + if((state==STATE_ESTABLISHED || state==STATE_RECONNECTING) && endpoints.size()>1){ + Endpoint* _preferredRelay=&endpoints.at(preferredRelay); + Endpoint* _currentEndpoint=&endpoints.at(currentEndpoint); + Endpoint* minPingRelay=_preferredRelay; + double minPing=_preferredRelay->averageRTT*(_preferredRelay->type==Endpoint::Type::TCP_RELAY ? 2 : 1); + if(minPing==0.0) // force the switch to an available relay, if any + minPing=DBL_MAX; + for(pair& _endpoint:endpoints){ + Endpoint& endpoint=_endpoint.second; + if(endpoint.type==Endpoint::Type::TCP_RELAY && !useTCP) + continue; + if(endpoint.type==Endpoint::Type::UDP_RELAY && !useUDP) + continue; + if(GetCurrentTime()-endpoint.lastPingTime>=10){ + LOGV("Sending ping to %s", endpoint.GetAddress().ToString().c_str()); + SendOrEnqueuePacket(PendingOutgoingPacket{ + /*.seq=*/(endpoint.lastPingSeq=GenerateOutSeq()), + /*.type=*/PKT_PING, + /*.len=*/0, + /*.data=*/Buffer(), + /*.endpoint=*/endpoint.id + }); + endpoint.lastPingTime=GetCurrentTime(); + } + if((useUDP && endpoint.type==Endpoint::Type::UDP_RELAY) || (useTCP && endpoint.type==Endpoint::Type::TCP_RELAY)){ + double k=endpoint.type==Endpoint::Type::UDP_RELAY ? 1 : 2; + if(endpoint.averageRTT>0 && endpoint.averageRTT*kid!=preferredRelay){ + preferredRelay=minPingRelay->id; + _preferredRelay=minPingRelay; + LOGV("set preferred relay to %s", _preferredRelay->address.ToString().c_str()); + if(_currentEndpoint->type==Endpoint::Type::UDP_RELAY || _currentEndpoint->type==Endpoint::Type::TCP_RELAY){ + currentEndpoint=preferredRelay; + _currentEndpoint=_preferredRelay; + } + } + if(_currentEndpoint->type==Endpoint::Type::UDP_RELAY && useUDP){ + constexpr int64_t p2pID=(int64_t)(FOURCC('P','2','P','4')) << 32; + constexpr int64_t lanID=(int64_t)(FOURCC('L','A','N','4')) << 32; + + if(endpoints.find(p2pID)!=endpoints.end()){ + Endpoint& p2p=endpoints[p2pID]; + if(endpoints.find(lanID)!=endpoints.end() && endpoints[lanID].averageRTT>0 && endpoints[lanID].averageRTT0 && p2p.averageRTT0 && minPing<_currentEndpoint->averageRTT*p2pToRelaySwitchThreshold){ + LOGI("Switching to relay"); + currentEndpoint=preferredRelay; + } + } + } +} + +void VoIPController::UpdateRTT(){ + rttHistory.Add(GetAverageRTT()); + //double v=rttHistory.Average(); + if(rttHistory[0]>10.0 && rttHistory[8]>10.0 && (networkType==NET_TYPE_EDGE || networkType==NET_TYPE_GPRS)){ + waitingForAcks=true; + }else{ + waitingForAcks=false; + } + //LOGI("%.3lf/%.3lf, rtt diff %.3lf, waiting=%d, queue=%d", rttHistory[0], rttHistory[8], v, waitingForAcks, sendQueue->Size()); + for(vector>::iterator stm=incomingStreams.begin();stm!=incomingStreams.end();++stm){ + if((*stm)->jitterBuffer){ + int lostCount=(*stm)->jitterBuffer->GetAndResetLostPacketCount(); + if(lostCount>0 || (lostCount<0 && recvLossCount>((uint32_t) -lostCount))) + recvLossCount+=lostCount; + } + } +} + +void VoIPController::UpdateCongestion(){ + if(conctl && encoder){ + uint32_t sendLossCount=conctl->GetSendLossCount(); + sendLossCountHistory.Add(sendLossCount-prevSendLossCount); + prevSendLossCount=sendLossCount; + double packetsPerSec=1000/(double) outgoingStreams[0]->frameDuration; + double avgSendLossCount=sendLossCountHistory.Average()/packetsPerSec; + //LOGV("avg send loss: %.3f%%", avgSendLossCount*100); + + if(avgSendLossCount>packetLossToEnableExtraEC && networkType!=NET_TYPE_GPRS && networkType!=NET_TYPE_EDGE){ + if(!shittyInternetMode){ + // Shitty Internet Mode™. Redundant redundancy you can trust. + shittyInternetMode=true; + for(shared_ptr &s:outgoingStreams){ + if(s->type==STREAM_TYPE_AUDIO){ + s->extraECEnabled=true; + SendStreamFlags(*s); + break; + } + } + if(encoder) + encoder->SetSecondaryEncoderEnabled(true); + LOGW("Enabling extra EC"); + if(needRateFlags & NEED_RATE_FLAG_SHITTY_INTERNET_MODE) + needRate=true; + wasExtraEC=true; + } + } + + if(avgSendLossCount>0.08){ + extraEcLevel=4; + }else if(avgSendLossCount>0.05){ + extraEcLevel=3; + }else if(avgSendLossCount>0.02){ + extraEcLevel=2; + }else{ + extraEcLevel=0; + } + encoder->SetPacketLoss((int)(avgSendLossCount*100.0)); + if(avgSendLossCount>rateMaxAcceptableSendLoss) + needRate=true; + + if((avgSendLossCount &s:outgoingStreams){ + if(s->type==STREAM_TYPE_AUDIO){ + s->extraECEnabled=false; + SendStreamFlags(*s); + break; + } + } + if(encoder) + encoder->SetSecondaryEncoderEnabled(false); + LOGW("Disabling extra EC"); + } + if(!wasEncoderLaggy && encoder->GetComplexity()<10) + wasEncoderLaggy=true; + } +} + +void VoIPController::UpdateAudioBitrate(){ + if(encoder && conctl){ + double time=GetCurrentTime(); + if((audioInput && !audioInput->IsInitialized()) || (audioOutput && !audioOutput->IsInitialized())){ + LOGE("Audio I/O failed"); + lastError=ERROR_AUDIO_IO; + SetState(STATE_FAILED); + } + + int act=conctl->GetBandwidthControlAction(); + if(shittyInternetMode){ + encoder->SetBitrate(8000); + }else if(act==TGVOIP_CONCTL_ACT_DECREASE){ + uint32_t bitrate=encoder->GetBitrate(); + if(bitrate>8000) + encoder->SetBitrate(bitrate<(minAudioBitrate+audioBitrateStepDecr) ? minAudioBitrate : (bitrate-audioBitrateStepDecr)); + }else if(act==TGVOIP_CONCTL_ACT_INCREASE){ + uint32_t bitrate=encoder->GetBitrate(); + if(bitrateSetBitrate(bitrate+audioBitrateStepIncr); + } + + if(state==STATE_ESTABLISHED && time-lastRecvPacketTime>=reconnectingTimeout){ + SetState(STATE_RECONNECTING); + if(needRateFlags & NEED_RATE_FLAG_RECONNECTING) + needRate=true; + wasReconnecting=true; + ResetUdpAvailability(); + } + + if(state==STATE_ESTABLISHED || state==STATE_RECONNECTING){ + if(time-lastRecvPacketTime>=config.recvTimeout){ + const Endpoint& _currentEndpoint=endpoints.at(currentEndpoint); + if(_currentEndpoint.type!=Endpoint::Type::UDP_RELAY && _currentEndpoint.type!=Endpoint::Type::TCP_RELAY){ + LOGW("Packet receive timeout, switching to relay"); + currentEndpoint=preferredRelay; + for(pair& _e:endpoints){ + Endpoint& e=_e.second; + if(e.type==Endpoint::Type::UDP_P2P_INET || e.type==Endpoint::Type::UDP_P2P_LAN){ + e.averageRTT=0; + e.rtts.Reset(); + } + } + if(allowP2p){ + SendPublicEndpointsRequest(); + } + UpdateDataSavingState(); + UpdateAudioBitrateLimit(); + BufferOutputStream s(4); + s.WriteInt32(dataSavingMode ? INIT_FLAG_DATA_SAVING_ENABLED : 0); + if(peerVersion<6){ + SendPacketReliably(PKT_NETWORK_CHANGED, s.GetBuffer(), s.GetLength(), 1, 20); + }else{ + Buffer buf(move(s)); + SendExtra(buf, EXTRA_TYPE_NETWORK_CHANGED); + } + lastRecvPacketTime=time; + }else{ + LOGW("Packet receive timeout, disconnecting"); + lastError=ERROR_TIMEOUT; + SetState(STATE_FAILED); + } + } + } + } +} + +void VoIPController::UpdateSignalBars(){ + int prevSignalBarCount=GetSignalBarsCount(); + double packetsPerSec=1000/(double) outgoingStreams[0]->frameDuration; + double avgSendLossCount=sendLossCountHistory.Average()/packetsPerSec; + + int signalBarCount=4; + if(state==STATE_RECONNECTING || waitingForAcks) + signalBarCount=1; + if(endpoints.at(currentEndpoint).type==Endpoint::Type::TCP_RELAY){ + signalBarCount=std::min(signalBarCount, 3); + } + if(avgSendLossCount>0.1){ + signalBarCount=1; + }else if(avgSendLossCount>0.0625){ + signalBarCount=std::min(signalBarCount, 2); + }else if(avgSendLossCount>0.025){ + signalBarCount=std::min(signalBarCount, 3); + } + + for(shared_ptr& stm:incomingStreams){ + if(stm->jitterBuffer){ + double avgLateCount[3]; + stm->jitterBuffer->GetAverageLateCount(avgLateCount); + if(avgLateCount[2]>=0.2) + signalBarCount=1; + else if(avgLateCount[2]>=0.1) + signalBarCount=std::min(signalBarCount, 2); + } + } + + signalBarsHistory.Add(static_cast(signalBarCount)); + //LOGV("Signal bar count history %08X", *reinterpret_cast(&signalBarsHistory)); + int _signalBarCount=GetSignalBarsCount(); + if(_signalBarCount!=prevSignalBarCount){ + LOGD("SIGNAL BAR COUNT CHANGED: %d", _signalBarCount); + if(callbacks.signalBarCountChanged) + callbacks.signalBarCountChanged(this, _signalBarCount); + } +} + +void VoIPController::UpdateQueuedPackets(){ + vector packetsToSend; + for(std::vector::iterator qp=queuedPackets.begin(); qp!=queuedPackets.end();){ + if(qp->timeout>0 && qp->firstSentTime>0 && GetCurrentTime()-qp->firstSentTime>=qp->timeout){ + LOGD("Removing queued packet because of timeout"); + qp=queuedPackets.erase(qp); + continue; + } + if(GetCurrentTime()-qp->lastSentTime>=qp->retryInterval){ + messageThread.Post(std::bind(&VoIPController::UpdateQueuedPackets, this), qp->retryInterval); + uint32_t seq=GenerateOutSeq(); + qp->seqs.Add(seq); + qp->lastSentTime=GetCurrentTime(); + //LOGD("Sending queued packet, seq=%u, type=%u, len=%u", seq, qp.type, qp.data.Length()); + Buffer buf(qp->data.Length()); + if(qp->firstSentTime==0) + qp->firstSentTime=qp->lastSentTime; + if(qp->data.Length()) + buf.CopyFrom(qp->data, qp->data.Length()); + packetsToSend.push_back(PendingOutgoingPacket{ + /*.seq=*/seq, + /*.type=*/qp->type, + /*.len=*/qp->data.Length(), + /*.data=*/move(buf), + /*.endpoint=*/0 + }); + } + ++qp; + } + for(PendingOutgoingPacket& pkt:packetsToSend){ + SendOrEnqueuePacket(move(pkt)); + } +} + +void VoIPController::SendNopPacket(){ + if(state!=STATE_ESTABLISHED) + return; + SendOrEnqueuePacket(PendingOutgoingPacket{ + /*.seq=*/(firstSentPing=GenerateOutSeq()), + /*.type=*/PKT_NOP, + /*.len=*/0, + /*.data=*/Buffer(), + /*.endpoint=*/0 + }); +} + +void VoIPController::SendPublicEndpointsRequest(){ + ENFORCE_MSG_THREAD; + if(!allowP2p) + return; + LOGI("Sending public endpoints request"); + for(pair& e:endpoints){ + if(e.second.type==Endpoint::Type::UDP_RELAY && !e.second.IsIPv6Only()){ + SendPublicEndpointsRequest(e.second); + } + } + publicEndpointsReqCount++; + if(publicEndpointsReqCount<10){ + messageThread.Post([this]{ + if(waitingForRelayPeerInfo){ + LOGW("Resending peer relay info request"); + SendPublicEndpointsRequest(); + } + }, 5.0); + }else{ + publicEndpointsReqCount=0; + } +} + +void VoIPController::TickJitterBufferAndCongestionControl(){ + // TODO get rid of this and update states of these things internally and retroactively + for(shared_ptr& stm:incomingStreams){ + if(stm->jitterBuffer){ + stm->jitterBuffer->Tick(); + } + } + if(conctl){ + conctl->Tick(); + } + + //MutexGuard m(queuedPacketsMutex); + double currentTime=GetCurrentTime(); + double rtt=GetAverageRTT(); + double packetLossTimeout=std::max(rtt*2.0, 0.1); + for(RecentOutgoingPacket& pkt:recentOutgoingPackets){ + if(pkt.ackTime!=0.0 || pkt.lost) + continue; + if(currentTime-pkt.sendTime>packetLossTimeout){ + pkt.lost=true; + sendLosses++; + LOGW("Outgoing packet lost: seq=%u, type=%s, size=%u", pkt.seq, GetPacketTypeString(pkt.type).c_str(), (unsigned int)pkt.size); + if(pkt.sender){ + pkt.sender->PacketLost(pkt.seq, pkt.type, pkt.size); + }else if(pkt.type==PKT_STREAM_DATA){ + conctl->PacketLost(pkt.seq); + } + } + } +} + +#pragma mark - Endpoint + +Endpoint::Endpoint(int64_t id, uint16_t port, const IPv4Address& _address, const IPv6Address& _v6address, Type type, unsigned char peerTag[16]) : address(NetworkAddress::IPv4(_address.addr)), v6address(NetworkAddress::IPv6(_v6address.addr)){ + this->id=id; + this->port=port; + this->type=type; + memcpy(this->peerTag, peerTag, 16); + if(type==Type::UDP_RELAY && ServerConfig::GetSharedInstance()->GetBoolean("force_tcp", false)) + this->type=Type::TCP_RELAY; + + lastPingSeq=0; + lastPingTime=0; + averageRTT=0; + socket=NULL; + udpPongCount=0; +} + +Endpoint::Endpoint(int64_t id, uint16_t port, const NetworkAddress _address, const NetworkAddress _v6address, Type type, unsigned char peerTag[16]) : address(_address), v6address(_v6address){ + this->id=id; + this->port=port; + this->type=type; + memcpy(this->peerTag, peerTag, 16); + if(type==Type::UDP_RELAY && ServerConfig::GetSharedInstance()->GetBoolean("force_tcp", false)) + this->type=Type::TCP_RELAY; + + lastPingSeq=0; + lastPingTime=0; + averageRTT=0; + socket=NULL; + udpPongCount=0; +} + +Endpoint::Endpoint() : address(NetworkAddress::Empty()), v6address(NetworkAddress::Empty()){ + lastPingSeq=0; + lastPingTime=0; + averageRTT=0; + socket=NULL; + udpPongCount=0; +} + +const NetworkAddress &Endpoint::GetAddress() const{ + return IsIPv6Only() ? (NetworkAddress&)v6address : (NetworkAddress&)address; +} + +NetworkAddress &Endpoint::GetAddress(){ + return IsIPv6Only() ? (NetworkAddress&)v6address : (NetworkAddress&)address; +} + +bool Endpoint::IsIPv6Only() const{ + return address.IsEmpty() && !v6address.IsEmpty(); +} + +int64_t Endpoint::CleanID() const{ + int64_t _id=id; + if(type==Type::TCP_RELAY){ + _id=_id ^ ((int64_t)FOURCC('T','C','P',' ') << 32); + } + if(IsIPv6Only()){ + _id=_id ^ ((int64_t)FOURCC('I','P','v','6') << 32); + } + return _id; +} + +Endpoint::~Endpoint(){ + if(socket){ + socket->Close(); + } +} + +#pragma mark - AudioInputTester + +AudioInputTester::AudioInputTester(std::string deviceID) : deviceID(std::move(deviceID)){ + io=audio::AudioIO::Create(deviceID, "default"); + if(io->Failed()){ + LOGE("Audio IO failed"); + return; + } + input=io->GetInput(); + input->SetCallback([](unsigned char* data, size_t size, void* ctx) -> size_t{ + reinterpret_cast(ctx)->Update(reinterpret_cast(data), size/2); + return 0; + }, this); + input->Start(); +} + +AudioInputTester::~AudioInputTester(){ + input->Stop(); + delete io; +} + +void AudioInputTester::Update(int16_t *samples, size_t count){ + for(size_t i=0;imaxSample) + maxSample=s; + } +} + +float AudioInputTester::GetAndResetLevel(){ + float s=maxSample; + maxSample=0; + return s/(float)INT16_MAX; +} diff --git a/TMessagesProj/jni/libtgvoip2/VoIPController.h b/TMessagesProj/jni/libtgvoip2/VoIPController.h new file mode 100644 index 000000000..ea301d2f4 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/VoIPController.h @@ -0,0 +1,887 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef __VOIPCONTROLLER_H +#define __VOIPCONTROLLER_H + +#ifndef _WIN32 +#include +#include +#endif +#ifdef __APPLE__ +#include +#include "os/darwin/AudioUnitIO.h" +#endif +#include +#include +#include +#include +#include +#include +#include "video/VideoSource.h" +#include "video/VideoRenderer.h" +#include +#include "video/ScreamCongestionController.h" +#include "audio/AudioInput.h" +#include "BlockingQueue.h" +#include "audio/AudioOutput.h" +#include "audio/AudioIO.h" +#include "JitterBuffer.h" +#include "OpusDecoder.h" +#include "OpusEncoder.h" +#include "EchoCanceller.h" +#include "CongestionControl.h" +#include "NetworkSocket.h" +#include "Buffers.h" +#include "PacketReassembler.h" +#include "MessageThread.h" +#include "utils.h" + +#define LIBTGVOIP_VERSION "2.6" + +#ifdef _WIN32 +#undef GetCurrentTime +#undef ERROR_TIMEOUT +#endif + +#define TGVOIP_PEER_CAP_GROUP_CALLS 1 +#define TGVOIP_PEER_CAP_VIDEO_CAPTURE 2 +#define TGVOIP_PEER_CAP_VIDEO_DISPLAY 4 + +namespace tgvoip{ + + enum{ + PROXY_NONE=0, + PROXY_SOCKS5, + //PROXY_HTTP + }; + + enum{ + STATE_WAIT_INIT=1, + STATE_WAIT_INIT_ACK, + STATE_ESTABLISHED, + STATE_FAILED, + STATE_RECONNECTING + }; + + enum{ + ERROR_UNKNOWN=0, + ERROR_INCOMPATIBLE, + ERROR_TIMEOUT, + ERROR_AUDIO_IO, + ERROR_PROXY + }; + + enum{ + NET_TYPE_UNKNOWN=0, + NET_TYPE_GPRS, + NET_TYPE_EDGE, + NET_TYPE_3G, + NET_TYPE_HSPA, + NET_TYPE_LTE, + NET_TYPE_WIFI, + NET_TYPE_ETHERNET, + NET_TYPE_OTHER_HIGH_SPEED, + NET_TYPE_OTHER_LOW_SPEED, + NET_TYPE_DIALUP, + NET_TYPE_OTHER_MOBILE + }; + + enum{ + DATA_SAVING_NEVER=0, + DATA_SAVING_MOBILE, + DATA_SAVING_ALWAYS + }; + + struct CryptoFunctions{ + void (*rand_bytes)(uint8_t* buffer, size_t length); + void (*sha1)(uint8_t* msg, size_t length, uint8_t* output); + void (*sha256)(uint8_t* msg, size_t length, uint8_t* output); + void (*aes_ige_encrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); + void (*aes_ige_decrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); + void (*aes_ctr_encrypt)(uint8_t* inout, size_t length, uint8_t* key, uint8_t* iv, uint8_t* ecount, uint32_t* num); + void (*aes_cbc_encrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); + void (*aes_cbc_decrypt)(uint8_t* in, uint8_t* out, size_t length, uint8_t* key, uint8_t* iv); + }; + + struct CellularCarrierInfo{ + std::string name; + std::string mcc; + std::string mnc; + std::string countryCode; + }; + + // API compatibility + struct IPv4Address{ + IPv4Address(std::string addr) : addr(addr){}; + std::string addr; + }; + struct IPv6Address{ + IPv6Address(std::string addr) : addr(addr){}; + std::string addr; + }; + + class Endpoint{ + friend class VoIPController; + friend class VoIPGroupController; + public: + + enum Type{ + UDP_P2P_INET=1, + UDP_P2P_LAN, + UDP_RELAY, + TCP_RELAY + }; + + Endpoint(int64_t id, uint16_t port, const IPv4Address& address, const IPv6Address& v6address, Type type, unsigned char* peerTag); + Endpoint(int64_t id, uint16_t port, const NetworkAddress address, const NetworkAddress v6address, Type type, unsigned char* peerTag); + Endpoint(); + ~Endpoint(); + const NetworkAddress& GetAddress() const; + NetworkAddress& GetAddress(); + bool IsIPv6Only() const; + int64_t CleanID() const; + int64_t id; + uint16_t port; + NetworkAddress address; + NetworkAddress v6address; + Type type; + unsigned char peerTag[16]; + + private: + double lastPingTime; + uint32_t lastPingSeq; + HistoricBuffer rtts; + HistoricBuffer selfRtts; + std::map udpPingTimes; + double averageRTT; + std::shared_ptr socket; + int udpPongCount; + int totalUdpPings=0; + int totalUdpPingReplies=0; + }; + + class AudioDevice{ + public: + std::string id; + std::string displayName; + }; + + class AudioOutputDevice : public AudioDevice{ + + }; + + class AudioInputDevice : public AudioDevice{ + + }; + + class AudioInputTester{ + public: + AudioInputTester(const std::string deviceID); + ~AudioInputTester(); + TGVOIP_DISALLOW_COPY_AND_ASSIGN(AudioInputTester); + float GetAndResetLevel(); + bool Failed(){ + return io && io->Failed(); + } + private: + void Update(int16_t* samples, size_t count); + audio::AudioIO* io=NULL; + audio::AudioInput* input=NULL; + int16_t maxSample=0; + std::string deviceID; + }; + + class PacketSender; + namespace video{ + class VideoPacketSender; + } + + class VoIPController{ + friend class VoIPGroupController; + friend class PacketSender; + public: + TGVOIP_DISALLOW_COPY_AND_ASSIGN(VoIPController); + struct Config{ + Config(double initTimeout=30.0, double recvTimeout=20.0, int dataSaving=DATA_SAVING_NEVER, bool enableAEC=false, bool enableNS=false, bool enableAGC=false, bool enableCallUpgrade=false){ + this->initTimeout=initTimeout; + this->recvTimeout=recvTimeout; + this->dataSaving=dataSaving; + this->enableAEC=enableAEC; + this->enableNS=enableNS; + this->enableAGC=enableAGC; + this->enableCallUpgrade=enableCallUpgrade; + } + + double initTimeout; + double recvTimeout; + int dataSaving; +#ifndef _WIN32 + std::string logFilePath=""; + std::string statsDumpFilePath=""; +#else + std::wstring logFilePath=L""; + std::wstring statsDumpFilePath=L""; +#endif + + bool enableAEC; + bool enableNS; + bool enableAGC; + + bool enableCallUpgrade; + + bool logPacketStats=false; + bool enableVolumeControl=false; + + bool enableVideoSend=false; + bool enableVideoReceive=false; + }; + + struct TrafficStats{ + uint64_t bytesSentWifi; + uint64_t bytesRecvdWifi; + uint64_t bytesSentMobile; + uint64_t bytesRecvdMobile; + }; + + + VoIPController(); + virtual ~VoIPController(); + + /** + * Set the initial endpoints (relays) + * @param endpoints Endpoints converted from phone.PhoneConnection TL objects + * @param allowP2p Whether p2p connectivity is allowed + * @param connectionMaxLayer The max_layer field from the phoneCallProtocol object returned by Telegram server. + * DO NOT HARDCODE THIS VALUE, it's extremely important for backwards compatibility. + */ + void SetRemoteEndpoints(std::vector endpoints, bool allowP2p, int32_t connectionMaxLayer); + /** + * Initialize and start all the internal threads + */ + void Start(); + /** + * Stop any internal threads. Don't call any other methods after this. + */ + void Stop(); + /** + * Initiate connection + */ + void Connect(); + Endpoint& GetRemoteEndpoint(); + /** + * Get the debug info string to be displayed in client UI + */ + virtual std::string GetDebugString(); + /** + * Notify the library of network type change + * @param type The new network type + */ + virtual void SetNetworkType(int type); + /** + * Get the average round-trip time for network packets + * @return + */ + double GetAverageRTT(); + static double GetCurrentTime(); + /** + * Use this field to store any of your context data associated with this call + */ + void* implData; + /** + * + * @param mute + */ + virtual void SetMicMute(bool mute); + /** + * + * @param key + * @param isOutgoing + */ + void SetEncryptionKey(char* key, bool isOutgoing); + /** + * + * @param cfg + */ + void SetConfig(const Config& cfg); + void DebugCtl(int request, int param); + /** + * + * @param stats + */ + void GetStats(TrafficStats* stats); + /** + * + * @return + */ + int64_t GetPreferredRelayID(); + /** + * + * @return + */ + int GetLastError(); + /** + * + */ + static CryptoFunctions crypto; + /** + * + * @return + */ + static const char* GetVersion(); + /** + * + * @return + */ + std::string GetDebugLog(); + /** + * + * @return + */ + static std::vector EnumerateAudioInputs(); + /** + * + * @return + */ + static std::vector EnumerateAudioOutputs(); + /** + * + * @param id + */ + void SetCurrentAudioInput(std::string id); + /** + * + * @param id + */ + void SetCurrentAudioOutput(std::string id); + /** + * + * @return + */ + std::string GetCurrentAudioInputID(); + /** + * + * @return + */ + std::string GetCurrentAudioOutputID(); + /** + * Set the proxy server to route the data through. Call this before connecting. + * @param protocol PROXY_NONE or PROXY_SOCKS5 + * @param address IP address or domain name of the server + * @param port Port of the server + * @param username Username; empty string for anonymous + * @param password Password; empty string if none + */ + void SetProxy(int protocol, std::string address, uint16_t port, std::string username, std::string password); + /** + * Get the number of signal bars to display in the client UI. + * @return the number of signal bars, from 1 to 4 + */ + int GetSignalBarsCount(); + /** + * Enable or disable AGC (automatic gain control) on audio output. Should only be enabled on phones when the earpiece speaker is being used. + * The audio output will be louder with this on. + * AGC with speakerphone or other kinds of loud speakers has detrimental effects on some echo cancellation implementations. + * @param enabled I usually pick argument names to be self-explanatory + */ + void SetAudioOutputGainControlEnabled(bool enabled); + /** + * Get the additional capabilities of the peer client app + * @return corresponding TGVOIP_PEER_CAP_* flags OR'ed together + */ + uint32_t GetPeerCapabilities(); + /** + * Send the peer the key for the group call to prepare this private call to an upgrade to a E2E group call. + * The peer must have the TGVOIP_PEER_CAP_GROUP_CALLS capability. After the peer acknowledges the key, Callbacks::groupCallKeySent will be called. + * @param key newly-generated group call key, must be exactly 265 bytes long + */ + void SendGroupCallKey(unsigned char* key); + /** + * In an incoming call, request the peer to generate a new encryption key, send it to you and upgrade this call to a E2E group call. + */ + void RequestCallUpgrade(); + void SetEchoCancellationStrength(int strength); + int GetConnectionState(); + bool NeedRate(); + /** + * Get the maximum connection layer supported by this libtgvoip version. + * Pass this as max_layer in the phone.phoneConnection TL object when requesting and accepting calls. + */ + static int32_t GetConnectionMaxLayer(){ + return 92; + }; + /** + * Get the persistable state of the library, like proxy capabilities, to save somewhere on the disk. Call this at the end of the call. + * Using this will speed up the connection establishment in some cases. + */ + std::vector GetPersistentState(); + /** + * Load the persistable state. Call this before starting the call. + */ + void SetPersistentState(std::vector state); + +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) + void SetAudioDataCallbacks(std::function input, std::function output, std::function preprocessed); +#endif + + void SetVideoCodecSpecificData(const std::vector& data); + + struct Callbacks{ + void (*connectionStateChanged)(VoIPController*, int); + void (*signalBarCountChanged)(VoIPController*, int); + void (*groupCallKeySent)(VoIPController*); + void (*groupCallKeyReceived)(VoIPController*, const unsigned char*); + void (*upgradeToGroupCallRequested)(VoIPController*); + }; + void SetCallbacks(Callbacks callbacks); + + float GetOutputLevel(){ + return 0.0f; + }; + void SetVideoSource(video::VideoSource* source); + void SetVideoRenderer(video::VideoRenderer* renderer); + + void SetInputVolume(float level); + void SetOutputVolume(float level); +#if defined(__APPLE__) && defined(TARGET_OS_OSX) + void SetAudioOutputDuckingEnabled(bool enabled); +#endif + + struct PendingOutgoingPacket{ + PendingOutgoingPacket(uint32_t seq, unsigned char type, size_t len, Buffer&& data, int64_t endpoint){ + this->seq=seq; + this->type=type; + this->len=len; + this->data=std::move(data); + this->endpoint=endpoint; + } + PendingOutgoingPacket(PendingOutgoingPacket&& other){ + seq=other.seq; + type=other.type; + len=other.len; + data=std::move(other.data); + endpoint=other.endpoint; + } + PendingOutgoingPacket& operator=(PendingOutgoingPacket&& other){ + if(this!=&other){ + seq=other.seq; + type=other.type; + len=other.len; + data=std::move(other.data); + endpoint=other.endpoint; + } + return *this; + } + TGVOIP_DISALLOW_COPY_AND_ASSIGN(PendingOutgoingPacket); + uint32_t seq; + unsigned char type; + size_t len; + Buffer data; + int64_t endpoint; + }; + + struct Stream{ + int32_t userID; + unsigned char id; + unsigned char type; + uint32_t codec; + bool enabled; + bool extraECEnabled; + uint16_t frameDuration; + std::shared_ptr jitterBuffer; + std::shared_ptr decoder; + std::shared_ptr packetReassembler; + std::shared_ptr callbackWrapper; + std::vector codecSpecificData; + bool csdIsValid=false; + bool paused=false; + int resolution; + unsigned int width=0; + unsigned int height=0; + uint16_t rotation=0; + }; + + struct ProtocolInfo{ + uint32_t version; + uint32_t maxVideoResolution; + std::vector videoDecoders; + bool videoCaptureSupported; + bool videoDisplaySupported; + bool callUpgradeSupported; + }; + + private: + struct UnacknowledgedExtraData; + + protected: + struct RecentOutgoingPacket{ + uint32_t seq; + uint16_t id; // for group calls only + double sendTime; + double ackTime; + uint8_t type; + uint32_t size; + PacketSender* sender; + bool lost; + }; + struct QueuedPacket{ + Buffer data; + unsigned char type; + HistoricBuffer seqs; + double firstSentTime; + double lastSentTime; + double retryInterval; + double timeout; + }; + virtual void ProcessIncomingPacket(NetworkPacket& packet, Endpoint& srcEndpoint); + virtual void ProcessExtraData(Buffer& data); + virtual void WritePacketHeader(uint32_t seq, BufferOutputStream* s, unsigned char type, uint32_t length, PacketSender* source); + virtual void SendPacket(unsigned char* data, size_t len, Endpoint& ep, PendingOutgoingPacket& srcPacket); + virtual void SendInit(); + virtual void SendUdpPing(Endpoint& endpoint); + virtual void SendRelayPings(); + virtual void OnAudioOutputReady(); + virtual void SendExtra(Buffer& data, unsigned char type); + void SendStreamFlags(Stream& stream); + void InitializeTimers(); + void ResetEndpointPingStats(); + void SendVideoFrame(const Buffer& frame, uint32_t flags, uint32_t rotation); + void ProcessIncomingVideoFrame(Buffer frame, uint32_t pts, bool keyframe, uint16_t rotation); + std::shared_ptr GetStreamByType(int type, bool outgoing); + std::shared_ptr GetStreamByID(unsigned char id, bool outgoing); + Endpoint* GetEndpointForPacket(const PendingOutgoingPacket& pkt); + bool SendOrEnqueuePacket(PendingOutgoingPacket pkt, bool enqueue=true, PacketSender* source=NULL); + static std::string NetworkTypeToString(int type); + CellularCarrierInfo GetCarrierInfo(); + + private: + struct UnacknowledgedExtraData{ + unsigned char type; + Buffer data; + uint32_t firstContainingSeq; + }; + struct RecentIncomingPacket{ + uint32_t seq; + double recvTime; + }; + enum{ + UDP_UNKNOWN=0, + UDP_PING_PENDING, + UDP_PING_SENT, + UDP_AVAILABLE, + UDP_NOT_AVAILABLE, + UDP_BAD + }; + struct DebugLoggedPacket{ + int32_t seq; + double timestamp; + int32_t length; + }; + struct RawPendingOutgoingPacket{ + TGVOIP_MOVE_ONLY(RawPendingOutgoingPacket); + NetworkPacket packet; + std::shared_ptr socket; + }; + + void RunRecvThread(); + void RunSendThread(); + void HandleAudioInput(unsigned char* data, size_t len, unsigned char* secondaryData, size_t secondaryLen); + void UpdateAudioBitrateLimit(); + void SetState(int state); + void UpdateAudioOutputState(); + void InitUDPProxy(); + void UpdateDataSavingState(); + void KDF(unsigned char* msgKey, size_t x, unsigned char* aesKey, unsigned char* aesIv); + void KDF2(unsigned char* msgKey, size_t x, unsigned char* aesKey, unsigned char* aesIv); + void SendPublicEndpointsRequest(); + void SendPublicEndpointsRequest(const Endpoint& relay); + Endpoint& GetEndpointByType(int type); + void SendPacketReliably(unsigned char type, unsigned char* data, size_t len, double retryInterval, double timeout); + uint32_t GenerateOutSeq(); + void ActuallySendPacket(NetworkPacket pkt, Endpoint& ep); + void InitializeAudio(); + void StartAudio(); + void ProcessAcknowledgedOutgoingExtra(UnacknowledgedExtraData& extra); + void AddIPv6Relays(); + void AddTCPRelays(); + void SendUdpPings(); + void EvaluateUdpPingResults(); + void UpdateRTT(); + void UpdateCongestion(); + void UpdateAudioBitrate(); + void UpdateSignalBars(); + void UpdateQueuedPackets(); + void SendNopPacket(); + void TickJitterBufferAndCongestionControl(); + void ResetUdpAvailability(); + std::string GetPacketTypeString(unsigned char type); + void SetupOutgoingVideoStream(); + bool WasOutgoingPacketAcknowledged(uint32_t seq); + RecentOutgoingPacket* GetRecentOutgoingPacket(uint32_t seq); + void NetworkPacketReceived(std::shared_ptr packet); + void TrySendQueuedPackets(); + + int state; + std::map endpoints; + int64_t currentEndpoint=0; + int64_t preferredRelay=0; + int64_t peerPreferredRelay=0; + std::atomic runReceiver; + std::atomic seq; + uint32_t lastRemoteSeq; + uint32_t lastRemoteAckSeq; + uint32_t lastSentSeq; + std::vector recentOutgoingPackets; + std::vector recentIncomingPackets; + HistoricBuffer sendLossCountHistory; + uint32_t audioTimestampIn; + uint32_t audioTimestampOut; + tgvoip::audio::AudioIO* audioIO=NULL; + tgvoip::audio::AudioInput* audioInput=NULL; + tgvoip::audio::AudioOutput* audioOutput=NULL; + OpusEncoder* encoder; + std::vector sendQueue; + EchoCanceller* echoCanceller; + std::atomic stopping; + bool audioOutStarted; + Thread* recvThread; + Thread* sendThread; + uint32_t packetsReceived; + uint32_t recvLossCount; + uint32_t prevSendLossCount; + uint32_t firstSentPing; + HistoricBuffer rttHistory; + bool waitingForAcks; + int networkType; + int dontSendPackets; + int lastError; + bool micMuted; + uint32_t maxBitrate; + std::vector> outgoingStreams; + std::vector> incomingStreams; + unsigned char encryptionKey[256]; + unsigned char keyFingerprint[8]; + unsigned char callID[16]; + double stateChangeTime; + bool waitingForRelayPeerInfo; + bool allowP2p; + bool dataSavingMode; + bool dataSavingRequestedByPeer; + std::string activeNetItfName; + double publicEndpointsReqTime; + std::vector queuedPackets; + double connectionInitTime; + double lastRecvPacketTime; + Config config; + int32_t peerVersion; + CongestionControl* conctl; + TrafficStats stats; + bool receivedInit; + bool receivedInitAck; + bool isOutgoing; + NetworkSocket* udpSocket; + NetworkSocket* realUdpSocket; + FILE* statsDump; + std::string currentAudioInput; + std::string currentAudioOutput; + bool useTCP; + bool useUDP; + bool didAddTcpRelays; + SocketSelectCanceller* selectCanceller; + HistoricBuffer signalBarsHistory; + bool audioStarted=false; + + int udpConnectivityState; + double lastUdpPingTime; + int udpPingCount; + int echoCancellationStrength; + + int proxyProtocol; + std::string proxyAddress; + uint16_t proxyPort; + std::string proxyUsername; + std::string proxyPassword; + NetworkAddress resolvedProxyAddress=NetworkAddress::Empty(); + + uint32_t peerCapabilities; + Callbacks callbacks; + bool didReceiveGroupCallKey; + bool didReceiveGroupCallKeyAck; + bool didSendGroupCallKey; + bool didSendUpgradeRequest; + bool didInvokeUpgradeCallback; + + int32_t connectionMaxLayer; + bool useMTProto2; + bool setCurrentEndpointToTCP; + + std::vector currentExtras; + std::unordered_map lastReceivedExtrasByType; + bool useIPv6; + bool peerIPv6Available; + NetworkAddress myIPv6=NetworkAddress::Empty(); + bool shittyInternetMode; + int extraEcLevel=0; + std::vector ecAudioPackets; + bool didAddIPv6Relays; + bool didSendIPv6Endpoint; + int publicEndpointsReqCount=0; + bool wasEstablished=false; + bool receivedFirstStreamPacket=false; + std::atomic unsentStreamPackets; + HistoricBuffer unsentStreamPacketsHistory; + bool needReInitUdpProxy=true; + bool needRate=false; + std::vector debugLoggedPackets; + BufferPool<1024, 32> outgoingAudioBufferPool; + BlockingQueue rawSendQueue; + + uint32_t initTimeoutID=MessageThread::INVALID_ID; + uint32_t udpPingTimeoutID=MessageThread::INVALID_ID; + + effects::Volume outputVolume; + effects::Volume inputVolume; + + std::vector peerVideoDecoders; + + MessageThread messageThread; + + // Locked whenever the endpoints vector is modified (but not endpoints themselves) and whenever iterated outside of messageThread. + // After the call is started, only messageThread is allowed to modify the endpoints vector. + Mutex endpointsMutex; + // Locked while audio i/o is being initialized and deinitialized so as to allow it to fully initialize before deinitialization begins. + Mutex audioIOMutex; + +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) + std::function audioInputDataCallback; + std::function audioOutputDataCallback; + std::function audioPreprocDataCallback; + ::OpusDecoder* preprocDecoder=nullptr; + int16_t preprocBuffer[4096]; +#endif +#if defined(__APPLE__) && defined(TARGET_OS_OSX) + bool macAudioDuckingEnabled=true; +#endif + + video::VideoSource* videoSource=NULL; + video::VideoRenderer* videoRenderer=NULL; + uint32_t lastReceivedVideoFrameNumber=UINT32_MAX; + + video::VideoPacketSender* videoPacketSender=NULL; + uint32_t sendLosses=0; + uint32_t unacknowledgedIncomingPacketCount=0; + + ProtocolInfo protocolInfo={0}; + + /*** debug report problems ***/ + bool wasReconnecting=false; + bool wasExtraEC=false; + bool wasEncoderLaggy=false; + bool wasNetworkHandover=false; + + /*** persistable state values ***/ + bool proxySupportsUDP=true; + bool proxySupportsTCP=true; + std::string lastTestedProxyServer=""; + + /*** server config values ***/ + uint32_t maxAudioBitrate; + uint32_t maxAudioBitrateEDGE; + uint32_t maxAudioBitrateGPRS; + uint32_t maxAudioBitrateSaving; + uint32_t initAudioBitrate; + uint32_t initAudioBitrateEDGE; + uint32_t initAudioBitrateGPRS; + uint32_t initAudioBitrateSaving; + uint32_t minAudioBitrate; + uint32_t audioBitrateStepIncr; + uint32_t audioBitrateStepDecr; + double relaySwitchThreshold; + double p2pToRelaySwitchThreshold; + double relayToP2pSwitchThreshold; + double reconnectingTimeout; + uint32_t needRateFlags; + double rateMaxAcceptableRTT; + double rateMaxAcceptableSendLoss; + double packetLossToEnableExtraEC; + uint32_t maxUnsentStreamPackets; + uint32_t unackNopThreshold; + + public: +#ifdef __APPLE__ + static double machTimebase; + static uint64_t machTimestart; +#endif +#ifdef _WIN32 + static int64_t win32TimeScale; + static bool didInitWin32TimeScale; +#endif + }; + + class VoIPGroupController : public VoIPController{ + public: + VoIPGroupController(int32_t timeDifference); + virtual ~VoIPGroupController(); + void SetGroupCallInfo(unsigned char* encryptionKey, unsigned char* reflectorGroupTag, unsigned char* reflectorSelfTag, unsigned char* reflectorSelfSecret, unsigned char* reflectorSelfTagHash, int32_t selfUserID, NetworkAddress reflectorAddress, NetworkAddress reflectorAddressV6, uint16_t reflectorPort); + void AddGroupCallParticipant(int32_t userID, unsigned char* memberTagHash, unsigned char* serializedStreams, size_t streamsLength); + void RemoveGroupCallParticipant(int32_t userID); + float GetParticipantAudioLevel(int32_t userID); + virtual void SetMicMute(bool mute); + void SetParticipantVolume(int32_t userID, float volume); + void SetParticipantStreams(int32_t userID, unsigned char* serializedStreams, size_t length); + static size_t GetInitialStreams(unsigned char* buf, size_t size); + + struct Callbacks : public VoIPController::Callbacks{ + void (*updateStreams)(VoIPGroupController*, unsigned char*, size_t); + void (*participantAudioStateChanged)(VoIPGroupController*, int32_t, bool); + + }; + void SetCallbacks(Callbacks callbacks); + virtual std::string GetDebugString(); + virtual void SetNetworkType(int type); + protected: + virtual void ProcessIncomingPacket(NetworkPacket& packet, Endpoint& srcEndpoint); + virtual void SendInit(); + virtual void SendUdpPing(Endpoint& endpoint); + virtual void SendRelayPings(); + virtual void SendPacket(unsigned char* data, size_t len, Endpoint& ep, PendingOutgoingPacket& srcPacket); + virtual void WritePacketHeader(uint32_t seq, BufferOutputStream* s, unsigned char type, uint32_t length, PacketSender* sender=NULL); + virtual void OnAudioOutputReady(); + private: + int32_t GetCurrentUnixtime(); + std::vector> DeserializeStreams(BufferInputStream& in); + void SendRecentPacketsRequest(); + void SendSpecialReflectorRequest(unsigned char* data, size_t len); + void SerializeAndUpdateOutgoingStreams(); + struct GroupCallParticipant{ + int32_t userID; + unsigned char memberTagHash[32]; + std::vector> streams; + AudioLevelMeter* levelMeter; + }; + std::vector participants; + unsigned char reflectorSelfTag[16]; + unsigned char reflectorSelfSecret[16]; + unsigned char reflectorSelfTagHash[32]; + int32_t userSelfID; + Endpoint groupReflector; + AudioMixer* audioMixer; + AudioLevelMeter selfLevelMeter; + Callbacks groupCallbacks; + struct PacketIdMapping{ + uint32_t seq; + uint16_t id; + double ackTime; + }; + std::vector recentSentPackets; + Mutex sentPacketsMutex; + Mutex participantsMutex; + int32_t timeDifference; + }; + +}; + +#endif diff --git a/TMessagesProj/jni/libtgvoip2/VoIPGroupController.cpp b/TMessagesProj/jni/libtgvoip2/VoIPGroupController.cpp new file mode 100644 index 000000000..fa46ad952 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/VoIPGroupController.cpp @@ -0,0 +1,816 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "VoIPController.h" +#include "logging.h" +#include "VoIPServerConfig.h" +#include "PrivateDefines.h" +#include +#include +#include + +using namespace tgvoip; +using namespace std; + +VoIPGroupController::VoIPGroupController(int32_t timeDifference){ + audioMixer=new AudioMixer(); + memset(&callbacks, 0, sizeof(callbacks)); + userSelfID=0; + this->timeDifference=timeDifference; + LOGV("Created VoIPGroupController; timeDifference=%d", timeDifference); +} + +VoIPGroupController::~VoIPGroupController(){ + if(audioOutput){ + audioOutput->Stop(); + } + LOGD("before stop audio mixer"); + audioMixer->Stop(); + delete audioMixer; + + for(vector::iterator p=participants.begin();p!=participants.end();p++){ + if(p->levelMeter) + delete p->levelMeter; + } +} + +void VoIPGroupController::SetGroupCallInfo(unsigned char *encryptionKey, unsigned char *reflectorGroupTag, unsigned char *reflectorSelfTag, unsigned char *reflectorSelfSecret, unsigned char* reflectorSelfTagHash, int32_t selfUserID, NetworkAddress reflectorAddress, NetworkAddress reflectorAddressV6, uint16_t reflectorPort){ + Endpoint e; + e.address=reflectorAddress; + e.v6address=reflectorAddressV6; + e.port=reflectorPort; + memcpy(e.peerTag, reflectorGroupTag, 16); + e.type=Endpoint::Type::UDP_RELAY; + e.id=FOURCC('G','R','P','R'); + endpoints[e.id]=e; + groupReflector=e; + currentEndpoint=e.id; + + memcpy(this->encryptionKey, encryptionKey, 256); + memcpy(this->reflectorSelfTag, reflectorSelfTag, 16); + memcpy(this->reflectorSelfSecret, reflectorSelfSecret, 16); + memcpy(this->reflectorSelfTagHash, reflectorSelfTagHash, 16); + uint8_t sha256[SHA256_LENGTH]; + crypto.sha256((uint8_t*) encryptionKey, 256, sha256); + memcpy(callID, sha256+(SHA256_LENGTH-16), 16); + memcpy(keyFingerprint, sha256+(SHA256_LENGTH-16), 8); + this->userSelfID=selfUserID; + + //LOGD("reflectorSelfTag = %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X", reflectorSelfTag[0], reflectorSelfTag[1], reflectorSelfTag[2], reflectorSelfTag[3], reflectorSelfTag[4], reflectorSelfTag[5], reflectorSelfTag[6], reflectorSelfTag[7], reflectorSelfTag[8], reflectorSelfTag[9], reflectorSelfTag[10], reflectorSelfTag[11], reflectorSelfTag[12], reflectorSelfTag[13], reflectorSelfTag[14], reflectorSelfTag[15]); + //LOGD("reflectorSelfSecret = %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X", reflectorSelfSecret[0], reflectorSelfSecret[1], reflectorSelfSecret[2], reflectorSelfSecret[3], reflectorSelfSecret[4], reflectorSelfSecret[5], reflectorSelfSecret[6], reflectorSelfSecret[7], reflectorSelfSecret[8], reflectorSelfSecret[9], reflectorSelfSecret[10], reflectorSelfSecret[11], reflectorSelfSecret[12], reflectorSelfSecret[13], reflectorSelfSecret[14], reflectorSelfSecret[15]); + //LOGD("reflectorSelfTagHash = %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X", reflectorSelfTagHash[0], reflectorSelfTagHash[1], reflectorSelfTagHash[2], reflectorSelfTagHash[3], reflectorSelfTagHash[4], reflectorSelfTagHash[5], reflectorSelfTagHash[6], reflectorSelfTagHash[7], reflectorSelfTagHash[8], reflectorSelfTagHash[9], reflectorSelfTagHash[10], reflectorSelfTagHash[11], reflectorSelfTagHash[12], reflectorSelfTagHash[13], reflectorSelfTagHash[14], reflectorSelfTagHash[15]); +} + +void VoIPGroupController::AddGroupCallParticipant(int32_t userID, unsigned char *memberTagHash, unsigned char* serializedStreams, size_t streamsLength){ + if(userID==userSelfID) + return; + if(userSelfID==0) + return; + //if(streamsLength==0) + // return; + MutexGuard m(participantsMutex); + LOGV("Adding group call user %d, streams length %u", userID, (unsigned int)streamsLength); + + for(vector::iterator p=participants.begin();p!=participants.end();++p){ + if(p->userID==userID){ + LOGE("user %d already added", userID); + abort(); + break; + } + } + + GroupCallParticipant p; + p.userID=userID; + memcpy(p.memberTagHash, memberTagHash, sizeof(p.memberTagHash)); + p.levelMeter=new AudioLevelMeter(); + + BufferInputStream ss(serializedStreams, streamsLength); + vector> streams=DeserializeStreams(ss); + + unsigned char audioStreamID=0; + + for(vector>::iterator _s=streams.begin();_s!=streams.end();++_s){ + shared_ptr& s=*_s; + s->userID=userID; + if(s->type==STREAM_TYPE_AUDIO && s->codec==CODEC_OPUS && !audioStreamID){ + audioStreamID=s->id; + s->jitterBuffer=make_shared(nullptr, s->frameDuration); + if(s->frameDuration>50) + s->jitterBuffer->SetMinPacketCount((uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_initial_delay_60", 2)); + else if(s->frameDuration>30) + s->jitterBuffer->SetMinPacketCount((uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_initial_delay_40", 4)); + else + s->jitterBuffer->SetMinPacketCount((uint32_t) ServerConfig::GetSharedInstance()->GetInt("jitter_initial_delay_20", 6)); + s->callbackWrapper=make_shared(); + s->decoder=make_shared(s->callbackWrapper, false, false); + s->decoder->SetJitterBuffer(s->jitterBuffer); + s->decoder->SetFrameDuration(s->frameDuration); + s->decoder->SetDTX(true); + s->decoder->SetLevelMeter(p.levelMeter); + audioMixer->AddInput(s->callbackWrapper); + } + incomingStreams.push_back(s); + } + + if(!audioStreamID){ + LOGW("User %d has no usable audio stream", userID); + } + + p.streams.insert(p.streams.end(), streams.begin(), streams.end()); + participants.push_back(p); + LOGI("Added group call participant %d", userID); +} + +void VoIPGroupController::RemoveGroupCallParticipant(int32_t userID){ + MutexGuard m(participantsMutex); + vector>::iterator stm=incomingStreams.begin(); + while(stm!=incomingStreams.end()){ + if((*stm)->userID==userID){ + LOGI("Removed stream %d belonging to user %d", (*stm)->id, userID); + audioMixer->RemoveInput((*stm)->callbackWrapper); + (*stm)->decoder->Stop(); + //delete (*stm)->decoder; + //delete (*stm)->jitterBuffer; + //delete (*stm)->callbackWrapper; + stm=incomingStreams.erase(stm); + continue; + } + ++stm; + } + for(vector::iterator p=participants.begin();p!=participants.end();++p){ + if(p->userID==userID){ + if(p->levelMeter) + delete p->levelMeter; + participants.erase(p); + LOGI("Removed group call participant %d", userID); + break; + } + } +} + +vector> VoIPGroupController::DeserializeStreams(BufferInputStream& in){ + vector> res; + try{ + unsigned char count=in.ReadByte(); + for(unsigned char i=0;i s=make_shared(); + s->id=inner.ReadByte(); + s->type=inner.ReadByte(); + s->codec=(uint32_t) inner.ReadInt32(); + uint32_t flags=(uint32_t) inner.ReadInt32(); + s->enabled=(flags & STREAM_FLAG_ENABLED)==STREAM_FLAG_ENABLED; + s->frameDuration=(uint16_t) inner.ReadInt16(); + res.push_back(s); + } + }catch(out_of_range& x){ + LOGW("Error deserializing streams: %s", x.what()); + } + return res; +} + +void VoIPGroupController::SetParticipantStreams(int32_t userID, unsigned char *serializedStreams, size_t length){ + LOGD("Set participant streams for %d", userID); + MutexGuard m(participantsMutex); + for(vector::iterator p=participants.begin();p!=participants.end();++p){ + if(p->userID==userID){ + BufferInputStream in(serializedStreams, length); + vector> streams=DeserializeStreams(in); + for(vector>::iterator ns=streams.begin();ns!=streams.end();++ns){ + bool found=false; + for(vector>::iterator s=p->streams.begin();s!=p->streams.end();++s){ + if((*s)->id==(*ns)->id){ + (*s)->enabled=(*ns)->enabled; + if(groupCallbacks.participantAudioStateChanged) + groupCallbacks.participantAudioStateChanged(this, userID, (*s)->enabled); + found=true; + break; + } + } + if(!found){ + LOGW("Tried to add stream %d for user %d but adding/removing streams is not supported", (*ns)->id, userID); + } + } + break; + } + } +} + +size_t VoIPGroupController::GetInitialStreams(unsigned char *buf, size_t size){ + BufferOutputStream s(buf, size); + s.WriteByte(1); // streams count + + s.WriteInt16(12); // this object length + s.WriteByte(1); // stream id + s.WriteByte(STREAM_TYPE_AUDIO); + s.WriteInt32(CODEC_OPUS); + s.WriteInt32(STREAM_FLAG_ENABLED | STREAM_FLAG_DTX); // flags + s.WriteInt16(60); // frame duration + + return s.GetLength(); +} + +void VoIPGroupController::SendInit(){ + SendRecentPacketsRequest(); +} + +void VoIPGroupController::ProcessIncomingPacket(NetworkPacket &packet, Endpoint& srcEndpoint){ + //LOGD("Received incoming packet from %s:%u, %u bytes", packet.address->ToString().c_str(), packet.port, packet.length); + /*if(packet.length<17 || packet.length>2000){ + LOGW("Received packet has wrong length %d", (int)packet.length); + return; + } + BufferOutputStream sigData(packet.length); + sigData.WriteBytes(packet.data, packet.length-16); + sigData.WriteBytes(reflectorSelfSecret, 16); + unsigned char sig[32]; + crypto.sha256(sigData.GetBuffer(), sigData.GetLength(), sig); + if(memcmp(sig, packet.data+(packet.length-16), 16)!=0){ + LOGW("Received packet has incorrect signature"); + return; + } + + // reflector special response + if(memcmp(packet.data, reflectorSelfTagHash, 16)==0 && packet.length>60){ + //LOGI("possible reflector special response"); + unsigned char firstBlock[16]; + unsigned char iv[16]; + memcpy(iv, packet.data+16, 16); + unsigned char key[32]; + crypto.sha256(reflectorSelfSecret, 16, key); + crypto.aes_cbc_decrypt(packet.data+32, firstBlock, 16, key, iv); + BufferInputStream in(firstBlock, 16); + in.Seek(8); + size_t len=(size_t) in.ReadInt32(); + int32_t tlid=in.ReadInt32(); + //LOGD("special response: len=%d, tlid=0x%08X", len, tlid); + if(len%4==0 && len+60<=packet.length && packet.length<=1500){ + lastRecvPacketTime=GetCurrentTime(); + memcpy(iv, packet.data+16, 16); + unsigned char buf[1500]; + crypto.aes_cbc_decrypt(packet.data+32, buf, len+16, key, iv); + try{ + if(tlid==TLID_UDP_REFLECTOR_LAST_PACKETS_INFO){ + MutexGuard m(sentPacketsMutex); + //LOGV("received udpReflector.lastPacketsInfo"); + in=BufferInputStream(buf, len+16); + in.Seek(16); + /*int32_t date=* /in.ReadInt32(); + /*int64_t queryID=* /in.ReadInt64(); + int32_t vectorMagic=in.ReadInt32(); + if(vectorMagic!=TLID_VECTOR){ + LOGW("last packets info: expected vector, got %08X", vectorMagic); + return; + } + int32_t recvCount=in.ReadInt32(); + //LOGV("%d received packets", recvCount); + for(int i=0;i::iterator pkt=recentSentPackets.begin();pkt!=recentSentPackets.end();++pkt){ + //LOGV("== sent id %04X", pkt->id); + if(pkt->id==id){ + if(!pkt->ackTime){ + pkt->ackTime=GetCurrentTime(); + conctl->PacketAcknowledged(pkt->seq); + //LOGV("relay acknowledged packet %u", pkt->seq); + if(seqgt(pkt->seq, lastRemoteAckSeq)) + lastRemoteAckSeq=pkt->seq; + } + break; + } + } + } + vectorMagic=in.ReadInt32(); + if(vectorMagic!=TLID_VECTOR){ + LOGW("last packets info: expected vector, got %08X", vectorMagic); + return; + } + int32_t sentCount=in.ReadInt32(); + //LOGV("%d sent packets", sentCount); + for(int i=0;iStart(); + } + } + } + }catch(out_of_range& x){ + LOGE("Error parsing special response: %s", x.what()); + } + return; + } + } + + if(packet.length<32) + return; + + // it's a packet relayed from another participant - find the sender + MutexGuard m(participantsMutex); + GroupCallParticipant* sender=NULL; + for(vector::iterator p=participants.begin();p!=participants.end();++p){ + if(memcmp(packet.data, p->memberTagHash, 16)==0){ + //LOGV("received data packet from user %d", p->userID); + sender=&*p; + break; + } + } + if(!sender){ + LOGV("Received data packet is from unknown user"); + return; + } + + if(memcmp(packet.data+16, keyFingerprint, 8)!=0){ + LOGW("received packet has wrong key fingerprint"); + return; + } + + BufferInputStream in(packet.data, packet.length-16); + in.Seek(16+8); // peer tag + key fingerprint + + unsigned char msgKey[16]; + in.ReadBytes(msgKey, 16); + + unsigned char decrypted[1500]; + unsigned char aesKey[32], aesIv[32]; + KDF2(msgKey, 0, aesKey, aesIv); + size_t decryptedLen=in.Remaining()-16; + if(decryptedLen>sizeof(decrypted)) + return; + //LOGV("-> MSG KEY: %08x %08x %08x %08x, hashed %u", *reinterpret_cast(msgKey), *reinterpret_cast(msgKey+4), *reinterpret_cast(msgKey+8), *reinterpret_cast(msgKey+12), decryptedLen-4); + uint8_t *decryptOffset = packet.data + in.GetOffset(); + if ((((intptr_t)decryptOffset) % sizeof(long)) != 0) { + LOGE("alignment2 packet.data+in.GetOffset()"); + } + if (decryptedLen % sizeof(long) != 0) { + LOGE("alignment2 decryptedLen"); + } + crypto.aes_ige_decrypt(packet.data+in.GetOffset(), decrypted, decryptedLen, aesKey, aesIv); + + in=BufferInputStream(decrypted, decryptedLen); + //LOGD("received packet length: %d", in.ReadInt32()); + + BufferOutputStream buf(decryptedLen+32); + size_t x=0; + buf.WriteBytes(encryptionKey+88+x, 32); + buf.WriteBytes(decrypted+4, decryptedLen-4); + unsigned char msgKeyLarge[32]; + crypto.sha256(buf.GetBuffer(), buf.GetLength(), msgKeyLarge); + + if(memcmp(msgKey, msgKeyLarge+8, 16)!=0){ + LOGW("Received packet from user %d has wrong hash", sender->userID); + return; + } + + uint32_t innerLen=(uint32_t) in.ReadInt32(); + if(innerLen>decryptedLen-4){ + LOGW("Received packet has wrong inner length (%d with total of %u)", (int)innerLen, (unsigned int)decryptedLen); + return; + } + if(decryptedLen-innerLen<12){ + LOGW("Received packet has too little padding (%u)", (unsigned int)(decryptedLen-innerLen)); + return; + } + in=BufferInputStream(decrypted+4, (size_t) innerLen); + + uint32_t tlid=(uint32_t) in.ReadInt32(); + if(tlid!=TLID_DECRYPTED_AUDIO_BLOCK){ + LOGW("Received packet has unknown TL ID 0x%08x", tlid); + return; + } + in.Seek(in.GetOffset()+16); // random bytes + int32_t flags=in.ReadInt32(); + if(!(flags & PFLAG_HAS_SEQ) || !(flags & PFLAG_HAS_SENDER_TAG_HASH)){ + LOGW("Received packet has wrong flags"); + return; + } + /*uint32_t seq=(uint32_t) * /in.ReadInt32(); + unsigned char senderTagHash[16]; + in.ReadBytes(senderTagHash, 16); + if(memcmp(senderTagHash, sender->memberTagHash, 16)!=0){ + LOGW("Received packet has wrong inner sender tag hash"); + return; + } + + //int32_t oneMoreInnerLengthWhyDoWeEvenNeedThis; + if(flags & PFLAG_HAS_DATA){ + /*oneMoreInnerLengthWhyDoWeEvenNeedThis=* /in.ReadTlLength(); + } + unsigned char type=(unsigned char) ((flags >> 24) & 0xFF); + lastRecvPacketTime=GetCurrentTime(); + + if(type==PKT_STREAM_DATA || type==PKT_STREAM_DATA_X2 || type==PKT_STREAM_DATA_X3){ + if(state!=STATE_ESTABLISHED && receivedInitAck) + SetState(STATE_ESTABLISHED); + int count; + switch(type){ + case PKT_STREAM_DATA_X2: + count=2; + break; + case PKT_STREAM_DATA_X3: + count=3; + break; + case PKT_STREAM_DATA: + default: + count=1; + break; + } + int i; + //if(srcEndpoint->type==Endpoint::Type::UDP_RELAY && srcEndpoint!=peerPreferredRelay){ + // peerPreferredRelay=srcEndpoint; + //} + for(i=0;iStart(); + audioOutStarted=true; + }* / + if(in.GetOffset()+sdlen>in.GetLength()){ + return; + } + for(vector>::iterator stm=sender->streams.begin();stm!=sender->streams.end();++stm){ + if((*stm)->id==streamID){ + if((*stm)->jitterBuffer){ + (*stm)->jitterBuffer->HandleInput(decrypted+4+in.GetOffset(), sdlen, pts, false); + } + break; + } + } + if(iGetLocalInterfaceInfo(NULL, NULL); + if(itfName!=activeNetItfName){ + udpSocket->OnActiveInterfaceChanged(); + LOGI("Active network interface changed: %s -> %s", activeNetItfName.c_str(), itfName.c_str()); + bool isFirstChange=activeNetItfName.length()==0; + activeNetItfName=itfName; + if(isFirstChange) + return; + udpConnectivityState=UDP_UNKNOWN; + udpPingCount=0; + lastUdpPingTime=0; + if(proxyProtocol==PROXY_SOCKS5) + InitUDPProxy(); + selectCanceller->CancelSelect(); + } +} + +void VoIPGroupController::SendRecentPacketsRequest(){ + BufferOutputStream out(1024); + out.WriteInt32(TLID_UDP_REFLECTOR_REQUEST_PACKETS_INFO); // TL function + out.WriteInt32(GetCurrentUnixtime()); // date:int + out.WriteInt64(0); // query_id:long + out.WriteInt32(64); // recv_num:int + out.WriteInt32(0); // sent_num:int + SendSpecialReflectorRequest(out.GetBuffer(), out.GetLength()); +} + +void VoIPGroupController::SendSpecialReflectorRequest(unsigned char *data, size_t len){ + /*BufferOutputStream out(1024); + unsigned char buf[1500]; + crypto.rand_bytes(buf, 8); + out.WriteBytes(buf, 8); + out.WriteInt32((int32_t)len); + out.WriteBytes(data, len); + if(out.GetLength()%16!=0){ + size_t paddingLen=16-(out.GetLength()%16); + crypto.rand_bytes(buf, paddingLen); + out.WriteBytes(buf, paddingLen); + } + unsigned char iv[16]; + crypto.rand_bytes(iv, 16); + unsigned char key[32]; + crypto.sha256(reflectorSelfSecret, 16, key); + unsigned char _iv[16]; + memcpy(_iv, iv, 16); + size_t encryptedLen=out.GetLength(); + crypto.aes_cbc_encrypt(out.GetBuffer(), buf, encryptedLen, key, _iv); + out.Reset(); + out.WriteBytes(reflectorSelfTag, 16); + out.WriteBytes(iv, 16); + out.WriteBytes(buf, encryptedLen); + out.WriteBytes(reflectorSelfSecret, 16); + crypto.sha256(out.GetBuffer(), out.GetLength(), buf); + out.Rewind(16); + out.WriteBytes(buf, 16); + + NetworkPacket pkt={0}; + pkt.address=&groupReflector.address; + pkt.port=groupReflector.port; + pkt.protocol=PROTO_UDP; + pkt.data=out.GetBuffer(); + pkt.length=out.GetLength(); + ActuallySendPacket(pkt, groupReflector);*/ +} + +void VoIPGroupController::SendRelayPings(){ + //LOGV("Send relay pings 2"); + double currentTime=GetCurrentTime(); + if(currentTime-groupReflector.lastPingTime>=0.25){ + SendRecentPacketsRequest(); + groupReflector.lastPingTime=currentTime; + } +} + +void VoIPGroupController::OnAudioOutputReady(){ + encoder->SetDTX(true); + audioMixer->SetOutput(audioOutput); + audioMixer->SetEchoCanceller(echoCanceller); + audioMixer->Start(); + audioOutput->Start(); + audioOutStarted=true; + encoder->SetLevelMeter(&selfLevelMeter); +} + +void VoIPGroupController::WritePacketHeader(uint32_t seq, BufferOutputStream *s, unsigned char type, uint32_t length, PacketSender* source){ + s->WriteInt32(TLID_DECRYPTED_AUDIO_BLOCK); + int64_t randomID; + crypto.rand_bytes((uint8_t *) &randomID, 8); + s->WriteInt64(randomID); + unsigned char randBytes[7]; + crypto.rand_bytes(randBytes, 7); + s->WriteByte(7); + s->WriteBytes(randBytes, 7); + uint32_t pflags=PFLAG_HAS_SEQ | PFLAG_HAS_SENDER_TAG_HASH; + if(length>0) + pflags|=PFLAG_HAS_DATA; + pflags|=((uint32_t) type) << 24; + s->WriteInt32(pflags); + + if(type==PKT_STREAM_DATA || type==PKT_STREAM_DATA_X2 || type==PKT_STREAM_DATA_X3){ + conctl->PacketSent(seq, length); + } + + /*if(pflags & PFLAG_HAS_CALL_ID){ + s->WriteBytes(callID, 16); + }*/ + //s->WriteInt32(lastRemoteSeq); + s->WriteInt32(seq); + s->WriteBytes(reflectorSelfTagHash, 16); + if(length>0){ + if(length<=253){ + s->WriteByte((unsigned char) length); + }else{ + s->WriteByte(254); + s->WriteByte((unsigned char) (length & 0xFF)); + s->WriteByte((unsigned char) ((length >> 8) & 0xFF)); + s->WriteByte((unsigned char) ((length >> 16) & 0xFF)); + } + } +} + +void VoIPGroupController::SendPacket(unsigned char *data, size_t len, Endpoint& ep, PendingOutgoingPacket& srcPacket){ + if(stopping) + return; + if(ep.type==Endpoint::Type::TCP_RELAY && !useTCP) + return; + BufferOutputStream out(len+128); + //LOGV("send group packet %u", len); + + out.WriteBytes(reflectorSelfTag, 16); + + if(len>0){ + BufferOutputStream inner(len+128); + inner.WriteInt32((uint32_t)len); + inner.WriteBytes(data, len); + size_t padLen=16-inner.GetLength()%16; + if(padLen<12) + padLen+=16; + unsigned char padding[28]; + crypto.rand_bytes((uint8_t *) padding, padLen); + inner.WriteBytes(padding, padLen); + assert(inner.GetLength()%16==0); + + unsigned char key[32], iv[32], msgKey[16]; + out.WriteBytes(keyFingerprint, 8); + BufferOutputStream buf(len+32); + size_t x=0; + buf.WriteBytes(encryptionKey+88+x, 32); + buf.WriteBytes(inner.GetBuffer()+4, inner.GetLength()-4); + unsigned char msgKeyLarge[32]; + crypto.sha256(buf.GetBuffer(), buf.GetLength(), msgKeyLarge); + memcpy(msgKey, msgKeyLarge+8, 16); + KDF2(msgKey, 0, key, iv); + out.WriteBytes(msgKey, 16); + //LOGV("<- MSG KEY: %08x %08x %08x %08x, hashed %u", *reinterpret_cast(msgKey), *reinterpret_cast(msgKey+4), *reinterpret_cast(msgKey+8), *reinterpret_cast(msgKey+12), inner.GetLength()-4); + + unsigned char aesOut[MSC_STACK_FALLBACK(inner.GetLength(), 1500)]; + crypto.aes_ige_encrypt(inner.GetBuffer(), aesOut, inner.GetLength(), key, iv); + out.WriteBytes(aesOut, inner.GetLength()); + } + + // relay signature + out.WriteBytes(reflectorSelfSecret, 16); + unsigned char sig[32]; + crypto.sha256(out.GetBuffer(), out.GetLength(), sig); + out.Rewind(16); + out.WriteBytes(sig, 16); + + if(srcPacket.type==PKT_STREAM_DATA || srcPacket.type==PKT_STREAM_DATA_X2 || srcPacket.type==PKT_STREAM_DATA_X3){ + PacketIdMapping mapping={srcPacket.seq, *reinterpret_cast(sig+14), 0}; + MutexGuard m(sentPacketsMutex); + recentSentPackets.push_back(mapping); + //LOGD("sent packet with id: %04X", mapping.id); + while(recentSentPackets.size()>64) + recentSentPackets.erase(recentSentPackets.begin()); + } + lastSentSeq=srcPacket.seq; + + if(IS_MOBILE_NETWORK(networkType)) + stats.bytesSentMobile+=(uint64_t)out.GetLength(); + else + stats.bytesSentWifi+=(uint64_t)out.GetLength(); + + /*NetworkPacket pkt={0}; + pkt.address=(NetworkAddress*)&ep.address; + pkt.port=ep.port; + pkt.length=out.GetLength(); + pkt.data=out.GetBuffer(); + pkt.protocol=ep.type==Endpoint::Type::TCP_RELAY ? PROTO_TCP : PROTO_UDP; + ActuallySendPacket(pkt, ep);*/ +} + +void VoIPGroupController::SetCallbacks(VoIPGroupController::Callbacks callbacks){ + VoIPController::SetCallbacks(callbacks); + this->groupCallbacks=callbacks; +} + +int32_t VoIPGroupController::GetCurrentUnixtime(){ + return time(NULL)+timeDifference; +} + +float VoIPGroupController::GetParticipantAudioLevel(int32_t userID){ + if(userID==userSelfID) + return selfLevelMeter.GetLevel(); + MutexGuard m(participantsMutex); + for(vector::iterator p=participants.begin(); p!=participants.end(); ++p){ + if(p->userID==userID){ + return p->levelMeter->GetLevel(); + } + } + return 0; +} + +void VoIPGroupController::SetMicMute(bool mute){ + micMuted=mute; + if(audioInput){ + if(mute) + audioInput->Stop(); + else + audioInput->Start(); + if(!audioInput->IsInitialized()){ + lastError=ERROR_AUDIO_IO; + SetState(STATE_FAILED); + return; + } + } + outgoingStreams[0]->enabled=!mute; + SerializeAndUpdateOutgoingStreams(); +} + +void VoIPGroupController::SetParticipantVolume(int32_t userID, float volume){ + MutexGuard m(participantsMutex); + for(vector::iterator p=participants.begin();p!=participants.end();++p){ + if(p->userID==userID){ + for(vector>::iterator s=p->streams.begin();s!=p->streams.end();++s){ + if((*s)->type==STREAM_TYPE_AUDIO){ + if((*s)->decoder){ + float db; + if(volume==0.0f) + db=-INFINITY; + else if(volume<1.0f) + db=-50.0f*(1.0f-volume); + else if(volume>1.0f && volume<=2.0f) + db=10.0f*(volume-1.0f); + else + db=0.0f; + //LOGV("Setting user %u audio volume to %.2f dB", userID, db); + audioMixer->SetInputVolume((*s)->callbackWrapper, db); + } + break; + } + } + break; + } + } +} + +void VoIPGroupController::SerializeAndUpdateOutgoingStreams(){ + BufferOutputStream out(1024); + out.WriteByte((unsigned char) outgoingStreams.size()); + + for(vector>::iterator s=outgoingStreams.begin(); s!=outgoingStreams.end(); ++s){ + BufferOutputStream o(128); + o.WriteByte((*s)->id); + o.WriteByte((*s)->type); + o.WriteInt32((*s)->codec); + o.WriteInt32((unsigned char) (((*s)->enabled ? STREAM_FLAG_ENABLED : 0) | STREAM_FLAG_DTX)); + o.WriteInt16((*s)->frameDuration); + out.WriteInt16((int16_t) o.GetLength()); + out.WriteBytes(o.GetBuffer(), o.GetLength()); + } + if(groupCallbacks.updateStreams) + groupCallbacks.updateStreams(this, out.GetBuffer(), out.GetLength()); +} + +std::string VoIPGroupController::GetDebugString(){ + std::string r="Remote endpoints: \n"; + char buffer[2048]; + for(pair& _endpoint:endpoints){ + Endpoint& endpoint=_endpoint.second; + const char* type; + switch(endpoint.type){ + case Endpoint::Type::UDP_P2P_INET: + type="UDP_P2P_INET"; + break; + case Endpoint::Type::UDP_P2P_LAN: + type="UDP_P2P_LAN"; + break; + case Endpoint::Type::UDP_RELAY: + type="UDP_RELAY"; + break; + case Endpoint::Type::TCP_RELAY: + type="TCP_RELAY"; + break; + default: + type="UNKNOWN"; + break; + } + snprintf(buffer, sizeof(buffer), "%s:%u %dms [%s%s]\n", endpoint.address.ToString().c_str(), endpoint.port, (int)(endpoint.averageRTT*1000), type, currentEndpoint==endpoint.id ? ", IN_USE" : ""); + r+=buffer; + } + double avgLate[3]; + shared_ptr jitterBuffer=incomingStreams.size()==1 ? incomingStreams[0]->jitterBuffer : NULL; + if(jitterBuffer) + jitterBuffer->GetAverageLateCount(avgLate); + else + memset(avgLate, 0, 3*sizeof(double)); + snprintf(buffer, sizeof(buffer), + "RTT avg/min: %d/%d\n" + "Congestion window: %d/%d bytes\n" + "Key fingerprint: %02hhX%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX\n" + "Last sent/ack'd seq: %u/%u\n" + "Send/recv losses: %u/%u (%d%%)\n" + "Audio bitrate: %d kbit\n" + "Bytes sent/recvd: %llu/%llu\n\n", + (int)(conctl->GetAverageRTT()*1000), (int)(conctl->GetMinimumRTT()*1000), + int(conctl->GetInflightDataSize()), int(conctl->GetCongestionWindow()), + keyFingerprint[0],keyFingerprint[1],keyFingerprint[2],keyFingerprint[3],keyFingerprint[4],keyFingerprint[5],keyFingerprint[6],keyFingerprint[7], + lastSentSeq, lastRemoteAckSeq, + conctl->GetSendLossCount(), recvLossCount, encoder ? encoder->GetPacketLoss() : 0, + encoder ? (encoder->GetBitrate()/1000) : 0, + (long long unsigned int)(stats.bytesSentMobile+stats.bytesSentWifi), + (long long unsigned int)(stats.bytesRecvdMobile+stats.bytesRecvdWifi)); + + MutexGuard m(participantsMutex); + for(vector::iterator p=participants.begin();p!=participants.end();++p){ + snprintf(buffer, sizeof(buffer), "Participant id: %d\n", p->userID); + r+=buffer; + for(vector>::iterator stm=p->streams.begin();stm!=p->streams.end();++stm){ + char* codec=reinterpret_cast(&(*stm)->codec); + snprintf(buffer, sizeof(buffer), "Stream %d (type %d, codec '%c%c%c%c', %sabled)\n", + (*stm)->id, (*stm)->type, codec[3], codec[2], codec[1], codec[0], (*stm)->enabled ? "en" : "dis"); + r+=buffer; + if((*stm)->enabled){ + if((*stm)->jitterBuffer){ + snprintf(buffer, sizeof(buffer), "Jitter buffer: %d/%.2f\n", + (*stm)->jitterBuffer->GetMinPacketCount(), (*stm)->jitterBuffer->GetAverageDelay()); + r+=buffer; + } + } + } + r+="\n"; + } + return r; +} diff --git a/TMessagesProj/jni/libtgvoip2/VoIPServerConfig.cpp b/TMessagesProj/jni/libtgvoip2/VoIPServerConfig.cpp new file mode 100644 index 000000000..27f15a78d --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/VoIPServerConfig.cpp @@ -0,0 +1,70 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "VoIPServerConfig.h" +#include +#include "logging.h" +#include +#include + +using namespace tgvoip; + +ServerConfig* ServerConfig::sharedInstance=NULL; + +ServerConfig::ServerConfig(){ +} + +ServerConfig::~ServerConfig(){ +} + +ServerConfig *ServerConfig::GetSharedInstance(){ + if(!sharedInstance) + sharedInstance=new ServerConfig(); + return sharedInstance; +} + +bool ServerConfig::GetBoolean(std::string name, bool fallback){ + MutexGuard sync(mutex); + if(ContainsKey(name) && config[name].is_bool()) + return config[name].bool_value(); + return fallback; +} + +double ServerConfig::GetDouble(std::string name, double fallback){ + MutexGuard sync(mutex); + if(ContainsKey(name) && config[name].is_number()) + return config[name].number_value(); + return fallback; +} + +int32_t ServerConfig::GetInt(std::string name, int32_t fallback){ + MutexGuard sync(mutex); + if(ContainsKey(name) && config[name].is_number()) + return config[name].int_value(); + return fallback; +} + +std::string ServerConfig::GetString(std::string name, std::string fallback){ + MutexGuard sync(mutex); + if(ContainsKey(name) && config[name].is_string()) + return config[name].string_value(); + return fallback; +} + +void ServerConfig::Update(std::string jsonString){ + MutexGuard sync(mutex); + LOGD("=== Updating voip config ==="); + LOGD("%s", jsonString.c_str()); + std::string jsonError; + config=json11::Json::parse(jsonString, jsonError); + if(!jsonError.empty()) + LOGE("Error parsing server config: %s", jsonError.c_str()); +} + + +bool ServerConfig::ContainsKey(std::string key){ + return config.object_items().find(key)!=config.object_items().end(); +} diff --git a/TMessagesProj/jni/libtgvoip2/VoIPServerConfig.h b/TMessagesProj/jni/libtgvoip2/VoIPServerConfig.h new file mode 100644 index 000000000..3eb5124e7 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/VoIPServerConfig.h @@ -0,0 +1,37 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef TGVOIP_VOIPSERVERCONFIG_H +#define TGVOIP_VOIPSERVERCONFIG_H + +#include +#include +#include +#include "threading.h" +#include "json11.hpp" + +namespace tgvoip{ + +class ServerConfig{ +public: + ServerConfig(); + ~ServerConfig(); + static ServerConfig* GetSharedInstance(); + int32_t GetInt(std::string name, int32_t fallback); + double GetDouble(std::string name, double fallback); + std::string GetString(std::string name, std::string fallback); + bool GetBoolean(std::string name, bool fallback); + void Update(std::string jsonString); + +private: + static ServerConfig* sharedInstance; + bool ContainsKey(std::string key); + json11::Json config; + Mutex mutex; +}; +} + +#endif //TGVOIP_VOIPSERVERCONFIG_H diff --git a/TMessagesProj/jni/libtgvoip2/aclocal.m4 b/TMessagesProj/jni/libtgvoip2/aclocal.m4 new file mode 100644 index 000000000..897cabf3a --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/aclocal.m4 @@ -0,0 +1,10209 @@ +# generated automatically by aclocal 1.16.1 -*- Autoconf -*- + +# Copyright (C) 1996-2018 Free Software Foundation, Inc. + +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +m4_ifndef([AC_CONFIG_MACRO_DIRS], [m4_defun([_AM_CONFIG_MACRO_DIRS], [])m4_defun([AC_CONFIG_MACRO_DIRS], [_AM_CONFIG_MACRO_DIRS($@)])]) +m4_ifndef([AC_AUTOCONF_VERSION], + [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl +m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.69],, +[m4_warning([this file was generated for autoconf 2.69. +You have another version of autoconf. It may work, but is not guaranteed to. +If you have problems, you may need to regenerate the build system entirely. +To do so, use the procedure documented by the package, typically 'autoreconf'.])]) + +# libtool.m4 - Configure libtool for the host system. -*-Autoconf-*- +# +# Copyright (C) 1996-2001, 2003-2018 Free Software Foundation, Inc. +# Written by Gordon Matzigkeit, 1996 +# +# This file is free software; the Free Software Foundation gives +# unlimited permission to copy and/or distribute it, with or without +# modifications, as long as this notice is preserved. + +m4_define([_LT_COPYING], [dnl +# Copyright (C) 2014 Free Software Foundation, Inc. +# This is free software; see the source for copying conditions. There is NO +# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + +# GNU Libtool 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 2 of of the License, or +# (at your option) any later version. +# +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program or library that is built +# using GNU Libtool, you may include this file under the same +# distribution terms that you use for the rest of that program. +# +# GNU Libtool 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 this program. If not, see . +]) + +# serial 58 LT_INIT + + +# LT_PREREQ(VERSION) +# ------------------ +# Complain and exit if this libtool version is less that VERSION. +m4_defun([LT_PREREQ], +[m4_if(m4_version_compare(m4_defn([LT_PACKAGE_VERSION]), [$1]), -1, + [m4_default([$3], + [m4_fatal([Libtool version $1 or higher is required], + 63)])], + [$2])]) + + +# _LT_CHECK_BUILDDIR +# ------------------ +# Complain if the absolute build directory name contains unusual characters +m4_defun([_LT_CHECK_BUILDDIR], +[case `pwd` in + *\ * | *\ *) + AC_MSG_WARN([Libtool does not cope well with whitespace in `pwd`]) ;; +esac +]) + + +# LT_INIT([OPTIONS]) +# ------------------ +AC_DEFUN([LT_INIT], +[AC_PREREQ([2.62])dnl We use AC_PATH_PROGS_FEATURE_CHECK +AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl +AC_BEFORE([$0], [LT_LANG])dnl +AC_BEFORE([$0], [LT_OUTPUT])dnl +AC_BEFORE([$0], [LTDL_INIT])dnl +m4_require([_LT_CHECK_BUILDDIR])dnl + +dnl Autoconf doesn't catch unexpanded LT_ macros by default: +m4_pattern_forbid([^_?LT_[A-Z_]+$])dnl +m4_pattern_allow([^(_LT_EOF|LT_DLGLOBAL|LT_DLLAZY_OR_NOW|LT_MULTI_MODULE)$])dnl +dnl aclocal doesn't pull ltoptions.m4, ltsugar.m4, or ltversion.m4 +dnl unless we require an AC_DEFUNed macro: +AC_REQUIRE([LTOPTIONS_VERSION])dnl +AC_REQUIRE([LTSUGAR_VERSION])dnl +AC_REQUIRE([LTVERSION_VERSION])dnl +AC_REQUIRE([LTOBSOLETE_VERSION])dnl +m4_require([_LT_PROG_LTMAIN])dnl + +_LT_SHELL_INIT([SHELL=${CONFIG_SHELL-/bin/sh}]) + +dnl Parse OPTIONS +_LT_SET_OPTIONS([$0], [$1]) + +# This can be used to rebuild libtool when needed +LIBTOOL_DEPS=$ltmain + +# Always use our own libtool. +LIBTOOL='$(SHELL) $(top_builddir)/libtool' +AC_SUBST(LIBTOOL)dnl + +_LT_SETUP + +# Only expand once: +m4_define([LT_INIT]) +])# LT_INIT + +# Old names: +AU_ALIAS([AC_PROG_LIBTOOL], [LT_INIT]) +AU_ALIAS([AM_PROG_LIBTOOL], [LT_INIT]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_PROG_LIBTOOL], []) +dnl AC_DEFUN([AM_PROG_LIBTOOL], []) + + +# _LT_PREPARE_CC_BASENAME +# ----------------------- +m4_defun([_LT_PREPARE_CC_BASENAME], [ +# Calculate cc_basename. Skip known compiler wrappers and cross-prefix. +func_cc_basename () +{ + for cc_temp in @S|@*""; do + case $cc_temp in + compile | *[[\\/]]compile | ccache | *[[\\/]]ccache ) ;; + distcc | *[[\\/]]distcc | purify | *[[\\/]]purify ) ;; + \-*) ;; + *) break;; + esac + done + func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` +} +])# _LT_PREPARE_CC_BASENAME + + +# _LT_CC_BASENAME(CC) +# ------------------- +# It would be clearer to call AC_REQUIREs from _LT_PREPARE_CC_BASENAME, +# but that macro is also expanded into generated libtool script, which +# arranges for $SED and $ECHO to be set by different means. +m4_defun([_LT_CC_BASENAME], +[m4_require([_LT_PREPARE_CC_BASENAME])dnl +AC_REQUIRE([_LT_DECL_SED])dnl +AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])dnl +func_cc_basename $1 +cc_basename=$func_cc_basename_result +]) + + +# _LT_FILEUTILS_DEFAULTS +# ---------------------- +# It is okay to use these file commands and assume they have been set +# sensibly after 'm4_require([_LT_FILEUTILS_DEFAULTS])'. +m4_defun([_LT_FILEUTILS_DEFAULTS], +[: ${CP="cp -f"} +: ${MV="mv -f"} +: ${RM="rm -f"} +])# _LT_FILEUTILS_DEFAULTS + + +# _LT_SETUP +# --------- +m4_defun([_LT_SETUP], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +AC_REQUIRE([AC_CANONICAL_BUILD])dnl +AC_REQUIRE([_LT_PREPARE_SED_QUOTE_VARS])dnl +AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])dnl + +_LT_DECL([], [PATH_SEPARATOR], [1], [The PATH separator for the build system])dnl +dnl +_LT_DECL([], [host_alias], [0], [The host system])dnl +_LT_DECL([], [host], [0])dnl +_LT_DECL([], [host_os], [0])dnl +dnl +_LT_DECL([], [build_alias], [0], [The build system])dnl +_LT_DECL([], [build], [0])dnl +_LT_DECL([], [build_os], [0])dnl +dnl +AC_REQUIRE([AC_PROG_CC])dnl +AC_REQUIRE([LT_PATH_LD])dnl +AC_REQUIRE([LT_PATH_NM])dnl +dnl +AC_REQUIRE([AC_PROG_LN_S])dnl +test -z "$LN_S" && LN_S="ln -s" +_LT_DECL([], [LN_S], [1], [Whether we need soft or hard links])dnl +dnl +AC_REQUIRE([LT_CMD_MAX_LEN])dnl +_LT_DECL([objext], [ac_objext], [0], [Object file suffix (normally "o")])dnl +_LT_DECL([], [exeext], [0], [Executable file suffix (normally "")])dnl +dnl +m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_CHECK_SHELL_FEATURES])dnl +m4_require([_LT_PATH_CONVERSION_FUNCTIONS])dnl +m4_require([_LT_CMD_RELOAD])dnl +m4_require([_LT_CHECK_MAGIC_METHOD])dnl +m4_require([_LT_CHECK_SHAREDLIB_FROM_LINKLIB])dnl +m4_require([_LT_CMD_OLD_ARCHIVE])dnl +m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl +m4_require([_LT_WITH_SYSROOT])dnl +m4_require([_LT_CMD_TRUNCATE])dnl + +_LT_CONFIG_LIBTOOL_INIT([ +# See if we are running on zsh, and set the options that allow our +# commands through without removal of \ escapes INIT. +if test -n "\${ZSH_VERSION+set}"; then + setopt NO_GLOB_SUBST +fi +]) +if test -n "${ZSH_VERSION+set}"; then + setopt NO_GLOB_SUBST +fi + +_LT_CHECK_OBJDIR + +m4_require([_LT_TAG_COMPILER])dnl + +case $host_os in +aix3*) + # AIX sometimes has problems with the GCC collect2 program. For some + # reason, if we set the COLLECT_NAMES environment variable, the problems + # vanish in a puff of smoke. + if test set != "${COLLECT_NAMES+set}"; then + COLLECT_NAMES= + export COLLECT_NAMES + fi + ;; +esac + +# Global variables: +ofile=libtool +can_build_shared=yes + +# All known linkers require a '.a' archive for static linking (except MSVC and +# ICC, which need '.lib'). +libext=a + +with_gnu_ld=$lt_cv_prog_gnu_ld + +old_CC=$CC +old_CFLAGS=$CFLAGS + +# Set sane defaults for various variables +test -z "$CC" && CC=cc +test -z "$LTCC" && LTCC=$CC +test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS +test -z "$LD" && LD=ld +test -z "$ac_objext" && ac_objext=o + +_LT_CC_BASENAME([$compiler]) + +# Only perform the check for file, if the check method requires it +test -z "$MAGIC_CMD" && MAGIC_CMD=file +case $deplibs_check_method in +file_magic*) + if test "$file_magic_cmd" = '$MAGIC_CMD'; then + _LT_PATH_MAGIC + fi + ;; +esac + +# Use C for the default configuration in the libtool script +LT_SUPPORTED_TAG([CC]) +_LT_LANG_C_CONFIG +_LT_LANG_DEFAULT_CONFIG +_LT_CONFIG_COMMANDS +])# _LT_SETUP + + +# _LT_PREPARE_SED_QUOTE_VARS +# -------------------------- +# Define a few sed substitution that help us do robust quoting. +m4_defun([_LT_PREPARE_SED_QUOTE_VARS], +[# Backslashify metacharacters that are still active within +# double-quoted strings. +sed_quote_subst='s/\([["`$\\]]\)/\\\1/g' + +# Same as above, but do not quote variable references. +double_quote_subst='s/\([["`\\]]\)/\\\1/g' + +# Sed substitution to delay expansion of an escaped shell variable in a +# double_quote_subst'ed string. +delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' + +# Sed substitution to delay expansion of an escaped single quote. +delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' + +# Sed substitution to avoid accidental globbing in evaled expressions +no_glob_subst='s/\*/\\\*/g' +]) + +# _LT_PROG_LTMAIN +# --------------- +# Note that this code is called both from 'configure', and 'config.status' +# now that we use AC_CONFIG_COMMANDS to generate libtool. Notably, +# 'config.status' has no value for ac_aux_dir unless we are using Automake, +# so we pass a copy along to make sure it has a sensible value anyway. +m4_defun([_LT_PROG_LTMAIN], +[m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([ltmain.sh])])dnl +_LT_CONFIG_LIBTOOL_INIT([ac_aux_dir='$ac_aux_dir']) +ltmain=$ac_aux_dir/ltmain.sh +])# _LT_PROG_LTMAIN + + + +# So that we can recreate a full libtool script including additional +# tags, we accumulate the chunks of code to send to AC_CONFIG_COMMANDS +# in macros and then make a single call at the end using the 'libtool' +# label. + + +# _LT_CONFIG_LIBTOOL_INIT([INIT-COMMANDS]) +# ---------------------------------------- +# Register INIT-COMMANDS to be passed to AC_CONFIG_COMMANDS later. +m4_define([_LT_CONFIG_LIBTOOL_INIT], +[m4_ifval([$1], + [m4_append([_LT_OUTPUT_LIBTOOL_INIT], + [$1 +])])]) + +# Initialize. +m4_define([_LT_OUTPUT_LIBTOOL_INIT]) + + +# _LT_CONFIG_LIBTOOL([COMMANDS]) +# ------------------------------ +# Register COMMANDS to be passed to AC_CONFIG_COMMANDS later. +m4_define([_LT_CONFIG_LIBTOOL], +[m4_ifval([$1], + [m4_append([_LT_OUTPUT_LIBTOOL_COMMANDS], + [$1 +])])]) + +# Initialize. +m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS]) + + +# _LT_CONFIG_SAVE_COMMANDS([COMMANDS], [INIT_COMMANDS]) +# ----------------------------------------------------- +m4_defun([_LT_CONFIG_SAVE_COMMANDS], +[_LT_CONFIG_LIBTOOL([$1]) +_LT_CONFIG_LIBTOOL_INIT([$2]) +]) + + +# _LT_FORMAT_COMMENT([COMMENT]) +# ----------------------------- +# Add leading comment marks to the start of each line, and a trailing +# full-stop to the whole comment if one is not present already. +m4_define([_LT_FORMAT_COMMENT], +[m4_ifval([$1], [ +m4_bpatsubst([m4_bpatsubst([$1], [^ *], [# ])], + [['`$\]], [\\\&])]m4_bmatch([$1], [[!?.]$], [], [.]) +)]) + + + + + +# _LT_DECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION], [IS-TAGGED?]) +# ------------------------------------------------------------------- +# CONFIGNAME is the name given to the value in the libtool script. +# VARNAME is the (base) name used in the configure script. +# VALUE may be 0, 1 or 2 for a computed quote escaped value based on +# VARNAME. Any other value will be used directly. +m4_define([_LT_DECL], +[lt_if_append_uniq([lt_decl_varnames], [$2], [, ], + [lt_dict_add_subkey([lt_decl_dict], [$2], [libtool_name], + [m4_ifval([$1], [$1], [$2])]) + lt_dict_add_subkey([lt_decl_dict], [$2], [value], [$3]) + m4_ifval([$4], + [lt_dict_add_subkey([lt_decl_dict], [$2], [description], [$4])]) + lt_dict_add_subkey([lt_decl_dict], [$2], + [tagged?], [m4_ifval([$5], [yes], [no])])]) +]) + + +# _LT_TAGDECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION]) +# -------------------------------------------------------- +m4_define([_LT_TAGDECL], [_LT_DECL([$1], [$2], [$3], [$4], [yes])]) + + +# lt_decl_tag_varnames([SEPARATOR], [VARNAME1...]) +# ------------------------------------------------ +m4_define([lt_decl_tag_varnames], +[_lt_decl_filter([tagged?], [yes], $@)]) + + +# _lt_decl_filter(SUBKEY, VALUE, [SEPARATOR], [VARNAME1..]) +# --------------------------------------------------------- +m4_define([_lt_decl_filter], +[m4_case([$#], + [0], [m4_fatal([$0: too few arguments: $#])], + [1], [m4_fatal([$0: too few arguments: $#: $1])], + [2], [lt_dict_filter([lt_decl_dict], [$1], [$2], [], lt_decl_varnames)], + [3], [lt_dict_filter([lt_decl_dict], [$1], [$2], [$3], lt_decl_varnames)], + [lt_dict_filter([lt_decl_dict], $@)])[]dnl +]) + + +# lt_decl_quote_varnames([SEPARATOR], [VARNAME1...]) +# -------------------------------------------------- +m4_define([lt_decl_quote_varnames], +[_lt_decl_filter([value], [1], $@)]) + + +# lt_decl_dquote_varnames([SEPARATOR], [VARNAME1...]) +# --------------------------------------------------- +m4_define([lt_decl_dquote_varnames], +[_lt_decl_filter([value], [2], $@)]) + + +# lt_decl_varnames_tagged([SEPARATOR], [VARNAME1...]) +# --------------------------------------------------- +m4_define([lt_decl_varnames_tagged], +[m4_assert([$# <= 2])dnl +_$0(m4_quote(m4_default([$1], [[, ]])), + m4_ifval([$2], [[$2]], [m4_dquote(lt_decl_tag_varnames)]), + m4_split(m4_normalize(m4_quote(_LT_TAGS)), [ ]))]) +m4_define([_lt_decl_varnames_tagged], +[m4_ifval([$3], [lt_combine([$1], [$2], [_], $3)])]) + + +# lt_decl_all_varnames([SEPARATOR], [VARNAME1...]) +# ------------------------------------------------ +m4_define([lt_decl_all_varnames], +[_$0(m4_quote(m4_default([$1], [[, ]])), + m4_if([$2], [], + m4_quote(lt_decl_varnames), + m4_quote(m4_shift($@))))[]dnl +]) +m4_define([_lt_decl_all_varnames], +[lt_join($@, lt_decl_varnames_tagged([$1], + lt_decl_tag_varnames([[, ]], m4_shift($@))))dnl +]) + + +# _LT_CONFIG_STATUS_DECLARE([VARNAME]) +# ------------------------------------ +# Quote a variable value, and forward it to 'config.status' so that its +# declaration there will have the same value as in 'configure'. VARNAME +# must have a single quote delimited value for this to work. +m4_define([_LT_CONFIG_STATUS_DECLARE], +[$1='`$ECHO "$][$1" | $SED "$delay_single_quote_subst"`']) + + +# _LT_CONFIG_STATUS_DECLARATIONS +# ------------------------------ +# We delimit libtool config variables with single quotes, so when +# we write them to config.status, we have to be sure to quote all +# embedded single quotes properly. In configure, this macro expands +# each variable declared with _LT_DECL (and _LT_TAGDECL) into: +# +# ='`$ECHO "$" | $SED "$delay_single_quote_subst"`' +m4_defun([_LT_CONFIG_STATUS_DECLARATIONS], +[m4_foreach([_lt_var], m4_quote(lt_decl_all_varnames), + [m4_n([_LT_CONFIG_STATUS_DECLARE(_lt_var)])])]) + + +# _LT_LIBTOOL_TAGS +# ---------------- +# Output comment and list of tags supported by the script +m4_defun([_LT_LIBTOOL_TAGS], +[_LT_FORMAT_COMMENT([The names of the tagged configurations supported by this script])dnl +available_tags='_LT_TAGS'dnl +]) + + +# _LT_LIBTOOL_DECLARE(VARNAME, [TAG]) +# ----------------------------------- +# Extract the dictionary values for VARNAME (optionally with TAG) and +# expand to a commented shell variable setting: +# +# # Some comment about what VAR is for. +# visible_name=$lt_internal_name +m4_define([_LT_LIBTOOL_DECLARE], +[_LT_FORMAT_COMMENT(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], + [description])))[]dnl +m4_pushdef([_libtool_name], + m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [libtool_name])))[]dnl +m4_case(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [value])), + [0], [_libtool_name=[$]$1], + [1], [_libtool_name=$lt_[]$1], + [2], [_libtool_name=$lt_[]$1], + [_libtool_name=lt_dict_fetch([lt_decl_dict], [$1], [value])])[]dnl +m4_ifval([$2], [_$2])[]m4_popdef([_libtool_name])[]dnl +]) + + +# _LT_LIBTOOL_CONFIG_VARS +# ----------------------- +# Produce commented declarations of non-tagged libtool config variables +# suitable for insertion in the LIBTOOL CONFIG section of the 'libtool' +# script. Tagged libtool config variables (even for the LIBTOOL CONFIG +# section) are produced by _LT_LIBTOOL_TAG_VARS. +m4_defun([_LT_LIBTOOL_CONFIG_VARS], +[m4_foreach([_lt_var], + m4_quote(_lt_decl_filter([tagged?], [no], [], lt_decl_varnames)), + [m4_n([_LT_LIBTOOL_DECLARE(_lt_var)])])]) + + +# _LT_LIBTOOL_TAG_VARS(TAG) +# ------------------------- +m4_define([_LT_LIBTOOL_TAG_VARS], +[m4_foreach([_lt_var], m4_quote(lt_decl_tag_varnames), + [m4_n([_LT_LIBTOOL_DECLARE(_lt_var, [$1])])])]) + + +# _LT_TAGVAR(VARNAME, [TAGNAME]) +# ------------------------------ +m4_define([_LT_TAGVAR], [m4_ifval([$2], [$1_$2], [$1])]) + + +# _LT_CONFIG_COMMANDS +# ------------------- +# Send accumulated output to $CONFIG_STATUS. Thanks to the lists of +# variables for single and double quote escaping we saved from calls +# to _LT_DECL, we can put quote escaped variables declarations +# into 'config.status', and then the shell code to quote escape them in +# for loops in 'config.status'. Finally, any additional code accumulated +# from calls to _LT_CONFIG_LIBTOOL_INIT is expanded. +m4_defun([_LT_CONFIG_COMMANDS], +[AC_PROVIDE_IFELSE([LT_OUTPUT], + dnl If the libtool generation code has been placed in $CONFIG_LT, + dnl instead of duplicating it all over again into config.status, + dnl then we will have config.status run $CONFIG_LT later, so it + dnl needs to know what name is stored there: + [AC_CONFIG_COMMANDS([libtool], + [$SHELL $CONFIG_LT || AS_EXIT(1)], [CONFIG_LT='$CONFIG_LT'])], + dnl If the libtool generation code is destined for config.status, + dnl expand the accumulated commands and init code now: + [AC_CONFIG_COMMANDS([libtool], + [_LT_OUTPUT_LIBTOOL_COMMANDS], [_LT_OUTPUT_LIBTOOL_COMMANDS_INIT])]) +])#_LT_CONFIG_COMMANDS + + +# Initialize. +m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS_INIT], +[ + +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + +sed_quote_subst='$sed_quote_subst' +double_quote_subst='$double_quote_subst' +delay_variable_subst='$delay_variable_subst' +_LT_CONFIG_STATUS_DECLARATIONS +LTCC='$LTCC' +LTCFLAGS='$LTCFLAGS' +compiler='$compiler_DEFAULT' + +# A function that is used when there is no print builtin or printf. +func_fallback_echo () +{ + eval 'cat <<_LTECHO_EOF +\$[]1 +_LTECHO_EOF' +} + +# Quote evaled strings. +for var in lt_decl_all_varnames([[ \ +]], lt_decl_quote_varnames); do + case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in + *[[\\\\\\\`\\"\\\$]]*) + eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes + ;; + *) + eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" + ;; + esac +done + +# Double-quote double-evaled strings. +for var in lt_decl_all_varnames([[ \ +]], lt_decl_dquote_varnames); do + case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in + *[[\\\\\\\`\\"\\\$]]*) + eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes + ;; + *) + eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" + ;; + esac +done + +_LT_OUTPUT_LIBTOOL_INIT +]) + +# _LT_GENERATED_FILE_INIT(FILE, [COMMENT]) +# ------------------------------------ +# Generate a child script FILE with all initialization necessary to +# reuse the environment learned by the parent script, and make the +# file executable. If COMMENT is supplied, it is inserted after the +# '#!' sequence but before initialization text begins. After this +# macro, additional text can be appended to FILE to form the body of +# the child script. The macro ends with non-zero status if the +# file could not be fully written (such as if the disk is full). +m4_ifdef([AS_INIT_GENERATED], +[m4_defun([_LT_GENERATED_FILE_INIT],[AS_INIT_GENERATED($@)])], +[m4_defun([_LT_GENERATED_FILE_INIT], +[m4_require([AS_PREPARE])]dnl +[m4_pushdef([AS_MESSAGE_LOG_FD])]dnl +[lt_write_fail=0 +cat >$1 <<_ASEOF || lt_write_fail=1 +#! $SHELL +# Generated by $as_me. +$2 +SHELL=\${CONFIG_SHELL-$SHELL} +export SHELL +_ASEOF +cat >>$1 <<\_ASEOF || lt_write_fail=1 +AS_SHELL_SANITIZE +_AS_PREPARE +exec AS_MESSAGE_FD>&1 +_ASEOF +test 0 = "$lt_write_fail" && chmod +x $1[]dnl +m4_popdef([AS_MESSAGE_LOG_FD])])])# _LT_GENERATED_FILE_INIT + +# LT_OUTPUT +# --------- +# This macro allows early generation of the libtool script (before +# AC_OUTPUT is called), incase it is used in configure for compilation +# tests. +AC_DEFUN([LT_OUTPUT], +[: ${CONFIG_LT=./config.lt} +AC_MSG_NOTICE([creating $CONFIG_LT]) +_LT_GENERATED_FILE_INIT(["$CONFIG_LT"], +[# Run this file to recreate a libtool stub with the current configuration.]) + +cat >>"$CONFIG_LT" <<\_LTEOF +lt_cl_silent=false +exec AS_MESSAGE_LOG_FD>>config.log +{ + echo + AS_BOX([Running $as_me.]) +} >&AS_MESSAGE_LOG_FD + +lt_cl_help="\ +'$as_me' creates a local libtool stub from the current configuration, +for use in further configure time tests before the real libtool is +generated. + +Usage: $[0] [[OPTIONS]] + + -h, --help print this help, then exit + -V, --version print version number, then exit + -q, --quiet do not print progress messages + -d, --debug don't remove temporary files + +Report bugs to ." + +lt_cl_version="\ +m4_ifset([AC_PACKAGE_NAME], [AC_PACKAGE_NAME ])config.lt[]dnl +m4_ifset([AC_PACKAGE_VERSION], [ AC_PACKAGE_VERSION]) +configured by $[0], generated by m4_PACKAGE_STRING. + +Copyright (C) 2011 Free Software Foundation, Inc. +This config.lt script is free software; the Free Software Foundation +gives unlimited permision to copy, distribute and modify it." + +while test 0 != $[#] +do + case $[1] in + --version | --v* | -V ) + echo "$lt_cl_version"; exit 0 ;; + --help | --h* | -h ) + echo "$lt_cl_help"; exit 0 ;; + --debug | --d* | -d ) + debug=: ;; + --quiet | --q* | --silent | --s* | -q ) + lt_cl_silent=: ;; + + -*) AC_MSG_ERROR([unrecognized option: $[1] +Try '$[0] --help' for more information.]) ;; + + *) AC_MSG_ERROR([unrecognized argument: $[1] +Try '$[0] --help' for more information.]) ;; + esac + shift +done + +if $lt_cl_silent; then + exec AS_MESSAGE_FD>/dev/null +fi +_LTEOF + +cat >>"$CONFIG_LT" <<_LTEOF +_LT_OUTPUT_LIBTOOL_COMMANDS_INIT +_LTEOF + +cat >>"$CONFIG_LT" <<\_LTEOF +AC_MSG_NOTICE([creating $ofile]) +_LT_OUTPUT_LIBTOOL_COMMANDS +AS_EXIT(0) +_LTEOF +chmod +x "$CONFIG_LT" + +# configure is writing to config.log, but config.lt does its own redirection, +# appending to config.log, which fails on DOS, as config.log is still kept +# open by configure. Here we exec the FD to /dev/null, effectively closing +# config.log, so it can be properly (re)opened and appended to by config.lt. +lt_cl_success=: +test yes = "$silent" && + lt_config_lt_args="$lt_config_lt_args --quiet" +exec AS_MESSAGE_LOG_FD>/dev/null +$SHELL "$CONFIG_LT" $lt_config_lt_args || lt_cl_success=false +exec AS_MESSAGE_LOG_FD>>config.log +$lt_cl_success || AS_EXIT(1) +])# LT_OUTPUT + + +# _LT_CONFIG(TAG) +# --------------- +# If TAG is the built-in tag, create an initial libtool script with a +# default configuration from the untagged config vars. Otherwise add code +# to config.status for appending the configuration named by TAG from the +# matching tagged config vars. +m4_defun([_LT_CONFIG], +[m4_require([_LT_FILEUTILS_DEFAULTS])dnl +_LT_CONFIG_SAVE_COMMANDS([ + m4_define([_LT_TAG], m4_if([$1], [], [C], [$1]))dnl + m4_if(_LT_TAG, [C], [ + # See if we are running on zsh, and set the options that allow our + # commands through without removal of \ escapes. + if test -n "${ZSH_VERSION+set}"; then + setopt NO_GLOB_SUBST + fi + + cfgfile=${ofile}T + trap "$RM \"$cfgfile\"; exit 1" 1 2 15 + $RM "$cfgfile" + + cat <<_LT_EOF >> "$cfgfile" +#! $SHELL +# Generated automatically by $as_me ($PACKAGE) $VERSION +# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: +# NOTE: Changes made to this file will be lost: look at ltmain.sh. + +# Provide generalized library-building support services. +# Written by Gordon Matzigkeit, 1996 + +_LT_COPYING +_LT_LIBTOOL_TAGS + +# Configured defaults for sys_lib_dlsearch_path munging. +: \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"} + +# ### BEGIN LIBTOOL CONFIG +_LT_LIBTOOL_CONFIG_VARS +_LT_LIBTOOL_TAG_VARS +# ### END LIBTOOL CONFIG + +_LT_EOF + + cat <<'_LT_EOF' >> "$cfgfile" + +# ### BEGIN FUNCTIONS SHARED WITH CONFIGURE + +_LT_PREPARE_MUNGE_PATH_LIST +_LT_PREPARE_CC_BASENAME + +# ### END FUNCTIONS SHARED WITH CONFIGURE + +_LT_EOF + + case $host_os in + aix3*) + cat <<\_LT_EOF >> "$cfgfile" +# AIX sometimes has problems with the GCC collect2 program. For some +# reason, if we set the COLLECT_NAMES environment variable, the problems +# vanish in a puff of smoke. +if test set != "${COLLECT_NAMES+set}"; then + COLLECT_NAMES= + export COLLECT_NAMES +fi +_LT_EOF + ;; + esac + + _LT_PROG_LTMAIN + + # We use sed instead of cat because bash on DJGPP gets confused if + # if finds mixed CR/LF and LF-only lines. Since sed operates in + # text mode, it properly converts lines to CR/LF. This bash problem + # is reportedly fixed, but why not run on old versions too? + sed '$q' "$ltmain" >> "$cfgfile" \ + || (rm -f "$cfgfile"; exit 1) + + mv -f "$cfgfile" "$ofile" || + (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") + chmod +x "$ofile" +], +[cat <<_LT_EOF >> "$ofile" + +dnl Unfortunately we have to use $1 here, since _LT_TAG is not expanded +dnl in a comment (ie after a #). +# ### BEGIN LIBTOOL TAG CONFIG: $1 +_LT_LIBTOOL_TAG_VARS(_LT_TAG) +# ### END LIBTOOL TAG CONFIG: $1 +_LT_EOF +])dnl /m4_if +], +[m4_if([$1], [], [ + PACKAGE='$PACKAGE' + VERSION='$VERSION' + RM='$RM' + ofile='$ofile'], []) +])dnl /_LT_CONFIG_SAVE_COMMANDS +])# _LT_CONFIG + + +# LT_SUPPORTED_TAG(TAG) +# --------------------- +# Trace this macro to discover what tags are supported by the libtool +# --tag option, using: +# autoconf --trace 'LT_SUPPORTED_TAG:$1' +AC_DEFUN([LT_SUPPORTED_TAG], []) + + +# C support is built-in for now +m4_define([_LT_LANG_C_enabled], []) +m4_define([_LT_TAGS], []) + + +# LT_LANG(LANG) +# ------------- +# Enable libtool support for the given language if not already enabled. +AC_DEFUN([LT_LANG], +[AC_BEFORE([$0], [LT_OUTPUT])dnl +m4_case([$1], + [C], [_LT_LANG(C)], + [C++], [_LT_LANG(CXX)], + [Go], [_LT_LANG(GO)], + [Java], [_LT_LANG(GCJ)], + [Fortran 77], [_LT_LANG(F77)], + [Fortran], [_LT_LANG(FC)], + [Windows Resource], [_LT_LANG(RC)], + [m4_ifdef([_LT_LANG_]$1[_CONFIG], + [_LT_LANG($1)], + [m4_fatal([$0: unsupported language: "$1"])])])dnl +])# LT_LANG + + +# _LT_LANG(LANGNAME) +# ------------------ +m4_defun([_LT_LANG], +[m4_ifdef([_LT_LANG_]$1[_enabled], [], + [LT_SUPPORTED_TAG([$1])dnl + m4_append([_LT_TAGS], [$1 ])dnl + m4_define([_LT_LANG_]$1[_enabled], [])dnl + _LT_LANG_$1_CONFIG($1)])dnl +])# _LT_LANG + + +m4_ifndef([AC_PROG_GO], [ +# NOTE: This macro has been submitted for inclusion into # +# GNU Autoconf as AC_PROG_GO. When it is available in # +# a released version of Autoconf we should remove this # +# macro and use it instead. # +m4_defun([AC_PROG_GO], +[AC_LANG_PUSH(Go)dnl +AC_ARG_VAR([GOC], [Go compiler command])dnl +AC_ARG_VAR([GOFLAGS], [Go compiler flags])dnl +_AC_ARG_VAR_LDFLAGS()dnl +AC_CHECK_TOOL(GOC, gccgo) +if test -z "$GOC"; then + if test -n "$ac_tool_prefix"; then + AC_CHECK_PROG(GOC, [${ac_tool_prefix}gccgo], [${ac_tool_prefix}gccgo]) + fi +fi +if test -z "$GOC"; then + AC_CHECK_PROG(GOC, gccgo, gccgo, false) +fi +])#m4_defun +])#m4_ifndef + + +# _LT_LANG_DEFAULT_CONFIG +# ----------------------- +m4_defun([_LT_LANG_DEFAULT_CONFIG], +[AC_PROVIDE_IFELSE([AC_PROG_CXX], + [LT_LANG(CXX)], + [m4_define([AC_PROG_CXX], defn([AC_PROG_CXX])[LT_LANG(CXX)])]) + +AC_PROVIDE_IFELSE([AC_PROG_F77], + [LT_LANG(F77)], + [m4_define([AC_PROG_F77], defn([AC_PROG_F77])[LT_LANG(F77)])]) + +AC_PROVIDE_IFELSE([AC_PROG_FC], + [LT_LANG(FC)], + [m4_define([AC_PROG_FC], defn([AC_PROG_FC])[LT_LANG(FC)])]) + +dnl The call to [A][M_PROG_GCJ] is quoted like that to stop aclocal +dnl pulling things in needlessly. +AC_PROVIDE_IFELSE([AC_PROG_GCJ], + [LT_LANG(GCJ)], + [AC_PROVIDE_IFELSE([A][M_PROG_GCJ], + [LT_LANG(GCJ)], + [AC_PROVIDE_IFELSE([LT_PROG_GCJ], + [LT_LANG(GCJ)], + [m4_ifdef([AC_PROG_GCJ], + [m4_define([AC_PROG_GCJ], defn([AC_PROG_GCJ])[LT_LANG(GCJ)])]) + m4_ifdef([A][M_PROG_GCJ], + [m4_define([A][M_PROG_GCJ], defn([A][M_PROG_GCJ])[LT_LANG(GCJ)])]) + m4_ifdef([LT_PROG_GCJ], + [m4_define([LT_PROG_GCJ], defn([LT_PROG_GCJ])[LT_LANG(GCJ)])])])])]) + +AC_PROVIDE_IFELSE([AC_PROG_GO], + [LT_LANG(GO)], + [m4_define([AC_PROG_GO], defn([AC_PROG_GO])[LT_LANG(GO)])]) + +AC_PROVIDE_IFELSE([LT_PROG_RC], + [LT_LANG(RC)], + [m4_define([LT_PROG_RC], defn([LT_PROG_RC])[LT_LANG(RC)])]) +])# _LT_LANG_DEFAULT_CONFIG + +# Obsolete macros: +AU_DEFUN([AC_LIBTOOL_CXX], [LT_LANG(C++)]) +AU_DEFUN([AC_LIBTOOL_F77], [LT_LANG(Fortran 77)]) +AU_DEFUN([AC_LIBTOOL_FC], [LT_LANG(Fortran)]) +AU_DEFUN([AC_LIBTOOL_GCJ], [LT_LANG(Java)]) +AU_DEFUN([AC_LIBTOOL_RC], [LT_LANG(Windows Resource)]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_CXX], []) +dnl AC_DEFUN([AC_LIBTOOL_F77], []) +dnl AC_DEFUN([AC_LIBTOOL_FC], []) +dnl AC_DEFUN([AC_LIBTOOL_GCJ], []) +dnl AC_DEFUN([AC_LIBTOOL_RC], []) + + +# _LT_TAG_COMPILER +# ---------------- +m4_defun([_LT_TAG_COMPILER], +[AC_REQUIRE([AC_PROG_CC])dnl + +_LT_DECL([LTCC], [CC], [1], [A C compiler])dnl +_LT_DECL([LTCFLAGS], [CFLAGS], [1], [LTCC compiler flags])dnl +_LT_TAGDECL([CC], [compiler], [1], [A language specific compiler])dnl +_LT_TAGDECL([with_gcc], [GCC], [0], [Is the compiler the GNU compiler?])dnl + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# If no C compiler flags were specified, use CFLAGS. +LTCFLAGS=${LTCFLAGS-"$CFLAGS"} + +# Allow CC to be a program name with arguments. +compiler=$CC +])# _LT_TAG_COMPILER + + +# _LT_COMPILER_BOILERPLATE +# ------------------------ +# Check for compiler boilerplate output or warnings with +# the simple compiler test code. +m4_defun([_LT_COMPILER_BOILERPLATE], +[m4_require([_LT_DECL_SED])dnl +ac_outfile=conftest.$ac_objext +echo "$lt_simple_compile_test_code" >conftest.$ac_ext +eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err +_lt_compiler_boilerplate=`cat conftest.err` +$RM conftest* +])# _LT_COMPILER_BOILERPLATE + + +# _LT_LINKER_BOILERPLATE +# ---------------------- +# Check for linker boilerplate output or warnings with +# the simple link test code. +m4_defun([_LT_LINKER_BOILERPLATE], +[m4_require([_LT_DECL_SED])dnl +ac_outfile=conftest.$ac_objext +echo "$lt_simple_link_test_code" >conftest.$ac_ext +eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err +_lt_linker_boilerplate=`cat conftest.err` +$RM -r conftest* +])# _LT_LINKER_BOILERPLATE + +# _LT_REQUIRED_DARWIN_CHECKS +# ------------------------- +m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[ + case $host_os in + rhapsody* | darwin*) + AC_CHECK_TOOL([DSYMUTIL], [dsymutil], [:]) + AC_CHECK_TOOL([NMEDIT], [nmedit], [:]) + AC_CHECK_TOOL([LIPO], [lipo], [:]) + AC_CHECK_TOOL([OTOOL], [otool], [:]) + AC_CHECK_TOOL([OTOOL64], [otool64], [:]) + _LT_DECL([], [DSYMUTIL], [1], + [Tool to manipulate archived DWARF debug symbol files on Mac OS X]) + _LT_DECL([], [NMEDIT], [1], + [Tool to change global to local symbols on Mac OS X]) + _LT_DECL([], [LIPO], [1], + [Tool to manipulate fat objects and archives on Mac OS X]) + _LT_DECL([], [OTOOL], [1], + [ldd/readelf like tool for Mach-O binaries on Mac OS X]) + _LT_DECL([], [OTOOL64], [1], + [ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4]) + + AC_CACHE_CHECK([for -single_module linker flag],[lt_cv_apple_cc_single_mod], + [lt_cv_apple_cc_single_mod=no + if test -z "$LT_MULTI_MODULE"; then + # By default we will add the -single_module flag. You can override + # by either setting the environment variable LT_MULTI_MODULE + # non-empty at configure time, or by adding -multi_module to the + # link flags. + rm -rf libconftest.dylib* + echo "int foo(void){return 1;}" > conftest.c + echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ +-dynamiclib -Wl,-single_module conftest.c" >&AS_MESSAGE_LOG_FD + $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ + -dynamiclib -Wl,-single_module conftest.c 2>conftest.err + _lt_result=$? + # If there is a non-empty error log, and "single_module" + # appears in it, assume the flag caused a linker warning + if test -s conftest.err && $GREP single_module conftest.err; then + cat conftest.err >&AS_MESSAGE_LOG_FD + # Otherwise, if the output was created with a 0 exit code from + # the compiler, it worked. + elif test -f libconftest.dylib && test 0 = "$_lt_result"; then + lt_cv_apple_cc_single_mod=yes + else + cat conftest.err >&AS_MESSAGE_LOG_FD + fi + rm -rf libconftest.dylib* + rm -f conftest.* + fi]) + + AC_CACHE_CHECK([for -exported_symbols_list linker flag], + [lt_cv_ld_exported_symbols_list], + [lt_cv_ld_exported_symbols_list=no + save_LDFLAGS=$LDFLAGS + echo "_main" > conftest.sym + LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" + AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], + [lt_cv_ld_exported_symbols_list=yes], + [lt_cv_ld_exported_symbols_list=no]) + LDFLAGS=$save_LDFLAGS + ]) + + AC_CACHE_CHECK([for -force_load linker flag],[lt_cv_ld_force_load], + [lt_cv_ld_force_load=no + cat > conftest.c << _LT_EOF +int forced_loaded() { return 2;} +_LT_EOF + echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&AS_MESSAGE_LOG_FD + $LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&AS_MESSAGE_LOG_FD + echo "$AR $AR_FLAGS libconftest.a conftest.o" >&AS_MESSAGE_LOG_FD + $AR $AR_FLAGS libconftest.a conftest.o 2>&AS_MESSAGE_LOG_FD + echo "$RANLIB libconftest.a" >&AS_MESSAGE_LOG_FD + $RANLIB libconftest.a 2>&AS_MESSAGE_LOG_FD + cat > conftest.c << _LT_EOF +int main() { return 0;} +_LT_EOF + echo "$LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a" >&AS_MESSAGE_LOG_FD + $LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a 2>conftest.err + _lt_result=$? + if test -s conftest.err && $GREP force_load conftest.err; then + cat conftest.err >&AS_MESSAGE_LOG_FD + elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then + lt_cv_ld_force_load=yes + else + cat conftest.err >&AS_MESSAGE_LOG_FD + fi + rm -f conftest.err libconftest.a conftest conftest.c + rm -rf conftest.dSYM + ]) + case $host_os in + rhapsody* | darwin1.[[012]]) + _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;; + darwin1.*) + _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; + darwin*) # darwin 5.x on + # if running on 10.5 or later, the deployment target defaults + # to the OS version, if on x86, and 10.4, the deployment + # target defaults to 10.4. Don't you love it? + case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in + 10.0,*86*-darwin8*|10.0,*-darwin[[91]]*) + _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; + 10.[[012]][[,.]]*) + _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; + 10.*) + _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; + esac + ;; + esac + if test yes = "$lt_cv_apple_cc_single_mod"; then + _lt_dar_single_mod='$single_module' + fi + if test yes = "$lt_cv_ld_exported_symbols_list"; then + _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym' + else + _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib' + fi + if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then + _lt_dsymutil='~$DSYMUTIL $lib || :' + else + _lt_dsymutil= + fi + ;; + esac +]) + + +# _LT_DARWIN_LINKER_FEATURES([TAG]) +# --------------------------------- +# Checks for linker and compiler features on darwin +m4_defun([_LT_DARWIN_LINKER_FEATURES], +[ + m4_require([_LT_REQUIRED_DARWIN_CHECKS]) + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_automatic, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported + if test yes = "$lt_cv_ld_force_load"; then + _LT_TAGVAR(whole_archive_flag_spec, $1)='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' + m4_case([$1], [F77], [_LT_TAGVAR(compiler_needs_object, $1)=yes], + [FC], [_LT_TAGVAR(compiler_needs_object, $1)=yes]) + else + _LT_TAGVAR(whole_archive_flag_spec, $1)='' + fi + _LT_TAGVAR(link_all_deplibs, $1)=yes + _LT_TAGVAR(allow_undefined_flag, $1)=$_lt_dar_allow_undefined + case $cc_basename in + ifort*|nagfor*) _lt_dar_can_shared=yes ;; + *) _lt_dar_can_shared=$GCC ;; + esac + if test yes = "$_lt_dar_can_shared"; then + output_verbose_link_cmd=func_echo_all + _LT_TAGVAR(archive_cmds, $1)="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil" + _LT_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil" + _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil" + _LT_TAGVAR(module_expsym_cmds, $1)="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil" + m4_if([$1], [CXX], +[ if test yes != "$lt_cv_apple_cc_single_mod"; then + _LT_TAGVAR(archive_cmds, $1)="\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dsymutil" + _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dar_export_syms$_lt_dsymutil" + fi +],[]) + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi +]) + +# _LT_SYS_MODULE_PATH_AIX([TAGNAME]) +# ---------------------------------- +# Links a minimal program and checks the executable +# for the system default hardcoded library path. In most cases, +# this is /usr/lib:/lib, but when the MPI compilers are used +# the location of the communication and MPI libs are included too. +# If we don't find anything, use the default library path according +# to the aix ld manual. +# Store the results from the different compilers for each TAGNAME. +# Allow to override them for all tags through lt_cv_aix_libpath. +m4_defun([_LT_SYS_MODULE_PATH_AIX], +[m4_require([_LT_DECL_SED])dnl +if test set = "${lt_cv_aix_libpath+set}"; then + aix_libpath=$lt_cv_aix_libpath +else + AC_CACHE_VAL([_LT_TAGVAR([lt_cv_aix_libpath_], [$1])], + [AC_LINK_IFELSE([AC_LANG_PROGRAM],[ + lt_aix_libpath_sed='[ + /Import File Strings/,/^$/ { + /^0/ { + s/^0 *\([^ ]*\) *$/\1/ + p + } + }]' + _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` + # Check for a 64-bit object if we didn't find anything. + if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then + _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` + fi],[]) + if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then + _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=/usr/lib:/lib + fi + ]) + aix_libpath=$_LT_TAGVAR([lt_cv_aix_libpath_], [$1]) +fi +])# _LT_SYS_MODULE_PATH_AIX + + +# _LT_SHELL_INIT(ARG) +# ------------------- +m4_define([_LT_SHELL_INIT], +[m4_divert_text([M4SH-INIT], [$1 +])])# _LT_SHELL_INIT + + + +# _LT_PROG_ECHO_BACKSLASH +# ----------------------- +# Find how we can fake an echo command that does not interpret backslash. +# In particular, with Autoconf 2.60 or later we add some code to the start +# of the generated configure script that will find a shell with a builtin +# printf (that we can use as an echo command). +m4_defun([_LT_PROG_ECHO_BACKSLASH], +[ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' +ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO +ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO + +AC_MSG_CHECKING([how to print strings]) +# Test print first, because it will be a builtin if present. +if test "X`( print -r -- -n ) 2>/dev/null`" = X-n && \ + test "X`print -r -- $ECHO 2>/dev/null`" = "X$ECHO"; then + ECHO='print -r --' +elif test "X`printf %s $ECHO 2>/dev/null`" = "X$ECHO"; then + ECHO='printf %s\n' +else + # Use this function as a fallback that always works. + func_fallback_echo () + { + eval 'cat <<_LTECHO_EOF +$[]1 +_LTECHO_EOF' + } + ECHO='func_fallback_echo' +fi + +# func_echo_all arg... +# Invoke $ECHO with all args, space-separated. +func_echo_all () +{ + $ECHO "$*" +} + +case $ECHO in + printf*) AC_MSG_RESULT([printf]) ;; + print*) AC_MSG_RESULT([print -r]) ;; + *) AC_MSG_RESULT([cat]) ;; +esac + +m4_ifdef([_AS_DETECT_SUGGESTED], +[_AS_DETECT_SUGGESTED([ + test -n "${ZSH_VERSION+set}${BASH_VERSION+set}" || ( + ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' + ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO + ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO + PATH=/empty FPATH=/empty; export PATH FPATH + test "X`printf %s $ECHO`" = "X$ECHO" \ + || test "X`print -r -- $ECHO`" = "X$ECHO" )])]) + +_LT_DECL([], [SHELL], [1], [Shell to use when invoking shell scripts]) +_LT_DECL([], [ECHO], [1], [An echo program that protects backslashes]) +])# _LT_PROG_ECHO_BACKSLASH + + +# _LT_WITH_SYSROOT +# ---------------- +AC_DEFUN([_LT_WITH_SYSROOT], +[AC_MSG_CHECKING([for sysroot]) +AC_ARG_WITH([sysroot], +[AS_HELP_STRING([--with-sysroot@<:@=DIR@:>@], + [Search for dependent libraries within DIR (or the compiler's sysroot + if not specified).])], +[], [with_sysroot=no]) + +dnl lt_sysroot will always be passed unquoted. We quote it here +dnl in case the user passed a directory name. +lt_sysroot= +case $with_sysroot in #( + yes) + if test yes = "$GCC"; then + lt_sysroot=`$CC --print-sysroot 2>/dev/null` + fi + ;; #( + /*) + lt_sysroot=`echo "$with_sysroot" | sed -e "$sed_quote_subst"` + ;; #( + no|'') + ;; #( + *) + AC_MSG_RESULT([$with_sysroot]) + AC_MSG_ERROR([The sysroot must be an absolute path.]) + ;; +esac + + AC_MSG_RESULT([${lt_sysroot:-no}]) +_LT_DECL([], [lt_sysroot], [0], [The root where to search for ]dnl +[dependent libraries, and where our libraries should be installed.])]) + +# _LT_ENABLE_LOCK +# --------------- +m4_defun([_LT_ENABLE_LOCK], +[AC_ARG_ENABLE([libtool-lock], + [AS_HELP_STRING([--disable-libtool-lock], + [avoid locking (might break parallel builds)])]) +test no = "$enable_libtool_lock" || enable_libtool_lock=yes + +# Some flags need to be propagated to the compiler or linker for good +# libtool support. +case $host in +ia64-*-hpux*) + # Find out what ABI is being produced by ac_compile, and set mode + # options accordingly. + echo 'int i;' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + case `/usr/bin/file conftest.$ac_objext` in + *ELF-32*) + HPUX_IA64_MODE=32 + ;; + *ELF-64*) + HPUX_IA64_MODE=64 + ;; + esac + fi + rm -rf conftest* + ;; +*-*-irix6*) + # Find out what ABI is being produced by ac_compile, and set linker + # options accordingly. + echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + if test yes = "$lt_cv_prog_gnu_ld"; then + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -melf32bsmip" + ;; + *N32*) + LD="${LD-ld} -melf32bmipn32" + ;; + *64-bit*) + LD="${LD-ld} -melf64bmip" + ;; + esac + else + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -32" + ;; + *N32*) + LD="${LD-ld} -n32" + ;; + *64-bit*) + LD="${LD-ld} -64" + ;; + esac + fi + fi + rm -rf conftest* + ;; + +mips64*-*linux*) + # Find out what ABI is being produced by ac_compile, and set linker + # options accordingly. + echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + emul=elf + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + emul="${emul}32" + ;; + *64-bit*) + emul="${emul}64" + ;; + esac + case `/usr/bin/file conftest.$ac_objext` in + *MSB*) + emul="${emul}btsmip" + ;; + *LSB*) + emul="${emul}ltsmip" + ;; + esac + case `/usr/bin/file conftest.$ac_objext` in + *N32*) + emul="${emul}n32" + ;; + esac + LD="${LD-ld} -m $emul" + fi + rm -rf conftest* + ;; + +x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ +s390*-*linux*|s390*-*tpf*|sparc*-*linux*) + # Find out what ABI is being produced by ac_compile, and set linker + # options accordingly. Note that the listed cases only cover the + # situations where additional linker options are needed (such as when + # doing 32-bit compilation for a host where ld defaults to 64-bit, or + # vice versa); the common cases where no linker options are needed do + # not appear in the list. + echo 'int i;' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + case `/usr/bin/file conftest.o` in + *32-bit*) + case $host in + x86_64-*kfreebsd*-gnu) + LD="${LD-ld} -m elf_i386_fbsd" + ;; + x86_64-*linux*) + case `/usr/bin/file conftest.o` in + *x86-64*) + LD="${LD-ld} -m elf32_x86_64" + ;; + *) + LD="${LD-ld} -m elf_i386" + ;; + esac + ;; + powerpc64le-*linux*) + LD="${LD-ld} -m elf32lppclinux" + ;; + powerpc64-*linux*) + LD="${LD-ld} -m elf32ppclinux" + ;; + s390x-*linux*) + LD="${LD-ld} -m elf_s390" + ;; + sparc64-*linux*) + LD="${LD-ld} -m elf32_sparc" + ;; + esac + ;; + *64-bit*) + case $host in + x86_64-*kfreebsd*-gnu) + LD="${LD-ld} -m elf_x86_64_fbsd" + ;; + x86_64-*linux*) + LD="${LD-ld} -m elf_x86_64" + ;; + powerpcle-*linux*) + LD="${LD-ld} -m elf64lppc" + ;; + powerpc-*linux*) + LD="${LD-ld} -m elf64ppc" + ;; + s390*-*linux*|s390*-*tpf*) + LD="${LD-ld} -m elf64_s390" + ;; + sparc*-*linux*) + LD="${LD-ld} -m elf64_sparc" + ;; + esac + ;; + esac + fi + rm -rf conftest* + ;; + +*-*-sco3.2v5*) + # On SCO OpenServer 5, we need -belf to get full-featured binaries. + SAVE_CFLAGS=$CFLAGS + CFLAGS="$CFLAGS -belf" + AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf, + [AC_LANG_PUSH(C) + AC_LINK_IFELSE([AC_LANG_PROGRAM([[]],[[]])],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no]) + AC_LANG_POP]) + if test yes != "$lt_cv_cc_needs_belf"; then + # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf + CFLAGS=$SAVE_CFLAGS + fi + ;; +*-*solaris*) + # Find out what ABI is being produced by ac_compile, and set linker + # options accordingly. + echo 'int i;' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + case `/usr/bin/file conftest.o` in + *64-bit*) + case $lt_cv_prog_gnu_ld in + yes*) + case $host in + i?86-*-solaris*|x86_64-*-solaris*) + LD="${LD-ld} -m elf_x86_64" + ;; + sparc*-*-solaris*) + LD="${LD-ld} -m elf64_sparc" + ;; + esac + # GNU ld 2.21 introduced _sol2 emulations. Use them if available. + if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then + LD=${LD-ld}_sol2 + fi + ;; + *) + if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then + LD="${LD-ld} -64" + fi + ;; + esac + ;; + esac + fi + rm -rf conftest* + ;; +esac + +need_locks=$enable_libtool_lock +])# _LT_ENABLE_LOCK + + +# _LT_PROG_AR +# ----------- +m4_defun([_LT_PROG_AR], +[AC_CHECK_TOOLS(AR, [ar], false) +: ${AR=ar} +_LT_DECL([], [AR], [1], [The archiver]) + +# Use ARFLAGS variable as AR's operation code to sync the variable naming with +# Automake. If both AR_FLAGS and ARFLAGS are specified, AR_FLAGS should have +# higher priority because thats what people were doing historically (setting +# ARFLAGS for automake and AR_FLAGS for libtool). FIXME: Make the AR_FLAGS +# variable obsoleted/removed. + +test ${AR_FLAGS+y} || AR_FLAGS=${ARFLAGS-cr} +lt_ar_flags=$AR_FLAGS +_LT_DECL([], [lt_ar_flags], [0], [Flags to create an archive (by configure)]) + +# Make AR_FLAGS overridable by 'make ARFLAGS='. Don't try to run-time override +# by AR_FLAGS because that was never working and AR_FLAGS is about to die. +_LT_DECL([], [AR_FLAGS], [\@S|@{ARFLAGS-"\@S|@lt_ar_flags"}], + [Flags to create an archive]) + +AC_CACHE_CHECK([for archiver @FILE support], [lt_cv_ar_at_file], + [lt_cv_ar_at_file=no + AC_COMPILE_IFELSE([AC_LANG_PROGRAM], + [echo conftest.$ac_objext > conftest.lst + lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&AS_MESSAGE_LOG_FD' + AC_TRY_EVAL([lt_ar_try]) + if test 0 -eq "$ac_status"; then + # Ensure the archiver fails upon bogus file names. + rm -f conftest.$ac_objext libconftest.a + AC_TRY_EVAL([lt_ar_try]) + if test 0 -ne "$ac_status"; then + lt_cv_ar_at_file=@ + fi + fi + rm -f conftest.* libconftest.a + ]) + ]) + +if test no = "$lt_cv_ar_at_file"; then + archiver_list_spec= +else + archiver_list_spec=$lt_cv_ar_at_file +fi +_LT_DECL([], [archiver_list_spec], [1], + [How to feed a file listing to the archiver]) +])# _LT_PROG_AR + + +# _LT_CMD_OLD_ARCHIVE +# ------------------- +m4_defun([_LT_CMD_OLD_ARCHIVE], +[_LT_PROG_AR + +AC_CHECK_TOOL(STRIP, strip, :) +test -z "$STRIP" && STRIP=: +_LT_DECL([], [STRIP], [1], [A symbol stripping program]) + +AC_CHECK_TOOL(RANLIB, ranlib, :) +test -z "$RANLIB" && RANLIB=: +_LT_DECL([], [RANLIB], [1], + [Commands used to install an old-style archive]) + +# Determine commands to create old-style static archives. +old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' +old_postinstall_cmds='chmod 644 $oldlib' +old_postuninstall_cmds= + +if test -n "$RANLIB"; then + case $host_os in + bitrig* | openbsd*) + old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib" + ;; + *) + old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$tool_oldlib" + ;; + esac + old_archive_cmds="$old_archive_cmds~\$RANLIB \$tool_oldlib" +fi + +case $host_os in + darwin*) + lock_old_archive_extraction=yes ;; + *) + lock_old_archive_extraction=no ;; +esac +_LT_DECL([], [old_postinstall_cmds], [2]) +_LT_DECL([], [old_postuninstall_cmds], [2]) +_LT_TAGDECL([], [old_archive_cmds], [2], + [Commands used to build an old-style archive]) +_LT_DECL([], [lock_old_archive_extraction], [0], + [Whether to use a lock for old archive extraction]) +])# _LT_CMD_OLD_ARCHIVE + + +# _LT_COMPILER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, +# [OUTPUT-FILE], [ACTION-SUCCESS], [ACTION-FAILURE]) +# ---------------------------------------------------------------- +# Check whether the given compiler option works +AC_DEFUN([_LT_COMPILER_OPTION], +[m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_DECL_SED])dnl +AC_CACHE_CHECK([$1], [$2], + [$2=no + m4_if([$4], , [ac_outfile=conftest.$ac_objext], [ac_outfile=$4]) + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="$3" ## exclude from sc_useless_quotes_in_assignment + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&AS_MESSAGE_LOG_FD) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&AS_MESSAGE_LOG_FD + echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then + $2=yes + fi + fi + $RM conftest* +]) + +if test yes = "[$]$2"; then + m4_if([$5], , :, [$5]) +else + m4_if([$6], , :, [$6]) +fi +])# _LT_COMPILER_OPTION + +# Old name: +AU_ALIAS([AC_LIBTOOL_COMPILER_OPTION], [_LT_COMPILER_OPTION]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_COMPILER_OPTION], []) + + +# _LT_LINKER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, +# [ACTION-SUCCESS], [ACTION-FAILURE]) +# ---------------------------------------------------- +# Check whether the given linker option works +AC_DEFUN([_LT_LINKER_OPTION], +[m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_DECL_SED])dnl +AC_CACHE_CHECK([$1], [$2], + [$2=no + save_LDFLAGS=$LDFLAGS + LDFLAGS="$LDFLAGS $3" + echo "$lt_simple_link_test_code" > conftest.$ac_ext + if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then + # The linker can only warn and ignore the option if not recognized + # So say no if there are warnings + if test -s conftest.err; then + # Append any errors to the config.log. + cat conftest.err 1>&AS_MESSAGE_LOG_FD + $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if diff conftest.exp conftest.er2 >/dev/null; then + $2=yes + fi + else + $2=yes + fi + fi + $RM -r conftest* + LDFLAGS=$save_LDFLAGS +]) + +if test yes = "[$]$2"; then + m4_if([$4], , :, [$4]) +else + m4_if([$5], , :, [$5]) +fi +])# _LT_LINKER_OPTION + +# Old name: +AU_ALIAS([AC_LIBTOOL_LINKER_OPTION], [_LT_LINKER_OPTION]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_LINKER_OPTION], []) + + +# LT_CMD_MAX_LEN +#--------------- +AC_DEFUN([LT_CMD_MAX_LEN], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +# find the maximum length of command line arguments +AC_MSG_CHECKING([the maximum length of command line arguments]) +AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl + i=0 + teststring=ABCD + + case $build_os in + msdosdjgpp*) + # On DJGPP, this test can blow up pretty badly due to problems in libc + # (any single argument exceeding 2000 bytes causes a buffer overrun + # during glob expansion). Even if it were fixed, the result of this + # check would be larger than it should be. + lt_cv_sys_max_cmd_len=12288; # 12K is about right + ;; + + gnu*) + # Under GNU Hurd, this test is not required because there is + # no limit to the length of command line arguments. + # Libtool will interpret -1 as no limit whatsoever + lt_cv_sys_max_cmd_len=-1; + ;; + + cygwin* | mingw* | cegcc*) + # On Win9x/ME, this test blows up -- it succeeds, but takes + # about 5 minutes as the teststring grows exponentially. + # Worse, since 9x/ME are not pre-emptively multitasking, + # you end up with a "frozen" computer, even though with patience + # the test eventually succeeds (with a max line length of 256k). + # Instead, let's just punt: use the minimum linelength reported by + # all of the supported platforms: 8192 (on NT/2K/XP). + lt_cv_sys_max_cmd_len=8192; + ;; + + mint*) + # On MiNT this can take a long time and run out of memory. + lt_cv_sys_max_cmd_len=8192; + ;; + + amigaos*) + # On AmigaOS with pdksh, this test takes hours, literally. + # So we just punt and use a minimum line length of 8192. + lt_cv_sys_max_cmd_len=8192; + ;; + + bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*) + # This has been around since 386BSD, at least. Likely further. + if test -x /sbin/sysctl; then + lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` + elif test -x /usr/sbin/sysctl; then + lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` + else + lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs + fi + # And add a safety zone + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` + ;; + + interix*) + # We know the value 262144 and hardcode it with a safety zone (like BSD) + lt_cv_sys_max_cmd_len=196608 + ;; + + os2*) + # The test takes a long time on OS/2. + lt_cv_sys_max_cmd_len=8192 + ;; + + osf*) + # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure + # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not + # nice to cause kernel panics so lets avoid the loop below. + # First set a reasonable default. + lt_cv_sys_max_cmd_len=16384 + # + if test -x /sbin/sysconfig; then + case `/sbin/sysconfig -q proc exec_disable_arg_limit` in + *1*) lt_cv_sys_max_cmd_len=-1 ;; + esac + fi + ;; + sco3.2v5*) + lt_cv_sys_max_cmd_len=102400 + ;; + sysv5* | sco5v6* | sysv4.2uw2*) + kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` + if test -n "$kargmax"; then + lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[[ ]]//'` + else + lt_cv_sys_max_cmd_len=32768 + fi + ;; + *) + lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` + if test -n "$lt_cv_sys_max_cmd_len" && \ + test undefined != "$lt_cv_sys_max_cmd_len"; then + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` + else + # Make teststring a little bigger before we do anything with it. + # a 1K string should be a reasonable start. + for i in 1 2 3 4 5 6 7 8; do + teststring=$teststring$teststring + done + SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} + # If test is not a shell built-in, we'll probably end up computing a + # maximum length that is only half of the actual maximum length, but + # we can't tell. + while { test X`env echo "$teststring$teststring" 2>/dev/null` \ + = "X$teststring$teststring"; } >/dev/null 2>&1 && + test 17 != "$i" # 1/2 MB should be enough + do + i=`expr $i + 1` + teststring=$teststring$teststring + done + # Only check the string length outside the loop. + lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` + teststring= + # Add a significant safety factor because C++ compilers can tack on + # massive amounts of additional arguments before passing them to the + # linker. It appears as though 1/2 is a usable value. + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` + fi + ;; + esac +]) +if test -n "$lt_cv_sys_max_cmd_len"; then + AC_MSG_RESULT($lt_cv_sys_max_cmd_len) +else + AC_MSG_RESULT(none) +fi +max_cmd_len=$lt_cv_sys_max_cmd_len +_LT_DECL([], [max_cmd_len], [0], + [What is the maximum length of a command?]) +])# LT_CMD_MAX_LEN + +# Old name: +AU_ALIAS([AC_LIBTOOL_SYS_MAX_CMD_LEN], [LT_CMD_MAX_LEN]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_SYS_MAX_CMD_LEN], []) + + +# _LT_HEADER_DLFCN +# ---------------- +m4_defun([_LT_HEADER_DLFCN], +[AC_CHECK_HEADERS([dlfcn.h], [], [], [AC_INCLUDES_DEFAULT])dnl +])# _LT_HEADER_DLFCN + + +# _LT_TRY_DLOPEN_SELF (ACTION-IF-TRUE, ACTION-IF-TRUE-W-USCORE, +# ACTION-IF-FALSE, ACTION-IF-CROSS-COMPILING) +# ---------------------------------------------------------------- +m4_defun([_LT_TRY_DLOPEN_SELF], +[m4_require([_LT_HEADER_DLFCN])dnl +if test yes = "$cross_compiling"; then : + [$4] +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext <<_LT_EOF +[#line $LINENO "configure" +#include "confdefs.h" + +#if HAVE_DLFCN_H +#include +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +/* When -fvisibility=hidden is used, assume the code has been annotated + correspondingly for the symbols needed. */ +#if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) +int fnord () __attribute__((visibility("default"))); +#endif + +int fnord () { return 42; } +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else + { + if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + else puts (dlerror ()); + } + /* dlclose (self); */ + } + else + puts (dlerror ()); + + return status; +}] +_LT_EOF + if AC_TRY_EVAL(ac_link) && test -s "conftest$ac_exeext" 2>/dev/null; then + (./conftest; exit; ) >&AS_MESSAGE_LOG_FD 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) $1 ;; + x$lt_dlneed_uscore) $2 ;; + x$lt_dlunknown|x*) $3 ;; + esac + else : + # compilation failed + $3 + fi +fi +rm -fr conftest* +])# _LT_TRY_DLOPEN_SELF + + +# LT_SYS_DLOPEN_SELF +# ------------------ +AC_DEFUN([LT_SYS_DLOPEN_SELF], +[m4_require([_LT_HEADER_DLFCN])dnl +if test yes != "$enable_dlopen"; then + enable_dlopen=unknown + enable_dlopen_self=unknown + enable_dlopen_self_static=unknown +else + lt_cv_dlopen=no + lt_cv_dlopen_libs= + + case $host_os in + beos*) + lt_cv_dlopen=load_add_on + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ;; + + mingw* | pw32* | cegcc*) + lt_cv_dlopen=LoadLibrary + lt_cv_dlopen_libs= + ;; + + cygwin*) + lt_cv_dlopen=dlopen + lt_cv_dlopen_libs= + ;; + + darwin*) + # if libdl is installed we need to link against it + AC_CHECK_LIB([dl], [dlopen], + [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl],[ + lt_cv_dlopen=dyld + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ]) + ;; + + tpf*) + # Don't try to run any link tests for TPF. We know it's impossible + # because TPF is a cross-compiler, and we know how we open DSOs. + lt_cv_dlopen=dlopen + lt_cv_dlopen_libs= + lt_cv_dlopen_self=no + ;; + + *) + AC_CHECK_FUNC([shl_load], + [lt_cv_dlopen=shl_load], + [AC_CHECK_LIB([dld], [shl_load], + [lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld], + [AC_CHECK_FUNC([dlopen], + [lt_cv_dlopen=dlopen], + [AC_CHECK_LIB([dl], [dlopen], + [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl], + [AC_CHECK_LIB([svld], [dlopen], + [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld], + [AC_CHECK_LIB([dld], [dld_link], + [lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld]) + ]) + ]) + ]) + ]) + ]) + ;; + esac + + if test no = "$lt_cv_dlopen"; then + enable_dlopen=no + else + enable_dlopen=yes + fi + + case $lt_cv_dlopen in + dlopen) + save_CPPFLAGS=$CPPFLAGS + test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" + + save_LDFLAGS=$LDFLAGS + wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" + + save_LIBS=$LIBS + LIBS="$lt_cv_dlopen_libs $LIBS" + + AC_CACHE_CHECK([whether a program can dlopen itself], + lt_cv_dlopen_self, [dnl + _LT_TRY_DLOPEN_SELF( + lt_cv_dlopen_self=yes, lt_cv_dlopen_self=yes, + lt_cv_dlopen_self=no, lt_cv_dlopen_self=cross) + ]) + + if test yes = "$lt_cv_dlopen_self"; then + wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" + AC_CACHE_CHECK([whether a statically linked program can dlopen itself], + lt_cv_dlopen_self_static, [dnl + _LT_TRY_DLOPEN_SELF( + lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=yes, + lt_cv_dlopen_self_static=no, lt_cv_dlopen_self_static=cross) + ]) + fi + + CPPFLAGS=$save_CPPFLAGS + LDFLAGS=$save_LDFLAGS + LIBS=$save_LIBS + ;; + esac + + case $lt_cv_dlopen_self in + yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; + *) enable_dlopen_self=unknown ;; + esac + + case $lt_cv_dlopen_self_static in + yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; + *) enable_dlopen_self_static=unknown ;; + esac +fi +_LT_DECL([dlopen_support], [enable_dlopen], [0], + [Whether dlopen is supported]) +_LT_DECL([dlopen_self], [enable_dlopen_self], [0], + [Whether dlopen of programs is supported]) +_LT_DECL([dlopen_self_static], [enable_dlopen_self_static], [0], + [Whether dlopen of statically linked programs is supported]) +])# LT_SYS_DLOPEN_SELF + +# Old name: +AU_ALIAS([AC_LIBTOOL_DLOPEN_SELF], [LT_SYS_DLOPEN_SELF]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_DLOPEN_SELF], []) + + +# _LT_COMPILER_C_O([TAGNAME]) +# --------------------------- +# Check to see if options -c and -o are simultaneously supported by compiler. +# This macro does not hard code the compiler like AC_PROG_CC_C_O. +m4_defun([_LT_COMPILER_C_O], +[m4_require([_LT_DECL_SED])dnl +m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_TAG_COMPILER])dnl +AC_CACHE_CHECK([if $compiler supports -c -o file.$ac_objext], + [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)], + [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=no + $RM -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&AS_MESSAGE_LOG_FD) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&AS_MESSAGE_LOG_FD + echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp + $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then + _LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes + fi + fi + chmod u+w . 2>&AS_MESSAGE_LOG_FD + $RM conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files + $RM out/* && rmdir out + cd .. + $RM -r conftest + $RM conftest* +]) +_LT_TAGDECL([compiler_c_o], [lt_cv_prog_compiler_c_o], [1], + [Does compiler simultaneously support -c and -o options?]) +])# _LT_COMPILER_C_O + + +# _LT_COMPILER_FILE_LOCKS([TAGNAME]) +# ---------------------------------- +# Check to see if we can do hard links to lock some files if needed +m4_defun([_LT_COMPILER_FILE_LOCKS], +[m4_require([_LT_ENABLE_LOCK])dnl +m4_require([_LT_FILEUTILS_DEFAULTS])dnl +_LT_COMPILER_C_O([$1]) + +hard_links=nottested +if test no = "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" && test no != "$need_locks"; then + # do not overwrite the value of need_locks provided by the user + AC_MSG_CHECKING([if we can lock with hard links]) + hard_links=yes + $RM conftest* + ln conftest.a conftest.b 2>/dev/null && hard_links=no + touch conftest.a + ln conftest.a conftest.b 2>&5 || hard_links=no + ln conftest.a conftest.b 2>/dev/null && hard_links=no + AC_MSG_RESULT([$hard_links]) + if test no = "$hard_links"; then + AC_MSG_WARN(['$CC' does not support '-c -o', so 'make -j' may be unsafe]) + need_locks=warn + fi +else + need_locks=no +fi +_LT_DECL([], [need_locks], [1], [Must we lock files when doing compilation?]) +])# _LT_COMPILER_FILE_LOCKS + + +# _LT_CHECK_OBJDIR +# ---------------- +m4_defun([_LT_CHECK_OBJDIR], +[AC_CACHE_CHECK([for objdir], [lt_cv_objdir], +[rm -f .libs 2>/dev/null +mkdir .libs 2>/dev/null +if test -d .libs; then + lt_cv_objdir=.libs +else + # MS-DOS does not allow filenames that begin with a dot. + lt_cv_objdir=_libs +fi +rmdir .libs 2>/dev/null]) +objdir=$lt_cv_objdir +_LT_DECL([], [objdir], [0], + [The name of the directory that contains temporary libtool files])dnl +m4_pattern_allow([LT_OBJDIR])dnl +AC_DEFINE_UNQUOTED([LT_OBJDIR], "$lt_cv_objdir/", + [Define to the sub-directory where libtool stores uninstalled libraries.]) +])# _LT_CHECK_OBJDIR + + +# _LT_LINKER_HARDCODE_LIBPATH([TAGNAME]) +# -------------------------------------- +# Check hardcoding attributes. +m4_defun([_LT_LINKER_HARDCODE_LIBPATH], +[AC_MSG_CHECKING([how to hardcode library paths into programs]) +_LT_TAGVAR(hardcode_action, $1)= +if test -n "$_LT_TAGVAR(hardcode_libdir_flag_spec, $1)" || + test -n "$_LT_TAGVAR(runpath_var, $1)" || + test yes = "$_LT_TAGVAR(hardcode_automatic, $1)"; then + + # We can hardcode non-existent directories. + if test no != "$_LT_TAGVAR(hardcode_direct, $1)" && + # If the only mechanism to avoid hardcoding is shlibpath_var, we + # have to relink, otherwise we might link with an installed library + # when we should be linking with a yet-to-be-installed one + ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, $1)" && + test no != "$_LT_TAGVAR(hardcode_minus_L, $1)"; then + # Linking always hardcodes the temporary library directory. + _LT_TAGVAR(hardcode_action, $1)=relink + else + # We can link without hardcoding, and we can hardcode nonexisting dirs. + _LT_TAGVAR(hardcode_action, $1)=immediate + fi +else + # We cannot hardcode anything, or else we can only hardcode existing + # directories. + _LT_TAGVAR(hardcode_action, $1)=unsupported +fi +AC_MSG_RESULT([$_LT_TAGVAR(hardcode_action, $1)]) + +if test relink = "$_LT_TAGVAR(hardcode_action, $1)" || + test yes = "$_LT_TAGVAR(inherit_rpath, $1)"; then + # Fast installation is not supported + enable_fast_install=no +elif test yes = "$shlibpath_overrides_runpath" || + test no = "$enable_shared"; then + # Fast installation is not necessary + enable_fast_install=needless +fi +_LT_TAGDECL([], [hardcode_action], [0], + [How to hardcode a shared library path into an executable]) +])# _LT_LINKER_HARDCODE_LIBPATH + + +# _LT_CMD_STRIPLIB +# ---------------- +m4_defun([_LT_CMD_STRIPLIB], +[m4_require([_LT_DECL_EGREP]) +striplib= +old_striplib= +AC_MSG_CHECKING([whether stripping libraries is possible]) +if test -z "$STRIP"; then + AC_MSG_RESULT([no]) +else + if $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then + old_striplib="$STRIP --strip-debug" + striplib="$STRIP --strip-unneeded" + AC_MSG_RESULT([yes]) + else + case $host_os in + darwin*) + # FIXME - insert some real tests, host_os isn't really good enough + striplib="$STRIP -x" + old_striplib="$STRIP -S" + AC_MSG_RESULT([yes]) + ;; + freebsd*) + if $STRIP -V 2>&1 | $GREP "elftoolchain" >/dev/null; then + old_striplib="$STRIP --strip-debug" + striplib="$STRIP --strip-unneeded" + AC_MSG_RESULT([yes]) + else + AC_MSG_RESULT([no]) + fi + ;; + *) + AC_MSG_RESULT([no]) + ;; + esac + fi +fi +_LT_DECL([], [old_striplib], [1], [Commands to strip libraries]) +_LT_DECL([], [striplib], [1]) +])# _LT_CMD_STRIPLIB + + +# _LT_PREPARE_MUNGE_PATH_LIST +# --------------------------- +# Make sure func_munge_path_list() is defined correctly. +m4_defun([_LT_PREPARE_MUNGE_PATH_LIST], +[[# func_munge_path_list VARIABLE PATH +# ----------------------------------- +# VARIABLE is name of variable containing _space_ separated list of +# directories to be munged by the contents of PATH, which is string +# having a format: +# "DIR[:DIR]:" +# string "DIR[ DIR]" will be prepended to VARIABLE +# ":DIR[:DIR]" +# string "DIR[ DIR]" will be appended to VARIABLE +# "DIRP[:DIRP]::[DIRA:]DIRA" +# string "DIRP[ DIRP]" will be prepended to VARIABLE and string +# "DIRA[ DIRA]" will be appended to VARIABLE +# "DIR[:DIR]" +# VARIABLE will be replaced by "DIR[ DIR]" +func_munge_path_list () +{ + case x@S|@2 in + x) + ;; + *:) + eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'` \@S|@@S|@1\" + ;; + x:*) + eval @S|@1=\"\@S|@@S|@1 `$ECHO @S|@2 | $SED 's/:/ /g'`\" + ;; + *::*) + eval @S|@1=\"\@S|@@S|@1\ `$ECHO @S|@2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" + eval @S|@1=\"`$ECHO @S|@2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \@S|@@S|@1\" + ;; + *) + eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'`\" + ;; + esac +} +]])# _LT_PREPARE_PATH_LIST + + +# _LT_SYS_DYNAMIC_LINKER([TAG]) +# ----------------------------- +# PORTME Fill in your ld.so characteristics +m4_defun([_LT_SYS_DYNAMIC_LINKER], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +m4_require([_LT_DECL_EGREP])dnl +m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_DECL_OBJDUMP])dnl +m4_require([_LT_DECL_SED])dnl +m4_require([_LT_CHECK_SHELL_FEATURES])dnl +m4_require([_LT_PREPARE_MUNGE_PATH_LIST])dnl +AC_MSG_CHECKING([dynamic linker characteristics]) +m4_if([$1], + [], [ +if test yes = "$GCC"; then + case $host_os in + darwin*) lt_awk_arg='/^libraries:/,/LR/' ;; + *) lt_awk_arg='/^libraries:/' ;; + esac + case $host_os in + mingw* | cegcc*) lt_sed_strip_eq='s|=\([[A-Za-z]]:\)|\1|g' ;; + *) lt_sed_strip_eq='s|=/|/|g' ;; + esac + lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq` + case $lt_search_path_spec in + *\;*) + # if the path contains ";" then we assume it to be the separator + # otherwise default to the standard path separator (i.e. ":") - it is + # assumed that no part of a normal pathname contains ";" but that should + # okay in the real world where ";" in dirpaths is itself problematic. + lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED 's/;/ /g'` + ;; + *) + lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED "s/$PATH_SEPARATOR/ /g"` + ;; + esac + # Ok, now we have the path, separated by spaces, we can step through it + # and add multilib dir if necessary... + lt_tmp_lt_search_path_spec= + lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` + # ...but if some path component already ends with the multilib dir we assume + # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer). + case "$lt_multi_os_dir; $lt_search_path_spec " in + "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*) + lt_multi_os_dir= + ;; + esac + for lt_sys_path in $lt_search_path_spec; do + if test -d "$lt_sys_path$lt_multi_os_dir"; then + lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir" + elif test -n "$lt_multi_os_dir"; then + test -d "$lt_sys_path" && \ + lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" + fi + done + lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk ' +BEGIN {RS = " "; FS = "/|\n";} { + lt_foo = ""; + lt_count = 0; + for (lt_i = NF; lt_i > 0; lt_i--) { + if ($lt_i != "" && $lt_i != ".") { + if ($lt_i == "..") { + lt_count++; + } else { + if (lt_count == 0) { + lt_foo = "/" $lt_i lt_foo; + } else { + lt_count--; + } + } + } + } + if (lt_foo != "") { lt_freq[[lt_foo]]++; } + if (lt_freq[[lt_foo]] == 1) { print lt_foo; } +}'` + # AWK program above erroneously prepends '/' to C:/dos/paths + # for these hosts. + case $host_os in + mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\ + $SED 's|/\([[A-Za-z]]:\)|\1|g'` ;; + esac + sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP` +else + sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" +fi]) +library_names_spec= +libname_spec='lib$name' +soname_spec= +shrext_cmds=.so +postinstall_cmds= +postuninstall_cmds= +finish_cmds= +finish_eval= +shlibpath_var= +shlibpath_overrides_runpath=unknown +version_type=none +dynamic_linker="$host_os ld.so" +sys_lib_dlsearch_path_spec="/lib /usr/lib" +need_lib_prefix=unknown +hardcode_into_libs=no + +# when you set need_version to no, make sure it does not cause -set_version +# flags to be left without arguments +need_version=unknown + +AC_ARG_VAR([LT_SYS_LIBRARY_PATH], +[User-defined run-time library search path.]) + +case $host_os in +aix3*) + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$release$shared_ext$versuffix $libname.a' + shlibpath_var=LIBPATH + + # AIX 3 has no versioning support, so we append a major version to the name. + soname_spec='$libname$release$shared_ext$major' + ;; + +aix[[4-9]]*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + hardcode_into_libs=yes + if test ia64 = "$host_cpu"; then + # AIX 5 supports IA64 + library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext' + shlibpath_var=LD_LIBRARY_PATH + else + # With GCC up to 2.95.x, collect2 would create an import file + # for dependence libraries. The import file would start with + # the line '#! .'. This would cause the generated library to + # depend on '.', always an invalid library. This was fixed in + # development snapshots of GCC prior to 3.0. + case $host_os in + aix4 | aix4.[[01]] | aix4.[[01]].*) + if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' + echo ' yes ' + echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then + : + else + can_build_shared=no + fi + ;; + esac + # Using Import Files as archive members, it is possible to support + # filename-based versioning of shared library archives on AIX. While + # this would work for both with and without runtime linking, it will + # prevent static linking of such archives. So we do filename-based + # shared library versioning with .so extension only, which is used + # when both runtime linking and shared linking is enabled. + # Unfortunately, runtime linking may impact performance, so we do + # not want this to be the default eventually. Also, we use the + # versioned .so libs for executables only if there is the -brtl + # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. + # To allow for filename-based versioning support, we need to create + # libNAME.so.V as an archive file, containing: + # *) an Import File, referring to the versioned filename of the + # archive as well as the shared archive member, telling the + # bitwidth (32 or 64) of that shared object, and providing the + # list of exported symbols of that shared object, eventually + # decorated with the 'weak' keyword + # *) the shared object with the F_LOADONLY flag set, to really avoid + # it being seen by the linker. + # At run time we better use the real file rather than another symlink, + # but for link time we create the symlink libNAME.so -> libNAME.so.V + + case $with_aix_soname,$aix_use_runtimelinking in + # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + aix,yes) # traditional libtool + dynamic_linker='AIX unversionable lib.so' + # If using run time linking (on AIX 4.2 or later) use lib.so + # instead of lib.a to let people know that these are not + # typical AIX shared libraries. + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + ;; + aix,no) # traditional AIX only + dynamic_linker='AIX lib.a[(]lib.so.V[)]' + # We preserve .a as extension for shared libraries through AIX4.2 + # and later when we are not doing run time linking. + library_names_spec='$libname$release.a $libname.a' + soname_spec='$libname$release$shared_ext$major' + ;; + svr4,*) # full svr4 only + dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)]" + library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' + # We do not specify a path in Import Files, so LIBPATH fires. + shlibpath_overrides_runpath=yes + ;; + *,yes) # both, prefer svr4 + dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)], lib.a[(]lib.so.V[)]" + library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' + # unpreferred sharedlib libNAME.a needs extra handling + postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' + postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' + # We do not specify a path in Import Files, so LIBPATH fires. + shlibpath_overrides_runpath=yes + ;; + *,no) # both, prefer aix + dynamic_linker="AIX lib.a[(]lib.so.V[)], lib.so.V[(]$shared_archive_member_spec.o[)]" + library_names_spec='$libname$release.a $libname.a' + soname_spec='$libname$release$shared_ext$major' + # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling + postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' + postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' + ;; + esac + shlibpath_var=LIBPATH + fi + ;; + +amigaos*) + case $host_cpu in + powerpc) + # Since July 2007 AmigaOS4 officially supports .so libraries. + # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + ;; + m68k) + library_names_spec='$libname.ixlibrary $libname.a' + # Create ${libname}_ixlibrary.a entries in /sys/libs. + finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' + ;; + esac + ;; + +beos*) + library_names_spec='$libname$shared_ext' + dynamic_linker="$host_os ld.so" + shlibpath_var=LIBRARY_PATH + ;; + +bsdi[[45]]*) + version_type=linux # correct to gnu/linux during the next big refactor + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + # the default ld.so.conf also contains /usr/contrib/lib and + # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow + # libtool to hard-code these into programs + ;; + +cygwin* | mingw* | pw32* | cegcc*) + version_type=windows + shrext_cmds=.dll + need_version=no + need_lib_prefix=no + + case $GCC,$cc_basename in + yes,*) + # gcc + library_names_spec='$libname.dll.a' + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \$file`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname~ + if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then + eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; + fi' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $RM \$dlpath' + shlibpath_overrides_runpath=yes + + case $host_os in + cygwin*) + # Cygwin DLLs use 'cyg' prefix rather than 'lib' + soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' +m4_if([$1], [],[ + sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api"]) + ;; + mingw* | cegcc*) + # MinGW DLLs use traditional 'lib' prefix + soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' + ;; + pw32*) + # pw32 DLLs use 'pw' prefix rather than 'lib' + library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' + ;; + esac + dynamic_linker='Win32 ld.exe' + ;; + + *,cl* | *,icl*) + # Native MSVC or ICC + libname_spec='$name' + soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' + library_names_spec='$libname.dll.lib' + + case $build_os in + mingw*) + sys_lib_search_path_spec= + lt_save_ifs=$IFS + IFS=';' + for lt_path in $LIB + do + IFS=$lt_save_ifs + # Let DOS variable expansion print the short 8.3 style file name. + lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` + sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" + done + IFS=$lt_save_ifs + # Convert to MSYS style. + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | sed -e 's|\\\\|/|g' -e 's| \\([[a-zA-Z]]\\):| /\\1|g' -e 's|^ ||'` + ;; + cygwin*) + # Convert to unix form, then to dos form, then back to unix form + # but this time dos style (no spaces!) so that the unix form looks + # like /cygdrive/c/PROGRA~1:/cygdr... + sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` + sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` + sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + ;; + *) + sys_lib_search_path_spec=$LIB + if $ECHO "$sys_lib_search_path_spec" | [$GREP ';[c-zC-Z]:/' >/dev/null]; then + # It is most probably a Windows format PATH. + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + # FIXME: find the short name or the path components, as spaces are + # common. (e.g. "Program Files" -> "PROGRA~1") + ;; + esac + + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \$file`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $RM \$dlpath' + shlibpath_overrides_runpath=yes + dynamic_linker='Win32 link.exe' + ;; + + *) + # Assume MSVC and ICC wrapper + library_names_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext $libname.lib' + dynamic_linker='Win32 ld.exe' + ;; + esac + # FIXME: first we should search . and the directory the executable is in + shlibpath_var=PATH + ;; + +darwin* | rhapsody*) + dynamic_linker="$host_os dyld" + version_type=darwin + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$major$shared_ext $libname$shared_ext' + soname_spec='$libname$release$major$shared_ext' + shlibpath_overrides_runpath=yes + shlibpath_var=DYLD_LIBRARY_PATH + shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' +m4_if([$1], [],[ + sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib"]) + sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' + ;; + +dgux*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +freebsd* | dragonfly*) + # DragonFly does not have aout. When/if they implement a new + # versioning mechanism, adjust this. + if test -x /usr/bin/objformat; then + objformat=`/usr/bin/objformat` + else + case $host_os in + freebsd[[23]].*) objformat=aout ;; + *) objformat=elf ;; + esac + fi + version_type=freebsd-$objformat + case $version_type in + freebsd-elf*) + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + need_version=no + need_lib_prefix=no + ;; + freebsd-*) + library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' + need_version=yes + ;; + esac + shlibpath_var=LD_LIBRARY_PATH + case $host_os in + freebsd2.*) + shlibpath_overrides_runpath=yes + ;; + freebsd3.[[01]]* | freebsdelf3.[[01]]*) + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + freebsd3.[[2-9]]* | freebsdelf3.[[2-9]]* | \ + freebsd4.[[0-5]] | freebsdelf4.[[0-5]] | freebsd4.1.1 | freebsdelf4.1.1) + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + *) # from 4.6 on, and DragonFly + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + esac + ;; + +haiku*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + dynamic_linker="$host_os runtime_loader" + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LIBRARY_PATH + shlibpath_overrides_runpath=no + sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' + hardcode_into_libs=yes + ;; + +hpux9* | hpux10* | hpux11*) + # Give a soname corresponding to the major version so that dld.sl refuses to + # link against other versions. + version_type=sunos + need_lib_prefix=no + need_version=no + case $host_cpu in + ia64*) + shrext_cmds='.so' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.so" + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + if test 32 = "$HPUX_IA64_MODE"; then + sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" + sys_lib_dlsearch_path_spec=/usr/lib/hpux32 + else + sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" + sys_lib_dlsearch_path_spec=/usr/lib/hpux64 + fi + ;; + hppa*64*) + shrext_cmds='.sl' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.sl" + shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + *) + shrext_cmds='.sl' + dynamic_linker="$host_os dld.sl" + shlibpath_var=SHLIB_PATH + shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + ;; + esac + # HP-UX runs *really* slowly unless shared libraries are mode 555, ... + postinstall_cmds='chmod 555 $lib' + # or fails outright, so override atomically: + install_override_mode=555 + ;; + +interix[[3-9]]*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + +irix5* | irix6* | nonstopux*) + case $host_os in + nonstopux*) version_type=nonstopux ;; + *) + if test yes = "$lt_cv_prog_gnu_ld"; then + version_type=linux # correct to gnu/linux during the next big refactor + else + version_type=irix + fi ;; + esac + need_lib_prefix=no + need_version=no + soname_spec='$libname$release$shared_ext$major' + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext' + case $host_os in + irix5* | nonstopux*) + libsuff= shlibsuff= + ;; + *) + case $LD in # libtool.m4 will add one of these switches to LD + *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") + libsuff= shlibsuff= libmagic=32-bit;; + *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") + libsuff=32 shlibsuff=N32 libmagic=N32;; + *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") + libsuff=64 shlibsuff=64 libmagic=64-bit;; + *) libsuff= shlibsuff= libmagic=never-match;; + esac + ;; + esac + shlibpath_var=LD_LIBRARY${shlibsuff}_PATH + shlibpath_overrides_runpath=no + sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff" + sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff" + hardcode_into_libs=yes + ;; + +# No shared lib support for Linux oldld, aout, or coff. +linux*oldld* | linux*aout* | linux*coff*) + dynamic_linker=no + ;; + +linux*android*) + version_type=none # Android doesn't support versioned libraries. + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext' + soname_spec='$libname$release$shared_ext' + finish_cmds= + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + dynamic_linker='Android linker' + # Don't embed -rpath directories since the linker doesn't support them. + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + ;; + +# This must be glibc/ELF. +linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + + # Some binutils ld are patched to set DT_RUNPATH + AC_CACHE_VAL([lt_cv_shlibpath_overrides_runpath], + [lt_cv_shlibpath_overrides_runpath=no + save_LDFLAGS=$LDFLAGS + save_libdir=$libdir + eval "libdir=/foo; wl=\"$_LT_TAGVAR(lt_prog_compiler_wl, $1)\"; \ + LDFLAGS=\"\$LDFLAGS $_LT_TAGVAR(hardcode_libdir_flag_spec, $1)\"" + AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], + [AS_IF([ ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null], + [lt_cv_shlibpath_overrides_runpath=yes])]) + LDFLAGS=$save_LDFLAGS + libdir=$save_libdir + ]) + shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath + + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + # Ideally, we could use ldconfig to report *all* directores which are + # searched for libraries, however this is still not possible. Aside from not + # being certain /sbin/ldconfig is available, command + # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, + # even though it is searched at run-time. Try to do the best guess by + # appending ld.so.conf contents (and includes) to the search path. + if test -f /etc/ld.so.conf; then + lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \[$]2)); skip = 1; } { if (!skip) print \[$]0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` + sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" + fi + + # We used to test for /lib/ld.so.1 and disable shared libraries on + # powerpc, because MkLinux only supported shared libraries with the + # GNU dynamic linker. Since this was broken with cross compilers, + # most powerpc-linux boxes support dynamic linking these days and + # people can always --disable-shared, the test was removed, and we + # assume the GNU/Linux dynamic linker is in use. + dynamic_linker='GNU/Linux ld.so' + ;; + +netbsd*) + version_type=sunos + need_lib_prefix=no + need_version=no + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + dynamic_linker='NetBSD (a.out) ld.so' + else + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + dynamic_linker='NetBSD ld.elf_so' + fi + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + +newsos6) + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +*nto* | *qnx*) + version_type=qnx + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='ldqnx.so' + ;; + +openbsd* | bitrig*) + version_type=sunos + sys_lib_dlsearch_path_spec=/usr/lib + need_lib_prefix=no + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then + need_version=no + else + need_version=yes + fi + library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +os2*) + libname_spec='$name' + version_type=windows + shrext_cmds=.dll + need_version=no + need_lib_prefix=no + # OS/2 can only load a DLL with a base name of 8 characters or less. + soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; + v=$($ECHO $release$versuffix | tr -d .-); + n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); + $ECHO $n$v`$shared_ext' + library_names_spec='${libname}_dll.$libext' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=BEGINLIBPATH + sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + postinstall_cmds='base_file=`basename \$file`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname~ + if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then + eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; + fi' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $RM \$dlpath' + ;; + +osf3* | osf4* | osf5*) + version_type=osf + need_lib_prefix=no + need_version=no + soname_spec='$libname$release$shared_ext$major' + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + +rdos*) + dynamic_linker=no + ;; + +solaris*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + # ldd complains unless libraries are executable + postinstall_cmds='chmod +x $lib' + ;; + +sunos4*) + version_type=sunos + library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' + finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + if test yes = "$with_gnu_ld"; then + need_lib_prefix=no + fi + need_version=yes + ;; + +sysv4 | sysv4.3*) + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + case $host_vendor in + sni) + shlibpath_overrides_runpath=no + need_lib_prefix=no + runpath_var=LD_RUN_PATH + ;; + siemens) + need_lib_prefix=no + ;; + motorola) + need_lib_prefix=no + need_version=no + shlibpath_overrides_runpath=no + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + ;; + esac + ;; + +sysv4*MP*) + if test -d /usr/nec; then + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext' + soname_spec='$libname$shared_ext.$major' + shlibpath_var=LD_LIBRARY_PATH + fi + ;; + +sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) + version_type=sco + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + if test yes = "$with_gnu_ld"; then + sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' + else + sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' + case $host_os in + sco3.2v5*) + sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" + ;; + esac + fi + sys_lib_dlsearch_path_spec='/usr/lib' + ;; + +tpf*) + # TPF is a cross-target only. Preferred cross-host = GNU/Linux. + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + +uts4*) + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +*) + dynamic_linker=no + ;; +esac +AC_MSG_RESULT([$dynamic_linker]) +test no = "$dynamic_linker" && can_build_shared=no + +variables_saved_for_relink="PATH $shlibpath_var $runpath_var" +if test yes = "$GCC"; then + variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" +fi + +if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then + sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec +fi + +if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then + sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec +fi + +# remember unaugmented sys_lib_dlsearch_path content for libtool script decls... +configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec + +# ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code +func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" + +# to be used as default LT_SYS_LIBRARY_PATH value in generated libtool +configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH + +_LT_DECL([], [variables_saved_for_relink], [1], + [Variables whose values should be saved in libtool wrapper scripts and + restored at link time]) +_LT_DECL([], [need_lib_prefix], [0], + [Do we need the "lib" prefix for modules?]) +_LT_DECL([], [need_version], [0], [Do we need a version for libraries?]) +_LT_DECL([], [version_type], [0], [Library versioning type]) +_LT_DECL([], [runpath_var], [0], [Shared library runtime path variable]) +_LT_DECL([], [shlibpath_var], [0],[Shared library path variable]) +_LT_DECL([], [shlibpath_overrides_runpath], [0], + [Is shlibpath searched before the hard-coded library search path?]) +_LT_DECL([], [libname_spec], [1], [Format of library name prefix]) +_LT_DECL([], [library_names_spec], [1], + [[List of archive names. First name is the real one, the rest are links. + The last name is the one that the linker finds with -lNAME]]) +_LT_DECL([], [soname_spec], [1], + [[The coded name of the library, if different from the real name]]) +_LT_DECL([], [install_override_mode], [1], + [Permission mode override for installation of shared libraries]) +_LT_DECL([], [postinstall_cmds], [2], + [Command to use after installation of a shared archive]) +_LT_DECL([], [postuninstall_cmds], [2], + [Command to use after uninstallation of a shared archive]) +_LT_DECL([], [finish_cmds], [2], + [Commands used to finish a libtool library installation in a directory]) +_LT_DECL([], [finish_eval], [1], + [[As "finish_cmds", except a single script fragment to be evaled but + not shown]]) +_LT_DECL([], [hardcode_into_libs], [0], + [Whether we should hardcode library paths into libraries]) +_LT_DECL([], [sys_lib_search_path_spec], [2], + [Compile-time system search path for libraries]) +_LT_DECL([sys_lib_dlsearch_path_spec], [configure_time_dlsearch_path], [2], + [Detected run-time system search path for libraries]) +_LT_DECL([], [configure_time_lt_sys_library_path], [2], + [Explicit LT_SYS_LIBRARY_PATH set during ./configure time]) +])# _LT_SYS_DYNAMIC_LINKER + + +# _LT_PATH_TOOL_PREFIX(TOOL) +# -------------------------- +# find a file program that can recognize shared library +AC_DEFUN([_LT_PATH_TOOL_PREFIX], +[m4_require([_LT_DECL_EGREP])dnl +AC_MSG_CHECKING([for $1]) +AC_CACHE_VAL(lt_cv_path_MAGIC_CMD, +[case $MAGIC_CMD in +[[\\/*] | ?:[\\/]*]) + lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. + ;; +*) + lt_save_MAGIC_CMD=$MAGIC_CMD + lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR +dnl $ac_dummy forces splitting on constant user-supplied paths. +dnl POSIX.2 word splitting is done only on the output of word expansions, +dnl not every word. This closes a longstanding sh security hole. + ac_dummy="m4_if([$2], , $PATH, [$2])" + for ac_dir in $ac_dummy; do + IFS=$lt_save_ifs + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$1"; then + lt_cv_path_MAGIC_CMD=$ac_dir/"$1" + if test -n "$file_magic_test_file"; then + case $deplibs_check_method in + "file_magic "*) + file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` + MAGIC_CMD=$lt_cv_path_MAGIC_CMD + if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | + $EGREP "$file_magic_regex" > /dev/null; then + : + else + cat <<_LT_EOF 1>&2 + +*** Warning: the command libtool uses to detect shared libraries, +*** $file_magic_cmd, produces output that libtool cannot recognize. +*** The result is that libtool may fail to recognize shared libraries +*** as such. This will affect the creation of libtool libraries that +*** depend on shared libraries, but programs linked with such libtool +*** libraries will work regardless of this problem. Nevertheless, you +*** may want to report the problem to your system manager and/or to +*** bug-libtool@gnu.org + +_LT_EOF + fi ;; + esac + fi + break + fi + done + IFS=$lt_save_ifs + MAGIC_CMD=$lt_save_MAGIC_CMD + ;; +esac]) +MAGIC_CMD=$lt_cv_path_MAGIC_CMD +if test -n "$MAGIC_CMD"; then + AC_MSG_RESULT($MAGIC_CMD) +else + AC_MSG_RESULT(no) +fi +_LT_DECL([], [MAGIC_CMD], [0], + [Used to examine libraries when file_magic_cmd begins with "file"])dnl +])# _LT_PATH_TOOL_PREFIX + +# Old name: +AU_ALIAS([AC_PATH_TOOL_PREFIX], [_LT_PATH_TOOL_PREFIX]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_PATH_TOOL_PREFIX], []) + + +# _LT_PATH_MAGIC +# -------------- +# find a file program that can recognize a shared library +m4_defun([_LT_PATH_MAGIC], +[_LT_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH) +if test -z "$lt_cv_path_MAGIC_CMD"; then + if test -n "$ac_tool_prefix"; then + _LT_PATH_TOOL_PREFIX(file, /usr/bin$PATH_SEPARATOR$PATH) + else + MAGIC_CMD=: + fi +fi +])# _LT_PATH_MAGIC + + +# LT_PATH_LD +# ---------- +# find the pathname to the GNU or non-GNU linker +AC_DEFUN([LT_PATH_LD], +[AC_REQUIRE([AC_PROG_CC])dnl +AC_REQUIRE([AC_CANONICAL_HOST])dnl +AC_REQUIRE([AC_CANONICAL_BUILD])dnl +m4_require([_LT_DECL_SED])dnl +m4_require([_LT_DECL_EGREP])dnl +m4_require([_LT_PROG_ECHO_BACKSLASH])dnl + +AC_ARG_WITH([gnu-ld], + [AS_HELP_STRING([--with-gnu-ld], + [assume the C compiler uses GNU ld @<:@default=no@:>@])], + [test no = "$withval" || with_gnu_ld=yes], + [with_gnu_ld=no])dnl + +ac_prog=ld +if test yes = "$GCC"; then + # Check if gcc -print-prog-name=ld gives a path. + AC_MSG_CHECKING([for ld used by $CC]) + case $host in + *-*-mingw*) + # gcc leaves a trailing carriage return, which upsets mingw + ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; + *) + ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; + esac + case $ac_prog in + # Accept absolute paths. + [[\\/]]* | ?:[[\\/]]*) + re_direlt='/[[^/]][[^/]]*/\.\./' + # Canonicalize the pathname of ld + ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` + while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do + ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` + done + test -z "$LD" && LD=$ac_prog + ;; + "") + # If it fails, then pretend we aren't using GCC. + ac_prog=ld + ;; + *) + # If it is relative, then search for the first ld in PATH. + with_gnu_ld=unknown + ;; + esac +elif test yes = "$with_gnu_ld"; then + AC_MSG_CHECKING([for GNU ld]) +else + AC_MSG_CHECKING([for non-GNU ld]) +fi +AC_CACHE_VAL(lt_cv_path_LD, +[if test -z "$LD"; then + lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR + for ac_dir in $PATH; do + IFS=$lt_save_ifs + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then + lt_cv_path_LD=$ac_dir/$ac_prog + # Check to see if the program is GNU ld. I'd rather use --version, + # but apparently some variants of GNU ld only accept -v. + # Break only if it was the GNU/non-GNU ld that we prefer. + case `"$lt_cv_path_LD" -v 2>&1 &1 conftest.i +cat conftest.i conftest.i >conftest2.i +: ${lt_DD:=$DD} +AC_PATH_PROGS_FEATURE_CHECK([lt_DD], [dd], +[if "$ac_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then + cmp -s conftest.i conftest.out \ + && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=: +fi]) +rm -f conftest.i conftest2.i conftest.out]) +])# _LT_PATH_DD + + +# _LT_CMD_TRUNCATE +# ---------------- +# find command to truncate a binary pipe +m4_defun([_LT_CMD_TRUNCATE], +[m4_require([_LT_PATH_DD]) +AC_CACHE_CHECK([how to truncate binary pipes], [lt_cv_truncate_bin], +[printf 0123456789abcdef0123456789abcdef >conftest.i +cat conftest.i conftest.i >conftest2.i +lt_cv_truncate_bin= +if "$ac_cv_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then + cmp -s conftest.i conftest.out \ + && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1" +fi +rm -f conftest.i conftest2.i conftest.out +test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q"]) +_LT_DECL([lt_truncate_bin], [lt_cv_truncate_bin], [1], + [Command to truncate a binary pipe]) +])# _LT_CMD_TRUNCATE + + +# _LT_CHECK_MAGIC_METHOD +# ---------------------- +# how to check for library dependencies +# -- PORTME fill in with the dynamic library characteristics +m4_defun([_LT_CHECK_MAGIC_METHOD], +[m4_require([_LT_DECL_EGREP]) +m4_require([_LT_DECL_OBJDUMP]) +AC_CACHE_CHECK([how to recognize dependent libraries], +lt_cv_deplibs_check_method, +[lt_cv_file_magic_cmd='$MAGIC_CMD' +lt_cv_file_magic_test_file= +lt_cv_deplibs_check_method='unknown' +# Need to set the preceding variable on all platforms that support +# interlibrary dependencies. +# 'none' -- dependencies not supported. +# 'unknown' -- same as none, but documents that we really don't know. +# 'pass_all' -- all dependencies passed with no checks. +# 'test_compile' -- check by making test program. +# 'file_magic [[regex]]' -- check by looking for files in library path +# that responds to the $file_magic_cmd with a given extended regex. +# If you have 'file' or equivalent on your system and you're not sure +# whether 'pass_all' will *always* work, you probably want this one. + +case $host_os in +aix[[4-9]]*) + lt_cv_deplibs_check_method=pass_all + ;; + +beos*) + lt_cv_deplibs_check_method=pass_all + ;; + +bsdi[[45]]*) + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib)' + lt_cv_file_magic_cmd='/usr/bin/file -L' + lt_cv_file_magic_test_file=/shlib/libc.so + ;; + +cygwin*) + # func_win32_libid is a shell function defined in ltmain.sh + lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' + lt_cv_file_magic_cmd='func_win32_libid' + ;; + +mingw* | pw32*) + # Base MSYS/MinGW do not provide the 'file' command needed by + # func_win32_libid shell function, so use a weaker test based on 'objdump', + # unless we find 'file', for example because we are cross-compiling. + if ( file / ) >/dev/null 2>&1; then + lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' + lt_cv_file_magic_cmd='func_win32_libid' + else + # Keep this pattern in sync with the one in func_win32_libid. + lt_cv_deplibs_check_method='file_magic file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' + lt_cv_file_magic_cmd='$OBJDUMP -f' + fi + ;; + +cegcc*) + # use the weaker test based on 'objdump'. See mingw*. + lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' + lt_cv_file_magic_cmd='$OBJDUMP -f' + ;; + +darwin* | rhapsody*) + lt_cv_deplibs_check_method=pass_all + ;; + +freebsd* | dragonfly*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then + case $host_cpu in + i*86 ) + # Not sure whether the presence of OpenBSD here was a mistake. + # Let's accept both of them until this is cleared up. + lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[[3-9]]86 (compact )?demand paged shared library' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` + ;; + esac + else + lt_cv_deplibs_check_method=pass_all + fi + ;; + +haiku*) + lt_cv_deplibs_check_method=pass_all + ;; + +hpux10.20* | hpux11*) + lt_cv_file_magic_cmd=/usr/bin/file + case $host_cpu in + ia64*) + lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|ELF-[[0-9]][[0-9]]) shared object file - IA64' + lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so + ;; + hppa*64*) + [lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF[ -][0-9][0-9])(-bit)?( [LM]SB)? shared object( file)?[, -]* PA-RISC [0-9]\.[0-9]'] + lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl + ;; + *) + lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|PA-RISC[[0-9]]\.[[0-9]]) shared library' + lt_cv_file_magic_test_file=/usr/lib/libc.sl + ;; + esac + ;; + +interix[[3-9]]*) + # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|\.a)$' + ;; + +irix5* | irix6* | nonstopux*) + case $LD in + *-32|*"-32 ") libmagic=32-bit;; + *-n32|*"-n32 ") libmagic=N32;; + *-64|*"-64 ") libmagic=64-bit;; + *) libmagic=never-match;; + esac + lt_cv_deplibs_check_method=pass_all + ;; + +# This must be glibc/ELF. +linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) + lt_cv_deplibs_check_method=pass_all + ;; + +netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' + else + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|_pic\.a)$' + fi + ;; + +newos6*) + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (executable|dynamic lib)' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=/usr/lib/libnls.so + ;; + +*nto* | *qnx*) + lt_cv_deplibs_check_method=pass_all + ;; + +openbsd* | bitrig*) + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|\.so|_pic\.a)$' + else + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' + fi + ;; + +osf3* | osf4* | osf5*) + lt_cv_deplibs_check_method=pass_all + ;; + +rdos*) + lt_cv_deplibs_check_method=pass_all + ;; + +solaris*) + lt_cv_deplibs_check_method=pass_all + ;; + +sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) + lt_cv_deplibs_check_method=pass_all + ;; + +sysv4 | sysv4.3*) + case $host_vendor in + motorola) + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib) M[[0-9]][[0-9]]* Version [[0-9]]' + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` + ;; + ncr) + lt_cv_deplibs_check_method=pass_all + ;; + sequent) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB (shared object|dynamic lib )' + ;; + sni) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method="file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB dynamic lib" + lt_cv_file_magic_test_file=/lib/libc.so + ;; + siemens) + lt_cv_deplibs_check_method=pass_all + ;; + pc) + lt_cv_deplibs_check_method=pass_all + ;; + esac + ;; + +tpf*) + lt_cv_deplibs_check_method=pass_all + ;; +os2*) + lt_cv_deplibs_check_method=pass_all + ;; +esac +]) + +file_magic_glob= +want_nocaseglob=no +if test "$build" = "$host"; then + case $host_os in + mingw* | pw32*) + if ( shopt | grep nocaseglob ) >/dev/null 2>&1; then + want_nocaseglob=yes + else + file_magic_glob=`echo aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ | $SED -e "s/\(..\)/s\/[[\1]]\/[[\1]]\/g;/g"` + fi + ;; + esac +fi + +file_magic_cmd=$lt_cv_file_magic_cmd +deplibs_check_method=$lt_cv_deplibs_check_method +test -z "$deplibs_check_method" && deplibs_check_method=unknown + +_LT_DECL([], [deplibs_check_method], [1], + [Method to check whether dependent libraries are shared objects]) +_LT_DECL([], [file_magic_cmd], [1], + [Command to use when deplibs_check_method = "file_magic"]) +_LT_DECL([], [file_magic_glob], [1], + [How to find potential files when deplibs_check_method = "file_magic"]) +_LT_DECL([], [want_nocaseglob], [1], + [Find potential files using nocaseglob when deplibs_check_method = "file_magic"]) +])# _LT_CHECK_MAGIC_METHOD + + +# LT_PATH_NM +# ---------- +# find the pathname to a BSD- or MS-compatible name lister +AC_DEFUN([LT_PATH_NM], +[AC_REQUIRE([AC_PROG_CC])dnl +AC_CACHE_CHECK([for BSD- or MS-compatible name lister (nm)], lt_cv_path_NM, +[if test -n "$NM"; then + # Let the user override the test. + lt_cv_path_NM=$NM +else + lt_nm_to_check=${ac_tool_prefix}nm + if test -n "$ac_tool_prefix" && test "$build" = "$host"; then + lt_nm_to_check="$lt_nm_to_check nm" + fi + for lt_tmp_nm in $lt_nm_to_check; do + lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR + for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do + IFS=$lt_save_ifs + test -z "$ac_dir" && ac_dir=. + tmp_nm=$ac_dir/$lt_tmp_nm + if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext"; then + # Check to see if the nm accepts a BSD-compat flag. + # Adding the 'sed 1q' prevents false positives on HP-UX, which says: + # nm: unknown option "B" ignored + # Tru64's nm complains that /dev/null is an invalid object file + # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty + case $build_os in + mingw*) lt_bad_file=conftest.nm/nofile ;; + *) lt_bad_file=/dev/null ;; + esac + case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in + *$lt_bad_file* | *'Invalid file or object type'*) + lt_cv_path_NM="$tmp_nm -B" + break 2 + ;; + *) + case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in + */dev/null*) + lt_cv_path_NM="$tmp_nm -p" + break 2 + ;; + *) + lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but + continue # so that we can try to find one that supports BSD flags + ;; + esac + ;; + esac + fi + done + IFS=$lt_save_ifs + done + : ${lt_cv_path_NM=no} +fi]) +if test no != "$lt_cv_path_NM"; then + NM=$lt_cv_path_NM +else + # Didn't find any BSD compatible name lister, look for dumpbin. + if test -n "$DUMPBIN"; then : + # Let the user override the test. + else + AC_CHECK_TOOLS(DUMPBIN, [dumpbin "link -dump"], :) + case `$DUMPBIN -symbols -headers /dev/null 2>&1 | sed '1q'` in + *COFF*) + DUMPBIN="$DUMPBIN -symbols -headers" + ;; + *) + DUMPBIN=: + ;; + esac + fi + AC_SUBST([DUMPBIN]) + if test : != "$DUMPBIN"; then + NM=$DUMPBIN + fi +fi +test -z "$NM" && NM=nm +AC_SUBST([NM]) +_LT_DECL([], [NM], [1], [A BSD- or MS-compatible name lister])dnl + +AC_CACHE_CHECK([the name lister ($NM) interface], [lt_cv_nm_interface], + [lt_cv_nm_interface="BSD nm" + echo "int some_variable = 0;" > conftest.$ac_ext + (eval echo "\"\$as_me:$LINENO: $ac_compile\"" >&AS_MESSAGE_LOG_FD) + (eval "$ac_compile" 2>conftest.err) + cat conftest.err >&AS_MESSAGE_LOG_FD + (eval echo "\"\$as_me:$LINENO: $NM \\\"conftest.$ac_objext\\\"\"" >&AS_MESSAGE_LOG_FD) + (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) + cat conftest.err >&AS_MESSAGE_LOG_FD + (eval echo "\"\$as_me:$LINENO: output\"" >&AS_MESSAGE_LOG_FD) + cat conftest.out >&AS_MESSAGE_LOG_FD + if $GREP 'External.*some_variable' conftest.out > /dev/null; then + lt_cv_nm_interface="MS dumpbin" + fi + rm -f conftest*]) +])# LT_PATH_NM + +# Old names: +AU_ALIAS([AM_PROG_NM], [LT_PATH_NM]) +AU_ALIAS([AC_PROG_NM], [LT_PATH_NM]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AM_PROG_NM], []) +dnl AC_DEFUN([AC_PROG_NM], []) + +# _LT_CHECK_SHAREDLIB_FROM_LINKLIB +# -------------------------------- +# how to determine the name of the shared library +# associated with a specific link library. +# -- PORTME fill in with the dynamic library characteristics +m4_defun([_LT_CHECK_SHAREDLIB_FROM_LINKLIB], +[m4_require([_LT_DECL_EGREP]) +m4_require([_LT_DECL_OBJDUMP]) +m4_require([_LT_DECL_DLLTOOL]) +AC_CACHE_CHECK([how to associate runtime and link libraries], +lt_cv_sharedlib_from_linklib_cmd, +[lt_cv_sharedlib_from_linklib_cmd='unknown' + +case $host_os in +cygwin* | mingw* | pw32* | cegcc*) + # two different shell functions defined in ltmain.sh; + # decide which one to use based on capabilities of $DLLTOOL + case `$DLLTOOL --help 2>&1` in + *--identify-strict*) + lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib + ;; + *) + lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib_fallback + ;; + esac + ;; +*) + # fallback: assume linklib IS sharedlib + lt_cv_sharedlib_from_linklib_cmd=$ECHO + ;; +esac +]) +sharedlib_from_linklib_cmd=$lt_cv_sharedlib_from_linklib_cmd +test -z "$sharedlib_from_linklib_cmd" && sharedlib_from_linklib_cmd=$ECHO + +_LT_DECL([], [sharedlib_from_linklib_cmd], [1], + [Command to associate shared and link libraries]) +])# _LT_CHECK_SHAREDLIB_FROM_LINKLIB + + +# _LT_PATH_MANIFEST_TOOL +# ---------------------- +# locate the manifest tool +m4_defun([_LT_PATH_MANIFEST_TOOL], +[AC_CHECK_TOOL(MANIFEST_TOOL, mt, :) +test -z "$MANIFEST_TOOL" && MANIFEST_TOOL=mt +AC_CACHE_CHECK([if $MANIFEST_TOOL is a manifest tool], [lt_cv_path_mainfest_tool], + [lt_cv_path_mainfest_tool=no + echo "$as_me:$LINENO: $MANIFEST_TOOL '-?'" >&AS_MESSAGE_LOG_FD + $MANIFEST_TOOL '-?' 2>conftest.err > conftest.out + cat conftest.err >&AS_MESSAGE_LOG_FD + if $GREP 'Manifest Tool' conftest.out > /dev/null; then + lt_cv_path_mainfest_tool=yes + fi + rm -f conftest*]) +if test yes != "$lt_cv_path_mainfest_tool"; then + MANIFEST_TOOL=: +fi +_LT_DECL([], [MANIFEST_TOOL], [1], [Manifest tool])dnl +])# _LT_PATH_MANIFEST_TOOL + + +# _LT_DLL_DEF_P([FILE]) +# --------------------- +# True iff FILE is a Windows DLL '.def' file. +# Keep in sync with func_dll_def_p in the libtool script +AC_DEFUN([_LT_DLL_DEF_P], +[dnl + test DEF = "`$SED -n dnl + -e '\''s/^[[ ]]*//'\'' dnl Strip leading whitespace + -e '\''/^\(;.*\)*$/d'\'' dnl Delete empty lines and comments + -e '\''s/^\(EXPORTS\|LIBRARY\)\([[ ]].*\)*$/DEF/p'\'' dnl + -e q dnl Only consider the first "real" line + $1`" dnl +])# _LT_DLL_DEF_P + + +# LT_LIB_M +# -------- +# check for math library +AC_DEFUN([LT_LIB_M], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +LIBM= +case $host in +*-*-beos* | *-*-cegcc* | *-*-cygwin* | *-*-haiku* | *-*-pw32* | *-*-darwin*) + # These system don't have libm, or don't need it + ;; +*-ncr-sysv4.3*) + AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM=-lmw) + AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm") + ;; +*) + AC_CHECK_LIB(m, cos, LIBM=-lm) + ;; +esac +AC_SUBST([LIBM]) +])# LT_LIB_M + +# Old name: +AU_ALIAS([AC_CHECK_LIBM], [LT_LIB_M]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_CHECK_LIBM], []) + + +# _LT_COMPILER_NO_RTTI([TAGNAME]) +# ------------------------------- +m4_defun([_LT_COMPILER_NO_RTTI], +[m4_require([_LT_TAG_COMPILER])dnl + +_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= + +if test yes = "$GCC"; then + case $cc_basename in + nvcc*) + _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -Xcompiler -fno-builtin' ;; + *) + _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' ;; + esac + + _LT_COMPILER_OPTION([if $compiler supports -fno-rtti -fno-exceptions], + lt_cv_prog_compiler_rtti_exceptions, + [-fno-rtti -fno-exceptions], [], + [_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)="$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) -fno-rtti -fno-exceptions"]) +fi +_LT_TAGDECL([no_builtin_flag], [lt_prog_compiler_no_builtin_flag], [1], + [Compiler flag to turn off builtin functions]) +])# _LT_COMPILER_NO_RTTI + + +# _LT_CMD_GLOBAL_SYMBOLS +# ---------------------- +m4_defun([_LT_CMD_GLOBAL_SYMBOLS], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +AC_REQUIRE([AC_PROG_CC])dnl +AC_REQUIRE([AC_PROG_AWK])dnl +AC_REQUIRE([LT_PATH_NM])dnl +AC_REQUIRE([LT_PATH_LD])dnl +m4_require([_LT_DECL_SED])dnl +m4_require([_LT_DECL_EGREP])dnl +m4_require([_LT_TAG_COMPILER])dnl + +# Check for command to grab the raw symbol name followed by C symbol from nm. +AC_MSG_CHECKING([command to parse $NM output from $compiler object]) +AC_CACHE_VAL([lt_cv_sys_global_symbol_pipe], +[ +# These are sane defaults that work on at least a few old systems. +# [They come from Ultrix. What could be older than Ultrix?!! ;)] + +# Character class describing NM global symbol codes. +symcode='[[BCDEGRST]]' + +# Regexp to match symbols that can be accessed directly from C. +sympat='\([[_A-Za-z]][[_A-Za-z0-9]]*\)' + +# Define system-specific variables. +case $host_os in +aix*) + symcode='[[BCDT]]' + ;; +cygwin* | mingw* | pw32* | cegcc*) + symcode='[[ABCDGISTW]]' + ;; +hpux*) + if test ia64 = "$host_cpu"; then + symcode='[[ABCDEGRST]]' + fi + ;; +irix* | nonstopux*) + symcode='[[BCDEGRST]]' + ;; +osf*) + symcode='[[BCDEGQRST]]' + ;; +solaris*) + symcode='[[BDRT]]' + ;; +sco3.2v5*) + symcode='[[DT]]' + ;; +sysv4.2uw2*) + symcode='[[DT]]' + ;; +sysv5* | sco5v6* | unixware* | OpenUNIX*) + symcode='[[ABDT]]' + ;; +sysv4) + symcode='[[DFNSTU]]' + ;; +esac + +# If we're using GNU nm, then use its standard symbol codes. +case `$NM -V 2>&1` in +*GNU* | *'with BFD'*) + symcode='[[ABCDGIRSTW]]' ;; +esac + +if test "$lt_cv_nm_interface" = "MS dumpbin"; then + # Gets list of data symbols to import. + lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'" + # Adjust the below global symbol transforms to fixup imported variables. + lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'" + lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'" + lt_c_name_lib_hook="\ + -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\ + -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'" +else + # Disable hooks by default. + lt_cv_sys_global_symbol_to_import= + lt_cdecl_hook= + lt_c_name_hook= + lt_c_name_lib_hook= +fi + +# Transform an extracted symbol line into a proper C declaration. +# Some systems (esp. on ia64) link data and code symbols differently, +# so use this general approach. +lt_cv_sys_global_symbol_to_cdecl="sed -n"\ +$lt_cdecl_hook\ +" -e 's/^T .* \(.*\)$/extern int \1();/p'"\ +" -e 's/^$symcode$symcode* .* \(.*\)$/extern char \1;/p'" + +# Transform an extracted symbol line into symbol name and symbol address +lt_cv_sys_global_symbol_to_c_name_address="sed -n"\ +$lt_c_name_hook\ +" -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ +" -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'" + +# Transform an extracted symbol line into symbol name with lib prefix and +# symbol address. +lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\ +$lt_c_name_lib_hook\ +" -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ +" -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\ +" -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/p'" + +# Handle CRLF in mingw tool chain +opt_cr= +case $build_os in +mingw*) + opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp + ;; +esac + +# Try without a prefix underscore, then with it. +for ac_symprfx in "" "_"; do + + # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. + symxfrm="\\1 $ac_symprfx\\2 \\2" + + # Write the raw and C identifiers. + if test "$lt_cv_nm_interface" = "MS dumpbin"; then + # Fake it for dumpbin and say T for any non-static function, + # D for any global variable and I for any imported variable. + # Also find C++ and __fastcall symbols from MSVC++ or ICC, + # which start with @ or ?. + lt_cv_sys_global_symbol_pipe="$AWK ['"\ +" {last_section=section; section=\$ 3};"\ +" /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\ +" /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ +" /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\ +" /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\ +" /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\ +" \$ 0!~/External *\|/{next};"\ +" / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ +" {if(hide[section]) next};"\ +" {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\ +" {split(\$ 0,a,/\||\r/); split(a[2],s)};"\ +" s[1]~/^[@?]/{print f,s[1],s[1]; next};"\ +" s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\ +" ' prfx=^$ac_symprfx]" + else + lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[[ ]]\($symcode$symcode*\)[[ ]][[ ]]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" + fi + lt_cv_sys_global_symbol_pipe="$lt_cv_sys_global_symbol_pipe | sed '/ __gnu_lto/d'" + + # Check to see that the pipe works correctly. + pipe_works=no + + rm -f conftest* + cat > conftest.$ac_ext <<_LT_EOF +#ifdef __cplusplus +extern "C" { +#endif +char nm_test_var; +void nm_test_func(void); +void nm_test_func(void){} +#ifdef __cplusplus +} +#endif +int main(){nm_test_var='a';nm_test_func();return(0);} +_LT_EOF + + if AC_TRY_EVAL(ac_compile); then + # Now try to grab the symbols. + nlist=conftest.nm + if AC_TRY_EVAL(NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) && test -s "$nlist"; then + # Try sorting and uniquifying the output. + if sort "$nlist" | uniq > "$nlist"T; then + mv -f "$nlist"T "$nlist" + else + rm -f "$nlist"T + fi + + # Make sure that we snagged all the symbols we need. + if $GREP ' nm_test_var$' "$nlist" >/dev/null; then + if $GREP ' nm_test_func$' "$nlist" >/dev/null; then + cat <<_LT_EOF > conftest.$ac_ext +/* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ +#if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE +/* DATA imports from DLLs on WIN32 can't be const, because runtime + relocations are performed -- see ld's documentation on pseudo-relocs. */ +# define LT@&t@_DLSYM_CONST +#elif defined __osf__ +/* This system does not cope well with relocations in const data. */ +# define LT@&t@_DLSYM_CONST +#else +# define LT@&t@_DLSYM_CONST const +#endif + +#ifdef __cplusplus +extern "C" { +#endif + +_LT_EOF + # Now generate the symbol file. + eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' + + cat <<_LT_EOF >> conftest.$ac_ext + +/* The mapping between symbol names and symbols. */ +LT@&t@_DLSYM_CONST struct { + const char *name; + void *address; +} +lt__PROGRAM__LTX_preloaded_symbols[[]] = +{ + { "@PROGRAM@", (void *) 0 }, +_LT_EOF + $SED "s/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext + cat <<\_LT_EOF >> conftest.$ac_ext + {0, (void *) 0} +}; + +/* This works around a problem in FreeBSD linker */ +#ifdef FREEBSD_WORKAROUND +static const void *lt_preloaded_setup() { + return lt__PROGRAM__LTX_preloaded_symbols; +} +#endif + +#ifdef __cplusplus +} +#endif +_LT_EOF + # Now try linking the two files. + mv conftest.$ac_objext conftstm.$ac_objext + lt_globsym_save_LIBS=$LIBS + lt_globsym_save_CFLAGS=$CFLAGS + LIBS=conftstm.$ac_objext + CFLAGS="$CFLAGS$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)" + if AC_TRY_EVAL(ac_link) && test -s conftest$ac_exeext; then + pipe_works=yes + fi + LIBS=$lt_globsym_save_LIBS + CFLAGS=$lt_globsym_save_CFLAGS + else + echo "cannot find nm_test_func in $nlist" >&AS_MESSAGE_LOG_FD + fi + else + echo "cannot find nm_test_var in $nlist" >&AS_MESSAGE_LOG_FD + fi + else + echo "cannot run $lt_cv_sys_global_symbol_pipe" >&AS_MESSAGE_LOG_FD + fi + else + echo "$progname: failed program was:" >&AS_MESSAGE_LOG_FD + cat conftest.$ac_ext >&5 + fi + rm -rf conftest* conftst* + + # Do not use the global_symbol_pipe unless it works. + if test yes = "$pipe_works"; then + break + else + lt_cv_sys_global_symbol_pipe= + fi +done +]) +if test -z "$lt_cv_sys_global_symbol_pipe"; then + lt_cv_sys_global_symbol_to_cdecl= +fi +if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then + AC_MSG_RESULT(failed) +else + AC_MSG_RESULT(ok) +fi + +# Response file support. +if test "$lt_cv_nm_interface" = "MS dumpbin"; then + nm_file_list_spec='@' +elif $NM --help 2>/dev/null | grep '[[@]]FILE' >/dev/null; then + nm_file_list_spec='@' +fi + +_LT_DECL([global_symbol_pipe], [lt_cv_sys_global_symbol_pipe], [1], + [Take the output of nm and produce a listing of raw symbols and C names]) +_LT_DECL([global_symbol_to_cdecl], [lt_cv_sys_global_symbol_to_cdecl], [1], + [Transform the output of nm in a proper C declaration]) +_LT_DECL([global_symbol_to_import], [lt_cv_sys_global_symbol_to_import], [1], + [Transform the output of nm into a list of symbols to manually relocate]) +_LT_DECL([global_symbol_to_c_name_address], + [lt_cv_sys_global_symbol_to_c_name_address], [1], + [Transform the output of nm in a C name address pair]) +_LT_DECL([global_symbol_to_c_name_address_lib_prefix], + [lt_cv_sys_global_symbol_to_c_name_address_lib_prefix], [1], + [Transform the output of nm in a C name address pair when lib prefix is needed]) +_LT_DECL([nm_interface], [lt_cv_nm_interface], [1], + [The name lister interface]) +_LT_DECL([], [nm_file_list_spec], [1], + [Specify filename containing input files for $NM]) +]) # _LT_CMD_GLOBAL_SYMBOLS + + +# _LT_COMPILER_PIC([TAGNAME]) +# --------------------------- +m4_defun([_LT_COMPILER_PIC], +[m4_require([_LT_TAG_COMPILER])dnl +_LT_TAGVAR(lt_prog_compiler_wl, $1)= +_LT_TAGVAR(lt_prog_compiler_pic, $1)= +_LT_TAGVAR(lt_prog_compiler_static, $1)= + +m4_if([$1], [CXX], [ + # C++ specific cases for pic, static, wl, etc. + if test yes = "$GXX"; then + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test ia64 = "$host_cpu"; then + # AIX 5 now supports IA64 processor + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + m68k) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the '-m68020' flag to GCC prevents building anything better, + # like '-m68040'. + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' + ;; + esac + ;; + + beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + mingw* | cygwin* | os2* | pw32* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + # Although the cygwin gcc ignores -fPIC, still need this for old-style + # (--disable-auto-import) libraries + m4_if([$1], [GCJ], [], + [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) + case $host_os in + os2*) + _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' + ;; + esac + ;; + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' + ;; + *djgpp*) + # DJGPP does not support shared libraries at all + _LT_TAGVAR(lt_prog_compiler_pic, $1)= + ;; + haiku*) + # PIC is the default for Haiku. + # The "-static" flag exists, but is broken. + _LT_TAGVAR(lt_prog_compiler_static, $1)= + ;; + interix[[3-9]]*) + # Interix 3.x gcc -fpic/-fPIC options generate broken code. + # Instead, we relocate shared libraries at runtime. + ;; + sysv4*MP*) + if test -d /usr/nec; then + _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic + fi + ;; + hpux*) + # PIC is the default for 64-bit PA HP-UX, but not for 32-bit + # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag + # sets the default TLS model and affects inlining. + case $host_cpu in + hppa*64*) + ;; + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + ;; + *qnx* | *nto*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' + ;; + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + else + case $host_os in + aix[[4-9]]*) + # All AIX code is PIC. + if test ia64 = "$host_cpu"; then + # AIX 5 now supports IA64 processor + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + else + _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' + fi + ;; + chorus*) + case $cc_basename in + cxch68*) + # Green Hills C++ Compiler + # _LT_TAGVAR(lt_prog_compiler_static, $1)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" + ;; + esac + ;; + mingw* | cygwin* | os2* | pw32* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + m4_if([$1], [GCJ], [], + [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) + ;; + dgux*) + case $cc_basename in + ec++*) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + ;; + ghcx*) + # Green Hills C++ Compiler + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + ;; + *) + ;; + esac + ;; + freebsd* | dragonfly*) + # FreeBSD uses GNU C++ + ;; + hpux9* | hpux10* | hpux11*) + case $cc_basename in + CC*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' + if test ia64 != "$host_cpu"; then + _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' + fi + ;; + aCC*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' + ;; + esac + ;; + *) + ;; + esac + ;; + interix*) + # This is c89, which is MS Visual C++ (no shared libs) + # Anyone wants to do a port? + ;; + irix5* | irix6* | nonstopux*) + case $cc_basename in + CC*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + # CC pic flag -KPIC is the default. + ;; + *) + ;; + esac + ;; + linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) + case $cc_basename in + KCC*) + # KAI C++ Compiler + _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + ecpc* ) + # old Intel C++ for x86_64, which still supported -KPIC. + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + icpc* ) + # Intel C++, used to be incompatible with GCC. + # ICC 10 doesn't accept -KPIC any more. + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + pgCC* | pgcpp*) + # Portland Group C++ compiler + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + cxx*) + # Compaq C++ + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + _LT_TAGVAR(lt_prog_compiler_pic, $1)= + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + xlc* | xlC* | bgxl[[cC]]* | mpixl[[cC]]*) + # IBM XL 8.0, 9.0 on PPC and BlueGene + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' + ;; + *) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) + # Sun C++ 5.9 + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' + ;; + esac + ;; + esac + ;; + lynxos*) + ;; + m88k*) + ;; + mvs*) + case $cc_basename in + cxx*) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-W c,exportall' + ;; + *) + ;; + esac + ;; + netbsd*) + ;; + *qnx* | *nto*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' + ;; + osf3* | osf4* | osf5*) + case $cc_basename in + KCC*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' + ;; + RCC*) + # Rational C++ 2.4.1 + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + ;; + cxx*) + # Digital/Compaq C++ + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + _LT_TAGVAR(lt_prog_compiler_pic, $1)= + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + *) + ;; + esac + ;; + psos*) + ;; + solaris*) + case $cc_basename in + CC* | sunCC*) + # Sun C++ 4.2, 5.x and Centerline C++ + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' + ;; + gcx*) + # Green Hills C++ Compiler + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' + ;; + *) + ;; + esac + ;; + sunos4*) + case $cc_basename in + CC*) + # Sun C++ 4.x + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + lcc*) + # Lucid + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + ;; + *) + ;; + esac + ;; + sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) + case $cc_basename in + CC*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + esac + ;; + tandem*) + case $cc_basename in + NCC*) + # NonStop-UX NCC 3.20 + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + ;; + *) + ;; + esac + ;; + vxworks*) + ;; + *) + _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + ;; + esac + fi +], +[ + if test yes = "$GCC"; then + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test ia64 = "$host_cpu"; then + # AIX 5 now supports IA64 processor + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + m68k) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the '-m68020' flag to GCC prevents building anything better, + # like '-m68040'. + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' + ;; + esac + ;; + + beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + + mingw* | cygwin* | pw32* | os2* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + # Although the cygwin gcc ignores -fPIC, still need this for old-style + # (--disable-auto-import) libraries + m4_if([$1], [GCJ], [], + [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) + case $host_os in + os2*) + _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' + ;; + esac + ;; + + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' + ;; + + haiku*) + # PIC is the default for Haiku. + # The "-static" flag exists, but is broken. + _LT_TAGVAR(lt_prog_compiler_static, $1)= + ;; + + hpux*) + # PIC is the default for 64-bit PA HP-UX, but not for 32-bit + # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag + # sets the default TLS model and affects inlining. + case $host_cpu in + hppa*64*) + # +Z the default + ;; + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + ;; + + interix[[3-9]]*) + # Interix 3.x gcc -fpic/-fPIC options generate broken code. + # Instead, we relocate shared libraries at runtime. + ;; + + msdosdjgpp*) + # Just because we use GCC doesn't mean we suddenly get shared libraries + # on systems that don't support them. + _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + enable_shared=no + ;; + + *nto* | *qnx*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic + fi + ;; + + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + + case $cc_basename in + nvcc*) # Cuda Compiler Driver 2.2 + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Xlinker ' + if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then + _LT_TAGVAR(lt_prog_compiler_pic, $1)="-Xcompiler $_LT_TAGVAR(lt_prog_compiler_pic, $1)" + fi + ;; + esac + else + # PORTME Check for flag to pass linker flags through the system compiler. + case $host_os in + aix*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + if test ia64 = "$host_cpu"; then + # AIX 5 now supports IA64 processor + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + else + _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' + fi + ;; + + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' + case $cc_basename in + nagfor*) + # NAG Fortran compiler + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,-Wl,,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + esac + ;; + + mingw* | cygwin* | pw32* | os2* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + m4_if([$1], [GCJ], [], + [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) + case $host_os in + os2*) + _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' + ;; + esac + ;; + + hpux9* | hpux10* | hpux11*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' + ;; + esac + # Is there a better lt_prog_compiler_static that works with the bundled CC? + _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' + ;; + + irix5* | irix6* | nonstopux*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # PIC (with -KPIC) is the default. + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + + linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) + case $cc_basename in + # old Intel for x86_64, which still supported -KPIC. + ecc*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + # icc used to be incompatible with GCC. + # ICC 10 doesn't accept -KPIC any more. + icc* | ifort*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + # Lahey Fortran 8.1. + lf95*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='--shared' + _LT_TAGVAR(lt_prog_compiler_static, $1)='--static' + ;; + nagfor*) + # NAG Fortran compiler + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,-Wl,,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + tcc*) + # Fabrice Bellard et al's Tiny C Compiler + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) + # Portland Group compilers (*not* the Pentium gcc compiler, + # which looks to be a dead project) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + ccc*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # All Alpha code is PIC. + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + xl* | bgxl* | bgf* | mpixl*) + # IBM XL C 8.0/Fortran 10.1, 11.1 on PPC and BlueGene + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' + ;; + *) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ Ceres\ Fortran* | *Sun*Fortran*\ [[1-7]].* | *Sun*Fortran*\ 8.[[0-3]]*) + # Sun Fortran 8.3 passes all unrecognized flags to the linker + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + _LT_TAGVAR(lt_prog_compiler_wl, $1)='' + ;; + *Sun\ F* | *Sun*Fortran*) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' + ;; + *Sun\ C*) + # Sun C 5.9 + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + ;; + *Intel*\ [[CF]]*Compiler*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + *Portland\ Group*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + esac + ;; + esac + ;; + + newsos6) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + *nto* | *qnx*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' + ;; + + osf3* | osf4* | osf5*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # All OSF/1 code is PIC. + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + + rdos*) + _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + + solaris*) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + case $cc_basename in + f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ';; + *) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,';; + esac + ;; + + sunos4*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + sysv4 | sysv4.2uw2* | sysv4.3*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-Kconform_pic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + ;; + + sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + unicos*) + _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + ;; + + uts4*) + _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + *) + _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + ;; + esac + fi +]) +case $host_os in + # For platforms that do not support PIC, -DPIC is meaningless: + *djgpp*) + _LT_TAGVAR(lt_prog_compiler_pic, $1)= + ;; + *) + _LT_TAGVAR(lt_prog_compiler_pic, $1)="$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])" + ;; +esac + +AC_CACHE_CHECK([for $compiler option to produce PIC], + [_LT_TAGVAR(lt_cv_prog_compiler_pic, $1)], + [_LT_TAGVAR(lt_cv_prog_compiler_pic, $1)=$_LT_TAGVAR(lt_prog_compiler_pic, $1)]) +_LT_TAGVAR(lt_prog_compiler_pic, $1)=$_LT_TAGVAR(lt_cv_prog_compiler_pic, $1) + +# +# Check to make sure the PIC flag actually works. +# +if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then + _LT_COMPILER_OPTION([if $compiler PIC flag $_LT_TAGVAR(lt_prog_compiler_pic, $1) works], + [_LT_TAGVAR(lt_cv_prog_compiler_pic_works, $1)], + [$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])], [], + [case $_LT_TAGVAR(lt_prog_compiler_pic, $1) in + "" | " "*) ;; + *) _LT_TAGVAR(lt_prog_compiler_pic, $1)=" $_LT_TAGVAR(lt_prog_compiler_pic, $1)" ;; + esac], + [_LT_TAGVAR(lt_prog_compiler_pic, $1)= + _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no]) +fi +_LT_TAGDECL([pic_flag], [lt_prog_compiler_pic], [1], + [Additional compiler flags for building library objects]) + +_LT_TAGDECL([wl], [lt_prog_compiler_wl], [1], + [How to pass a linker flag through the compiler]) +# +# Check to make sure the static flag actually works. +# +wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) eval lt_tmp_static_flag=\"$_LT_TAGVAR(lt_prog_compiler_static, $1)\" +_LT_LINKER_OPTION([if $compiler static flag $lt_tmp_static_flag works], + _LT_TAGVAR(lt_cv_prog_compiler_static_works, $1), + $lt_tmp_static_flag, + [], + [_LT_TAGVAR(lt_prog_compiler_static, $1)=]) +_LT_TAGDECL([link_static_flag], [lt_prog_compiler_static], [1], + [Compiler flag to prevent dynamic linking]) +])# _LT_COMPILER_PIC + + +# _LT_LINKER_SHLIBS([TAGNAME]) +# ---------------------------- +# See if the linker supports building shared libraries. +m4_defun([_LT_LINKER_SHLIBS], +[AC_REQUIRE([LT_PATH_LD])dnl +AC_REQUIRE([LT_PATH_NM])dnl +m4_require([_LT_PATH_MANIFEST_TOOL])dnl +m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_DECL_EGREP])dnl +m4_require([_LT_DECL_SED])dnl +m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl +m4_require([_LT_TAG_COMPILER])dnl +AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) +m4_if([$1], [CXX], [ + _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] + case $host_os in + aix[[4-9]]*) + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to GNU nm, but means don't demangle to AIX nm. + # Without the "-l" option, or with the "-B" option, AIX nm treats + # weak defined symbols like other global defined symbols, whereas + # GNU nm marks them as "W". + # While the 'weak' keyword is ignored in the Export File, we need + # it in the Import File for the 'aix-soname' feature, so we have + # to replace the "-B" option with "-P" for AIX nm. + if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then + _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' + else + _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "L") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' + fi + ;; + pw32*) + _LT_TAGVAR(export_symbols_cmds, $1)=$ltdll_cmds + ;; + cygwin* | mingw* | cegcc*) + case $cc_basename in + cl* | icl*) + _LT_TAGVAR(exclude_expsyms, $1)='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' + ;; + *) + _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols' + _LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'] + ;; + esac + ;; + *) + _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + ;; + esac +], [ + runpath_var= + _LT_TAGVAR(allow_undefined_flag, $1)= + _LT_TAGVAR(always_export_symbols, $1)=no + _LT_TAGVAR(archive_cmds, $1)= + _LT_TAGVAR(archive_expsym_cmds, $1)= + _LT_TAGVAR(compiler_needs_object, $1)=no + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no + _LT_TAGVAR(export_dynamic_flag_spec, $1)= + _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + _LT_TAGVAR(hardcode_automatic, $1)=no + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_direct_absolute, $1)=no + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= + _LT_TAGVAR(hardcode_libdir_separator, $1)= + _LT_TAGVAR(hardcode_minus_L, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported + _LT_TAGVAR(inherit_rpath, $1)=no + _LT_TAGVAR(link_all_deplibs, $1)=unknown + _LT_TAGVAR(module_cmds, $1)= + _LT_TAGVAR(module_expsym_cmds, $1)= + _LT_TAGVAR(old_archive_from_new_cmds, $1)= + _LT_TAGVAR(old_archive_from_expsyms_cmds, $1)= + _LT_TAGVAR(thread_safe_flag_spec, $1)= + _LT_TAGVAR(whole_archive_flag_spec, $1)= + # include_expsyms should be a list of space-separated symbols to be *always* + # included in the symbol list + _LT_TAGVAR(include_expsyms, $1)= + # exclude_expsyms can be an extended regexp of symbols to exclude + # it will be wrapped by ' (' and ')$', so one must not match beginning or + # end of line. Example: 'a|bc|.*d.*' will exclude the symbols 'a' and 'bc', + # as well as any symbol that contains 'd'. + _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] + # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out + # platforms (ab)use it in PIC code, but their linkers get confused if + # the symbol is explicitly referenced. Since portable code cannot + # rely on this symbol name, it's probably fine to never include it in + # preloaded symbol tables. + # Exclude shared library initialization/finalization symbols. +dnl Note also adjust exclude_expsyms for C++ above. + extract_expsyms_cmds= + + case $host_os in + cygwin* | mingw* | pw32* | cegcc*) + # FIXME: the MSVC++ and ICC port hasn't been tested in a loooong time + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++ or Intel C++ Compiler. + if test yes != "$GCC"; then + with_gnu_ld=no + fi + ;; + interix*) + # we just hope/assume this is gcc and not c89 (= MSVC++ or ICC) + with_gnu_ld=yes + ;; + openbsd* | bitrig*) + with_gnu_ld=no + ;; + esac + + _LT_TAGVAR(ld_shlibs, $1)=yes + + # On some targets, GNU ld is compatible enough with the native linker + # that we're better off using the native interface for both. + lt_use_gnu_ld_interface=no + if test yes = "$with_gnu_ld"; then + case $host_os in + aix*) + # The AIX port of GNU ld has always aspired to compatibility + # with the native linker. However, as the warning in the GNU ld + # block says, versions before 2.19.5* couldn't really create working + # shared libraries, regardless of the interface used. + case `$LD -v 2>&1` in + *\ \(GNU\ Binutils\)\ 2.19.5*) ;; + *\ \(GNU\ Binutils\)\ 2.[[2-9]]*) ;; + *\ \(GNU\ Binutils\)\ [[3-9]]*) ;; + *) + lt_use_gnu_ld_interface=yes + ;; + esac + ;; + *) + lt_use_gnu_ld_interface=yes + ;; + esac + fi + + if test yes = "$lt_use_gnu_ld_interface"; then + # If archive_cmds runs LD, not CC, wlarc should be empty + wlarc='$wl' + + # Set some defaults for GNU ld with shared library support. These + # are reset later if shared libraries are not supported. Putting them + # here allows them to be overridden if necessary. + runpath_var=LD_RUN_PATH + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' + # ancient GNU ld didn't support --whole-archive et. al. + if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then + _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' + else + _LT_TAGVAR(whole_archive_flag_spec, $1)= + fi + supports_anon_versioning=no + case `$LD -v | $SED -e 's/([^)]\+)\s\+//' 2>&1` in + *GNU\ gold*) supports_anon_versioning=yes ;; + *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.10.*) ;; # catch versions < 2.11 + *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... + *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... + *\ 2.11.*) ;; # other 2.11 versions + *) supports_anon_versioning=yes ;; + esac + + # See if GNU ld supports shared libraries. + case $host_os in + aix[[3-9]]*) + # On AIX/PPC, the GNU linker is very broken + if test ia64 != "$host_cpu"; then + _LT_TAGVAR(ld_shlibs, $1)=no + cat <<_LT_EOF 1>&2 + +*** Warning: the GNU linker, at least up to release 2.19, is reported +*** to be unable to reliably create shared libraries on AIX. +*** Therefore, libtool is disabling shared libraries support. If you +*** really care for shared libraries, you may want to install binutils +*** 2.20 or above, or modify your PATH so that a non-GNU linker is found. +*** You will then need to restart the configuration process. + +_LT_EOF + fi + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='' + ;; + m68k) + _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_minus_L, $1)=yes + ;; + esac + ;; + + beos*) + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + cygwin* | mingw* | pw32* | cegcc*) + # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, + # as there is no search path for DLLs. + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols' + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_TAGVAR(always_export_symbols, $1)=no + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols' + _LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'] + + if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + # If the export-symbols file already is a .def file, use it as + # is; otherwise, prepend EXPORTS... + _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + haiku*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(link_all_deplibs, $1)=yes + ;; + + os2*) + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + shrext_cmds=.dll + _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + prefix_cmds="$SED"~ + if test EXPORTS = "`$SED 1q $export_symbols`"; then + prefix_cmds="$prefix_cmds -e 1d"; + fi~ + prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ + cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + _LT_TAGVAR(file_list_spec, $1)='@' + ;; + + interix[[3-9]]*) + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' + # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. + # Instead, shared libraries are loaded at an image base (0x10000000 by + # default) and relocated if they conflict, which is a slow very memory + # consuming and fragmenting process. To avoid this, we pick a random, + # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link + # time. Moving up from 0x10000000 also allows more sbrk(2) space. + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + ;; + + gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) + tmp_diet=no + if test linux-dietlibc = "$host_os"; then + case $cc_basename in + diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) + esac + fi + if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ + && test no = "$tmp_diet" + then + tmp_addflag=' $pic_flag' + tmp_sharedflag='-shared' + case $cc_basename,$host_cpu in + pgcc*) # Portland Group C compiler + _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' + tmp_addflag=' $pic_flag' + ;; + pgf77* | pgf90* | pgf95* | pgfortran*) + # Portland Group f77 and f90 compilers + _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' + tmp_addflag=' $pic_flag -Mnomain' ;; + ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 + tmp_addflag=' -i_dynamic' ;; + efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 + tmp_addflag=' -i_dynamic -nofor_main' ;; + ifc* | ifort*) # Intel Fortran compiler + tmp_addflag=' -nofor_main' ;; + lf95*) # Lahey Fortran 8.1 + _LT_TAGVAR(whole_archive_flag_spec, $1)= + tmp_sharedflag='--shared' ;; + nagfor*) # NAGFOR 5.3 + tmp_sharedflag='-Wl,-shared' ;; + xl[[cC]]* | bgxl[[cC]]* | mpixl[[cC]]*) # IBM XL C 8.0 on PPC (deal with xlf below) + tmp_sharedflag='-qmkshrobj' + tmp_addflag= ;; + nvcc*) # Cuda Compiler Driver 2.2 + _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' + _LT_TAGVAR(compiler_needs_object, $1)=yes + ;; + esac + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) # Sun C 5.9 + _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' + _LT_TAGVAR(compiler_needs_object, $1)=yes + tmp_sharedflag='-G' ;; + *Sun\ F*) # Sun Fortran 8.3 + tmp_sharedflag='-G' ;; + esac + _LT_TAGVAR(archive_cmds, $1)='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + + if test yes = "$supports_anon_versioning"; then + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + echo "local: *; };" >> $output_objdir/$libname.ver~ + $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' + fi + + case $cc_basename in + tcc*) + _LT_TAGVAR(export_dynamic_flag_spec, $1)='-rdynamic' + ;; + xlf* | bgf* | bgxlf* | mpixlf*) + # IBM XL Fortran 10.1 on PPC cannot create shared libs itself + _LT_TAGVAR(whole_archive_flag_spec, $1)='--whole-archive$convenience --no-whole-archive' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' + _LT_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib' + if test yes = "$supports_anon_versioning"; then + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + echo "local: *; };" >> $output_objdir/$libname.ver~ + $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' + fi + ;; + esac + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' + wlarc= + else + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + fi + ;; + + solaris*) + if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then + _LT_TAGVAR(ld_shlibs, $1)=no + cat <<_LT_EOF 1>&2 + +*** Warning: The releases 2.8.* of the GNU linker cannot reliably +*** create shared libraries on Solaris systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.9.1 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +_LT_EOF + elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) + case `$LD -v 2>&1` in + *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.1[[0-5]].*) + _LT_TAGVAR(ld_shlibs, $1)=no + cat <<_LT_EOF 1>&2 + +*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot +*** reliably create shared libraries on SCO systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.16.91.0.3 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +_LT_EOF + ;; + *) + # For security reasons, it is highly recommended that you always + # use absolute paths for naming shared libraries, and exclude the + # DT_RUNPATH tag from executables and libraries. But doing so + # requires that you compile everything twice, which is a pain. + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + + sunos4*) + _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' + wlarc= + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + *) + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + + if test no = "$_LT_TAGVAR(ld_shlibs, $1)"; then + runpath_var= + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= + _LT_TAGVAR(export_dynamic_flag_spec, $1)= + _LT_TAGVAR(whole_archive_flag_spec, $1)= + fi + else + # PORTME fill in a description of your system's linker (not GNU ld) + case $host_os in + aix3*) + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_TAGVAR(always_export_symbols, $1)=yes + _LT_TAGVAR(archive_expsym_cmds, $1)='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' + # Note: this linker hardcodes the directories in LIBPATH if there + # are no directories specified by -L. + _LT_TAGVAR(hardcode_minus_L, $1)=yes + if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then + # Neither direct hardcoding nor static linking is supported with a + # broken collect2. + _LT_TAGVAR(hardcode_direct, $1)=unsupported + fi + ;; + + aix[[4-9]]*) + if test ia64 = "$host_cpu"; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag= + else + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to GNU nm, but means don't demangle to AIX nm. + # Without the "-l" option, or with the "-B" option, AIX nm treats + # weak defined symbols like other global defined symbols, whereas + # GNU nm marks them as "W". + # While the 'weak' keyword is ignored in the Export File, we need + # it in the Import File for the 'aix-soname' feature, so we have + # to replace the "-B" option with "-P" for AIX nm. + if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then + _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' + else + _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "L") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' + fi + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # have runtime linking enabled, and use it for executables. + # For shared libraries, we enable/disable runtime linking + # depending on the kind of the shared library created - + # when "with_aix_soname,aix_use_runtimelinking" is: + # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables + # "aix,yes" lib.so shared, rtl:yes, for executables + # lib.a static archive + # "both,no" lib.so.V(shr.o) shared, rtl:yes + # lib.a(lib.so.V) shared, rtl:no, for executables + # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables + # lib.a(lib.so.V) shared, rtl:no + # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables + # lib.a static archive + case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) + for ld_flag in $LDFLAGS; do + if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then + aix_use_runtimelinking=yes + break + fi + done + if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then + # With aix-soname=svr4, we create the lib.so.V shared archives only, + # so we don't have lib.a shared libs to link our executables. + # We have to force runtime linking in this case. + aix_use_runtimelinking=yes + LDFLAGS="$LDFLAGS -Wl,-brtl" + fi + ;; + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + _LT_TAGVAR(archive_cmds, $1)='' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + _LT_TAGVAR(hardcode_libdir_separator, $1)=':' + _LT_TAGVAR(link_all_deplibs, $1)=yes + _LT_TAGVAR(file_list_spec, $1)='$wl-f,' + case $with_aix_soname,$aix_use_runtimelinking in + aix,*) ;; # traditional, no import file + svr4,* | *,yes) # use import file + # The Import File defines what to hardcode. + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_direct_absolute, $1)=no + ;; + esac + + if test yes = "$GCC"; then + case $host_os in aix4.[[012]]|aix4.[[012]].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`$CC -print-prog-name=collect2` + if test -f "$collect2name" && + strings "$collect2name" | $GREP resolve_lib_name >/dev/null + then + # We have reworked collect2 + : + else + # We have old collect2 + _LT_TAGVAR(hardcode_direct, $1)=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)= + fi + ;; + esac + shared_flag='-shared' + if test yes = "$aix_use_runtimelinking"; then + shared_flag="$shared_flag "'$wl-G' + fi + # Need to ensure runtime linking is disabled for the traditional + # shared library, or the linker may eventually find shared libraries + # /with/ Import File - we do not want to mix them. + shared_flag_aix='-shared' + shared_flag_svr4='-shared $wl-G' + else + # not using gcc + if test ia64 = "$host_cpu"; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test yes = "$aix_use_runtimelinking"; then + shared_flag='$wl-G' + else + shared_flag='$wl-bM:SRE' + fi + shared_flag_aix='$wl-bM:SRE' + shared_flag_svr4='$wl-G' + fi + fi + + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall' + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to export. + _LT_TAGVAR(always_export_symbols, $1)=yes + if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + _LT_TAGVAR(allow_undefined_flag, $1)='-berok' + # Determine the default libpath from the value encoded in an + # empty executable. + _LT_SYS_MODULE_PATH_AIX([$1]) + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag + else + if test ia64 = "$host_cpu"; then + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib' + _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" + _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an + # empty executable. + _LT_SYS_MODULE_PATH_AIX([$1]) + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok' + _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok' + if test yes = "$with_gnu_ld"; then + # We only use this code for GNU lds that support --whole-archive. + _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' + else + # Exported symbols can be pulled into shared objects from archives + _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' + fi + _LT_TAGVAR(archive_cmds_need_lc, $1)=yes + _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' + # -brtl affects multiple linker settings, -berok does not and is overridden later + compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`' + if test svr4 != "$with_aix_soname"; then + # This is similar to how AIX traditionally builds its shared libraries. + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' + fi + if test aix != "$with_aix_soname"; then + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' + else + # used by -dlpreopen to get the symbols + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' + fi + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' + fi + fi + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='' + ;; + m68k) + _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_minus_L, $1)=yes + ;; + esac + ;; + + bsdi[[45]]*) + _LT_TAGVAR(export_dynamic_flag_spec, $1)=-rdynamic + ;; + + cygwin* | mingw* | pw32* | cegcc*) + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++ or Intel C++ Compiler. + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + case $cc_basename in + cl* | icl*) + # Native MSVC or ICC + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_TAGVAR(always_export_symbols, $1)=yes + _LT_TAGVAR(file_list_spec, $1)='@' + # Tell ltmain to make .lib files, not .a files. + libext=lib + # Tell ltmain to make .dll files, not .so files. + shrext_cmds=.dll + # FIXME: Setting linknames here is a bad hack. + _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' + _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then + cp "$export_symbols" "$output_objdir/$soname.def"; + echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; + else + $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; + fi~ + $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ + linknames=' + # The linker will not automatically build a static lib if we build a DLL. + # _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + _LT_TAGVAR(exclude_expsyms, $1)='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' + _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1,DATA/'\'' | $SED -e '\''/^[[AITW]][[ ]]/s/.*[[ ]]//'\'' | sort | uniq > $export_symbols' + # Don't use ranlib + _LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib' + _LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~ + lt_tool_outputfile="@TOOL_OUTPUT@"~ + case $lt_outputfile in + *.exe|*.EXE) ;; + *) + lt_outputfile=$lt_outputfile.exe + lt_tool_outputfile=$lt_tool_outputfile.exe + ;; + esac~ + if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then + $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; + $RM "$lt_outputfile.manifest"; + fi' + ;; + *) + # Assume MSVC and ICC wrapper + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + # Tell ltmain to make .lib files, not .a files. + libext=lib + # Tell ltmain to make .dll files, not .so files. + shrext_cmds=.dll + # FIXME: Setting linknames here is a bad hack. + _LT_TAGVAR(archive_cmds, $1)='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames=' + # The linker will automatically build a .lib file if we build a DLL. + _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' + # FIXME: Should let the user specify the lib program. + _LT_TAGVAR(old_archive_cmds, $1)='lib -OUT:$oldlib$oldobjs$old_deplibs' + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + ;; + esac + ;; + + darwin* | rhapsody*) + _LT_DARWIN_LINKER_FEATURES($1) + ;; + + dgux*) + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor + # support. Future versions do this automatically, but an explicit c++rt0.o + # does not break anything, and helps significantly (at the cost of a little + # extra space). + freebsd2.2*) + _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + # Unfortunately, older versions of FreeBSD 2 do not have this feature. + freebsd2.*) + _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + # FreeBSD 3 and greater uses gcc -shared to do shared libraries. + freebsd* | dragonfly*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + hpux9*) + if test yes = "$GCC"; then + _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' + else + _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' + fi + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_TAGVAR(hardcode_direct, $1)=yes + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' + ;; + + hpux10*) + if test yes,no = "$GCC,$with_gnu_ld"; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + else + _LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' + fi + if test no = "$with_gnu_ld"; then + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + _LT_TAGVAR(hardcode_minus_L, $1)=yes + fi + ;; + + hpux11*) + if test yes,no = "$GCC,$with_gnu_ld"; then + case $host_cpu in + hppa*64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + ia64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + else + case $host_cpu in + hppa*64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + ia64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + m4_if($1, [], [ + # Older versions of the 11.00 compiler do not understand -b yet + # (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does) + _LT_LINKER_OPTION([if $CC understands -b], + _LT_TAGVAR(lt_cv_prog_compiler__b, $1), [-b], + [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'], + [_LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'])], + [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags']) + ;; + esac + fi + if test no = "$with_gnu_ld"; then + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + + case $host_cpu in + hppa*64*|ia64*) + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + *) + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + _LT_TAGVAR(hardcode_minus_L, $1)=yes + ;; + esac + fi + ;; + + irix5* | irix6* | nonstopux*) + if test yes = "$GCC"; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' + # Try to use the -exported_symbol ld option, if it does not + # work, assume that -exports_file does not work either and + # implicitly export all symbols. + # This should be the same for all languages, so no per-tag cache variable. + AC_CACHE_CHECK([whether the $host_os linker accepts -exported_symbol], + [lt_cv_irix_exported_symbol], + [save_LDFLAGS=$LDFLAGS + LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null" + AC_LINK_IFELSE( + [AC_LANG_SOURCE( + [AC_LANG_CASE([C], [[int foo (void) { return 0; }]], + [C++], [[int foo (void) { return 0; }]], + [Fortran 77], [[ + subroutine foo + end]], + [Fortran], [[ + subroutine foo + end]])])], + [lt_cv_irix_exported_symbol=yes], + [lt_cv_irix_exported_symbol=no]) + LDFLAGS=$save_LDFLAGS]) + if test yes = "$lt_cv_irix_exported_symbol"; then + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib' + fi + else + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib' + fi + _LT_TAGVAR(archive_cmds_need_lc, $1)='no' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_TAGVAR(inherit_rpath, $1)=yes + _LT_TAGVAR(link_all_deplibs, $1)=yes + ;; + + linux*) + case $cc_basename in + tcc*) + # Fabrice Bellard et al's Tiny C Compiler + _LT_TAGVAR(ld_shlibs, $1)=yes + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out + else + _LT_TAGVAR(archive_cmds, $1)='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF + fi + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + newsos6) + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + *nto* | *qnx*) + ;; + + openbsd* | bitrig*) + if test -f /usr/libexec/ld.so; then + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags $wl-retain-symbols-file,$export_symbols' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' + else + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' + fi + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + os2*) + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + shrext_cmds=.dll + _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + prefix_cmds="$SED"~ + if test EXPORTS = "`$SED 1q $export_symbols`"; then + prefix_cmds="$prefix_cmds -e 1d"; + fi~ + prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ + cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + _LT_TAGVAR(file_list_spec, $1)='@' + ;; + + osf3*) + if test yes = "$GCC"; then + _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' + else + _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' + fi + _LT_TAGVAR(archive_cmds_need_lc, $1)='no' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + ;; + + osf4* | osf5*) # as osf3* with the addition of -msym flag + if test yes = "$GCC"; then + _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' + else + _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ + $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~$RM $lib.exp' + + # Both c and cxx compiler support -rpath directly + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' + fi + _LT_TAGVAR(archive_cmds_need_lc, $1)='no' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + ;; + + solaris*) + _LT_TAGVAR(no_undefined_flag, $1)=' -z defs' + if test yes = "$GCC"; then + wlarc='$wl' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl-z ${wl}text $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' + else + case `$CC -V 2>&1` in + *"Compilers 5.0"*) + wlarc='' + _LT_TAGVAR(archive_cmds, $1)='$LD -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' + ;; + *) + wlarc='$wl' + _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' + ;; + esac + fi + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + case $host_os in + solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; + *) + # The compiler driver will combine and reorder linker options, + # but understands '-z linker_flag'. GCC discards it without '$wl', + # but is careful enough not to reorder. + # Supported since Solaris 2.6 (maybe 2.5.1?) + if test yes = "$GCC"; then + _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' + else + _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' + fi + ;; + esac + _LT_TAGVAR(link_all_deplibs, $1)=yes + ;; + + sunos4*) + if test sequent = "$host_vendor"; then + # Use $CC to link under sequent, because it throws in some extra .o + # files that make .init and .fini sections work. + _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h $soname -o $lib $libobjs $deplibs $compiler_flags' + else + _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' + fi + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + sysv4) + case $host_vendor in + sni) + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_direct, $1)=yes # is this really true??? + ;; + siemens) + ## LD is ld it makes a PLAMLIB + ## CC just makes a GrossModule. + _LT_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(reload_cmds, $1)='$CC -r -o $output$reload_objs' + _LT_TAGVAR(hardcode_direct, $1)=no + ;; + motorola) + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_direct, $1)=no #Motorola manual says yes, but my tests say they lie + ;; + esac + runpath_var='LD_RUN_PATH' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + sysv4.3*) + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(export_dynamic_flag_spec, $1)='-Bexport' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + _LT_TAGVAR(ld_shlibs, $1)=yes + fi + ;; + + sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) + _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + runpath_var='LD_RUN_PATH' + + if test yes = "$GCC"; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + else + _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + fi + ;; + + sysv5* | sco3.2v5* | sco5v6*) + # Note: We CANNOT use -z defs as we might desire, because we do not + # link with -lc, and that would cause any symbols used from libc to + # always be unresolved, which means just about no library would + # ever link correctly. If we're not using GNU ld we use -z text + # though, which does catch some bad symbols but isn't as heavy-handed + # as -z defs. + _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' + _LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs' + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=':' + _LT_TAGVAR(link_all_deplibs, $1)=yes + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport' + runpath_var='LD_RUN_PATH' + + if test yes = "$GCC"; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + else + _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + fi + ;; + + uts4*) + _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + *) + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + + if test sni = "$host_vendor"; then + case $host in + sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Blargedynsym' + ;; + esac + fi + fi +]) +AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) +test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no + +_LT_TAGVAR(with_gnu_ld, $1)=$with_gnu_ld + +_LT_DECL([], [libext], [0], [Old archive suffix (normally "a")])dnl +_LT_DECL([], [shrext_cmds], [1], [Shared library suffix (normally ".so")])dnl +_LT_DECL([], [extract_expsyms_cmds], [2], + [The commands to extract the exported symbol list from a shared archive]) + +# +# Do we need to explicitly link libc? +# +case "x$_LT_TAGVAR(archive_cmds_need_lc, $1)" in +x|xyes) + # Assume -lc should be added + _LT_TAGVAR(archive_cmds_need_lc, $1)=yes + + if test yes,yes = "$GCC,$enable_shared"; then + case $_LT_TAGVAR(archive_cmds, $1) in + *'~'*) + # FIXME: we may have to deal with multi-command sequences. + ;; + '$CC '*) + # Test whether the compiler implicitly links with -lc since on some + # systems, -lgcc has to come before -lc. If gcc already passes -lc + # to ld, don't add -lc before -lgcc. + AC_CACHE_CHECK([whether -lc should be explicitly linked in], + [lt_cv_]_LT_TAGVAR(archive_cmds_need_lc, $1), + [$RM conftest* + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + if AC_TRY_EVAL(ac_compile) 2>conftest.err; then + soname=conftest + lib=conftest + libobjs=conftest.$ac_objext + deplibs= + wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) + pic_flag=$_LT_TAGVAR(lt_prog_compiler_pic, $1) + compiler_flags=-v + linker_flags=-v + verstring= + output_objdir=. + libname=conftest + lt_save_allow_undefined_flag=$_LT_TAGVAR(allow_undefined_flag, $1) + _LT_TAGVAR(allow_undefined_flag, $1)= + if AC_TRY_EVAL(_LT_TAGVAR(archive_cmds, $1) 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) + then + lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1)=no + else + lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1)=yes + fi + _LT_TAGVAR(allow_undefined_flag, $1)=$lt_save_allow_undefined_flag + else + cat conftest.err 1>&5 + fi + $RM conftest* + ]) + _LT_TAGVAR(archive_cmds_need_lc, $1)=$lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1) + ;; + esac + fi + ;; +esac + +_LT_TAGDECL([build_libtool_need_lc], [archive_cmds_need_lc], [0], + [Whether or not to add -lc for building shared libraries]) +_LT_TAGDECL([allow_libtool_libs_with_static_runtimes], + [enable_shared_with_static_runtimes], [0], + [Whether or not to disallow shared libs when runtime libs are static]) +_LT_TAGDECL([], [export_dynamic_flag_spec], [1], + [Compiler flag to allow reflexive dlopens]) +_LT_TAGDECL([], [whole_archive_flag_spec], [1], + [Compiler flag to generate shared objects directly from archives]) +_LT_TAGDECL([], [compiler_needs_object], [1], + [Whether the compiler copes with passing no objects directly]) +_LT_TAGDECL([], [old_archive_from_new_cmds], [2], + [Create an old-style archive from a shared archive]) +_LT_TAGDECL([], [old_archive_from_expsyms_cmds], [2], + [Create a temporary old-style archive to link instead of a shared archive]) +_LT_TAGDECL([], [archive_cmds], [2], [Commands used to build a shared archive]) +_LT_TAGDECL([], [archive_expsym_cmds], [2]) +_LT_TAGDECL([], [module_cmds], [2], + [Commands used to build a loadable module if different from building + a shared archive.]) +_LT_TAGDECL([], [module_expsym_cmds], [2]) +_LT_TAGDECL([], [with_gnu_ld], [1], + [Whether we are building with GNU ld or not]) +_LT_TAGDECL([], [allow_undefined_flag], [1], + [Flag that allows shared libraries with undefined symbols to be built]) +_LT_TAGDECL([], [no_undefined_flag], [1], + [Flag that enforces no undefined symbols]) +_LT_TAGDECL([], [hardcode_libdir_flag_spec], [1], + [Flag to hardcode $libdir into a binary during linking. + This must work even if $libdir does not exist]) +_LT_TAGDECL([], [hardcode_libdir_separator], [1], + [Whether we need a single "-rpath" flag with a separated argument]) +_LT_TAGDECL([], [hardcode_direct], [0], + [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes + DIR into the resulting binary]) +_LT_TAGDECL([], [hardcode_direct_absolute], [0], + [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes + DIR into the resulting binary and the resulting library dependency is + "absolute", i.e impossible to change by setting $shlibpath_var if the + library is relocated]) +_LT_TAGDECL([], [hardcode_minus_L], [0], + [Set to "yes" if using the -LDIR flag during linking hardcodes DIR + into the resulting binary]) +_LT_TAGDECL([], [hardcode_shlibpath_var], [0], + [Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR + into the resulting binary]) +_LT_TAGDECL([], [hardcode_automatic], [0], + [Set to "yes" if building a shared library automatically hardcodes DIR + into the library and all subsequent libraries and executables linked + against it]) +_LT_TAGDECL([], [inherit_rpath], [0], + [Set to yes if linker adds runtime paths of dependent libraries + to runtime path list]) +_LT_TAGDECL([], [link_all_deplibs], [0], + [Whether libtool must link a program against all its dependency libraries]) +_LT_TAGDECL([], [always_export_symbols], [0], + [Set to "yes" if exported symbols are required]) +_LT_TAGDECL([], [export_symbols_cmds], [2], + [The commands to list exported symbols]) +_LT_TAGDECL([], [exclude_expsyms], [1], + [Symbols that should not be listed in the preloaded symbols]) +_LT_TAGDECL([], [include_expsyms], [1], + [Symbols that must always be exported]) +_LT_TAGDECL([], [prelink_cmds], [2], + [Commands necessary for linking programs (against libraries) with templates]) +_LT_TAGDECL([], [postlink_cmds], [2], + [Commands necessary for finishing linking programs]) +_LT_TAGDECL([], [file_list_spec], [1], + [Specify filename containing input files]) +dnl FIXME: Not yet implemented +dnl _LT_TAGDECL([], [thread_safe_flag_spec], [1], +dnl [Compiler flag to generate thread safe objects]) +])# _LT_LINKER_SHLIBS + + +# _LT_LANG_C_CONFIG([TAG]) +# ------------------------ +# Ensure that the configuration variables for a C compiler are suitably +# defined. These variables are subsequently used by _LT_CONFIG to write +# the compiler configuration to 'libtool'. +m4_defun([_LT_LANG_C_CONFIG], +[m4_require([_LT_DECL_EGREP])dnl +lt_save_CC=$CC +AC_LANG_PUSH(C) + +# Source file extension for C test sources. +ac_ext=c + +# Object file extension for compiled C test sources. +objext=o +_LT_TAGVAR(objext, $1)=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="int some_variable = 0;" + +# Code to be used in simple link tests +lt_simple_link_test_code='int main(){return(0);}' + +_LT_TAG_COMPILER +# Save the default compiler, since it gets overwritten when the other +# tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. +compiler_DEFAULT=$CC + +# save warnings/boilerplate of simple test code +_LT_COMPILER_BOILERPLATE +_LT_LINKER_BOILERPLATE + +if test -n "$compiler"; then + _LT_COMPILER_NO_RTTI($1) + _LT_COMPILER_PIC($1) + _LT_COMPILER_C_O($1) + _LT_COMPILER_FILE_LOCKS($1) + _LT_LINKER_SHLIBS($1) + _LT_SYS_DYNAMIC_LINKER($1) + _LT_LINKER_HARDCODE_LIBPATH($1) + LT_SYS_DLOPEN_SELF + _LT_CMD_STRIPLIB + + # Report what library types will actually be built + AC_MSG_CHECKING([if libtool supports shared libraries]) + AC_MSG_RESULT([$can_build_shared]) + + AC_MSG_CHECKING([whether to build shared libraries]) + test no = "$can_build_shared" && enable_shared=no + + # On AIX, shared libraries and static libraries use the same namespace, and + # are all built from PIC. + case $host_os in + aix3*) + test yes = "$enable_shared" && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + + aix[[4-9]]*) + if test ia64 != "$host_cpu"; then + case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in + yes,aix,yes) ;; # shared object as lib.so file only + yes,svr4,*) ;; # shared object as lib.so archive member only + yes,*) enable_static=no ;; # shared object in lib.a archive as well + esac + fi + ;; + esac + AC_MSG_RESULT([$enable_shared]) + + AC_MSG_CHECKING([whether to build static libraries]) + # Make sure either enable_shared or enable_static is yes. + test yes = "$enable_shared" || enable_static=yes + AC_MSG_RESULT([$enable_static]) + + _LT_CONFIG($1) +fi +AC_LANG_POP +CC=$lt_save_CC +])# _LT_LANG_C_CONFIG + + +# _LT_LANG_CXX_CONFIG([TAG]) +# -------------------------- +# Ensure that the configuration variables for a C++ compiler are suitably +# defined. These variables are subsequently used by _LT_CONFIG to write +# the compiler configuration to 'libtool'. +m4_defun([_LT_LANG_CXX_CONFIG], +[m4_require([_LT_FILEUTILS_DEFAULTS])dnl +m4_require([_LT_DECL_EGREP])dnl +m4_require([_LT_PATH_MANIFEST_TOOL])dnl +if test -n "$CXX" && ( test no != "$CXX" && + ( (test g++ = "$CXX" && `g++ -v >/dev/null 2>&1` ) || + (test g++ != "$CXX"))); then + AC_PROG_CXXCPP +else + _lt_caught_CXX_error=yes +fi + +AC_LANG_PUSH(C++) +_LT_TAGVAR(archive_cmds_need_lc, $1)=no +_LT_TAGVAR(allow_undefined_flag, $1)= +_LT_TAGVAR(always_export_symbols, $1)=no +_LT_TAGVAR(archive_expsym_cmds, $1)= +_LT_TAGVAR(compiler_needs_object, $1)=no +_LT_TAGVAR(export_dynamic_flag_spec, $1)= +_LT_TAGVAR(hardcode_direct, $1)=no +_LT_TAGVAR(hardcode_direct_absolute, $1)=no +_LT_TAGVAR(hardcode_libdir_flag_spec, $1)= +_LT_TAGVAR(hardcode_libdir_separator, $1)= +_LT_TAGVAR(hardcode_minus_L, $1)=no +_LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported +_LT_TAGVAR(hardcode_automatic, $1)=no +_LT_TAGVAR(inherit_rpath, $1)=no +_LT_TAGVAR(module_cmds, $1)= +_LT_TAGVAR(module_expsym_cmds, $1)= +_LT_TAGVAR(link_all_deplibs, $1)=unknown +_LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds +_LT_TAGVAR(reload_flag, $1)=$reload_flag +_LT_TAGVAR(reload_cmds, $1)=$reload_cmds +_LT_TAGVAR(no_undefined_flag, $1)= +_LT_TAGVAR(whole_archive_flag_spec, $1)= +_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no + +# Source file extension for C++ test sources. +ac_ext=cpp + +# Object file extension for compiled C++ test sources. +objext=o +_LT_TAGVAR(objext, $1)=$objext + +# No sense in running all these tests if we already determined that +# the CXX compiler isn't working. Some variables (like enable_shared) +# are currently assumed to apply to all compilers on this platform, +# and will be corrupted by setting them based on a non-working compiler. +if test yes != "$_lt_caught_CXX_error"; then + # Code to be used in simple compile tests + lt_simple_compile_test_code="int some_variable = 0;" + + # Code to be used in simple link tests + lt_simple_link_test_code='int main(int, char *[[]]) { return(0); }' + + # ltmain only uses $CC for tagged configurations so make sure $CC is set. + _LT_TAG_COMPILER + + # save warnings/boilerplate of simple test code + _LT_COMPILER_BOILERPLATE + _LT_LINKER_BOILERPLATE + + # Allow CC to be a program name with arguments. + lt_save_CC=$CC + lt_save_CFLAGS=$CFLAGS + lt_save_LD=$LD + lt_save_GCC=$GCC + GCC=$GXX + lt_save_with_gnu_ld=$with_gnu_ld + lt_save_path_LD=$lt_cv_path_LD + if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then + lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx + else + $as_unset lt_cv_prog_gnu_ld + fi + if test -n "${lt_cv_path_LDCXX+set}"; then + lt_cv_path_LD=$lt_cv_path_LDCXX + else + $as_unset lt_cv_path_LD + fi + test -z "${LDCXX+set}" || LD=$LDCXX + CC=${CXX-"c++"} + CFLAGS=$CXXFLAGS + compiler=$CC + _LT_TAGVAR(compiler, $1)=$CC + _LT_CC_BASENAME([$compiler]) + + if test -n "$compiler"; then + # We don't want -fno-exception when compiling C++ code, so set the + # no_builtin_flag separately + if test yes = "$GXX"; then + _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' + else + _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= + fi + + if test yes = "$GXX"; then + # Set up default GNU C++ configuration + + LT_PATH_LD + + # Check if GNU C++ uses GNU ld as the underlying linker, since the + # archiving commands below assume that GNU ld is being used. + if test yes = "$with_gnu_ld"; then + _LT_TAGVAR(archive_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' + + # If archive_cmds runs LD, not CC, wlarc should be empty + # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to + # investigate it a little bit more. (MM) + wlarc='$wl' + + # ancient GNU ld didn't support --whole-archive et. al. + if eval "`$CC -print-prog-name=ld` --help 2>&1" | + $GREP 'no-whole-archive' > /dev/null; then + _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' + else + _LT_TAGVAR(whole_archive_flag_spec, $1)= + fi + else + with_gnu_ld=no + wlarc= + + # A generic and very simple default shared library creation + # command for GNU C++ for the case where it uses the native + # linker, instead of GNU ld. If possible, this setting should + # overridden to take advantage of the native linker features on + # the platform it is being used on. + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' + fi + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' + + else + GXX=no + with_gnu_ld=no + wlarc= + fi + + # PORTME: fill in a description of your system's C++ link characteristics + AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) + _LT_TAGVAR(ld_shlibs, $1)=yes + case $host_os in + aix3*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + aix[[4-9]]*) + if test ia64 = "$host_cpu"; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag= + else + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # have runtime linking enabled, and use it for executables. + # For shared libraries, we enable/disable runtime linking + # depending on the kind of the shared library created - + # when "with_aix_soname,aix_use_runtimelinking" is: + # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables + # "aix,yes" lib.so shared, rtl:yes, for executables + # lib.a static archive + # "both,no" lib.so.V(shr.o) shared, rtl:yes + # lib.a(lib.so.V) shared, rtl:no, for executables + # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables + # lib.a(lib.so.V) shared, rtl:no + # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables + # lib.a static archive + case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) + for ld_flag in $LDFLAGS; do + case $ld_flag in + *-brtl*) + aix_use_runtimelinking=yes + break + ;; + esac + done + if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then + # With aix-soname=svr4, we create the lib.so.V shared archives only, + # so we don't have lib.a shared libs to link our executables. + # We have to force runtime linking in this case. + aix_use_runtimelinking=yes + LDFLAGS="$LDFLAGS -Wl,-brtl" + fi + ;; + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + _LT_TAGVAR(archive_cmds, $1)='' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + _LT_TAGVAR(hardcode_libdir_separator, $1)=':' + _LT_TAGVAR(link_all_deplibs, $1)=yes + _LT_TAGVAR(file_list_spec, $1)='$wl-f,' + case $with_aix_soname,$aix_use_runtimelinking in + aix,*) ;; # no import file + svr4,* | *,yes) # use import file + # The Import File defines what to hardcode. + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_direct_absolute, $1)=no + ;; + esac + + if test yes = "$GXX"; then + case $host_os in aix4.[[012]]|aix4.[[012]].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`$CC -print-prog-name=collect2` + if test -f "$collect2name" && + strings "$collect2name" | $GREP resolve_lib_name >/dev/null + then + # We have reworked collect2 + : + else + # We have old collect2 + _LT_TAGVAR(hardcode_direct, $1)=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)= + fi + esac + shared_flag='-shared' + if test yes = "$aix_use_runtimelinking"; then + shared_flag=$shared_flag' $wl-G' + fi + # Need to ensure runtime linking is disabled for the traditional + # shared library, or the linker may eventually find shared libraries + # /with/ Import File - we do not want to mix them. + shared_flag_aix='-shared' + shared_flag_svr4='-shared $wl-G' + else + # not using gcc + if test ia64 = "$host_cpu"; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test yes = "$aix_use_runtimelinking"; then + shared_flag='$wl-G' + else + shared_flag='$wl-bM:SRE' + fi + shared_flag_aix='$wl-bM:SRE' + shared_flag_svr4='$wl-G' + fi + fi + + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall' + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to + # export. + _LT_TAGVAR(always_export_symbols, $1)=yes + if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + # The "-G" linker flag allows undefined symbols. + _LT_TAGVAR(no_undefined_flag, $1)='-bernotok' + # Determine the default libpath from the value encoded in an empty + # executable. + _LT_SYS_MODULE_PATH_AIX([$1]) + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" + + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag + else + if test ia64 = "$host_cpu"; then + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib' + _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" + _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an + # empty executable. + _LT_SYS_MODULE_PATH_AIX([$1]) + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok' + _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok' + if test yes = "$with_gnu_ld"; then + # We only use this code for GNU lds that support --whole-archive. + _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' + else + # Exported symbols can be pulled into shared objects from archives + _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' + fi + _LT_TAGVAR(archive_cmds_need_lc, $1)=yes + _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' + # -brtl affects multiple linker settings, -berok does not and is overridden later + compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`' + if test svr4 != "$with_aix_soname"; then + # This is similar to how AIX traditionally builds its shared + # libraries. Need -bnortl late, we may have -brtl in LDFLAGS. + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' + fi + if test aix != "$with_aix_soname"; then + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' + else + # used by -dlpreopen to get the symbols + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' + fi + _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' + fi + fi + ;; + + beos*) + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + chorus*) + case $cc_basename in + *) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + + cygwin* | mingw* | pw32* | cegcc*) + case $GXX,$cc_basename in + ,cl* | no,cl* | ,icl* | no,icl*) + # Native MSVC or ICC + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_TAGVAR(always_export_symbols, $1)=yes + _LT_TAGVAR(file_list_spec, $1)='@' + # Tell ltmain to make .lib files, not .a files. + libext=lib + # Tell ltmain to make .dll files, not .so files. + shrext_cmds=.dll + # FIXME: Setting linknames here is a bad hack. + _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' + _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then + cp "$export_symbols" "$output_objdir/$soname.def"; + echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; + else + $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; + fi~ + $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ + linknames=' + # The linker will not automatically build a static lib if we build a DLL. + # _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + # Don't use ranlib + _LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib' + _LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~ + lt_tool_outputfile="@TOOL_OUTPUT@"~ + case $lt_outputfile in + *.exe|*.EXE) ;; + *) + lt_outputfile=$lt_outputfile.exe + lt_tool_outputfile=$lt_tool_outputfile.exe + ;; + esac~ + func_to_tool_file "$lt_outputfile"~ + if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then + $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; + $RM "$lt_outputfile.manifest"; + fi' + ;; + *) + # g++ + # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, + # as there is no search path for DLLs. + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols' + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_TAGVAR(always_export_symbols, $1)=no + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + + if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + # If the export-symbols file already is a .def file, use it as + # is; otherwise, prepend EXPORTS... + _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + darwin* | rhapsody*) + _LT_DARWIN_LINKER_FEATURES($1) + ;; + + os2*) + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_TAGVAR(hardcode_minus_L, $1)=yes + _LT_TAGVAR(allow_undefined_flag, $1)=unsupported + shrext_cmds=.dll + _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + prefix_cmds="$SED"~ + if test EXPORTS = "`$SED 1q $export_symbols`"; then + prefix_cmds="$prefix_cmds -e 1d"; + fi~ + prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ + cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' + _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + _LT_TAGVAR(file_list_spec, $1)='@' + ;; + + dgux*) + case $cc_basename in + ec++*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + ghcx*) + # Green Hills C++ Compiler + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + + freebsd2.*) + # C++ shared libraries reported to be fairly broken before + # switch to ELF + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + + freebsd-elf*) + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + ;; + + freebsd* | dragonfly*) + # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF + # conventions + _LT_TAGVAR(ld_shlibs, $1)=yes + ;; + + haiku*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(link_all_deplibs, $1)=yes + ;; + + hpux9*) + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, + # but as the default + # location of the library. + + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + aCC*) + _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -b $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' + ;; + *) + if test yes = "$GXX"; then + _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' + else + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + + hpux10*|hpux11*) + if test no = "$with_gnu_ld"; then + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + + case $host_cpu in + hppa*64*|ia64*) + ;; + *) + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' + ;; + esac + fi + case $host_cpu in + hppa*64*|ia64*) + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + *) + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, + # but as the default + # location of the library. + ;; + esac + + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + aCC*) + case $host_cpu in + hppa*64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + ia64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' + ;; + *) + if test yes = "$GXX"; then + if test no = "$with_gnu_ld"; then + case $host_cpu in + hppa*64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + ia64*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + fi + else + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + + interix[[3-9]]*) + _LT_TAGVAR(hardcode_direct, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' + # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. + # Instead, shared libraries are loaded at an image base (0x10000000 by + # default) and relocated if they conflict, which is a slow very memory + # consuming and fragmenting process. To avoid this, we pick a random, + # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link + # time. Moving up from 0x10000000 also allows more sbrk(2) space. + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + ;; + irix5* | irix6*) + case $cc_basename in + CC*) + # SGI C++ + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' + + # Archives containing C++ object files must be created using + # "CC -ar", where "CC" is the IRIX C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + _LT_TAGVAR(old_archive_cmds, $1)='$CC -ar -WR,-u -o $oldlib $oldobjs' + ;; + *) + if test yes = "$GXX"; then + if test no = "$with_gnu_ld"; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' + else + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` -o $lib' + fi + fi + _LT_TAGVAR(link_all_deplibs, $1)=yes + ;; + esac + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_TAGVAR(inherit_rpath, $1)=yes + ;; + + linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib $wl-retain-symbols-file,$export_symbols; mv \$templib $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' + + # Archives containing C++ object files must be created using + # "CC -Bstatic", where "CC" is the KAI C++ compiler. + _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' + ;; + icpc* | ecpc* ) + # Intel C++ + with_gnu_ld=yes + # version 8.0 and above of icpc choke on multiply defined symbols + # if we add $predep_objects and $postdep_objects, however 7.1 and + # earlier do not add the objects themselves. + case `$CC -V 2>&1` in + *"Version 7."*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + ;; + *) # Version 8.0 or newer + tmp_idyn= + case $host_cpu in + ia64*) tmp_idyn=' -i_dynamic';; + esac + _LT_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + ;; + esac + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' + _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' + ;; + pgCC* | pgcpp*) + # Portland Group C++ compiler + case `$CC -V` in + *pgCC\ [[1-5]].* | *pgcpp\ [[1-5]].*) + _LT_TAGVAR(prelink_cmds, $1)='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~ + compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"' + _LT_TAGVAR(old_archive_cmds, $1)='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~ + $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~ + $RANLIB $oldlib' + _LT_TAGVAR(archive_cmds, $1)='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ + $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ + $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + ;; + *) # Version 6 and above use weak symbols + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + ;; + esac + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl--rpath $wl$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' + _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' + ;; + cxx*) + # Compaq C++ + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib $wl-retain-symbols-file $wl$export_symbols' + + runpath_var=LD_RUN_PATH + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "X$list" | $Xsed' + ;; + xl* | mpixl* | bgxl*) + # IBM XL 8.0 on PPC, with GNU ld + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' + _LT_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + if test yes = "$supports_anon_versioning"; then + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + echo "local: *; };" >> $output_objdir/$libname.ver~ + $CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' + fi + ;; + *) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) + # Sun C++ 5.9 + _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' + _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file $wl$export_symbols' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' + _LT_TAGVAR(compiler_needs_object, $1)=yes + + # Not sure whether something based on + # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 + # would be better. + output_verbose_link_cmd='func_echo_all' + + # Archives containing C++ object files must be created using + # "CC -xar", where "CC" is the Sun C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' + ;; + esac + ;; + esac + ;; + + lynxos*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + + m88k*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + + mvs*) + case $cc_basename in + cxx*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' + wlarc= + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + fi + # Workaround some broken pre-1.5 toolchains + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' + ;; + + *nto* | *qnx*) + _LT_TAGVAR(ld_shlibs, $1)=yes + ;; + + openbsd* | bitrig*) + if test -f /usr/libexec/ld.so; then + _LT_TAGVAR(hardcode_direct, $1)=yes + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(hardcode_direct_absolute, $1)=yes + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`"; then + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file,$export_symbols -o $lib' + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' + _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' + fi + output_verbose_link_cmd=func_echo_all + else + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + osf3* | osf4* | osf5*) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + + # Archives containing C++ object files must be created using + # the KAI C++ compiler. + case $host in + osf3*) _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' ;; + *) _LT_TAGVAR(old_archive_cmds, $1)='$CC -o $oldlib $oldobjs' ;; + esac + ;; + RCC*) + # Rational C++ 2.4.1 + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + cxx*) + case $host in + osf3*) + _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $soname `test -n "$verstring" && func_echo_all "$wl-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' + ;; + *) + _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' + _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ + echo "-hidden">> $lib.exp~ + $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname $wl-input $wl$lib.exp `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~ + $RM $lib.exp' + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' + ;; + esac + + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' + ;; + *) + if test yes,no = "$GXX,$with_gnu_ld"; then + _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' + case $host in + osf3*) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' + ;; + esac + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' + + else + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + + psos*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + + sunos4*) + case $cc_basename in + CC*) + # Sun C++ 4.x + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + lcc*) + # Lucid + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + + solaris*) + case $cc_basename in + CC* | sunCC*) + # Sun C++ 4.2, 5.x and Centerline C++ + _LT_TAGVAR(archive_cmds_need_lc,$1)=yes + _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' + _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -G$allow_undefined_flag $wl-M $wl$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + case $host_os in + solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; + *) + # The compiler driver will combine and reorder linker options, + # but understands '-z linker_flag'. + # Supported since Solaris 2.6 (maybe 2.5.1?) + _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' + ;; + esac + _LT_TAGVAR(link_all_deplibs, $1)=yes + + output_verbose_link_cmd='func_echo_all' + + # Archives containing C++ object files must be created using + # "CC -xar", where "CC" is the Sun C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' + ;; + gcx*) + # Green Hills C++ Compiler + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' + + # The C++ compiler must be used to create the archive. + _LT_TAGVAR(old_archive_cmds, $1)='$CC $LDFLAGS -archive -o $oldlib $oldobjs' + ;; + *) + # GNU C++ compiler with Solaris linker + if test yes,no = "$GXX,$with_gnu_ld"; then + _LT_TAGVAR(no_undefined_flag, $1)=' $wl-z ${wl}defs' + if $CC --version | $GREP -v '^2\.7' > /dev/null; then + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -shared $pic_flag -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' + else + # g++ 2.7 appears to require '-G' NOT '-shared' on this + # platform. + _LT_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' + _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -G -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' + fi + + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $wl$libdir' + case $host_os in + solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; + *) + _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' + ;; + esac + fi + ;; + esac + ;; + + sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) + _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + runpath_var='LD_RUN_PATH' + + case $cc_basename in + CC*) + _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + ;; + + sysv5* | sco3.2v5* | sco5v6*) + # Note: We CANNOT use -z defs as we might desire, because we do not + # link with -lc, and that would cause any symbols used from libc to + # always be unresolved, which means just about no library would + # ever link correctly. If we're not using GNU ld we use -z text + # though, which does catch some bad symbols but isn't as heavy-handed + # as -z defs. + _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' + _LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs' + _LT_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir' + _LT_TAGVAR(hardcode_libdir_separator, $1)=':' + _LT_TAGVAR(link_all_deplibs, $1)=yes + _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport' + runpath_var='LD_RUN_PATH' + + case $cc_basename in + CC*) + _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(old_archive_cmds, $1)='$CC -Tprelink_objects $oldobjs~ + '"$_LT_TAGVAR(old_archive_cmds, $1)" + _LT_TAGVAR(reload_cmds, $1)='$CC -Tprelink_objects $reload_objs~ + '"$_LT_TAGVAR(reload_cmds, $1)" + ;; + *) + _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + ;; + + tandem*) + case $cc_basename in + NCC*) + # NonStop-UX NCC 3.20 + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + + vxworks*) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + + *) + # FIXME: insert proper C++ library support + _LT_TAGVAR(ld_shlibs, $1)=no + ;; + esac + + AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) + test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no + + _LT_TAGVAR(GCC, $1)=$GXX + _LT_TAGVAR(LD, $1)=$LD + + ## CAVEAT EMPTOR: + ## There is no encapsulation within the following macros, do not change + ## the running order or otherwise move them around unless you know exactly + ## what you are doing... + _LT_SYS_HIDDEN_LIBDEPS($1) + _LT_COMPILER_PIC($1) + _LT_COMPILER_C_O($1) + _LT_COMPILER_FILE_LOCKS($1) + _LT_LINKER_SHLIBS($1) + _LT_SYS_DYNAMIC_LINKER($1) + _LT_LINKER_HARDCODE_LIBPATH($1) + + _LT_CONFIG($1) + fi # test -n "$compiler" + + CC=$lt_save_CC + CFLAGS=$lt_save_CFLAGS + LDCXX=$LD + LD=$lt_save_LD + GCC=$lt_save_GCC + with_gnu_ld=$lt_save_with_gnu_ld + lt_cv_path_LDCXX=$lt_cv_path_LD + lt_cv_path_LD=$lt_save_path_LD + lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld + lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld +fi # test yes != "$_lt_caught_CXX_error" + +AC_LANG_POP +])# _LT_LANG_CXX_CONFIG + + +# _LT_FUNC_STRIPNAME_CNF +# ---------------------- +# func_stripname_cnf prefix suffix name +# strip PREFIX and SUFFIX off of NAME. +# PREFIX and SUFFIX must not contain globbing or regex special +# characters, hashes, percent signs, but SUFFIX may contain a leading +# dot (in which case that matches only a dot). +# +# This function is identical to the (non-XSI) version of func_stripname, +# except this one can be used by m4 code that may be executed by configure, +# rather than the libtool script. +m4_defun([_LT_FUNC_STRIPNAME_CNF],[dnl +AC_REQUIRE([_LT_DECL_SED]) +AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH]) +func_stripname_cnf () +{ + case @S|@2 in + .*) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%\\\\@S|@2\$%%"`;; + *) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%@S|@2\$%%"`;; + esac +} # func_stripname_cnf +])# _LT_FUNC_STRIPNAME_CNF + + +# _LT_SYS_HIDDEN_LIBDEPS([TAGNAME]) +# --------------------------------- +# Figure out "hidden" library dependencies from verbose +# compiler output when linking a shared library. +# Parse the compiler output and extract the necessary +# objects, libraries and library flags. +m4_defun([_LT_SYS_HIDDEN_LIBDEPS], +[m4_require([_LT_FILEUTILS_DEFAULTS])dnl +AC_REQUIRE([_LT_FUNC_STRIPNAME_CNF])dnl +# Dependencies to place before and after the object being linked: +_LT_TAGVAR(predep_objects, $1)= +_LT_TAGVAR(postdep_objects, $1)= +_LT_TAGVAR(predeps, $1)= +_LT_TAGVAR(postdeps, $1)= +_LT_TAGVAR(compiler_lib_search_path, $1)= + +dnl we can't use the lt_simple_compile_test_code here, +dnl because it contains code intended for an executable, +dnl not a library. It's possible we should let each +dnl tag define a new lt_????_link_test_code variable, +dnl but it's only used here... +m4_if([$1], [], [cat > conftest.$ac_ext <<_LT_EOF +int a; +void foo (void) { a = 0; } +_LT_EOF +], [$1], [CXX], [cat > conftest.$ac_ext <<_LT_EOF +class Foo +{ +public: + Foo (void) { a = 0; } +private: + int a; +}; +_LT_EOF +], [$1], [F77], [cat > conftest.$ac_ext <<_LT_EOF + subroutine foo + implicit none + integer*4 a + a=0 + return + end +_LT_EOF +], [$1], [FC], [cat > conftest.$ac_ext <<_LT_EOF + subroutine foo + implicit none + integer a + a=0 + return + end +_LT_EOF +], [$1], [GCJ], [cat > conftest.$ac_ext <<_LT_EOF +public class foo { + private int a; + public void bar (void) { + a = 0; + } +}; +_LT_EOF +], [$1], [GO], [cat > conftest.$ac_ext <<_LT_EOF +package foo +func foo() { +} +_LT_EOF +]) + +_lt_libdeps_save_CFLAGS=$CFLAGS +case "$CC $CFLAGS " in #( +*\ -flto*\ *) CFLAGS="$CFLAGS -fno-lto" ;; +*\ -fwhopr*\ *) CFLAGS="$CFLAGS -fno-whopr" ;; +*\ -fuse-linker-plugin*\ *) CFLAGS="$CFLAGS -fno-use-linker-plugin" ;; +esac + +dnl Parse the compiler output and extract the necessary +dnl objects, libraries and library flags. +if AC_TRY_EVAL(ac_compile); then + # Parse the compiler output and extract the necessary + # objects, libraries and library flags. + + # Sentinel used to keep track of whether or not we are before + # the conftest object file. + pre_test_object_deps_done=no + + for p in `eval "$output_verbose_link_cmd"`; do + case $prev$p in + + -L* | -R* | -l*) + # Some compilers place space between "-{L,R}" and the path. + # Remove the space. + if test x-L = "$p" || + test x-R = "$p"; then + prev=$p + continue + fi + + # Expand the sysroot to ease extracting the directories later. + if test -z "$prev"; then + case $p in + -L*) func_stripname_cnf '-L' '' "$p"; prev=-L; p=$func_stripname_result ;; + -R*) func_stripname_cnf '-R' '' "$p"; prev=-R; p=$func_stripname_result ;; + -l*) func_stripname_cnf '-l' '' "$p"; prev=-l; p=$func_stripname_result ;; + esac + fi + case $p in + =*) func_stripname_cnf '=' '' "$p"; p=$lt_sysroot$func_stripname_result ;; + esac + if test no = "$pre_test_object_deps_done"; then + case $prev in + -L | -R) + # Internal compiler library paths should come after those + # provided the user. The postdeps already come after the + # user supplied libs so there is no need to process them. + if test -z "$_LT_TAGVAR(compiler_lib_search_path, $1)"; then + _LT_TAGVAR(compiler_lib_search_path, $1)=$prev$p + else + _LT_TAGVAR(compiler_lib_search_path, $1)="${_LT_TAGVAR(compiler_lib_search_path, $1)} $prev$p" + fi + ;; + # The "-l" case would never come before the object being + # linked, so don't bother handling this case. + esac + else + if test -z "$_LT_TAGVAR(postdeps, $1)"; then + _LT_TAGVAR(postdeps, $1)=$prev$p + else + _LT_TAGVAR(postdeps, $1)="${_LT_TAGVAR(postdeps, $1)} $prev$p" + fi + fi + prev= + ;; + + *.lto.$objext) ;; # Ignore GCC LTO objects + *.$objext) + # This assumes that the test object file only shows up + # once in the compiler output. + if test "$p" = "conftest.$objext"; then + pre_test_object_deps_done=yes + continue + fi + + if test no = "$pre_test_object_deps_done"; then + if test -z "$_LT_TAGVAR(predep_objects, $1)"; then + _LT_TAGVAR(predep_objects, $1)=$p + else + _LT_TAGVAR(predep_objects, $1)="$_LT_TAGVAR(predep_objects, $1) $p" + fi + else + if test -z "$_LT_TAGVAR(postdep_objects, $1)"; then + _LT_TAGVAR(postdep_objects, $1)=$p + else + _LT_TAGVAR(postdep_objects, $1)="$_LT_TAGVAR(postdep_objects, $1) $p" + fi + fi + ;; + + *) ;; # Ignore the rest. + + esac + done + + # Clean up. + rm -f a.out a.exe +else + echo "libtool.m4: error: problem compiling $1 test program" +fi + +$RM -f confest.$objext +CFLAGS=$_lt_libdeps_save_CFLAGS + +# PORTME: override above test on systems where it is broken +m4_if([$1], [CXX], +[case $host_os in +interix[[3-9]]*) + # Interix 3.5 installs completely hosed .la files for C++, so rather than + # hack all around it, let's just trust "g++" to DTRT. + _LT_TAGVAR(predep_objects,$1)= + _LT_TAGVAR(postdep_objects,$1)= + _LT_TAGVAR(postdeps,$1)= + ;; +esac +]) + +case " $_LT_TAGVAR(postdeps, $1) " in +*" -lc "*) _LT_TAGVAR(archive_cmds_need_lc, $1)=no ;; +esac + _LT_TAGVAR(compiler_lib_search_dirs, $1)= +if test -n "${_LT_TAGVAR(compiler_lib_search_path, $1)}"; then + _LT_TAGVAR(compiler_lib_search_dirs, $1)=`echo " ${_LT_TAGVAR(compiler_lib_search_path, $1)}" | $SED -e 's! -L! !g' -e 's!^ !!'` +fi +_LT_TAGDECL([], [compiler_lib_search_dirs], [1], + [The directories searched by this compiler when creating a shared library]) +_LT_TAGDECL([], [predep_objects], [1], + [Dependencies to place before and after the objects being linked to + create a shared library]) +_LT_TAGDECL([], [postdep_objects], [1]) +_LT_TAGDECL([], [predeps], [1]) +_LT_TAGDECL([], [postdeps], [1]) +_LT_TAGDECL([], [compiler_lib_search_path], [1], + [The library search path used internally by the compiler when linking + a shared library]) +])# _LT_SYS_HIDDEN_LIBDEPS + + +# _LT_LANG_F77_CONFIG([TAG]) +# -------------------------- +# Ensure that the configuration variables for a Fortran 77 compiler are +# suitably defined. These variables are subsequently used by _LT_CONFIG +# to write the compiler configuration to 'libtool'. +m4_defun([_LT_LANG_F77_CONFIG], +[AC_LANG_PUSH(Fortran 77) +if test -z "$F77" || test no = "$F77"; then + _lt_disable_F77=yes +fi + +_LT_TAGVAR(archive_cmds_need_lc, $1)=no +_LT_TAGVAR(allow_undefined_flag, $1)= +_LT_TAGVAR(always_export_symbols, $1)=no +_LT_TAGVAR(archive_expsym_cmds, $1)= +_LT_TAGVAR(export_dynamic_flag_spec, $1)= +_LT_TAGVAR(hardcode_direct, $1)=no +_LT_TAGVAR(hardcode_direct_absolute, $1)=no +_LT_TAGVAR(hardcode_libdir_flag_spec, $1)= +_LT_TAGVAR(hardcode_libdir_separator, $1)= +_LT_TAGVAR(hardcode_minus_L, $1)=no +_LT_TAGVAR(hardcode_automatic, $1)=no +_LT_TAGVAR(inherit_rpath, $1)=no +_LT_TAGVAR(module_cmds, $1)= +_LT_TAGVAR(module_expsym_cmds, $1)= +_LT_TAGVAR(link_all_deplibs, $1)=unknown +_LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds +_LT_TAGVAR(reload_flag, $1)=$reload_flag +_LT_TAGVAR(reload_cmds, $1)=$reload_cmds +_LT_TAGVAR(no_undefined_flag, $1)= +_LT_TAGVAR(whole_archive_flag_spec, $1)= +_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no + +# Source file extension for f77 test sources. +ac_ext=f + +# Object file extension for compiled f77 test sources. +objext=o +_LT_TAGVAR(objext, $1)=$objext + +# No sense in running all these tests if we already determined that +# the F77 compiler isn't working. Some variables (like enable_shared) +# are currently assumed to apply to all compilers on this platform, +# and will be corrupted by setting them based on a non-working compiler. +if test yes != "$_lt_disable_F77"; then + # Code to be used in simple compile tests + lt_simple_compile_test_code="\ + subroutine t + return + end +" + + # Code to be used in simple link tests + lt_simple_link_test_code="\ + program t + end +" + + # ltmain only uses $CC for tagged configurations so make sure $CC is set. + _LT_TAG_COMPILER + + # save warnings/boilerplate of simple test code + _LT_COMPILER_BOILERPLATE + _LT_LINKER_BOILERPLATE + + # Allow CC to be a program name with arguments. + lt_save_CC=$CC + lt_save_GCC=$GCC + lt_save_CFLAGS=$CFLAGS + CC=${F77-"f77"} + CFLAGS=$FFLAGS + compiler=$CC + _LT_TAGVAR(compiler, $1)=$CC + _LT_CC_BASENAME([$compiler]) + GCC=$G77 + if test -n "$compiler"; then + AC_MSG_CHECKING([if libtool supports shared libraries]) + AC_MSG_RESULT([$can_build_shared]) + + AC_MSG_CHECKING([whether to build shared libraries]) + test no = "$can_build_shared" && enable_shared=no + + # On AIX, shared libraries and static libraries use the same namespace, and + # are all built from PIC. + case $host_os in + aix3*) + test yes = "$enable_shared" && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + aix[[4-9]]*) + if test ia64 != "$host_cpu"; then + case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in + yes,aix,yes) ;; # shared object as lib.so file only + yes,svr4,*) ;; # shared object as lib.so archive member only + yes,*) enable_static=no ;; # shared object in lib.a archive as well + esac + fi + ;; + esac + AC_MSG_RESULT([$enable_shared]) + + AC_MSG_CHECKING([whether to build static libraries]) + # Make sure either enable_shared or enable_static is yes. + test yes = "$enable_shared" || enable_static=yes + AC_MSG_RESULT([$enable_static]) + + _LT_TAGVAR(GCC, $1)=$G77 + _LT_TAGVAR(LD, $1)=$LD + + ## CAVEAT EMPTOR: + ## There is no encapsulation within the following macros, do not change + ## the running order or otherwise move them around unless you know exactly + ## what you are doing... + _LT_COMPILER_PIC($1) + _LT_COMPILER_C_O($1) + _LT_COMPILER_FILE_LOCKS($1) + _LT_LINKER_SHLIBS($1) + _LT_SYS_DYNAMIC_LINKER($1) + _LT_LINKER_HARDCODE_LIBPATH($1) + + _LT_CONFIG($1) + fi # test -n "$compiler" + + GCC=$lt_save_GCC + CC=$lt_save_CC + CFLAGS=$lt_save_CFLAGS +fi # test yes != "$_lt_disable_F77" + +AC_LANG_POP +])# _LT_LANG_F77_CONFIG + + +# _LT_LANG_FC_CONFIG([TAG]) +# ------------------------- +# Ensure that the configuration variables for a Fortran compiler are +# suitably defined. These variables are subsequently used by _LT_CONFIG +# to write the compiler configuration to 'libtool'. +m4_defun([_LT_LANG_FC_CONFIG], +[AC_LANG_PUSH(Fortran) + +if test -z "$FC" || test no = "$FC"; then + _lt_disable_FC=yes +fi + +_LT_TAGVAR(archive_cmds_need_lc, $1)=no +_LT_TAGVAR(allow_undefined_flag, $1)= +_LT_TAGVAR(always_export_symbols, $1)=no +_LT_TAGVAR(archive_expsym_cmds, $1)= +_LT_TAGVAR(export_dynamic_flag_spec, $1)= +_LT_TAGVAR(hardcode_direct, $1)=no +_LT_TAGVAR(hardcode_direct_absolute, $1)=no +_LT_TAGVAR(hardcode_libdir_flag_spec, $1)= +_LT_TAGVAR(hardcode_libdir_separator, $1)= +_LT_TAGVAR(hardcode_minus_L, $1)=no +_LT_TAGVAR(hardcode_automatic, $1)=no +_LT_TAGVAR(inherit_rpath, $1)=no +_LT_TAGVAR(module_cmds, $1)= +_LT_TAGVAR(module_expsym_cmds, $1)= +_LT_TAGVAR(link_all_deplibs, $1)=unknown +_LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds +_LT_TAGVAR(reload_flag, $1)=$reload_flag +_LT_TAGVAR(reload_cmds, $1)=$reload_cmds +_LT_TAGVAR(no_undefined_flag, $1)= +_LT_TAGVAR(whole_archive_flag_spec, $1)= +_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no + +# Source file extension for fc test sources. +ac_ext=${ac_fc_srcext-f} + +# Object file extension for compiled fc test sources. +objext=o +_LT_TAGVAR(objext, $1)=$objext + +# No sense in running all these tests if we already determined that +# the FC compiler isn't working. Some variables (like enable_shared) +# are currently assumed to apply to all compilers on this platform, +# and will be corrupted by setting them based on a non-working compiler. +if test yes != "$_lt_disable_FC"; then + # Code to be used in simple compile tests + lt_simple_compile_test_code="\ + subroutine t + return + end +" + + # Code to be used in simple link tests + lt_simple_link_test_code="\ + program t + end +" + + # ltmain only uses $CC for tagged configurations so make sure $CC is set. + _LT_TAG_COMPILER + + # save warnings/boilerplate of simple test code + _LT_COMPILER_BOILERPLATE + _LT_LINKER_BOILERPLATE + + # Allow CC to be a program name with arguments. + lt_save_CC=$CC + lt_save_GCC=$GCC + lt_save_CFLAGS=$CFLAGS + CC=${FC-"f95"} + CFLAGS=$FCFLAGS + compiler=$CC + GCC=$ac_cv_fc_compiler_gnu + + _LT_TAGVAR(compiler, $1)=$CC + _LT_CC_BASENAME([$compiler]) + + if test -n "$compiler"; then + AC_MSG_CHECKING([if libtool supports shared libraries]) + AC_MSG_RESULT([$can_build_shared]) + + AC_MSG_CHECKING([whether to build shared libraries]) + test no = "$can_build_shared" && enable_shared=no + + # On AIX, shared libraries and static libraries use the same namespace, and + # are all built from PIC. + case $host_os in + aix3*) + test yes = "$enable_shared" && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + aix[[4-9]]*) + if test ia64 != "$host_cpu"; then + case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in + yes,aix,yes) ;; # shared object as lib.so file only + yes,svr4,*) ;; # shared object as lib.so archive member only + yes,*) enable_static=no ;; # shared object in lib.a archive as well + esac + fi + ;; + esac + AC_MSG_RESULT([$enable_shared]) + + AC_MSG_CHECKING([whether to build static libraries]) + # Make sure either enable_shared or enable_static is yes. + test yes = "$enable_shared" || enable_static=yes + AC_MSG_RESULT([$enable_static]) + + _LT_TAGVAR(GCC, $1)=$ac_cv_fc_compiler_gnu + _LT_TAGVAR(LD, $1)=$LD + + ## CAVEAT EMPTOR: + ## There is no encapsulation within the following macros, do not change + ## the running order or otherwise move them around unless you know exactly + ## what you are doing... + _LT_SYS_HIDDEN_LIBDEPS($1) + _LT_COMPILER_PIC($1) + _LT_COMPILER_C_O($1) + _LT_COMPILER_FILE_LOCKS($1) + _LT_LINKER_SHLIBS($1) + _LT_SYS_DYNAMIC_LINKER($1) + _LT_LINKER_HARDCODE_LIBPATH($1) + + _LT_CONFIG($1) + fi # test -n "$compiler" + + GCC=$lt_save_GCC + CC=$lt_save_CC + CFLAGS=$lt_save_CFLAGS +fi # test yes != "$_lt_disable_FC" + +AC_LANG_POP +])# _LT_LANG_FC_CONFIG + + +# _LT_LANG_GCJ_CONFIG([TAG]) +# -------------------------- +# Ensure that the configuration variables for the GNU Java Compiler compiler +# are suitably defined. These variables are subsequently used by _LT_CONFIG +# to write the compiler configuration to 'libtool'. +m4_defun([_LT_LANG_GCJ_CONFIG], +[AC_REQUIRE([LT_PROG_GCJ])dnl +AC_LANG_SAVE + +# Source file extension for Java test sources. +ac_ext=java + +# Object file extension for compiled Java test sources. +objext=o +_LT_TAGVAR(objext, $1)=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="class foo {}" + +# Code to be used in simple link tests +lt_simple_link_test_code='public class conftest { public static void main(String[[]] argv) {}; }' + +# ltmain only uses $CC for tagged configurations so make sure $CC is set. +_LT_TAG_COMPILER + +# save warnings/boilerplate of simple test code +_LT_COMPILER_BOILERPLATE +_LT_LINKER_BOILERPLATE + +# Allow CC to be a program name with arguments. +lt_save_CC=$CC +lt_save_CFLAGS=$CFLAGS +lt_save_GCC=$GCC +GCC=yes +CC=${GCJ-"gcj"} +CFLAGS=$GCJFLAGS +compiler=$CC +_LT_TAGVAR(compiler, $1)=$CC +_LT_TAGVAR(LD, $1)=$LD +_LT_CC_BASENAME([$compiler]) + +# GCJ did not exist at the time GCC didn't implicitly link libc in. +_LT_TAGVAR(archive_cmds_need_lc, $1)=no + +_LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds +_LT_TAGVAR(reload_flag, $1)=$reload_flag +_LT_TAGVAR(reload_cmds, $1)=$reload_cmds + +if test -n "$compiler"; then + _LT_COMPILER_NO_RTTI($1) + _LT_COMPILER_PIC($1) + _LT_COMPILER_C_O($1) + _LT_COMPILER_FILE_LOCKS($1) + _LT_LINKER_SHLIBS($1) + _LT_LINKER_HARDCODE_LIBPATH($1) + + _LT_CONFIG($1) +fi + +AC_LANG_RESTORE + +GCC=$lt_save_GCC +CC=$lt_save_CC +CFLAGS=$lt_save_CFLAGS +])# _LT_LANG_GCJ_CONFIG + + +# _LT_LANG_GO_CONFIG([TAG]) +# -------------------------- +# Ensure that the configuration variables for the GNU Go compiler +# are suitably defined. These variables are subsequently used by _LT_CONFIG +# to write the compiler configuration to 'libtool'. +m4_defun([_LT_LANG_GO_CONFIG], +[AC_REQUIRE([LT_PROG_GO])dnl +AC_LANG_SAVE + +# Source file extension for Go test sources. +ac_ext=go + +# Object file extension for compiled Go test sources. +objext=o +_LT_TAGVAR(objext, $1)=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="package main; func main() { }" + +# Code to be used in simple link tests +lt_simple_link_test_code='package main; func main() { }' + +# ltmain only uses $CC for tagged configurations so make sure $CC is set. +_LT_TAG_COMPILER + +# save warnings/boilerplate of simple test code +_LT_COMPILER_BOILERPLATE +_LT_LINKER_BOILERPLATE + +# Allow CC to be a program name with arguments. +lt_save_CC=$CC +lt_save_CFLAGS=$CFLAGS +lt_save_GCC=$GCC +GCC=yes +CC=${GOC-"gccgo"} +CFLAGS=$GOFLAGS +compiler=$CC +_LT_TAGVAR(compiler, $1)=$CC +_LT_TAGVAR(LD, $1)=$LD +_LT_CC_BASENAME([$compiler]) + +# Go did not exist at the time GCC didn't implicitly link libc in. +_LT_TAGVAR(archive_cmds_need_lc, $1)=no + +_LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds +_LT_TAGVAR(reload_flag, $1)=$reload_flag +_LT_TAGVAR(reload_cmds, $1)=$reload_cmds + +if test -n "$compiler"; then + _LT_COMPILER_NO_RTTI($1) + _LT_COMPILER_PIC($1) + _LT_COMPILER_C_O($1) + _LT_COMPILER_FILE_LOCKS($1) + _LT_LINKER_SHLIBS($1) + _LT_LINKER_HARDCODE_LIBPATH($1) + + _LT_CONFIG($1) +fi + +AC_LANG_RESTORE + +GCC=$lt_save_GCC +CC=$lt_save_CC +CFLAGS=$lt_save_CFLAGS +])# _LT_LANG_GO_CONFIG + + +# _LT_LANG_RC_CONFIG([TAG]) +# ------------------------- +# Ensure that the configuration variables for the Windows resource compiler +# are suitably defined. These variables are subsequently used by _LT_CONFIG +# to write the compiler configuration to 'libtool'. +m4_defun([_LT_LANG_RC_CONFIG], +[AC_REQUIRE([LT_PROG_RC])dnl +AC_LANG_SAVE + +# Source file extension for RC test sources. +ac_ext=rc + +# Object file extension for compiled RC test sources. +objext=o +_LT_TAGVAR(objext, $1)=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code='sample MENU { MENUITEM "&Soup", 100, CHECKED }' + +# Code to be used in simple link tests +lt_simple_link_test_code=$lt_simple_compile_test_code + +# ltmain only uses $CC for tagged configurations so make sure $CC is set. +_LT_TAG_COMPILER + +# save warnings/boilerplate of simple test code +_LT_COMPILER_BOILERPLATE +_LT_LINKER_BOILERPLATE + +# Allow CC to be a program name with arguments. +lt_save_CC=$CC +lt_save_CFLAGS=$CFLAGS +lt_save_GCC=$GCC +GCC= +CC=${RC-"windres"} +CFLAGS= +compiler=$CC +_LT_TAGVAR(compiler, $1)=$CC +_LT_CC_BASENAME([$compiler]) +_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes + +if test -n "$compiler"; then + : + _LT_CONFIG($1) +fi + +GCC=$lt_save_GCC +AC_LANG_RESTORE +CC=$lt_save_CC +CFLAGS=$lt_save_CFLAGS +])# _LT_LANG_RC_CONFIG + + +# LT_PROG_GCJ +# ----------- +AC_DEFUN([LT_PROG_GCJ], +[m4_ifdef([AC_PROG_GCJ], [AC_PROG_GCJ], + [m4_ifdef([A][M_PROG_GCJ], [A][M_PROG_GCJ], + [AC_CHECK_TOOL(GCJ, gcj,) + test set = "${GCJFLAGS+set}" || GCJFLAGS="-g -O2" + AC_SUBST(GCJFLAGS)])])[]dnl +]) + +# Old name: +AU_ALIAS([LT_AC_PROG_GCJ], [LT_PROG_GCJ]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([LT_AC_PROG_GCJ], []) + + +# LT_PROG_GO +# ---------- +AC_DEFUN([LT_PROG_GO], +[AC_CHECK_TOOL(GOC, gccgo,) +]) + + +# LT_PROG_RC +# ---------- +AC_DEFUN([LT_PROG_RC], +[AC_CHECK_TOOL(RC, windres,) +]) + +# Old name: +AU_ALIAS([LT_AC_PROG_RC], [LT_PROG_RC]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([LT_AC_PROG_RC], []) + + +# _LT_DECL_EGREP +# -------------- +# If we don't have a new enough Autoconf to choose the best grep +# available, choose the one first in the user's PATH. +m4_defun([_LT_DECL_EGREP], +[AC_REQUIRE([AC_PROG_EGREP])dnl +AC_REQUIRE([AC_PROG_FGREP])dnl +test -z "$GREP" && GREP=grep +_LT_DECL([], [GREP], [1], [A grep program that handles long lines]) +_LT_DECL([], [EGREP], [1], [An ERE matcher]) +_LT_DECL([], [FGREP], [1], [A literal string matcher]) +dnl Non-bleeding-edge autoconf doesn't subst GREP, so do it here too +AC_SUBST([GREP]) +]) + + +# _LT_DECL_OBJDUMP +# -------------- +# If we don't have a new enough Autoconf to choose the best objdump +# available, choose the one first in the user's PATH. +m4_defun([_LT_DECL_OBJDUMP], +[AC_CHECK_TOOL(OBJDUMP, objdump, false) +test -z "$OBJDUMP" && OBJDUMP=objdump +_LT_DECL([], [OBJDUMP], [1], [An object symbol dumper]) +AC_SUBST([OBJDUMP]) +]) + +# _LT_DECL_DLLTOOL +# ---------------- +# Ensure DLLTOOL variable is set. +m4_defun([_LT_DECL_DLLTOOL], +[AC_CHECK_TOOL(DLLTOOL, dlltool, false) +test -z "$DLLTOOL" && DLLTOOL=dlltool +_LT_DECL([], [DLLTOOL], [1], [DLL creation program]) +AC_SUBST([DLLTOOL]) +]) + +# _LT_DECL_SED +# ------------ +# Check for a fully-functional sed program, that truncates +# as few characters as possible. Prefer GNU sed if found. +m4_defun([_LT_DECL_SED], +[AC_PROG_SED +test -z "$SED" && SED=sed +Xsed="$SED -e 1s/^X//" +_LT_DECL([], [SED], [1], [A sed program that does not truncate output]) +_LT_DECL([], [Xsed], ["\$SED -e 1s/^X//"], + [Sed that helps us avoid accidentally triggering echo(1) options like -n]) +])# _LT_DECL_SED + +m4_ifndef([AC_PROG_SED], [ +# NOTE: This macro has been submitted for inclusion into # +# GNU Autoconf as AC_PROG_SED. When it is available in # +# a released version of Autoconf we should remove this # +# macro and use it instead. # + +m4_defun([AC_PROG_SED], +[AC_MSG_CHECKING([for a sed that does not truncate output]) +AC_CACHE_VAL(lt_cv_path_SED, +[# Loop through the user's path and test for sed and gsed. +# Then use that list of sed's as ones to test for truncation. +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for lt_ac_prog in sed gsed; do + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$lt_ac_prog$ac_exec_ext"; then + lt_ac_sed_list="$lt_ac_sed_list $as_dir/$lt_ac_prog$ac_exec_ext" + fi + done + done +done +IFS=$as_save_IFS +lt_ac_max=0 +lt_ac_count=0 +# Add /usr/xpg4/bin/sed as it is typically found on Solaris +# along with /bin/sed that truncates output. +for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do + test ! -f "$lt_ac_sed" && continue + cat /dev/null > conftest.in + lt_ac_count=0 + echo $ECHO_N "0123456789$ECHO_C" >conftest.in + # Check for GNU sed and select it if it is found. + if "$lt_ac_sed" --version 2>&1 < /dev/null | grep 'GNU' > /dev/null; then + lt_cv_path_SED=$lt_ac_sed + break + fi + while true; do + cat conftest.in conftest.in >conftest.tmp + mv conftest.tmp conftest.in + cp conftest.in conftest.nl + echo >>conftest.nl + $lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break + cmp -s conftest.out conftest.nl || break + # 10000 chars as input seems more than enough + test 10 -lt "$lt_ac_count" && break + lt_ac_count=`expr $lt_ac_count + 1` + if test "$lt_ac_count" -gt "$lt_ac_max"; then + lt_ac_max=$lt_ac_count + lt_cv_path_SED=$lt_ac_sed + fi + done +done +]) +SED=$lt_cv_path_SED +AC_SUBST([SED]) +AC_MSG_RESULT([$SED]) +])#AC_PROG_SED +])#m4_ifndef + +# Old name: +AU_ALIAS([LT_AC_PROG_SED], [AC_PROG_SED]) +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([LT_AC_PROG_SED], []) + + +# _LT_CHECK_SHELL_FEATURES +# ------------------------ +# Find out whether the shell is Bourne or XSI compatible, +# or has some other useful features. +m4_defun([_LT_CHECK_SHELL_FEATURES], +[if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then + lt_unset=unset +else + lt_unset=false +fi +_LT_DECL([], [lt_unset], [0], [whether the shell understands "unset"])dnl + +# test EBCDIC or ASCII +case `echo X|tr X '\101'` in + A) # ASCII based system + # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr + lt_SP2NL='tr \040 \012' + lt_NL2SP='tr \015\012 \040\040' + ;; + *) # EBCDIC based system + lt_SP2NL='tr \100 \n' + lt_NL2SP='tr \r\n \100\100' + ;; +esac +_LT_DECL([SP2NL], [lt_SP2NL], [1], [turn spaces into newlines])dnl +_LT_DECL([NL2SP], [lt_NL2SP], [1], [turn newlines into spaces])dnl +])# _LT_CHECK_SHELL_FEATURES + + +# _LT_PATH_CONVERSION_FUNCTIONS +# ----------------------------- +# Determine what file name conversion functions should be used by +# func_to_host_file (and, implicitly, by func_to_host_path). These are needed +# for certain cross-compile configurations and native mingw. +m4_defun([_LT_PATH_CONVERSION_FUNCTIONS], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +AC_REQUIRE([AC_CANONICAL_BUILD])dnl +AC_MSG_CHECKING([how to convert $build file names to $host format]) +AC_CACHE_VAL(lt_cv_to_host_file_cmd, +[case $host in + *-*-mingw* ) + case $build in + *-*-mingw* ) # actually msys + lt_cv_to_host_file_cmd=func_convert_file_msys_to_w32 + ;; + *-*-cygwin* ) + lt_cv_to_host_file_cmd=func_convert_file_cygwin_to_w32 + ;; + * ) # otherwise, assume *nix + lt_cv_to_host_file_cmd=func_convert_file_nix_to_w32 + ;; + esac + ;; + *-*-cygwin* ) + case $build in + *-*-mingw* ) # actually msys + lt_cv_to_host_file_cmd=func_convert_file_msys_to_cygwin + ;; + *-*-cygwin* ) + lt_cv_to_host_file_cmd=func_convert_file_noop + ;; + * ) # otherwise, assume *nix + lt_cv_to_host_file_cmd=func_convert_file_nix_to_cygwin + ;; + esac + ;; + * ) # unhandled hosts (and "normal" native builds) + lt_cv_to_host_file_cmd=func_convert_file_noop + ;; +esac +]) +to_host_file_cmd=$lt_cv_to_host_file_cmd +AC_MSG_RESULT([$lt_cv_to_host_file_cmd]) +_LT_DECL([to_host_file_cmd], [lt_cv_to_host_file_cmd], + [0], [convert $build file names to $host format])dnl + +AC_MSG_CHECKING([how to convert $build file names to toolchain format]) +AC_CACHE_VAL(lt_cv_to_tool_file_cmd, +[#assume ordinary cross tools, or native build. +lt_cv_to_tool_file_cmd=func_convert_file_noop +case $host in + *-*-mingw* ) + case $build in + *-*-mingw* ) # actually msys + lt_cv_to_tool_file_cmd=func_convert_file_msys_to_w32 + ;; + esac + ;; +esac +]) +to_tool_file_cmd=$lt_cv_to_tool_file_cmd +AC_MSG_RESULT([$lt_cv_to_tool_file_cmd]) +_LT_DECL([to_tool_file_cmd], [lt_cv_to_tool_file_cmd], + [0], [convert $build files to toolchain format])dnl +])# _LT_PATH_CONVERSION_FUNCTIONS + +# Helper functions for option handling. -*- Autoconf -*- +# +# Copyright (C) 2004-2005, 2007-2009, 2011-2018 Free Software +# Foundation, Inc. +# Written by Gary V. Vaughan, 2004 +# +# This file is free software; the Free Software Foundation gives +# unlimited permission to copy and/or distribute it, with or without +# modifications, as long as this notice is preserved. + +# serial 8 ltoptions.m4 + +# This is to help aclocal find these macros, as it can't see m4_define. +AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])]) + + +# _LT_MANGLE_OPTION(MACRO-NAME, OPTION-NAME) +# ------------------------------------------ +m4_define([_LT_MANGLE_OPTION], +[[_LT_OPTION_]m4_bpatsubst($1__$2, [[^a-zA-Z0-9_]], [_])]) + + +# _LT_SET_OPTION(MACRO-NAME, OPTION-NAME) +# --------------------------------------- +# Set option OPTION-NAME for macro MACRO-NAME, and if there is a +# matching handler defined, dispatch to it. Other OPTION-NAMEs are +# saved as a flag. +m4_define([_LT_SET_OPTION], +[m4_define(_LT_MANGLE_OPTION([$1], [$2]))dnl +m4_ifdef(_LT_MANGLE_DEFUN([$1], [$2]), + _LT_MANGLE_DEFUN([$1], [$2]), + [m4_warning([Unknown $1 option '$2'])])[]dnl +]) + + +# _LT_IF_OPTION(MACRO-NAME, OPTION-NAME, IF-SET, [IF-NOT-SET]) +# ------------------------------------------------------------ +# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. +m4_define([_LT_IF_OPTION], +[m4_ifdef(_LT_MANGLE_OPTION([$1], [$2]), [$3], [$4])]) + + +# _LT_UNLESS_OPTIONS(MACRO-NAME, OPTION-LIST, IF-NOT-SET) +# ------------------------------------------------------- +# Execute IF-NOT-SET unless all options in OPTION-LIST for MACRO-NAME +# are set. +m4_define([_LT_UNLESS_OPTIONS], +[m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), + [m4_ifdef(_LT_MANGLE_OPTION([$1], _LT_Option), + [m4_define([$0_found])])])[]dnl +m4_ifdef([$0_found], [m4_undefine([$0_found])], [$3 +])[]dnl +]) + + +# _LT_SET_OPTIONS(MACRO-NAME, OPTION-LIST) +# ---------------------------------------- +# OPTION-LIST is a space-separated list of Libtool options associated +# with MACRO-NAME. If any OPTION has a matching handler declared with +# LT_OPTION_DEFINE, dispatch to that macro; otherwise complain about +# the unknown option and exit. +m4_defun([_LT_SET_OPTIONS], +[# Set options +m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), + [_LT_SET_OPTION([$1], _LT_Option)]) + +m4_if([$1],[LT_INIT],[ + dnl + dnl Simply set some default values (i.e off) if boolean options were not + dnl specified: + _LT_UNLESS_OPTIONS([LT_INIT], [dlopen], [enable_dlopen=no + ]) + _LT_UNLESS_OPTIONS([LT_INIT], [win32-dll], [enable_win32_dll=no + ]) + dnl + dnl If no reference was made to various pairs of opposing options, then + dnl we run the default mode handler for the pair. For example, if neither + dnl 'shared' nor 'disable-shared' was passed, we enable building of shared + dnl archives by default: + _LT_UNLESS_OPTIONS([LT_INIT], [shared disable-shared], [_LT_ENABLE_SHARED]) + _LT_UNLESS_OPTIONS([LT_INIT], [static disable-static], [_LT_ENABLE_STATIC]) + _LT_UNLESS_OPTIONS([LT_INIT], [pic-only no-pic], [_LT_WITH_PIC]) + _LT_UNLESS_OPTIONS([LT_INIT], [fast-install disable-fast-install], + [_LT_ENABLE_FAST_INSTALL]) + _LT_UNLESS_OPTIONS([LT_INIT], [aix-soname=aix aix-soname=both aix-soname=svr4], + [_LT_WITH_AIX_SONAME([aix])]) + ]) +])# _LT_SET_OPTIONS + + + +# _LT_MANGLE_DEFUN(MACRO-NAME, OPTION-NAME) +# ----------------------------------------- +m4_define([_LT_MANGLE_DEFUN], +[[_LT_OPTION_DEFUN_]m4_bpatsubst(m4_toupper([$1__$2]), [[^A-Z0-9_]], [_])]) + + +# LT_OPTION_DEFINE(MACRO-NAME, OPTION-NAME, CODE) +# ----------------------------------------------- +m4_define([LT_OPTION_DEFINE], +[m4_define(_LT_MANGLE_DEFUN([$1], [$2]), [$3])[]dnl +])# LT_OPTION_DEFINE + + +# dlopen +# ------ +LT_OPTION_DEFINE([LT_INIT], [dlopen], [enable_dlopen=yes +]) + +AU_DEFUN([AC_LIBTOOL_DLOPEN], +[_LT_SET_OPTION([LT_INIT], [dlopen]) +AC_DIAGNOSE([obsolete], +[$0: Remove this warning and the call to _LT_SET_OPTION when you +put the 'dlopen' option into LT_INIT's first parameter.]) +]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_DLOPEN], []) + + +# win32-dll +# --------- +# Declare package support for building win32 dll's. +LT_OPTION_DEFINE([LT_INIT], [win32-dll], +[enable_win32_dll=yes + +case $host in +*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc*) + AC_CHECK_TOOL(AS, as, false) + AC_CHECK_TOOL(DLLTOOL, dlltool, false) + AC_CHECK_TOOL(OBJDUMP, objdump, false) + ;; +esac + +test -z "$AS" && AS=as +_LT_DECL([], [AS], [1], [Assembler program])dnl + +test -z "$DLLTOOL" && DLLTOOL=dlltool +_LT_DECL([], [DLLTOOL], [1], [DLL creation program])dnl + +test -z "$OBJDUMP" && OBJDUMP=objdump +_LT_DECL([], [OBJDUMP], [1], [Object dumper program])dnl +])# win32-dll + +AU_DEFUN([AC_LIBTOOL_WIN32_DLL], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +_LT_SET_OPTION([LT_INIT], [win32-dll]) +AC_DIAGNOSE([obsolete], +[$0: Remove this warning and the call to _LT_SET_OPTION when you +put the 'win32-dll' option into LT_INIT's first parameter.]) +]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_WIN32_DLL], []) + + +# _LT_ENABLE_SHARED([DEFAULT]) +# ---------------------------- +# implement the --enable-shared flag, and supports the 'shared' and +# 'disable-shared' LT_INIT options. +# DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. +m4_define([_LT_ENABLE_SHARED], +[m4_define([_LT_ENABLE_SHARED_DEFAULT], [m4_if($1, no, no, yes)])dnl +AC_ARG_ENABLE([shared], + [AS_HELP_STRING([--enable-shared@<:@=PKGS@:>@], + [build shared libraries @<:@default=]_LT_ENABLE_SHARED_DEFAULT[@:>@])], + [p=${PACKAGE-default} + case $enableval in + yes) enable_shared=yes ;; + no) enable_shared=no ;; + *) + enable_shared=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, + for pkg in $enableval; do + IFS=$lt_save_ifs + if test "X$pkg" = "X$p"; then + enable_shared=yes + fi + done + IFS=$lt_save_ifs + ;; + esac], + [enable_shared=]_LT_ENABLE_SHARED_DEFAULT) + + _LT_DECL([build_libtool_libs], [enable_shared], [0], + [Whether or not to build shared libraries]) +])# _LT_ENABLE_SHARED + +LT_OPTION_DEFINE([LT_INIT], [shared], [_LT_ENABLE_SHARED([yes])]) +LT_OPTION_DEFINE([LT_INIT], [disable-shared], [_LT_ENABLE_SHARED([no])]) + +# Old names: +AC_DEFUN([AC_ENABLE_SHARED], +[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[shared]) +]) + +AC_DEFUN([AC_DISABLE_SHARED], +[_LT_SET_OPTION([LT_INIT], [disable-shared]) +]) + +AU_DEFUN([AM_ENABLE_SHARED], [AC_ENABLE_SHARED($@)]) +AU_DEFUN([AM_DISABLE_SHARED], [AC_DISABLE_SHARED($@)]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AM_ENABLE_SHARED], []) +dnl AC_DEFUN([AM_DISABLE_SHARED], []) + + + +# _LT_ENABLE_STATIC([DEFAULT]) +# ---------------------------- +# implement the --enable-static flag, and support the 'static' and +# 'disable-static' LT_INIT options. +# DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. +m4_define([_LT_ENABLE_STATIC], +[m4_define([_LT_ENABLE_STATIC_DEFAULT], [m4_if($1, no, no, yes)])dnl +AC_ARG_ENABLE([static], + [AS_HELP_STRING([--enable-static@<:@=PKGS@:>@], + [build static libraries @<:@default=]_LT_ENABLE_STATIC_DEFAULT[@:>@])], + [p=${PACKAGE-default} + case $enableval in + yes) enable_static=yes ;; + no) enable_static=no ;; + *) + enable_static=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, + for pkg in $enableval; do + IFS=$lt_save_ifs + if test "X$pkg" = "X$p"; then + enable_static=yes + fi + done + IFS=$lt_save_ifs + ;; + esac], + [enable_static=]_LT_ENABLE_STATIC_DEFAULT) + + _LT_DECL([build_old_libs], [enable_static], [0], + [Whether or not to build static libraries]) +])# _LT_ENABLE_STATIC + +LT_OPTION_DEFINE([LT_INIT], [static], [_LT_ENABLE_STATIC([yes])]) +LT_OPTION_DEFINE([LT_INIT], [disable-static], [_LT_ENABLE_STATIC([no])]) + +# Old names: +AC_DEFUN([AC_ENABLE_STATIC], +[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[static]) +]) + +AC_DEFUN([AC_DISABLE_STATIC], +[_LT_SET_OPTION([LT_INIT], [disable-static]) +]) + +AU_DEFUN([AM_ENABLE_STATIC], [AC_ENABLE_STATIC($@)]) +AU_DEFUN([AM_DISABLE_STATIC], [AC_DISABLE_STATIC($@)]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AM_ENABLE_STATIC], []) +dnl AC_DEFUN([AM_DISABLE_STATIC], []) + + + +# _LT_ENABLE_FAST_INSTALL([DEFAULT]) +# ---------------------------------- +# implement the --enable-fast-install flag, and support the 'fast-install' +# and 'disable-fast-install' LT_INIT options. +# DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. +m4_define([_LT_ENABLE_FAST_INSTALL], +[m4_define([_LT_ENABLE_FAST_INSTALL_DEFAULT], [m4_if($1, no, no, yes)])dnl +AC_ARG_ENABLE([fast-install], + [AS_HELP_STRING([--enable-fast-install@<:@=PKGS@:>@], + [optimize for fast installation @<:@default=]_LT_ENABLE_FAST_INSTALL_DEFAULT[@:>@])], + [p=${PACKAGE-default} + case $enableval in + yes) enable_fast_install=yes ;; + no) enable_fast_install=no ;; + *) + enable_fast_install=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, + for pkg in $enableval; do + IFS=$lt_save_ifs + if test "X$pkg" = "X$p"; then + enable_fast_install=yes + fi + done + IFS=$lt_save_ifs + ;; + esac], + [enable_fast_install=]_LT_ENABLE_FAST_INSTALL_DEFAULT) + +_LT_DECL([fast_install], [enable_fast_install], [0], + [Whether or not to optimize for fast installation])dnl +])# _LT_ENABLE_FAST_INSTALL + +LT_OPTION_DEFINE([LT_INIT], [fast-install], [_LT_ENABLE_FAST_INSTALL([yes])]) +LT_OPTION_DEFINE([LT_INIT], [disable-fast-install], [_LT_ENABLE_FAST_INSTALL([no])]) + +# Old names: +AU_DEFUN([AC_ENABLE_FAST_INSTALL], +[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[fast-install]) +AC_DIAGNOSE([obsolete], +[$0: Remove this warning and the call to _LT_SET_OPTION when you put +the 'fast-install' option into LT_INIT's first parameter.]) +]) + +AU_DEFUN([AC_DISABLE_FAST_INSTALL], +[_LT_SET_OPTION([LT_INIT], [disable-fast-install]) +AC_DIAGNOSE([obsolete], +[$0: Remove this warning and the call to _LT_SET_OPTION when you put +the 'disable-fast-install' option into LT_INIT's first parameter.]) +]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_ENABLE_FAST_INSTALL], []) +dnl AC_DEFUN([AM_DISABLE_FAST_INSTALL], []) + + +# _LT_WITH_AIX_SONAME([DEFAULT]) +# ---------------------------------- +# implement the --with-aix-soname flag, and support the `aix-soname=aix' +# and `aix-soname=both' and `aix-soname=svr4' LT_INIT options. DEFAULT +# is either `aix', `both' or `svr4'. If omitted, it defaults to `aix'. +m4_define([_LT_WITH_AIX_SONAME], +[m4_define([_LT_WITH_AIX_SONAME_DEFAULT], [m4_if($1, svr4, svr4, m4_if($1, both, both, aix))])dnl +shared_archive_member_spec= +case $host,$enable_shared in +power*-*-aix[[5-9]]*,yes) + AC_MSG_CHECKING([which variant of shared library versioning to provide]) + AC_ARG_WITH([aix-soname], + [AS_HELP_STRING([--with-aix-soname=aix|svr4|both], + [shared library versioning (aka "SONAME") variant to provide on AIX, @<:@default=]_LT_WITH_AIX_SONAME_DEFAULT[@:>@.])], + [case $withval in + aix|svr4|both) + ;; + *) + AC_MSG_ERROR([Unknown argument to --with-aix-soname]) + ;; + esac + lt_cv_with_aix_soname=$with_aix_soname], + [AC_CACHE_VAL([lt_cv_with_aix_soname], + [lt_cv_with_aix_soname=]_LT_WITH_AIX_SONAME_DEFAULT) + with_aix_soname=$lt_cv_with_aix_soname]) + AC_MSG_RESULT([$with_aix_soname]) + if test aix != "$with_aix_soname"; then + # For the AIX way of multilib, we name the shared archive member + # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o', + # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File. + # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag, + # the AIX toolchain works better with OBJECT_MODE set (default 32). + if test 64 = "${OBJECT_MODE-32}"; then + shared_archive_member_spec=shr_64 + else + shared_archive_member_spec=shr + fi + fi + ;; +*) + with_aix_soname=aix + ;; +esac + +_LT_DECL([], [shared_archive_member_spec], [0], + [Shared archive member basename, for filename based shared library versioning on AIX])dnl +])# _LT_WITH_AIX_SONAME + +LT_OPTION_DEFINE([LT_INIT], [aix-soname=aix], [_LT_WITH_AIX_SONAME([aix])]) +LT_OPTION_DEFINE([LT_INIT], [aix-soname=both], [_LT_WITH_AIX_SONAME([both])]) +LT_OPTION_DEFINE([LT_INIT], [aix-soname=svr4], [_LT_WITH_AIX_SONAME([svr4])]) + + +# _LT_WITH_PIC([MODE]) +# -------------------- +# implement the --with-pic flag, and support the 'pic-only' and 'no-pic' +# LT_INIT options. +# MODE is either 'yes' or 'no'. If omitted, it defaults to 'both'. +m4_define([_LT_WITH_PIC], +[AC_ARG_WITH([pic], + [AS_HELP_STRING([--with-pic@<:@=PKGS@:>@], + [try to use only PIC/non-PIC objects @<:@default=use both@:>@])], + [lt_p=${PACKAGE-default} + case $withval in + yes|no) pic_mode=$withval ;; + *) + pic_mode=default + # Look at the argument we got. We use all the common list separators. + lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, + for lt_pkg in $withval; do + IFS=$lt_save_ifs + if test "X$lt_pkg" = "X$lt_p"; then + pic_mode=yes + fi + done + IFS=$lt_save_ifs + ;; + esac], + [pic_mode=m4_default([$1], [default])]) + +_LT_DECL([], [pic_mode], [0], [What type of objects to build])dnl +])# _LT_WITH_PIC + +LT_OPTION_DEFINE([LT_INIT], [pic-only], [_LT_WITH_PIC([yes])]) +LT_OPTION_DEFINE([LT_INIT], [no-pic], [_LT_WITH_PIC([no])]) + +# Old name: +AU_DEFUN([AC_LIBTOOL_PICMODE], +[_LT_SET_OPTION([LT_INIT], [pic-only]) +AC_DIAGNOSE([obsolete], +[$0: Remove this warning and the call to _LT_SET_OPTION when you +put the 'pic-only' option into LT_INIT's first parameter.]) +]) + +dnl aclocal-1.4 backwards compatibility: +dnl AC_DEFUN([AC_LIBTOOL_PICMODE], []) + + +m4_define([_LTDL_MODE], []) +LT_OPTION_DEFINE([LTDL_INIT], [nonrecursive], + [m4_define([_LTDL_MODE], [nonrecursive])]) +LT_OPTION_DEFINE([LTDL_INIT], [recursive], + [m4_define([_LTDL_MODE], [recursive])]) +LT_OPTION_DEFINE([LTDL_INIT], [subproject], + [m4_define([_LTDL_MODE], [subproject])]) + +m4_define([_LTDL_TYPE], []) +LT_OPTION_DEFINE([LTDL_INIT], [installable], + [m4_define([_LTDL_TYPE], [installable])]) +LT_OPTION_DEFINE([LTDL_INIT], [convenience], + [m4_define([_LTDL_TYPE], [convenience])]) + +# ltsugar.m4 -- libtool m4 base layer. -*-Autoconf-*- +# +# Copyright (C) 2004-2005, 2007-2008, 2011-2018 Free Software +# Foundation, Inc. +# Written by Gary V. Vaughan, 2004 +# +# This file is free software; the Free Software Foundation gives +# unlimited permission to copy and/or distribute it, with or without +# modifications, as long as this notice is preserved. + +# serial 6 ltsugar.m4 + +# This is to help aclocal find these macros, as it can't see m4_define. +AC_DEFUN([LTSUGAR_VERSION], [m4_if([0.1])]) + + +# lt_join(SEP, ARG1, [ARG2...]) +# ----------------------------- +# Produce ARG1SEPARG2...SEPARGn, omitting [] arguments and their +# associated separator. +# Needed until we can rely on m4_join from Autoconf 2.62, since all earlier +# versions in m4sugar had bugs. +m4_define([lt_join], +[m4_if([$#], [1], [], + [$#], [2], [[$2]], + [m4_if([$2], [], [], [[$2]_])$0([$1], m4_shift(m4_shift($@)))])]) +m4_define([_lt_join], +[m4_if([$#$2], [2], [], + [m4_if([$2], [], [], [[$1$2]])$0([$1], m4_shift(m4_shift($@)))])]) + + +# lt_car(LIST) +# lt_cdr(LIST) +# ------------ +# Manipulate m4 lists. +# These macros are necessary as long as will still need to support +# Autoconf-2.59, which quotes differently. +m4_define([lt_car], [[$1]]) +m4_define([lt_cdr], +[m4_if([$#], 0, [m4_fatal([$0: cannot be called without arguments])], + [$#], 1, [], + [m4_dquote(m4_shift($@))])]) +m4_define([lt_unquote], $1) + + +# lt_append(MACRO-NAME, STRING, [SEPARATOR]) +# ------------------------------------------ +# Redefine MACRO-NAME to hold its former content plus 'SEPARATOR''STRING'. +# Note that neither SEPARATOR nor STRING are expanded; they are appended +# to MACRO-NAME as is (leaving the expansion for when MACRO-NAME is invoked). +# No SEPARATOR is output if MACRO-NAME was previously undefined (different +# than defined and empty). +# +# This macro is needed until we can rely on Autoconf 2.62, since earlier +# versions of m4sugar mistakenly expanded SEPARATOR but not STRING. +m4_define([lt_append], +[m4_define([$1], + m4_ifdef([$1], [m4_defn([$1])[$3]])[$2])]) + + + +# lt_combine(SEP, PREFIX-LIST, INFIX, SUFFIX1, [SUFFIX2...]) +# ---------------------------------------------------------- +# Produce a SEP delimited list of all paired combinations of elements of +# PREFIX-LIST with SUFFIX1 through SUFFIXn. Each element of the list +# has the form PREFIXmINFIXSUFFIXn. +# Needed until we can rely on m4_combine added in Autoconf 2.62. +m4_define([lt_combine], +[m4_if(m4_eval([$# > 3]), [1], + [m4_pushdef([_Lt_sep], [m4_define([_Lt_sep], m4_defn([lt_car]))])]]dnl +[[m4_foreach([_Lt_prefix], [$2], + [m4_foreach([_Lt_suffix], + ]m4_dquote(m4_dquote(m4_shift(m4_shift(m4_shift($@)))))[, + [_Lt_sep([$1])[]m4_defn([_Lt_prefix])[$3]m4_defn([_Lt_suffix])])])])]) + + +# lt_if_append_uniq(MACRO-NAME, VARNAME, [SEPARATOR], [UNIQ], [NOT-UNIQ]) +# ----------------------------------------------------------------------- +# Iff MACRO-NAME does not yet contain VARNAME, then append it (delimited +# by SEPARATOR if supplied) and expand UNIQ, else NOT-UNIQ. +m4_define([lt_if_append_uniq], +[m4_ifdef([$1], + [m4_if(m4_index([$3]m4_defn([$1])[$3], [$3$2$3]), [-1], + [lt_append([$1], [$2], [$3])$4], + [$5])], + [lt_append([$1], [$2], [$3])$4])]) + + +# lt_dict_add(DICT, KEY, VALUE) +# ----------------------------- +m4_define([lt_dict_add], +[m4_define([$1($2)], [$3])]) + + +# lt_dict_add_subkey(DICT, KEY, SUBKEY, VALUE) +# -------------------------------------------- +m4_define([lt_dict_add_subkey], +[m4_define([$1($2:$3)], [$4])]) + + +# lt_dict_fetch(DICT, KEY, [SUBKEY]) +# ---------------------------------- +m4_define([lt_dict_fetch], +[m4_ifval([$3], + m4_ifdef([$1($2:$3)], [m4_defn([$1($2:$3)])]), + m4_ifdef([$1($2)], [m4_defn([$1($2)])]))]) + + +# lt_if_dict_fetch(DICT, KEY, [SUBKEY], VALUE, IF-TRUE, [IF-FALSE]) +# ----------------------------------------------------------------- +m4_define([lt_if_dict_fetch], +[m4_if(lt_dict_fetch([$1], [$2], [$3]), [$4], + [$5], + [$6])]) + + +# lt_dict_filter(DICT, [SUBKEY], VALUE, [SEPARATOR], KEY, [...]) +# -------------------------------------------------------------- +m4_define([lt_dict_filter], +[m4_if([$5], [], [], + [lt_join(m4_quote(m4_default([$4], [[, ]])), + lt_unquote(m4_split(m4_normalize(m4_foreach(_Lt_key, lt_car([m4_shiftn(4, $@)]), + [lt_if_dict_fetch([$1], _Lt_key, [$2], [$3], [_Lt_key ])])))))])[]dnl +]) + +# ltversion.m4 -- version numbers -*- Autoconf -*- +# +# Copyright (C) 2004, 2011-2018 Free Software Foundation, Inc. +# Written by Scott James Remnant, 2004 +# +# This file is free software; the Free Software Foundation gives +# unlimited permission to copy and/or distribute it, with or without +# modifications, as long as this notice is preserved. + +# @configure_input@ + +# serial 4221 ltversion.m4 +# This file is part of GNU Libtool + +m4_define([LT_PACKAGE_VERSION], [2.4.6.42-b88ce]) +m4_define([LT_PACKAGE_REVISION], [2.4.6.42]) + +AC_DEFUN([LTVERSION_VERSION], +[macro_version='2.4.6.42-b88ce' +macro_revision='2.4.6.42' +_LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?]) +_LT_DECL(, macro_revision, 0) +]) + +# lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*- +# +# Copyright (C) 2004-2005, 2007, 2009, 2011-2018 Free Software +# Foundation, Inc. +# Written by Scott James Remnant, 2004. +# +# This file is free software; the Free Software Foundation gives +# unlimited permission to copy and/or distribute it, with or without +# modifications, as long as this notice is preserved. + +# serial 5 lt~obsolete.m4 + +# These exist entirely to fool aclocal when bootstrapping libtool. +# +# In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN), +# which have later been changed to m4_define as they aren't part of the +# exported API, or moved to Autoconf or Automake where they belong. +# +# The trouble is, aclocal is a bit thick. It'll see the old AC_DEFUN +# in /usr/share/aclocal/libtool.m4 and remember it, then when it sees us +# using a macro with the same name in our local m4/libtool.m4 it'll +# pull the old libtool.m4 in (it doesn't see our shiny new m4_define +# and doesn't know about Autoconf macros at all.) +# +# So we provide this file, which has a silly filename so it's always +# included after everything else. This provides aclocal with the +# AC_DEFUNs it wants, but when m4 processes it, it doesn't do anything +# because those macros already exist, or will be overwritten later. +# We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6. +# +# Anytime we withdraw an AC_DEFUN or AU_DEFUN, remember to add it here. +# Yes, that means every name once taken will need to remain here until +# we give up compatibility with versions before 1.7, at which point +# we need to keep only those names which we still refer to. + +# This is to help aclocal find these macros, as it can't see m4_define. +AC_DEFUN([LTOBSOLETE_VERSION], [m4_if([1])]) + +m4_ifndef([AC_LIBTOOL_LINKER_OPTION], [AC_DEFUN([AC_LIBTOOL_LINKER_OPTION])]) +m4_ifndef([AC_PROG_EGREP], [AC_DEFUN([AC_PROG_EGREP])]) +m4_ifndef([_LT_AC_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_AC_PROG_ECHO_BACKSLASH])]) +m4_ifndef([_LT_AC_SHELL_INIT], [AC_DEFUN([_LT_AC_SHELL_INIT])]) +m4_ifndef([_LT_AC_SYS_LIBPATH_AIX], [AC_DEFUN([_LT_AC_SYS_LIBPATH_AIX])]) +m4_ifndef([_LT_PROG_LTMAIN], [AC_DEFUN([_LT_PROG_LTMAIN])]) +m4_ifndef([_LT_AC_TAGVAR], [AC_DEFUN([_LT_AC_TAGVAR])]) +m4_ifndef([AC_LTDL_ENABLE_INSTALL], [AC_DEFUN([AC_LTDL_ENABLE_INSTALL])]) +m4_ifndef([AC_LTDL_PREOPEN], [AC_DEFUN([AC_LTDL_PREOPEN])]) +m4_ifndef([_LT_AC_SYS_COMPILER], [AC_DEFUN([_LT_AC_SYS_COMPILER])]) +m4_ifndef([_LT_AC_LOCK], [AC_DEFUN([_LT_AC_LOCK])]) +m4_ifndef([AC_LIBTOOL_SYS_OLD_ARCHIVE], [AC_DEFUN([AC_LIBTOOL_SYS_OLD_ARCHIVE])]) +m4_ifndef([_LT_AC_TRY_DLOPEN_SELF], [AC_DEFUN([_LT_AC_TRY_DLOPEN_SELF])]) +m4_ifndef([AC_LIBTOOL_PROG_CC_C_O], [AC_DEFUN([AC_LIBTOOL_PROG_CC_C_O])]) +m4_ifndef([AC_LIBTOOL_SYS_HARD_LINK_LOCKS], [AC_DEFUN([AC_LIBTOOL_SYS_HARD_LINK_LOCKS])]) +m4_ifndef([AC_LIBTOOL_OBJDIR], [AC_DEFUN([AC_LIBTOOL_OBJDIR])]) +m4_ifndef([AC_LTDL_OBJDIR], [AC_DEFUN([AC_LTDL_OBJDIR])]) +m4_ifndef([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH], [AC_DEFUN([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH])]) +m4_ifndef([AC_LIBTOOL_SYS_LIB_STRIP], [AC_DEFUN([AC_LIBTOOL_SYS_LIB_STRIP])]) +m4_ifndef([AC_PATH_MAGIC], [AC_DEFUN([AC_PATH_MAGIC])]) +m4_ifndef([AC_PROG_LD_GNU], [AC_DEFUN([AC_PROG_LD_GNU])]) +m4_ifndef([AC_PROG_LD_RELOAD_FLAG], [AC_DEFUN([AC_PROG_LD_RELOAD_FLAG])]) +m4_ifndef([AC_DEPLIBS_CHECK_METHOD], [AC_DEFUN([AC_DEPLIBS_CHECK_METHOD])]) +m4_ifndef([AC_LIBTOOL_PROG_COMPILER_NO_RTTI], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_NO_RTTI])]) +m4_ifndef([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE], [AC_DEFUN([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE])]) +m4_ifndef([AC_LIBTOOL_PROG_COMPILER_PIC], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_PIC])]) +m4_ifndef([AC_LIBTOOL_PROG_LD_SHLIBS], [AC_DEFUN([AC_LIBTOOL_PROG_LD_SHLIBS])]) +m4_ifndef([AC_LIBTOOL_POSTDEP_PREDEP], [AC_DEFUN([AC_LIBTOOL_POSTDEP_PREDEP])]) +m4_ifndef([LT_AC_PROG_EGREP], [AC_DEFUN([LT_AC_PROG_EGREP])]) +m4_ifndef([LT_AC_PROG_SED], [AC_DEFUN([LT_AC_PROG_SED])]) +m4_ifndef([_LT_CC_BASENAME], [AC_DEFUN([_LT_CC_BASENAME])]) +m4_ifndef([_LT_COMPILER_BOILERPLATE], [AC_DEFUN([_LT_COMPILER_BOILERPLATE])]) +m4_ifndef([_LT_LINKER_BOILERPLATE], [AC_DEFUN([_LT_LINKER_BOILERPLATE])]) +m4_ifndef([_AC_PROG_LIBTOOL], [AC_DEFUN([_AC_PROG_LIBTOOL])]) +m4_ifndef([AC_LIBTOOL_SETUP], [AC_DEFUN([AC_LIBTOOL_SETUP])]) +m4_ifndef([_LT_AC_CHECK_DLFCN], [AC_DEFUN([_LT_AC_CHECK_DLFCN])]) +m4_ifndef([AC_LIBTOOL_SYS_DYNAMIC_LINKER], [AC_DEFUN([AC_LIBTOOL_SYS_DYNAMIC_LINKER])]) +m4_ifndef([_LT_AC_TAGCONFIG], [AC_DEFUN([_LT_AC_TAGCONFIG])]) +m4_ifndef([AC_DISABLE_FAST_INSTALL], [AC_DEFUN([AC_DISABLE_FAST_INSTALL])]) +m4_ifndef([_LT_AC_LANG_CXX], [AC_DEFUN([_LT_AC_LANG_CXX])]) +m4_ifndef([_LT_AC_LANG_F77], [AC_DEFUN([_LT_AC_LANG_F77])]) +m4_ifndef([_LT_AC_LANG_GCJ], [AC_DEFUN([_LT_AC_LANG_GCJ])]) +m4_ifndef([AC_LIBTOOL_LANG_C_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG])]) +m4_ifndef([_LT_AC_LANG_C_CONFIG], [AC_DEFUN([_LT_AC_LANG_C_CONFIG])]) +m4_ifndef([AC_LIBTOOL_LANG_CXX_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG])]) +m4_ifndef([_LT_AC_LANG_CXX_CONFIG], [AC_DEFUN([_LT_AC_LANG_CXX_CONFIG])]) +m4_ifndef([AC_LIBTOOL_LANG_F77_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_F77_CONFIG])]) +m4_ifndef([_LT_AC_LANG_F77_CONFIG], [AC_DEFUN([_LT_AC_LANG_F77_CONFIG])]) +m4_ifndef([AC_LIBTOOL_LANG_GCJ_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_GCJ_CONFIG])]) +m4_ifndef([_LT_AC_LANG_GCJ_CONFIG], [AC_DEFUN([_LT_AC_LANG_GCJ_CONFIG])]) +m4_ifndef([AC_LIBTOOL_LANG_RC_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_RC_CONFIG])]) +m4_ifndef([_LT_AC_LANG_RC_CONFIG], [AC_DEFUN([_LT_AC_LANG_RC_CONFIG])]) +m4_ifndef([AC_LIBTOOL_CONFIG], [AC_DEFUN([AC_LIBTOOL_CONFIG])]) +m4_ifndef([_LT_AC_FILE_LTDLL_C], [AC_DEFUN([_LT_AC_FILE_LTDLL_C])]) +m4_ifndef([_LT_REQUIRED_DARWIN_CHECKS], [AC_DEFUN([_LT_REQUIRED_DARWIN_CHECKS])]) +m4_ifndef([_LT_AC_PROG_CXXCPP], [AC_DEFUN([_LT_AC_PROG_CXXCPP])]) +m4_ifndef([_LT_PREPARE_SED_QUOTE_VARS], [AC_DEFUN([_LT_PREPARE_SED_QUOTE_VARS])]) +m4_ifndef([_LT_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_PROG_ECHO_BACKSLASH])]) +m4_ifndef([_LT_PROG_F77], [AC_DEFUN([_LT_PROG_F77])]) +m4_ifndef([_LT_PROG_FC], [AC_DEFUN([_LT_PROG_FC])]) +m4_ifndef([_LT_PROG_CXX], [AC_DEFUN([_LT_PROG_CXX])]) + +# Copyright (C) 2002-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_AUTOMAKE_VERSION(VERSION) +# ---------------------------- +# Automake X.Y traces this macro to ensure aclocal.m4 has been +# generated from the m4 files accompanying Automake X.Y. +# (This private macro should not be called outside this file.) +AC_DEFUN([AM_AUTOMAKE_VERSION], +[am__api_version='1.16' +dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to +dnl require some minimum version. Point them to the right macro. +m4_if([$1], [1.16.1], [], + [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl +]) + +# _AM_AUTOCONF_VERSION(VERSION) +# ----------------------------- +# aclocal traces this macro to find the Autoconf version. +# This is a private macro too. Using m4_define simplifies +# the logic in aclocal, which can simply ignore this definition. +m4_define([_AM_AUTOCONF_VERSION], []) + +# AM_SET_CURRENT_AUTOMAKE_VERSION +# ------------------------------- +# Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced. +# This function is AC_REQUIREd by AM_INIT_AUTOMAKE. +AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION], +[AM_AUTOMAKE_VERSION([1.16.1])dnl +m4_ifndef([AC_AUTOCONF_VERSION], + [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl +_AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))]) + +# Figure out how to run the assembler. -*- Autoconf -*- + +# Copyright (C) 2001-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_PROG_AS +# ---------- +AC_DEFUN([AM_PROG_AS], +[# By default we simply use the C compiler to build assembly code. +AC_REQUIRE([AC_PROG_CC]) +test "${CCAS+set}" = set || CCAS=$CC +test "${CCASFLAGS+set}" = set || CCASFLAGS=$CFLAGS +AC_ARG_VAR([CCAS], [assembler compiler command (defaults to CC)]) +AC_ARG_VAR([CCASFLAGS], [assembler compiler flags (defaults to CFLAGS)]) +_AM_IF_OPTION([no-dependencies],, [_AM_DEPENDENCIES([CCAS])])dnl +]) + +# AM_AUX_DIR_EXPAND -*- Autoconf -*- + +# Copyright (C) 2001-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets +# $ac_aux_dir to '$srcdir/foo'. In other projects, it is set to +# '$srcdir', '$srcdir/..', or '$srcdir/../..'. +# +# Of course, Automake must honor this variable whenever it calls a +# tool from the auxiliary directory. The problem is that $srcdir (and +# therefore $ac_aux_dir as well) can be either absolute or relative, +# depending on how configure is run. This is pretty annoying, since +# it makes $ac_aux_dir quite unusable in subdirectories: in the top +# source directory, any form will work fine, but in subdirectories a +# relative path needs to be adjusted first. +# +# $ac_aux_dir/missing +# fails when called from a subdirectory if $ac_aux_dir is relative +# $top_srcdir/$ac_aux_dir/missing +# fails if $ac_aux_dir is absolute, +# fails when called from a subdirectory in a VPATH build with +# a relative $ac_aux_dir +# +# The reason of the latter failure is that $top_srcdir and $ac_aux_dir +# are both prefixed by $srcdir. In an in-source build this is usually +# harmless because $srcdir is '.', but things will broke when you +# start a VPATH build or use an absolute $srcdir. +# +# So we could use something similar to $top_srcdir/$ac_aux_dir/missing, +# iff we strip the leading $srcdir from $ac_aux_dir. That would be: +# am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"` +# and then we would define $MISSING as +# MISSING="\${SHELL} $am_aux_dir/missing" +# This will work as long as MISSING is not called from configure, because +# unfortunately $(top_srcdir) has no meaning in configure. +# However there are other variables, like CC, which are often used in +# configure, and could therefore not use this "fixed" $ac_aux_dir. +# +# Another solution, used here, is to always expand $ac_aux_dir to an +# absolute PATH. The drawback is that using absolute paths prevent a +# configured tree to be moved without reconfiguration. + +AC_DEFUN([AM_AUX_DIR_EXPAND], +[AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl +# Expand $ac_aux_dir to an absolute path. +am_aux_dir=`cd "$ac_aux_dir" && pwd` +]) + +# AM_CONDITIONAL -*- Autoconf -*- + +# Copyright (C) 1997-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_CONDITIONAL(NAME, SHELL-CONDITION) +# ------------------------------------- +# Define a conditional. +AC_DEFUN([AM_CONDITIONAL], +[AC_PREREQ([2.52])dnl + m4_if([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])], + [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl +AC_SUBST([$1_TRUE])dnl +AC_SUBST([$1_FALSE])dnl +_AM_SUBST_NOTMAKE([$1_TRUE])dnl +_AM_SUBST_NOTMAKE([$1_FALSE])dnl +m4_define([_AM_COND_VALUE_$1], [$2])dnl +if $2; then + $1_TRUE= + $1_FALSE='#' +else + $1_TRUE='#' + $1_FALSE= +fi +AC_CONFIG_COMMANDS_PRE( +[if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then + AC_MSG_ERROR([[conditional "$1" was never defined. +Usually this means the macro was only invoked conditionally.]]) +fi])]) + +# Copyright (C) 1999-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + + +# There are a few dirty hacks below to avoid letting 'AC_PROG_CC' be +# written in clear, in which case automake, when reading aclocal.m4, +# will think it sees a *use*, and therefore will trigger all it's +# C support machinery. Also note that it means that autoscan, seeing +# CC etc. in the Makefile, will ask for an AC_PROG_CC use... + + +# _AM_DEPENDENCIES(NAME) +# ---------------------- +# See how the compiler implements dependency checking. +# NAME is "CC", "CXX", "OBJC", "OBJCXX", "UPC", or "GJC". +# We try a few techniques and use that to set a single cache variable. +# +# We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was +# modified to invoke _AM_DEPENDENCIES(CC); we would have a circular +# dependency, and given that the user is not expected to run this macro, +# just rely on AC_PROG_CC. +AC_DEFUN([_AM_DEPENDENCIES], +[AC_REQUIRE([AM_SET_DEPDIR])dnl +AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl +AC_REQUIRE([AM_MAKE_INCLUDE])dnl +AC_REQUIRE([AM_DEP_TRACK])dnl + +m4_if([$1], [CC], [depcc="$CC" am_compiler_list=], + [$1], [CXX], [depcc="$CXX" am_compiler_list=], + [$1], [OBJC], [depcc="$OBJC" am_compiler_list='gcc3 gcc'], + [$1], [OBJCXX], [depcc="$OBJCXX" am_compiler_list='gcc3 gcc'], + [$1], [UPC], [depcc="$UPC" am_compiler_list=], + [$1], [GCJ], [depcc="$GCJ" am_compiler_list='gcc3 gcc'], + [depcc="$$1" am_compiler_list=]) + +AC_CACHE_CHECK([dependency style of $depcc], + [am_cv_$1_dependencies_compiler_type], +[if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named 'D' -- because '-MD' means "put the output + # in D". + rm -rf conftest.dir + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_$1_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp` + fi + am__universal=false + m4_case([$1], [CC], + [case " $depcc " in #( + *\ -arch\ *\ -arch\ *) am__universal=true ;; + esac], + [CXX], + [case " $depcc " in #( + *\ -arch\ *\ -arch\ *) am__universal=true ;; + esac]) + + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with + # Solaris 10 /bin/sh. + echo '/* dummy */' > sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + # We check with '-c' and '-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle '-M -o', and we need to detect this. Also, some Intel + # versions had trouble with output in subdirs. + am__obj=sub/conftest.${OBJEXT-o} + am__minus_obj="-o $am__obj" + case $depmode in + gcc) + # This depmode causes a compiler race in universal mode. + test "$am__universal" = false || continue + ;; + nosideeffect) + # After this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested. + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + msvc7 | msvc7msys | msvisualcpp | msvcmsys) + # This compiler won't grok '-c -o', but also, the minuso test has + # not run yet. These depmodes are late enough in the game, and + # so weak that their functioning should not be impacted. + am__obj=conftest.${OBJEXT-o} + am__minus_obj= + ;; + none) break ;; + esac + if depmode=$depmode \ + source=sub/conftest.c object=$am__obj \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep $am__obj sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_$1_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_$1_dependencies_compiler_type=none +fi +]) +AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type]) +AM_CONDITIONAL([am__fastdep$1], [ + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_$1_dependencies_compiler_type" = gcc3]) +]) + + +# AM_SET_DEPDIR +# ------------- +# Choose a directory name for dependency files. +# This macro is AC_REQUIREd in _AM_DEPENDENCIES. +AC_DEFUN([AM_SET_DEPDIR], +[AC_REQUIRE([AM_SET_LEADING_DOT])dnl +AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl +]) + + +# AM_DEP_TRACK +# ------------ +AC_DEFUN([AM_DEP_TRACK], +[AC_ARG_ENABLE([dependency-tracking], [dnl +AS_HELP_STRING( + [--enable-dependency-tracking], + [do not reject slow dependency extractors]) +AS_HELP_STRING( + [--disable-dependency-tracking], + [speeds up one-time build])]) +if test "x$enable_dependency_tracking" != xno; then + am_depcomp="$ac_aux_dir/depcomp" + AMDEPBACKSLASH='\' + am__nodep='_no' +fi +AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno]) +AC_SUBST([AMDEPBACKSLASH])dnl +_AM_SUBST_NOTMAKE([AMDEPBACKSLASH])dnl +AC_SUBST([am__nodep])dnl +_AM_SUBST_NOTMAKE([am__nodep])dnl +]) + +# Generate code to set up dependency tracking. -*- Autoconf -*- + +# Copyright (C) 1999-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# _AM_OUTPUT_DEPENDENCY_COMMANDS +# ------------------------------ +AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], +[{ + # Older Autoconf quotes --file arguments for eval, but not when files + # are listed without --file. Let's play safe and only enable the eval + # if we detect the quoting. + # TODO: see whether this extra hack can be removed once we start + # requiring Autoconf 2.70 or later. + AS_CASE([$CONFIG_FILES], + [*\'*], [eval set x "$CONFIG_FILES"], + [*], [set x $CONFIG_FILES]) + shift + # Used to flag and report bootstrapping failures. + am_rc=0 + for am_mf + do + # Strip MF so we end up with the name of the file. + am_mf=`AS_ECHO(["$am_mf"]) | sed -e 's/:.*$//'` + # Check whether this is an Automake generated Makefile which includes + # dependency-tracking related rules and includes. + # Grep'ing the whole file directly is not great: AIX grep has a line + # limit of 2048, but all sed's we know have understand at least 4000. + sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \ + || continue + am_dirpart=`AS_DIRNAME(["$am_mf"])` + am_filepart=`AS_BASENAME(["$am_mf"])` + AM_RUN_LOG([cd "$am_dirpart" \ + && sed -e '/# am--include-marker/d' "$am_filepart" \ + | $MAKE -f - am--depfiles]) || am_rc=$? + done + if test $am_rc -ne 0; then + AC_MSG_FAILURE([Something went wrong bootstrapping makefile fragments + for automatic dependency tracking. Try re-running configure with the + '--disable-dependency-tracking' option to at least be able to build + the package (albeit without support for automatic dependency tracking).]) + fi + AS_UNSET([am_dirpart]) + AS_UNSET([am_filepart]) + AS_UNSET([am_mf]) + AS_UNSET([am_rc]) + rm -f conftest-deps.mk +} +])# _AM_OUTPUT_DEPENDENCY_COMMANDS + + +# AM_OUTPUT_DEPENDENCY_COMMANDS +# ----------------------------- +# This macro should only be invoked once -- use via AC_REQUIRE. +# +# This code is only required when automatic dependency tracking is enabled. +# This creates each '.Po' and '.Plo' makefile fragment that we'll need in +# order to bootstrap the dependency handling code. +AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS], +[AC_CONFIG_COMMANDS([depfiles], + [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS], + [AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"])]) + +# Do all the work for Automake. -*- Autoconf -*- + +# Copyright (C) 1996-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This macro actually does too much. Some checks are only needed if +# your package does certain things. But this isn't really a big deal. + +dnl Redefine AC_PROG_CC to automatically invoke _AM_PROG_CC_C_O. +m4_define([AC_PROG_CC], +m4_defn([AC_PROG_CC]) +[_AM_PROG_CC_C_O +]) + +# AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE]) +# AM_INIT_AUTOMAKE([OPTIONS]) +# ----------------------------------------------- +# The call with PACKAGE and VERSION arguments is the old style +# call (pre autoconf-2.50), which is being phased out. PACKAGE +# and VERSION should now be passed to AC_INIT and removed from +# the call to AM_INIT_AUTOMAKE. +# We support both call styles for the transition. After +# the next Automake release, Autoconf can make the AC_INIT +# arguments mandatory, and then we can depend on a new Autoconf +# release and drop the old call support. +AC_DEFUN([AM_INIT_AUTOMAKE], +[AC_PREREQ([2.65])dnl +dnl Autoconf wants to disallow AM_ names. We explicitly allow +dnl the ones we care about. +m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl +AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl +AC_REQUIRE([AC_PROG_INSTALL])dnl +if test "`cd $srcdir && pwd`" != "`pwd`"; then + # Use -I$(srcdir) only when $(srcdir) != ., so that make's output + # is not polluted with repeated "-I." + AC_SUBST([am__isrc], [' -I$(srcdir)'])_AM_SUBST_NOTMAKE([am__isrc])dnl + # test to see if srcdir already configured + if test -f $srcdir/config.status; then + AC_MSG_ERROR([source directory already configured; run "make distclean" there first]) + fi +fi + +# test whether we have cygpath +if test -z "$CYGPATH_W"; then + if (cygpath --version) >/dev/null 2>/dev/null; then + CYGPATH_W='cygpath -w' + else + CYGPATH_W=echo + fi +fi +AC_SUBST([CYGPATH_W]) + +# Define the identity of the package. +dnl Distinguish between old-style and new-style calls. +m4_ifval([$2], +[AC_DIAGNOSE([obsolete], + [$0: two- and three-arguments forms are deprecated.]) +m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl + AC_SUBST([PACKAGE], [$1])dnl + AC_SUBST([VERSION], [$2])], +[_AM_SET_OPTIONS([$1])dnl +dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT. +m4_if( + m4_ifdef([AC_PACKAGE_NAME], [ok]):m4_ifdef([AC_PACKAGE_VERSION], [ok]), + [ok:ok],, + [m4_fatal([AC_INIT should be called with package and version arguments])])dnl + AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl + AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl + +_AM_IF_OPTION([no-define],, +[AC_DEFINE_UNQUOTED([PACKAGE], ["$PACKAGE"], [Name of package]) + AC_DEFINE_UNQUOTED([VERSION], ["$VERSION"], [Version number of package])])dnl + +# Some tools Automake needs. +AC_REQUIRE([AM_SANITY_CHECK])dnl +AC_REQUIRE([AC_ARG_PROGRAM])dnl +AM_MISSING_PROG([ACLOCAL], [aclocal-${am__api_version}]) +AM_MISSING_PROG([AUTOCONF], [autoconf]) +AM_MISSING_PROG([AUTOMAKE], [automake-${am__api_version}]) +AM_MISSING_PROG([AUTOHEADER], [autoheader]) +AM_MISSING_PROG([MAKEINFO], [makeinfo]) +AC_REQUIRE([AM_PROG_INSTALL_SH])dnl +AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl +AC_REQUIRE([AC_PROG_MKDIR_P])dnl +# For better backward compatibility. To be removed once Automake 1.9.x +# dies out for good. For more background, see: +# +# +AC_SUBST([mkdir_p], ['$(MKDIR_P)']) +# We need awk for the "check" target (and possibly the TAP driver). The +# system "awk" is bad on some platforms. +AC_REQUIRE([AC_PROG_AWK])dnl +AC_REQUIRE([AC_PROG_MAKE_SET])dnl +AC_REQUIRE([AM_SET_LEADING_DOT])dnl +_AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])], + [_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])], + [_AM_PROG_TAR([v7])])]) +_AM_IF_OPTION([no-dependencies],, +[AC_PROVIDE_IFELSE([AC_PROG_CC], + [_AM_DEPENDENCIES([CC])], + [m4_define([AC_PROG_CC], + m4_defn([AC_PROG_CC])[_AM_DEPENDENCIES([CC])])])dnl +AC_PROVIDE_IFELSE([AC_PROG_CXX], + [_AM_DEPENDENCIES([CXX])], + [m4_define([AC_PROG_CXX], + m4_defn([AC_PROG_CXX])[_AM_DEPENDENCIES([CXX])])])dnl +AC_PROVIDE_IFELSE([AC_PROG_OBJC], + [_AM_DEPENDENCIES([OBJC])], + [m4_define([AC_PROG_OBJC], + m4_defn([AC_PROG_OBJC])[_AM_DEPENDENCIES([OBJC])])])dnl +AC_PROVIDE_IFELSE([AC_PROG_OBJCXX], + [_AM_DEPENDENCIES([OBJCXX])], + [m4_define([AC_PROG_OBJCXX], + m4_defn([AC_PROG_OBJCXX])[_AM_DEPENDENCIES([OBJCXX])])])dnl +]) +AC_REQUIRE([AM_SILENT_RULES])dnl +dnl The testsuite driver may need to know about EXEEXT, so add the +dnl 'am__EXEEXT' conditional if _AM_COMPILER_EXEEXT was seen. This +dnl macro is hooked onto _AC_COMPILER_EXEEXT early, see below. +AC_CONFIG_COMMANDS_PRE(dnl +[m4_provide_if([_AM_COMPILER_EXEEXT], + [AM_CONDITIONAL([am__EXEEXT], [test -n "$EXEEXT"])])])dnl + +# POSIX will say in a future version that running "rm -f" with no argument +# is OK; and we want to be able to make that assumption in our Makefile +# recipes. So use an aggressive probe to check that the usage we want is +# actually supported "in the wild" to an acceptable degree. +# See automake bug#10828. +# To make any issue more visible, cause the running configure to be aborted +# by default if the 'rm' program in use doesn't match our expectations; the +# user can still override this though. +if rm -f && rm -fr && rm -rf; then : OK; else + cat >&2 <<'END' +Oops! + +Your 'rm' program seems unable to run without file operands specified +on the command line, even when the '-f' option is present. This is contrary +to the behaviour of most rm programs out there, and not conforming with +the upcoming POSIX standard: + +Please tell bug-automake@gnu.org about your system, including the value +of your $PATH and any error possibly output before this message. This +can help us improve future automake versions. + +END + if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then + echo 'Configuration will proceed anyway, since you have set the' >&2 + echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 + echo >&2 + else + cat >&2 <<'END' +Aborting the configuration process, to ensure you take notice of the issue. + +You can download and install GNU coreutils to get an 'rm' implementation +that behaves properly: . + +If you want to complete the configuration process using your problematic +'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM +to "yes", and re-run configure. + +END + AC_MSG_ERROR([Your 'rm' program is bad, sorry.]) + fi +fi +dnl The trailing newline in this macro's definition is deliberate, for +dnl backward compatibility and to allow trailing 'dnl'-style comments +dnl after the AM_INIT_AUTOMAKE invocation. See automake bug#16841. +]) + +dnl Hook into '_AC_COMPILER_EXEEXT' early to learn its expansion. Do not +dnl add the conditional right here, as _AC_COMPILER_EXEEXT may be further +dnl mangled by Autoconf and run in a shell conditional statement. +m4_define([_AC_COMPILER_EXEEXT], +m4_defn([_AC_COMPILER_EXEEXT])[m4_provide([_AM_COMPILER_EXEEXT])]) + +# When config.status generates a header, we must update the stamp-h file. +# This file resides in the same directory as the config header +# that is generated. The stamp files are numbered to have different names. + +# Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the +# loop where config.status creates the headers, so we can generate +# our stamp files there. +AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK], +[# Compute $1's index in $config_headers. +_am_arg=$1 +_am_stamp_count=1 +for _am_header in $config_headers :; do + case $_am_header in + $_am_arg | $_am_arg:* ) + break ;; + * ) + _am_stamp_count=`expr $_am_stamp_count + 1` ;; + esac +done +echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count]) + +# Copyright (C) 2001-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_PROG_INSTALL_SH +# ------------------ +# Define $install_sh. +AC_DEFUN([AM_PROG_INSTALL_SH], +[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl +if test x"${install_sh+set}" != xset; then + case $am_aux_dir in + *\ * | *\ *) + install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; + *) + install_sh="\${SHELL} $am_aux_dir/install-sh" + esac +fi +AC_SUBST([install_sh])]) + +# Copyright (C) 2003-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# Check whether the underlying file-system supports filenames +# with a leading dot. For instance MS-DOS doesn't. +AC_DEFUN([AM_SET_LEADING_DOT], +[rm -rf .tst 2>/dev/null +mkdir .tst 2>/dev/null +if test -d .tst; then + am__leading_dot=. +else + am__leading_dot=_ +fi +rmdir .tst 2>/dev/null +AC_SUBST([am__leading_dot])]) + +# Check to see how 'make' treats includes. -*- Autoconf -*- + +# Copyright (C) 2001-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_MAKE_INCLUDE() +# ----------------- +# Check whether make has an 'include' directive that can support all +# the idioms we need for our automatic dependency tracking code. +AC_DEFUN([AM_MAKE_INCLUDE], +[AC_MSG_CHECKING([whether ${MAKE-make} supports the include directive]) +cat > confinc.mk << 'END' +am__doit: + @echo this is the am__doit target >confinc.out +.PHONY: am__doit +END +am__include="#" +am__quote= +# BSD make does it like this. +echo '.include "confinc.mk" # ignored' > confmf.BSD +# Other make implementations (GNU, Solaris 10, AIX) do it like this. +echo 'include confinc.mk # ignored' > confmf.GNU +_am_result=no +for s in GNU BSD; do + AM_RUN_LOG([${MAKE-make} -f confmf.$s && cat confinc.out]) + AS_CASE([$?:`cat confinc.out 2>/dev/null`], + ['0:this is the am__doit target'], + [AS_CASE([$s], + [BSD], [am__include='.include' am__quote='"'], + [am__include='include' am__quote=''])]) + if test "$am__include" != "#"; then + _am_result="yes ($s style)" + break + fi +done +rm -f confinc.* confmf.* +AC_MSG_RESULT([${_am_result}]) +AC_SUBST([am__include])]) +AC_SUBST([am__quote])]) + +# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*- + +# Copyright (C) 1997-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_MISSING_PROG(NAME, PROGRAM) +# ------------------------------ +AC_DEFUN([AM_MISSING_PROG], +[AC_REQUIRE([AM_MISSING_HAS_RUN]) +$1=${$1-"${am_missing_run}$2"} +AC_SUBST($1)]) + +# AM_MISSING_HAS_RUN +# ------------------ +# Define MISSING if not defined so far and test if it is modern enough. +# If it is, set am_missing_run to use it, otherwise, to nothing. +AC_DEFUN([AM_MISSING_HAS_RUN], +[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl +AC_REQUIRE_AUX_FILE([missing])dnl +if test x"${MISSING+set}" != xset; then + case $am_aux_dir in + *\ * | *\ *) + MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; + *) + MISSING="\${SHELL} $am_aux_dir/missing" ;; + esac +fi +# Use eval to expand $SHELL +if eval "$MISSING --is-lightweight"; then + am_missing_run="$MISSING " +else + am_missing_run= + AC_MSG_WARN(['missing' script is too old or missing]) +fi +]) + +# Helper functions for option handling. -*- Autoconf -*- + +# Copyright (C) 2001-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# _AM_MANGLE_OPTION(NAME) +# ----------------------- +AC_DEFUN([_AM_MANGLE_OPTION], +[[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])]) + +# _AM_SET_OPTION(NAME) +# -------------------- +# Set option NAME. Presently that only means defining a flag for this option. +AC_DEFUN([_AM_SET_OPTION], +[m4_define(_AM_MANGLE_OPTION([$1]), [1])]) + +# _AM_SET_OPTIONS(OPTIONS) +# ------------------------ +# OPTIONS is a space-separated list of Automake options. +AC_DEFUN([_AM_SET_OPTIONS], +[m4_foreach_w([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])]) + +# _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET]) +# ------------------------------------------- +# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. +AC_DEFUN([_AM_IF_OPTION], +[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])]) + +# Copyright (C) 1999-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# _AM_PROG_CC_C_O +# --------------- +# Like AC_PROG_CC_C_O, but changed for automake. We rewrite AC_PROG_CC +# to automatically call this. +AC_DEFUN([_AM_PROG_CC_C_O], +[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl +AC_REQUIRE_AUX_FILE([compile])dnl +AC_LANG_PUSH([C])dnl +AC_CACHE_CHECK( + [whether $CC understands -c and -o together], + [am_cv_prog_cc_c_o], + [AC_LANG_CONFTEST([AC_LANG_PROGRAM([])]) + # Make sure it works both with $CC and with simple cc. + # Following AC_PROG_CC_C_O, we do the test twice because some + # compilers refuse to overwrite an existing .o file with -o, + # though they will create one. + am_cv_prog_cc_c_o=yes + for am_i in 1 2; do + if AM_RUN_LOG([$CC -c conftest.$ac_ext -o conftest2.$ac_objext]) \ + && test -f conftest2.$ac_objext; then + : OK + else + am_cv_prog_cc_c_o=no + break + fi + done + rm -f core conftest* + unset am_i]) +if test "$am_cv_prog_cc_c_o" != yes; then + # Losing compiler, so override with the script. + # FIXME: It is wrong to rewrite CC. + # But if we don't then we get into trouble of one sort or another. + # A longer-term fix would be to have automake use am__CC in this case, + # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" + CC="$am_aux_dir/compile $CC" +fi +AC_LANG_POP([C])]) + +# For backward compatibility. +AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])]) + +# Copyright (C) 2001-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_RUN_LOG(COMMAND) +# ------------------- +# Run COMMAND, save the exit status in ac_status, and log it. +# (This has been adapted from Autoconf's _AC_RUN_LOG macro.) +AC_DEFUN([AM_RUN_LOG], +[{ echo "$as_me:$LINENO: $1" >&AS_MESSAGE_LOG_FD + ($1) >&AS_MESSAGE_LOG_FD 2>&AS_MESSAGE_LOG_FD + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD + (exit $ac_status); }]) + +# Check to make sure that the build environment is sane. -*- Autoconf -*- + +# Copyright (C) 1996-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_SANITY_CHECK +# --------------- +AC_DEFUN([AM_SANITY_CHECK], +[AC_MSG_CHECKING([whether build environment is sane]) +# Reject unsafe characters in $srcdir or the absolute working directory +# name. Accept space and tab only in the latter. +am_lf=' +' +case `pwd` in + *[[\\\"\#\$\&\'\`$am_lf]]*) + AC_MSG_ERROR([unsafe absolute working directory name]);; +esac +case $srcdir in + *[[\\\"\#\$\&\'\`$am_lf\ \ ]]*) + AC_MSG_ERROR([unsafe srcdir value: '$srcdir']);; +esac + +# Do 'set' in a subshell so we don't clobber the current shell's +# arguments. Must try -L first in case configure is actually a +# symlink; some systems play weird games with the mod time of symlinks +# (eg FreeBSD returns the mod time of the symlink's containing +# directory). +if ( + am_has_slept=no + for am_try in 1 2; do + echo "timestamp, slept: $am_has_slept" > conftest.file + set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` + if test "$[*]" = "X"; then + # -L didn't work. + set X `ls -t "$srcdir/configure" conftest.file` + fi + if test "$[*]" != "X $srcdir/configure conftest.file" \ + && test "$[*]" != "X conftest.file $srcdir/configure"; then + + # If neither matched, then we have a broken ls. This can happen + # if, for instance, CONFIG_SHELL is bash and it inherits a + # broken ls alias from the environment. This has actually + # happened. Such a system could not be considered "sane". + AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken + alias in your environment]) + fi + if test "$[2]" = conftest.file || test $am_try -eq 2; then + break + fi + # Just in case. + sleep 1 + am_has_slept=yes + done + test "$[2]" = conftest.file + ) +then + # Ok. + : +else + AC_MSG_ERROR([newly created file is older than distributed files! +Check your system clock]) +fi +AC_MSG_RESULT([yes]) +# If we didn't sleep, we still need to ensure time stamps of config.status and +# generated files are strictly newer. +am_sleep_pid= +if grep 'slept: no' conftest.file >/dev/null 2>&1; then + ( sleep 1 ) & + am_sleep_pid=$! +fi +AC_CONFIG_COMMANDS_PRE( + [AC_MSG_CHECKING([that generated files are newer than configure]) + if test -n "$am_sleep_pid"; then + # Hide warnings about reused PIDs. + wait $am_sleep_pid 2>/dev/null + fi + AC_MSG_RESULT([done])]) +rm -f conftest.file +]) + +# Copyright (C) 2009-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_SILENT_RULES([DEFAULT]) +# -------------------------- +# Enable less verbose build rules; with the default set to DEFAULT +# ("yes" being less verbose, "no" or empty being verbose). +AC_DEFUN([AM_SILENT_RULES], +[AC_ARG_ENABLE([silent-rules], [dnl +AS_HELP_STRING( + [--enable-silent-rules], + [less verbose build output (undo: "make V=1")]) +AS_HELP_STRING( + [--disable-silent-rules], + [verbose build output (undo: "make V=0")])dnl +]) +case $enable_silent_rules in @%:@ ((( + yes) AM_DEFAULT_VERBOSITY=0;; + no) AM_DEFAULT_VERBOSITY=1;; + *) AM_DEFAULT_VERBOSITY=m4_if([$1], [yes], [0], [1]);; +esac +dnl +dnl A few 'make' implementations (e.g., NonStop OS and NextStep) +dnl do not support nested variable expansions. +dnl See automake bug#9928 and bug#10237. +am_make=${MAKE-make} +AC_CACHE_CHECK([whether $am_make supports nested variables], + [am_cv_make_support_nested_variables], + [if AS_ECHO([['TRUE=$(BAR$(V)) +BAR0=false +BAR1=true +V=1 +am__doit: + @$(TRUE) +.PHONY: am__doit']]) | $am_make -f - >/dev/null 2>&1; then + am_cv_make_support_nested_variables=yes +else + am_cv_make_support_nested_variables=no +fi]) +if test $am_cv_make_support_nested_variables = yes; then + dnl Using '$V' instead of '$(V)' breaks IRIX make. + AM_V='$(V)' + AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' +else + AM_V=$AM_DEFAULT_VERBOSITY + AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY +fi +AC_SUBST([AM_V])dnl +AM_SUBST_NOTMAKE([AM_V])dnl +AC_SUBST([AM_DEFAULT_V])dnl +AM_SUBST_NOTMAKE([AM_DEFAULT_V])dnl +AC_SUBST([AM_DEFAULT_VERBOSITY])dnl +AM_BACKSLASH='\' +AC_SUBST([AM_BACKSLASH])dnl +_AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl +]) + +# Copyright (C) 2001-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_PROG_INSTALL_STRIP +# --------------------- +# One issue with vendor 'install' (even GNU) is that you can't +# specify the program used to strip binaries. This is especially +# annoying in cross-compiling environments, where the build's strip +# is unlikely to handle the host's binaries. +# Fortunately install-sh will honor a STRIPPROG variable, so we +# always use install-sh in "make install-strip", and initialize +# STRIPPROG with the value of the STRIP variable (set by the user). +AC_DEFUN([AM_PROG_INSTALL_STRIP], +[AC_REQUIRE([AM_PROG_INSTALL_SH])dnl +# Installed binaries are usually stripped using 'strip' when the user +# run "make install-strip". However 'strip' might not be the right +# tool to use in cross-compilation environments, therefore Automake +# will honor the 'STRIP' environment variable to overrule this program. +dnl Don't test for $cross_compiling = yes, because it might be 'maybe'. +if test "$cross_compiling" != no; then + AC_CHECK_TOOL([STRIP], [strip], :) +fi +INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" +AC_SUBST([INSTALL_STRIP_PROGRAM])]) + +# Copyright (C) 2006-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# _AM_SUBST_NOTMAKE(VARIABLE) +# --------------------------- +# Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in. +# This macro is traced by Automake. +AC_DEFUN([_AM_SUBST_NOTMAKE]) + +# AM_SUBST_NOTMAKE(VARIABLE) +# -------------------------- +# Public sister of _AM_SUBST_NOTMAKE. +AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)]) + +# Check how to create a tarball. -*- Autoconf -*- + +# Copyright (C) 2004-2018 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# _AM_PROG_TAR(FORMAT) +# -------------------- +# Check how to create a tarball in format FORMAT. +# FORMAT should be one of 'v7', 'ustar', or 'pax'. +# +# Substitute a variable $(am__tar) that is a command +# writing to stdout a FORMAT-tarball containing the directory +# $tardir. +# tardir=directory && $(am__tar) > result.tar +# +# Substitute a variable $(am__untar) that extract such +# a tarball read from stdin. +# $(am__untar) < result.tar +# +AC_DEFUN([_AM_PROG_TAR], +[# Always define AMTAR for backward compatibility. Yes, it's still used +# in the wild :-( We should find a proper way to deprecate it ... +AC_SUBST([AMTAR], ['$${TAR-tar}']) + +# We'll loop over all known methods to create a tar archive until one works. +_am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none' + +m4_if([$1], [v7], + [am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -'], + + [m4_case([$1], + [ustar], + [# The POSIX 1988 'ustar' format is defined with fixed-size fields. + # There is notably a 21 bits limit for the UID and the GID. In fact, + # the 'pax' utility can hang on bigger UID/GID (see automake bug#8343 + # and bug#13588). + am_max_uid=2097151 # 2^21 - 1 + am_max_gid=$am_max_uid + # The $UID and $GID variables are not portable, so we need to resort + # to the POSIX-mandated id(1) utility. Errors in the 'id' calls + # below are definitely unexpected, so allow the users to see them + # (that is, avoid stderr redirection). + am_uid=`id -u || echo unknown` + am_gid=`id -g || echo unknown` + AC_MSG_CHECKING([whether UID '$am_uid' is supported by ustar format]) + if test $am_uid -le $am_max_uid; then + AC_MSG_RESULT([yes]) + else + AC_MSG_RESULT([no]) + _am_tools=none + fi + AC_MSG_CHECKING([whether GID '$am_gid' is supported by ustar format]) + if test $am_gid -le $am_max_gid; then + AC_MSG_RESULT([yes]) + else + AC_MSG_RESULT([no]) + _am_tools=none + fi], + + [pax], + [], + + [m4_fatal([Unknown tar format])]) + + AC_MSG_CHECKING([how to create a $1 tar archive]) + + # Go ahead even if we have the value already cached. We do so because we + # need to set the values for the 'am__tar' and 'am__untar' variables. + _am_tools=${am_cv_prog_tar_$1-$_am_tools} + + for _am_tool in $_am_tools; do + case $_am_tool in + gnutar) + for _am_tar in tar gnutar gtar; do + AM_RUN_LOG([$_am_tar --version]) && break + done + am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"' + am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"' + am__untar="$_am_tar -xf -" + ;; + plaintar) + # Must skip GNU tar: if it does not support --format= it doesn't create + # ustar tarball either. + (tar --version) >/dev/null 2>&1 && continue + am__tar='tar chf - "$$tardir"' + am__tar_='tar chf - "$tardir"' + am__untar='tar xf -' + ;; + pax) + am__tar='pax -L -x $1 -w "$$tardir"' + am__tar_='pax -L -x $1 -w "$tardir"' + am__untar='pax -r' + ;; + cpio) + am__tar='find "$$tardir" -print | cpio -o -H $1 -L' + am__tar_='find "$tardir" -print | cpio -o -H $1 -L' + am__untar='cpio -i -H $1 -d' + ;; + none) + am__tar=false + am__tar_=false + am__untar=false + ;; + esac + + # If the value was cached, stop now. We just wanted to have am__tar + # and am__untar set. + test -n "${am_cv_prog_tar_$1}" && break + + # tar/untar a dummy directory, and stop if the command works. + rm -rf conftest.dir + mkdir conftest.dir + echo GrepMe > conftest.dir/file + AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar]) + rm -rf conftest.dir + if test -s conftest.tar; then + AM_RUN_LOG([$am__untar /dev/null 2>&1 && break + fi + done + rm -rf conftest.dir + + AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool]) + AC_MSG_RESULT([$am_cv_prog_tar_$1])]) + +AC_SUBST([am__tar]) +AC_SUBST([am__untar]) +]) # _AM_PROG_TAR + diff --git a/TMessagesProj/jni/libtgvoip2/audio/AudioIO.cpp b/TMessagesProj/jni/libtgvoip2/audio/AudioIO.cpp new file mode 100644 index 000000000..2c16ca701 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/audio/AudioIO.cpp @@ -0,0 +1,92 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + + +#include "AudioIO.h" +#include "../logging.h" + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) +#include "AudioIOCallback.h" +#elif defined(__ANDROID__) +#include "../os/android/AudioInputAndroid.h" +#include "../os/android/AudioOutputAndroid.h" +#elif defined(__APPLE__) +#include +#include "../os/darwin/AudioUnitIO.h" +#if TARGET_OS_OSX +#include "../os/darwin/AudioInputAudioUnitOSX.h" +#include "../os/darwin/AudioOutputAudioUnitOSX.h" +#endif +#elif defined(_WIN32) +#ifdef TGVOIP_WINXP_COMPAT +#include "../os/windows/AudioInputWave.h" +#include "../os/windows/AudioOutputWave.h" +#endif +#include "../os/windows/AudioInputWASAPI.h" +#include "../os/windows/AudioOutputWASAPI.h" +#elif defined(__linux__) || defined(__FreeBSD_kernel__) || defined(__gnu_hurd__) +#ifndef WITHOUT_ALSA +#include "../os/linux/AudioInputALSA.h" +#include "../os/linux/AudioOutputALSA.h" +#endif +#ifndef WITHOUT_PULSE +#include "../os/linux/AudioPulse.h" +#endif +#else +#error "Unsupported operating system" +#endif + +using namespace tgvoip; +using namespace tgvoip::audio; +using namespace std; + +AudioIO* AudioIO::Create(std::string inputDevice, std::string outputDevice){ +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) + return new AudioIOCallback(); +#elif defined(__ANDROID__) + return new ContextlessAudioIO(); +#elif defined(__APPLE__) +#if TARGET_OS_OSX + if(kCFCoreFoundationVersionNumber(inputDevice, outputDevice); + +#endif + return new AudioUnitIO(inputDevice, outputDevice); +#elif defined(_WIN32) +#ifdef TGVOIP_WINXP_COMPAT + if(LOBYTE(LOWORD(GetVersion()))<6) + return new ContextlessAudioIO(inputDevice, outputDevice); +#endif + return new ContextlessAudioIO(inputDevice, outputDevice); +#elif defined(__linux__) +#ifndef WITHOUT_ALSA +#ifndef WITHOUT_PULSE + if(AudioPulse::Load()){ + AudioIO* io=new AudioPulse(inputDevice, outputDevice); + if(!io->Failed() && io->GetInput()->IsInitialized() && io->GetOutput()->IsInitialized()) + return io; + LOGW("PulseAudio available but not working; trying ALSA"); + delete io; + } +#endif + return new ContextlessAudioIO(inputDevice, outputDevice); +#else + return new AudioPulse(inputDevice, outputDevice); +#endif +#endif +} + +bool AudioIO::Failed(){ + return failed; +} + +std::string AudioIO::GetErrorDescription(){ + return error; +} diff --git a/TMessagesProj/jni/libtgvoip2/audio/AudioIO.h b/TMessagesProj/jni/libtgvoip2/audio/AudioIO.h new file mode 100644 index 000000000..a9affa677 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/audio/AudioIO.h @@ -0,0 +1,65 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + + +#ifndef LIBTGVOIP_AUDIOIO_H +#define LIBTGVOIP_AUDIOIO_H + +#include "AudioInput.h" +#include "AudioOutput.h" +#include "../utils.h" +#include +#include + +namespace tgvoip{ + namespace audio { + class AudioIO{ + public: + AudioIO(){}; + virtual ~AudioIO(){}; + TGVOIP_DISALLOW_COPY_AND_ASSIGN(AudioIO); + static AudioIO* Create(std::string inputDevice, std::string outputDevice); + virtual AudioInput* GetInput()=0; + virtual AudioOutput* GetOutput()=0; + bool Failed(); + std::string GetErrorDescription(); + protected: + bool failed=false; + std::string error; + }; + + template class ContextlessAudioIO : public AudioIO{ + public: + ContextlessAudioIO(){ + input=new I(); + output=new O(); + } + + ContextlessAudioIO(std::string inputDeviceID, std::string outputDeviceID){ + input=new I(inputDeviceID); + output=new O(outputDeviceID); + } + + virtual ~ContextlessAudioIO(){ + delete input; + delete output; + } + + virtual AudioInput* GetInput(){ + return input; + } + + virtual AudioOutput* GetOutput(){ + return output; + } + private: + I* input; + O* output; + }; + } +} + +#endif //LIBTGVOIP_AUDIOIO_H diff --git a/TMessagesProj/jni/libtgvoip2/audio/AudioIOCallback.cpp b/TMessagesProj/jni/libtgvoip2/audio/AudioIOCallback.cpp new file mode 100644 index 000000000..012a705c1 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/audio/AudioIOCallback.cpp @@ -0,0 +1,121 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "AudioIOCallback.h" +#include "../VoIPController.h" +#include "../logging.h" + +using namespace tgvoip; +using namespace tgvoip::audio; + +#pragma mark - IO + +AudioIOCallback::AudioIOCallback(){ + input=new AudioInputCallback(); + output=new AudioOutputCallback(); +} + +AudioIOCallback::~AudioIOCallback(){ + delete input; + delete output; +} + +AudioInput* AudioIOCallback::GetInput(){ + return input; +} + +AudioOutput* AudioIOCallback::GetOutput(){ + return output; +} + +#pragma mark - Input + +AudioInputCallback::AudioInputCallback(){ + thread=new Thread(std::bind(&AudioInputCallback::RunThread, this)); + thread->SetName("AudioInputCallback"); +} + +AudioInputCallback::~AudioInputCallback(){ + running=false; + thread->Join(); + delete thread; +} + +void AudioInputCallback::Start(){ + if(!running){ + running=true; + thread->Start(); + } + recording=true; +} + +void AudioInputCallback::Stop(){ + recording=false; +} + +void AudioInputCallback::SetDataCallback(std::function c){ + dataCallback=c; +} + +void AudioInputCallback::RunThread(){ + int16_t buf[960]; + while(running){ + double t=VoIPController::GetCurrentTime(); + memset(buf, 0, sizeof(buf)); + dataCallback(buf, 960); + InvokeCallback(reinterpret_cast(buf), 960*2); + double sl=0.02-(VoIPController::GetCurrentTime()-t); + if(sl>0) + Thread::Sleep(sl); + } +} + +#pragma mark - Output + +AudioOutputCallback::AudioOutputCallback(){ + thread=new Thread(std::bind(&AudioOutputCallback::RunThread, this)); + thread->SetName("AudioOutputCallback"); +} + +AudioOutputCallback::~AudioOutputCallback(){ + running=false; + thread->Join(); + delete thread; +} + +void AudioOutputCallback::Start(){ + if(!running){ + running=true; + thread->Start(); + } + playing=true; +} + +void AudioOutputCallback::Stop(){ + playing=false; +} + +bool AudioOutputCallback::IsPlaying(){ + return playing; +} + +void AudioOutputCallback::SetDataCallback(std::function c){ + dataCallback=c; +} + +void AudioOutputCallback::RunThread(){ + int16_t buf[960]; + while(running){ + double t=VoIPController::GetCurrentTime(); + InvokeCallback(reinterpret_cast(buf), 960*2); + dataCallback(buf, 960); + double sl=0.02-(VoIPController::GetCurrentTime()-t); + if(sl>0) + Thread::Sleep(sl); + } +} + + diff --git a/TMessagesProj/jni/libtgvoip2/audio/AudioIOCallback.h b/TMessagesProj/jni/libtgvoip2/audio/AudioIOCallback.h new file mode 100644 index 000000000..2949b82b0 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/audio/AudioIOCallback.h @@ -0,0 +1,63 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIO_IO_CALLBACK +#define LIBTGVOIP_AUDIO_IO_CALLBACK + +#include "AudioIO.h" +#include +#include + +#include "../threading.h" + +namespace tgvoip{ + namespace audio{ + class AudioInputCallback : public AudioInput{ + public: + AudioInputCallback(); + virtual ~AudioInputCallback(); + virtual void Start() override; + virtual void Stop() override; + void SetDataCallback(std::function c); + private: + void RunThread(); + std::atomic running{false}; + bool recording=false; + Thread* thread; + std::function dataCallback; + }; + + class AudioOutputCallback : public AudioOutput{ + public: + AudioOutputCallback(); + virtual ~AudioOutputCallback(); + virtual void Start() override; + virtual void Stop() override; + virtual bool IsPlaying() override; + void SetDataCallback(std::function c); + private: + void RunThread(); + std::atomic running{false}; + bool playing=false; + Thread* thread; + std::function dataCallback; + }; + + class AudioIOCallback : public AudioIO{ + public: + AudioIOCallback(); + virtual ~AudioIOCallback(); + virtual AudioInput* GetInput() override; + virtual AudioOutput* GetOutput() override; + private: + AudioInputCallback* input; + AudioOutputCallback* output; + }; + } +} + + +#endif /* LIBTGVOIP_AUDIO_IO_CALLBACK */ diff --git a/TMessagesProj/jni/libtgvoip2/audio/AudioInput.cpp b/TMessagesProj/jni/libtgvoip2/audio/AudioInput.cpp new file mode 100644 index 000000000..674cd34eb --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/audio/AudioInput.cpp @@ -0,0 +1,97 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "AudioInput.h" +#include "../logging.h" + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) +// nothing +#elif defined(__ANDROID__) +#include "../os/android/AudioInputAndroid.h" +#elif defined(__APPLE__) +#include +#include "../os/darwin/AudioInputAudioUnit.h" +#if TARGET_OS_OSX +#include "../os/darwin/AudioInputAudioUnitOSX.h" +#endif +#elif defined(_WIN32) +#ifdef TGVOIP_WINXP_COMPAT +#include "../os/windows/AudioInputWave.h" +#endif +#include "../os/windows/AudioInputWASAPI.h" +#elif defined(__linux__) || defined(__FreeBSD_kernel__) || defined(__gnu_hurd__) +#ifndef WITHOUT_ALSA +#include "../os/linux/AudioInputALSA.h" +#endif +#ifndef WITHOUT_PULSE +#include "../os/linux/AudioPulse.h" +#endif +#else +#error "Unsupported operating system" +#endif + +using namespace tgvoip; +using namespace tgvoip::audio; + +int32_t AudioInput::estimatedDelay=60; + +AudioInput::AudioInput() : currentDevice("default"){ + failed=false; +} + +AudioInput::AudioInput(std::string deviceID) : currentDevice(deviceID){ + failed=false; +} + + +AudioInput::~AudioInput(){ + +} + +bool AudioInput::IsInitialized(){ + return !failed; +} + +void AudioInput::EnumerateDevices(std::vector& devs){ +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) + // not supported +#elif defined(__APPLE__) && TARGET_OS_OSX + AudioInputAudioUnitLegacy::EnumerateDevices(devs); +#elif defined(_WIN32) +#ifdef TGVOIP_WINXP_COMPAT + if(LOBYTE(LOWORD(GetVersion()))<6){ + AudioInputWave::EnumerateDevices(devs); + return; + } +#endif + AudioInputWASAPI::EnumerateDevices(devs); +#elif defined(__linux__) && !defined(__ANDROID__) +#if !defined(WITHOUT_PULSE) && !defined(WITHOUT_ALSA) + if(!AudioInputPulse::EnumerateDevices(devs)) + AudioInputALSA::EnumerateDevices(devs); +#elif defined(WITHOUT_PULSE) + AudioInputALSA::EnumerateDevices(devs); +#else + AudioInputPulse::EnumerateDevices(devs); +#endif +#endif +} + +std::string AudioInput::GetCurrentDevice(){ + return currentDevice; +} + +void AudioInput::SetCurrentDevice(std::string deviceID){ + +} + +int32_t AudioInput::GetEstimatedDelay(){ + return estimatedDelay; +} diff --git a/TMessagesProj/jni/libtgvoip2/audio/AudioInput.h b/TMessagesProj/jni/libtgvoip2/audio/AudioInput.h new file mode 100644 index 000000000..ea8c04b2d --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/audio/AudioInput.h @@ -0,0 +1,41 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOINPUT_H +#define LIBTGVOIP_AUDIOINPUT_H + +#include +#include +#include +#include "../MediaStreamItf.h" + +namespace tgvoip{ + +class AudioInputDevice; +class AudioOutputDevice; + +namespace audio{ +class AudioInput : public MediaStreamItf{ +public: + AudioInput(); + AudioInput(std::string deviceID); + virtual ~AudioInput(); + + bool IsInitialized(); + virtual std::string GetCurrentDevice(); + virtual void SetCurrentDevice(std::string deviceID); + //static AudioInput* Create(std::string deviceID, void* platformSpecific); + static void EnumerateDevices(std::vector& devs); + static int32_t GetEstimatedDelay(); + +protected: + std::string currentDevice; + bool failed; + static int32_t estimatedDelay; +}; +}} + +#endif //LIBTGVOIP_AUDIOINPUT_H diff --git a/TMessagesProj/jni/libtgvoip2/audio/AudioOutput.cpp b/TMessagesProj/jni/libtgvoip2/audio/AudioOutput.cpp new file mode 100644 index 000000000..14ab0be69 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/audio/AudioOutput.cpp @@ -0,0 +1,109 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "AudioOutput.h" +#include "../logging.h" +#include + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) +// nothing +#elif defined(__ANDROID__) +#include "../os/android/AudioOutputOpenSLES.h" +#include "../os/android/AudioOutputAndroid.h" +#include +#elif defined(__APPLE__) +#include +#include "../os/darwin/AudioOutputAudioUnit.h" +#if TARGET_OS_OSX +#include "../os/darwin/AudioOutputAudioUnitOSX.h" +#endif +#elif defined(_WIN32) +#ifdef TGVOIP_WINXP_COMPAT +#include "../os/windows/AudioOutputWave.h" +#endif +#include "../os/windows/AudioOutputWASAPI.h" +#elif defined(__linux__) || defined(__FreeBSD_kernel__) || defined(__gnu_hurd__) +#ifndef WITHOUT_ALSA +#include "../os/linux/AudioOutputALSA.h" +#endif +#ifndef WITHOUT_PULSE +#include "../os/linux/AudioOutputPulse.h" +#include "../os/linux/AudioPulse.h" +#endif +#else +#error "Unsupported operating system" +#endif + +using namespace tgvoip; +using namespace tgvoip::audio; + +int32_t AudioOutput::estimatedDelay=60; + +AudioOutput::AudioOutput() : currentDevice("default"){ + failed=false; +} + +AudioOutput::AudioOutput(std::string deviceID) : currentDevice(deviceID){ + failed=false; +} + +AudioOutput::~AudioOutput(){ + +} + + +int32_t AudioOutput::GetEstimatedDelay(){ +#if defined(__ANDROID__) + char sdkNum[PROP_VALUE_MAX]; + __system_property_get("ro.build.version.sdk", sdkNum); + int systemVersion=atoi(sdkNum); + return systemVersion<21 ? 150 : 50; +#endif + return estimatedDelay; +} + + +void AudioOutput::EnumerateDevices(std::vector& devs){ +#if defined(TGVOIP_USE_CALLBACK_AUDIO_IO) + // not supported +#elif defined(__APPLE__) && TARGET_OS_OSX + AudioOutputAudioUnitLegacy::EnumerateDevices(devs); +#elif defined(_WIN32) +#ifdef TGVOIP_WINXP_COMPAT + if(LOBYTE(LOWORD(GetVersion()))<6){ + AudioOutputWave::EnumerateDevices(devs); + return; + } +#endif + AudioOutputWASAPI::EnumerateDevices(devs); +#elif defined(__linux__) && !defined(__ANDROID__) +#if !defined(WITHOUT_PULSE) && !defined(WITHOUT_ALSA) + if(!AudioOutputPulse::EnumerateDevices(devs)) + AudioOutputALSA::EnumerateDevices(devs); +#elif defined(WITHOUT_PULSE) + AudioOutputALSA::EnumerateDevices(devs); +#else + AudioOutputPulse::EnumerateDevices(devs); +#endif +#endif +} + + +std::string AudioOutput::GetCurrentDevice(){ + return currentDevice; +} + +void AudioOutput::SetCurrentDevice(std::string deviceID){ + +} + +bool AudioOutput::IsInitialized(){ + return !failed; +} diff --git a/TMessagesProj/jni/libtgvoip2/audio/AudioOutput.h b/TMessagesProj/jni/libtgvoip2/audio/AudioOutput.h new file mode 100644 index 000000000..cff28fe26 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/audio/AudioOutput.h @@ -0,0 +1,42 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOOUTPUT_H +#define LIBTGVOIP_AUDIOOUTPUT_H + +#include +#include +#include +#include +#include "../MediaStreamItf.h" + +namespace tgvoip{ + +class AudioInputDevice; +class AudioOutputDevice; + +namespace audio{ +class AudioOutput : public MediaStreamItf{ +public: + AudioOutput(); + AudioOutput(std::string deviceID); + virtual ~AudioOutput(); + virtual bool IsPlaying()=0; + static int32_t GetEstimatedDelay(); + virtual std::string GetCurrentDevice(); + virtual void SetCurrentDevice(std::string deviceID); + //static std::unique_ptr Create(std::string deviceID, void* platformSpecific); + static void EnumerateDevices(std::vector& devs); + bool IsInitialized(); + +protected: + std::string currentDevice; + bool failed; + static int32_t estimatedDelay; +}; +}} + +#endif //LIBTGVOIP_AUDIOOUTPUT_H diff --git a/TMessagesProj/jni/libtgvoip2/audio/Resampler.cpp b/TMessagesProj/jni/libtgvoip2/audio/Resampler.cpp new file mode 100644 index 000000000..a478162cf --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/audio/Resampler.cpp @@ -0,0 +1,123 @@ +// +// Created by Grishka on 01.04.17. +// + +#include +#include +#include "Resampler.h" + +using namespace tgvoip::audio; +static constexpr int16_t hann[960] = { + 0x0000, 0x0000, 0x0000, 0x0001, 0x0001, 0x0002, 0x0003, 0x0004, 0x0006, 0x0007, 0x0009, 0x000B, 0x000D, 0x000F, 0x0011, 0x0014, 0x0016, 0x0019, 0x001C, 0x0020, + 0x0023, 0x0027, 0x002A, 0x002E, 0x0033, 0x0037, 0x003B, 0x0040, 0x0045, 0x004A, 0x004F, 0x0054, 0x005A, 0x0060, 0x0065, 0x006B, 0x0072, 0x0078, 0x007F, 0x0085, + 0x008C, 0x0093, 0x009B, 0x00A2, 0x00AA, 0x00B2, 0x00B9, 0x00C2, 0x00CA, 0x00D2, 0x00DB, 0x00E4, 0x00ED, 0x00F6, 0x00FF, 0x0109, 0x0113, 0x011C, 0x0127, 0x0131, + 0x013B, 0x0146, 0x0150, 0x015B, 0x0166, 0x0172, 0x017D, 0x0189, 0x0194, 0x01A0, 0x01AC, 0x01B9, 0x01C5, 0x01D2, 0x01DF, 0x01EC, 0x01F9, 0x0206, 0x0213, 0x0221, + 0x022F, 0x023D, 0x024B, 0x0259, 0x0268, 0x0276, 0x0285, 0x0294, 0x02A3, 0x02B3, 0x02C2, 0x02D2, 0x02E2, 0x02F2, 0x0302, 0x0312, 0x0323, 0x0333, 0x0344, 0x0355, + 0x0366, 0x0378, 0x0389, 0x039B, 0x03AD, 0x03BF, 0x03D1, 0x03E3, 0x03F6, 0x0408, 0x041B, 0x042E, 0x0441, 0x0455, 0x0468, 0x047C, 0x0490, 0x04A4, 0x04B8, 0x04CC, + 0x04E0, 0x04F5, 0x050A, 0x051F, 0x0534, 0x0549, 0x055F, 0x0574, 0x058A, 0x05A0, 0x05B6, 0x05CC, 0x05E2, 0x05F9, 0x0610, 0x0627, 0x063E, 0x0655, 0x066C, 0x0684, + 0x069B, 0x06B3, 0x06CB, 0x06E3, 0x06FC, 0x0714, 0x072D, 0x0745, 0x075E, 0x0777, 0x0791, 0x07AA, 0x07C3, 0x07DD, 0x07F7, 0x0811, 0x082B, 0x0845, 0x0860, 0x087A, + 0x0895, 0x08B0, 0x08CB, 0x08E6, 0x0902, 0x091D, 0x0939, 0x0955, 0x0971, 0x098D, 0x09A9, 0x09C6, 0x09E2, 0x09FF, 0x0A1C, 0x0A39, 0x0A56, 0x0A73, 0x0A91, 0x0AAE, + 0x0ACC, 0x0AEA, 0x0B08, 0x0B26, 0x0B44, 0x0B63, 0x0B81, 0x0BA0, 0x0BBF, 0x0BDE, 0x0BFD, 0x0C1D, 0x0C3C, 0x0C5C, 0x0C7B, 0x0C9B, 0x0CBB, 0x0CDC, 0x0CFC, 0x0D1C, + 0x0D3D, 0x0D5E, 0x0D7F, 0x0DA0, 0x0DC1, 0x0DE2, 0x0E04, 0x0E25, 0x0E47, 0x0E69, 0x0E8B, 0x0EAD, 0x0ECF, 0x0EF1, 0x0F14, 0x0F37, 0x0F59, 0x0F7C, 0x0F9F, 0x0FC2, + 0x0FE6, 0x1009, 0x102D, 0x1051, 0x1074, 0x1098, 0x10BC, 0x10E1, 0x1105, 0x112A, 0x114E, 0x1173, 0x1198, 0x11BD, 0x11E2, 0x1207, 0x122D, 0x1252, 0x1278, 0x129D, + 0x12C3, 0x12E9, 0x130F, 0x1336, 0x135C, 0x1383, 0x13A9, 0x13D0, 0x13F7, 0x141E, 0x1445, 0x146C, 0x1494, 0x14BB, 0x14E3, 0x150A, 0x1532, 0x155A, 0x1582, 0x15AA, + 0x15D3, 0x15FB, 0x1623, 0x164C, 0x1675, 0x169E, 0x16C7, 0x16F0, 0x1719, 0x1742, 0x176C, 0x1795, 0x17BF, 0x17E9, 0x1813, 0x183D, 0x1867, 0x1891, 0x18BB, 0x18E6, + 0x1910, 0x193B, 0x1965, 0x1990, 0x19BB, 0x19E6, 0x1A11, 0x1A3D, 0x1A68, 0x1A93, 0x1ABF, 0x1AEB, 0x1B17, 0x1B42, 0x1B6E, 0x1B9A, 0x1BC7, 0x1BF3, 0x1C1F, 0x1C4C, + 0x1C78, 0x1CA5, 0x1CD2, 0x1CFF, 0x1D2C, 0x1D59, 0x1D86, 0x1DB3, 0x1DE0, 0x1E0E, 0x1E3B, 0x1E69, 0x1E97, 0x1EC4, 0x1EF2, 0x1F20, 0x1F4E, 0x1F7C, 0x1FAB, 0x1FD9, + 0x2007, 0x2036, 0x2065, 0x2093, 0x20C2, 0x20F1, 0x2120, 0x214F, 0x217E, 0x21AD, 0x21DD, 0x220C, 0x223B, 0x226B, 0x229A, 0x22CA, 0x22FA, 0x232A, 0x235A, 0x238A, + 0x23BA, 0x23EA, 0x241A, 0x244B, 0x247B, 0x24AB, 0x24DC, 0x250D, 0x253D, 0x256E, 0x259F, 0x25D0, 0x2601, 0x2632, 0x2663, 0x2694, 0x26C5, 0x26F7, 0x2728, 0x275A, + 0x278B, 0x27BD, 0x27EE, 0x2820, 0x2852, 0x2884, 0x28B6, 0x28E8, 0x291A, 0x294C, 0x297E, 0x29B0, 0x29E3, 0x2A15, 0x2A47, 0x2A7A, 0x2AAC, 0x2ADF, 0x2B12, 0x2B44, + 0x2B77, 0x2BAA, 0x2BDD, 0x2C10, 0x2C43, 0x2C76, 0x2CA9, 0x2CDC, 0x2D0F, 0x2D43, 0x2D76, 0x2DA9, 0x2DDD, 0x2E10, 0x2E44, 0x2E77, 0x2EAB, 0x2EDF, 0x2F12, 0x2F46, + 0x2F7A, 0x2FAE, 0x2FE2, 0x3016, 0x304A, 0x307E, 0x30B2, 0x30E6, 0x311A, 0x314E, 0x3182, 0x31B7, 0x31EB, 0x321F, 0x3254, 0x3288, 0x32BD, 0x32F1, 0x3326, 0x335A, + 0x338F, 0x33C3, 0x33F8, 0x342D, 0x3461, 0x3496, 0x34CB, 0x3500, 0x3535, 0x356A, 0x359F, 0x35D4, 0x3608, 0x363D, 0x3673, 0x36A8, 0x36DD, 0x3712, 0x3747, 0x377C, + 0x37B1, 0x37E6, 0x381C, 0x3851, 0x3886, 0x38BB, 0x38F1, 0x3926, 0x395B, 0x3991, 0x39C6, 0x39FC, 0x3A31, 0x3A66, 0x3A9C, 0x3AD1, 0x3B07, 0x3B3C, 0x3B72, 0x3BA7, + 0x3BDD, 0x3C12, 0x3C48, 0x3C7D, 0x3CB3, 0x3CE9, 0x3D1E, 0x3D54, 0x3D89, 0x3DBF, 0x3DF5, 0x3E2A, 0x3E60, 0x3E95, 0x3ECB, 0x3F01, 0x3F36, 0x3F6C, 0x3FA2, 0x3FD7, + 0x400D, 0x4043, 0x4078, 0x40AE, 0x40E3, 0x4119, 0x414F, 0x4184, 0x41BA, 0x41F0, 0x4225, 0x425B, 0x4290, 0x42C6, 0x42FC, 0x4331, 0x4367, 0x439C, 0x43D2, 0x4407, + 0x443D, 0x4472, 0x44A8, 0x44DD, 0x4513, 0x4548, 0x457E, 0x45B3, 0x45E9, 0x461E, 0x4654, 0x4689, 0x46BE, 0x46F4, 0x4729, 0x475E, 0x4793, 0x47C9, 0x47FE, 0x4833, + 0x4868, 0x489E, 0x48D3, 0x4908, 0x493D, 0x4972, 0x49A7, 0x49DC, 0x4A11, 0x4A46, 0x4A7B, 0x4AB0, 0x4AE5, 0x4B1A, 0x4B4E, 0x4B83, 0x4BB8, 0x4BED, 0x4C21, 0x4C56, + 0x4C8B, 0x4CBF, 0x4CF4, 0x4D28, 0x4D5D, 0x4D91, 0x4DC6, 0x4DFA, 0x4E2E, 0x4E63, 0x4E97, 0x4ECB, 0x4EFF, 0x4F33, 0x4F67, 0x4F9B, 0x4FCF, 0x5003, 0x5037, 0x506B, + 0x509F, 0x50D3, 0x5106, 0x513A, 0x516E, 0x51A1, 0x51D5, 0x5208, 0x523C, 0x526F, 0x52A3, 0x52D6, 0x5309, 0x533C, 0x536F, 0x53A3, 0x53D6, 0x5409, 0x543B, 0x546E, + 0x54A1, 0x54D4, 0x5507, 0x5539, 0x556C, 0x559E, 0x55D1, 0x5603, 0x5636, 0x5668, 0x569A, 0x56CC, 0x56FE, 0x5730, 0x5762, 0x5794, 0x57C6, 0x57F8, 0x5829, 0x585B, + 0x588D, 0x58BE, 0x58F0, 0x5921, 0x5952, 0x5984, 0x59B5, 0x59E6, 0x5A17, 0x5A48, 0x5A79, 0x5AA9, 0x5ADA, 0x5B0B, 0x5B3B, 0x5B6C, 0x5B9C, 0x5BCD, 0x5BFD, 0x5C2D, + 0x5C5D, 0x5C8D, 0x5CBD, 0x5CED, 0x5D1D, 0x5D4D, 0x5D7C, 0x5DAC, 0x5DDB, 0x5E0B, 0x5E3A, 0x5E69, 0x5E99, 0x5EC8, 0x5EF7, 0x5F26, 0x5F54, 0x5F83, 0x5FB2, 0x5FE0, + 0x600F, 0x603D, 0x606B, 0x609A, 0x60C8, 0x60F6, 0x6124, 0x6152, 0x617F, 0x61AD, 0x61DB, 0x6208, 0x6235, 0x6263, 0x6290, 0x62BD, 0x62EA, 0x6317, 0x6344, 0x6370, + 0x639D, 0x63CA, 0x63F6, 0x6422, 0x644E, 0x647B, 0x64A7, 0x64D3, 0x64FE, 0x652A, 0x6556, 0x6581, 0x65AD, 0x65D8, 0x6603, 0x662E, 0x6659, 0x6684, 0x66AF, 0x66DA, + 0x6704, 0x672F, 0x6759, 0x6783, 0x67AD, 0x67D7, 0x6801, 0x682B, 0x6855, 0x687E, 0x68A8, 0x68D1, 0x68FB, 0x6924, 0x694D, 0x6976, 0x699F, 0x69C7, 0x69F0, 0x6A18, + 0x6A41, 0x6A69, 0x6A91, 0x6AB9, 0x6AE1, 0x6B09, 0x6B30, 0x6B58, 0x6B7F, 0x6BA6, 0x6BCE, 0x6BF5, 0x6C1C, 0x6C42, 0x6C69, 0x6C90, 0x6CB6, 0x6CDC, 0x6D03, 0x6D29, + 0x6D4F, 0x6D74, 0x6D9A, 0x6DC0, 0x6DE5, 0x6E0A, 0x6E30, 0x6E55, 0x6E7A, 0x6E9E, 0x6EC3, 0x6EE8, 0x6F0C, 0x6F30, 0x6F55, 0x6F79, 0x6F9D, 0x6FC0, 0x6FE4, 0x7008, + 0x702B, 0x704E, 0x7071, 0x7094, 0x70B7, 0x70DA, 0x70FC, 0x711F, 0x7141, 0x7163, 0x7185, 0x71A7, 0x71C9, 0x71EB, 0x720C, 0x722E, 0x724F, 0x7270, 0x7291, 0x72B2, + 0x72D2, 0x72F3, 0x7313, 0x7333, 0x7354, 0x7374, 0x7393, 0x73B3, 0x73D3, 0x73F2, 0x7411, 0x7430, 0x744F, 0x746E, 0x748D, 0x74AB, 0x74CA, 0x74E8, 0x7506, 0x7524, + 0x7542, 0x7560, 0x757D, 0x759B, 0x75B8, 0x75D5, 0x75F2, 0x760F, 0x762B, 0x7648, 0x7664, 0x7680, 0x769C, 0x76B8, 0x76D4, 0x76F0, 0x770B, 0x7726, 0x7741, 0x775C, + 0x7777, 0x7792, 0x77AC, 0x77C7, 0x77E1, 0x77FB, 0x7815, 0x782F, 0x7848, 0x7862, 0x787B, 0x7894, 0x78AD, 0x78C6, 0x78DF, 0x78F7, 0x7910, 0x7928, 0x7940, 0x7958, + 0x7970, 0x7987, 0x799F, 0x79B6, 0x79CD, 0x79E4, 0x79FB, 0x7A11, 0x7A28, 0x7A3E, 0x7A54, 0x7A6A, 0x7A80, 0x7A96, 0x7AAB, 0x7AC1, 0x7AD6, 0x7AEB, 0x7B00, 0x7B14, + 0x7B29, 0x7B3D, 0x7B51, 0x7B65, 0x7B79, 0x7B8D, 0x7BA1, 0x7BB4, 0x7BC7, 0x7BDA, 0x7BED, 0x7C00, 0x7C13, 0x7C25, 0x7C37, 0x7C49, 0x7C5B, 0x7C6D, 0x7C7F, 0x7C90, + 0x7CA1, 0x7CB2, 0x7CC3, 0x7CD4, 0x7CE5, 0x7CF5, 0x7D05, 0x7D15, 0x7D25, 0x7D35, 0x7D45, 0x7D54, 0x7D63, 0x7D72, 0x7D81, 0x7D90, 0x7D9F, 0x7DAD, 0x7DBB, 0x7DC9, + 0x7DD7, 0x7DE5, 0x7DF2, 0x7E00, 0x7E0D, 0x7E1A, 0x7E27, 0x7E34, 0x7E40, 0x7E4C, 0x7E59, 0x7E65, 0x7E71, 0x7E7C, 0x7E88, 0x7E93, 0x7E9E, 0x7EA9, 0x7EB4, 0x7EBF, + 0x7EC9, 0x7ED3, 0x7EDE, 0x7EE7, 0x7EF1, 0x7EFB, 0x7F04, 0x7F0E, 0x7F17, 0x7F20, 0x7F28, 0x7F31, 0x7F39, 0x7F41, 0x7F4A, 0x7F51, 0x7F59, 0x7F61, 0x7F68, 0x7F6F, + 0x7F76, 0x7F7D, 0x7F84, 0x7F8A, 0x7F90, 0x7F97, 0x7F9D, 0x7FA2, 0x7FA8, 0x7FAD, 0x7FB3, 0x7FB8, 0x7FBD, 0x7FC1, 0x7FC6, 0x7FCA, 0x7FCF, 0x7FD3, 0x7FD6, 0x7FDA, + 0x7FDE, 0x7FE1, 0x7FE4, 0x7FE7, 0x7FEA, 0x7FED, 0x7FEF, 0x7FF1, 0x7FF3, 0x7FF5, 0x7FF7, 0x7FF9, 0x7FFA, 0x7FFB, 0x7FFC, 0x7FFD, 0x7FFE, 0x7FFE, 0x7FFF, 0x7FFF +}; + +#define MIN(a, b) (((a)<(b)) ? (a) : (b)) + +size_t Resampler::Convert48To44(int16_t* from, int16_t* to, size_t fromLen, size_t toLen) { + size_t outLen = fromLen * 147 / 160; + if (toLen < outLen) + outLen = toLen; + for (unsigned int offset = 0; offset < outLen; offset++) { + float offsetf = offset * 160.0f / 147.0f; + float factor = offsetf - floorf(offsetf); + to[offset] = static_cast(from[static_cast(floorf(offsetf))] * (1 - factor) + + from[static_cast(ceilf(offsetf))] * factor); + } + return outLen; +} + +size_t Resampler::Convert44To48(int16_t* from, int16_t* to, size_t fromLen, size_t toLen) { + size_t outLen = fromLen * 160 / 147; + if (toLen < outLen) + outLen = toLen; + unsigned int offset; + for (offset = 0; offset < outLen; offset++) { + float offsetf = offset * 147.0f / 160.0f; + float factor = offsetf - floorf(offsetf); + to[offset] = static_cast(from[static_cast(floorf(offsetf))] * (1 - factor) + + from[static_cast(ceilf(offsetf))] * factor); + } + return outLen; +} + + +size_t Resampler::Convert(int16_t* from, int16_t* to, size_t fromLen, size_t toLen, size_t num, size_t denom) { + size_t outLen = fromLen * num / denom; + if (toLen < outLen) + outLen = toLen; + unsigned int offset; + for (offset = 0; offset < outLen; offset++) { + float offsetf = offset * static_cast(denom) / static_cast(num); + float factor = offsetf - floorf(offsetf); + to[offset] = static_cast(from[static_cast(floorf(offsetf))] * (1 - factor) + + from[static_cast(ceilf(offsetf))] * factor); + } + return outLen; +} + +void Resampler::Rescale60To80(int16_t* in, int16_t* out) { + std::memcpy(out, in, 960 * 2); + std::memcpy(out + 960 * 3, in + 960 * 2, 960 * 2); + for (int i = 0; i < 960; i++) { + out[960 + i] = static_cast(((static_cast(in[960 + i]) * hann[959 - i]) >> 15) + + ((static_cast(in[480 + i]) * hann[i]) >> 15)); + out[1920 + i] = static_cast(((static_cast(in[960 + 480 + i]) * hann[959 - i]) >> 15) + + ((static_cast(in[480 + 480 + i]) * hann[i]) >> 15)); + } +} + +void Resampler::Rescale60To40(int16_t* in, int16_t* out) { + for (int i = 0; i < 960; i++) { + out[i] = static_cast(((static_cast(in[i]) * hann[959 - i]) >> 15) + + ((static_cast(in[480 + i]) * hann[i]) >> 15)); + out[960 + i] = static_cast(((static_cast(in[1920 + i]) * hann[i]) >> 15) + + ((static_cast(in[1440 + i]) * hann[959 - i]) >> 15)); + } +} diff --git a/TMessagesProj/jni/libtgvoip2/audio/Resampler.h b/TMessagesProj/jni/libtgvoip2/audio/Resampler.h new file mode 100644 index 000000000..cec9362b0 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/audio/Resampler.h @@ -0,0 +1,24 @@ +// +// Created by Grishka on 01.04.17. +// + +#ifndef LIBTGVOIP_RESAMPLER_H +#define LIBTGVOIP_RESAMPLER_H + +#include +#include + +namespace tgvoip { +namespace audio { + class Resampler { + public: + static size_t Convert48To44(int16_t* from, int16_t* to, size_t fromLen, size_t toLen); + static size_t Convert44To48(int16_t* from, int16_t* to, size_t fromLen, size_t toLen); + static size_t Convert(int16_t* from, int16_t* to, size_t fromLen, size_t toLen, size_t num, size_t denom); + static void Rescale60To80(int16_t* in, int16_t* out); + static void Rescale60To40(int16_t* in, int16_t* out); + }; +} // namespace audio +} // namespace tgvoip + +#endif //LIBTGVOIP_RESAMPLER_H diff --git a/TMessagesProj/jni/libtgvoip2/client/android/org_telegram_messenger_voip_TgVoip.cpp b/TMessagesProj/jni/libtgvoip2/client/android/org_telegram_messenger_voip_TgVoip.cpp new file mode 100644 index 000000000..6af749265 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/client/android/org_telegram_messenger_voip_TgVoip.cpp @@ -0,0 +1,405 @@ +#include +#include +#include +#include +#include +#include "org_telegram_messenger_voip_TgVoip.h" + +using namespace tgvoip; + +extern "C" int tgvoipOnJniLoad(JavaVM *vm, JNIEnv *env) { + return JNI_TRUE; +} + +#pragma mark - Helpers + +class JavaObject { +private: + JNIEnv *env; + jobject obj; + jclass clazz; + +public: + JavaObject(JNIEnv *env, jobject obj) : JavaObject(env, obj, env->GetObjectClass(obj)) { + } + + JavaObject(JNIEnv *env, jobject obj, jclass clazz) { + this->env = env; + this->obj = obj; + this->clazz = clazz; + } + + jint getIntField(const char *name) { + return env->GetIntField(obj, env->GetFieldID(clazz, name, "I")); + } + + jlong getLongField(const char *name) { + return env->GetLongField(obj, env->GetFieldID(clazz, name, "J")); + } + + jboolean getBooleanField(const char *name) { + return env->GetBooleanField(obj, env->GetFieldID(clazz, name, "Z")); + } + + jdouble getDoubleField(const char *name) { + return env->GetDoubleField(obj, env->GetFieldID(clazz, name, "D")); + } + + jbyteArray getByteArrayField(const char *name) { + return (jbyteArray) env->GetObjectField(obj, env->GetFieldID(clazz, name, "[B")); + } + + jstring getStringField(const char *name) { + return (jstring) env->GetObjectField(obj, env->GetFieldID(clazz, name, "Ljava/lang/String;")); + } +}; + +struct InstanceHolder { + TgVoip *nativeInstance; + jobject javaInstance; +}; + +jlong getInstanceHolderId(JNIEnv *env, jobject obj) { + return env->GetLongField(obj, env->GetFieldID(env->GetObjectClass(obj), "nativeInstanceId", "J")); +} + +InstanceHolder *getInstanceHolder(JNIEnv *env, jobject obj) { + return reinterpret_cast(getInstanceHolderId(env, obj)); +} + +TgVoip *getTgVoip(JNIEnv *env, jobject obj) { + return getInstanceHolder(env, obj)->nativeInstance; +} + +jint throwNewJavaException(JNIEnv *env, const char *className, const char *message) { + return env->ThrowNew(env->FindClass(className), message); +} + +jint throwNewJavaIllegalArgumentException(JNIEnv *env, const char *message) { + return throwNewJavaException(env, "java/lang/IllegalStateException", message); +} + +jbyteArray copyVectorToJavaByteArray(JNIEnv *env, const std::vector &bytes) { + unsigned int size = bytes.size(); + jbyteArray bytesArray = env->NewByteArray(size); + env->SetByteArrayRegion(bytesArray, 0, size, (jbyte *) bytes.data()); + return bytesArray; +} + +void readTgVoipPersistentState(const char *filePath, TgVoipPersistentState &tgVoipPersistentState) { + FILE *persistentStateFile = fopen(filePath, "r"); + if (persistentStateFile) { + fseek(persistentStateFile, 0, SEEK_END); + auto len = static_cast(ftell(persistentStateFile)); + fseek(persistentStateFile, 0, SEEK_SET); + if (len < 1024 * 512 && len > 0) { + auto *buffer = static_cast(malloc(len)); + fread(buffer, 1, len, persistentStateFile); + tgVoipPersistentState.value = std::vector(buffer, buffer + len); + free(buffer); + } + fclose(persistentStateFile); + } +} + +void saveTgVoipPersistentState(const char *filePath, const TgVoipPersistentState &tgVoipPersistentState) { + FILE *persistentStateFile = fopen(filePath, "w"); + if (persistentStateFile) { + fwrite(tgVoipPersistentState.value.data(), 1, tgVoipPersistentState.value.size(), persistentStateFile); + fclose(persistentStateFile); + } +} + +#pragma mark - Mappers + +TgVoipNetworkType parseTgVoipNetworkType(jint networkType) { + switch (networkType) { + case org_telegram_messenger_voip_TgVoip_NET_TYPE_GPRS: + return TgVoipNetworkType::Gprs; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_EDGE: + return TgVoipNetworkType::Edge; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_3G: + return TgVoipNetworkType::ThirdGeneration; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_HSPA: + return TgVoipNetworkType::Hspa; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_LTE: + return TgVoipNetworkType::Lte; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_WIFI: + return TgVoipNetworkType::WiFi; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_ETHERNET: + return TgVoipNetworkType::Ethernet; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_HIGH_SPEED: + return TgVoipNetworkType::OtherHighSpeed; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_LOW_SPEED: + return TgVoipNetworkType::OtherLowSpeed; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_DIALUP: + return TgVoipNetworkType::Dialup; + case org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_MOBILE: + return TgVoipNetworkType::OtherMobile; + default: + return TgVoipNetworkType::Unknown; + } +} + +TgVoipDataSaving parseTgVoipDataSaving(JNIEnv *env, jint dataSaving) { + switch (dataSaving) { + case org_telegram_messenger_voip_TgVoip_DATA_SAVING_NEVER: + return TgVoipDataSaving::Never; + case org_telegram_messenger_voip_TgVoip_DATA_SAVING_MOBILE: + return TgVoipDataSaving::Mobile; + case org_telegram_messenger_voip_TgVoip_DATA_SAVING_ALWAYS: + return TgVoipDataSaving::Always; + case org_telegram_messenger_voip_TgVoip_DATA_SAVING_ROAMING: + throwNewJavaIllegalArgumentException(env, "DATA_SAVING_ROAMING is not supported"); + return TgVoipDataSaving::Never; + default: + throwNewJavaIllegalArgumentException(env, "Unknown data saving constant: " + dataSaving); + return TgVoipDataSaving::Never; + } +} + +void parseTgVoipConfig(JNIEnv *env, jobject config, TgVoipConfig &tgVoipConfig) { + JavaObject configObject(env, config); + tgVoipConfig.initializationTimeout = configObject.getDoubleField("initializationTimeout"); + tgVoipConfig.receiveTimeout = configObject.getDoubleField("receiveTimeout"); + tgVoipConfig.dataSaving = parseTgVoipDataSaving(env, configObject.getIntField("dataSaving")); + tgVoipConfig.enableP2P = configObject.getBooleanField("enableP2p") == JNI_TRUE; + tgVoipConfig.enableAEC = configObject.getBooleanField("enableAec") == JNI_TRUE; + tgVoipConfig.enableNS = configObject.getBooleanField("enableNs") == JNI_TRUE; + tgVoipConfig.enableAGC = configObject.getBooleanField("enableAgc") == JNI_TRUE; + tgVoipConfig.enableCallUpgrade = configObject.getBooleanField("enableCallUpgrade") == JNI_TRUE; + tgVoipConfig.logPath = jni::JavaStringToStdString(env, configObject.getStringField("logPath")); + tgVoipConfig.maxApiLayer = configObject.getIntField("maxApiLayer"); +} + +TgVoipEndpointType parseTgVoipEndpointType(JNIEnv *env, jint endpointType) { + switch (endpointType) { + case org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_INET: + return TgVoipEndpointType::Inet; + case org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_LAN: + return TgVoipEndpointType::Lan; + case org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_TCP_RELAY: + return TgVoipEndpointType::TcpRelay; + case org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_UDP_RELAY: + return TgVoipEndpointType::UdpRelay; + default: + throwNewJavaIllegalArgumentException(env, std::string("Unknown endpoint type: ").append(std::to_string(endpointType)).c_str()); + return TgVoipEndpointType::UdpRelay; + } +} + +void parseTgVoipEndpoint(JNIEnv *env, jobject endpoint, TgVoipEndpoint &tgVoipEndpoint) { + JavaObject endpointObject(env, endpoint); + tgVoipEndpoint.endpointId = endpointObject.getLongField("id"); + tgVoipEndpoint.host = { + .ipv4 = jni::JavaStringToStdString(env, endpointObject.getStringField("ipv4")), + .ipv6 = jni::JavaStringToStdString(env, endpointObject.getStringField("ipv6")) + }; + tgVoipEndpoint.port = static_cast(endpointObject.getIntField("port")); + tgVoipEndpoint.type = parseTgVoipEndpointType(env, endpointObject.getIntField("type")); + jbyteArray peerTag = endpointObject.getByteArrayField("peerTag"); + if (peerTag && env->GetArrayLength(peerTag)) { + jbyte *peerTagBytes = env->GetByteArrayElements(peerTag, nullptr); + memcpy(tgVoipEndpoint.peerTag, peerTagBytes, 16); + env->ReleaseByteArrayElements(peerTag, peerTagBytes, JNI_ABORT); + } +} + +void parseTgVoipEndpoints(JNIEnv *env, jobjectArray endpoints, std::vector &tgVoipEndpoints) { + for (int i = 0, size = env->GetArrayLength(endpoints); i < size; i++) { + TgVoipEndpoint tgVoipEndpoint; + parseTgVoipEndpoint(env, env->GetObjectArrayElement(endpoints, i), tgVoipEndpoint); + tgVoipEndpoints.push_back(tgVoipEndpoint); + } +} + +void parseTgVoipEncryptionKey(JNIEnv *env, jobject encryptionKey, TgVoipEncryptionKey &tgVoipEncryptionKey) { + JavaObject encryptionKeyObject(env, encryptionKey); + tgVoipEncryptionKey.isOutgoing = encryptionKeyObject.getBooleanField("isOutgoing") == JNI_TRUE; + jbyteArray valueByteArray = encryptionKeyObject.getByteArrayField("value"); + auto *valueBytes = (uint8_t *) env->GetByteArrayElements(valueByteArray, nullptr); + tgVoipEncryptionKey.value = std::vector(valueBytes, valueBytes + env->GetArrayLength(valueByteArray)); + env->ReleaseByteArrayElements(valueByteArray, (jbyte *) valueBytes, JNI_ABORT); +} + +void parseTgVoipProxy(JNIEnv *env, jobject proxy, std::unique_ptr &tgVoipProxy) { + if (!env->IsSameObject(proxy, nullptr)) { + JavaObject proxyObject(env, proxy); + tgVoipProxy = std::unique_ptr(new TgVoipProxy); + tgVoipProxy->host = jni::JavaStringToStdString(env, proxyObject.getStringField("host")); + tgVoipProxy->port = static_cast(proxyObject.getIntField("port")); + tgVoipProxy->login = jni::JavaStringToStdString(env, proxyObject.getStringField("login")); + tgVoipProxy->password = jni::JavaStringToStdString(env, proxyObject.getStringField("password")); + } else { + tgVoipProxy = nullptr; + } +} + +jint asJavaState(const TgVoipState &tgVoipState) { + switch (tgVoipState) { + case TgVoipState::WaitInit: + return org_telegram_messenger_voip_TgVoip_STATE_WAIT_INIT; + case TgVoipState::WaitInitAck: + return org_telegram_messenger_voip_TgVoip_STATE_WAIT_INIT_ACK; + case TgVoipState::Estabilished: + return org_telegram_messenger_voip_TgVoip_STATE_ESTABLISHED; + case TgVoipState::Failed: + return org_telegram_messenger_voip_TgVoip_STATE_FAILED; + case TgVoipState::Reconnecting: + return org_telegram_messenger_voip_TgVoip_STATE_RECONNECTING; + } +} + +jobject asJavaTrafficStats(JNIEnv *env, const TgVoipTrafficStats &trafficStats) { + jclass clazz = env->FindClass("org/telegram/messenger/voip/TgVoip$TrafficStats"); + jmethodID initMethodId = env->GetMethodID(clazz, "", "(JJJJ)V"); + return env->NewObject(clazz, initMethodId, trafficStats.bytesSentWifi, trafficStats.bytesReceivedWifi, trafficStats.bytesSentMobile, trafficStats.bytesReceivedMobile); +} + +jobject asJavaFinalState(JNIEnv *env, const TgVoipFinalState &tgVoipFinalState) { + jbyteArray persistentState = copyVectorToJavaByteArray(env, tgVoipFinalState.persistentState.value); + jstring debugLog = env->NewStringUTF(tgVoipFinalState.debugLog.c_str()); + jobject trafficStats = asJavaTrafficStats(env, tgVoipFinalState.trafficStats); + auto isRatingSuggested = static_cast(tgVoipFinalState.isRatingSuggested); + jclass finalStateClass = env->FindClass("org/telegram/messenger/voip/TgVoip$FinalState"); + jmethodID finalStateInitMethodId = env->GetMethodID(finalStateClass, "", "([BLjava/lang/String;Lorg/telegram/messenger/voip/TgVoip$TrafficStats;Z)V"); + return env->NewObject(finalStateClass, finalStateInitMethodId, persistentState, debugLog, trafficStats, isRatingSuggested); +} + +extern "C" { + + #pragma mark - Static JNI Methods + + JNIEXPORT jlong JNICALL Java_org_telegram_messenger_voip_NativeTgVoipDelegate_makeNativeInstance(JNIEnv *env, jobject obj, jobject instanceObj, jobject config, jstring persistentStateFilePath, jobjectArray endpoints, jobject proxy, jint networkType, jobject encryptionKey) { + // reading persistent state + TgVoipPersistentState tgVoipPersistentState; + readTgVoipPersistentState(jni::JavaStringToStdString(env, persistentStateFilePath).c_str(), tgVoipPersistentState); + + // parsing config + TgVoipConfig tgVoipConfig; + parseTgVoipConfig(env, config, tgVoipConfig); + + // parsing endpoints + std::vector tgVoipEndpoints; + parseTgVoipEndpoints(env, endpoints, tgVoipEndpoints); + + // parsing proxy + std::unique_ptr tgVoipProxy; + parseTgVoipProxy(env, proxy, tgVoipProxy); + + // parse encryption key + TgVoipEncryptionKey tgVoipEncryptionKey; + parseTgVoipEncryptionKey(env, encryptionKey, tgVoipEncryptionKey); + + TgVoip *tgVoip = TgVoip::makeInstance(tgVoipConfig, tgVoipPersistentState, tgVoipEndpoints, tgVoipProxy, parseTgVoipNetworkType(networkType), tgVoipEncryptionKey); + + if (env->ExceptionCheck() == JNI_TRUE) { + return 0; + } + + jobject globalRef = env->NewGlobalRef(instanceObj); + + tgVoip->setOnStateUpdated([globalRef](TgVoipState tgVoipState) { + jint state = asJavaState(tgVoipState); + jni::DoWithJNI([globalRef, state](JNIEnv *env) { + env->CallVoidMethod(globalRef, env->GetMethodID(env->GetObjectClass(globalRef), "onStateUpdated", "(I)V"), state); + }); + }); + + tgVoip->setOnSignalBarsUpdated([globalRef](int signalBars) { + jni::DoWithJNI([globalRef, signalBars](JNIEnv *env) { + env->CallVoidMethod(globalRef, env->GetMethodID(env->GetObjectClass(globalRef), "onSignalBarsUpdated", "(I)V"), signalBars); + }); + }); + + auto *instance = new InstanceHolder; + instance->nativeInstance = tgVoip; + instance->javaInstance = globalRef; + return reinterpret_cast(instance); + } + + JNIEXPORT void JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipDelegate_setGlobalServerConfig(JNIEnv *env, jobject obj, jstring serverConfigJson) { + TgVoip::setGlobalServerConfig(jni::JavaStringToStdString(env, serverConfigJson)); + } + + JNIEXPORT jint JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipDelegate_getConnectionMaxLayer(JNIEnv *env, jobject obj) { + return TgVoip::getConnectionMaxLayer(); + } + + JNIEXPORT jstring JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipDelegate_getVersion(JNIEnv *env, jobject obj) { + return env->NewStringUTF(TgVoip::getVersion().c_str()); + } + + JNIEXPORT void JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipDelegate_setBufferSize(JNIEnv *env, jobject obj, jint size) { + tgvoip::audio::AudioOutputOpenSLES::nativeBufferSize = (unsigned int) size; + tgvoip::audio::AudioInputOpenSLES::nativeBufferSize = (unsigned int) size; + } + + #pragma mark - Virtual JNI Methods + + JNIEXPORT void JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_setNetworkType(JNIEnv *env, jobject obj, jint networkType) { + getTgVoip(env, obj)->setNetworkType(parseTgVoipNetworkType(networkType)); + } + + JNIEXPORT void JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_setMuteMicrophone(JNIEnv *env, jobject obj, jboolean muteMicrophone) { + getTgVoip(env, obj)->setMuteMicrophone(muteMicrophone); + } + + JNIEXPORT void JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_setAudioOutputGainControlEnabled(JNIEnv *env, jobject obj, jboolean enabled) { + getTgVoip(env, obj)->setAudioOutputGainControlEnabled(enabled); + } + + JNIEXPORT void JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_setEchoCancellationStrength(JNIEnv *env, jobject obj, jint strength) { + getTgVoip(env, obj)->setEchoCancellationStrength(strength); + } + + JNIEXPORT jstring JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_getLastError(JNIEnv *env, jobject obj) { + return env->NewStringUTF(getTgVoip(env, obj)->getLastError().c_str()); + } + + JNIEXPORT jstring JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_getDebugInfo(JNIEnv *env, jobject obj) { + return env->NewStringUTF(getTgVoip(env, obj)->getDebugInfo().c_str()); + } + + JNIEXPORT jlong JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_getPreferredRelayId(JNIEnv *env, jobject obj) { + return getTgVoip(env, obj)->getPreferredRelayId(); + } + + JNIEXPORT jobject JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_getTrafficStats(JNIEnv *env, jobject obj) { + return asJavaTrafficStats(env, getTgVoip(env, obj)->getTrafficStats()); + } + + JNIEXPORT jbyteArray JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_getPersistentState(JNIEnv *env, jobject obj) { + return copyVectorToJavaByteArray(env, getTgVoip(env, obj)->getPersistentState().value); + } + + JNIEXPORT jobject JNICALL + Java_org_telegram_messenger_voip_NativeTgVoipInstance_stop(JNIEnv *env, jobject obj) { + InstanceHolder *instance = getInstanceHolder(env, obj); + TgVoipFinalState tgVoipFinalState = instance->nativeInstance->stop(); + + // saving persistent state + const std::string &path = jni::JavaStringToStdString(env, JavaObject(env, obj).getStringField("persistentStateFilePath")); + saveTgVoipPersistentState(path.c_str(), tgVoipFinalState.persistentState); + + // clean + env->DeleteGlobalRef(instance->javaInstance); + delete instance->nativeInstance; + delete instance; + + return asJavaFinalState(env, tgVoipFinalState); + } +} \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/client/android/org_telegram_messenger_voip_TgVoip.h b/TMessagesProj/jni/libtgvoip2/client/android/org_telegram_messenger_voip_TgVoip.h new file mode 100644 index 000000000..ae6775a6a --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/client/android/org_telegram_messenger_voip_TgVoip.h @@ -0,0 +1,63 @@ +#include + +#ifndef _Included_org_telegram_messenger_voip_TgVoip +#define _Included_org_telegram_messenger_voip_TgVoip +#ifdef __cplusplus +extern "C" { +#endif +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_UNKNOWN +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_UNKNOWN 0L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_GPRS +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_GPRS 1L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_EDGE +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_EDGE 2L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_3G +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_3G 3L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_HSPA +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_HSPA 4L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_LTE +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_LTE 5L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_WIFI +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_WIFI 6L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_ETHERNET +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_ETHERNET 7L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_HIGH_SPEED +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_HIGH_SPEED 8L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_LOW_SPEED +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_LOW_SPEED 9L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_DIALUP +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_DIALUP 10L +#undef org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_MOBILE +#define org_telegram_messenger_voip_TgVoip_NET_TYPE_OTHER_MOBILE 11L +#undef org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_INET +#define org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_INET 0L +#undef org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_LAN +#define org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_LAN 1L +#undef org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_UDP_RELAY +#define org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_UDP_RELAY 2L +#undef org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_TCP_RELAY +#define org_telegram_messenger_voip_TgVoip_ENDPOINT_TYPE_TCP_RELAY 3L +#undef org_telegram_messenger_voip_TgVoip_STATE_WAIT_INIT +#define org_telegram_messenger_voip_TgVoip_STATE_WAIT_INIT 1L +#undef org_telegram_messenger_voip_TgVoip_STATE_WAIT_INIT_ACK +#define org_telegram_messenger_voip_TgVoip_STATE_WAIT_INIT_ACK 2L +#undef org_telegram_messenger_voip_TgVoip_STATE_ESTABLISHED +#define org_telegram_messenger_voip_TgVoip_STATE_ESTABLISHED 3L +#undef org_telegram_messenger_voip_TgVoip_STATE_FAILED +#define org_telegram_messenger_voip_TgVoip_STATE_FAILED 4L +#undef org_telegram_messenger_voip_TgVoip_STATE_RECONNECTING +#define org_telegram_messenger_voip_TgVoip_STATE_RECONNECTING 5L +#undef org_telegram_messenger_voip_TgVoip_DATA_SAVING_NEVER +#define org_telegram_messenger_voip_TgVoip_DATA_SAVING_NEVER 0L +#undef org_telegram_messenger_voip_TgVoip_DATA_SAVING_MOBILE +#define org_telegram_messenger_voip_TgVoip_DATA_SAVING_MOBILE 1L +#undef org_telegram_messenger_voip_TgVoip_DATA_SAVING_ALWAYS +#define org_telegram_messenger_voip_TgVoip_DATA_SAVING_ALWAYS 2L +#undef org_telegram_messenger_voip_TgVoip_DATA_SAVING_ROAMING +#define org_telegram_messenger_voip_TgVoip_DATA_SAVING_ROAMING 3L +#undef org_telegram_messenger_voip_TgVoip_PEER_CAP_GROUP_CALLS +#define org_telegram_messenger_voip_TgVoip_PEER_CAP_GROUP_CALLS 1L +#ifdef __cplusplus +} +#endif +#endif diff --git a/TMessagesProj/jni/libtgvoip2/client/android/tg_voip_jni.cpp b/TMessagesProj/jni/libtgvoip2/client/android/tg_voip_jni.cpp new file mode 100644 index 000000000..11f5de4c7 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/client/android/tg_voip_jni.cpp @@ -0,0 +1,760 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include +#include +#include +#include +#include +#include "../../VoIPServerConfig.h" +#include "../../VoIPController.h" +#include "../../os/android/AudioOutputOpenSLES.h" +#include "../../os/android/AudioInputOpenSLES.h" +#include "../../os/android/AudioInputAndroid.h" +#include "../../os/android/AudioOutputAndroid.h" +#include "../../os/android/VideoSourceAndroid.h" +#include "../../os/android/VideoRendererAndroid.h" +#include "../../audio/Resampler.h" +#include "../../os/android/JNIUtilities.h" +#include "../../PrivateDefines.h" +#include "../../logging.h" + +#ifdef TGVOIP_HAS_CONFIG +#include +#endif + +JavaVM* sharedJVM; +jfieldID audioRecordInstanceFld=NULL; +jfieldID audioTrackInstanceFld=NULL; +jmethodID setStateMethod=NULL; +jmethodID setSignalBarsMethod=NULL; +jmethodID setSelfStreamsMethod=NULL; +jmethodID setParticipantAudioEnabledMethod=NULL; +jmethodID groupCallKeyReceivedMethod=NULL; +jmethodID groupCallKeySentMethod=NULL; +jmethodID callUpgradeRequestReceivedMethod=NULL; +jclass jniUtilitiesClass=NULL; + +struct ImplDataAndroid{ + jobject javaObject; + std::string persistentStateFile=""; +}; + +#ifndef TGVOIP_PACKAGE_PATH +#define TGVOIP_PACKAGE_PATH "org/telegram/messenger/voip" +#endif + +#ifndef TGVOIP_PEER_TAG_VARIABLE_NAME +#define TGVOIP_PEER_TAG_VARIABLE_NAME "peer_tag" +#endif + +#ifndef TGVOIP_ENDPOINT_CLASS +#define TGVOIP_ENDPOINT_CLASS "org/telegram/tgnet/TLRPC$TL_phoneConnection" +#endif + +using namespace tgvoip; +using namespace tgvoip::audio; + +namespace tgvoip { +#pragma mark - Callbacks + + void updateConnectionState(VoIPController *cntrlr, int state){ + ImplDataAndroid *impl=(ImplDataAndroid *) cntrlr->implData; + jni::AttachAndCallVoidMethod(setStateMethod, impl->javaObject, state); + } + + void updateSignalBarCount(VoIPController *cntrlr, int count){ + ImplDataAndroid *impl=(ImplDataAndroid *) cntrlr->implData; + jni::AttachAndCallVoidMethod(setSignalBarsMethod, impl->javaObject, count); + } + + void updateGroupCallStreams(VoIPGroupController *cntrlr, unsigned char *streams, size_t len){ + ImplDataAndroid *impl=(ImplDataAndroid *) cntrlr->implData; + if(!impl->javaObject) + return; + jni::DoWithJNI([streams, len, &impl](JNIEnv* env){ + if(setSelfStreamsMethod){ + jbyteArray jstreams=env->NewByteArray(static_cast(len)); + jbyte *el=env->GetByteArrayElements(jstreams, NULL); + memcpy(el, streams, len); + env->ReleaseByteArrayElements(jstreams, el, 0); + env->CallVoidMethod(impl->javaObject, setSelfStreamsMethod, jstreams); + } + }); + } + + void groupCallKeyReceived(VoIPController *cntrlr, const unsigned char *key){ + ImplDataAndroid *impl=(ImplDataAndroid *) cntrlr->implData; + if(!impl->javaObject) + return; + jni::DoWithJNI([key, &impl](JNIEnv* env){ + if(groupCallKeyReceivedMethod){ + jbyteArray jkey=env->NewByteArray(256); + jbyte *el=env->GetByteArrayElements(jkey, NULL); + memcpy(el, key, 256); + env->ReleaseByteArrayElements(jkey, el, 0); + env->CallVoidMethod(impl->javaObject, groupCallKeyReceivedMethod, jkey); + } + }); + } + + void groupCallKeySent(VoIPController *cntrlr){ + ImplDataAndroid *impl=(ImplDataAndroid *) cntrlr->implData; + jni::AttachAndCallVoidMethod(groupCallKeySentMethod, impl->javaObject); + } + + void callUpgradeRequestReceived(VoIPController* cntrlr){ + ImplDataAndroid *impl=(ImplDataAndroid *) cntrlr->implData; + jni::AttachAndCallVoidMethod(callUpgradeRequestReceivedMethod, impl->javaObject); + } + + void updateParticipantAudioState(VoIPGroupController *cntrlr, int32_t userID, bool enabled){ + ImplDataAndroid *impl=(ImplDataAndroid *) cntrlr->implData; + jni::AttachAndCallVoidMethod(setParticipantAudioEnabledMethod, impl->javaObject, userID, enabled); + } + +#pragma mark - VoIPController + + uint32_t AndroidCodecToFOURCC(std::string mime){ + if(mime=="video/avc") + return CODEC_AVC; + else if(mime=="video/hevc") + return CODEC_HEVC; + else if(mime=="video/x-vnd.on2.vp8") + return CODEC_VP8; + else if(mime=="video/x-vnd.on2.vp9") + return CODEC_VP9; + return 0; + } + + jlong VoIPController_nativeInit(JNIEnv* env, jobject thiz, jstring persistentStateFile) { + ImplDataAndroid* impl=new ImplDataAndroid(); + impl->javaObject=env->NewGlobalRef(thiz); + if(persistentStateFile){ + impl->persistentStateFile=jni::JavaStringToStdString(env, persistentStateFile); + } + VoIPController* cntrlr=new VoIPController(); + cntrlr->implData=impl; + VoIPController::Callbacks callbacks; + callbacks.connectionStateChanged=updateConnectionState; + callbacks.signalBarCountChanged=updateSignalBarCount; + callbacks.groupCallKeyReceived=groupCallKeyReceived; + callbacks.groupCallKeySent=groupCallKeySent; + callbacks.upgradeToGroupCallRequested=callUpgradeRequestReceived; + cntrlr->SetCallbacks(callbacks); + if(!impl->persistentStateFile.empty()){ + FILE* f=fopen(impl->persistentStateFile.c_str(), "r"); + if(f){ + fseek(f, 0, SEEK_END); + size_t len=static_cast(ftell(f)); + fseek(f, 0, SEEK_SET); + if(len<1024*512 && len>0){ + char *fbuf=static_cast(malloc(len)); + fread(fbuf, 1, len, f); + std::vector state(fbuf, fbuf+len); + free(fbuf); + cntrlr->SetPersistentState(state); + } + fclose(f); + } + } +#ifndef TGVOIP_NO_VIDEO + if(video::VideoRendererAndroid::availableDecoders.empty() || video::VideoSourceAndroid::availableEncoders.empty()){ + video::VideoRendererAndroid::availableDecoders.clear(); + video::VideoSourceAndroid::availableEncoders.clear(); + jmethodID getCodecsMethod=env->GetStaticMethodID(jniUtilitiesClass, "getSupportedVideoCodecs", "()[[Ljava/lang/String;"); + jobjectArray codecs=static_cast(env->CallStaticObjectMethod(jniUtilitiesClass, getCodecsMethod)); + jobjectArray encoders=static_cast(env->GetObjectArrayElement(codecs, 0)); + jobjectArray decoders=static_cast(env->GetObjectArrayElement(codecs, 1)); + for(jsize i=0;iGetArrayLength(encoders);i++){ + std::string codec=jni::JavaStringToStdString(env, static_cast(env->GetObjectArrayElement(encoders, i))); + uint32_t id=AndroidCodecToFOURCC(codec); + if(id) + video::VideoSourceAndroid::availableEncoders.push_back(id); + } + for(jsize i=0;iGetArrayLength(decoders);i++){ + std::string codec=jni::JavaStringToStdString(env, static_cast(env->GetObjectArrayElement(decoders, i))); + uint32_t id=AndroidCodecToFOURCC(codec); + if(id) + video::VideoRendererAndroid::availableDecoders.push_back(id); + } + jmethodID getMaxResolutionMethod=env->GetStaticMethodID(jniUtilitiesClass, "getMaxVideoResolution", "()I"); + video::VideoRendererAndroid::maxResolution=env->CallStaticIntMethod(jniUtilitiesClass, getMaxResolutionMethod); + } +#endif + return (jlong)(intptr_t)cntrlr; + } + + void VoIPController_nativeStart(JNIEnv* env, jobject thiz, jlong inst){ + ((VoIPController*)(intptr_t)inst)->Start(); + } + + void VoIPController_nativeConnect(JNIEnv* env, jobject thiz, jlong inst){ + ((VoIPController*)(intptr_t)inst)->Connect(); + } + + void VoIPController_nativeSetProxy(JNIEnv* env, jobject thiz, jlong inst, jstring _address, jint port, jstring _username, jstring _password){ + ((VoIPController*)(intptr_t)inst)->SetProxy(PROXY_SOCKS5, jni::JavaStringToStdString(env, _address), (uint16_t)port, jni::JavaStringToStdString(env, _username), jni::JavaStringToStdString(env, _password)); + } + + void VoIPController_nativeSetEncryptionKey(JNIEnv* env, jobject thiz, jlong inst, jbyteArray key, jboolean isOutgoing){ + jbyte* akey=env->GetByteArrayElements(key, NULL); + ((VoIPController*)(intptr_t)inst)->SetEncryptionKey((char *) akey, isOutgoing); + env->ReleaseByteArrayElements(key, akey, JNI_ABORT); + } + + void VoIPController_nativeSetRemoteEndpoints(JNIEnv* env, jobject thiz, jlong inst, jobjectArray endpoints, jboolean allowP2p, jboolean tcp, jint connectionMaxLayer){ + size_t len=(size_t) env->GetArrayLength(endpoints); + std::vector eps; + /*public String ip; + public String ipv6; + public int port; + public byte[] peer_tag;*/ + jclass epClass=env->GetObjectClass(env->GetObjectArrayElement(endpoints, 0)); + jfieldID ipFld=env->GetFieldID(epClass, "ip", "Ljava/lang/String;"); + jfieldID ipv6Fld=env->GetFieldID(epClass, "ipv6", "Ljava/lang/String;"); + jfieldID portFld=env->GetFieldID(epClass, "port", "I"); + jfieldID peerTagFld=env->GetFieldID(epClass, TGVOIP_PEER_TAG_VARIABLE_NAME, "[B"); + jfieldID idFld=env->GetFieldID(epClass, "id", "J"); + for(unsigned int i=0;iGetObjectArrayElement(endpoints, i); + jstring ip=(jstring) env->GetObjectField(endpoint, ipFld); + jstring ipv6=(jstring) env->GetObjectField(endpoint, ipv6Fld); + jint port=env->GetIntField(endpoint, portFld); + jlong id=env->GetLongField(endpoint, idFld); + jbyteArray peerTag=(jbyteArray) env->GetObjectField(endpoint, peerTagFld); + IPv4Address v4addr(jni::JavaStringToStdString(env, ip)); + IPv6Address v6addr("::0"); + if(ipv6 && env->GetStringLength(ipv6)){ + v6addr=IPv6Address(jni::JavaStringToStdString(env, ipv6)); + } + unsigned char pTag[16]; + if(peerTag && env->GetArrayLength(peerTag)){ + jbyte* peerTagBytes=env->GetByteArrayElements(peerTag, NULL); + memcpy(pTag, peerTagBytes, 16); + env->ReleaseByteArrayElements(peerTag, peerTagBytes, JNI_ABORT); + } + eps.push_back(Endpoint((int64_t)id, (uint16_t)port, v4addr, v6addr, tcp ? Endpoint::Type::TCP_RELAY : Endpoint::Type::UDP_RELAY, pTag)); + } + ((VoIPController*)(intptr_t)inst)->SetRemoteEndpoints(eps, allowP2p, connectionMaxLayer); + } + + void VoIPController_nativeSetNativeBufferSize(JNIEnv* env, jclass thiz, jint size){ + AudioOutputOpenSLES::nativeBufferSize=(unsigned int) size; + AudioInputOpenSLES::nativeBufferSize=(unsigned int) size; + } + + void VoIPController_nativeRelease(JNIEnv* env, jobject thiz, jlong inst){ + //env->DeleteGlobalRef(AudioInputAndroid::jniClass); + + VoIPController* ctlr=((VoIPController*)(intptr_t)inst); + ImplDataAndroid* impl=(ImplDataAndroid*)ctlr->implData; + ctlr->Stop(); + std::vector state=ctlr->GetPersistentState(); + delete ctlr; + env->DeleteGlobalRef(impl->javaObject); + if(!impl->persistentStateFile.empty()){ + FILE* f=fopen(impl->persistentStateFile.c_str(), "w"); + if(f){ + fwrite(state.data(), 1, state.size(), f); + fclose(f); + } + } + delete impl; + } + + jstring VoIPController_nativeGetDebugString(JNIEnv* env, jobject thiz, jlong inst){ + std::string str=((VoIPController*)(intptr_t)inst)->GetDebugString(); + return env->NewStringUTF(str.c_str()); + } + + void VoIPController_nativeSetNetworkType(JNIEnv* env, jobject thiz, jlong inst, jint type){ + ((VoIPController*)(intptr_t)inst)->SetNetworkType(type); + } + + void VoIPController_nativeSetMicMute(JNIEnv* env, jobject thiz, jlong inst, jboolean mute){ + ((VoIPController*)(intptr_t)inst)->SetMicMute(mute); + } + + void VoIPController_nativeSetConfig(JNIEnv* env, jobject thiz, jlong inst, jdouble recvTimeout, jdouble initTimeout, jint dataSavingMode, jboolean enableAEC, jboolean enableNS, jboolean enableAGC, jstring logFilePath, jstring statsDumpPath, jboolean logPacketStats){ + VoIPController::Config cfg; + cfg.initTimeout=initTimeout; + cfg.recvTimeout=recvTimeout; + cfg.dataSaving=dataSavingMode; + cfg.enableAEC=enableAEC; + cfg.enableNS=enableNS; + cfg.enableAGC=enableAGC; + cfg.enableCallUpgrade=false; + cfg.logPacketStats=logPacketStats; + if(logFilePath){ + cfg.logFilePath=jni::JavaStringToStdString(env, logFilePath); + } + if(statsDumpPath){ + cfg.statsDumpFilePath=jni::JavaStringToStdString(env, statsDumpPath); + } + +#ifndef TGVOIP_NO_VIDEO + cfg.enableVideoReceive=cfg.enableVideoSend=true; +#endif + + ((VoIPController*)(intptr_t)inst)->SetConfig(cfg); + } + + void VoIPController_nativeDebugCtl(JNIEnv* env, jobject thiz, jlong inst, jint request, jint param){ + ((VoIPController*)(intptr_t)inst)->DebugCtl(request, param); + } + + jstring VoIPController_nativeGetVersion(JNIEnv* env, jclass clasz){ + return env->NewStringUTF(VoIPController::GetVersion()); + } + + jlong VoIPController_nativeGetPreferredRelayID(JNIEnv* env, jclass clasz, jlong inst){ + return ((VoIPController*)(intptr_t)inst)->GetPreferredRelayID(); + } + + jint VoIPController_nativeGetLastError(JNIEnv* env, jclass clasz, jlong inst){ + return ((VoIPController*)(intptr_t)inst)->GetLastError(); + } + + void VoIPController_nativeGetStats(JNIEnv* env, jclass clasz, jlong inst, jobject stats){ + VoIPController::TrafficStats _stats; + ((VoIPController*)(intptr_t)inst)->GetStats(&_stats); + jclass cls=env->GetObjectClass(stats); + env->SetLongField(stats, env->GetFieldID(cls, "bytesSentWifi", "J"), _stats.bytesSentWifi); + env->SetLongField(stats, env->GetFieldID(cls, "bytesSentMobile", "J"), _stats.bytesSentMobile); + env->SetLongField(stats, env->GetFieldID(cls, "bytesRecvdWifi", "J"), _stats.bytesRecvdWifi); + env->SetLongField(stats, env->GetFieldID(cls, "bytesRecvdMobile", "J"), _stats.bytesRecvdMobile); + } + + jstring VoIPController_nativeGetDebugLog(JNIEnv* env, jobject thiz, jlong inst){ + VoIPController* ctlr=((VoIPController*)(intptr_t)inst); + std::string log=ctlr->GetDebugLog(); + return env->NewStringUTF(log.c_str()); + } + + void VoIPController_nativeSetAudioOutputGainControlEnabled(JNIEnv* env, jclass clasz, jlong inst, jboolean enabled){ + ((VoIPController*)(intptr_t)inst)->SetAudioOutputGainControlEnabled(enabled); + } + + void VoIPController_nativeSetEchoCancellationStrength(JNIEnv* env, jclass cls, jlong inst, jint strength){ + ((VoIPController*)(intptr_t)inst)->SetEchoCancellationStrength(strength); + } + + jint VoIPController_nativeGetPeerCapabilities(JNIEnv* env, jclass cls, jlong inst){ + return ((VoIPController*)(intptr_t)inst)->GetPeerCapabilities(); + } + + void VoIPController_nativeSendGroupCallKey(JNIEnv* env, jclass cls, jlong inst, jbyteArray _key){ + jbyte* key=env->GetByteArrayElements(_key, NULL); + ((VoIPController*)(intptr_t)inst)->SendGroupCallKey((unsigned char *) key); + env->ReleaseByteArrayElements(_key, key, JNI_ABORT); + } + + void VoIPController_nativeRequestCallUpgrade(JNIEnv* env, jclass cls, jlong inst){ + ((VoIPController*)(intptr_t)inst)->RequestCallUpgrade(); + } + + void VoIPController_nativeSetVideoSource(JNIEnv* env, jobject thiz, jlong inst, jlong source){ + ((VoIPController*)(intptr_t)inst)->SetVideoSource((video::VideoSource*)(intptr_t)source); + } + + void VoIPController_nativeSetVideoRenderer(JNIEnv* env, jobject thiz, jlong inst, jlong renderer){ + ((VoIPController*)(intptr_t)inst)->SetVideoRenderer((video::VideoRenderer*)(intptr_t)renderer); + } + + jboolean VoIPController_nativeNeedRate(JNIEnv* env, jclass cls, jlong inst){ + return static_cast(((VoIPController*)(intptr_t)inst)->NeedRate()); + } + + jint VoIPController_getConnectionMaxLayer(JNIEnv* env, jclass cls){ + return VoIPController::GetConnectionMaxLayer(); + } + +#pragma mark - AudioRecordJNI + + void AudioRecordJNI_nativeCallback(JNIEnv* env, jobject thiz, jobject buffer){ + jlong inst=env->GetLongField(thiz, audioRecordInstanceFld); + AudioInputAndroid* in=(AudioInputAndroid*)(intptr_t)inst; + in->HandleCallback(env, buffer); + } + +#pragma mark - AudioTrackJNI + + void AudioTrackJNI_nativeCallback(JNIEnv* env, jobject thiz, jbyteArray buffer){ + jlong inst=env->GetLongField(thiz, audioTrackInstanceFld); + AudioOutputAndroid* in=(AudioOutputAndroid*)(intptr_t)inst; + in->HandleCallback(env, buffer); + } + +#pragma mark - VoIPServerConfig + + void VoIPServerConfig_nativeSetConfig(JNIEnv* env, jclass clasz, jstring jsonString){ + ServerConfig::GetSharedInstance()->Update(jni::JavaStringToStdString(env, jsonString)); + } + +#pragma mark - Resampler + + jint Resampler_convert44to48(JNIEnv* env, jclass cls, jobject from, jobject to){ + return (jint)tgvoip::audio::Resampler::Convert44To48((int16_t *) env->GetDirectBufferAddress(from), (int16_t *) env->GetDirectBufferAddress(to), (size_t) (env->GetDirectBufferCapacity(from)/2), (size_t) (env->GetDirectBufferCapacity(to)/2)); + } + + jint Resampler_convert48to44(JNIEnv* env, jclass cls, jobject from, jobject to){ + return (jint)tgvoip::audio::Resampler::Convert48To44((int16_t *) env->GetDirectBufferAddress(from), (int16_t *) env->GetDirectBufferAddress(to), (size_t) (env->GetDirectBufferCapacity(from)/2), (size_t) (env->GetDirectBufferCapacity(to)/2)); + } + +#pragma mark - VoIPGroupController + +#ifndef TGVOIP_NO_GROUP_CALLS + jlong VoIPGroupController_nativeInit(JNIEnv* env, jobject thiz, jint timeDifference){ + ImplDataAndroid* impl=(ImplDataAndroid*) malloc(sizeof(ImplDataAndroid)); + impl->javaObject=env->NewGlobalRef(thiz); + VoIPGroupController* cntrlr=new VoIPGroupController(timeDifference); + cntrlr->implData=impl; + + VoIPGroupController::Callbacks callbacks; + callbacks.connectionStateChanged=updateConnectionState; + callbacks.updateStreams=updateGroupCallStreams; + callbacks.participantAudioStateChanged=updateParticipantAudioState; + callbacks.signalBarCountChanged=NULL; + cntrlr->SetCallbacks(callbacks); + + return (jlong)(intptr_t)cntrlr; + } + + void VoIPGroupController_nativeSetGroupCallInfo(JNIEnv* env, jclass cls, jlong inst, jbyteArray _encryptionKey, jbyteArray _reflectorGroupTag, jbyteArray _reflectorSelfTag, jbyteArray _reflectorSelfSecret, jbyteArray _reflectorSelfTagHash, jint selfUserID, jstring reflectorAddress, jstring reflectorAddressV6, jint reflectorPort){ + VoIPGroupController* ctlr=((VoIPGroupController*)(intptr_t)inst); + jbyte* encryptionKey=env->GetByteArrayElements(_encryptionKey, NULL); + jbyte* reflectorGroupTag=env->GetByteArrayElements(_reflectorGroupTag, NULL); + jbyte* reflectorSelfTag=env->GetByteArrayElements(_reflectorSelfTag, NULL); + jbyte* reflectorSelfSecret=env->GetByteArrayElements(_reflectorSelfSecret, NULL); + jbyte* reflectorSelfTagHash=env->GetByteArrayElements(_reflectorSelfTagHash, NULL); + + + const char* ipChars=env->GetStringUTFChars(reflectorAddress, NULL); + std::string ipLiteral(ipChars); + NetworkAddress v4addr=NetworkAddress::IPv4(ipLiteral); + NetworkAddress v6addr=NetworkAddress::Empty(); + env->ReleaseStringUTFChars(reflectorAddress, ipChars); + if(reflectorAddressV6 && env->GetStringLength(reflectorAddressV6)){ + const char* ipv6Chars=env->GetStringUTFChars(reflectorAddressV6, NULL); + v6addr=NetworkAddress::IPv6(ipv6Chars); + env->ReleaseStringUTFChars(reflectorAddressV6, ipv6Chars); + } + ctlr->SetGroupCallInfo((unsigned char *) encryptionKey, (unsigned char *) reflectorGroupTag, (unsigned char *) reflectorSelfTag, (unsigned char *) reflectorSelfSecret, (unsigned char*) reflectorSelfTagHash, selfUserID, v4addr, v6addr, (uint16_t)reflectorPort); + + env->ReleaseByteArrayElements(_encryptionKey, encryptionKey, JNI_ABORT); + env->ReleaseByteArrayElements(_reflectorGroupTag, reflectorGroupTag, JNI_ABORT); + env->ReleaseByteArrayElements(_reflectorSelfTag, reflectorSelfTag, JNI_ABORT); + env->ReleaseByteArrayElements(_reflectorSelfSecret, reflectorSelfSecret, JNI_ABORT); + env->ReleaseByteArrayElements(_reflectorSelfTagHash, reflectorSelfTagHash, JNI_ABORT); + } + + void VoIPGroupController_nativeAddGroupCallParticipant(JNIEnv* env, jclass cls, jlong inst, jint userID, jbyteArray _memberTagHash, jbyteArray _streams){ + VoIPGroupController* ctlr=((VoIPGroupController*)(intptr_t)inst); + jbyte* memberTagHash=env->GetByteArrayElements(_memberTagHash, NULL); + jbyte* streams=_streams ? env->GetByteArrayElements(_streams, NULL) : NULL; + + ctlr->AddGroupCallParticipant(userID, (unsigned char *) memberTagHash, (unsigned char *) streams, (size_t) env->GetArrayLength(_streams)); + + env->ReleaseByteArrayElements(_memberTagHash, memberTagHash, JNI_ABORT); + if(_streams) + env->ReleaseByteArrayElements(_streams, streams, JNI_ABORT); + + } + + void VoIPGroupController_nativeRemoveGroupCallParticipant(JNIEnv* env, jclass cls, jlong inst, jint userID){ + VoIPGroupController* ctlr=((VoIPGroupController*)(intptr_t)inst); + ctlr->RemoveGroupCallParticipant(userID); + } + + jfloat VoIPGroupController_nativeGetParticipantAudioLevel(JNIEnv* env, jclass cls, jlong inst, jint userID){ + return ((VoIPGroupController*)(intptr_t)inst)->GetParticipantAudioLevel(userID); + } + + void VoIPGroupController_nativeSetParticipantVolume(JNIEnv* env, jclass cls, jlong inst, jint userID, jfloat volume){ + ((VoIPGroupController*)(intptr_t)inst)->SetParticipantVolume(userID, volume); + } + + jbyteArray VoIPGroupController_getInitialStreams(JNIEnv* env, jclass cls){ + unsigned char buf[1024]; + size_t len=VoIPGroupController::GetInitialStreams(buf, sizeof(buf)); + jbyteArray arr=env->NewByteArray(len); + jbyte* arrElems=env->GetByteArrayElements(arr, NULL); + memcpy(arrElems, buf, len); + env->ReleaseByteArrayElements(arr, arrElems, 0); + return arr; + } + + void VoIPGroupController_nativeSetParticipantStreams(JNIEnv* env, jclass cls, jlong inst, jint userID, jbyteArray _streams){ + jbyte* streams=env->GetByteArrayElements(_streams, NULL); + + ((VoIPGroupController*)(intptr_t)inst)->SetParticipantStreams(userID, (unsigned char *) streams, (size_t) env->GetArrayLength(_streams)); + + env->ReleaseByteArrayElements(_streams, streams, JNI_ABORT); + } +#endif + +#pragma mark - VideoSource + + jlong VideoSource_nativeInit(JNIEnv* env, jobject thiz){ + return (jlong)(intptr_t)new video::VideoSourceAndroid(env->NewGlobalRef(thiz)); + } + + void VideoSource_nativeRelease(JNIEnv* env, jobject thiz, jlong inst){ + delete (video::VideoSource*)(intptr_t)inst; + } + + void VideoSource_nativeSetVideoStreamParameters(JNIEnv* env, jobject thiz, jlong inst, jobjectArray _csd, jint width, jint height){ + std::vector csd; + if(_csd){ + for(int i=0; iGetArrayLength(_csd); i++){ + jobject _buf=env->GetObjectArrayElement(_csd, i); + size_t len=static_cast(env->GetDirectBufferCapacity(_buf)); + Buffer buf(len); + buf.CopyFrom(env->GetDirectBufferAddress(_buf), 0, len); + csd.push_back(std::move(buf)); + } + } + ((video::VideoSourceAndroid*)(intptr_t)inst)->SetStreamParameters(std::move(csd), width, height); + } + + void VideoSource_nativeSendFrame(JNIEnv* env, jobject thiz, jlong inst, jobject buffer, jint offset, jint length, jint flags){ + //size_t bufsize=(size_t)env->GetDirectBufferCapacity(buffer); + Buffer buf(static_cast(length)); + buf.CopyFrom(((char*)env->GetDirectBufferAddress(buffer))+offset, 0, static_cast(length)); + ((video::VideoSourceAndroid*)(intptr_t)inst)->SendFrame(std::move(buf), static_cast(flags)); + } + + void VideoSource_nativeSetRotation(JNIEnv* env, jobject thiz, jlong inst, jint rotation){ + ((video::VideoSourceAndroid*)(intptr_t)inst)->SetRotation((unsigned int)rotation); + } + + void VideoSource_nativeSetPaused(JNIEnv* env, jobject thiz, jlong inst, jboolean paused){ + ((video::VideoSourceAndroid*)(intptr_t)inst)->SetStreamPaused((bool)paused); + } + +#pragma mark - VideoRenderer + + jlong VideoRenderer_nativeInit(JNIEnv* env, jobject thiz){ + return (jlong)(intptr_t)new video::VideoRendererAndroid(env->NewGlobalRef(thiz)); + } + +#pragma mark - VLog + + template void VLog_log(JNIEnv* env, jclass cls, jstring jmsg){ + const char* format="[java] %s"; + std::string msg=jni::JavaStringToStdString(env, jmsg); + switch(level){ + case 0: + LOGV(format, msg.c_str()); + break; + case 1: + LOGD(format, msg.c_str()); + break; + case 2: + LOGI(format, msg.c_str()); + break; + case 3: + LOGW(format, msg.c_str()); + break; + case 4: + LOGE(format, msg.c_str()); + break; + default: + break; + } + } +} + +extern "C" int tgvoipOnJniLoad(JavaVM *vm, JNIEnv *env); + +extern "C" jint JNI_OnLoad(JavaVM *vm, void *reserved) { + JNIEnv *env = 0; + srand(time(NULL)); + + if (vm->GetEnv((void **) &env, JNI_VERSION_1_6) != JNI_OK) { + return -1; + } + + if (tgvoipOnJniLoad(vm, env) != JNI_TRUE) { + return -1; + } + + jclass controller=env->FindClass(TGVOIP_PACKAGE_PATH "/VoIPController"); + jclass groupController=env->FindClass(TGVOIP_PACKAGE_PATH "/VoIPGroupController"); + if(env->ExceptionCheck()){ + env->ExceptionClear(); // is returning NULL from FindClass not enough? + } + jclass audioRecordJNI=env->FindClass(TGVOIP_PACKAGE_PATH "/AudioRecordJNI"); + jclass audioTrackJNI=env->FindClass(TGVOIP_PACKAGE_PATH "/AudioTrackJNI"); + jclass serverConfig=env->FindClass(TGVOIP_PACKAGE_PATH "/VoIPServerConfig"); + jclass resampler=env->FindClass(TGVOIP_PACKAGE_PATH "/Resampler"); + jclass videoSource=env->FindClass(TGVOIP_PACKAGE_PATH "/VideoSource"); + if(env->ExceptionCheck()){ + env->ExceptionClear(); // is returning NULL from FindClass not enough? + } + jclass videoRenderer=env->FindClass(TGVOIP_PACKAGE_PATH "/VideoRenderer"); + if(env->ExceptionCheck()){ + env->ExceptionClear(); // is returning NULL from FindClass not enough? + } + jclass vlog=env->FindClass(TGVOIP_PACKAGE_PATH "/VLog"); + if(env->ExceptionCheck()){ + env->ExceptionClear(); + } + assert(controller && audioRecordJNI && audioTrackJNI && serverConfig && resampler); + + audioRecordInstanceFld=env->GetFieldID(audioRecordJNI, "nativeInst", "J"); + audioTrackInstanceFld=env->GetFieldID(audioTrackJNI, "nativeInst", "J"); + + env->GetJavaVM(&sharedJVM); + if(!AudioInputAndroid::jniClass){ + jclass cls=env->FindClass(TGVOIP_PACKAGE_PATH "/AudioRecordJNI"); + AudioInputAndroid::jniClass=(jclass) env->NewGlobalRef(cls); + AudioInputAndroid::initMethod=env->GetMethodID(cls, "init", "(IIII)V"); + AudioInputAndroid::releaseMethod=env->GetMethodID(cls, "release", "()V"); + AudioInputAndroid::startMethod=env->GetMethodID(cls, "start", "()Z"); + AudioInputAndroid::stopMethod=env->GetMethodID(cls, "stop", "()V"); + AudioInputAndroid::getEnabledEffectsMaskMethod=env->GetMethodID(cls, "getEnabledEffectsMask", "()I"); + + cls=env->FindClass(TGVOIP_PACKAGE_PATH "/AudioTrackJNI"); + AudioOutputAndroid::jniClass=(jclass) env->NewGlobalRef(cls); + AudioOutputAndroid::initMethod=env->GetMethodID(cls, "init", "(IIII)V"); + AudioOutputAndroid::releaseMethod=env->GetMethodID(cls, "release", "()V"); + AudioOutputAndroid::startMethod=env->GetMethodID(cls, "start", "()V"); + AudioOutputAndroid::stopMethod=env->GetMethodID(cls, "stop", "()V"); + + if(videoRenderer){ + video::VideoRendererAndroid::decodeAndDisplayMethod=env->GetMethodID(videoRenderer, "decodeAndDisplay", "(Ljava/nio/ByteBuffer;IJ)V"); + video::VideoRendererAndroid::resetMethod=env->GetMethodID(videoRenderer, "reset", "(Ljava/lang/String;II[[B)V"); + video::VideoRendererAndroid::setStreamEnabledMethod=env->GetMethodID(videoRenderer, "setStreamEnabled", "(ZZ)V"); + video::VideoRendererAndroid::setRotationMethod=env->GetMethodID(videoRenderer, "setRotation", "(I)V"); + } + } + + setStateMethod=env->GetMethodID(controller, "handleStateChange", "(I)V"); + setSignalBarsMethod=env->GetMethodID(controller, "handleSignalBarsChange", "(I)V"); + groupCallKeyReceivedMethod=env->GetMethodID(controller, "groupCallKeyReceived", "([B)V"); + groupCallKeySentMethod=env->GetMethodID(controller, "groupCallKeySent", "()V"); + callUpgradeRequestReceivedMethod=env->GetMethodID(controller, "callUpgradeRequestReceived", "()V"); + + if(!jniUtilitiesClass) + jniUtilitiesClass=(jclass) env->NewGlobalRef(env->FindClass(TGVOIP_PACKAGE_PATH "/JNIUtilities")); + + // VoIPController + JNINativeMethod controllerMethods[]={ + {"nativeInit", "(Ljava/lang/String;)J", (void*)&tgvoip::VoIPController_nativeInit}, + {"nativeStart", "(J)V", (void*)&tgvoip::VoIPController_nativeStart}, + {"nativeConnect", "(J)V", (void*)&tgvoip::VoIPController_nativeConnect}, + {"nativeSetProxy", "(JLjava/lang/String;ILjava/lang/String;Ljava/lang/String;)V", (void*)&tgvoip::VoIPController_nativeSetProxy}, + {"nativeSetEncryptionKey", "(J[BZ)V", (void*)&tgvoip::VoIPController_nativeSetEncryptionKey}, + {"nativeSetRemoteEndpoints", "(J[L" TGVOIP_ENDPOINT_CLASS ";ZZI)V", (void*)&tgvoip::VoIPController_nativeSetRemoteEndpoints}, + {"nativeSetNativeBufferSize", "(I)V", (void*)&tgvoip::VoIPController_nativeSetNativeBufferSize}, + {"nativeRelease", "(J)V", (void*)&tgvoip::VoIPController_nativeRelease}, + {"nativeGetDebugString", "(J)Ljava/lang/String;", (void*)&tgvoip::VoIPController_nativeGetDebugString}, + {"nativeSetNetworkType", "(JI)V", (void*)&tgvoip::VoIPController_nativeSetNetworkType}, + {"nativeSetMicMute", "(JZ)V", (void*)&tgvoip::VoIPController_nativeSetMicMute}, + {"nativeSetConfig", "(JDDIZZZLjava/lang/String;Ljava/lang/String;Z)V", (void*)&tgvoip::VoIPController_nativeSetConfig}, + {"nativeDebugCtl", "(JII)V", (void*)&tgvoip::VoIPController_nativeDebugCtl}, + {"nativeGetVersion", "()Ljava/lang/String;", (void*)&tgvoip::VoIPController_nativeGetVersion}, + {"nativeGetPreferredRelayID", "(J)J", (void*)&tgvoip::VoIPController_nativeGetPreferredRelayID}, + {"nativeGetLastError", "(J)I", (void*)&tgvoip::VoIPController_nativeGetLastError}, + {"nativeGetStats", "(JL" TGVOIP_PACKAGE_PATH "/VoIPController$Stats;)V", (void*)&tgvoip::VoIPController_nativeGetStats}, + {"nativeGetDebugLog", "(J)Ljava/lang/String;", (void*)&tgvoip::VoIPController_nativeGetDebugLog}, + {"nativeSetAudioOutputGainControlEnabled", "(JZ)V", (void*)&tgvoip::VoIPController_nativeSetAudioOutputGainControlEnabled}, + {"nativeSetEchoCancellationStrength", "(JI)V", (void*)&tgvoip::VoIPController_nativeSetEchoCancellationStrength}, + {"nativeGetPeerCapabilities", "(J)I", (void*)&tgvoip::VoIPController_nativeGetPeerCapabilities}, + {"nativeSendGroupCallKey", "(J[B)V", (void*)&tgvoip::VoIPController_nativeSendGroupCallKey}, + {"nativeRequestCallUpgrade", "(J)V", (void*)&tgvoip::VoIPController_nativeRequestCallUpgrade}, + {"nativeNeedRate", "(J)Z", (void*)&tgvoip::VoIPController_nativeNeedRate}, + {"getConnectionMaxLayer", "()I", (void*)&tgvoip::VoIPController_getConnectionMaxLayer} +#ifndef TGVOIP_NO_VIDEO + ,{"nativeSetVideoSource", "(JJ)V", (void*)&tgvoip::VoIPController_nativeSetVideoSource}, + {"nativeSetVideoRenderer", "(JJ)V", (void*)&tgvoip::VoIPController_nativeSetVideoRenderer} +#endif + }; + env->RegisterNatives(controller, controllerMethods, sizeof(controllerMethods)/sizeof(JNINativeMethod)); + + // VoIPGroupController +#ifndef TGVOIP_NO_GROUP_CALLS + if(groupController){ + setStateMethod=env->GetMethodID(groupController, "handleStateChange", "(I)V"); + setParticipantAudioEnabledMethod=env->GetMethodID(groupController, "setParticipantAudioEnabled", "(IZ)V"); + setSelfStreamsMethod=env->GetMethodID(groupController, "setSelfStreams", "([B)V"); + + JNINativeMethod groupControllerMethods[]={ + {"nativeInit", "(I)J", (void*)&tgvoip::VoIPGroupController_nativeInit}, + {"nativeSetGroupCallInfo", "(J[B[B[B[B[BILjava/lang/String;Ljava/lang/String;I)V", (void*)&tgvoip::VoIPGroupController_nativeSetGroupCallInfo}, + {"nativeAddGroupCallParticipant", "(JI[B[B)V", (void*)&tgvoip::VoIPGroupController_nativeAddGroupCallParticipant}, + {"nativeRemoveGroupCallParticipant", "(JI)V", (void*)&tgvoip::VoIPGroupController_nativeRemoveGroupCallParticipant}, + {"nativeGetParticipantAudioLevel", "(JI)F", (void*)&tgvoip::VoIPGroupController_nativeGetParticipantAudioLevel}, + {"nativeSetParticipantVolume", "(JIF)V", (void*)&tgvoip::VoIPGroupController_nativeSetParticipantVolume}, + {"getInitialStreams", "()[B", (void*)&tgvoip::VoIPGroupController_getInitialStreams}, + {"nativeSetParticipantStreams", "(JI[B)V", (void*)&tgvoip::VoIPGroupController_nativeSetParticipantStreams} + }; + env->RegisterNatives(groupController, groupControllerMethods, sizeof(groupControllerMethods)/sizeof(JNINativeMethod)); + } +#endif + + // AudioRecordJNI + JNINativeMethod audioRecordMethods[]={ + {"nativeCallback", "(Ljava/nio/ByteBuffer;)V", (void*)&tgvoip::AudioRecordJNI_nativeCallback} + }; + env->RegisterNatives(audioRecordJNI, audioRecordMethods, sizeof(audioRecordMethods)/sizeof(JNINativeMethod)); + + // AudioTrackJNI + JNINativeMethod audioTrackMethods[]={ + {"nativeCallback", "([B)V", (void*)&tgvoip::AudioTrackJNI_nativeCallback} + }; + env->RegisterNatives(audioTrackJNI, audioTrackMethods, sizeof(audioTrackMethods)/sizeof(JNINativeMethod)); + + // VoIPServerConfig + JNINativeMethod serverConfigMethods[]={ + {"nativeSetConfig", "(Ljava/lang/String;)V", (void*)&tgvoip::VoIPServerConfig_nativeSetConfig} + }; + env->RegisterNatives(serverConfig, serverConfigMethods, sizeof(serverConfigMethods)/sizeof(JNINativeMethod)); + + // Resampler + JNINativeMethod resamplerMethods[]={ + {"convert44to48", "(Ljava/nio/ByteBuffer;Ljava/nio/ByteBuffer;)I", (void*)&tgvoip::Resampler_convert44to48}, + {"convert48to44", "(Ljava/nio/ByteBuffer;Ljava/nio/ByteBuffer;)I", (void*)&tgvoip::Resampler_convert48to44} + }; + env->RegisterNatives(resampler, resamplerMethods, sizeof(resamplerMethods)/sizeof(JNINativeMethod)); + + if(videoSource){ + // VideoSource + JNINativeMethod videoSourceMethods[]={ + {"nativeInit", "()J", (void *) &tgvoip::VideoSource_nativeInit}, + {"nativeRelease", "(J)V", (void *) &tgvoip::VideoSource_nativeRelease}, + {"nativeSetVideoStreamParameters", "(J[Ljava/nio/ByteBuffer;II)V", (void *) &tgvoip::VideoSource_nativeSetVideoStreamParameters}, + {"nativeSendFrame", "(JLjava/nio/ByteBuffer;III)V", (void *) &tgvoip::VideoSource_nativeSendFrame}, + {"nativeSetRotation", "(JI)V", (void*)&tgvoip::VideoSource_nativeSetRotation}, + {"nativeSetPaused", "(JZ)V", (void*)&tgvoip::VideoSource_nativeSetPaused} + }; + env->RegisterNatives(videoSource, videoSourceMethods, sizeof(videoSourceMethods)/sizeof(JNINativeMethod)); + } + + if(videoRenderer){ + // VideoRenderer + JNINativeMethod videoRendererMethods[]={ + {"nativeInit", "()J", (void *) &tgvoip::VideoRenderer_nativeInit} + }; + env->RegisterNatives(videoRenderer, videoRendererMethods, sizeof(videoRendererMethods)/sizeof(JNINativeMethod)); + } + + if(vlog){ + // VLog + JNINativeMethod vlogMethods[]={ + {"v", "(Ljava/lang/String;)V", (void *) &tgvoip::VLog_log<0>}, + {"d", "(Ljava/lang/String;)V", (void *) &tgvoip::VLog_log<1>}, + {"i", "(Ljava/lang/String;)V", (void *) &tgvoip::VLog_log<2>}, + {"w", "(Ljava/lang/String;)V", (void *) &tgvoip::VLog_log<3>}, + {"e", "(Ljava/lang/String;)V", (void *) &tgvoip::VLog_log<4>} + }; + env->RegisterNatives(vlog, vlogMethods, sizeof(vlogMethods)/sizeof(JNINativeMethod)); + } + + return JNI_VERSION_1_6; +} diff --git a/TMessagesProj/jni/libtgvoip2/client/android/tg_voip_jni.h b/TMessagesProj/jni/libtgvoip2/client/android/tg_voip_jni.h new file mode 100644 index 000000000..8c85b6965 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/client/android/tg_voip_jni.h @@ -0,0 +1,18 @@ +// +// Created by Grishka on 14.08.2018. +// + +#ifndef TELEGRAM_TG_VOIP_JNI_H +#define TELEGRAM_TG_VOIP_JNI_H + +#include + +#ifdef __cplusplus +extern "C"{ +#endif +void tgvoipRegisterNatives(JNIEnv* env); +#ifdef __cplusplus +} +#endif + +#endif //TELEGRAM_TG_VOIP_JNI_H diff --git a/TMessagesProj/jni/libtgvoip2/compile b/TMessagesProj/jni/libtgvoip2/compile new file mode 100644 index 000000000..99e50524b --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/compile @@ -0,0 +1,348 @@ +#! /bin/sh +# Wrapper for compilers which do not understand '-c -o'. + +scriptversion=2018-03-07.03; # UTC + +# Copyright (C) 1999-2018 Free Software Foundation, Inc. +# Written by Tom Tromey . +# +# This program 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 2, or (at your option) +# any later version. +# +# This program 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 this program. If not, see . + +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + +# This file is maintained in Automake, please report +# bugs to or send patches to +# . + +nl=' +' + +# We need space, tab and new line, in precisely that order. Quoting is +# there to prevent tools from complaining about whitespace usage. +IFS=" "" $nl" + +file_conv= + +# func_file_conv build_file lazy +# Convert a $build file to $host form and store it in $file +# Currently only supports Windows hosts. If the determined conversion +# type is listed in (the comma separated) LAZY, no conversion will +# take place. +func_file_conv () +{ + file=$1 + case $file in + / | /[!/]*) # absolute file, and not a UNC file + if test -z "$file_conv"; then + # lazily determine how to convert abs files + case `uname -s` in + MINGW*) + file_conv=mingw + ;; + CYGWIN*) + file_conv=cygwin + ;; + *) + file_conv=wine + ;; + esac + fi + case $file_conv/,$2, in + *,$file_conv,*) + ;; + mingw/*) + file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'` + ;; + cygwin/*) + file=`cygpath -m "$file" || echo "$file"` + ;; + wine/*) + file=`winepath -w "$file" || echo "$file"` + ;; + esac + ;; + esac +} + +# func_cl_dashL linkdir +# Make cl look for libraries in LINKDIR +func_cl_dashL () +{ + func_file_conv "$1" + if test -z "$lib_path"; then + lib_path=$file + else + lib_path="$lib_path;$file" + fi + linker_opts="$linker_opts -LIBPATH:$file" +} + +# func_cl_dashl library +# Do a library search-path lookup for cl +func_cl_dashl () +{ + lib=$1 + found=no + save_IFS=$IFS + IFS=';' + for dir in $lib_path $LIB + do + IFS=$save_IFS + if $shared && test -f "$dir/$lib.dll.lib"; then + found=yes + lib=$dir/$lib.dll.lib + break + fi + if test -f "$dir/$lib.lib"; then + found=yes + lib=$dir/$lib.lib + break + fi + if test -f "$dir/lib$lib.a"; then + found=yes + lib=$dir/lib$lib.a + break + fi + done + IFS=$save_IFS + + if test "$found" != yes; then + lib=$lib.lib + fi +} + +# func_cl_wrapper cl arg... +# Adjust compile command to suit cl +func_cl_wrapper () +{ + # Assume a capable shell + lib_path= + shared=: + linker_opts= + for arg + do + if test -n "$eat"; then + eat= + else + case $1 in + -o) + # configure might choose to run compile as 'compile cc -o foo foo.c'. + eat=1 + case $2 in + *.o | *.[oO][bB][jJ]) + func_file_conv "$2" + set x "$@" -Fo"$file" + shift + ;; + *) + func_file_conv "$2" + set x "$@" -Fe"$file" + shift + ;; + esac + ;; + -I) + eat=1 + func_file_conv "$2" mingw + set x "$@" -I"$file" + shift + ;; + -I*) + func_file_conv "${1#-I}" mingw + set x "$@" -I"$file" + shift + ;; + -l) + eat=1 + func_cl_dashl "$2" + set x "$@" "$lib" + shift + ;; + -l*) + func_cl_dashl "${1#-l}" + set x "$@" "$lib" + shift + ;; + -L) + eat=1 + func_cl_dashL "$2" + ;; + -L*) + func_cl_dashL "${1#-L}" + ;; + -static) + shared=false + ;; + -Wl,*) + arg=${1#-Wl,} + save_ifs="$IFS"; IFS=',' + for flag in $arg; do + IFS="$save_ifs" + linker_opts="$linker_opts $flag" + done + IFS="$save_ifs" + ;; + -Xlinker) + eat=1 + linker_opts="$linker_opts $2" + ;; + -*) + set x "$@" "$1" + shift + ;; + *.cc | *.CC | *.cxx | *.CXX | *.[cC]++) + func_file_conv "$1" + set x "$@" -Tp"$file" + shift + ;; + *.c | *.cpp | *.CPP | *.lib | *.LIB | *.Lib | *.OBJ | *.obj | *.[oO]) + func_file_conv "$1" mingw + set x "$@" "$file" + shift + ;; + *) + set x "$@" "$1" + shift + ;; + esac + fi + shift + done + if test -n "$linker_opts"; then + linker_opts="-link$linker_opts" + fi + exec "$@" $linker_opts + exit 1 +} + +eat= + +case $1 in + '') + echo "$0: No command. Try '$0 --help' for more information." 1>&2 + exit 1; + ;; + -h | --h*) + cat <<\EOF +Usage: compile [--help] [--version] PROGRAM [ARGS] + +Wrapper for compilers which do not understand '-c -o'. +Remove '-o dest.o' from ARGS, run PROGRAM with the remaining +arguments, and rename the output as expected. + +If you are trying to build a whole package this is not the +right script to run: please start by reading the file 'INSTALL'. + +Report bugs to . +EOF + exit $? + ;; + -v | --v*) + echo "compile $scriptversion" + exit $? + ;; + cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \ + icl | *[/\\]icl | icl.exe | *[/\\]icl.exe ) + func_cl_wrapper "$@" # Doesn't return... + ;; +esac + +ofile= +cfile= + +for arg +do + if test -n "$eat"; then + eat= + else + case $1 in + -o) + # configure might choose to run compile as 'compile cc -o foo foo.c'. + # So we strip '-o arg' only if arg is an object. + eat=1 + case $2 in + *.o | *.obj) + ofile=$2 + ;; + *) + set x "$@" -o "$2" + shift + ;; + esac + ;; + *.c) + cfile=$1 + set x "$@" "$1" + shift + ;; + *) + set x "$@" "$1" + shift + ;; + esac + fi + shift +done + +if test -z "$ofile" || test -z "$cfile"; then + # If no '-o' option was seen then we might have been invoked from a + # pattern rule where we don't need one. That is ok -- this is a + # normal compilation that the losing compiler can handle. If no + # '.c' file was seen then we are probably linking. That is also + # ok. + exec "$@" +fi + +# Name of file we expect compiler to create. +cofile=`echo "$cfile" | sed 's|^.*[\\/]||; s|^[a-zA-Z]:||; s/\.c$/.o/'` + +# Create the lock directory. +# Note: use '[/\\:.-]' here to ensure that we don't use the same name +# that we are using for the .o file. Also, base the name on the expected +# object file name, since that is what matters with a parallel build. +lockdir=`echo "$cofile" | sed -e 's|[/\\:.-]|_|g'`.d +while true; do + if mkdir "$lockdir" >/dev/null 2>&1; then + break + fi + sleep 1 +done +# FIXME: race condition here if user kills between mkdir and trap. +trap "rmdir '$lockdir'; exit 1" 1 2 15 + +# Run the compile. +"$@" +ret=$? + +if test -f "$cofile"; then + test "$cofile" = "$ofile" || mv "$cofile" "$ofile" +elif test -f "${cofile}bj"; then + test "${cofile}bj" = "$ofile" || mv "${cofile}bj" "$ofile" +fi + +rmdir "$lockdir" +exit $ret + +# Local Variables: +# mode: shell-script +# sh-indentation: 2 +# eval: (add-hook 'before-save-hook 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-time-zone: "UTC0" +# time-stamp-end: "; # UTC" +# End: diff --git a/TMessagesProj/jni/libtgvoip2/config.guess b/TMessagesProj/jni/libtgvoip2/config.guess new file mode 100644 index 000000000..256083a70 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/config.guess @@ -0,0 +1,1476 @@ +#! /bin/sh +# Attempt to guess a canonical system name. +# Copyright 1992-2018 Free Software Foundation, Inc. + +timestamp='2018-03-08' + +# This file 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. +# +# This program 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 this program; if not, see . +# +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that +# program. This Exception is an additional permission under section 7 +# of the GNU General Public License, version 3 ("GPLv3"). +# +# Originally written by Per Bothner; maintained since 2000 by Ben Elliston. +# +# You can get the latest version of this script from: +# https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess +# +# Please send patches to . + + +me=`echo "$0" | sed -e 's,.*/,,'` + +usage="\ +Usage: $0 [OPTION] + +Output the configuration name of the system \`$me' is run on. + +Options: + -h, --help print this help, then exit + -t, --time-stamp print date of last modification, then exit + -v, --version print version number, then exit + +Report bugs and patches to ." + +version="\ +GNU config.guess ($timestamp) + +Originally written by Per Bothner. +Copyright 1992-2018 Free Software Foundation, Inc. + +This is free software; see the source for copying conditions. There is NO +warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." + +help=" +Try \`$me --help' for more information." + +# Parse command line +while test $# -gt 0 ; do + case $1 in + --time-stamp | --time* | -t ) + echo "$timestamp" ; exit ;; + --version | -v ) + echo "$version" ; exit ;; + --help | --h* | -h ) + echo "$usage"; exit ;; + -- ) # Stop option processing + shift; break ;; + - ) # Use stdin as input. + break ;; + -* ) + echo "$me: invalid option $1$help" >&2 + exit 1 ;; + * ) + break ;; + esac +done + +if test $# != 0; then + echo "$me: too many arguments$help" >&2 + exit 1 +fi + +trap 'exit 1' 1 2 15 + +# CC_FOR_BUILD -- compiler used by this script. Note that the use of a +# compiler to aid in system detection is discouraged as it requires +# temporary files to be created and, as you can see below, it is a +# headache to deal with in a portable fashion. + +# Historically, `CC_FOR_BUILD' used to be named `HOST_CC'. We still +# use `HOST_CC' if defined, but it is deprecated. + +# Portable tmp directory creation inspired by the Autoconf team. + +set_cc_for_build=' +trap "exitcode=\$?; (rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null) && exit \$exitcode" 0 ; +trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ; +: ${TMPDIR=/tmp} ; + { tmp=`(umask 077 && mktemp -d "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } || + { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir $tmp) ; } || + { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir $tmp) && echo "Warning: creating insecure temp directory" >&2 ; } || + { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } ; +dummy=$tmp/dummy ; +tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ; +case $CC_FOR_BUILD,$HOST_CC,$CC in + ,,) echo "int x;" > "$dummy.c" ; + for c in cc gcc c89 c99 ; do + if ($c -c -o "$dummy.o" "$dummy.c") >/dev/null 2>&1 ; then + CC_FOR_BUILD="$c"; break ; + fi ; + done ; + if test x"$CC_FOR_BUILD" = x ; then + CC_FOR_BUILD=no_compiler_found ; + fi + ;; + ,,*) CC_FOR_BUILD=$CC ;; + ,*,*) CC_FOR_BUILD=$HOST_CC ;; +esac ; set_cc_for_build= ;' + +# This is needed to find uname on a Pyramid OSx when run in the BSD universe. +# (ghazi@noc.rutgers.edu 1994-08-24) +if (test -f /.attbin/uname) >/dev/null 2>&1 ; then + PATH=$PATH:/.attbin ; export PATH +fi + +UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown +UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown +UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown +UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown + +case "$UNAME_SYSTEM" in +Linux|GNU|GNU/*) + # If the system lacks a compiler, then just pick glibc. + # We could probably try harder. + LIBC=gnu + + eval "$set_cc_for_build" + cat <<-EOF > "$dummy.c" + #include + #if defined(__UCLIBC__) + LIBC=uclibc + #elif defined(__dietlibc__) + LIBC=dietlibc + #else + LIBC=gnu + #endif + EOF + eval "`$CC_FOR_BUILD -E "$dummy.c" 2>/dev/null | grep '^LIBC' | sed 's, ,,g'`" + + # If ldd exists, use it to detect musl libc. + if command -v ldd >/dev/null && \ + ldd --version 2>&1 | grep -q ^musl + then + LIBC=musl + fi + ;; +esac + +# Note: order is significant - the case branches are not exclusive. + +case "$UNAME_MACHINE:$UNAME_SYSTEM:$UNAME_RELEASE:$UNAME_VERSION" in + *:NetBSD:*:*) + # NetBSD (nbsd) targets should (where applicable) match one or + # more of the tuples: *-*-netbsdelf*, *-*-netbsdaout*, + # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently + # switched to ELF, *-*-netbsd* would select the old + # object file format. This provides both forward + # compatibility and a consistent mechanism for selecting the + # object file format. + # + # Note: NetBSD doesn't particularly care about the vendor + # portion of the name. We always set it to "unknown". + sysctl="sysctl -n hw.machine_arch" + UNAME_MACHINE_ARCH=`(uname -p 2>/dev/null || \ + "/sbin/$sysctl" 2>/dev/null || \ + "/usr/sbin/$sysctl" 2>/dev/null || \ + echo unknown)` + case "$UNAME_MACHINE_ARCH" in + armeb) machine=armeb-unknown ;; + arm*) machine=arm-unknown ;; + sh3el) machine=shl-unknown ;; + sh3eb) machine=sh-unknown ;; + sh5el) machine=sh5le-unknown ;; + earmv*) + arch=`echo "$UNAME_MACHINE_ARCH" | sed -e 's,^e\(armv[0-9]\).*$,\1,'` + endian=`echo "$UNAME_MACHINE_ARCH" | sed -ne 's,^.*\(eb\)$,\1,p'` + machine="${arch}${endian}"-unknown + ;; + *) machine="$UNAME_MACHINE_ARCH"-unknown ;; + esac + # The Operating System including object format, if it has switched + # to ELF recently (or will in the future) and ABI. + case "$UNAME_MACHINE_ARCH" in + earm*) + os=netbsdelf + ;; + arm*|i386|m68k|ns32k|sh3*|sparc|vax) + eval "$set_cc_for_build" + if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \ + | grep -q __ELF__ + then + # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout). + # Return netbsd for either. FIX? + os=netbsd + else + os=netbsdelf + fi + ;; + *) + os=netbsd + ;; + esac + # Determine ABI tags. + case "$UNAME_MACHINE_ARCH" in + earm*) + expr='s/^earmv[0-9]/-eabi/;s/eb$//' + abi=`echo "$UNAME_MACHINE_ARCH" | sed -e "$expr"` + ;; + esac + # The OS release + # Debian GNU/NetBSD machines have a different userland, and + # thus, need a distinct triplet. However, they do not need + # kernel version information, so it can be replaced with a + # suitable tag, in the style of linux-gnu. + case "$UNAME_VERSION" in + Debian*) + release='-gnu' + ;; + *) + release=`echo "$UNAME_RELEASE" | sed -e 's/[-_].*//' | cut -d. -f1,2` + ;; + esac + # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM: + # contains redundant information, the shorter form: + # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used. + echo "$machine-${os}${release}${abi}" + exit ;; + *:Bitrig:*:*) + UNAME_MACHINE_ARCH=`arch | sed 's/Bitrig.//'` + echo "$UNAME_MACHINE_ARCH"-unknown-bitrig"$UNAME_RELEASE" + exit ;; + *:OpenBSD:*:*) + UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'` + echo "$UNAME_MACHINE_ARCH"-unknown-openbsd"$UNAME_RELEASE" + exit ;; + *:LibertyBSD:*:*) + UNAME_MACHINE_ARCH=`arch | sed 's/^.*BSD\.//'` + echo "$UNAME_MACHINE_ARCH"-unknown-libertybsd"$UNAME_RELEASE" + exit ;; + *:MidnightBSD:*:*) + echo "$UNAME_MACHINE"-unknown-midnightbsd"$UNAME_RELEASE" + exit ;; + *:ekkoBSD:*:*) + echo "$UNAME_MACHINE"-unknown-ekkobsd"$UNAME_RELEASE" + exit ;; + *:SolidBSD:*:*) + echo "$UNAME_MACHINE"-unknown-solidbsd"$UNAME_RELEASE" + exit ;; + macppc:MirBSD:*:*) + echo powerpc-unknown-mirbsd"$UNAME_RELEASE" + exit ;; + *:MirBSD:*:*) + echo "$UNAME_MACHINE"-unknown-mirbsd"$UNAME_RELEASE" + exit ;; + *:Sortix:*:*) + echo "$UNAME_MACHINE"-unknown-sortix + exit ;; + *:Redox:*:*) + echo "$UNAME_MACHINE"-unknown-redox + exit ;; + mips:OSF1:*.*) + echo mips-dec-osf1 + exit ;; + alpha:OSF1:*:*) + case $UNAME_RELEASE in + *4.0) + UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'` + ;; + *5.*) + UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'` + ;; + esac + # According to Compaq, /usr/sbin/psrinfo has been available on + # OSF/1 and Tru64 systems produced since 1995. I hope that + # covers most systems running today. This code pipes the CPU + # types through head -n 1, so we only detect the type of CPU 0. + ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1` + case "$ALPHA_CPU_TYPE" in + "EV4 (21064)") + UNAME_MACHINE=alpha ;; + "EV4.5 (21064)") + UNAME_MACHINE=alpha ;; + "LCA4 (21066/21068)") + UNAME_MACHINE=alpha ;; + "EV5 (21164)") + UNAME_MACHINE=alphaev5 ;; + "EV5.6 (21164A)") + UNAME_MACHINE=alphaev56 ;; + "EV5.6 (21164PC)") + UNAME_MACHINE=alphapca56 ;; + "EV5.7 (21164PC)") + UNAME_MACHINE=alphapca57 ;; + "EV6 (21264)") + UNAME_MACHINE=alphaev6 ;; + "EV6.7 (21264A)") + UNAME_MACHINE=alphaev67 ;; + "EV6.8CB (21264C)") + UNAME_MACHINE=alphaev68 ;; + "EV6.8AL (21264B)") + UNAME_MACHINE=alphaev68 ;; + "EV6.8CX (21264D)") + UNAME_MACHINE=alphaev68 ;; + "EV6.9A (21264/EV69A)") + UNAME_MACHINE=alphaev69 ;; + "EV7 (21364)") + UNAME_MACHINE=alphaev7 ;; + "EV7.9 (21364A)") + UNAME_MACHINE=alphaev79 ;; + esac + # A Pn.n version is a patched version. + # A Vn.n version is a released version. + # A Tn.n version is a released field test version. + # A Xn.n version is an unreleased experimental baselevel. + # 1.2 uses "1.2" for uname -r. + echo "$UNAME_MACHINE"-dec-osf"`echo "$UNAME_RELEASE" | sed -e 's/^[PVTX]//' | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz`" + # Reset EXIT trap before exiting to avoid spurious non-zero exit code. + exitcode=$? + trap '' 0 + exit $exitcode ;; + Amiga*:UNIX_System_V:4.0:*) + echo m68k-unknown-sysv4 + exit ;; + *:[Aa]miga[Oo][Ss]:*:*) + echo "$UNAME_MACHINE"-unknown-amigaos + exit ;; + *:[Mm]orph[Oo][Ss]:*:*) + echo "$UNAME_MACHINE"-unknown-morphos + exit ;; + *:OS/390:*:*) + echo i370-ibm-openedition + exit ;; + *:z/VM:*:*) + echo s390-ibm-zvmoe + exit ;; + *:OS400:*:*) + echo powerpc-ibm-os400 + exit ;; + arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*) + echo arm-acorn-riscix"$UNAME_RELEASE" + exit ;; + arm*:riscos:*:*|arm*:RISCOS:*:*) + echo arm-unknown-riscos + exit ;; + SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*) + echo hppa1.1-hitachi-hiuxmpp + exit ;; + Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*) + # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE. + if test "`(/bin/universe) 2>/dev/null`" = att ; then + echo pyramid-pyramid-sysv3 + else + echo pyramid-pyramid-bsd + fi + exit ;; + NILE*:*:*:dcosx) + echo pyramid-pyramid-svr4 + exit ;; + DRS?6000:unix:4.0:6*) + echo sparc-icl-nx6 + exit ;; + DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*) + case `/usr/bin/uname -p` in + sparc) echo sparc-icl-nx7; exit ;; + esac ;; + s390x:SunOS:*:*) + echo "$UNAME_MACHINE"-ibm-solaris2"`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'`" + exit ;; + sun4H:SunOS:5.*:*) + echo sparc-hal-solaris2"`echo "$UNAME_RELEASE"|sed -e 's/[^.]*//'`" + exit ;; + sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*) + echo sparc-sun-solaris2"`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'`" + exit ;; + i86pc:AuroraUX:5.*:* | i86xen:AuroraUX:5.*:*) + echo i386-pc-auroraux"$UNAME_RELEASE" + exit ;; + i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*) + eval "$set_cc_for_build" + SUN_ARCH=i386 + # If there is a compiler, see if it is configured for 64-bit objects. + # Note that the Sun cc does not turn __LP64__ into 1 like gcc does. + # This test works for both compilers. + if [ "$CC_FOR_BUILD" != no_compiler_found ]; then + if (echo '#ifdef __amd64'; echo IS_64BIT_ARCH; echo '#endif') | \ + (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | \ + grep IS_64BIT_ARCH >/dev/null + then + SUN_ARCH=x86_64 + fi + fi + echo "$SUN_ARCH"-pc-solaris2"`echo "$UNAME_RELEASE"|sed -e 's/[^.]*//'`" + exit ;; + sun4*:SunOS:6*:*) + # According to config.sub, this is the proper way to canonicalize + # SunOS6. Hard to guess exactly what SunOS6 will be like, but + # it's likely to be more like Solaris than SunOS4. + echo sparc-sun-solaris3"`echo "$UNAME_RELEASE"|sed -e 's/[^.]*//'`" + exit ;; + sun4*:SunOS:*:*) + case "`/usr/bin/arch -k`" in + Series*|S4*) + UNAME_RELEASE=`uname -v` + ;; + esac + # Japanese Language versions have a version number like `4.1.3-JL'. + echo sparc-sun-sunos"`echo "$UNAME_RELEASE"|sed -e 's/-/_/'`" + exit ;; + sun3*:SunOS:*:*) + echo m68k-sun-sunos"$UNAME_RELEASE" + exit ;; + sun*:*:4.2BSD:*) + UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null` + test "x$UNAME_RELEASE" = x && UNAME_RELEASE=3 + case "`/bin/arch`" in + sun3) + echo m68k-sun-sunos"$UNAME_RELEASE" + ;; + sun4) + echo sparc-sun-sunos"$UNAME_RELEASE" + ;; + esac + exit ;; + aushp:SunOS:*:*) + echo sparc-auspex-sunos"$UNAME_RELEASE" + exit ;; + # The situation for MiNT is a little confusing. The machine name + # can be virtually everything (everything which is not + # "atarist" or "atariste" at least should have a processor + # > m68000). The system name ranges from "MiNT" over "FreeMiNT" + # to the lowercase version "mint" (or "freemint"). Finally + # the system name "TOS" denotes a system which is actually not + # MiNT. But MiNT is downward compatible to TOS, so this should + # be no problem. + atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*) + echo m68k-atari-mint"$UNAME_RELEASE" + exit ;; + atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*) + echo m68k-atari-mint"$UNAME_RELEASE" + exit ;; + *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*) + echo m68k-atari-mint"$UNAME_RELEASE" + exit ;; + milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*) + echo m68k-milan-mint"$UNAME_RELEASE" + exit ;; + hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*) + echo m68k-hades-mint"$UNAME_RELEASE" + exit ;; + *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*) + echo m68k-unknown-mint"$UNAME_RELEASE" + exit ;; + m68k:machten:*:*) + echo m68k-apple-machten"$UNAME_RELEASE" + exit ;; + powerpc:machten:*:*) + echo powerpc-apple-machten"$UNAME_RELEASE" + exit ;; + RISC*:Mach:*:*) + echo mips-dec-mach_bsd4.3 + exit ;; + RISC*:ULTRIX:*:*) + echo mips-dec-ultrix"$UNAME_RELEASE" + exit ;; + VAX*:ULTRIX*:*:*) + echo vax-dec-ultrix"$UNAME_RELEASE" + exit ;; + 2020:CLIX:*:* | 2430:CLIX:*:*) + echo clipper-intergraph-clix"$UNAME_RELEASE" + exit ;; + mips:*:*:UMIPS | mips:*:*:RISCos) + eval "$set_cc_for_build" + sed 's/^ //' << EOF > "$dummy.c" +#ifdef __cplusplus +#include /* for printf() prototype */ + int main (int argc, char *argv[]) { +#else + int main (argc, argv) int argc; char *argv[]; { +#endif + #if defined (host_mips) && defined (MIPSEB) + #if defined (SYSTYPE_SYSV) + printf ("mips-mips-riscos%ssysv\\n", argv[1]); exit (0); + #endif + #if defined (SYSTYPE_SVR4) + printf ("mips-mips-riscos%ssvr4\\n", argv[1]); exit (0); + #endif + #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD) + printf ("mips-mips-riscos%sbsd\\n", argv[1]); exit (0); + #endif + #endif + exit (-1); + } +EOF + $CC_FOR_BUILD -o "$dummy" "$dummy.c" && + dummyarg=`echo "$UNAME_RELEASE" | sed -n 's/\([0-9]*\).*/\1/p'` && + SYSTEM_NAME=`"$dummy" "$dummyarg"` && + { echo "$SYSTEM_NAME"; exit; } + echo mips-mips-riscos"$UNAME_RELEASE" + exit ;; + Motorola:PowerMAX_OS:*:*) + echo powerpc-motorola-powermax + exit ;; + Motorola:*:4.3:PL8-*) + echo powerpc-harris-powermax + exit ;; + Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*) + echo powerpc-harris-powermax + exit ;; + Night_Hawk:Power_UNIX:*:*) + echo powerpc-harris-powerunix + exit ;; + m88k:CX/UX:7*:*) + echo m88k-harris-cxux7 + exit ;; + m88k:*:4*:R4*) + echo m88k-motorola-sysv4 + exit ;; + m88k:*:3*:R3*) + echo m88k-motorola-sysv3 + exit ;; + AViiON:dgux:*:*) + # DG/UX returns AViiON for all architectures + UNAME_PROCESSOR=`/usr/bin/uname -p` + if [ "$UNAME_PROCESSOR" = mc88100 ] || [ "$UNAME_PROCESSOR" = mc88110 ] + then + if [ "$TARGET_BINARY_INTERFACE"x = m88kdguxelfx ] || \ + [ "$TARGET_BINARY_INTERFACE"x = x ] + then + echo m88k-dg-dgux"$UNAME_RELEASE" + else + echo m88k-dg-dguxbcs"$UNAME_RELEASE" + fi + else + echo i586-dg-dgux"$UNAME_RELEASE" + fi + exit ;; + M88*:DolphinOS:*:*) # DolphinOS (SVR3) + echo m88k-dolphin-sysv3 + exit ;; + M88*:*:R3*:*) + # Delta 88k system running SVR3 + echo m88k-motorola-sysv3 + exit ;; + XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3) + echo m88k-tektronix-sysv3 + exit ;; + Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD) + echo m68k-tektronix-bsd + exit ;; + *:IRIX*:*:*) + echo mips-sgi-irix"`echo "$UNAME_RELEASE"|sed -e 's/-/_/g'`" + exit ;; + ????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX. + echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id + exit ;; # Note that: echo "'`uname -s`'" gives 'AIX ' + i*86:AIX:*:*) + echo i386-ibm-aix + exit ;; + ia64:AIX:*:*) + if [ -x /usr/bin/oslevel ] ; then + IBM_REV=`/usr/bin/oslevel` + else + IBM_REV="$UNAME_VERSION.$UNAME_RELEASE" + fi + echo "$UNAME_MACHINE"-ibm-aix"$IBM_REV" + exit ;; + *:AIX:2:3) + if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then + eval "$set_cc_for_build" + sed 's/^ //' << EOF > "$dummy.c" + #include + + main() + { + if (!__power_pc()) + exit(1); + puts("powerpc-ibm-aix3.2.5"); + exit(0); + } +EOF + if $CC_FOR_BUILD -o "$dummy" "$dummy.c" && SYSTEM_NAME=`"$dummy"` + then + echo "$SYSTEM_NAME" + else + echo rs6000-ibm-aix3.2.5 + fi + elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then + echo rs6000-ibm-aix3.2.4 + else + echo rs6000-ibm-aix3.2 + fi + exit ;; + *:AIX:*:[4567]) + IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'` + if /usr/sbin/lsattr -El "$IBM_CPU_ID" | grep ' POWER' >/dev/null 2>&1; then + IBM_ARCH=rs6000 + else + IBM_ARCH=powerpc + fi + if [ -x /usr/bin/lslpp ] ; then + IBM_REV=`/usr/bin/lslpp -Lqc bos.rte.libc | + awk -F: '{ print $3 }' | sed s/[0-9]*$/0/` + else + IBM_REV="$UNAME_VERSION.$UNAME_RELEASE" + fi + echo "$IBM_ARCH"-ibm-aix"$IBM_REV" + exit ;; + *:AIX:*:*) + echo rs6000-ibm-aix + exit ;; + ibmrt:4.4BSD:*|romp-ibm:4.4BSD:*) + echo romp-ibm-bsd4.4 + exit ;; + ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and + echo romp-ibm-bsd"$UNAME_RELEASE" # 4.3 with uname added to + exit ;; # report: romp-ibm BSD 4.3 + *:BOSX:*:*) + echo rs6000-bull-bosx + exit ;; + DPX/2?00:B.O.S.:*:*) + echo m68k-bull-sysv3 + exit ;; + 9000/[34]??:4.3bsd:1.*:*) + echo m68k-hp-bsd + exit ;; + hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*) + echo m68k-hp-bsd4.4 + exit ;; + 9000/[34678]??:HP-UX:*:*) + HPUX_REV=`echo "$UNAME_RELEASE"|sed -e 's/[^.]*.[0B]*//'` + case "$UNAME_MACHINE" in + 9000/31?) HP_ARCH=m68000 ;; + 9000/[34]??) HP_ARCH=m68k ;; + 9000/[678][0-9][0-9]) + if [ -x /usr/bin/getconf ]; then + sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null` + sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null` + case "$sc_cpu_version" in + 523) HP_ARCH=hppa1.0 ;; # CPU_PA_RISC1_0 + 528) HP_ARCH=hppa1.1 ;; # CPU_PA_RISC1_1 + 532) # CPU_PA_RISC2_0 + case "$sc_kernel_bits" in + 32) HP_ARCH=hppa2.0n ;; + 64) HP_ARCH=hppa2.0w ;; + '') HP_ARCH=hppa2.0 ;; # HP-UX 10.20 + esac ;; + esac + fi + if [ "$HP_ARCH" = "" ]; then + eval "$set_cc_for_build" + sed 's/^ //' << EOF > "$dummy.c" + + #define _HPUX_SOURCE + #include + #include + + int main () + { + #if defined(_SC_KERNEL_BITS) + long bits = sysconf(_SC_KERNEL_BITS); + #endif + long cpu = sysconf (_SC_CPU_VERSION); + + switch (cpu) + { + case CPU_PA_RISC1_0: puts ("hppa1.0"); break; + case CPU_PA_RISC1_1: puts ("hppa1.1"); break; + case CPU_PA_RISC2_0: + #if defined(_SC_KERNEL_BITS) + switch (bits) + { + case 64: puts ("hppa2.0w"); break; + case 32: puts ("hppa2.0n"); break; + default: puts ("hppa2.0"); break; + } break; + #else /* !defined(_SC_KERNEL_BITS) */ + puts ("hppa2.0"); break; + #endif + default: puts ("hppa1.0"); break; + } + exit (0); + } +EOF + (CCOPTS="" $CC_FOR_BUILD -o "$dummy" "$dummy.c" 2>/dev/null) && HP_ARCH=`"$dummy"` + test -z "$HP_ARCH" && HP_ARCH=hppa + fi ;; + esac + if [ "$HP_ARCH" = hppa2.0w ] + then + eval "$set_cc_for_build" + + # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating + # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler + # generating 64-bit code. GNU and HP use different nomenclature: + # + # $ CC_FOR_BUILD=cc ./config.guess + # => hppa2.0w-hp-hpux11.23 + # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess + # => hppa64-hp-hpux11.23 + + if echo __LP64__ | (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | + grep -q __LP64__ + then + HP_ARCH=hppa2.0w + else + HP_ARCH=hppa64 + fi + fi + echo "$HP_ARCH"-hp-hpux"$HPUX_REV" + exit ;; + ia64:HP-UX:*:*) + HPUX_REV=`echo "$UNAME_RELEASE"|sed -e 's/[^.]*.[0B]*//'` + echo ia64-hp-hpux"$HPUX_REV" + exit ;; + 3050*:HI-UX:*:*) + eval "$set_cc_for_build" + sed 's/^ //' << EOF > "$dummy.c" + #include + int + main () + { + long cpu = sysconf (_SC_CPU_VERSION); + /* The order matters, because CPU_IS_HP_MC68K erroneously returns + true for CPU_PA_RISC1_0. CPU_IS_PA_RISC returns correct + results, however. */ + if (CPU_IS_PA_RISC (cpu)) + { + switch (cpu) + { + case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break; + case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break; + case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break; + default: puts ("hppa-hitachi-hiuxwe2"); break; + } + } + else if (CPU_IS_HP_MC68K (cpu)) + puts ("m68k-hitachi-hiuxwe2"); + else puts ("unknown-hitachi-hiuxwe2"); + exit (0); + } +EOF + $CC_FOR_BUILD -o "$dummy" "$dummy.c" && SYSTEM_NAME=`"$dummy"` && + { echo "$SYSTEM_NAME"; exit; } + echo unknown-hitachi-hiuxwe2 + exit ;; + 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:*) + echo hppa1.1-hp-bsd + exit ;; + 9000/8??:4.3bsd:*:*) + echo hppa1.0-hp-bsd + exit ;; + *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*) + echo hppa1.0-hp-mpeix + exit ;; + hp7??:OSF1:*:* | hp8?[79]:OSF1:*:*) + echo hppa1.1-hp-osf + exit ;; + hp8??:OSF1:*:*) + echo hppa1.0-hp-osf + exit ;; + i*86:OSF1:*:*) + if [ -x /usr/sbin/sysversion ] ; then + echo "$UNAME_MACHINE"-unknown-osf1mk + else + echo "$UNAME_MACHINE"-unknown-osf1 + fi + exit ;; + parisc*:Lites*:*:*) + echo hppa1.1-hp-lites + exit ;; + C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*) + echo c1-convex-bsd + exit ;; + C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*) + if getsysinfo -f scalar_acc + then echo c32-convex-bsd + else echo c2-convex-bsd + fi + exit ;; + C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*) + echo c34-convex-bsd + exit ;; + C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*) + echo c38-convex-bsd + exit ;; + C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*) + echo c4-convex-bsd + exit ;; + CRAY*Y-MP:*:*:*) + echo ymp-cray-unicos"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*[A-Z]90:*:*:*) + echo "$UNAME_MACHINE"-cray-unicos"$UNAME_RELEASE" \ + | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \ + -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \ + -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*TS:*:*:*) + echo t90-cray-unicos"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*T3E:*:*:*) + echo alphaev5-cray-unicosmk"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/' + exit ;; + CRAY*SV1:*:*:*) + echo sv1-cray-unicos"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/' + exit ;; + *:UNICOS/mp:*:*) + echo craynv-cray-unicosmp"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/' + exit ;; + F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*) + FUJITSU_PROC=`uname -m | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz` + FUJITSU_SYS=`uname -p | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/\///'` + FUJITSU_REL=`echo "$UNAME_RELEASE" | sed -e 's/ /_/'` + echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" + exit ;; + 5000:UNIX_System_V:4.*:*) + FUJITSU_SYS=`uname -p | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/\///'` + FUJITSU_REL=`echo "$UNAME_RELEASE" | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/ /_/'` + echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}" + exit ;; + i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*) + echo "$UNAME_MACHINE"-pc-bsdi"$UNAME_RELEASE" + exit ;; + sparc*:BSD/OS:*:*) + echo sparc-unknown-bsdi"$UNAME_RELEASE" + exit ;; + *:BSD/OS:*:*) + echo "$UNAME_MACHINE"-unknown-bsdi"$UNAME_RELEASE" + exit ;; + *:FreeBSD:*:*) + UNAME_PROCESSOR=`/usr/bin/uname -p` + case "$UNAME_PROCESSOR" in + amd64) + UNAME_PROCESSOR=x86_64 ;; + i386) + UNAME_PROCESSOR=i586 ;; + esac + echo "$UNAME_PROCESSOR"-unknown-freebsd"`echo "$UNAME_RELEASE"|sed -e 's/[-(].*//'`" + exit ;; + i*:CYGWIN*:*) + echo "$UNAME_MACHINE"-pc-cygwin + exit ;; + *:MINGW64*:*) + echo "$UNAME_MACHINE"-pc-mingw64 + exit ;; + *:MINGW*:*) + echo "$UNAME_MACHINE"-pc-mingw32 + exit ;; + *:MSYS*:*) + echo "$UNAME_MACHINE"-pc-msys + exit ;; + i*:PW*:*) + echo "$UNAME_MACHINE"-pc-pw32 + exit ;; + *:Interix*:*) + case "$UNAME_MACHINE" in + x86) + echo i586-pc-interix"$UNAME_RELEASE" + exit ;; + authenticamd | genuineintel | EM64T) + echo x86_64-unknown-interix"$UNAME_RELEASE" + exit ;; + IA64) + echo ia64-unknown-interix"$UNAME_RELEASE" + exit ;; + esac ;; + i*:UWIN*:*) + echo "$UNAME_MACHINE"-pc-uwin + exit ;; + amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*) + echo x86_64-unknown-cygwin + exit ;; + prep*:SunOS:5.*:*) + echo powerpcle-unknown-solaris2"`echo "$UNAME_RELEASE"|sed -e 's/[^.]*//'`" + exit ;; + *:GNU:*:*) + # the GNU system + echo "`echo "$UNAME_MACHINE"|sed -e 's,[-/].*$,,'`-unknown-$LIBC`echo "$UNAME_RELEASE"|sed -e 's,/.*$,,'`" + exit ;; + *:GNU/*:*:*) + # other systems with GNU libc and userland + echo "$UNAME_MACHINE-unknown-`echo "$UNAME_SYSTEM" | sed 's,^[^/]*/,,' | tr "[:upper:]" "[:lower:]"``echo "$UNAME_RELEASE"|sed -e 's/[-(].*//'`-$LIBC" + exit ;; + i*86:Minix:*:*) + echo "$UNAME_MACHINE"-pc-minix + exit ;; + aarch64:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + aarch64_be:Linux:*:*) + UNAME_MACHINE=aarch64_be + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + alpha:Linux:*:*) + case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in + EV5) UNAME_MACHINE=alphaev5 ;; + EV56) UNAME_MACHINE=alphaev56 ;; + PCA56) UNAME_MACHINE=alphapca56 ;; + PCA57) UNAME_MACHINE=alphapca56 ;; + EV6) UNAME_MACHINE=alphaev6 ;; + EV67) UNAME_MACHINE=alphaev67 ;; + EV68*) UNAME_MACHINE=alphaev68 ;; + esac + objdump --private-headers /bin/sh | grep -q ld.so.1 + if test "$?" = 0 ; then LIBC=gnulibc1 ; fi + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + arc:Linux:*:* | arceb:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + arm*:Linux:*:*) + eval "$set_cc_for_build" + if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \ + | grep -q __ARM_EABI__ + then + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + else + if echo __ARM_PCS_VFP | $CC_FOR_BUILD -E - 2>/dev/null \ + | grep -q __ARM_PCS_VFP + then + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"eabi + else + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"eabihf + fi + fi + exit ;; + avr32*:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + cris:Linux:*:*) + echo "$UNAME_MACHINE"-axis-linux-"$LIBC" + exit ;; + crisv32:Linux:*:*) + echo "$UNAME_MACHINE"-axis-linux-"$LIBC" + exit ;; + e2k:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + frv:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + hexagon:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + i*86:Linux:*:*) + echo "$UNAME_MACHINE"-pc-linux-"$LIBC" + exit ;; + ia64:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + k1om:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + m32r*:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + m68*:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + mips:Linux:*:* | mips64:Linux:*:*) + eval "$set_cc_for_build" + sed 's/^ //' << EOF > "$dummy.c" + #undef CPU + #undef ${UNAME_MACHINE} + #undef ${UNAME_MACHINE}el + #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) + CPU=${UNAME_MACHINE}el + #else + #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) + CPU=${UNAME_MACHINE} + #else + CPU= + #endif + #endif +EOF + eval "`$CC_FOR_BUILD -E "$dummy.c" 2>/dev/null | grep '^CPU'`" + test "x$CPU" != x && { echo "$CPU-unknown-linux-$LIBC"; exit; } + ;; + mips64el:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + openrisc*:Linux:*:*) + echo or1k-unknown-linux-"$LIBC" + exit ;; + or32:Linux:*:* | or1k*:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + padre:Linux:*:*) + echo sparc-unknown-linux-"$LIBC" + exit ;; + parisc64:Linux:*:* | hppa64:Linux:*:*) + echo hppa64-unknown-linux-"$LIBC" + exit ;; + parisc:Linux:*:* | hppa:Linux:*:*) + # Look for CPU level + case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in + PA7*) echo hppa1.1-unknown-linux-"$LIBC" ;; + PA8*) echo hppa2.0-unknown-linux-"$LIBC" ;; + *) echo hppa-unknown-linux-"$LIBC" ;; + esac + exit ;; + ppc64:Linux:*:*) + echo powerpc64-unknown-linux-"$LIBC" + exit ;; + ppc:Linux:*:*) + echo powerpc-unknown-linux-"$LIBC" + exit ;; + ppc64le:Linux:*:*) + echo powerpc64le-unknown-linux-"$LIBC" + exit ;; + ppcle:Linux:*:*) + echo powerpcle-unknown-linux-"$LIBC" + exit ;; + riscv32:Linux:*:* | riscv64:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + s390:Linux:*:* | s390x:Linux:*:*) + echo "$UNAME_MACHINE"-ibm-linux-"$LIBC" + exit ;; + sh64*:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + sh*:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + sparc:Linux:*:* | sparc64:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + tile*:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + vax:Linux:*:*) + echo "$UNAME_MACHINE"-dec-linux-"$LIBC" + exit ;; + x86_64:Linux:*:*) + echo "$UNAME_MACHINE"-pc-linux-"$LIBC" + exit ;; + xtensa*:Linux:*:*) + echo "$UNAME_MACHINE"-unknown-linux-"$LIBC" + exit ;; + i*86:DYNIX/ptx:4*:*) + # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. + # earlier versions are messed up and put the nodename in both + # sysname and nodename. + echo i386-sequent-sysv4 + exit ;; + i*86:UNIX_SV:4.2MP:2.*) + # Unixware is an offshoot of SVR4, but it has its own version + # number series starting with 2... + # I am not positive that other SVR4 systems won't match this, + # I just have to hope. -- rms. + # Use sysv4.2uw... so that sysv4* matches it. + echo "$UNAME_MACHINE"-pc-sysv4.2uw"$UNAME_VERSION" + exit ;; + i*86:OS/2:*:*) + # If we were able to find `uname', then EMX Unix compatibility + # is probably installed. + echo "$UNAME_MACHINE"-pc-os2-emx + exit ;; + i*86:XTS-300:*:STOP) + echo "$UNAME_MACHINE"-unknown-stop + exit ;; + i*86:atheos:*:*) + echo "$UNAME_MACHINE"-unknown-atheos + exit ;; + i*86:syllable:*:*) + echo "$UNAME_MACHINE"-pc-syllable + exit ;; + i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*) + echo i386-unknown-lynxos"$UNAME_RELEASE" + exit ;; + i*86:*DOS:*:*) + echo "$UNAME_MACHINE"-pc-msdosdjgpp + exit ;; + i*86:*:4.*:*) + UNAME_REL=`echo "$UNAME_RELEASE" | sed 's/\/MP$//'` + if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then + echo "$UNAME_MACHINE"-univel-sysv"$UNAME_REL" + else + echo "$UNAME_MACHINE"-pc-sysv"$UNAME_REL" + fi + exit ;; + i*86:*:5:[678]*) + # UnixWare 7.x, OpenUNIX and OpenServer 6. + case `/bin/uname -X | grep "^Machine"` in + *486*) UNAME_MACHINE=i486 ;; + *Pentium) UNAME_MACHINE=i586 ;; + *Pent*|*Celeron) UNAME_MACHINE=i686 ;; + esac + echo "$UNAME_MACHINE-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}{$UNAME_VERSION}" + exit ;; + i*86:*:3.2:*) + if test -f /usr/options/cb.name; then + UNAME_REL=`sed -n 's/.*Version //p' /dev/null >/dev/null ; then + UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')` + (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486 + (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \ + && UNAME_MACHINE=i586 + (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \ + && UNAME_MACHINE=i686 + (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \ + && UNAME_MACHINE=i686 + echo "$UNAME_MACHINE"-pc-sco"$UNAME_REL" + else + echo "$UNAME_MACHINE"-pc-sysv32 + fi + exit ;; + pc:*:*:*) + # Left here for compatibility: + # uname -m prints for DJGPP always 'pc', but it prints nothing about + # the processor, so we play safe by assuming i586. + # Note: whatever this is, it MUST be the same as what config.sub + # prints for the "djgpp" host, or else GDB configure will decide that + # this is a cross-build. + echo i586-pc-msdosdjgpp + exit ;; + Intel:Mach:3*:*) + echo i386-pc-mach3 + exit ;; + paragon:*:*:*) + echo i860-intel-osf1 + exit ;; + i860:*:4.*:*) # i860-SVR4 + if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then + echo i860-stardent-sysv"$UNAME_RELEASE" # Stardent Vistra i860-SVR4 + else # Add other i860-SVR4 vendors below as they are discovered. + echo i860-unknown-sysv"$UNAME_RELEASE" # Unknown i860-SVR4 + fi + exit ;; + mini*:CTIX:SYS*5:*) + # "miniframe" + echo m68010-convergent-sysv + exit ;; + mc68k:UNIX:SYSTEM5:3.51m) + echo m68k-convergent-sysv + exit ;; + M680?0:D-NIX:5.3:*) + echo m68k-diab-dnix + exit ;; + M68*:*:R3V[5678]*:*) + test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;; + 3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0) + OS_REL='' + test -r /etc/.relid \ + && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` + /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ + && { echo i486-ncr-sysv4.3"$OS_REL"; exit; } + /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ + && { echo i586-ncr-sysv4.3"$OS_REL"; exit; } ;; + 3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*) + /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ + && { echo i486-ncr-sysv4; exit; } ;; + NCR*:*:4.2:* | MPRAS*:*:4.2:*) + OS_REL='.3' + test -r /etc/.relid \ + && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` + /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ + && { echo i486-ncr-sysv4.3"$OS_REL"; exit; } + /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ + && { echo i586-ncr-sysv4.3"$OS_REL"; exit; } + /bin/uname -p 2>/dev/null | /bin/grep pteron >/dev/null \ + && { echo i586-ncr-sysv4.3"$OS_REL"; exit; } ;; + m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*) + echo m68k-unknown-lynxos"$UNAME_RELEASE" + exit ;; + mc68030:UNIX_System_V:4.*:*) + echo m68k-atari-sysv4 + exit ;; + TSUNAMI:LynxOS:2.*:*) + echo sparc-unknown-lynxos"$UNAME_RELEASE" + exit ;; + rs6000:LynxOS:2.*:*) + echo rs6000-unknown-lynxos"$UNAME_RELEASE" + exit ;; + PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.[02]*:*) + echo powerpc-unknown-lynxos"$UNAME_RELEASE" + exit ;; + SM[BE]S:UNIX_SV:*:*) + echo mips-dde-sysv"$UNAME_RELEASE" + exit ;; + RM*:ReliantUNIX-*:*:*) + echo mips-sni-sysv4 + exit ;; + RM*:SINIX-*:*:*) + echo mips-sni-sysv4 + exit ;; + *:SINIX-*:*:*) + if uname -p 2>/dev/null >/dev/null ; then + UNAME_MACHINE=`(uname -p) 2>/dev/null` + echo "$UNAME_MACHINE"-sni-sysv4 + else + echo ns32k-sni-sysv + fi + exit ;; + PENTIUM:*:4.0*:*) # Unisys `ClearPath HMP IX 4000' SVR4/MP effort + # says + echo i586-unisys-sysv4 + exit ;; + *:UNIX_System_V:4*:FTX*) + # From Gerald Hewes . + # How about differentiating between stratus architectures? -djm + echo hppa1.1-stratus-sysv4 + exit ;; + *:*:*:FTX*) + # From seanf@swdc.stratus.com. + echo i860-stratus-sysv4 + exit ;; + i*86:VOS:*:*) + # From Paul.Green@stratus.com. + echo "$UNAME_MACHINE"-stratus-vos + exit ;; + *:VOS:*:*) + # From Paul.Green@stratus.com. + echo hppa1.1-stratus-vos + exit ;; + mc68*:A/UX:*:*) + echo m68k-apple-aux"$UNAME_RELEASE" + exit ;; + news*:NEWS-OS:6*:*) + echo mips-sony-newsos6 + exit ;; + R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*) + if [ -d /usr/nec ]; then + echo mips-nec-sysv"$UNAME_RELEASE" + else + echo mips-unknown-sysv"$UNAME_RELEASE" + fi + exit ;; + BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only. + echo powerpc-be-beos + exit ;; + BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only. + echo powerpc-apple-beos + exit ;; + BePC:BeOS:*:*) # BeOS running on Intel PC compatible. + echo i586-pc-beos + exit ;; + BePC:Haiku:*:*) # Haiku running on Intel PC compatible. + echo i586-pc-haiku + exit ;; + x86_64:Haiku:*:*) + echo x86_64-unknown-haiku + exit ;; + SX-4:SUPER-UX:*:*) + echo sx4-nec-superux"$UNAME_RELEASE" + exit ;; + SX-5:SUPER-UX:*:*) + echo sx5-nec-superux"$UNAME_RELEASE" + exit ;; + SX-6:SUPER-UX:*:*) + echo sx6-nec-superux"$UNAME_RELEASE" + exit ;; + SX-7:SUPER-UX:*:*) + echo sx7-nec-superux"$UNAME_RELEASE" + exit ;; + SX-8:SUPER-UX:*:*) + echo sx8-nec-superux"$UNAME_RELEASE" + exit ;; + SX-8R:SUPER-UX:*:*) + echo sx8r-nec-superux"$UNAME_RELEASE" + exit ;; + SX-ACE:SUPER-UX:*:*) + echo sxace-nec-superux"$UNAME_RELEASE" + exit ;; + Power*:Rhapsody:*:*) + echo powerpc-apple-rhapsody"$UNAME_RELEASE" + exit ;; + *:Rhapsody:*:*) + echo "$UNAME_MACHINE"-apple-rhapsody"$UNAME_RELEASE" + exit ;; + *:Darwin:*:*) + UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown + eval "$set_cc_for_build" + if test "$UNAME_PROCESSOR" = unknown ; then + UNAME_PROCESSOR=powerpc + fi + if test "`echo "$UNAME_RELEASE" | sed -e 's/\..*//'`" -le 10 ; then + if [ "$CC_FOR_BUILD" != no_compiler_found ]; then + if (echo '#ifdef __LP64__'; echo IS_64BIT_ARCH; echo '#endif') | \ + (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | \ + grep IS_64BIT_ARCH >/dev/null + then + case $UNAME_PROCESSOR in + i386) UNAME_PROCESSOR=x86_64 ;; + powerpc) UNAME_PROCESSOR=powerpc64 ;; + esac + fi + # On 10.4-10.6 one might compile for PowerPC via gcc -arch ppc + if (echo '#ifdef __POWERPC__'; echo IS_PPC; echo '#endif') | \ + (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | \ + grep IS_PPC >/dev/null + then + UNAME_PROCESSOR=powerpc + fi + fi + elif test "$UNAME_PROCESSOR" = i386 ; then + # Avoid executing cc on OS X 10.9, as it ships with a stub + # that puts up a graphical alert prompting to install + # developer tools. Any system running Mac OS X 10.7 or + # later (Darwin 11 and later) is required to have a 64-bit + # processor. This is not true of the ARM version of Darwin + # that Apple uses in portable devices. + UNAME_PROCESSOR=x86_64 + fi + echo "$UNAME_PROCESSOR"-apple-darwin"$UNAME_RELEASE" + exit ;; + *:procnto*:*:* | *:QNX:[0123456789]*:*) + UNAME_PROCESSOR=`uname -p` + if test "$UNAME_PROCESSOR" = x86; then + UNAME_PROCESSOR=i386 + UNAME_MACHINE=pc + fi + echo "$UNAME_PROCESSOR"-"$UNAME_MACHINE"-nto-qnx"$UNAME_RELEASE" + exit ;; + *:QNX:*:4*) + echo i386-pc-qnx + exit ;; + NEO-*:NONSTOP_KERNEL:*:*) + echo neo-tandem-nsk"$UNAME_RELEASE" + exit ;; + NSE-*:NONSTOP_KERNEL:*:*) + echo nse-tandem-nsk"$UNAME_RELEASE" + exit ;; + NSR-*:NONSTOP_KERNEL:*:*) + echo nsr-tandem-nsk"$UNAME_RELEASE" + exit ;; + NSV-*:NONSTOP_KERNEL:*:*) + echo nsv-tandem-nsk"$UNAME_RELEASE" + exit ;; + NSX-*:NONSTOP_KERNEL:*:*) + echo nsx-tandem-nsk"$UNAME_RELEASE" + exit ;; + *:NonStop-UX:*:*) + echo mips-compaq-nonstopux + exit ;; + BS2000:POSIX*:*:*) + echo bs2000-siemens-sysv + exit ;; + DS/*:UNIX_System_V:*:*) + echo "$UNAME_MACHINE"-"$UNAME_SYSTEM"-"$UNAME_RELEASE" + exit ;; + *:Plan9:*:*) + # "uname -m" is not consistent, so use $cputype instead. 386 + # is converted to i386 for consistency with other x86 + # operating systems. + if test "$cputype" = 386; then + UNAME_MACHINE=i386 + else + UNAME_MACHINE="$cputype" + fi + echo "$UNAME_MACHINE"-unknown-plan9 + exit ;; + *:TOPS-10:*:*) + echo pdp10-unknown-tops10 + exit ;; + *:TENEX:*:*) + echo pdp10-unknown-tenex + exit ;; + KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*) + echo pdp10-dec-tops20 + exit ;; + XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*) + echo pdp10-xkl-tops20 + exit ;; + *:TOPS-20:*:*) + echo pdp10-unknown-tops20 + exit ;; + *:ITS:*:*) + echo pdp10-unknown-its + exit ;; + SEI:*:*:SEIUX) + echo mips-sei-seiux"$UNAME_RELEASE" + exit ;; + *:DragonFly:*:*) + echo "$UNAME_MACHINE"-unknown-dragonfly"`echo "$UNAME_RELEASE"|sed -e 's/[-(].*//'`" + exit ;; + *:*VMS:*:*) + UNAME_MACHINE=`(uname -p) 2>/dev/null` + case "$UNAME_MACHINE" in + A*) echo alpha-dec-vms ; exit ;; + I*) echo ia64-dec-vms ; exit ;; + V*) echo vax-dec-vms ; exit ;; + esac ;; + *:XENIX:*:SysV) + echo i386-pc-xenix + exit ;; + i*86:skyos:*:*) + echo "$UNAME_MACHINE"-pc-skyos"`echo "$UNAME_RELEASE" | sed -e 's/ .*$//'`" + exit ;; + i*86:rdos:*:*) + echo "$UNAME_MACHINE"-pc-rdos + exit ;; + i*86:AROS:*:*) + echo "$UNAME_MACHINE"-pc-aros + exit ;; + x86_64:VMkernel:*:*) + echo "$UNAME_MACHINE"-unknown-esx + exit ;; + amd64:Isilon\ OneFS:*:*) + echo x86_64-unknown-onefs + exit ;; +esac + +echo "$0: unable to guess system type" >&2 + +case "$UNAME_MACHINE:$UNAME_SYSTEM" in + mips:Linux | mips64:Linux) + # If we got here on MIPS GNU/Linux, output extra information. + cat >&2 <&2 </dev/null || echo unknown` +uname -r = `(uname -r) 2>/dev/null || echo unknown` +uname -s = `(uname -s) 2>/dev/null || echo unknown` +uname -v = `(uname -v) 2>/dev/null || echo unknown` + +/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null` +/bin/uname -X = `(/bin/uname -X) 2>/dev/null` + +hostinfo = `(hostinfo) 2>/dev/null` +/bin/universe = `(/bin/universe) 2>/dev/null` +/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null` +/bin/arch = `(/bin/arch) 2>/dev/null` +/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null` +/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null` + +UNAME_MACHINE = "$UNAME_MACHINE" +UNAME_RELEASE = "$UNAME_RELEASE" +UNAME_SYSTEM = "$UNAME_SYSTEM" +UNAME_VERSION = "$UNAME_VERSION" +EOF + +exit 1 + +# Local variables: +# eval: (add-hook 'before-save-hook 'time-stamp) +# time-stamp-start: "timestamp='" +# time-stamp-format: "%:y-%02m-%02d" +# time-stamp-end: "'" +# End: diff --git a/TMessagesProj/jni/libtgvoip2/config.h.in b/TMessagesProj/jni/libtgvoip2/config.h.in new file mode 100644 index 000000000..9499995fa --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/config.h.in @@ -0,0 +1,265 @@ +/* config.h.in. Generated from configure.ac by autoheader. */ + +/* Define to one of `_getb67', `GETB67', `getb67' for Cray-2 and Cray-YMP + systems. This function is required for `alloca.c' support on those systems. + */ +#undef CRAY_STACKSEG_END + +/* Define to 1 if using `alloca.c'. */ +#undef C_ALLOCA + +/* Define to 1 if you have `alloca', as a function or macro. */ +#undef HAVE_ALLOCA + +/* Define to 1 if you have and it should be used (not on Ultrix). + */ +#undef HAVE_ALLOCA_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_ARPA_INET_H + +/* Define to 1 if you have the `clock_gettime' function. */ +#undef HAVE_CLOCK_GETTIME + +/* Define to 1 if you have the header file. */ +#undef HAVE_DLFCN_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_FLOAT_H + +/* Define to 1 if you have the `floor' function. */ +#undef HAVE_FLOOR + +/* Define to 1 if you have the `gettimeofday' function. */ +#undef HAVE_GETTIMEOFDAY + +/* Define to 1 if you have the `inet_ntoa' function. */ +#undef HAVE_INET_NTOA + +/* Define to 1 if you have the header file. */ +#undef HAVE_INTTYPES_H + +/* Define to 1 if you have the `crypto' library (-lcrypto). */ +#undef HAVE_LIBCRYPTO + +/* Define to 1 if you have the `dl' library (-ldl). */ +#undef HAVE_LIBDL + +/* Define to 1 if you have the `m' library (-lm). */ +#undef HAVE_LIBM + +/* Define to 1 if you have the `opus' library (-lopus). */ +#undef HAVE_LIBOPUS + +/* Define to 1 if you have the `pthread' library (-lpthread). */ +#undef HAVE_LIBPTHREAD + +/* Define to 1 if your system has a GNU libc compatible `malloc' function, and + to 0 otherwise. */ +#undef HAVE_MALLOC + +/* Define to 1 if you have the header file. */ +#undef HAVE_MALLOC_H + +/* Define to 1 if you have the `memmove' function. */ +#undef HAVE_MEMMOVE + +/* Define to 1 if you have the header file. */ +#undef HAVE_MEMORY_H + +/* Define to 1 if you have the `memset' function. */ +#undef HAVE_MEMSET + +/* Define to 1 if you have the header file. */ +#undef HAVE_NETDB_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_NETINET_IN_H + +/* Define to 1 if the system has the type `ptrdiff_t'. */ +#undef HAVE_PTRDIFF_T + +/* Define to 1 if your system has a GNU libc compatible `realloc' function, + and to 0 otherwise. */ +#undef HAVE_REALLOC + +/* Define to 1 if you have the `select' function. */ +#undef HAVE_SELECT + +/* Define to 1 if you have the `socket' function. */ +#undef HAVE_SOCKET + +/* Define to 1 if you have the `sqrt' function. */ +#undef HAVE_SQRT + +/* Define to 1 if you have the header file. */ +#undef HAVE_STDDEF_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_STDINT_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_STDLIB_H + +/* Define to 1 if you have the `strcasecmp' function. */ +#undef HAVE_STRCASECMP + +/* Define to 1 if you have the `strchr' function. */ +#undef HAVE_STRCHR + +/* Define to 1 if you have the `strerror' function. */ +#undef HAVE_STRERROR + +/* Define to 1 if you have the header file. */ +#undef HAVE_STRINGS_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_STRING_H + +/* Define to 1 if you have the `strncasecmp' function. */ +#undef HAVE_STRNCASECMP + +/* Define to 1 if you have the `strstr' function. */ +#undef HAVE_STRSTR + +/* Define to 1 if you have the `strtol' function. */ +#undef HAVE_STRTOL + +/* Define to 1 if you have the `strtoul' function. */ +#undef HAVE_STRTOUL + +/* Define to 1 if you have the header file. */ +#undef HAVE_SYS_IOCTL_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_SYS_SOCKET_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_SYS_STAT_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_SYS_TIME_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_SYS_TYPES_H + +/* Define to 1 if you have the `uname' function. */ +#undef HAVE_UNAME + +/* Define to 1 if you have the header file. */ +#undef HAVE_UNISTD_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_WCHAR_H + +/* Define to 1 if the system has the type `_Bool'. */ +#undef HAVE__BOOL + +/* Define to the sub-directory where libtool stores uninstalled libraries. */ +#undef LT_OBJDIR + +/* Name of package */ +#undef PACKAGE + +/* Define to the address where bug reports for this package should be sent. */ +#undef PACKAGE_BUGREPORT + +/* Define to the full name of this package. */ +#undef PACKAGE_NAME + +/* Define to the full name and version of this package. */ +#undef PACKAGE_STRING + +/* Define to the one symbol short name of this package. */ +#undef PACKAGE_TARNAME + +/* Define to the home page for this package. */ +#undef PACKAGE_URL + +/* Define to the version of this package. */ +#undef PACKAGE_VERSION + +/* If using the C implementation of alloca, define if you know the + direction of stack growth for your system; otherwise it will be + automatically deduced at runtime. + STACK_DIRECTION > 0 => grows toward higher addresses + STACK_DIRECTION < 0 => grows toward lower addresses + STACK_DIRECTION = 0 => direction of growth unknown */ +#undef STACK_DIRECTION + +/* Define to 1 if you have the ANSI C header files. */ +#undef STDC_HEADERS + +/* Version number of package */ +#undef VERSION + +/* Define to disable ALSA support */ +#undef WITHOUT_ALSA + +/* Define to disable PulseAudio support */ +#undef WITHOUT_PULSE + +/* Define for Solaris 2.5.1 so the uint32_t typedef from , + , or is not used. If the typedef were allowed, the + #define below would cause a syntax error. */ +#undef _UINT32_T + +/* Define for Solaris 2.5.1 so the uint64_t typedef from , + , or is not used. If the typedef were allowed, the + #define below would cause a syntax error. */ +#undef _UINT64_T + +/* Define for Solaris 2.5.1 so the uint8_t typedef from , + , or is not used. If the typedef were allowed, the + #define below would cause a syntax error. */ +#undef _UINT8_T + +/* Define to `__inline__' or `__inline' if that's what the C compiler + calls it, or to nothing if 'inline' is not supported under any name. */ +#ifndef __cplusplus +#undef inline +#endif + +/* Define to the type of a signed integer type of width exactly 16 bits if + such a type exists and the standard includes do not define it. */ +#undef int16_t + +/* Define to the type of a signed integer type of width exactly 32 bits if + such a type exists and the standard includes do not define it. */ +#undef int32_t + +/* Define to the type of a signed integer type of width exactly 64 bits if + such a type exists and the standard includes do not define it. */ +#undef int64_t + +/* Define to the type of a signed integer type of width exactly 8 bits if such + a type exists and the standard includes do not define it. */ +#undef int8_t + +/* Define to rpl_malloc if the replacement function should be used. */ +#undef malloc + +/* Define to rpl_realloc if the replacement function should be used. */ +#undef realloc + +/* Define to `unsigned int' if does not define. */ +#undef size_t + +/* Define to `int' if does not define. */ +#undef ssize_t + +/* Define to the type of an unsigned integer type of width exactly 16 bits if + such a type exists and the standard includes do not define it. */ +#undef uint16_t + +/* Define to the type of an unsigned integer type of width exactly 32 bits if + such a type exists and the standard includes do not define it. */ +#undef uint32_t + +/* Define to the type of an unsigned integer type of width exactly 64 bits if + such a type exists and the standard includes do not define it. */ +#undef uint64_t + +/* Define to the type of an unsigned integer type of width exactly 8 bits if + such a type exists and the standard includes do not define it. */ +#undef uint8_t diff --git a/TMessagesProj/jni/libtgvoip2/config.sub b/TMessagesProj/jni/libtgvoip2/config.sub new file mode 100644 index 000000000..9ccf09a7a --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/config.sub @@ -0,0 +1,1801 @@ +#! /bin/sh +# Configuration validation subroutine script. +# Copyright 1992-2018 Free Software Foundation, Inc. + +timestamp='2018-03-08' + +# This file 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. +# +# This program 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 this program; if not, see . +# +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that +# program. This Exception is an additional permission under section 7 +# of the GNU General Public License, version 3 ("GPLv3"). + + +# Please send patches to . +# +# Configuration subroutine to validate and canonicalize a configuration type. +# Supply the specified configuration type as an argument. +# If it is invalid, we print an error message on stderr and exit with code 1. +# Otherwise, we print the canonical config type on stdout and succeed. + +# You can get the latest version of this script from: +# https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub + +# This file is supposed to be the same for all GNU packages +# and recognize all the CPU types, system types and aliases +# that are meaningful with *any* GNU software. +# Each package is responsible for reporting which valid configurations +# it does not support. The user should be able to distinguish +# a failure to support a valid configuration from a meaningless +# configuration. + +# The goal of this file is to map all the various variations of a given +# machine specification into a single specification in the form: +# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM +# or in some cases, the newer four-part form: +# CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM +# It is wrong to echo any other type of specification. + +me=`echo "$0" | sed -e 's,.*/,,'` + +usage="\ +Usage: $0 [OPTION] CPU-MFR-OPSYS or ALIAS + +Canonicalize a configuration name. + +Options: + -h, --help print this help, then exit + -t, --time-stamp print date of last modification, then exit + -v, --version print version number, then exit + +Report bugs and patches to ." + +version="\ +GNU config.sub ($timestamp) + +Copyright 1992-2018 Free Software Foundation, Inc. + +This is free software; see the source for copying conditions. There is NO +warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." + +help=" +Try \`$me --help' for more information." + +# Parse command line +while test $# -gt 0 ; do + case $1 in + --time-stamp | --time* | -t ) + echo "$timestamp" ; exit ;; + --version | -v ) + echo "$version" ; exit ;; + --help | --h* | -h ) + echo "$usage"; exit ;; + -- ) # Stop option processing + shift; break ;; + - ) # Use stdin as input. + break ;; + -* ) + echo "$me: invalid option $1$help" + exit 1 ;; + + *local*) + # First pass through any local machine types. + echo "$1" + exit ;; + + * ) + break ;; + esac +done + +case $# in + 0) echo "$me: missing argument$help" >&2 + exit 1;; + 1) ;; + *) echo "$me: too many arguments$help" >&2 + exit 1;; +esac + +# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any). +# Here we must recognize all the valid KERNEL-OS combinations. +maybe_os=`echo "$1" | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'` +case $maybe_os in + nto-qnx* | linux-gnu* | linux-android* | linux-dietlibc | linux-newlib* | \ + linux-musl* | linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | \ + knetbsd*-gnu* | netbsd*-gnu* | netbsd*-eabi* | \ + kopensolaris*-gnu* | cloudabi*-eabi* | \ + storm-chaos* | os2-emx* | rtmk-nova*) + os=-$maybe_os + basic_machine=`echo "$1" | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'` + ;; + android-linux) + os=-linux-android + basic_machine=`echo "$1" | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`-unknown + ;; + *) + basic_machine=`echo "$1" | sed 's/-[^-]*$//'` + if [ "$basic_machine" != "$1" ] + then os=`echo "$1" | sed 's/.*-/-/'` + else os=; fi + ;; +esac + +### Let's recognize common machines as not being operating systems so +### that things like config.sub decstation-3100 work. We also +### recognize some manufacturers as not being operating systems, so we +### can provide default operating systems below. +case $os in + -sun*os*) + # Prevent following clause from handling this invalid input. + ;; + -dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \ + -att* | -7300* | -3300* | -delta* | -motorola* | -sun[234]* | \ + -unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \ + -convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\ + -c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \ + -harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \ + -apple | -axis | -knuth | -cray | -microblaze*) + os= + basic_machine=$1 + ;; + -bluegene*) + os=-cnk + ;; + -sim | -cisco | -oki | -wec | -winbond) + os= + basic_machine=$1 + ;; + -scout) + ;; + -wrs) + os=-vxworks + basic_machine=$1 + ;; + -chorusos*) + os=-chorusos + basic_machine=$1 + ;; + -chorusrdb) + os=-chorusrdb + basic_machine=$1 + ;; + -hiux*) + os=-hiuxwe2 + ;; + -sco6) + os=-sco5v6 + basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + ;; + -sco5) + os=-sco3.2v5 + basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + ;; + -sco4) + os=-sco3.2v4 + basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + ;; + -sco3.2.[4-9]*) + os=`echo $os | sed -e 's/sco3.2./sco3.2v/'` + basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + ;; + -sco3.2v[4-9]*) + # Don't forget version if it is 3.2v4 or newer. + basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + ;; + -sco5v6*) + # Don't forget version if it is 3.2v4 or newer. + basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + ;; + -sco*) + os=-sco3.2v2 + basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + ;; + -udk*) + basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + ;; + -isc) + os=-isc2.2 + basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + ;; + -clix*) + basic_machine=clipper-intergraph + ;; + -isc*) + basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'` + ;; + -lynx*178) + os=-lynxos178 + ;; + -lynx*5) + os=-lynxos5 + ;; + -lynx*) + os=-lynxos + ;; + -ptx*) + basic_machine=`echo "$1" | sed -e 's/86-.*/86-sequent/'` + ;; + -psos*) + os=-psos + ;; + -mint | -mint[0-9]*) + basic_machine=m68k-atari + os=-mint + ;; +esac + +# Decode aliases for certain CPU-COMPANY combinations. +case $basic_machine in + # Recognize the basic CPU types without company name. + # Some are omitted here because they have special meanings below. + 1750a | 580 \ + | a29k \ + | aarch64 | aarch64_be \ + | alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \ + | alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \ + | am33_2.0 \ + | arc | arceb \ + | arm | arm[bl]e | arme[lb] | armv[2-8] | armv[3-8][lb] | armv7[arm] \ + | avr | avr32 \ + | ba \ + | be32 | be64 \ + | bfin \ + | c4x | c8051 | clipper \ + | d10v | d30v | dlx | dsp16xx \ + | e2k | epiphany \ + | fido | fr30 | frv | ft32 \ + | h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \ + | hexagon \ + | i370 | i860 | i960 | ia16 | ia64 \ + | ip2k | iq2000 \ + | k1om \ + | le32 | le64 \ + | lm32 \ + | m32c | m32r | m32rle | m68000 | m68k | m88k \ + | maxq | mb | microblaze | microblazeel | mcore | mep | metag \ + | mips | mipsbe | mipseb | mipsel | mipsle \ + | mips16 \ + | mips64 | mips64el \ + | mips64octeon | mips64octeonel \ + | mips64orion | mips64orionel \ + | mips64r5900 | mips64r5900el \ + | mips64vr | mips64vrel \ + | mips64vr4100 | mips64vr4100el \ + | mips64vr4300 | mips64vr4300el \ + | mips64vr5000 | mips64vr5000el \ + | mips64vr5900 | mips64vr5900el \ + | mipsisa32 | mipsisa32el \ + | mipsisa32r2 | mipsisa32r2el \ + | mipsisa32r6 | mipsisa32r6el \ + | mipsisa64 | mipsisa64el \ + | mipsisa64r2 | mipsisa64r2el \ + | mipsisa64r6 | mipsisa64r6el \ + | mipsisa64sb1 | mipsisa64sb1el \ + | mipsisa64sr71k | mipsisa64sr71kel \ + | mipsr5900 | mipsr5900el \ + | mipstx39 | mipstx39el \ + | mn10200 | mn10300 \ + | moxie \ + | mt \ + | msp430 \ + | nds32 | nds32le | nds32be \ + | nios | nios2 | nios2eb | nios2el \ + | ns16k | ns32k \ + | open8 | or1k | or1knd | or32 \ + | pdp10 | pj | pjl \ + | powerpc | powerpc64 | powerpc64le | powerpcle \ + | pru \ + | pyramid \ + | riscv32 | riscv64 \ + | rl78 | rx \ + | score \ + | sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[234]eb | sheb | shbe | shle | sh[1234]le | sh3ele \ + | sh64 | sh64le \ + | sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet | sparclite \ + | sparcv8 | sparcv9 | sparcv9b | sparcv9v \ + | spu \ + | tahoe | tic4x | tic54x | tic55x | tic6x | tic80 | tron \ + | ubicom32 \ + | v850 | v850e | v850e1 | v850e2 | v850es | v850e2v3 \ + | visium \ + | wasm32 \ + | x86 | xc16x | xstormy16 | xtensa \ + | z8k | z80) + basic_machine=$basic_machine-unknown + ;; + c54x) + basic_machine=tic54x-unknown + ;; + c55x) + basic_machine=tic55x-unknown + ;; + c6x) + basic_machine=tic6x-unknown + ;; + leon|leon[3-9]) + basic_machine=sparc-$basic_machine + ;; + m6811 | m68hc11 | m6812 | m68hc12 | m68hcs12x | nvptx | picochip) + basic_machine=$basic_machine-unknown + os=-none + ;; + m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65) + ;; + ms1) + basic_machine=mt-unknown + ;; + + strongarm | thumb | xscale) + basic_machine=arm-unknown + ;; + xgate) + basic_machine=$basic_machine-unknown + os=-none + ;; + xscaleeb) + basic_machine=armeb-unknown + ;; + + xscaleel) + basic_machine=armel-unknown + ;; + + # We use `pc' rather than `unknown' + # because (1) that's what they normally are, and + # (2) the word "unknown" tends to confuse beginning users. + i*86 | x86_64) + basic_machine=$basic_machine-pc + ;; + # Object if more than one company name word. + *-*-*) + echo Invalid configuration \`"$1"\': machine \`"$basic_machine"\' not recognized 1>&2 + exit 1 + ;; + # Recognize the basic CPU types with company name. + 580-* \ + | a29k-* \ + | aarch64-* | aarch64_be-* \ + | alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \ + | alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \ + | alphapca5[67]-* | alpha64pca5[67]-* | arc-* | arceb-* \ + | arm-* | armbe-* | armle-* | armeb-* | armv*-* \ + | avr-* | avr32-* \ + | ba-* \ + | be32-* | be64-* \ + | bfin-* | bs2000-* \ + | c[123]* | c30-* | [cjt]90-* | c4x-* \ + | c8051-* | clipper-* | craynv-* | cydra-* \ + | d10v-* | d30v-* | dlx-* \ + | e2k-* | elxsi-* \ + | f30[01]-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \ + | h8300-* | h8500-* \ + | hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \ + | hexagon-* \ + | i*86-* | i860-* | i960-* | ia16-* | ia64-* \ + | ip2k-* | iq2000-* \ + | k1om-* \ + | le32-* | le64-* \ + | lm32-* \ + | m32c-* | m32r-* | m32rle-* \ + | m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \ + | m88110-* | m88k-* | maxq-* | mcore-* | metag-* \ + | microblaze-* | microblazeel-* \ + | mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \ + | mips16-* \ + | mips64-* | mips64el-* \ + | mips64octeon-* | mips64octeonel-* \ + | mips64orion-* | mips64orionel-* \ + | mips64r5900-* | mips64r5900el-* \ + | mips64vr-* | mips64vrel-* \ + | mips64vr4100-* | mips64vr4100el-* \ + | mips64vr4300-* | mips64vr4300el-* \ + | mips64vr5000-* | mips64vr5000el-* \ + | mips64vr5900-* | mips64vr5900el-* \ + | mipsisa32-* | mipsisa32el-* \ + | mipsisa32r2-* | mipsisa32r2el-* \ + | mipsisa32r6-* | mipsisa32r6el-* \ + | mipsisa64-* | mipsisa64el-* \ + | mipsisa64r2-* | mipsisa64r2el-* \ + | mipsisa64r6-* | mipsisa64r6el-* \ + | mipsisa64sb1-* | mipsisa64sb1el-* \ + | mipsisa64sr71k-* | mipsisa64sr71kel-* \ + | mipsr5900-* | mipsr5900el-* \ + | mipstx39-* | mipstx39el-* \ + | mmix-* \ + | mt-* \ + | msp430-* \ + | nds32-* | nds32le-* | nds32be-* \ + | nios-* | nios2-* | nios2eb-* | nios2el-* \ + | none-* | np1-* | ns16k-* | ns32k-* \ + | open8-* \ + | or1k*-* \ + | orion-* \ + | pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \ + | powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* \ + | pru-* \ + | pyramid-* \ + | riscv32-* | riscv64-* \ + | rl78-* | romp-* | rs6000-* | rx-* \ + | sh-* | sh[1234]-* | sh[24]a-* | sh[24]aeb-* | sh[23]e-* | sh[34]eb-* | sheb-* | shbe-* \ + | shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \ + | sparc-* | sparc64-* | sparc64b-* | sparc64v-* | sparc86x-* | sparclet-* \ + | sparclite-* \ + | sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | sv1-* | sx*-* \ + | tahoe-* \ + | tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* \ + | tile*-* \ + | tron-* \ + | ubicom32-* \ + | v850-* | v850e-* | v850e1-* | v850es-* | v850e2-* | v850e2v3-* \ + | vax-* \ + | visium-* \ + | wasm32-* \ + | we32k-* \ + | x86-* | x86_64-* | xc16x-* | xps100-* \ + | xstormy16-* | xtensa*-* \ + | ymp-* \ + | z8k-* | z80-*) + ;; + # Recognize the basic CPU types without company name, with glob match. + xtensa*) + basic_machine=$basic_machine-unknown + ;; + # Recognize the various machine names and aliases which stand + # for a CPU type and a company and sometimes even an OS. + 386bsd) + basic_machine=i386-pc + os=-bsd + ;; + 3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc) + basic_machine=m68000-att + ;; + 3b*) + basic_machine=we32k-att + ;; + a29khif) + basic_machine=a29k-amd + os=-udi + ;; + abacus) + basic_machine=abacus-unknown + ;; + adobe68k) + basic_machine=m68010-adobe + os=-scout + ;; + alliant | fx80) + basic_machine=fx80-alliant + ;; + altos | altos3068) + basic_machine=m68k-altos + ;; + am29k) + basic_machine=a29k-none + os=-bsd + ;; + amd64) + basic_machine=x86_64-pc + ;; + amd64-*) + basic_machine=x86_64-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + amdahl) + basic_machine=580-amdahl + os=-sysv + ;; + amiga | amiga-*) + basic_machine=m68k-unknown + ;; + amigaos | amigados) + basic_machine=m68k-unknown + os=-amigaos + ;; + amigaunix | amix) + basic_machine=m68k-unknown + os=-sysv4 + ;; + apollo68) + basic_machine=m68k-apollo + os=-sysv + ;; + apollo68bsd) + basic_machine=m68k-apollo + os=-bsd + ;; + aros) + basic_machine=i386-pc + os=-aros + ;; + asmjs) + basic_machine=asmjs-unknown + ;; + aux) + basic_machine=m68k-apple + os=-aux + ;; + balance) + basic_machine=ns32k-sequent + os=-dynix + ;; + blackfin) + basic_machine=bfin-unknown + os=-linux + ;; + blackfin-*) + basic_machine=bfin-`echo "$basic_machine" | sed 's/^[^-]*-//'` + os=-linux + ;; + bluegene*) + basic_machine=powerpc-ibm + os=-cnk + ;; + c54x-*) + basic_machine=tic54x-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + c55x-*) + basic_machine=tic55x-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + c6x-*) + basic_machine=tic6x-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + c90) + basic_machine=c90-cray + os=-unicos + ;; + cegcc) + basic_machine=arm-unknown + os=-cegcc + ;; + convex-c1) + basic_machine=c1-convex + os=-bsd + ;; + convex-c2) + basic_machine=c2-convex + os=-bsd + ;; + convex-c32) + basic_machine=c32-convex + os=-bsd + ;; + convex-c34) + basic_machine=c34-convex + os=-bsd + ;; + convex-c38) + basic_machine=c38-convex + os=-bsd + ;; + cray | j90) + basic_machine=j90-cray + os=-unicos + ;; + craynv) + basic_machine=craynv-cray + os=-unicosmp + ;; + cr16 | cr16-*) + basic_machine=cr16-unknown + os=-elf + ;; + crds | unos) + basic_machine=m68k-crds + ;; + crisv32 | crisv32-* | etraxfs*) + basic_machine=crisv32-axis + ;; + cris | cris-* | etrax*) + basic_machine=cris-axis + ;; + crx) + basic_machine=crx-unknown + os=-elf + ;; + da30 | da30-*) + basic_machine=m68k-da30 + ;; + decstation | decstation-3100 | pmax | pmax-* | pmin | dec3100 | decstatn) + basic_machine=mips-dec + ;; + decsystem10* | dec10*) + basic_machine=pdp10-dec + os=-tops10 + ;; + decsystem20* | dec20*) + basic_machine=pdp10-dec + os=-tops20 + ;; + delta | 3300 | motorola-3300 | motorola-delta \ + | 3300-motorola | delta-motorola) + basic_machine=m68k-motorola + ;; + delta88) + basic_machine=m88k-motorola + os=-sysv3 + ;; + dicos) + basic_machine=i686-pc + os=-dicos + ;; + djgpp) + basic_machine=i586-pc + os=-msdosdjgpp + ;; + dpx20 | dpx20-*) + basic_machine=rs6000-bull + os=-bosx + ;; + dpx2*) + basic_machine=m68k-bull + os=-sysv3 + ;; + e500v[12]) + basic_machine=powerpc-unknown + os=$os"spe" + ;; + e500v[12]-*) + basic_machine=powerpc-`echo "$basic_machine" | sed 's/^[^-]*-//'` + os=$os"spe" + ;; + ebmon29k) + basic_machine=a29k-amd + os=-ebmon + ;; + elxsi) + basic_machine=elxsi-elxsi + os=-bsd + ;; + encore | umax | mmax) + basic_machine=ns32k-encore + ;; + es1800 | OSE68k | ose68k | ose | OSE) + basic_machine=m68k-ericsson + os=-ose + ;; + fx2800) + basic_machine=i860-alliant + ;; + genix) + basic_machine=ns32k-ns + ;; + gmicro) + basic_machine=tron-gmicro + os=-sysv + ;; + go32) + basic_machine=i386-pc + os=-go32 + ;; + h3050r* | hiux*) + basic_machine=hppa1.1-hitachi + os=-hiuxwe2 + ;; + h8300hms) + basic_machine=h8300-hitachi + os=-hms + ;; + h8300xray) + basic_machine=h8300-hitachi + os=-xray + ;; + h8500hms) + basic_machine=h8500-hitachi + os=-hms + ;; + harris) + basic_machine=m88k-harris + os=-sysv3 + ;; + hp300-*) + basic_machine=m68k-hp + ;; + hp300bsd) + basic_machine=m68k-hp + os=-bsd + ;; + hp300hpux) + basic_machine=m68k-hp + os=-hpux + ;; + hp3k9[0-9][0-9] | hp9[0-9][0-9]) + basic_machine=hppa1.0-hp + ;; + hp9k2[0-9][0-9] | hp9k31[0-9]) + basic_machine=m68000-hp + ;; + hp9k3[2-9][0-9]) + basic_machine=m68k-hp + ;; + hp9k6[0-9][0-9] | hp6[0-9][0-9]) + basic_machine=hppa1.0-hp + ;; + hp9k7[0-79][0-9] | hp7[0-79][0-9]) + basic_machine=hppa1.1-hp + ;; + hp9k78[0-9] | hp78[0-9]) + # FIXME: really hppa2.0-hp + basic_machine=hppa1.1-hp + ;; + hp9k8[67]1 | hp8[67]1 | hp9k80[24] | hp80[24] | hp9k8[78]9 | hp8[78]9 | hp9k893 | hp893) + # FIXME: really hppa2.0-hp + basic_machine=hppa1.1-hp + ;; + hp9k8[0-9][13679] | hp8[0-9][13679]) + basic_machine=hppa1.1-hp + ;; + hp9k8[0-9][0-9] | hp8[0-9][0-9]) + basic_machine=hppa1.0-hp + ;; + hppaosf) + basic_machine=hppa1.1-hp + os=-osf + ;; + hppro) + basic_machine=hppa1.1-hp + os=-proelf + ;; + i370-ibm* | ibm*) + basic_machine=i370-ibm + ;; + i*86v32) + basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'` + os=-sysv32 + ;; + i*86v4*) + basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'` + os=-sysv4 + ;; + i*86v) + basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'` + os=-sysv + ;; + i*86sol2) + basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'` + os=-solaris2 + ;; + i386mach) + basic_machine=i386-mach + os=-mach + ;; + vsta) + basic_machine=i386-unknown + os=-vsta + ;; + iris | iris4d) + basic_machine=mips-sgi + case $os in + -irix*) + ;; + *) + os=-irix4 + ;; + esac + ;; + isi68 | isi) + basic_machine=m68k-isi + os=-sysv + ;; + leon-*|leon[3-9]-*) + basic_machine=sparc-`echo "$basic_machine" | sed 's/-.*//'` + ;; + m68knommu) + basic_machine=m68k-unknown + os=-linux + ;; + m68knommu-*) + basic_machine=m68k-`echo "$basic_machine" | sed 's/^[^-]*-//'` + os=-linux + ;; + magnum | m3230) + basic_machine=mips-mips + os=-sysv + ;; + merlin) + basic_machine=ns32k-utek + os=-sysv + ;; + microblaze*) + basic_machine=microblaze-xilinx + ;; + mingw64) + basic_machine=x86_64-pc + os=-mingw64 + ;; + mingw32) + basic_machine=i686-pc + os=-mingw32 + ;; + mingw32ce) + basic_machine=arm-unknown + os=-mingw32ce + ;; + miniframe) + basic_machine=m68000-convergent + ;; + *mint | -mint[0-9]* | *MiNT | *MiNT[0-9]*) + basic_machine=m68k-atari + os=-mint + ;; + mips3*-*) + basic_machine=`echo "$basic_machine" | sed -e 's/mips3/mips64/'` + ;; + mips3*) + basic_machine=`echo "$basic_machine" | sed -e 's/mips3/mips64/'`-unknown + ;; + monitor) + basic_machine=m68k-rom68k + os=-coff + ;; + morphos) + basic_machine=powerpc-unknown + os=-morphos + ;; + moxiebox) + basic_machine=moxie-unknown + os=-moxiebox + ;; + msdos) + basic_machine=i386-pc + os=-msdos + ;; + ms1-*) + basic_machine=`echo "$basic_machine" | sed -e 's/ms1-/mt-/'` + ;; + msys) + basic_machine=i686-pc + os=-msys + ;; + mvs) + basic_machine=i370-ibm + os=-mvs + ;; + nacl) + basic_machine=le32-unknown + os=-nacl + ;; + ncr3000) + basic_machine=i486-ncr + os=-sysv4 + ;; + netbsd386) + basic_machine=i386-unknown + os=-netbsd + ;; + netwinder) + basic_machine=armv4l-rebel + os=-linux + ;; + news | news700 | news800 | news900) + basic_machine=m68k-sony + os=-newsos + ;; + news1000) + basic_machine=m68030-sony + os=-newsos + ;; + news-3600 | risc-news) + basic_machine=mips-sony + os=-newsos + ;; + necv70) + basic_machine=v70-nec + os=-sysv + ;; + next | m*-next) + basic_machine=m68k-next + case $os in + -nextstep* ) + ;; + -ns2*) + os=-nextstep2 + ;; + *) + os=-nextstep3 + ;; + esac + ;; + nh3000) + basic_machine=m68k-harris + os=-cxux + ;; + nh[45]000) + basic_machine=m88k-harris + os=-cxux + ;; + nindy960) + basic_machine=i960-intel + os=-nindy + ;; + mon960) + basic_machine=i960-intel + os=-mon960 + ;; + nonstopux) + basic_machine=mips-compaq + os=-nonstopux + ;; + np1) + basic_machine=np1-gould + ;; + neo-tandem) + basic_machine=neo-tandem + ;; + nse-tandem) + basic_machine=nse-tandem + ;; + nsr-tandem) + basic_machine=nsr-tandem + ;; + nsv-tandem) + basic_machine=nsv-tandem + ;; + nsx-tandem) + basic_machine=nsx-tandem + ;; + op50n-* | op60c-*) + basic_machine=hppa1.1-oki + os=-proelf + ;; + openrisc | openrisc-*) + basic_machine=or32-unknown + ;; + os400) + basic_machine=powerpc-ibm + os=-os400 + ;; + OSE68000 | ose68000) + basic_machine=m68000-ericsson + os=-ose + ;; + os68k) + basic_machine=m68k-none + os=-os68k + ;; + pa-hitachi) + basic_machine=hppa1.1-hitachi + os=-hiuxwe2 + ;; + paragon) + basic_machine=i860-intel + os=-osf + ;; + parisc) + basic_machine=hppa-unknown + os=-linux + ;; + parisc-*) + basic_machine=hppa-`echo "$basic_machine" | sed 's/^[^-]*-//'` + os=-linux + ;; + pbd) + basic_machine=sparc-tti + ;; + pbb) + basic_machine=m68k-tti + ;; + pc532 | pc532-*) + basic_machine=ns32k-pc532 + ;; + pc98) + basic_machine=i386-pc + ;; + pc98-*) + basic_machine=i386-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + pentium | p5 | k5 | k6 | nexgen | viac3) + basic_machine=i586-pc + ;; + pentiumpro | p6 | 6x86 | athlon | athlon_*) + basic_machine=i686-pc + ;; + pentiumii | pentium2 | pentiumiii | pentium3) + basic_machine=i686-pc + ;; + pentium4) + basic_machine=i786-pc + ;; + pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*) + basic_machine=i586-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + pentiumpro-* | p6-* | 6x86-* | athlon-*) + basic_machine=i686-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*) + basic_machine=i686-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + pentium4-*) + basic_machine=i786-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + pn) + basic_machine=pn-gould + ;; + power) basic_machine=power-ibm + ;; + ppc | ppcbe) basic_machine=powerpc-unknown + ;; + ppc-* | ppcbe-*) + basic_machine=powerpc-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + ppcle | powerpclittle) + basic_machine=powerpcle-unknown + ;; + ppcle-* | powerpclittle-*) + basic_machine=powerpcle-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + ppc64) basic_machine=powerpc64-unknown + ;; + ppc64-*) basic_machine=powerpc64-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + ppc64le | powerpc64little) + basic_machine=powerpc64le-unknown + ;; + ppc64le-* | powerpc64little-*) + basic_machine=powerpc64le-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + ps2) + basic_machine=i386-ibm + ;; + pw32) + basic_machine=i586-unknown + os=-pw32 + ;; + rdos | rdos64) + basic_machine=x86_64-pc + os=-rdos + ;; + rdos32) + basic_machine=i386-pc + os=-rdos + ;; + rom68k) + basic_machine=m68k-rom68k + os=-coff + ;; + rm[46]00) + basic_machine=mips-siemens + ;; + rtpc | rtpc-*) + basic_machine=romp-ibm + ;; + s390 | s390-*) + basic_machine=s390-ibm + ;; + s390x | s390x-*) + basic_machine=s390x-ibm + ;; + sa29200) + basic_machine=a29k-amd + os=-udi + ;; + sb1) + basic_machine=mipsisa64sb1-unknown + ;; + sb1el) + basic_machine=mipsisa64sb1el-unknown + ;; + sde) + basic_machine=mipsisa32-sde + os=-elf + ;; + sei) + basic_machine=mips-sei + os=-seiux + ;; + sequent) + basic_machine=i386-sequent + ;; + sh5el) + basic_machine=sh5le-unknown + ;; + simso-wrs) + basic_machine=sparclite-wrs + os=-vxworks + ;; + sps7) + basic_machine=m68k-bull + os=-sysv2 + ;; + spur) + basic_machine=spur-unknown + ;; + st2000) + basic_machine=m68k-tandem + ;; + stratus) + basic_machine=i860-stratus + os=-sysv4 + ;; + strongarm-* | thumb-*) + basic_machine=arm-`echo "$basic_machine" | sed 's/^[^-]*-//'` + ;; + sun2) + basic_machine=m68000-sun + ;; + sun2os3) + basic_machine=m68000-sun + os=-sunos3 + ;; + sun2os4) + basic_machine=m68000-sun + os=-sunos4 + ;; + sun3os3) + basic_machine=m68k-sun + os=-sunos3 + ;; + sun3os4) + basic_machine=m68k-sun + os=-sunos4 + ;; + sun4os3) + basic_machine=sparc-sun + os=-sunos3 + ;; + sun4os4) + basic_machine=sparc-sun + os=-sunos4 + ;; + sun4sol2) + basic_machine=sparc-sun + os=-solaris2 + ;; + sun3 | sun3-*) + basic_machine=m68k-sun + ;; + sun4) + basic_machine=sparc-sun + ;; + sun386 | sun386i | roadrunner) + basic_machine=i386-sun + ;; + sv1) + basic_machine=sv1-cray + os=-unicos + ;; + symmetry) + basic_machine=i386-sequent + os=-dynix + ;; + t3e) + basic_machine=alphaev5-cray + os=-unicos + ;; + t90) + basic_machine=t90-cray + os=-unicos + ;; + tile*) + basic_machine=$basic_machine-unknown + os=-linux-gnu + ;; + tx39) + basic_machine=mipstx39-unknown + ;; + tx39el) + basic_machine=mipstx39el-unknown + ;; + toad1) + basic_machine=pdp10-xkl + os=-tops20 + ;; + tower | tower-32) + basic_machine=m68k-ncr + ;; + tpf) + basic_machine=s390x-ibm + os=-tpf + ;; + udi29k) + basic_machine=a29k-amd + os=-udi + ;; + ultra3) + basic_machine=a29k-nyu + os=-sym1 + ;; + v810 | necv810) + basic_machine=v810-nec + os=-none + ;; + vaxv) + basic_machine=vax-dec + os=-sysv + ;; + vms) + basic_machine=vax-dec + os=-vms + ;; + vpp*|vx|vx-*) + basic_machine=f301-fujitsu + ;; + vxworks960) + basic_machine=i960-wrs + os=-vxworks + ;; + vxworks68) + basic_machine=m68k-wrs + os=-vxworks + ;; + vxworks29k) + basic_machine=a29k-wrs + os=-vxworks + ;; + w65*) + basic_machine=w65-wdc + os=-none + ;; + w89k-*) + basic_machine=hppa1.1-winbond + os=-proelf + ;; + x64) + basic_machine=x86_64-pc + ;; + xbox) + basic_machine=i686-pc + os=-mingw32 + ;; + xps | xps100) + basic_machine=xps100-honeywell + ;; + xscale-* | xscalee[bl]-*) + basic_machine=`echo "$basic_machine" | sed 's/^xscale/arm/'` + ;; + ymp) + basic_machine=ymp-cray + os=-unicos + ;; + none) + basic_machine=none-none + os=-none + ;; + +# Here we handle the default manufacturer of certain CPU types. It is in +# some cases the only manufacturer, in others, it is the most popular. + w89k) + basic_machine=hppa1.1-winbond + ;; + op50n) + basic_machine=hppa1.1-oki + ;; + op60c) + basic_machine=hppa1.1-oki + ;; + romp) + basic_machine=romp-ibm + ;; + mmix) + basic_machine=mmix-knuth + ;; + rs6000) + basic_machine=rs6000-ibm + ;; + vax) + basic_machine=vax-dec + ;; + pdp11) + basic_machine=pdp11-dec + ;; + we32k) + basic_machine=we32k-att + ;; + sh[1234] | sh[24]a | sh[24]aeb | sh[34]eb | sh[1234]le | sh[23]ele) + basic_machine=sh-unknown + ;; + cydra) + basic_machine=cydra-cydrome + ;; + orion) + basic_machine=orion-highlevel + ;; + orion105) + basic_machine=clipper-highlevel + ;; + mac | mpw | mac-mpw) + basic_machine=m68k-apple + ;; + pmac | pmac-mpw) + basic_machine=powerpc-apple + ;; + *-unknown) + # Make sure to match an already-canonicalized machine name. + ;; + *) + echo Invalid configuration \`"$1"\': machine \`"$basic_machine"\' not recognized 1>&2 + exit 1 + ;; +esac + +# Here we canonicalize certain aliases for manufacturers. +case $basic_machine in + *-digital*) + basic_machine=`echo "$basic_machine" | sed 's/digital.*/dec/'` + ;; + *-commodore*) + basic_machine=`echo "$basic_machine" | sed 's/commodore.*/cbm/'` + ;; + *) + ;; +esac + +# Decode manufacturer-specific aliases for certain operating systems. + +if [ x"$os" != x"" ] +then +case $os in + # First match some system type aliases that might get confused + # with valid system types. + # -solaris* is a basic system type, with this one exception. + -auroraux) + os=-auroraux + ;; + -solaris1 | -solaris1.*) + os=`echo $os | sed -e 's|solaris1|sunos4|'` + ;; + -solaris) + os=-solaris2 + ;; + -unixware*) + os=-sysv4.2uw + ;; + -gnu/linux*) + os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'` + ;; + # es1800 is here to avoid being matched by es* (a different OS) + -es1800*) + os=-ose + ;; + # Now accept the basic system types. + # The portable systems comes first. + # Each alternative MUST end in a * to match a version number. + # -sysv* is not here because it comes later, after sysvr4. + -gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \ + | -*vms* | -sco* | -esix* | -isc* | -aix* | -cnk* | -sunos | -sunos[34]*\ + | -hpux* | -unos* | -osf* | -luna* | -dgux* | -auroraux* | -solaris* \ + | -sym* | -kopensolaris* | -plan9* \ + | -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \ + | -aos* | -aros* | -cloudabi* | -sortix* \ + | -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \ + | -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \ + | -hiux* | -knetbsd* | -mirbsd* | -netbsd* \ + | -bitrig* | -openbsd* | -solidbsd* | -libertybsd* \ + | -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \ + | -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \ + | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \ + | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* | -hcos* \ + | -chorusos* | -chorusrdb* | -cegcc* | -glidix* \ + | -cygwin* | -msys* | -pe* | -psos* | -moss* | -proelf* | -rtems* \ + | -midipix* | -mingw32* | -mingw64* | -linux-gnu* | -linux-android* \ + | -linux-newlib* | -linux-musl* | -linux-uclibc* \ + | -uxpv* | -beos* | -mpeix* | -udk* | -moxiebox* \ + | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* \ + | -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \ + | -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \ + | -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \ + | -morphos* | -superux* | -rtmk* | -windiss* \ + | -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \ + | -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es* \ + | -onefs* | -tirtos* | -phoenix* | -fuchsia* | -redox* | -bme* \ + | -midnightbsd*) + # Remember, each alternative MUST END IN *, to match a version number. + ;; + -qnx*) + case $basic_machine in + x86-* | i*86-*) + ;; + *) + os=-nto$os + ;; + esac + ;; + -nto-qnx*) + ;; + -nto*) + os=`echo $os | sed -e 's|nto|nto-qnx|'` + ;; + -sim | -xray | -os68k* | -v88r* \ + | -windows* | -osx | -abug | -netware* | -os9* \ + | -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*) + ;; + -mac*) + os=`echo "$os" | sed -e 's|mac|macos|'` + ;; + -linux-dietlibc) + os=-linux-dietlibc + ;; + -linux*) + os=`echo $os | sed -e 's|linux|linux-gnu|'` + ;; + -sunos5*) + os=`echo "$os" | sed -e 's|sunos5|solaris2|'` + ;; + -sunos6*) + os=`echo "$os" | sed -e 's|sunos6|solaris3|'` + ;; + -opened*) + os=-openedition + ;; + -os400*) + os=-os400 + ;; + -wince*) + os=-wince + ;; + -utek*) + os=-bsd + ;; + -dynix*) + os=-bsd + ;; + -acis*) + os=-aos + ;; + -atheos*) + os=-atheos + ;; + -syllable*) + os=-syllable + ;; + -386bsd) + os=-bsd + ;; + -ctix* | -uts*) + os=-sysv + ;; + -nova*) + os=-rtmk-nova + ;; + -ns2) + os=-nextstep2 + ;; + -nsk*) + os=-nsk + ;; + # Preserve the version number of sinix5. + -sinix5.*) + os=`echo $os | sed -e 's|sinix|sysv|'` + ;; + -sinix*) + os=-sysv4 + ;; + -tpf*) + os=-tpf + ;; + -triton*) + os=-sysv3 + ;; + -oss*) + os=-sysv3 + ;; + -svr4*) + os=-sysv4 + ;; + -svr3) + os=-sysv3 + ;; + -sysvr4) + os=-sysv4 + ;; + # This must come after -sysvr4. + -sysv*) + ;; + -ose*) + os=-ose + ;; + -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) + os=-mint + ;; + -zvmoe) + os=-zvmoe + ;; + -dicos*) + os=-dicos + ;; + -pikeos*) + # Until real need of OS specific support for + # particular features comes up, bare metal + # configurations are quite functional. + case $basic_machine in + arm*) + os=-eabi + ;; + *) + os=-elf + ;; + esac + ;; + -nacl*) + ;; + -ios) + ;; + -none) + ;; + *) + # Get rid of the `-' at the beginning of $os. + os=`echo $os | sed 's/[^-]*-//'` + echo Invalid configuration \`"$1"\': system \`"$os"\' not recognized 1>&2 + exit 1 + ;; +esac +else + +# Here we handle the default operating systems that come with various machines. +# The value should be what the vendor currently ships out the door with their +# machine or put another way, the most popular os provided with the machine. + +# Note that if you're going to try to match "-MANUFACTURER" here (say, +# "-sun"), then you have to tell the case statement up towards the top +# that MANUFACTURER isn't an operating system. Otherwise, code above +# will signal an error saying that MANUFACTURER isn't an operating +# system, and we'll never get to this point. + +case $basic_machine in + score-*) + os=-elf + ;; + spu-*) + os=-elf + ;; + *-acorn) + os=-riscix1.2 + ;; + arm*-rebel) + os=-linux + ;; + arm*-semi) + os=-aout + ;; + c4x-* | tic4x-*) + os=-coff + ;; + c8051-*) + os=-elf + ;; + hexagon-*) + os=-elf + ;; + tic54x-*) + os=-coff + ;; + tic55x-*) + os=-coff + ;; + tic6x-*) + os=-coff + ;; + # This must come before the *-dec entry. + pdp10-*) + os=-tops20 + ;; + pdp11-*) + os=-none + ;; + *-dec | vax-*) + os=-ultrix4.2 + ;; + m68*-apollo) + os=-domain + ;; + i386-sun) + os=-sunos4.0.2 + ;; + m68000-sun) + os=-sunos3 + ;; + m68*-cisco) + os=-aout + ;; + mep-*) + os=-elf + ;; + mips*-cisco) + os=-elf + ;; + mips*-*) + os=-elf + ;; + or32-*) + os=-coff + ;; + *-tti) # must be before sparc entry or we get the wrong os. + os=-sysv3 + ;; + sparc-* | *-sun) + os=-sunos4.1.1 + ;; + pru-*) + os=-elf + ;; + *-be) + os=-beos + ;; + *-ibm) + os=-aix + ;; + *-knuth) + os=-mmixware + ;; + *-wec) + os=-proelf + ;; + *-winbond) + os=-proelf + ;; + *-oki) + os=-proelf + ;; + *-hp) + os=-hpux + ;; + *-hitachi) + os=-hiux + ;; + i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent) + os=-sysv + ;; + *-cbm) + os=-amigaos + ;; + *-dg) + os=-dgux + ;; + *-dolphin) + os=-sysv3 + ;; + m68k-ccur) + os=-rtu + ;; + m88k-omron*) + os=-luna + ;; + *-next) + os=-nextstep + ;; + *-sequent) + os=-ptx + ;; + *-crds) + os=-unos + ;; + *-ns) + os=-genix + ;; + i370-*) + os=-mvs + ;; + *-gould) + os=-sysv + ;; + *-highlevel) + os=-bsd + ;; + *-encore) + os=-bsd + ;; + *-sgi) + os=-irix + ;; + *-siemens) + os=-sysv4 + ;; + *-masscomp) + os=-rtu + ;; + f30[01]-fujitsu | f700-fujitsu) + os=-uxpv + ;; + *-rom68k) + os=-coff + ;; + *-*bug) + os=-coff + ;; + *-apple) + os=-macos + ;; + *-atari*) + os=-mint + ;; + *) + os=-none + ;; +esac +fi + +# Here we handle the case where we know the os, and the CPU type, but not the +# manufacturer. We pick the logical manufacturer. +vendor=unknown +case $basic_machine in + *-unknown) + case $os in + -riscix*) + vendor=acorn + ;; + -sunos*) + vendor=sun + ;; + -cnk*|-aix*) + vendor=ibm + ;; + -beos*) + vendor=be + ;; + -hpux*) + vendor=hp + ;; + -mpeix*) + vendor=hp + ;; + -hiux*) + vendor=hitachi + ;; + -unos*) + vendor=crds + ;; + -dgux*) + vendor=dg + ;; + -luna*) + vendor=omron + ;; + -genix*) + vendor=ns + ;; + -mvs* | -opened*) + vendor=ibm + ;; + -os400*) + vendor=ibm + ;; + -ptx*) + vendor=sequent + ;; + -tpf*) + vendor=ibm + ;; + -vxsim* | -vxworks* | -windiss*) + vendor=wrs + ;; + -aux*) + vendor=apple + ;; + -hms*) + vendor=hitachi + ;; + -mpw* | -macos*) + vendor=apple + ;; + -*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*) + vendor=atari + ;; + -vos*) + vendor=stratus + ;; + esac + basic_machine=`echo "$basic_machine" | sed "s/unknown/$vendor/"` + ;; +esac + +echo "$basic_machine$os" +exit + +# Local variables: +# eval: (add-hook 'before-save-hook 'time-stamp) +# time-stamp-start: "timestamp='" +# time-stamp-format: "%:y-%02m-%02d" +# time-stamp-end: "'" +# End: diff --git a/TMessagesProj/jni/libtgvoip2/configure b/TMessagesProj/jni/libtgvoip2/configure new file mode 100644 index 000000000..648703782 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/configure @@ -0,0 +1,21185 @@ +#! /bin/sh +# Guess values for system-dependent variables and create Makefiles. +# Generated by GNU Autoconf 2.69 for libtgvoip 2.6. +# +# Report bugs to . +# +# +# Copyright (C) 1992-1996, 1998-2012 Free Software Foundation, Inc. +# +# +# This configure script is free software; the Free Software Foundation +# gives unlimited permission to copy, distribute and modify it. +## -------------------- ## +## M4sh Initialization. ## +## -------------------- ## + +# Be more Bourne compatible +DUALCASE=1; export DUALCASE # for MKS sh +if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : + emulate sh + NULLCMD=: + # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which + # is contrary to our usage. Disable this feature. + alias -g '${1+"$@"}'='"$@"' + setopt NO_GLOB_SUBST +else + case `(set -o) 2>/dev/null` in #( + *posix*) : + set -o posix ;; #( + *) : + ;; +esac +fi + + +as_nl=' +' +export as_nl +# Printing a long string crashes Solaris 7 /usr/bin/printf. +as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' +as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo +as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo +# Prefer a ksh shell builtin over an external printf program on Solaris, +# but without wasting forks for bash or zsh. +if test -z "$BASH_VERSION$ZSH_VERSION" \ + && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then + as_echo='print -r --' + as_echo_n='print -rn --' +elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then + as_echo='printf %s\n' + as_echo_n='printf %s' +else + if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then + as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' + as_echo_n='/usr/ucb/echo -n' + else + as_echo_body='eval expr "X$1" : "X\\(.*\\)"' + as_echo_n_body='eval + arg=$1; + case $arg in #( + *"$as_nl"*) + expr "X$arg" : "X\\(.*\\)$as_nl"; + arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; + esac; + expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" + ' + export as_echo_n_body + as_echo_n='sh -c $as_echo_n_body as_echo' + fi + export as_echo_body + as_echo='sh -c $as_echo_body as_echo' +fi + +# The user is always right. +if test "${PATH_SEPARATOR+set}" != set; then + PATH_SEPARATOR=: + (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { + (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || + PATH_SEPARATOR=';' + } +fi + + +# IFS +# We need space, tab and new line, in precisely that order. Quoting is +# there to prevent editors from complaining about space-tab. +# (If _AS_PATH_WALK were called with IFS unset, it would disable word +# splitting by setting IFS to empty value.) +IFS=" "" $as_nl" + +# Find who we are. Look in the path if we contain no directory separator. +as_myself= +case $0 in #(( + *[\\/]* ) as_myself=$0 ;; + *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break + done +IFS=$as_save_IFS + + ;; +esac +# We did not find ourselves, most probably we were run as `sh COMMAND' +# in which case we are not to be found in the path. +if test "x$as_myself" = x; then + as_myself=$0 +fi +if test ! -f "$as_myself"; then + $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 + exit 1 +fi + +# Unset variables that we do not need and which cause bugs (e.g. in +# pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" +# suppresses any "Segmentation fault" message there. '((' could +# trigger a bug in pdksh 5.2.14. +for as_var in BASH_ENV ENV MAIL MAILPATH +do eval test x\${$as_var+set} = xset \ + && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : +done +PS1='$ ' +PS2='> ' +PS4='+ ' + +# NLS nuisances. +LC_ALL=C +export LC_ALL +LANGUAGE=C +export LANGUAGE + +# CDPATH. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + +# Use a proper internal environment variable to ensure we don't fall + # into an infinite loop, continuously re-executing ourselves. + if test x"${_as_can_reexec}" != xno && test "x$CONFIG_SHELL" != x; then + _as_can_reexec=no; export _as_can_reexec; + # We cannot yet assume a decent shell, so we have to provide a +# neutralization value for shells without unset; and this also +# works around shells that cannot unset nonexistent variables. +# Preserve -v and -x to the replacement shell. +BASH_ENV=/dev/null +ENV=/dev/null +(unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV +case $- in # (((( + *v*x* | *x*v* ) as_opts=-vx ;; + *v* ) as_opts=-v ;; + *x* ) as_opts=-x ;; + * ) as_opts= ;; +esac +exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} +# Admittedly, this is quite paranoid, since all the known shells bail +# out after a failed `exec'. +$as_echo "$0: could not re-execute with $CONFIG_SHELL" >&2 +as_fn_exit 255 + fi + # We don't want this to propagate to other subprocesses. + { _as_can_reexec=; unset _as_can_reexec;} +if test "x$CONFIG_SHELL" = x; then + as_bourne_compatible="if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then : + emulate sh + NULLCMD=: + # Pre-4.2 versions of Zsh do word splitting on \${1+\"\$@\"}, which + # is contrary to our usage. Disable this feature. + alias -g '\${1+\"\$@\"}'='\"\$@\"' + setopt NO_GLOB_SUBST +else + case \`(set -o) 2>/dev/null\` in #( + *posix*) : + set -o posix ;; #( + *) : + ;; +esac +fi +" + as_required="as_fn_return () { (exit \$1); } +as_fn_success () { as_fn_return 0; } +as_fn_failure () { as_fn_return 1; } +as_fn_ret_success () { return 0; } +as_fn_ret_failure () { return 1; } + +exitcode=0 +as_fn_success || { exitcode=1; echo as_fn_success failed.; } +as_fn_failure && { exitcode=1; echo as_fn_failure succeeded.; } +as_fn_ret_success || { exitcode=1; echo as_fn_ret_success failed.; } +as_fn_ret_failure && { exitcode=1; echo as_fn_ret_failure succeeded.; } +if ( set x; as_fn_ret_success y && test x = \"\$1\" ); then : + +else + exitcode=1; echo positional parameters were not saved. +fi +test x\$exitcode = x0 || exit 1 +test -x / || exit 1" + as_suggested=" as_lineno_1=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_1a=\$LINENO + as_lineno_2=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_2a=\$LINENO + eval 'test \"x\$as_lineno_1'\$as_run'\" != \"x\$as_lineno_2'\$as_run'\" && + test \"x\`expr \$as_lineno_1'\$as_run' + 1\`\" = \"x\$as_lineno_2'\$as_run'\"' || exit 1 + + test -n \"\${ZSH_VERSION+set}\${BASH_VERSION+set}\" || ( + ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' + ECHO=\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO + ECHO=\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO + PATH=/empty FPATH=/empty; export PATH FPATH + test \"X\`printf %s \$ECHO\`\" = \"X\$ECHO\" \\ + || test \"X\`print -r -- \$ECHO\`\" = \"X\$ECHO\" ) || exit 1 +test \$(( 1 + 1 )) = 2 || exit 1" + if (eval "$as_required") 2>/dev/null; then : + as_have_required=yes +else + as_have_required=no +fi + if test x$as_have_required = xyes && (eval "$as_suggested") 2>/dev/null; then : + +else + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +as_found=false +for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + as_found=: + case $as_dir in #( + /*) + for as_base in sh bash ksh sh5; do + # Try only shells that exist, to save several forks. + as_shell=$as_dir/$as_base + if { test -f "$as_shell" || test -f "$as_shell.exe"; } && + { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$as_shell"; } 2>/dev/null; then : + CONFIG_SHELL=$as_shell as_have_required=yes + if { $as_echo "$as_bourne_compatible""$as_suggested" | as_run=a "$as_shell"; } 2>/dev/null; then : + break 2 +fi +fi + done;; + esac + as_found=false +done +$as_found || { if { test -f "$SHELL" || test -f "$SHELL.exe"; } && + { $as_echo "$as_bourne_compatible""$as_required" | as_run=a "$SHELL"; } 2>/dev/null; then : + CONFIG_SHELL=$SHELL as_have_required=yes +fi; } +IFS=$as_save_IFS + + + if test "x$CONFIG_SHELL" != x; then : + export CONFIG_SHELL + # We cannot yet assume a decent shell, so we have to provide a +# neutralization value for shells without unset; and this also +# works around shells that cannot unset nonexistent variables. +# Preserve -v and -x to the replacement shell. +BASH_ENV=/dev/null +ENV=/dev/null +(unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV +case $- in # (((( + *v*x* | *x*v* ) as_opts=-vx ;; + *v* ) as_opts=-v ;; + *x* ) as_opts=-x ;; + * ) as_opts= ;; +esac +exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} +# Admittedly, this is quite paranoid, since all the known shells bail +# out after a failed `exec'. +$as_echo "$0: could not re-execute with $CONFIG_SHELL" >&2 +exit 255 +fi + + if test x$as_have_required = xno; then : + $as_echo "$0: This script requires a shell more modern than all" + $as_echo "$0: the shells that I found on your system." + if test x${ZSH_VERSION+set} = xset ; then + $as_echo "$0: In particular, zsh $ZSH_VERSION has bugs and should" + $as_echo "$0: be upgraded to zsh 4.3.4 or later." + else + $as_echo "$0: Please tell bug-autoconf@gnu.org and +$0: https://github.com/grishka/libtgvoip/issues about your +$0: system, including any error possibly output before this +$0: message. Then install a modern shell, or manually run +$0: the script under such a shell if you do have one." + fi + exit 1 +fi +fi +fi +SHELL=${CONFIG_SHELL-/bin/sh} +export SHELL +# Unset more variables known to interfere with behavior of common tools. +CLICOLOR_FORCE= GREP_OPTIONS= +unset CLICOLOR_FORCE GREP_OPTIONS + +## --------------------- ## +## M4sh Shell Functions. ## +## --------------------- ## +# as_fn_unset VAR +# --------------- +# Portably unset VAR. +as_fn_unset () +{ + { eval $1=; unset $1;} +} +as_unset=as_fn_unset + +# as_fn_set_status STATUS +# ----------------------- +# Set $? to STATUS, without forking. +as_fn_set_status () +{ + return $1 +} # as_fn_set_status + +# as_fn_exit STATUS +# ----------------- +# Exit the shell with STATUS, even in a "trap 0" or "set -e" context. +as_fn_exit () +{ + set +e + as_fn_set_status $1 + exit $1 +} # as_fn_exit + +# as_fn_mkdir_p +# ------------- +# Create "$as_dir" as a directory, including parents if necessary. +as_fn_mkdir_p () +{ + + case $as_dir in #( + -*) as_dir=./$as_dir;; + esac + test -d "$as_dir" || eval $as_mkdir_p || { + as_dirs= + while :; do + case $as_dir in #( + *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( + *) as_qdir=$as_dir;; + esac + as_dirs="'$as_qdir' $as_dirs" + as_dir=`$as_dirname -- "$as_dir" || +$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$as_dir" : 'X\(//\)[^/]' \| \ + X"$as_dir" : 'X\(//\)$' \| \ + X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$as_dir" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + test -d "$as_dir" && break + done + test -z "$as_dirs" || eval "mkdir $as_dirs" + } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" + + +} # as_fn_mkdir_p + +# as_fn_executable_p FILE +# ----------------------- +# Test if FILE is an executable regular file. +as_fn_executable_p () +{ + test -f "$1" && test -x "$1" +} # as_fn_executable_p +# as_fn_append VAR VALUE +# ---------------------- +# Append the text in VALUE to the end of the definition contained in VAR. Take +# advantage of any shell optimizations that allow amortized linear growth over +# repeated appends, instead of the typical quadratic growth present in naive +# implementations. +if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : + eval 'as_fn_append () + { + eval $1+=\$2 + }' +else + as_fn_append () + { + eval $1=\$$1\$2 + } +fi # as_fn_append + +# as_fn_arith ARG... +# ------------------ +# Perform arithmetic evaluation on the ARGs, and store the result in the +# global $as_val. Take advantage of shells that can avoid forks. The arguments +# must be portable across $(()) and expr. +if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : + eval 'as_fn_arith () + { + as_val=$(( $* )) + }' +else + as_fn_arith () + { + as_val=`expr "$@" || test $? -eq 1` + } +fi # as_fn_arith + + +# as_fn_error STATUS ERROR [LINENO LOG_FD] +# ---------------------------------------- +# Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are +# provided, also output the error to LOG_FD, referencing LINENO. Then exit the +# script with STATUS, using 1 if that was 0. +as_fn_error () +{ + as_status=$1; test $as_status -eq 0 && as_status=1 + if test "$4"; then + as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + $as_echo "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 + fi + $as_echo "$as_me: error: $2" >&2 + as_fn_exit $as_status +} # as_fn_error + +if expr a : '\(a\)' >/dev/null 2>&1 && + test "X`expr 00001 : '.*\(...\)'`" = X001; then + as_expr=expr +else + as_expr=false +fi + +if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then + as_basename=basename +else + as_basename=false +fi + +if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then + as_dirname=dirname +else + as_dirname=false +fi + +as_me=`$as_basename -- "$0" || +$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ + X"$0" : 'X\(//\)$' \| \ + X"$0" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X/"$0" | + sed '/^.*\/\([^/][^/]*\)\/*$/{ + s//\1/ + q + } + /^X\/\(\/\/\)$/{ + s//\1/ + q + } + /^X\/\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + +# Avoid depending upon Character Ranges. +as_cr_letters='abcdefghijklmnopqrstuvwxyz' +as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' +as_cr_Letters=$as_cr_letters$as_cr_LETTERS +as_cr_digits='0123456789' +as_cr_alnum=$as_cr_Letters$as_cr_digits + + + as_lineno_1=$LINENO as_lineno_1a=$LINENO + as_lineno_2=$LINENO as_lineno_2a=$LINENO + eval 'test "x$as_lineno_1'$as_run'" != "x$as_lineno_2'$as_run'" && + test "x`expr $as_lineno_1'$as_run' + 1`" = "x$as_lineno_2'$as_run'"' || { + # Blame Lee E. McMahon (1931-1989) for sed's syntax. :-) + sed -n ' + p + /[$]LINENO/= + ' <$as_myself | + sed ' + s/[$]LINENO.*/&-/ + t lineno + b + :lineno + N + :loop + s/[$]LINENO\([^'$as_cr_alnum'_].*\n\)\(.*\)/\2\1\2/ + t loop + s/-\n.*// + ' >$as_me.lineno && + chmod +x "$as_me.lineno" || + { $as_echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2; as_fn_exit 1; } + + # If we had to re-execute with $CONFIG_SHELL, we're ensured to have + # already done that, so ensure we don't try to do so again and fall + # in an infinite loop. This has already happened in practice. + _as_can_reexec=no; export _as_can_reexec + # Don't try to exec as it changes $[0], causing all sort of problems + # (the dirname of $[0] is not the place where we might find the + # original and so on. Autoconf is especially sensitive to this). + . "./$as_me.lineno" + # Exit status is that of the last command. + exit +} + +ECHO_C= ECHO_N= ECHO_T= +case `echo -n x` in #((((( +-n*) + case `echo 'xy\c'` in + *c*) ECHO_T=' ';; # ECHO_T is single tab character. + xy) ECHO_C='\c';; + *) echo `echo ksh88 bug on AIX 6.1` > /dev/null + ECHO_T=' ';; + esac;; +*) + ECHO_N='-n';; +esac + +rm -f conf$$ conf$$.exe conf$$.file +if test -d conf$$.dir; then + rm -f conf$$.dir/conf$$.file +else + rm -f conf$$.dir + mkdir conf$$.dir 2>/dev/null +fi +if (echo >conf$$.file) 2>/dev/null; then + if ln -s conf$$.file conf$$ 2>/dev/null; then + as_ln_s='ln -s' + # ... but there are two gotchas: + # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. + # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. + # In both cases, we have to default to `cp -pR'. + ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || + as_ln_s='cp -pR' + elif ln conf$$.file conf$$ 2>/dev/null; then + as_ln_s=ln + else + as_ln_s='cp -pR' + fi +else + as_ln_s='cp -pR' +fi +rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file +rmdir conf$$.dir 2>/dev/null + +if mkdir -p . 2>/dev/null; then + as_mkdir_p='mkdir -p "$as_dir"' +else + test -d ./-p && rmdir ./-p + as_mkdir_p=false +fi + +as_test_x='test -x' +as_executable_p=as_fn_executable_p + +# Sed expression to map a string onto a valid CPP name. +as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" + +# Sed expression to map a string onto a valid variable name. +as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" + +SHELL=${CONFIG_SHELL-/bin/sh} + + +test -n "$DJDIR" || exec 7<&0 &1 + +# Name of the host. +# hostname on some systems (SVR3.2, old GNU/Linux) returns a bogus exit status, +# so uname gets run too. +ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q` + +# +# Initializations. +# +ac_default_prefix=/usr/local +ac_clean_files= +ac_config_libobj_dir=. +LIBOBJS= +cross_compiling=no +subdirs= +MFLAGS= +MAKEFLAGS= + +# Identity of this package. +PACKAGE_NAME='libtgvoip' +PACKAGE_TARNAME='libtgvoip' +PACKAGE_VERSION='2.6' +PACKAGE_STRING='libtgvoip 2.6' +PACKAGE_BUGREPORT='https://github.com/grishka/libtgvoip/issues' +PACKAGE_URL='' + +ac_unique_file="config.h.in" +# Factoring default headers for most tests. +ac_includes_default="\ +#include +#ifdef HAVE_SYS_TYPES_H +# include +#endif +#ifdef HAVE_SYS_STAT_H +# include +#endif +#ifdef STDC_HEADERS +# include +# include +#else +# ifdef HAVE_STDLIB_H +# include +# endif +#endif +#ifdef HAVE_STRING_H +# if !defined STDC_HEADERS && defined HAVE_MEMORY_H +# include +# endif +# include +#endif +#ifdef HAVE_STRINGS_H +# include +#endif +#ifdef HAVE_INTTYPES_H +# include +#endif +#ifdef HAVE_STDINT_H +# include +#endif +#ifdef HAVE_UNISTD_H +# include +#endif" + +ac_subst_vars='am__EXEEXT_FALSE +am__EXEEXT_TRUE +LTLIBOBJS +LIBOBJS +ALLOCA +ENABLE_DSP_FALSE +ENABLE_DSP_TRUE +WITH_ALSA_FALSE +WITH_ALSA_TRUE +WITH_PULSE_FALSE +WITH_PULSE_TRUE +ENABLE_AUDIO_CALLBACK_FALSE +ENABLE_AUDIO_CALLBACK_TRUE +TARGET_OS_OSX_FALSE +TARGET_OS_OSX_TRUE +TARGET_CPU_ARMV7_FALSE +TARGET_CPU_ARMV7_TRUE +TARGET_CPU_ARM_FALSE +TARGET_CPU_ARM_TRUE +TARGET_CPU_X86_FALSE +TARGET_CPU_X86_TRUE +am__fastdepCCAS_FALSE +am__fastdepCCAS_TRUE +CCASDEPMODE +CCASFLAGS +CCAS +am__fastdepOBJCXX_FALSE +am__fastdepOBJCXX_TRUE +OBJCXXDEPMODE +ac_ct_OBJCXX +OBJCXXFLAGS +OBJCXX +CXXCPP +am__fastdepCXX_FALSE +am__fastdepCXX_TRUE +CXXDEPMODE +ac_ct_CXX +CXXFLAGS +CXX +CPP +LT_SYS_LIBRARY_PATH +OTOOL64 +OTOOL +LIPO +NMEDIT +DSYMUTIL +MANIFEST_TOOL +RANLIB +ac_ct_AR +AR +DLLTOOL +OBJDUMP +LN_S +NM +ac_ct_DUMPBIN +DUMPBIN +LD +FGREP +EGREP +GREP +SED +am__fastdepCC_FALSE +am__fastdepCC_TRUE +CCDEPMODE +am__nodep +AMDEPBACKSLASH +AMDEP_FALSE +AMDEP_TRUE +am__include +DEPDIR +OBJEXT +EXEEXT +ac_ct_CC +CPPFLAGS +LDFLAGS +CFLAGS +CC +host_os +host_vendor +host_cpu +host +build_os +build_vendor +build_cpu +build +LIBTOOL +AM_BACKSLASH +AM_DEFAULT_VERBOSITY +AM_DEFAULT_V +AM_V +am__untar +am__tar +AMTAR +am__leading_dot +SET_MAKE +AWK +mkdir_p +MKDIR_P +INSTALL_STRIP_PROGRAM +STRIP +install_sh +MAKEINFO +AUTOHEADER +AUTOMAKE +AUTOCONF +ACLOCAL +VERSION +PACKAGE +CYGPATH_W +am__isrc +INSTALL_DATA +INSTALL_SCRIPT +INSTALL_PROGRAM +target_alias +host_alias +build_alias +LIBS +ECHO_T +ECHO_N +ECHO_C +DEFS +mandir +localedir +libdir +psdir +pdfdir +dvidir +htmldir +infodir +docdir +oldincludedir +includedir +localstatedir +sharedstatedir +sysconfdir +datadir +datarootdir +libexecdir +sbindir +bindir +program_transform_name +prefix +exec_prefix +PACKAGE_URL +PACKAGE_BUGREPORT +PACKAGE_STRING +PACKAGE_VERSION +PACKAGE_TARNAME +PACKAGE_NAME +PATH_SEPARATOR +SHELL +am__quote' +ac_subst_files='' +ac_user_opts=' +enable_option_checking +enable_silent_rules +enable_shared +enable_static +with_pic +enable_fast_install +with_aix_soname +enable_dependency_tracking +with_gnu_ld +with_sysroot +enable_libtool_lock +enable_audio_callback +with_pulse +with_alsa +enable_dsp +' + ac_precious_vars='build_alias +host_alias +target_alias +CC +CFLAGS +LDFLAGS +LIBS +CPPFLAGS +LT_SYS_LIBRARY_PATH +CPP +CXX +CXXFLAGS +CCC +CXXCPP +OBJCXX +OBJCXXFLAGS +CCAS +CCASFLAGS' + + +# Initialize some variables set by options. +ac_init_help= +ac_init_version=false +ac_unrecognized_opts= +ac_unrecognized_sep= +# The variables have the same names as the options, with +# dashes changed to underlines. +cache_file=/dev/null +exec_prefix=NONE +no_create= +no_recursion= +prefix=NONE +program_prefix=NONE +program_suffix=NONE +program_transform_name=s,x,x, +silent= +site= +srcdir= +verbose= +x_includes=NONE +x_libraries=NONE + +# Installation directory options. +# These are left unexpanded so users can "make install exec_prefix=/foo" +# and all the variables that are supposed to be based on exec_prefix +# by default will actually change. +# Use braces instead of parens because sh, perl, etc. also accept them. +# (The list follows the same order as the GNU Coding Standards.) +bindir='${exec_prefix}/bin' +sbindir='${exec_prefix}/sbin' +libexecdir='${exec_prefix}/libexec' +datarootdir='${prefix}/share' +datadir='${datarootdir}' +sysconfdir='${prefix}/etc' +sharedstatedir='${prefix}/com' +localstatedir='${prefix}/var' +includedir='${prefix}/include' +oldincludedir='/usr/include' +docdir='${datarootdir}/doc/${PACKAGE_TARNAME}' +infodir='${datarootdir}/info' +htmldir='${docdir}' +dvidir='${docdir}' +pdfdir='${docdir}' +psdir='${docdir}' +libdir='${exec_prefix}/lib' +localedir='${datarootdir}/locale' +mandir='${datarootdir}/man' + +ac_prev= +ac_dashdash= +for ac_option +do + # If the previous option needs an argument, assign it. + if test -n "$ac_prev"; then + eval $ac_prev=\$ac_option + ac_prev= + continue + fi + + case $ac_option in + *=?*) ac_optarg=`expr "X$ac_option" : '[^=]*=\(.*\)'` ;; + *=) ac_optarg= ;; + *) ac_optarg=yes ;; + esac + + # Accept the important Cygnus configure options, so we can diagnose typos. + + case $ac_dashdash$ac_option in + --) + ac_dashdash=yes ;; + + -bindir | --bindir | --bindi | --bind | --bin | --bi) + ac_prev=bindir ;; + -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) + bindir=$ac_optarg ;; + + -build | --build | --buil | --bui | --bu) + ac_prev=build_alias ;; + -build=* | --build=* | --buil=* | --bui=* | --bu=*) + build_alias=$ac_optarg ;; + + -cache-file | --cache-file | --cache-fil | --cache-fi \ + | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) + ac_prev=cache_file ;; + -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ + | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) + cache_file=$ac_optarg ;; + + --config-cache | -C) + cache_file=config.cache ;; + + -datadir | --datadir | --datadi | --datad) + ac_prev=datadir ;; + -datadir=* | --datadir=* | --datadi=* | --datad=*) + datadir=$ac_optarg ;; + + -datarootdir | --datarootdir | --datarootdi | --datarootd | --dataroot \ + | --dataroo | --dataro | --datar) + ac_prev=datarootdir ;; + -datarootdir=* | --datarootdir=* | --datarootdi=* | --datarootd=* \ + | --dataroot=* | --dataroo=* | --dataro=* | --datar=*) + datarootdir=$ac_optarg ;; + + -disable-* | --disable-*) + ac_useropt=`expr "x$ac_option" : 'x-*disable-\(.*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && + as_fn_error $? "invalid feature name: $ac_useropt" + ac_useropt_orig=$ac_useropt + ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` + case $ac_user_opts in + *" +"enable_$ac_useropt" +"*) ;; + *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--disable-$ac_useropt_orig" + ac_unrecognized_sep=', ';; + esac + eval enable_$ac_useropt=no ;; + + -docdir | --docdir | --docdi | --doc | --do) + ac_prev=docdir ;; + -docdir=* | --docdir=* | --docdi=* | --doc=* | --do=*) + docdir=$ac_optarg ;; + + -dvidir | --dvidir | --dvidi | --dvid | --dvi | --dv) + ac_prev=dvidir ;; + -dvidir=* | --dvidir=* | --dvidi=* | --dvid=* | --dvi=* | --dv=*) + dvidir=$ac_optarg ;; + + -enable-* | --enable-*) + ac_useropt=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && + as_fn_error $? "invalid feature name: $ac_useropt" + ac_useropt_orig=$ac_useropt + ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` + case $ac_user_opts in + *" +"enable_$ac_useropt" +"*) ;; + *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--enable-$ac_useropt_orig" + ac_unrecognized_sep=', ';; + esac + eval enable_$ac_useropt=\$ac_optarg ;; + + -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ + | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ + | --exec | --exe | --ex) + ac_prev=exec_prefix ;; + -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ + | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ + | --exec=* | --exe=* | --ex=*) + exec_prefix=$ac_optarg ;; + + -gas | --gas | --ga | --g) + # Obsolete; use --with-gas. + with_gas=yes ;; + + -help | --help | --hel | --he | -h) + ac_init_help=long ;; + -help=r* | --help=r* | --hel=r* | --he=r* | -hr*) + ac_init_help=recursive ;; + -help=s* | --help=s* | --hel=s* | --he=s* | -hs*) + ac_init_help=short ;; + + -host | --host | --hos | --ho) + ac_prev=host_alias ;; + -host=* | --host=* | --hos=* | --ho=*) + host_alias=$ac_optarg ;; + + -htmldir | --htmldir | --htmldi | --htmld | --html | --htm | --ht) + ac_prev=htmldir ;; + -htmldir=* | --htmldir=* | --htmldi=* | --htmld=* | --html=* | --htm=* \ + | --ht=*) + htmldir=$ac_optarg ;; + + -includedir | --includedir | --includedi | --included | --include \ + | --includ | --inclu | --incl | --inc) + ac_prev=includedir ;; + -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ + | --includ=* | --inclu=* | --incl=* | --inc=*) + includedir=$ac_optarg ;; + + -infodir | --infodir | --infodi | --infod | --info | --inf) + ac_prev=infodir ;; + -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) + infodir=$ac_optarg ;; + + -libdir | --libdir | --libdi | --libd) + ac_prev=libdir ;; + -libdir=* | --libdir=* | --libdi=* | --libd=*) + libdir=$ac_optarg ;; + + -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ + | --libexe | --libex | --libe) + ac_prev=libexecdir ;; + -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ + | --libexe=* | --libex=* | --libe=*) + libexecdir=$ac_optarg ;; + + -localedir | --localedir | --localedi | --localed | --locale) + ac_prev=localedir ;; + -localedir=* | --localedir=* | --localedi=* | --localed=* | --locale=*) + localedir=$ac_optarg ;; + + -localstatedir | --localstatedir | --localstatedi | --localstated \ + | --localstate | --localstat | --localsta | --localst | --locals) + ac_prev=localstatedir ;; + -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ + | --localstate=* | --localstat=* | --localsta=* | --localst=* | --locals=*) + localstatedir=$ac_optarg ;; + + -mandir | --mandir | --mandi | --mand | --man | --ma | --m) + ac_prev=mandir ;; + -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) + mandir=$ac_optarg ;; + + -nfp | --nfp | --nf) + # Obsolete; use --without-fp. + with_fp=no ;; + + -no-create | --no-create | --no-creat | --no-crea | --no-cre \ + | --no-cr | --no-c | -n) + no_create=yes ;; + + -no-recursion | --no-recursion | --no-recursio | --no-recursi \ + | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) + no_recursion=yes ;; + + -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ + | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ + | --oldin | --oldi | --old | --ol | --o) + ac_prev=oldincludedir ;; + -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ + | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ + | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) + oldincludedir=$ac_optarg ;; + + -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) + ac_prev=prefix ;; + -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) + prefix=$ac_optarg ;; + + -program-prefix | --program-prefix | --program-prefi | --program-pref \ + | --program-pre | --program-pr | --program-p) + ac_prev=program_prefix ;; + -program-prefix=* | --program-prefix=* | --program-prefi=* \ + | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) + program_prefix=$ac_optarg ;; + + -program-suffix | --program-suffix | --program-suffi | --program-suff \ + | --program-suf | --program-su | --program-s) + ac_prev=program_suffix ;; + -program-suffix=* | --program-suffix=* | --program-suffi=* \ + | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) + program_suffix=$ac_optarg ;; + + -program-transform-name | --program-transform-name \ + | --program-transform-nam | --program-transform-na \ + | --program-transform-n | --program-transform- \ + | --program-transform | --program-transfor \ + | --program-transfo | --program-transf \ + | --program-trans | --program-tran \ + | --progr-tra | --program-tr | --program-t) + ac_prev=program_transform_name ;; + -program-transform-name=* | --program-transform-name=* \ + | --program-transform-nam=* | --program-transform-na=* \ + | --program-transform-n=* | --program-transform-=* \ + | --program-transform=* | --program-transfor=* \ + | --program-transfo=* | --program-transf=* \ + | --program-trans=* | --program-tran=* \ + | --progr-tra=* | --program-tr=* | --program-t=*) + program_transform_name=$ac_optarg ;; + + -pdfdir | --pdfdir | --pdfdi | --pdfd | --pdf | --pd) + ac_prev=pdfdir ;; + -pdfdir=* | --pdfdir=* | --pdfdi=* | --pdfd=* | --pdf=* | --pd=*) + pdfdir=$ac_optarg ;; + + -psdir | --psdir | --psdi | --psd | --ps) + ac_prev=psdir ;; + -psdir=* | --psdir=* | --psdi=* | --psd=* | --ps=*) + psdir=$ac_optarg ;; + + -q | -quiet | --quiet | --quie | --qui | --qu | --q \ + | -silent | --silent | --silen | --sile | --sil) + silent=yes ;; + + -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) + ac_prev=sbindir ;; + -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ + | --sbi=* | --sb=*) + sbindir=$ac_optarg ;; + + -sharedstatedir | --sharedstatedir | --sharedstatedi \ + | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ + | --sharedst | --shareds | --shared | --share | --shar \ + | --sha | --sh) + ac_prev=sharedstatedir ;; + -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ + | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ + | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ + | --sha=* | --sh=*) + sharedstatedir=$ac_optarg ;; + + -site | --site | --sit) + ac_prev=site ;; + -site=* | --site=* | --sit=*) + site=$ac_optarg ;; + + -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) + ac_prev=srcdir ;; + -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) + srcdir=$ac_optarg ;; + + -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ + | --syscon | --sysco | --sysc | --sys | --sy) + ac_prev=sysconfdir ;; + -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ + | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) + sysconfdir=$ac_optarg ;; + + -target | --target | --targe | --targ | --tar | --ta | --t) + ac_prev=target_alias ;; + -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) + target_alias=$ac_optarg ;; + + -v | -verbose | --verbose | --verbos | --verbo | --verb) + verbose=yes ;; + + -version | --version | --versio | --versi | --vers | -V) + ac_init_version=: ;; + + -with-* | --with-*) + ac_useropt=`expr "x$ac_option" : 'x-*with-\([^=]*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && + as_fn_error $? "invalid package name: $ac_useropt" + ac_useropt_orig=$ac_useropt + ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` + case $ac_user_opts in + *" +"with_$ac_useropt" +"*) ;; + *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--with-$ac_useropt_orig" + ac_unrecognized_sep=', ';; + esac + eval with_$ac_useropt=\$ac_optarg ;; + + -without-* | --without-*) + ac_useropt=`expr "x$ac_option" : 'x-*without-\(.*\)'` + # Reject names that are not valid shell variable names. + expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && + as_fn_error $? "invalid package name: $ac_useropt" + ac_useropt_orig=$ac_useropt + ac_useropt=`$as_echo "$ac_useropt" | sed 's/[-+.]/_/g'` + case $ac_user_opts in + *" +"with_$ac_useropt" +"*) ;; + *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--without-$ac_useropt_orig" + ac_unrecognized_sep=', ';; + esac + eval with_$ac_useropt=no ;; + + --x) + # Obsolete; use --with-x. + with_x=yes ;; + + -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ + | --x-incl | --x-inc | --x-in | --x-i) + ac_prev=x_includes ;; + -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ + | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) + x_includes=$ac_optarg ;; + + -x-libraries | --x-libraries | --x-librarie | --x-librari \ + | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) + ac_prev=x_libraries ;; + -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ + | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) + x_libraries=$ac_optarg ;; + + -*) as_fn_error $? "unrecognized option: \`$ac_option' +Try \`$0 --help' for more information" + ;; + + *=*) + ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='` + # Reject names that are not valid shell variable names. + case $ac_envvar in #( + '' | [0-9]* | *[!_$as_cr_alnum]* ) + as_fn_error $? "invalid variable name: \`$ac_envvar'" ;; + esac + eval $ac_envvar=\$ac_optarg + export $ac_envvar ;; + + *) + # FIXME: should be removed in autoconf 3.0. + $as_echo "$as_me: WARNING: you should use --build, --host, --target" >&2 + expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && + $as_echo "$as_me: WARNING: invalid host type: $ac_option" >&2 + : "${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option}" + ;; + + esac +done + +if test -n "$ac_prev"; then + ac_option=--`echo $ac_prev | sed 's/_/-/g'` + as_fn_error $? "missing argument to $ac_option" +fi + +if test -n "$ac_unrecognized_opts"; then + case $enable_option_checking in + no) ;; + fatal) as_fn_error $? "unrecognized options: $ac_unrecognized_opts" ;; + *) $as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2 ;; + esac +fi + +# Check all directory arguments for consistency. +for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \ + datadir sysconfdir sharedstatedir localstatedir includedir \ + oldincludedir docdir infodir htmldir dvidir pdfdir psdir \ + libdir localedir mandir +do + eval ac_val=\$$ac_var + # Remove trailing slashes. + case $ac_val in + */ ) + ac_val=`expr "X$ac_val" : 'X\(.*[^/]\)' \| "X$ac_val" : 'X\(.*\)'` + eval $ac_var=\$ac_val;; + esac + # Be sure to have absolute directory names. + case $ac_val in + [\\/$]* | ?:[\\/]* ) continue;; + NONE | '' ) case $ac_var in *prefix ) continue;; esac;; + esac + as_fn_error $? "expected an absolute directory name for --$ac_var: $ac_val" +done + +# There might be people who depend on the old broken behavior: `$host' +# used to hold the argument of --host etc. +# FIXME: To remove some day. +build=$build_alias +host=$host_alias +target=$target_alias + +# FIXME: To remove some day. +if test "x$host_alias" != x; then + if test "x$build_alias" = x; then + cross_compiling=maybe + elif test "x$build_alias" != "x$host_alias"; then + cross_compiling=yes + fi +fi + +ac_tool_prefix= +test -n "$host_alias" && ac_tool_prefix=$host_alias- + +test "$silent" = yes && exec 6>/dev/null + + +ac_pwd=`pwd` && test -n "$ac_pwd" && +ac_ls_di=`ls -di .` && +ac_pwd_ls_di=`cd "$ac_pwd" && ls -di .` || + as_fn_error $? "working directory cannot be determined" +test "X$ac_ls_di" = "X$ac_pwd_ls_di" || + as_fn_error $? "pwd does not report name of working directory" + + +# Find the source files, if location was not specified. +if test -z "$srcdir"; then + ac_srcdir_defaulted=yes + # Try the directory containing this script, then the parent directory. + ac_confdir=`$as_dirname -- "$as_myself" || +$as_expr X"$as_myself" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$as_myself" : 'X\(//\)[^/]' \| \ + X"$as_myself" : 'X\(//\)$' \| \ + X"$as_myself" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$as_myself" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + srcdir=$ac_confdir + if test ! -r "$srcdir/$ac_unique_file"; then + srcdir=.. + fi +else + ac_srcdir_defaulted=no +fi +if test ! -r "$srcdir/$ac_unique_file"; then + test "$ac_srcdir_defaulted" = yes && srcdir="$ac_confdir or .." + as_fn_error $? "cannot find sources ($ac_unique_file) in $srcdir" +fi +ac_msg="sources are in $srcdir, but \`cd $srcdir' does not work" +ac_abs_confdir=`( + cd "$srcdir" && test -r "./$ac_unique_file" || as_fn_error $? "$ac_msg" + pwd)` +# When building in place, set srcdir=. +if test "$ac_abs_confdir" = "$ac_pwd"; then + srcdir=. +fi +# Remove unnecessary trailing slashes from srcdir. +# Double slashes in file names in object file debugging info +# mess up M-x gdb in Emacs. +case $srcdir in +*/) srcdir=`expr "X$srcdir" : 'X\(.*[^/]\)' \| "X$srcdir" : 'X\(.*\)'`;; +esac +for ac_var in $ac_precious_vars; do + eval ac_env_${ac_var}_set=\${${ac_var}+set} + eval ac_env_${ac_var}_value=\$${ac_var} + eval ac_cv_env_${ac_var}_set=\${${ac_var}+set} + eval ac_cv_env_${ac_var}_value=\$${ac_var} +done + +# +# Report the --help message. +# +if test "$ac_init_help" = "long"; then + # Omit some internal or obsolete options to make the list less imposing. + # This message is too long to be a string in the A/UX 3.1 sh. + cat <<_ACEOF +\`configure' configures libtgvoip 2.6 to adapt to many kinds of systems. + +Usage: $0 [OPTION]... [VAR=VALUE]... + +To assign environment variables (e.g., CC, CFLAGS...), specify them as +VAR=VALUE. See below for descriptions of some of the useful variables. + +Defaults for the options are specified in brackets. + +Configuration: + -h, --help display this help and exit + --help=short display options specific to this package + --help=recursive display the short help of all the included packages + -V, --version display version information and exit + -q, --quiet, --silent do not print \`checking ...' messages + --cache-file=FILE cache test results in FILE [disabled] + -C, --config-cache alias for \`--cache-file=config.cache' + -n, --no-create do not create output files + --srcdir=DIR find the sources in DIR [configure dir or \`..'] + +Installation directories: + --prefix=PREFIX install architecture-independent files in PREFIX + [$ac_default_prefix] + --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX + [PREFIX] + +By default, \`make install' will install all the files in +\`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify +an installation prefix other than \`$ac_default_prefix' using \`--prefix', +for instance \`--prefix=\$HOME'. + +For better control, use the options below. + +Fine tuning of the installation directories: + --bindir=DIR user executables [EPREFIX/bin] + --sbindir=DIR system admin executables [EPREFIX/sbin] + --libexecdir=DIR program executables [EPREFIX/libexec] + --sysconfdir=DIR read-only single-machine data [PREFIX/etc] + --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] + --localstatedir=DIR modifiable single-machine data [PREFIX/var] + --libdir=DIR object code libraries [EPREFIX/lib] + --includedir=DIR C header files [PREFIX/include] + --oldincludedir=DIR C header files for non-gcc [/usr/include] + --datarootdir=DIR read-only arch.-independent data root [PREFIX/share] + --datadir=DIR read-only architecture-independent data [DATAROOTDIR] + --infodir=DIR info documentation [DATAROOTDIR/info] + --localedir=DIR locale-dependent data [DATAROOTDIR/locale] + --mandir=DIR man documentation [DATAROOTDIR/man] + --docdir=DIR documentation root [DATAROOTDIR/doc/libtgvoip] + --htmldir=DIR html documentation [DOCDIR] + --dvidir=DIR dvi documentation [DOCDIR] + --pdfdir=DIR pdf documentation [DOCDIR] + --psdir=DIR ps documentation [DOCDIR] +_ACEOF + + cat <<\_ACEOF + +Program names: + --program-prefix=PREFIX prepend PREFIX to installed program names + --program-suffix=SUFFIX append SUFFIX to installed program names + --program-transform-name=PROGRAM run sed PROGRAM on installed program names + +System types: + --build=BUILD configure for building on BUILD [guessed] + --host=HOST cross-compile to build programs to run on HOST [BUILD] +_ACEOF +fi + +if test -n "$ac_init_help"; then + case $ac_init_help in + short | recursive ) echo "Configuration of libtgvoip 2.6:";; + esac + cat <<\_ACEOF + +Optional Features: + --disable-option-checking ignore unrecognized --enable/--with options + --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) + --enable-FEATURE[=ARG] include FEATURE [ARG=yes] + --enable-silent-rules less verbose build output (undo: "make V=1") + --disable-silent-rules verbose build output (undo: "make V=0") + --enable-shared[=PKGS] build shared libraries [default=yes] + --enable-static[=PKGS] build static libraries [default=yes] + --enable-fast-install[=PKGS] + optimize for fast installation [default=yes] + --enable-dependency-tracking + do not reject slow dependency extractors + --disable-dependency-tracking + speeds up one-time build + --disable-libtool-lock avoid locking (might break parallel builds) + --enable-audio-callback enable callback-based audio I/O + --disable-dsp disable signal processing (echo cancellation, noise + suppression, and automatic gain control) + +Optional Packages: + --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] + --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) + --with-pic[=PKGS] try to use only PIC/non-PIC objects [default=use + both] + --with-aix-soname=aix|svr4|both + shared library versioning (aka "SONAME") variant to + provide on AIX, [default=aix]. + --with-gnu-ld assume the C compiler uses GNU ld [default=no] + --with-sysroot[=DIR] Search for dependent libraries within DIR (or the + compiler's sysroot if not specified). + --without-pulse disable PulseAudio support + --without-alsa disable ALSA support + +Some influential environment variables: + CC C compiler command + CFLAGS C compiler flags + LDFLAGS linker flags, e.g. -L if you have libraries in a + nonstandard directory + LIBS libraries to pass to the linker, e.g. -l + CPPFLAGS (Objective) C/C++ preprocessor flags, e.g. -I if + you have headers in a nonstandard directory + LT_SYS_LIBRARY_PATH + User-defined run-time library search path. + CPP C preprocessor + CXX C++ compiler command + CXXFLAGS C++ compiler flags + CXXCPP C++ preprocessor + OBJCXX Objective C++ compiler command + OBJCXXFLAGS Objective C++ compiler flags + CCAS assembler compiler command (defaults to CC) + CCASFLAGS assembler compiler flags (defaults to CFLAGS) + +Use these variables to override the choices made by `configure' or to help +it to find libraries and programs with nonstandard names/locations. + +Report bugs to . +_ACEOF +ac_status=$? +fi + +if test "$ac_init_help" = "recursive"; then + # If there are subdirs, report their specific --help. + for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue + test -d "$ac_dir" || + { cd "$srcdir" && ac_pwd=`pwd` && srcdir=. && test -d "$ac_dir"; } || + continue + ac_builddir=. + +case "$ac_dir" in +.) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; +*) + ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` + # A ".." for each directory in $ac_dir_suffix. + ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` + case $ac_top_builddir_sub in + "") ac_top_builddir_sub=. ac_top_build_prefix= ;; + *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; + esac ;; +esac +ac_abs_top_builddir=$ac_pwd +ac_abs_builddir=$ac_pwd$ac_dir_suffix +# for backward compatibility: +ac_top_builddir=$ac_top_build_prefix + +case $srcdir in + .) # We are building in place. + ac_srcdir=. + ac_top_srcdir=$ac_top_builddir_sub + ac_abs_top_srcdir=$ac_pwd ;; + [\\/]* | ?:[\\/]* ) # Absolute name. + ac_srcdir=$srcdir$ac_dir_suffix; + ac_top_srcdir=$srcdir + ac_abs_top_srcdir=$srcdir ;; + *) # Relative name. + ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix + ac_top_srcdir=$ac_top_build_prefix$srcdir + ac_abs_top_srcdir=$ac_pwd/$srcdir ;; +esac +ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix + + cd "$ac_dir" || { ac_status=$?; continue; } + # Check for guested configure. + if test -f "$ac_srcdir/configure.gnu"; then + echo && + $SHELL "$ac_srcdir/configure.gnu" --help=recursive + elif test -f "$ac_srcdir/configure"; then + echo && + $SHELL "$ac_srcdir/configure" --help=recursive + else + $as_echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2 + fi || ac_status=$? + cd "$ac_pwd" || { ac_status=$?; break; } + done +fi + +test -n "$ac_init_help" && exit $ac_status +if $ac_init_version; then + cat <<\_ACEOF +libtgvoip configure 2.6 +generated by GNU Autoconf 2.69 + +Copyright (C) 2012 Free Software Foundation, Inc. +This configure script is free software; the Free Software Foundation +gives unlimited permission to copy, distribute and modify it. +_ACEOF + exit +fi + +## ------------------------ ## +## Autoconf initialization. ## +## ------------------------ ## + +# ac_fn_c_try_compile LINENO +# -------------------------- +# Try to compile conftest.$ac_ext, and return whether this succeeded. +ac_fn_c_try_compile () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + rm -f conftest.$ac_objext + if { { ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compile") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + grep -v '^ *+' conftest.err >conftest.er1 + cat conftest.er1 >&5 + mv -f conftest.er1 conftest.err + fi + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then : + ac_retval=0 +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_retval=1 +fi + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + as_fn_set_status $ac_retval + +} # ac_fn_c_try_compile + +# ac_fn_c_try_link LINENO +# ----------------------- +# Try to link conftest.$ac_ext, and return whether this succeeded. +ac_fn_c_try_link () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + rm -f conftest.$ac_objext conftest$ac_exeext + if { { ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + grep -v '^ *+' conftest.err >conftest.er1 + cat conftest.er1 >&5 + mv -f conftest.er1 conftest.err + fi + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } && { + test -z "$ac_c_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + test -x conftest$ac_exeext + }; then : + ac_retval=0 +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_retval=1 +fi + # Delete the IPA/IPO (Inter Procedural Analysis/Optimization) information + # created by the PGI compiler (conftest_ipa8_conftest.oo), as it would + # interfere with the next link command; also delete a directory that is + # left behind by Apple's compiler. We do this before executing the actions. + rm -rf conftest.dSYM conftest_ipa8_conftest.oo + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + as_fn_set_status $ac_retval + +} # ac_fn_c_try_link + +# ac_fn_c_check_header_compile LINENO HEADER VAR INCLUDES +# ------------------------------------------------------- +# Tests whether HEADER exists and can be compiled using the include files in +# INCLUDES, setting the cache variable VAR accordingly. +ac_fn_c_check_header_compile () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 +$as_echo_n "checking for $2... " >&6; } +if eval \${$3+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +$4 +#include <$2> +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + eval "$3=yes" +else + eval "$3=no" +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +eval ac_res=\$$3 + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + +} # ac_fn_c_check_header_compile + +# ac_fn_c_try_cpp LINENO +# ---------------------- +# Try to preprocess conftest.$ac_ext, and return whether this succeeded. +ac_fn_c_try_cpp () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + if { { ac_try="$ac_cpp conftest.$ac_ext" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_cpp conftest.$ac_ext") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + grep -v '^ *+' conftest.err >conftest.er1 + cat conftest.er1 >&5 + mv -f conftest.er1 conftest.err + fi + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } > conftest.i && { + test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || + test ! -s conftest.err + }; then : + ac_retval=0 +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_retval=1 +fi + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + as_fn_set_status $ac_retval + +} # ac_fn_c_try_cpp + +# ac_fn_c_try_run LINENO +# ---------------------- +# Try to link conftest.$ac_ext, and return whether this succeeded. Assumes +# that executables *can* be run. +ac_fn_c_try_run () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + if { { ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } && { ac_try='./conftest$ac_exeext' + { { case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; }; then : + ac_retval=0 +else + $as_echo "$as_me: program exited with status $ac_status" >&5 + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_retval=$ac_status +fi + rm -rf conftest.dSYM conftest_ipa8_conftest.oo + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + as_fn_set_status $ac_retval + +} # ac_fn_c_try_run + +# ac_fn_c_check_func LINENO FUNC VAR +# ---------------------------------- +# Tests whether FUNC exists, setting the cache variable VAR accordingly +ac_fn_c_check_func () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 +$as_echo_n "checking for $2... " >&6; } +if eval \${$3+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +/* Define $2 to an innocuous variant, in case declares $2. + For example, HP-UX 11i declares gettimeofday. */ +#define $2 innocuous_$2 + +/* System header to define __stub macros and hopefully few prototypes, + which can conflict with char $2 (); below. + Prefer to if __STDC__ is defined, since + exists even on freestanding compilers. */ + +#ifdef __STDC__ +# include +#else +# include +#endif + +#undef $2 + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char $2 (); +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined __stub_$2 || defined __stub___$2 +choke me +#endif + +int +main () +{ +return $2 (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + eval "$3=yes" +else + eval "$3=no" +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +eval ac_res=\$$3 + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + +} # ac_fn_c_check_func + +# ac_fn_cxx_try_compile LINENO +# ---------------------------- +# Try to compile conftest.$ac_ext, and return whether this succeeded. +ac_fn_cxx_try_compile () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + rm -f conftest.$ac_objext + if { { ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compile") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + grep -v '^ *+' conftest.err >conftest.er1 + cat conftest.er1 >&5 + mv -f conftest.er1 conftest.err + fi + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then : + ac_retval=0 +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_retval=1 +fi + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + as_fn_set_status $ac_retval + +} # ac_fn_cxx_try_compile + +# ac_fn_cxx_try_cpp LINENO +# ------------------------ +# Try to preprocess conftest.$ac_ext, and return whether this succeeded. +ac_fn_cxx_try_cpp () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + if { { ac_try="$ac_cpp conftest.$ac_ext" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_cpp conftest.$ac_ext") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + grep -v '^ *+' conftest.err >conftest.er1 + cat conftest.er1 >&5 + mv -f conftest.er1 conftest.err + fi + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } > conftest.i && { + test -z "$ac_cxx_preproc_warn_flag$ac_cxx_werror_flag" || + test ! -s conftest.err + }; then : + ac_retval=0 +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_retval=1 +fi + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + as_fn_set_status $ac_retval + +} # ac_fn_cxx_try_cpp + +# ac_fn_cxx_try_link LINENO +# ------------------------- +# Try to link conftest.$ac_ext, and return whether this succeeded. +ac_fn_cxx_try_link () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + rm -f conftest.$ac_objext conftest$ac_exeext + if { { ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + grep -v '^ *+' conftest.err >conftest.er1 + cat conftest.er1 >&5 + mv -f conftest.er1 conftest.err + fi + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest$ac_exeext && { + test "$cross_compiling" = yes || + test -x conftest$ac_exeext + }; then : + ac_retval=0 +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_retval=1 +fi + # Delete the IPA/IPO (Inter Procedural Analysis/Optimization) information + # created by the PGI compiler (conftest_ipa8_conftest.oo), as it would + # interfere with the next link command; also delete a directory that is + # left behind by Apple's compiler. We do this before executing the actions. + rm -rf conftest.dSYM conftest_ipa8_conftest.oo + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + as_fn_set_status $ac_retval + +} # ac_fn_cxx_try_link + +# ac_fn_objcxx_try_compile LINENO +# ------------------------------- +# Try to compile conftest.$ac_ext, and return whether this succeeded. +ac_fn_objcxx_try_compile () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + rm -f conftest.$ac_objext + if { { ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compile") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + grep -v '^ *+' conftest.err >conftest.er1 + cat conftest.er1 >&5 + mv -f conftest.er1 conftest.err + fi + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } && { + test -z "$ac_objcxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then : + ac_retval=0 +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + ac_retval=1 +fi + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + as_fn_set_status $ac_retval + +} # ac_fn_objcxx_try_compile + +# ac_fn_c_check_type LINENO TYPE VAR INCLUDES +# ------------------------------------------- +# Tests whether TYPE exists after having included INCLUDES, setting cache +# variable VAR accordingly. +ac_fn_c_check_type () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 +$as_echo_n "checking for $2... " >&6; } +if eval \${$3+:} false; then : + $as_echo_n "(cached) " >&6 +else + eval "$3=no" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +$4 +int +main () +{ +if (sizeof ($2)) + return 0; + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +$4 +int +main () +{ +if (sizeof (($2))) + return 0; + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + +else + eval "$3=yes" +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +eval ac_res=\$$3 + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + +} # ac_fn_c_check_type + +# ac_fn_c_check_header_mongrel LINENO HEADER VAR INCLUDES +# ------------------------------------------------------- +# Tests whether HEADER exists, giving a warning if it cannot be compiled using +# the include files in INCLUDES and setting the cache variable VAR +# accordingly. +ac_fn_c_check_header_mongrel () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + if eval \${$3+:} false; then : + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 +$as_echo_n "checking for $2... " >&6; } +if eval \${$3+:} false; then : + $as_echo_n "(cached) " >&6 +fi +eval ac_res=\$$3 + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } +else + # Is the header compilable? +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking $2 usability" >&5 +$as_echo_n "checking $2 usability... " >&6; } +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +$4 +#include <$2> +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_header_compiler=yes +else + ac_header_compiler=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_header_compiler" >&5 +$as_echo "$ac_header_compiler" >&6; } + +# Is the header present? +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking $2 presence" >&5 +$as_echo_n "checking $2 presence... " >&6; } +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include <$2> +_ACEOF +if ac_fn_c_try_cpp "$LINENO"; then : + ac_header_preproc=yes +else + ac_header_preproc=no +fi +rm -f conftest.err conftest.i conftest.$ac_ext +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_header_preproc" >&5 +$as_echo "$ac_header_preproc" >&6; } + +# So? What about this header? +case $ac_header_compiler:$ac_header_preproc:$ac_c_preproc_warn_flag in #(( + yes:no: ) + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: accepted by the compiler, rejected by the preprocessor!" >&5 +$as_echo "$as_me: WARNING: $2: accepted by the compiler, rejected by the preprocessor!" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: proceeding with the compiler's result" >&5 +$as_echo "$as_me: WARNING: $2: proceeding with the compiler's result" >&2;} + ;; + no:yes:* ) + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: present but cannot be compiled" >&5 +$as_echo "$as_me: WARNING: $2: present but cannot be compiled" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: check for missing prerequisite headers?" >&5 +$as_echo "$as_me: WARNING: $2: check for missing prerequisite headers?" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: see the Autoconf documentation" >&5 +$as_echo "$as_me: WARNING: $2: see the Autoconf documentation" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: section \"Present But Cannot Be Compiled\"" >&5 +$as_echo "$as_me: WARNING: $2: section \"Present But Cannot Be Compiled\"" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $2: proceeding with the compiler's result" >&5 +$as_echo "$as_me: WARNING: $2: proceeding with the compiler's result" >&2;} +( $as_echo "## ---------------------------------------------------------- ## +## Report this to https://github.com/grishka/libtgvoip/issues ## +## ---------------------------------------------------------- ##" + ) | sed "s/^/$as_me: WARNING: /" >&2 + ;; +esac + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 +$as_echo_n "checking for $2... " >&6; } +if eval \${$3+:} false; then : + $as_echo_n "(cached) " >&6 +else + eval "$3=\$ac_header_compiler" +fi +eval ac_res=\$$3 + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } +fi + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + +} # ac_fn_c_check_header_mongrel + +# ac_fn_c_find_intX_t LINENO BITS VAR +# ----------------------------------- +# Finds a signed integer type with width BITS, setting cache variable VAR +# accordingly. +ac_fn_c_find_intX_t () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for int$2_t" >&5 +$as_echo_n "checking for int$2_t... " >&6; } +if eval \${$3+:} false; then : + $as_echo_n "(cached) " >&6 +else + eval "$3=no" + # Order is important - never check a type that is potentially smaller + # than half of the expected target width. + for ac_type in int$2_t 'int' 'long int' \ + 'long long int' 'short int' 'signed char'; do + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +$ac_includes_default + enum { N = $2 / 2 - 1 }; +int +main () +{ +static int test_array [1 - 2 * !(0 < ($ac_type) ((((($ac_type) 1 << N) << N) - 1) * 2 + 1))]; +test_array [0] = 0; +return test_array [0]; + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +$ac_includes_default + enum { N = $2 / 2 - 1 }; +int +main () +{ +static int test_array [1 - 2 * !(($ac_type) ((((($ac_type) 1 << N) << N) - 1) * 2 + 1) + < ($ac_type) ((((($ac_type) 1 << N) << N) - 1) * 2 + 2))]; +test_array [0] = 0; +return test_array [0]; + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + +else + case $ac_type in #( + int$2_t) : + eval "$3=yes" ;; #( + *) : + eval "$3=\$ac_type" ;; +esac +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + if eval test \"x\$"$3"\" = x"no"; then : + +else + break +fi + done +fi +eval ac_res=\$$3 + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + +} # ac_fn_c_find_intX_t + +# ac_fn_c_find_uintX_t LINENO BITS VAR +# ------------------------------------ +# Finds an unsigned integer type with width BITS, setting cache variable VAR +# accordingly. +ac_fn_c_find_uintX_t () +{ + as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for uint$2_t" >&5 +$as_echo_n "checking for uint$2_t... " >&6; } +if eval \${$3+:} false; then : + $as_echo_n "(cached) " >&6 +else + eval "$3=no" + # Order is important - never check a type that is potentially smaller + # than half of the expected target width. + for ac_type in uint$2_t 'unsigned int' 'unsigned long int' \ + 'unsigned long long int' 'unsigned short int' 'unsigned char'; do + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +$ac_includes_default +int +main () +{ +static int test_array [1 - 2 * !((($ac_type) -1 >> ($2 / 2 - 1)) >> ($2 / 2 - 1) == 3)]; +test_array [0] = 0; +return test_array [0]; + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + case $ac_type in #( + uint$2_t) : + eval "$3=yes" ;; #( + *) : + eval "$3=\$ac_type" ;; +esac +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + if eval test \"x\$"$3"\" = x"no"; then : + +else + break +fi + done +fi +eval ac_res=\$$3 + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 +$as_echo "$ac_res" >&6; } + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno + +} # ac_fn_c_find_uintX_t +cat >config.log <<_ACEOF +This file contains any messages produced by compilers while +running configure, to aid debugging if configure makes a mistake. + +It was created by libtgvoip $as_me 2.6, which was +generated by GNU Autoconf 2.69. Invocation command line was + + $ $0 $@ + +_ACEOF +exec 5>>config.log +{ +cat <<_ASUNAME +## --------- ## +## Platform. ## +## --------- ## + +hostname = `(hostname || uname -n) 2>/dev/null | sed 1q` +uname -m = `(uname -m) 2>/dev/null || echo unknown` +uname -r = `(uname -r) 2>/dev/null || echo unknown` +uname -s = `(uname -s) 2>/dev/null || echo unknown` +uname -v = `(uname -v) 2>/dev/null || echo unknown` + +/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown` +/bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown` + +/bin/arch = `(/bin/arch) 2>/dev/null || echo unknown` +/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown` +/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown` +/usr/bin/hostinfo = `(/usr/bin/hostinfo) 2>/dev/null || echo unknown` +/bin/machine = `(/bin/machine) 2>/dev/null || echo unknown` +/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown` +/bin/universe = `(/bin/universe) 2>/dev/null || echo unknown` + +_ASUNAME + +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + $as_echo "PATH: $as_dir" + done +IFS=$as_save_IFS + +} >&5 + +cat >&5 <<_ACEOF + + +## ----------- ## +## Core tests. ## +## ----------- ## + +_ACEOF + + +# Keep a trace of the command line. +# Strip out --no-create and --no-recursion so they do not pile up. +# Strip out --silent because we don't want to record it for future runs. +# Also quote any args containing shell meta-characters. +# Make two passes to allow for proper duplicate-argument suppression. +ac_configure_args= +ac_configure_args0= +ac_configure_args1= +ac_must_keep_next=false +for ac_pass in 1 2 +do + for ac_arg + do + case $ac_arg in + -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;; + -q | -quiet | --quiet | --quie | --qui | --qu | --q \ + | -silent | --silent | --silen | --sile | --sil) + continue ;; + *\'*) + ac_arg=`$as_echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; + esac + case $ac_pass in + 1) as_fn_append ac_configure_args0 " '$ac_arg'" ;; + 2) + as_fn_append ac_configure_args1 " '$ac_arg'" + if test $ac_must_keep_next = true; then + ac_must_keep_next=false # Got value, back to normal. + else + case $ac_arg in + *=* | --config-cache | -C | -disable-* | --disable-* \ + | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \ + | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \ + | -with-* | --with-* | -without-* | --without-* | --x) + case "$ac_configure_args0 " in + "$ac_configure_args1"*" '$ac_arg' "* ) continue ;; + esac + ;; + -* ) ac_must_keep_next=true ;; + esac + fi + as_fn_append ac_configure_args " '$ac_arg'" + ;; + esac + done +done +{ ac_configure_args0=; unset ac_configure_args0;} +{ ac_configure_args1=; unset ac_configure_args1;} + +# When interrupted or exit'd, cleanup temporary files, and complete +# config.log. We remove comments because anyway the quotes in there +# would cause problems or look ugly. +# WARNING: Use '\'' to represent an apostrophe within the trap. +# WARNING: Do not start the trap code with a newline, due to a FreeBSD 4.0 bug. +trap 'exit_status=$? + # Save into config.log some information that might help in debugging. + { + echo + + $as_echo "## ---------------- ## +## Cache variables. ## +## ---------------- ##" + echo + # The following way of writing the cache mishandles newlines in values, +( + for ac_var in `(set) 2>&1 | sed -n '\''s/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'\''`; do + eval ac_val=\$$ac_var + case $ac_val in #( + *${as_nl}*) + case $ac_var in #( + *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 +$as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; + esac + case $ac_var in #( + _ | IFS | as_nl) ;; #( + BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( + *) { eval $ac_var=; unset $ac_var;} ;; + esac ;; + esac + done + (set) 2>&1 | + case $as_nl`(ac_space='\'' '\''; set) 2>&1` in #( + *${as_nl}ac_space=\ *) + sed -n \ + "s/'\''/'\''\\\\'\'''\''/g; + s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\''\\2'\''/p" + ;; #( + *) + sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" + ;; + esac | + sort +) + echo + + $as_echo "## ----------------- ## +## Output variables. ## +## ----------------- ##" + echo + for ac_var in $ac_subst_vars + do + eval ac_val=\$$ac_var + case $ac_val in + *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; + esac + $as_echo "$ac_var='\''$ac_val'\''" + done | sort + echo + + if test -n "$ac_subst_files"; then + $as_echo "## ------------------- ## +## File substitutions. ## +## ------------------- ##" + echo + for ac_var in $ac_subst_files + do + eval ac_val=\$$ac_var + case $ac_val in + *\'\''*) ac_val=`$as_echo "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; + esac + $as_echo "$ac_var='\''$ac_val'\''" + done | sort + echo + fi + + if test -s confdefs.h; then + $as_echo "## ----------- ## +## confdefs.h. ## +## ----------- ##" + echo + cat confdefs.h + echo + fi + test "$ac_signal" != 0 && + $as_echo "$as_me: caught signal $ac_signal" + $as_echo "$as_me: exit $exit_status" + } >&5 + rm -f core *.core core.conftest.* && + rm -f -r conftest* confdefs* conf$$* $ac_clean_files && + exit $exit_status +' 0 +for ac_signal in 1 2 13 15; do + trap 'ac_signal='$ac_signal'; as_fn_exit 1' $ac_signal +done +ac_signal=0 + +# confdefs.h avoids OS command line length limits that DEFS can exceed. +rm -f -r conftest* confdefs.h + +$as_echo "/* confdefs.h */" > confdefs.h + +# Predefined preprocessor variables. + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_NAME "$PACKAGE_NAME" +_ACEOF + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_TARNAME "$PACKAGE_TARNAME" +_ACEOF + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_VERSION "$PACKAGE_VERSION" +_ACEOF + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_STRING "$PACKAGE_STRING" +_ACEOF + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_BUGREPORT "$PACKAGE_BUGREPORT" +_ACEOF + +cat >>confdefs.h <<_ACEOF +#define PACKAGE_URL "$PACKAGE_URL" +_ACEOF + + +# Let the site file select an alternate cache file if it wants to. +# Prefer an explicitly selected file to automatically selected ones. +ac_site_file1=NONE +ac_site_file2=NONE +if test -n "$CONFIG_SITE"; then + # We do not want a PATH search for config.site. + case $CONFIG_SITE in #(( + -*) ac_site_file1=./$CONFIG_SITE;; + */*) ac_site_file1=$CONFIG_SITE;; + *) ac_site_file1=./$CONFIG_SITE;; + esac +elif test "x$prefix" != xNONE; then + ac_site_file1=$prefix/share/config.site + ac_site_file2=$prefix/etc/config.site +else + ac_site_file1=$ac_default_prefix/share/config.site + ac_site_file2=$ac_default_prefix/etc/config.site +fi +for ac_site_file in "$ac_site_file1" "$ac_site_file2" +do + test "x$ac_site_file" = xNONE && continue + if test /dev/null != "$ac_site_file" && test -r "$ac_site_file"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: loading site script $ac_site_file" >&5 +$as_echo "$as_me: loading site script $ac_site_file" >&6;} + sed 's/^/| /' "$ac_site_file" >&5 + . "$ac_site_file" \ + || { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "failed to load site script $ac_site_file +See \`config.log' for more details" "$LINENO" 5; } + fi +done + +if test -r "$cache_file"; then + # Some versions of bash will fail to source /dev/null (special files + # actually), so we avoid doing that. DJGPP emulates it as a regular file. + if test /dev/null != "$cache_file" && test -f "$cache_file"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: loading cache $cache_file" >&5 +$as_echo "$as_me: loading cache $cache_file" >&6;} + case $cache_file in + [\\/]* | ?:[\\/]* ) . "$cache_file";; + *) . "./$cache_file";; + esac + fi +else + { $as_echo "$as_me:${as_lineno-$LINENO}: creating cache $cache_file" >&5 +$as_echo "$as_me: creating cache $cache_file" >&6;} + >$cache_file +fi + +# Check that the precious variables saved in the cache have kept the same +# value. +ac_cache_corrupted=false +for ac_var in $ac_precious_vars; do + eval ac_old_set=\$ac_cv_env_${ac_var}_set + eval ac_new_set=\$ac_env_${ac_var}_set + eval ac_old_val=\$ac_cv_env_${ac_var}_value + eval ac_new_val=\$ac_env_${ac_var}_value + case $ac_old_set,$ac_new_set in + set,) + { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5 +$as_echo "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;} + ac_cache_corrupted=: ;; + ,set) + { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was not set in the previous run" >&5 +$as_echo "$as_me: error: \`$ac_var' was not set in the previous run" >&2;} + ac_cache_corrupted=: ;; + ,);; + *) + if test "x$ac_old_val" != "x$ac_new_val"; then + # differences in whitespace do not lead to failure. + ac_old_val_w=`echo x $ac_old_val` + ac_new_val_w=`echo x $ac_new_val` + if test "$ac_old_val_w" != "$ac_new_val_w"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' has changed since the previous run:" >&5 +$as_echo "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;} + ac_cache_corrupted=: + else + { $as_echo "$as_me:${as_lineno-$LINENO}: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&5 +$as_echo "$as_me: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&2;} + eval $ac_var=\$ac_old_val + fi + { $as_echo "$as_me:${as_lineno-$LINENO}: former value: \`$ac_old_val'" >&5 +$as_echo "$as_me: former value: \`$ac_old_val'" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: current value: \`$ac_new_val'" >&5 +$as_echo "$as_me: current value: \`$ac_new_val'" >&2;} + fi;; + esac + # Pass precious variables to config.status. + if test "$ac_new_set" = set; then + case $ac_new_val in + *\'*) ac_arg=$ac_var=`$as_echo "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;; + *) ac_arg=$ac_var=$ac_new_val ;; + esac + case " $ac_configure_args " in + *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy. + *) as_fn_append ac_configure_args " '$ac_arg'" ;; + esac + fi +done +if $ac_cache_corrupted; then + { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} + { $as_echo "$as_me:${as_lineno-$LINENO}: error: changes in the environment can compromise the build" >&5 +$as_echo "$as_me: error: changes in the environment can compromise the build" >&2;} + as_fn_error $? "run \`make distclean' and/or \`rm $cache_file' and start over" "$LINENO" 5 +fi +## -------------------- ## +## Main body of script. ## +## -------------------- ## + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + + +ac_config_headers="$ac_config_headers config.h" + +am__api_version='1.16' + +ac_aux_dir= +for ac_dir in "$srcdir" "$srcdir/.." "$srcdir/../.."; do + if test -f "$ac_dir/install-sh"; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/install-sh -c" + break + elif test -f "$ac_dir/install.sh"; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/install.sh -c" + break + elif test -f "$ac_dir/shtool"; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/shtool install -c" + break + fi +done +if test -z "$ac_aux_dir"; then + as_fn_error $? "cannot find install-sh, install.sh, or shtool in \"$srcdir\" \"$srcdir/..\" \"$srcdir/../..\"" "$LINENO" 5 +fi + +# These three variables are undocumented and unsupported, +# and are intended to be withdrawn in a future Autoconf release. +# They can cause serious problems if a builder's source tree is in a directory +# whose full name contains unusual characters. +ac_config_guess="$SHELL $ac_aux_dir/config.guess" # Please don't use this var. +ac_config_sub="$SHELL $ac_aux_dir/config.sub" # Please don't use this var. +ac_configure="$SHELL $ac_aux_dir/configure" # Please don't use this var. + + +# Find a good install program. We prefer a C program (faster), +# so one script is as good as another. But avoid the broken or +# incompatible versions: +# SysV /etc/install, /usr/sbin/install +# SunOS /usr/etc/install +# IRIX /sbin/install +# AIX /bin/install +# AmigaOS /C/install, which installs bootblocks on floppy discs +# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag +# AFS /usr/afsws/bin/install, which mishandles nonexistent args +# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" +# OS/2's system install, which has a completely different semantic +# ./install, which can be erroneously created by make from ./install.sh. +# Reject install programs that cannot install multiple files. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for a BSD-compatible install" >&5 +$as_echo_n "checking for a BSD-compatible install... " >&6; } +if test -z "$INSTALL"; then +if ${ac_cv_path_install+:} false; then : + $as_echo_n "(cached) " >&6 +else + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + # Account for people who put trailing slashes in PATH elements. +case $as_dir/ in #(( + ./ | .// | /[cC]/* | \ + /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ + ?:[\\/]os2[\\/]install[\\/]* | ?:[\\/]OS2[\\/]INSTALL[\\/]* | \ + /usr/ucb/* ) ;; + *) + # OSF1 and SCO ODT 3.0 have their own names for install. + # Don't use installbsd from OSF since it installs stuff as root + # by default. + for ac_prog in ginstall scoinst install; do + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext"; then + if test $ac_prog = install && + grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then + # AIX install. It has an incompatible calling convention. + : + elif test $ac_prog = install && + grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then + # program-specific install script used by HP pwplus--don't use. + : + else + rm -rf conftest.one conftest.two conftest.dir + echo one > conftest.one + echo two > conftest.two + mkdir conftest.dir + if "$as_dir/$ac_prog$ac_exec_ext" -c conftest.one conftest.two "`pwd`/conftest.dir" && + test -s conftest.one && test -s conftest.two && + test -s conftest.dir/conftest.one && + test -s conftest.dir/conftest.two + then + ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c" + break 3 + fi + fi + fi + done + done + ;; +esac + + done +IFS=$as_save_IFS + +rm -rf conftest.one conftest.two conftest.dir + +fi + if test "${ac_cv_path_install+set}" = set; then + INSTALL=$ac_cv_path_install + else + # As a last resort, use the slow shell script. Don't cache a + # value for INSTALL within a source directory, because that will + # break other packages using the cache if that directory is + # removed, or if the value is a relative name. + INSTALL=$ac_install_sh + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $INSTALL" >&5 +$as_echo "$INSTALL" >&6; } + +# Use test -z because SunOS4 sh mishandles braces in ${var-val}. +# It thinks the first close brace ends the variable substitution. +test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' + +test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' + +test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether build environment is sane" >&5 +$as_echo_n "checking whether build environment is sane... " >&6; } +# Reject unsafe characters in $srcdir or the absolute working directory +# name. Accept space and tab only in the latter. +am_lf=' +' +case `pwd` in + *[\\\"\#\$\&\'\`$am_lf]*) + as_fn_error $? "unsafe absolute working directory name" "$LINENO" 5;; +esac +case $srcdir in + *[\\\"\#\$\&\'\`$am_lf\ \ ]*) + as_fn_error $? "unsafe srcdir value: '$srcdir'" "$LINENO" 5;; +esac + +# Do 'set' in a subshell so we don't clobber the current shell's +# arguments. Must try -L first in case configure is actually a +# symlink; some systems play weird games with the mod time of symlinks +# (eg FreeBSD returns the mod time of the symlink's containing +# directory). +if ( + am_has_slept=no + for am_try in 1 2; do + echo "timestamp, slept: $am_has_slept" > conftest.file + set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` + if test "$*" = "X"; then + # -L didn't work. + set X `ls -t "$srcdir/configure" conftest.file` + fi + if test "$*" != "X $srcdir/configure conftest.file" \ + && test "$*" != "X conftest.file $srcdir/configure"; then + + # If neither matched, then we have a broken ls. This can happen + # if, for instance, CONFIG_SHELL is bash and it inherits a + # broken ls alias from the environment. This has actually + # happened. Such a system could not be considered "sane". + as_fn_error $? "ls -t appears to fail. Make sure there is not a broken + alias in your environment" "$LINENO" 5 + fi + if test "$2" = conftest.file || test $am_try -eq 2; then + break + fi + # Just in case. + sleep 1 + am_has_slept=yes + done + test "$2" = conftest.file + ) +then + # Ok. + : +else + as_fn_error $? "newly created file is older than distributed files! +Check your system clock" "$LINENO" 5 +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 +$as_echo "yes" >&6; } +# If we didn't sleep, we still need to ensure time stamps of config.status and +# generated files are strictly newer. +am_sleep_pid= +if grep 'slept: no' conftest.file >/dev/null 2>&1; then + ( sleep 1 ) & + am_sleep_pid=$! +fi + +rm -f conftest.file + +test "$program_prefix" != NONE && + program_transform_name="s&^&$program_prefix&;$program_transform_name" +# Use a double $ so make ignores it. +test "$program_suffix" != NONE && + program_transform_name="s&\$&$program_suffix&;$program_transform_name" +# Double any \ or $. +# By default was `s,x,x', remove it if useless. +ac_script='s/[\\$]/&&/g;s/;s,x,x,$//' +program_transform_name=`$as_echo "$program_transform_name" | sed "$ac_script"` + +# Expand $ac_aux_dir to an absolute path. +am_aux_dir=`cd "$ac_aux_dir" && pwd` + +if test x"${MISSING+set}" != xset; then + case $am_aux_dir in + *\ * | *\ *) + MISSING="\${SHELL} \"$am_aux_dir/missing\"" ;; + *) + MISSING="\${SHELL} $am_aux_dir/missing" ;; + esac +fi +# Use eval to expand $SHELL +if eval "$MISSING --is-lightweight"; then + am_missing_run="$MISSING " +else + am_missing_run= + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: 'missing' script is too old or missing" >&5 +$as_echo "$as_me: WARNING: 'missing' script is too old or missing" >&2;} +fi + +if test x"${install_sh+set}" != xset; then + case $am_aux_dir in + *\ * | *\ *) + install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; + *) + install_sh="\${SHELL} $am_aux_dir/install-sh" + esac +fi + +# Installed binaries are usually stripped using 'strip' when the user +# run "make install-strip". However 'strip' might not be the right +# tool to use in cross-compilation environments, therefore Automake +# will honor the 'STRIP' environment variable to overrule this program. +if test "$cross_compiling" != no; then + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. +set dummy ${ac_tool_prefix}strip; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_STRIP+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$STRIP"; then + ac_cv_prog_STRIP="$STRIP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_STRIP="${ac_tool_prefix}strip" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +STRIP=$ac_cv_prog_STRIP +if test -n "$STRIP"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 +$as_echo "$STRIP" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_STRIP"; then + ac_ct_STRIP=$STRIP + # Extract the first word of "strip", so it can be a program name with args. +set dummy strip; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_STRIP+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_STRIP"; then + ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_STRIP="strip" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP +if test -n "$ac_ct_STRIP"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 +$as_echo "$ac_ct_STRIP" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_STRIP" = x; then + STRIP=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + STRIP=$ac_ct_STRIP + fi +else + STRIP="$ac_cv_prog_STRIP" +fi + +fi +INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for a thread-safe mkdir -p" >&5 +$as_echo_n "checking for a thread-safe mkdir -p... " >&6; } +if test -z "$MKDIR_P"; then + if ${ac_cv_path_mkdir+:} false; then : + $as_echo_n "(cached) " >&6 +else + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH$PATH_SEPARATOR/opt/sfw/bin +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_prog in mkdir gmkdir; do + for ac_exec_ext in '' $ac_executable_extensions; do + as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext" || continue + case `"$as_dir/$ac_prog$ac_exec_ext" --version 2>&1` in #( + 'mkdir (GNU coreutils) '* | \ + 'mkdir (coreutils) '* | \ + 'mkdir (fileutils) '4.1*) + ac_cv_path_mkdir=$as_dir/$ac_prog$ac_exec_ext + break 3;; + esac + done + done + done +IFS=$as_save_IFS + +fi + + test -d ./--version && rmdir ./--version + if test "${ac_cv_path_mkdir+set}" = set; then + MKDIR_P="$ac_cv_path_mkdir -p" + else + # As a last resort, use the slow shell script. Don't cache a + # value for MKDIR_P within a source directory, because that will + # break other packages using the cache if that directory is + # removed, or if the value is a relative name. + MKDIR_P="$ac_install_sh -d" + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $MKDIR_P" >&5 +$as_echo "$MKDIR_P" >&6; } + +for ac_prog in gawk mawk nawk awk +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_AWK+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$AWK"; then + ac_cv_prog_AWK="$AWK" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_AWK="$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +AWK=$ac_cv_prog_AWK +if test -n "$AWK"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AWK" >&5 +$as_echo "$AWK" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$AWK" && break +done + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} sets \$(MAKE)" >&5 +$as_echo_n "checking whether ${MAKE-make} sets \$(MAKE)... " >&6; } +set x ${MAKE-make} +ac_make=`$as_echo "$2" | sed 's/+/p/g; s/[^a-zA-Z0-9_]/_/g'` +if eval \${ac_cv_prog_make_${ac_make}_set+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat >conftest.make <<\_ACEOF +SHELL = /bin/sh +all: + @echo '@@@%%%=$(MAKE)=@@@%%%' +_ACEOF +# GNU make sometimes prints "make[1]: Entering ...", which would confuse us. +case `${MAKE-make} -f conftest.make 2>/dev/null` in + *@@@%%%=?*=@@@%%%*) + eval ac_cv_prog_make_${ac_make}_set=yes;; + *) + eval ac_cv_prog_make_${ac_make}_set=no;; +esac +rm -f conftest.make +fi +if eval test \$ac_cv_prog_make_${ac_make}_set = yes; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 +$as_echo "yes" >&6; } + SET_MAKE= +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } + SET_MAKE="MAKE=${MAKE-make}" +fi + +rm -rf .tst 2>/dev/null +mkdir .tst 2>/dev/null +if test -d .tst; then + am__leading_dot=. +else + am__leading_dot=_ +fi +rmdir .tst 2>/dev/null + +# Check whether --enable-silent-rules was given. +if test "${enable_silent_rules+set}" = set; then : + enableval=$enable_silent_rules; +fi + +case $enable_silent_rules in # ((( + yes) AM_DEFAULT_VERBOSITY=0;; + no) AM_DEFAULT_VERBOSITY=1;; + *) AM_DEFAULT_VERBOSITY=1;; +esac +am_make=${MAKE-make} +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $am_make supports nested variables" >&5 +$as_echo_n "checking whether $am_make supports nested variables... " >&6; } +if ${am_cv_make_support_nested_variables+:} false; then : + $as_echo_n "(cached) " >&6 +else + if $as_echo 'TRUE=$(BAR$(V)) +BAR0=false +BAR1=true +V=1 +am__doit: + @$(TRUE) +.PHONY: am__doit' | $am_make -f - >/dev/null 2>&1; then + am_cv_make_support_nested_variables=yes +else + am_cv_make_support_nested_variables=no +fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_make_support_nested_variables" >&5 +$as_echo "$am_cv_make_support_nested_variables" >&6; } +if test $am_cv_make_support_nested_variables = yes; then + AM_V='$(V)' + AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' +else + AM_V=$AM_DEFAULT_VERBOSITY + AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY +fi +AM_BACKSLASH='\' + +if test "`cd $srcdir && pwd`" != "`pwd`"; then + # Use -I$(srcdir) only when $(srcdir) != ., so that make's output + # is not polluted with repeated "-I." + am__isrc=' -I$(srcdir)' + # test to see if srcdir already configured + if test -f $srcdir/config.status; then + as_fn_error $? "source directory already configured; run \"make distclean\" there first" "$LINENO" 5 + fi +fi + +# test whether we have cygpath +if test -z "$CYGPATH_W"; then + if (cygpath --version) >/dev/null 2>/dev/null; then + CYGPATH_W='cygpath -w' + else + CYGPATH_W=echo + fi +fi + + +# Define the identity of the package. + PACKAGE='libtgvoip' + VERSION='2.6' + + +cat >>confdefs.h <<_ACEOF +#define PACKAGE "$PACKAGE" +_ACEOF + + +cat >>confdefs.h <<_ACEOF +#define VERSION "$VERSION" +_ACEOF + +# Some tools Automake needs. + +ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"} + + +AUTOCONF=${AUTOCONF-"${am_missing_run}autoconf"} + + +AUTOMAKE=${AUTOMAKE-"${am_missing_run}automake-${am__api_version}"} + + +AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"} + + +MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"} + +# For better backward compatibility. To be removed once Automake 1.9.x +# dies out for good. For more background, see: +# +# +mkdir_p='$(MKDIR_P)' + +# We need awk for the "check" target (and possibly the TAP driver). The +# system "awk" is bad on some platforms. +# Always define AMTAR for backward compatibility. Yes, it's still used +# in the wild :-( We should find a proper way to deprecate it ... +AMTAR='$${TAR-tar}' + + +# We'll loop over all known methods to create a tar archive until one works. +_am_tools='gnutar pax cpio none' + +am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -' + + + + + + +# POSIX will say in a future version that running "rm -f" with no argument +# is OK; and we want to be able to make that assumption in our Makefile +# recipes. So use an aggressive probe to check that the usage we want is +# actually supported "in the wild" to an acceptable degree. +# See automake bug#10828. +# To make any issue more visible, cause the running configure to be aborted +# by default if the 'rm' program in use doesn't match our expectations; the +# user can still override this though. +if rm -f && rm -fr && rm -rf; then : OK; else + cat >&2 <<'END' +Oops! + +Your 'rm' program seems unable to run without file operands specified +on the command line, even when the '-f' option is present. This is contrary +to the behaviour of most rm programs out there, and not conforming with +the upcoming POSIX standard: + +Please tell bug-automake@gnu.org about your system, including the value +of your $PATH and any error possibly output before this message. This +can help us improve future automake versions. + +END + if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then + echo 'Configuration will proceed anyway, since you have set the' >&2 + echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 + echo >&2 + else + cat >&2 <<'END' +Aborting the configuration process, to ensure you take notice of the issue. + +You can download and install GNU coreutils to get an 'rm' implementation +that behaves properly: . + +If you want to complete the configuration process using your problematic +'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM +to "yes", and re-run configure. + +END + as_fn_error $? "Your 'rm' program is bad, sorry." "$LINENO" 5 + fi +fi + +# Check whether --enable-silent-rules was given. +if test "${enable_silent_rules+set}" = set; then : + enableval=$enable_silent_rules; +fi + +case $enable_silent_rules in # ((( + yes) AM_DEFAULT_VERBOSITY=0;; + no) AM_DEFAULT_VERBOSITY=1;; + *) AM_DEFAULT_VERBOSITY=0;; +esac +am_make=${MAKE-make} +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $am_make supports nested variables" >&5 +$as_echo_n "checking whether $am_make supports nested variables... " >&6; } +if ${am_cv_make_support_nested_variables+:} false; then : + $as_echo_n "(cached) " >&6 +else + if $as_echo 'TRUE=$(BAR$(V)) +BAR0=false +BAR1=true +V=1 +am__doit: + @$(TRUE) +.PHONY: am__doit' | $am_make -f - >/dev/null 2>&1; then + am_cv_make_support_nested_variables=yes +else + am_cv_make_support_nested_variables=no +fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_make_support_nested_variables" >&5 +$as_echo "$am_cv_make_support_nested_variables" >&6; } +if test $am_cv_make_support_nested_variables = yes; then + AM_V='$(V)' + AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' +else + AM_V=$AM_DEFAULT_VERBOSITY + AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY +fi +AM_BACKSLASH='\' + +case `pwd` in + *\ * | *\ *) + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&5 +$as_echo "$as_me: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&2;} ;; +esac + + + +macro_version='2.4.6.42-b88ce' +macro_revision='2.4.6.42' + + + + + + + + + + + + + +ltmain=$ac_aux_dir/ltmain.sh + +# Make sure we can run config.sub. +$SHELL "$ac_aux_dir/config.sub" sun4 >/dev/null 2>&1 || + as_fn_error $? "cannot run $SHELL $ac_aux_dir/config.sub" "$LINENO" 5 + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking build system type" >&5 +$as_echo_n "checking build system type... " >&6; } +if ${ac_cv_build+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_build_alias=$build_alias +test "x$ac_build_alias" = x && + ac_build_alias=`$SHELL "$ac_aux_dir/config.guess"` +test "x$ac_build_alias" = x && + as_fn_error $? "cannot guess build type; you must specify one" "$LINENO" 5 +ac_cv_build=`$SHELL "$ac_aux_dir/config.sub" $ac_build_alias` || + as_fn_error $? "$SHELL $ac_aux_dir/config.sub $ac_build_alias failed" "$LINENO" 5 + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_build" >&5 +$as_echo "$ac_cv_build" >&6; } +case $ac_cv_build in +*-*-*) ;; +*) as_fn_error $? "invalid value of canonical build" "$LINENO" 5;; +esac +build=$ac_cv_build +ac_save_IFS=$IFS; IFS='-' +set x $ac_cv_build +shift +build_cpu=$1 +build_vendor=$2 +shift; shift +# Remember, the first character of IFS is used to create $*, +# except with old shells: +build_os=$* +IFS=$ac_save_IFS +case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking host system type" >&5 +$as_echo_n "checking host system type... " >&6; } +if ${ac_cv_host+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test "x$host_alias" = x; then + ac_cv_host=$ac_cv_build +else + ac_cv_host=`$SHELL "$ac_aux_dir/config.sub" $host_alias` || + as_fn_error $? "$SHELL $ac_aux_dir/config.sub $host_alias failed" "$LINENO" 5 +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_host" >&5 +$as_echo "$ac_cv_host" >&6; } +case $ac_cv_host in +*-*-*) ;; +*) as_fn_error $? "invalid value of canonical host" "$LINENO" 5;; +esac +host=$ac_cv_host +ac_save_IFS=$IFS; IFS='-' +set x $ac_cv_host +shift +host_cpu=$1 +host_vendor=$2 +shift; shift +# Remember, the first character of IFS is used to create $*, +# except with old shells: +host_os=$* +IFS=$ac_save_IFS +case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac + + +# Backslashify metacharacters that are still active within +# double-quoted strings. +sed_quote_subst='s/\(["`$\\]\)/\\\1/g' + +# Same as above, but do not quote variable references. +double_quote_subst='s/\(["`\\]\)/\\\1/g' + +# Sed substitution to delay expansion of an escaped shell variable in a +# double_quote_subst'ed string. +delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' + +# Sed substitution to delay expansion of an escaped single quote. +delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' + +# Sed substitution to avoid accidental globbing in evaled expressions +no_glob_subst='s/\*/\\\*/g' + +ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' +ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO +ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to print strings" >&5 +$as_echo_n "checking how to print strings... " >&6; } +# Test print first, because it will be a builtin if present. +if test "X`( print -r -- -n ) 2>/dev/null`" = X-n && \ + test "X`print -r -- $ECHO 2>/dev/null`" = "X$ECHO"; then + ECHO='print -r --' +elif test "X`printf %s $ECHO 2>/dev/null`" = "X$ECHO"; then + ECHO='printf %s\n' +else + # Use this function as a fallback that always works. + func_fallback_echo () + { + eval 'cat <<_LTECHO_EOF +$1 +_LTECHO_EOF' + } + ECHO='func_fallback_echo' +fi + +# func_echo_all arg... +# Invoke $ECHO with all args, space-separated. +func_echo_all () +{ + $ECHO "" +} + +case $ECHO in + printf*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: printf" >&5 +$as_echo "printf" >&6; } ;; + print*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: print -r" >&5 +$as_echo "print -r" >&6; } ;; + *) { $as_echo "$as_me:${as_lineno-$LINENO}: result: cat" >&5 +$as_echo "cat" >&6; } ;; +esac + + + + + + + + + + + + + + +DEPDIR="${am__leading_dot}deps" + +ac_config_commands="$ac_config_commands depfiles" + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} supports the include directive" >&5 +$as_echo_n "checking whether ${MAKE-make} supports the include directive... " >&6; } +cat > confinc.mk << 'END' +am__doit: + @echo this is the am__doit target >confinc.out +.PHONY: am__doit +END +am__include="#" +am__quote= +# BSD make does it like this. +echo '.include "confinc.mk" # ignored' > confmf.BSD +# Other make implementations (GNU, Solaris 10, AIX) do it like this. +echo 'include confinc.mk # ignored' > confmf.GNU +_am_result=no +for s in GNU BSD; do + { echo "$as_me:$LINENO: ${MAKE-make} -f confmf.$s && cat confinc.out" >&5 + (${MAKE-make} -f confmf.$s && cat confinc.out) >&5 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + case $?:`cat confinc.out 2>/dev/null` in #( + '0:this is the am__doit target') : + case $s in #( + BSD) : + am__include='.include' am__quote='"' ;; #( + *) : + am__include='include' am__quote='' ;; +esac ;; #( + *) : + ;; +esac + if test "$am__include" != "#"; then + _am_result="yes ($s style)" + break + fi +done +rm -f confinc.* confmf.* +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: ${_am_result}" >&5 +$as_echo "${_am_result}" >&6; } + +# Check whether --enable-dependency-tracking was given. +if test "${enable_dependency_tracking+set}" = set; then : + enableval=$enable_dependency_tracking; +fi + +if test "x$enable_dependency_tracking" != xno; then + am_depcomp="$ac_aux_dir/depcomp" + AMDEPBACKSLASH='\' + am__nodep='_no' +fi + if test "x$enable_dependency_tracking" != xno; then + AMDEP_TRUE= + AMDEP_FALSE='#' +else + AMDEP_TRUE='#' + AMDEP_FALSE= +fi + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. +set dummy ${ac_tool_prefix}gcc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_CC="${ac_tool_prefix}gcc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_CC"; then + ac_ct_CC=$CC + # Extract the first word of "gcc", so it can be a program name with args. +set dummy gcc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_CC="gcc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 +$as_echo "$ac_ct_CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_CC" = x; then + CC="" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CC=$ac_ct_CC + fi +else + CC="$ac_cv_prog_CC" +fi + +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. +set dummy ${ac_tool_prefix}cc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_CC="${ac_tool_prefix}cc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + fi +fi +if test -z "$CC"; then + # Extract the first word of "cc", so it can be a program name with args. +set dummy cc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else + ac_prog_rejected=no +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then + ac_prog_rejected=yes + continue + fi + ac_cv_prog_CC="cc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +if test $ac_prog_rejected = yes; then + # We found a bogon in the path, so make sure we never use it. + set dummy $ac_cv_prog_CC + shift + if test $# != 0; then + # We chose a different compiler from the bogus one. + # However, it has the same basename, so the bogon will be chosen + # first if we set CC to just the basename; use the full file name. + shift + ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" + fi +fi +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + for ac_prog in cl.exe + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_CC="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$CC" && break + done +fi +if test -z "$CC"; then + ac_ct_CC=$CC + for ac_prog in cl.exe +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_CC="$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 +$as_echo "$ac_ct_CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_CC" && break +done + + if test "x$ac_ct_CC" = x; then + CC="" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CC=$ac_ct_CC + fi +fi + +fi + + +test -z "$CC" && { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "no acceptable C compiler found in \$PATH +See \`config.log' for more details" "$LINENO" 5; } + +# Provide some information about the compiler. +$as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 +set X $ac_compile +ac_compiler=$2 +for ac_option in --version -v -V -qversion; do + { { ac_try="$ac_compiler $ac_option >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compiler $ac_option >&5") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + sed '10a\ +... rest of stderr output deleted ... + 10q' conftest.err >conftest.er1 + cat conftest.er1 >&5 + fi + rm -f conftest.er1 conftest.err + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } +done + +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +ac_clean_files_save=$ac_clean_files +ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out" +# Try to create an executable without -o first, disregard a.out. +# It will help us diagnose broken compilers, and finding out an intuition +# of exeext. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler works" >&5 +$as_echo_n "checking whether the C compiler works... " >&6; } +ac_link_default=`$as_echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'` + +# The possible output files: +ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" + +ac_rmfiles= +for ac_file in $ac_files +do + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; + * ) ac_rmfiles="$ac_rmfiles $ac_file";; + esac +done +rm -f $ac_rmfiles + +if { { ac_try="$ac_link_default" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link_default") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then : + # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. +# So ignore a value of `no', otherwise this would lead to `EXEEXT = no' +# in a Makefile. We should not override ac_cv_exeext if it was cached, +# so that the user can short-circuit this test for compilers unknown to +# Autoconf. +for ac_file in $ac_files '' +do + test -f "$ac_file" || continue + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) + ;; + [ab].out ) + # We found the default executable, but exeext='' is most + # certainly right. + break;; + *.* ) + if test "${ac_cv_exeext+set}" = set && test "$ac_cv_exeext" != no; + then :; else + ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` + fi + # We set ac_cv_exeext here because the later test for it is not + # safe: cross compilers may not add the suffix if given an `-o' + # argument, so we may need to know it at that point already. + # Even if this section looks crufty: it has the advantage of + # actually working. + break;; + * ) + break;; + esac +done +test "$ac_cv_exeext" = no && ac_cv_exeext= + +else + ac_file='' +fi +if test -z "$ac_file"; then : + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +$as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error 77 "C compiler cannot create executables +See \`config.log' for more details" "$LINENO" 5; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 +$as_echo "yes" >&6; } +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler default output file name" >&5 +$as_echo_n "checking for C compiler default output file name... " >&6; } +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_file" >&5 +$as_echo "$ac_file" >&6; } +ac_exeext=$ac_cv_exeext + +rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out +ac_clean_files=$ac_clean_files_save +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of executables" >&5 +$as_echo_n "checking for suffix of executables... " >&6; } +if { { ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then : + # If both `conftest.exe' and `conftest' are `present' (well, observable) +# catch `conftest.exe'. For instance with Cygwin, `ls conftest' will +# work properly (i.e., refer to `conftest.exe'), while it won't with +# `rm'. +for ac_file in conftest.exe conftest conftest.*; do + test -f "$ac_file" || continue + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; + *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` + break;; + * ) break;; + esac +done +else + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "cannot compute suffix of executables: cannot compile and link +See \`config.log' for more details" "$LINENO" 5; } +fi +rm -f conftest conftest$ac_cv_exeext +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 +$as_echo "$ac_cv_exeext" >&6; } + +rm -f conftest.$ac_ext +EXEEXT=$ac_cv_exeext +ac_exeext=$EXEEXT +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +int +main () +{ +FILE *f = fopen ("conftest.out", "w"); + return ferror (f) || fclose (f) != 0; + + ; + return 0; +} +_ACEOF +ac_clean_files="$ac_clean_files conftest.out" +# Check that the compiler produces executables we can run. If not, either +# the compiler is broken, or we cross compile. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are cross compiling" >&5 +$as_echo_n "checking whether we are cross compiling... " >&6; } +if test "$cross_compiling" != yes; then + { { ac_try="$ac_link" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_link") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } + if { ac_try='./conftest$ac_cv_exeext' + { { case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_try") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; }; then + cross_compiling=no + else + if test "$cross_compiling" = maybe; then + cross_compiling=yes + else + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "cannot run C compiled programs. +If you meant to cross compile, use \`--host'. +See \`config.log' for more details" "$LINENO" 5; } + fi + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $cross_compiling" >&5 +$as_echo "$cross_compiling" >&6; } + +rm -f conftest.$ac_ext conftest$ac_cv_exeext conftest.out +ac_clean_files=$ac_clean_files_save +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 +$as_echo_n "checking for suffix of object files... " >&6; } +if ${ac_cv_objext+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +rm -f conftest.o conftest.obj +if { { ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compile") 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then : + for ac_file in conftest.o conftest.obj conftest.*; do + test -f "$ac_file" || continue; + case $ac_file in + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; + *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` + break;; + esac +done +else + $as_echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + +{ { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "cannot compute suffix of object files: cannot compile +See \`config.log' for more details" "$LINENO" 5; } +fi +rm -f conftest.$ac_cv_objext conftest.$ac_ext +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objext" >&5 +$as_echo "$ac_cv_objext" >&6; } +OBJEXT=$ac_cv_objext +ac_objext=$OBJEXT +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C compiler" >&5 +$as_echo_n "checking whether we are using the GNU C compiler... " >&6; } +if ${ac_cv_c_compiler_gnu+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_compiler_gnu=yes +else + ac_compiler_gnu=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_c_compiler_gnu=$ac_compiler_gnu + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_compiler_gnu" >&5 +$as_echo "$ac_cv_c_compiler_gnu" >&6; } +if test $ac_compiler_gnu = yes; then + GCC=yes +else + GCC= +fi +ac_test_CFLAGS=${CFLAGS+set} +ac_save_CFLAGS=$CFLAGS +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 +$as_echo_n "checking whether $CC accepts -g... " >&6; } +if ${ac_cv_prog_cc_g+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_save_c_werror_flag=$ac_c_werror_flag + ac_c_werror_flag=yes + ac_cv_prog_cc_g=no + CFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_prog_cc_g=yes +else + CFLAGS="" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + +else + ac_c_werror_flag=$ac_save_c_werror_flag + CFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_prog_cc_g=yes +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_c_werror_flag=$ac_save_c_werror_flag +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_g" >&5 +$as_echo "$ac_cv_prog_cc_g" >&6; } +if test "$ac_test_CFLAGS" = set; then + CFLAGS=$ac_save_CFLAGS +elif test $ac_cv_prog_cc_g = yes; then + if test "$GCC" = yes; then + CFLAGS="-g -O2" + else + CFLAGS="-g" + fi +else + if test "$GCC" = yes; then + CFLAGS="-O2" + else + CFLAGS= + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $CC option to accept ISO C89" >&5 +$as_echo_n "checking for $CC option to accept ISO C89... " >&6; } +if ${ac_cv_prog_cc_c89+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_cv_prog_cc_c89=no +ac_save_CC=$CC +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +#include +struct stat; +/* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ +struct buf { int x; }; +FILE * (*rcsopen) (struct buf *, struct stat *, int); +static char *e (p, i) + char **p; + int i; +{ + return p[i]; +} +static char *f (char * (*g) (char **, int), char **p, ...) +{ + char *s; + va_list v; + va_start (v,p); + s = g (p, va_arg (v,int)); + va_end (v); + return s; +} + +/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has + function prototypes and stuff, but not '\xHH' hex character constants. + These don't provoke an error unfortunately, instead are silently treated + as 'x'. The following induces an error, until -std is added to get + proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an + array size at least. It's necessary to write '\x00'==0 to get something + that's true only with -std. */ +int osf4_cc_array ['\x00' == 0 ? 1 : -1]; + +/* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters + inside strings and character constants. */ +#define FOO(x) 'x' +int xlc6_cc_array[FOO(a) == 'x' ? 1 : -1]; + +int test (int i, double x); +struct s1 {int (*f) (int a);}; +struct s2 {int (*f) (double a);}; +int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); +int argc; +char **argv; +int +main () +{ +return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; + ; + return 0; +} +_ACEOF +for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \ + -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" +do + CC="$ac_save_CC $ac_arg" + if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_prog_cc_c89=$ac_arg +fi +rm -f core conftest.err conftest.$ac_objext + test "x$ac_cv_prog_cc_c89" != "xno" && break +done +rm -f conftest.$ac_ext +CC=$ac_save_CC + +fi +# AC_CACHE_VAL +case "x$ac_cv_prog_cc_c89" in + x) + { $as_echo "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 +$as_echo "none needed" >&6; } ;; + xno) + { $as_echo "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 +$as_echo "unsupported" >&6; } ;; + *) + CC="$CC $ac_cv_prog_cc_c89" + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c89" >&5 +$as_echo "$ac_cv_prog_cc_c89" >&6; } ;; +esac +if test "x$ac_cv_prog_cc_c89" != xno; then : + +fi + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC understands -c and -o together" >&5 +$as_echo_n "checking whether $CC understands -c and -o together... " >&6; } +if ${am_cv_prog_cc_c_o+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF + # Make sure it works both with $CC and with simple cc. + # Following AC_PROG_CC_C_O, we do the test twice because some + # compilers refuse to overwrite an existing .o file with -o, + # though they will create one. + am_cv_prog_cc_c_o=yes + for am_i in 1 2; do + if { echo "$as_me:$LINENO: $CC -c conftest.$ac_ext -o conftest2.$ac_objext" >&5 + ($CC -c conftest.$ac_ext -o conftest2.$ac_objext) >&5 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } \ + && test -f conftest2.$ac_objext; then + : OK + else + am_cv_prog_cc_c_o=no + break + fi + done + rm -f core conftest* + unset am_i +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_prog_cc_c_o" >&5 +$as_echo "$am_cv_prog_cc_c_o" >&6; } +if test "$am_cv_prog_cc_c_o" != yes; then + # Losing compiler, so override with the script. + # FIXME: It is wrong to rewrite CC. + # But if we don't then we get into trouble of one sort or another. + # A longer-term fix would be to have automake use am__CC in this case, + # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" + CC="$am_aux_dir/compile $CC" +fi +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +depcc="$CC" am_compiler_list= + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 +$as_echo_n "checking dependency style of $depcc... " >&6; } +if ${am_cv_CC_dependencies_compiler_type+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named 'D' -- because '-MD' means "put the output + # in D". + rm -rf conftest.dir + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_CC_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` + fi + am__universal=false + case " $depcc " in #( + *\ -arch\ *\ -arch\ *) am__universal=true ;; + esac + + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with + # Solaris 10 /bin/sh. + echo '/* dummy */' > sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + # We check with '-c' and '-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle '-M -o', and we need to detect this. Also, some Intel + # versions had trouble with output in subdirs. + am__obj=sub/conftest.${OBJEXT-o} + am__minus_obj="-o $am__obj" + case $depmode in + gcc) + # This depmode causes a compiler race in universal mode. + test "$am__universal" = false || continue + ;; + nosideeffect) + # After this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested. + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + msvc7 | msvc7msys | msvisualcpp | msvcmsys) + # This compiler won't grok '-c -o', but also, the minuso test has + # not run yet. These depmodes are late enough in the game, and + # so weak that their functioning should not be impacted. + am__obj=conftest.${OBJEXT-o} + am__minus_obj= + ;; + none) break ;; + esac + if depmode=$depmode \ + source=sub/conftest.c object=$am__obj \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep $am__obj sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_CC_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_CC_dependencies_compiler_type=none +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_CC_dependencies_compiler_type" >&5 +$as_echo "$am_cv_CC_dependencies_compiler_type" >&6; } +CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type + + if + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then + am__fastdepCC_TRUE= + am__fastdepCC_FALSE='#' +else + am__fastdepCC_TRUE='#' + am__fastdepCC_FALSE= +fi + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for a sed that does not truncate output" >&5 +$as_echo_n "checking for a sed that does not truncate output... " >&6; } +if ${ac_cv_path_SED+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ + for ac_i in 1 2 3 4 5 6 7; do + ac_script="$ac_script$as_nl$ac_script" + done + echo "$ac_script" 2>/dev/null | sed 99q >conftest.sed + { ac_script=; unset ac_script;} + if test -z "$SED"; then + ac_path_SED_found=false + # Loop through the user's path and test for each of PROGNAME-LIST + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_prog in sed gsed; do + for ac_exec_ext in '' $ac_executable_extensions; do + ac_path_SED="$as_dir/$ac_prog$ac_exec_ext" + as_fn_executable_p "$ac_path_SED" || continue +# Check for GNU ac_path_SED and select it if it is found. + # Check for GNU $ac_path_SED +case `"$ac_path_SED" --version 2>&1` in +*GNU*) + ac_cv_path_SED="$ac_path_SED" ac_path_SED_found=:;; +*) + ac_count=0 + $as_echo_n 0123456789 >"conftest.in" + while : + do + cat "conftest.in" "conftest.in" >"conftest.tmp" + mv "conftest.tmp" "conftest.in" + cp "conftest.in" "conftest.nl" + $as_echo '' >> "conftest.nl" + "$ac_path_SED" -f conftest.sed < "conftest.nl" >"conftest.out" 2>/dev/null || break + diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break + as_fn_arith $ac_count + 1 && ac_count=$as_val + if test $ac_count -gt ${ac_path_SED_max-0}; then + # Best one so far, save it but keep looking for a better one + ac_cv_path_SED="$ac_path_SED" + ac_path_SED_max=$ac_count + fi + # 10*(2^10) chars as input seems more than enough + test $ac_count -gt 10 && break + done + rm -f conftest.in conftest.tmp conftest.nl conftest.out;; +esac + + $ac_path_SED_found && break 3 + done + done + done +IFS=$as_save_IFS + if test -z "$ac_cv_path_SED"; then + as_fn_error $? "no acceptable sed could be found in \$PATH" "$LINENO" 5 + fi +else + ac_cv_path_SED=$SED +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_SED" >&5 +$as_echo "$ac_cv_path_SED" >&6; } + SED="$ac_cv_path_SED" + rm -f conftest.sed + +test -z "$SED" && SED=sed +Xsed="$SED -e 1s/^X//" + + + + + + + + + + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for grep that handles long lines and -e" >&5 +$as_echo_n "checking for grep that handles long lines and -e... " >&6; } +if ${ac_cv_path_GREP+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -z "$GREP"; then + ac_path_GREP_found=false + # Loop through the user's path and test for each of PROGNAME-LIST + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_prog in grep ggrep; do + for ac_exec_ext in '' $ac_executable_extensions; do + ac_path_GREP="$as_dir/$ac_prog$ac_exec_ext" + as_fn_executable_p "$ac_path_GREP" || continue +# Check for GNU ac_path_GREP and select it if it is found. + # Check for GNU $ac_path_GREP +case `"$ac_path_GREP" --version 2>&1` in +*GNU*) + ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_found=:;; +*) + ac_count=0 + $as_echo_n 0123456789 >"conftest.in" + while : + do + cat "conftest.in" "conftest.in" >"conftest.tmp" + mv "conftest.tmp" "conftest.in" + cp "conftest.in" "conftest.nl" + $as_echo 'GREP' >> "conftest.nl" + "$ac_path_GREP" -e 'GREP$' -e '-(cannot match)-' < "conftest.nl" >"conftest.out" 2>/dev/null || break + diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break + as_fn_arith $ac_count + 1 && ac_count=$as_val + if test $ac_count -gt ${ac_path_GREP_max-0}; then + # Best one so far, save it but keep looking for a better one + ac_cv_path_GREP="$ac_path_GREP" + ac_path_GREP_max=$ac_count + fi + # 10*(2^10) chars as input seems more than enough + test $ac_count -gt 10 && break + done + rm -f conftest.in conftest.tmp conftest.nl conftest.out;; +esac + + $ac_path_GREP_found && break 3 + done + done + done +IFS=$as_save_IFS + if test -z "$ac_cv_path_GREP"; then + as_fn_error $? "no acceptable grep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 + fi +else + ac_cv_path_GREP=$GREP +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_GREP" >&5 +$as_echo "$ac_cv_path_GREP" >&6; } + GREP="$ac_cv_path_GREP" + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for egrep" >&5 +$as_echo_n "checking for egrep... " >&6; } +if ${ac_cv_path_EGREP+:} false; then : + $as_echo_n "(cached) " >&6 +else + if echo a | $GREP -E '(a|b)' >/dev/null 2>&1 + then ac_cv_path_EGREP="$GREP -E" + else + if test -z "$EGREP"; then + ac_path_EGREP_found=false + # Loop through the user's path and test for each of PROGNAME-LIST + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_prog in egrep; do + for ac_exec_ext in '' $ac_executable_extensions; do + ac_path_EGREP="$as_dir/$ac_prog$ac_exec_ext" + as_fn_executable_p "$ac_path_EGREP" || continue +# Check for GNU ac_path_EGREP and select it if it is found. + # Check for GNU $ac_path_EGREP +case `"$ac_path_EGREP" --version 2>&1` in +*GNU*) + ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_found=:;; +*) + ac_count=0 + $as_echo_n 0123456789 >"conftest.in" + while : + do + cat "conftest.in" "conftest.in" >"conftest.tmp" + mv "conftest.tmp" "conftest.in" + cp "conftest.in" "conftest.nl" + $as_echo 'EGREP' >> "conftest.nl" + "$ac_path_EGREP" 'EGREP$' < "conftest.nl" >"conftest.out" 2>/dev/null || break + diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break + as_fn_arith $ac_count + 1 && ac_count=$as_val + if test $ac_count -gt ${ac_path_EGREP_max-0}; then + # Best one so far, save it but keep looking for a better one + ac_cv_path_EGREP="$ac_path_EGREP" + ac_path_EGREP_max=$ac_count + fi + # 10*(2^10) chars as input seems more than enough + test $ac_count -gt 10 && break + done + rm -f conftest.in conftest.tmp conftest.nl conftest.out;; +esac + + $ac_path_EGREP_found && break 3 + done + done + done +IFS=$as_save_IFS + if test -z "$ac_cv_path_EGREP"; then + as_fn_error $? "no acceptable egrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 + fi +else + ac_cv_path_EGREP=$EGREP +fi + + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_EGREP" >&5 +$as_echo "$ac_cv_path_EGREP" >&6; } + EGREP="$ac_cv_path_EGREP" + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for fgrep" >&5 +$as_echo_n "checking for fgrep... " >&6; } +if ${ac_cv_path_FGREP+:} false; then : + $as_echo_n "(cached) " >&6 +else + if echo 'ab*c' | $GREP -F 'ab*c' >/dev/null 2>&1 + then ac_cv_path_FGREP="$GREP -F" + else + if test -z "$FGREP"; then + ac_path_FGREP_found=false + # Loop through the user's path and test for each of PROGNAME-LIST + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_prog in fgrep; do + for ac_exec_ext in '' $ac_executable_extensions; do + ac_path_FGREP="$as_dir/$ac_prog$ac_exec_ext" + as_fn_executable_p "$ac_path_FGREP" || continue +# Check for GNU ac_path_FGREP and select it if it is found. + # Check for GNU $ac_path_FGREP +case `"$ac_path_FGREP" --version 2>&1` in +*GNU*) + ac_cv_path_FGREP="$ac_path_FGREP" ac_path_FGREP_found=:;; +*) + ac_count=0 + $as_echo_n 0123456789 >"conftest.in" + while : + do + cat "conftest.in" "conftest.in" >"conftest.tmp" + mv "conftest.tmp" "conftest.in" + cp "conftest.in" "conftest.nl" + $as_echo 'FGREP' >> "conftest.nl" + "$ac_path_FGREP" FGREP < "conftest.nl" >"conftest.out" 2>/dev/null || break + diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break + as_fn_arith $ac_count + 1 && ac_count=$as_val + if test $ac_count -gt ${ac_path_FGREP_max-0}; then + # Best one so far, save it but keep looking for a better one + ac_cv_path_FGREP="$ac_path_FGREP" + ac_path_FGREP_max=$ac_count + fi + # 10*(2^10) chars as input seems more than enough + test $ac_count -gt 10 && break + done + rm -f conftest.in conftest.tmp conftest.nl conftest.out;; +esac + + $ac_path_FGREP_found && break 3 + done + done + done +IFS=$as_save_IFS + if test -z "$ac_cv_path_FGREP"; then + as_fn_error $? "no acceptable fgrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 + fi +else + ac_cv_path_FGREP=$FGREP +fi + + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_FGREP" >&5 +$as_echo "$ac_cv_path_FGREP" >&6; } + FGREP="$ac_cv_path_FGREP" + + +test -z "$GREP" && GREP=grep + + + + + + + + + + + + + + + + + + + +# Check whether --with-gnu-ld was given. +if test "${with_gnu_ld+set}" = set; then : + withval=$with_gnu_ld; test no = "$withval" || with_gnu_ld=yes +else + with_gnu_ld=no +fi + +ac_prog=ld +if test yes = "$GCC"; then + # Check if gcc -print-prog-name=ld gives a path. + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ld used by $CC" >&5 +$as_echo_n "checking for ld used by $CC... " >&6; } + case $host in + *-*-mingw*) + # gcc leaves a trailing carriage return, which upsets mingw + ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; + *) + ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; + esac + case $ac_prog in + # Accept absolute paths. + [\\/]* | ?:[\\/]*) + re_direlt='/[^/][^/]*/\.\./' + # Canonicalize the pathname of ld + ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` + while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do + ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` + done + test -z "$LD" && LD=$ac_prog + ;; + "") + # If it fails, then pretend we aren't using GCC. + ac_prog=ld + ;; + *) + # If it is relative, then search for the first ld in PATH. + with_gnu_ld=unknown + ;; + esac +elif test yes = "$with_gnu_ld"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for GNU ld" >&5 +$as_echo_n "checking for GNU ld... " >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for non-GNU ld" >&5 +$as_echo_n "checking for non-GNU ld... " >&6; } +fi +if ${lt_cv_path_LD+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -z "$LD"; then + lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR + for ac_dir in $PATH; do + IFS=$lt_save_ifs + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then + lt_cv_path_LD=$ac_dir/$ac_prog + # Check to see if the program is GNU ld. I'd rather use --version, + # but apparently some variants of GNU ld only accept -v. + # Break only if it was the GNU/non-GNU ld that we prefer. + case `"$lt_cv_path_LD" -v 2>&1 &5 +$as_echo "$LD" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi +test -z "$LD" && as_fn_error $? "no acceptable ld found in \$PATH" "$LINENO" 5 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if the linker ($LD) is GNU ld" >&5 +$as_echo_n "checking if the linker ($LD) is GNU ld... " >&6; } +if ${lt_cv_prog_gnu_ld+:} false; then : + $as_echo_n "(cached) " >&6 +else + # I'd rather use --version here, but apparently some GNU lds only accept -v. +case `$LD -v 2>&1 &5 +$as_echo "$lt_cv_prog_gnu_ld" >&6; } +with_gnu_ld=$lt_cv_prog_gnu_ld + + + + + + + + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for BSD- or MS-compatible name lister (nm)" >&5 +$as_echo_n "checking for BSD- or MS-compatible name lister (nm)... " >&6; } +if ${lt_cv_path_NM+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$NM"; then + # Let the user override the test. + lt_cv_path_NM=$NM +else + lt_nm_to_check=${ac_tool_prefix}nm + if test -n "$ac_tool_prefix" && test "$build" = "$host"; then + lt_nm_to_check="$lt_nm_to_check nm" + fi + for lt_tmp_nm in $lt_nm_to_check; do + lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR + for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do + IFS=$lt_save_ifs + test -z "$ac_dir" && ac_dir=. + tmp_nm=$ac_dir/$lt_tmp_nm + if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext"; then + # Check to see if the nm accepts a BSD-compat flag. + # Adding the 'sed 1q' prevents false positives on HP-UX, which says: + # nm: unknown option "B" ignored + # Tru64's nm complains that /dev/null is an invalid object file + # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty + case $build_os in + mingw*) lt_bad_file=conftest.nm/nofile ;; + *) lt_bad_file=/dev/null ;; + esac + case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in + *$lt_bad_file* | *'Invalid file or object type'*) + lt_cv_path_NM="$tmp_nm -B" + break 2 + ;; + *) + case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in + */dev/null*) + lt_cv_path_NM="$tmp_nm -p" + break 2 + ;; + *) + lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but + continue # so that we can try to find one that supports BSD flags + ;; + esac + ;; + esac + fi + done + IFS=$lt_save_ifs + done + : ${lt_cv_path_NM=no} +fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_NM" >&5 +$as_echo "$lt_cv_path_NM" >&6; } +if test no != "$lt_cv_path_NM"; then + NM=$lt_cv_path_NM +else + # Didn't find any BSD compatible name lister, look for dumpbin. + if test -n "$DUMPBIN"; then : + # Let the user override the test. + else + if test -n "$ac_tool_prefix"; then + for ac_prog in dumpbin "link -dump" + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_DUMPBIN+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$DUMPBIN"; then + ac_cv_prog_DUMPBIN="$DUMPBIN" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_DUMPBIN="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +DUMPBIN=$ac_cv_prog_DUMPBIN +if test -n "$DUMPBIN"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DUMPBIN" >&5 +$as_echo "$DUMPBIN" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$DUMPBIN" && break + done +fi +if test -z "$DUMPBIN"; then + ac_ct_DUMPBIN=$DUMPBIN + for ac_prog in dumpbin "link -dump" +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_DUMPBIN+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_DUMPBIN"; then + ac_cv_prog_ac_ct_DUMPBIN="$ac_ct_DUMPBIN" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_DUMPBIN="$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_DUMPBIN=$ac_cv_prog_ac_ct_DUMPBIN +if test -n "$ac_ct_DUMPBIN"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DUMPBIN" >&5 +$as_echo "$ac_ct_DUMPBIN" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_DUMPBIN" && break +done + + if test "x$ac_ct_DUMPBIN" = x; then + DUMPBIN=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + DUMPBIN=$ac_ct_DUMPBIN + fi +fi + + case `$DUMPBIN -symbols -headers /dev/null 2>&1 | sed '1q'` in + *COFF*) + DUMPBIN="$DUMPBIN -symbols -headers" + ;; + *) + DUMPBIN=: + ;; + esac + fi + + if test : != "$DUMPBIN"; then + NM=$DUMPBIN + fi +fi +test -z "$NM" && NM=nm + + + + + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking the name lister ($NM) interface" >&5 +$as_echo_n "checking the name lister ($NM) interface... " >&6; } +if ${lt_cv_nm_interface+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_nm_interface="BSD nm" + echo "int some_variable = 0;" > conftest.$ac_ext + (eval echo "\"\$as_me:$LINENO: $ac_compile\"" >&5) + (eval "$ac_compile" 2>conftest.err) + cat conftest.err >&5 + (eval echo "\"\$as_me:$LINENO: $NM \\\"conftest.$ac_objext\\\"\"" >&5) + (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) + cat conftest.err >&5 + (eval echo "\"\$as_me:$LINENO: output\"" >&5) + cat conftest.out >&5 + if $GREP 'External.*some_variable' conftest.out > /dev/null; then + lt_cv_nm_interface="MS dumpbin" + fi + rm -f conftest* +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_nm_interface" >&5 +$as_echo "$lt_cv_nm_interface" >&6; } + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ln -s works" >&5 +$as_echo_n "checking whether ln -s works... " >&6; } +LN_S=$as_ln_s +if test "$LN_S" = "ln -s"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 +$as_echo "yes" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no, using $LN_S" >&5 +$as_echo "no, using $LN_S" >&6; } +fi + +# find the maximum length of command line arguments +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking the maximum length of command line arguments" >&5 +$as_echo_n "checking the maximum length of command line arguments... " >&6; } +if ${lt_cv_sys_max_cmd_len+:} false; then : + $as_echo_n "(cached) " >&6 +else + i=0 + teststring=ABCD + + case $build_os in + msdosdjgpp*) + # On DJGPP, this test can blow up pretty badly due to problems in libc + # (any single argument exceeding 2000 bytes causes a buffer overrun + # during glob expansion). Even if it were fixed, the result of this + # check would be larger than it should be. + lt_cv_sys_max_cmd_len=12288; # 12K is about right + ;; + + gnu*) + # Under GNU Hurd, this test is not required because there is + # no limit to the length of command line arguments. + # Libtool will interpret -1 as no limit whatsoever + lt_cv_sys_max_cmd_len=-1; + ;; + + cygwin* | mingw* | cegcc*) + # On Win9x/ME, this test blows up -- it succeeds, but takes + # about 5 minutes as the teststring grows exponentially. + # Worse, since 9x/ME are not pre-emptively multitasking, + # you end up with a "frozen" computer, even though with patience + # the test eventually succeeds (with a max line length of 256k). + # Instead, let's just punt: use the minimum linelength reported by + # all of the supported platforms: 8192 (on NT/2K/XP). + lt_cv_sys_max_cmd_len=8192; + ;; + + mint*) + # On MiNT this can take a long time and run out of memory. + lt_cv_sys_max_cmd_len=8192; + ;; + + amigaos*) + # On AmigaOS with pdksh, this test takes hours, literally. + # So we just punt and use a minimum line length of 8192. + lt_cv_sys_max_cmd_len=8192; + ;; + + bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*) + # This has been around since 386BSD, at least. Likely further. + if test -x /sbin/sysctl; then + lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` + elif test -x /usr/sbin/sysctl; then + lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` + else + lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs + fi + # And add a safety zone + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` + ;; + + interix*) + # We know the value 262144 and hardcode it with a safety zone (like BSD) + lt_cv_sys_max_cmd_len=196608 + ;; + + os2*) + # The test takes a long time on OS/2. + lt_cv_sys_max_cmd_len=8192 + ;; + + osf*) + # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure + # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not + # nice to cause kernel panics so lets avoid the loop below. + # First set a reasonable default. + lt_cv_sys_max_cmd_len=16384 + # + if test -x /sbin/sysconfig; then + case `/sbin/sysconfig -q proc exec_disable_arg_limit` in + *1*) lt_cv_sys_max_cmd_len=-1 ;; + esac + fi + ;; + sco3.2v5*) + lt_cv_sys_max_cmd_len=102400 + ;; + sysv5* | sco5v6* | sysv4.2uw2*) + kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` + if test -n "$kargmax"; then + lt_cv_sys_max_cmd_len=`echo $kargmax | sed 's/.*[ ]//'` + else + lt_cv_sys_max_cmd_len=32768 + fi + ;; + *) + lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` + if test -n "$lt_cv_sys_max_cmd_len" && \ + test undefined != "$lt_cv_sys_max_cmd_len"; then + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` + else + # Make teststring a little bigger before we do anything with it. + # a 1K string should be a reasonable start. + for i in 1 2 3 4 5 6 7 8; do + teststring=$teststring$teststring + done + SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} + # If test is not a shell built-in, we'll probably end up computing a + # maximum length that is only half of the actual maximum length, but + # we can't tell. + while { test X`env echo "$teststring$teststring" 2>/dev/null` \ + = "X$teststring$teststring"; } >/dev/null 2>&1 && + test 17 != "$i" # 1/2 MB should be enough + do + i=`expr $i + 1` + teststring=$teststring$teststring + done + # Only check the string length outside the loop. + lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` + teststring= + # Add a significant safety factor because C++ compilers can tack on + # massive amounts of additional arguments before passing them to the + # linker. It appears as though 1/2 is a usable value. + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` + fi + ;; + esac + +fi + +if test -n "$lt_cv_sys_max_cmd_len"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sys_max_cmd_len" >&5 +$as_echo "$lt_cv_sys_max_cmd_len" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: none" >&5 +$as_echo "none" >&6; } +fi +max_cmd_len=$lt_cv_sys_max_cmd_len + + + + + + +: ${CP="cp -f"} +: ${MV="mv -f"} +: ${RM="rm -f"} + +if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then + lt_unset=unset +else + lt_unset=false +fi + + + + + +# test EBCDIC or ASCII +case `echo X|tr X '\101'` in + A) # ASCII based system + # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr + lt_SP2NL='tr \040 \012' + lt_NL2SP='tr \015\012 \040\040' + ;; + *) # EBCDIC based system + lt_SP2NL='tr \100 \n' + lt_NL2SP='tr \r\n \100\100' + ;; +esac + + + + + + + + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to convert $build file names to $host format" >&5 +$as_echo_n "checking how to convert $build file names to $host format... " >&6; } +if ${lt_cv_to_host_file_cmd+:} false; then : + $as_echo_n "(cached) " >&6 +else + case $host in + *-*-mingw* ) + case $build in + *-*-mingw* ) # actually msys + lt_cv_to_host_file_cmd=func_convert_file_msys_to_w32 + ;; + *-*-cygwin* ) + lt_cv_to_host_file_cmd=func_convert_file_cygwin_to_w32 + ;; + * ) # otherwise, assume *nix + lt_cv_to_host_file_cmd=func_convert_file_nix_to_w32 + ;; + esac + ;; + *-*-cygwin* ) + case $build in + *-*-mingw* ) # actually msys + lt_cv_to_host_file_cmd=func_convert_file_msys_to_cygwin + ;; + *-*-cygwin* ) + lt_cv_to_host_file_cmd=func_convert_file_noop + ;; + * ) # otherwise, assume *nix + lt_cv_to_host_file_cmd=func_convert_file_nix_to_cygwin + ;; + esac + ;; + * ) # unhandled hosts (and "normal" native builds) + lt_cv_to_host_file_cmd=func_convert_file_noop + ;; +esac + +fi + +to_host_file_cmd=$lt_cv_to_host_file_cmd +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_to_host_file_cmd" >&5 +$as_echo "$lt_cv_to_host_file_cmd" >&6; } + + + + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to convert $build file names to toolchain format" >&5 +$as_echo_n "checking how to convert $build file names to toolchain format... " >&6; } +if ${lt_cv_to_tool_file_cmd+:} false; then : + $as_echo_n "(cached) " >&6 +else + #assume ordinary cross tools, or native build. +lt_cv_to_tool_file_cmd=func_convert_file_noop +case $host in + *-*-mingw* ) + case $build in + *-*-mingw* ) # actually msys + lt_cv_to_tool_file_cmd=func_convert_file_msys_to_w32 + ;; + esac + ;; +esac + +fi + +to_tool_file_cmd=$lt_cv_to_tool_file_cmd +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_to_tool_file_cmd" >&5 +$as_echo "$lt_cv_to_tool_file_cmd" >&6; } + + + + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $LD option to reload object files" >&5 +$as_echo_n "checking for $LD option to reload object files... " >&6; } +if ${lt_cv_ld_reload_flag+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_ld_reload_flag='-r' +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_reload_flag" >&5 +$as_echo "$lt_cv_ld_reload_flag" >&6; } +reload_flag=$lt_cv_ld_reload_flag +case $reload_flag in +"" | " "*) ;; +*) reload_flag=" $reload_flag" ;; +esac +reload_cmds='$LD$reload_flag -o $output$reload_objs' +case $host_os in + cygwin* | mingw* | pw32* | cegcc*) + if test yes != "$GCC"; then + reload_cmds=false + fi + ;; + darwin*) + if test yes = "$GCC"; then + reload_cmds='$LTCC $LTCFLAGS -nostdlib $wl-r -o $output$reload_objs' + else + reload_cmds='$LD$reload_flag -o $output$reload_objs' + fi + ;; +esac + + + + + + + + + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args. +set dummy ${ac_tool_prefix}objdump; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_OBJDUMP+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$OBJDUMP"; then + ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +OBJDUMP=$ac_cv_prog_OBJDUMP +if test -n "$OBJDUMP"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OBJDUMP" >&5 +$as_echo "$OBJDUMP" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_OBJDUMP"; then + ac_ct_OBJDUMP=$OBJDUMP + # Extract the first word of "objdump", so it can be a program name with args. +set dummy objdump; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_OBJDUMP+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_OBJDUMP"; then + ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_OBJDUMP="objdump" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP +if test -n "$ac_ct_OBJDUMP"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OBJDUMP" >&5 +$as_echo "$ac_ct_OBJDUMP" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_OBJDUMP" = x; then + OBJDUMP="false" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + OBJDUMP=$ac_ct_OBJDUMP + fi +else + OBJDUMP="$ac_cv_prog_OBJDUMP" +fi + +test -z "$OBJDUMP" && OBJDUMP=objdump + + + + + + + + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to recognize dependent libraries" >&5 +$as_echo_n "checking how to recognize dependent libraries... " >&6; } +if ${lt_cv_deplibs_check_method+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_file_magic_cmd='$MAGIC_CMD' +lt_cv_file_magic_test_file= +lt_cv_deplibs_check_method='unknown' +# Need to set the preceding variable on all platforms that support +# interlibrary dependencies. +# 'none' -- dependencies not supported. +# 'unknown' -- same as none, but documents that we really don't know. +# 'pass_all' -- all dependencies passed with no checks. +# 'test_compile' -- check by making test program. +# 'file_magic [[regex]]' -- check by looking for files in library path +# that responds to the $file_magic_cmd with a given extended regex. +# If you have 'file' or equivalent on your system and you're not sure +# whether 'pass_all' will *always* work, you probably want this one. + +case $host_os in +aix[4-9]*) + lt_cv_deplibs_check_method=pass_all + ;; + +beos*) + lt_cv_deplibs_check_method=pass_all + ;; + +bsdi[45]*) + lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib)' + lt_cv_file_magic_cmd='/usr/bin/file -L' + lt_cv_file_magic_test_file=/shlib/libc.so + ;; + +cygwin*) + # func_win32_libid is a shell function defined in ltmain.sh + lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' + lt_cv_file_magic_cmd='func_win32_libid' + ;; + +mingw* | pw32*) + # Base MSYS/MinGW do not provide the 'file' command needed by + # func_win32_libid shell function, so use a weaker test based on 'objdump', + # unless we find 'file', for example because we are cross-compiling. + if ( file / ) >/dev/null 2>&1; then + lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' + lt_cv_file_magic_cmd='func_win32_libid' + else + # Keep this pattern in sync with the one in func_win32_libid. + lt_cv_deplibs_check_method='file_magic file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' + lt_cv_file_magic_cmd='$OBJDUMP -f' + fi + ;; + +cegcc*) + # use the weaker test based on 'objdump'. See mingw*. + lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' + lt_cv_file_magic_cmd='$OBJDUMP -f' + ;; + +darwin* | rhapsody*) + lt_cv_deplibs_check_method=pass_all + ;; + +freebsd* | dragonfly*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then + case $host_cpu in + i*86 ) + # Not sure whether the presence of OpenBSD here was a mistake. + # Let's accept both of them until this is cleared up. + lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[3-9]86 (compact )?demand paged shared library' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` + ;; + esac + else + lt_cv_deplibs_check_method=pass_all + fi + ;; + +haiku*) + lt_cv_deplibs_check_method=pass_all + ;; + +hpux10.20* | hpux11*) + lt_cv_file_magic_cmd=/usr/bin/file + case $host_cpu in + ia64*) + lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - IA64' + lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so + ;; + hppa*64*) + lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF[ -][0-9][0-9])(-bit)?( [LM]SB)? shared object( file)?[, -]* PA-RISC [0-9]\.[0-9]' + lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl + ;; + *) + lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|PA-RISC[0-9]\.[0-9]) shared library' + lt_cv_file_magic_test_file=/usr/lib/libc.sl + ;; + esac + ;; + +interix[3-9]*) + # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|\.a)$' + ;; + +irix5* | irix6* | nonstopux*) + case $LD in + *-32|*"-32 ") libmagic=32-bit;; + *-n32|*"-n32 ") libmagic=N32;; + *-64|*"-64 ") libmagic=64-bit;; + *) libmagic=never-match;; + esac + lt_cv_deplibs_check_method=pass_all + ;; + +# This must be glibc/ELF. +linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) + lt_cv_deplibs_check_method=pass_all + ;; + +netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' + else + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|_pic\.a)$' + fi + ;; + +newos6*) + lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (executable|dynamic lib)' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=/usr/lib/libnls.so + ;; + +*nto* | *qnx*) + lt_cv_deplibs_check_method=pass_all + ;; + +openbsd* | bitrig*) + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|\.so|_pic\.a)$' + else + lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' + fi + ;; + +osf3* | osf4* | osf5*) + lt_cv_deplibs_check_method=pass_all + ;; + +rdos*) + lt_cv_deplibs_check_method=pass_all + ;; + +solaris*) + lt_cv_deplibs_check_method=pass_all + ;; + +sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) + lt_cv_deplibs_check_method=pass_all + ;; + +sysv4 | sysv4.3*) + case $host_vendor in + motorola) + lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib) M[0-9][0-9]* Version [0-9]' + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` + ;; + ncr) + lt_cv_deplibs_check_method=pass_all + ;; + sequent) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [LM]SB (shared object|dynamic lib )' + ;; + sni) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method="file_magic ELF [0-9][0-9]*-bit [LM]SB dynamic lib" + lt_cv_file_magic_test_file=/lib/libc.so + ;; + siemens) + lt_cv_deplibs_check_method=pass_all + ;; + pc) + lt_cv_deplibs_check_method=pass_all + ;; + esac + ;; + +tpf*) + lt_cv_deplibs_check_method=pass_all + ;; +os2*) + lt_cv_deplibs_check_method=pass_all + ;; +esac + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_deplibs_check_method" >&5 +$as_echo "$lt_cv_deplibs_check_method" >&6; } + +file_magic_glob= +want_nocaseglob=no +if test "$build" = "$host"; then + case $host_os in + mingw* | pw32*) + if ( shopt | grep nocaseglob ) >/dev/null 2>&1; then + want_nocaseglob=yes + else + file_magic_glob=`echo aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ | $SED -e "s/\(..\)/s\/[\1]\/[\1]\/g;/g"` + fi + ;; + esac +fi + +file_magic_cmd=$lt_cv_file_magic_cmd +deplibs_check_method=$lt_cv_deplibs_check_method +test -z "$deplibs_check_method" && deplibs_check_method=unknown + + + + + + + + + + + + + + + + + + + + + + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}dlltool", so it can be a program name with args. +set dummy ${ac_tool_prefix}dlltool; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_DLLTOOL+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$DLLTOOL"; then + ac_cv_prog_DLLTOOL="$DLLTOOL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_DLLTOOL="${ac_tool_prefix}dlltool" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +DLLTOOL=$ac_cv_prog_DLLTOOL +if test -n "$DLLTOOL"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DLLTOOL" >&5 +$as_echo "$DLLTOOL" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_DLLTOOL"; then + ac_ct_DLLTOOL=$DLLTOOL + # Extract the first word of "dlltool", so it can be a program name with args. +set dummy dlltool; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_DLLTOOL+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_DLLTOOL"; then + ac_cv_prog_ac_ct_DLLTOOL="$ac_ct_DLLTOOL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_DLLTOOL="dlltool" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_DLLTOOL=$ac_cv_prog_ac_ct_DLLTOOL +if test -n "$ac_ct_DLLTOOL"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DLLTOOL" >&5 +$as_echo "$ac_ct_DLLTOOL" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_DLLTOOL" = x; then + DLLTOOL="false" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + DLLTOOL=$ac_ct_DLLTOOL + fi +else + DLLTOOL="$ac_cv_prog_DLLTOOL" +fi + +test -z "$DLLTOOL" && DLLTOOL=dlltool + + + + + + + + + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to associate runtime and link libraries" >&5 +$as_echo_n "checking how to associate runtime and link libraries... " >&6; } +if ${lt_cv_sharedlib_from_linklib_cmd+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_sharedlib_from_linklib_cmd='unknown' + +case $host_os in +cygwin* | mingw* | pw32* | cegcc*) + # two different shell functions defined in ltmain.sh; + # decide which one to use based on capabilities of $DLLTOOL + case `$DLLTOOL --help 2>&1` in + *--identify-strict*) + lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib + ;; + *) + lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib_fallback + ;; + esac + ;; +*) + # fallback: assume linklib IS sharedlib + lt_cv_sharedlib_from_linklib_cmd=$ECHO + ;; +esac + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sharedlib_from_linklib_cmd" >&5 +$as_echo "$lt_cv_sharedlib_from_linklib_cmd" >&6; } +sharedlib_from_linklib_cmd=$lt_cv_sharedlib_from_linklib_cmd +test -z "$sharedlib_from_linklib_cmd" && sharedlib_from_linklib_cmd=$ECHO + + + + + + + + +if test -n "$ac_tool_prefix"; then + for ac_prog in ar + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_AR+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$AR"; then + ac_cv_prog_AR="$AR" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_AR="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +AR=$ac_cv_prog_AR +if test -n "$AR"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AR" >&5 +$as_echo "$AR" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$AR" && break + done +fi +if test -z "$AR"; then + ac_ct_AR=$AR + for ac_prog in ar +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_AR+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_AR"; then + ac_cv_prog_ac_ct_AR="$ac_ct_AR" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_AR="$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_AR=$ac_cv_prog_ac_ct_AR +if test -n "$ac_ct_AR"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_AR" >&5 +$as_echo "$ac_ct_AR" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_AR" && break +done + + if test "x$ac_ct_AR" = x; then + AR="false" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + AR=$ac_ct_AR + fi +fi + +: ${AR=ar} + + + + + + +# Use ARFLAGS variable as AR's operation code to sync the variable naming with +# Automake. If both AR_FLAGS and ARFLAGS are specified, AR_FLAGS should have +# higher priority because thats what people were doing historically (setting +# ARFLAGS for automake and AR_FLAGS for libtool). FIXME: Make the AR_FLAGS +# variable obsoleted/removed. + +test ${AR_FLAGS+y} || AR_FLAGS=${ARFLAGS-cr} +lt_ar_flags=$AR_FLAGS + + + + + + +# Make AR_FLAGS overridable by 'make ARFLAGS='. Don't try to run-time override +# by AR_FLAGS because that was never working and AR_FLAGS is about to die. + + + + + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for archiver @FILE support" >&5 +$as_echo_n "checking for archiver @FILE support... " >&6; } +if ${lt_cv_ar_at_file+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_ar_at_file=no + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + echo conftest.$ac_objext > conftest.lst + lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&5' + { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5 + (eval $lt_ar_try) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } + if test 0 -eq "$ac_status"; then + # Ensure the archiver fails upon bogus file names. + rm -f conftest.$ac_objext libconftest.a + { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5 + (eval $lt_ar_try) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } + if test 0 -ne "$ac_status"; then + lt_cv_ar_at_file=@ + fi + fi + rm -f conftest.* libconftest.a + +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ar_at_file" >&5 +$as_echo "$lt_cv_ar_at_file" >&6; } + +if test no = "$lt_cv_ar_at_file"; then + archiver_list_spec= +else + archiver_list_spec=$lt_cv_ar_at_file +fi + + + + + + + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. +set dummy ${ac_tool_prefix}strip; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_STRIP+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$STRIP"; then + ac_cv_prog_STRIP="$STRIP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_STRIP="${ac_tool_prefix}strip" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +STRIP=$ac_cv_prog_STRIP +if test -n "$STRIP"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 +$as_echo "$STRIP" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_STRIP"; then + ac_ct_STRIP=$STRIP + # Extract the first word of "strip", so it can be a program name with args. +set dummy strip; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_STRIP+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_STRIP"; then + ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_STRIP="strip" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP +if test -n "$ac_ct_STRIP"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 +$as_echo "$ac_ct_STRIP" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_STRIP" = x; then + STRIP=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + STRIP=$ac_ct_STRIP + fi +else + STRIP="$ac_cv_prog_STRIP" +fi + +test -z "$STRIP" && STRIP=: + + + + + + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. +set dummy ${ac_tool_prefix}ranlib; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_RANLIB+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$RANLIB"; then + ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +RANLIB=$ac_cv_prog_RANLIB +if test -n "$RANLIB"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $RANLIB" >&5 +$as_echo "$RANLIB" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_RANLIB"; then + ac_ct_RANLIB=$RANLIB + # Extract the first word of "ranlib", so it can be a program name with args. +set dummy ranlib; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_RANLIB+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_RANLIB"; then + ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_RANLIB="ranlib" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB +if test -n "$ac_ct_RANLIB"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_RANLIB" >&5 +$as_echo "$ac_ct_RANLIB" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_RANLIB" = x; then + RANLIB=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + RANLIB=$ac_ct_RANLIB + fi +else + RANLIB="$ac_cv_prog_RANLIB" +fi + +test -z "$RANLIB" && RANLIB=: + + + + + + +# Determine commands to create old-style static archives. +old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' +old_postinstall_cmds='chmod 644 $oldlib' +old_postuninstall_cmds= + +if test -n "$RANLIB"; then + case $host_os in + bitrig* | openbsd*) + old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib" + ;; + *) + old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$tool_oldlib" + ;; + esac + old_archive_cmds="$old_archive_cmds~\$RANLIB \$tool_oldlib" +fi + +case $host_os in + darwin*) + lock_old_archive_extraction=yes ;; + *) + lock_old_archive_extraction=no ;; +esac + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# If no C compiler flags were specified, use CFLAGS. +LTCFLAGS=${LTCFLAGS-"$CFLAGS"} + +# Allow CC to be a program name with arguments. +compiler=$CC + + +# Check for command to grab the raw symbol name followed by C symbol from nm. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking command to parse $NM output from $compiler object" >&5 +$as_echo_n "checking command to parse $NM output from $compiler object... " >&6; } +if ${lt_cv_sys_global_symbol_pipe+:} false; then : + $as_echo_n "(cached) " >&6 +else + +# These are sane defaults that work on at least a few old systems. +# [They come from Ultrix. What could be older than Ultrix?!! ;)] + +# Character class describing NM global symbol codes. +symcode='[BCDEGRST]' + +# Regexp to match symbols that can be accessed directly from C. +sympat='\([_A-Za-z][_A-Za-z0-9]*\)' + +# Define system-specific variables. +case $host_os in +aix*) + symcode='[BCDT]' + ;; +cygwin* | mingw* | pw32* | cegcc*) + symcode='[ABCDGISTW]' + ;; +hpux*) + if test ia64 = "$host_cpu"; then + symcode='[ABCDEGRST]' + fi + ;; +irix* | nonstopux*) + symcode='[BCDEGRST]' + ;; +osf*) + symcode='[BCDEGQRST]' + ;; +solaris*) + symcode='[BDRT]' + ;; +sco3.2v5*) + symcode='[DT]' + ;; +sysv4.2uw2*) + symcode='[DT]' + ;; +sysv5* | sco5v6* | unixware* | OpenUNIX*) + symcode='[ABDT]' + ;; +sysv4) + symcode='[DFNSTU]' + ;; +esac + +# If we're using GNU nm, then use its standard symbol codes. +case `$NM -V 2>&1` in +*GNU* | *'with BFD'*) + symcode='[ABCDGIRSTW]' ;; +esac + +if test "$lt_cv_nm_interface" = "MS dumpbin"; then + # Gets list of data symbols to import. + lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'" + # Adjust the below global symbol transforms to fixup imported variables. + lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'" + lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'" + lt_c_name_lib_hook="\ + -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\ + -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'" +else + # Disable hooks by default. + lt_cv_sys_global_symbol_to_import= + lt_cdecl_hook= + lt_c_name_hook= + lt_c_name_lib_hook= +fi + +# Transform an extracted symbol line into a proper C declaration. +# Some systems (esp. on ia64) link data and code symbols differently, +# so use this general approach. +lt_cv_sys_global_symbol_to_cdecl="sed -n"\ +$lt_cdecl_hook\ +" -e 's/^T .* \(.*\)$/extern int \1();/p'"\ +" -e 's/^$symcode$symcode* .* \(.*\)$/extern char \1;/p'" + +# Transform an extracted symbol line into symbol name and symbol address +lt_cv_sys_global_symbol_to_c_name_address="sed -n"\ +$lt_c_name_hook\ +" -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ +" -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'" + +# Transform an extracted symbol line into symbol name with lib prefix and +# symbol address. +lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\ +$lt_c_name_lib_hook\ +" -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ +" -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\ +" -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/p'" + +# Handle CRLF in mingw tool chain +opt_cr= +case $build_os in +mingw*) + opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp + ;; +esac + +# Try without a prefix underscore, then with it. +for ac_symprfx in "" "_"; do + + # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. + symxfrm="\\1 $ac_symprfx\\2 \\2" + + # Write the raw and C identifiers. + if test "$lt_cv_nm_interface" = "MS dumpbin"; then + # Fake it for dumpbin and say T for any non-static function, + # D for any global variable and I for any imported variable. + # Also find C++ and __fastcall symbols from MSVC++ or ICC, + # which start with @ or ?. + lt_cv_sys_global_symbol_pipe="$AWK '"\ +" {last_section=section; section=\$ 3};"\ +" /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\ +" /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ +" /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\ +" /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\ +" /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\ +" \$ 0!~/External *\|/{next};"\ +" / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ +" {if(hide[section]) next};"\ +" {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\ +" {split(\$ 0,a,/\||\r/); split(a[2],s)};"\ +" s[1]~/^[@?]/{print f,s[1],s[1]; next};"\ +" s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\ +" ' prfx=^$ac_symprfx" + else + lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[ ]\($symcode$symcode*\)[ ][ ]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" + fi + lt_cv_sys_global_symbol_pipe="$lt_cv_sys_global_symbol_pipe | sed '/ __gnu_lto/d'" + + # Check to see that the pipe works correctly. + pipe_works=no + + rm -f conftest* + cat > conftest.$ac_ext <<_LT_EOF +#ifdef __cplusplus +extern "C" { +#endif +char nm_test_var; +void nm_test_func(void); +void nm_test_func(void){} +#ifdef __cplusplus +} +#endif +int main(){nm_test_var='a';nm_test_func();return(0);} +_LT_EOF + + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then + # Now try to grab the symbols. + nlist=conftest.nm + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist\""; } >&5 + (eval $NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } && test -s "$nlist"; then + # Try sorting and uniquifying the output. + if sort "$nlist" | uniq > "$nlist"T; then + mv -f "$nlist"T "$nlist" + else + rm -f "$nlist"T + fi + + # Make sure that we snagged all the symbols we need. + if $GREP ' nm_test_var$' "$nlist" >/dev/null; then + if $GREP ' nm_test_func$' "$nlist" >/dev/null; then + cat <<_LT_EOF > conftest.$ac_ext +/* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ +#if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE +/* DATA imports from DLLs on WIN32 can't be const, because runtime + relocations are performed -- see ld's documentation on pseudo-relocs. */ +# define LT_DLSYM_CONST +#elif defined __osf__ +/* This system does not cope well with relocations in const data. */ +# define LT_DLSYM_CONST +#else +# define LT_DLSYM_CONST const +#endif + +#ifdef __cplusplus +extern "C" { +#endif + +_LT_EOF + # Now generate the symbol file. + eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' + + cat <<_LT_EOF >> conftest.$ac_ext + +/* The mapping between symbol names and symbols. */ +LT_DLSYM_CONST struct { + const char *name; + void *address; +} +lt__PROGRAM__LTX_preloaded_symbols[] = +{ + { "@PROGRAM@", (void *) 0 }, +_LT_EOF + $SED "s/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext + cat <<\_LT_EOF >> conftest.$ac_ext + {0, (void *) 0} +}; + +/* This works around a problem in FreeBSD linker */ +#ifdef FREEBSD_WORKAROUND +static const void *lt_preloaded_setup() { + return lt__PROGRAM__LTX_preloaded_symbols; +} +#endif + +#ifdef __cplusplus +} +#endif +_LT_EOF + # Now try linking the two files. + mv conftest.$ac_objext conftstm.$ac_objext + lt_globsym_save_LIBS=$LIBS + lt_globsym_save_CFLAGS=$CFLAGS + LIBS=conftstm.$ac_objext + CFLAGS="$CFLAGS$lt_prog_compiler_no_builtin_flag" + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 + (eval $ac_link) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } && test -s conftest$ac_exeext; then + pipe_works=yes + fi + LIBS=$lt_globsym_save_LIBS + CFLAGS=$lt_globsym_save_CFLAGS + else + echo "cannot find nm_test_func in $nlist" >&5 + fi + else + echo "cannot find nm_test_var in $nlist" >&5 + fi + else + echo "cannot run $lt_cv_sys_global_symbol_pipe" >&5 + fi + else + echo "$progname: failed program was:" >&5 + cat conftest.$ac_ext >&5 + fi + rm -rf conftest* conftst* + + # Do not use the global_symbol_pipe unless it works. + if test yes = "$pipe_works"; then + break + else + lt_cv_sys_global_symbol_pipe= + fi +done + +fi + +if test -z "$lt_cv_sys_global_symbol_pipe"; then + lt_cv_sys_global_symbol_to_cdecl= +fi +if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: failed" >&5 +$as_echo "failed" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: ok" >&5 +$as_echo "ok" >&6; } +fi + +# Response file support. +if test "$lt_cv_nm_interface" = "MS dumpbin"; then + nm_file_list_spec='@' +elif $NM --help 2>/dev/null | grep '[@]FILE' >/dev/null; then + nm_file_list_spec='@' +fi + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for sysroot" >&5 +$as_echo_n "checking for sysroot... " >&6; } + +# Check whether --with-sysroot was given. +if test "${with_sysroot+set}" = set; then : + withval=$with_sysroot; +else + with_sysroot=no +fi + + +lt_sysroot= +case $with_sysroot in #( + yes) + if test yes = "$GCC"; then + lt_sysroot=`$CC --print-sysroot 2>/dev/null` + fi + ;; #( + /*) + lt_sysroot=`echo "$with_sysroot" | sed -e "$sed_quote_subst"` + ;; #( + no|'') + ;; #( + *) + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $with_sysroot" >&5 +$as_echo "$with_sysroot" >&6; } + as_fn_error $? "The sysroot must be an absolute path." "$LINENO" 5 + ;; +esac + + { $as_echo "$as_me:${as_lineno-$LINENO}: result: ${lt_sysroot:-no}" >&5 +$as_echo "${lt_sysroot:-no}" >&6; } + + + + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for a working dd" >&5 +$as_echo_n "checking for a working dd... " >&6; } +if ${ac_cv_path_lt_DD+:} false; then : + $as_echo_n "(cached) " >&6 +else + printf 0123456789abcdef0123456789abcdef >conftest.i +cat conftest.i conftest.i >conftest2.i +: ${lt_DD:=$DD} +if test -z "$lt_DD"; then + ac_path_lt_DD_found=false + # Loop through the user's path and test for each of PROGNAME-LIST + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_prog in dd; do + for ac_exec_ext in '' $ac_executable_extensions; do + ac_path_lt_DD="$as_dir/$ac_prog$ac_exec_ext" + as_fn_executable_p "$ac_path_lt_DD" || continue +if "$ac_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then + cmp -s conftest.i conftest.out \ + && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=: +fi + $ac_path_lt_DD_found && break 3 + done + done + done +IFS=$as_save_IFS + if test -z "$ac_cv_path_lt_DD"; then + : + fi +else + ac_cv_path_lt_DD=$lt_DD +fi + +rm -f conftest.i conftest2.i conftest.out +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_lt_DD" >&5 +$as_echo "$ac_cv_path_lt_DD" >&6; } + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to truncate binary pipes" >&5 +$as_echo_n "checking how to truncate binary pipes... " >&6; } +if ${lt_cv_truncate_bin+:} false; then : + $as_echo_n "(cached) " >&6 +else + printf 0123456789abcdef0123456789abcdef >conftest.i +cat conftest.i conftest.i >conftest2.i +lt_cv_truncate_bin= +if "$ac_cv_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then + cmp -s conftest.i conftest.out \ + && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1" +fi +rm -f conftest.i conftest2.i conftest.out +test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q" +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_truncate_bin" >&5 +$as_echo "$lt_cv_truncate_bin" >&6; } + + + + + + + +# Calculate cc_basename. Skip known compiler wrappers and cross-prefix. +func_cc_basename () +{ + for cc_temp in $*""; do + case $cc_temp in + compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; + distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; + \-*) ;; + *) break;; + esac + done + func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` +} + +# Check whether --enable-libtool-lock was given. +if test "${enable_libtool_lock+set}" = set; then : + enableval=$enable_libtool_lock; +fi + +test no = "$enable_libtool_lock" || enable_libtool_lock=yes + +# Some flags need to be propagated to the compiler or linker for good +# libtool support. +case $host in +ia64-*-hpux*) + # Find out what ABI is being produced by ac_compile, and set mode + # options accordingly. + echo 'int i;' > conftest.$ac_ext + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then + case `/usr/bin/file conftest.$ac_objext` in + *ELF-32*) + HPUX_IA64_MODE=32 + ;; + *ELF-64*) + HPUX_IA64_MODE=64 + ;; + esac + fi + rm -rf conftest* + ;; +*-*-irix6*) + # Find out what ABI is being produced by ac_compile, and set linker + # options accordingly. + echo '#line '$LINENO' "configure"' > conftest.$ac_ext + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then + if test yes = "$lt_cv_prog_gnu_ld"; then + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -melf32bsmip" + ;; + *N32*) + LD="${LD-ld} -melf32bmipn32" + ;; + *64-bit*) + LD="${LD-ld} -melf64bmip" + ;; + esac + else + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -32" + ;; + *N32*) + LD="${LD-ld} -n32" + ;; + *64-bit*) + LD="${LD-ld} -64" + ;; + esac + fi + fi + rm -rf conftest* + ;; + +mips64*-*linux*) + # Find out what ABI is being produced by ac_compile, and set linker + # options accordingly. + echo '#line '$LINENO' "configure"' > conftest.$ac_ext + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then + emul=elf + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + emul="${emul}32" + ;; + *64-bit*) + emul="${emul}64" + ;; + esac + case `/usr/bin/file conftest.$ac_objext` in + *MSB*) + emul="${emul}btsmip" + ;; + *LSB*) + emul="${emul}ltsmip" + ;; + esac + case `/usr/bin/file conftest.$ac_objext` in + *N32*) + emul="${emul}n32" + ;; + esac + LD="${LD-ld} -m $emul" + fi + rm -rf conftest* + ;; + +x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ +s390*-*linux*|s390*-*tpf*|sparc*-*linux*) + # Find out what ABI is being produced by ac_compile, and set linker + # options accordingly. Note that the listed cases only cover the + # situations where additional linker options are needed (such as when + # doing 32-bit compilation for a host where ld defaults to 64-bit, or + # vice versa); the common cases where no linker options are needed do + # not appear in the list. + echo 'int i;' > conftest.$ac_ext + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then + case `/usr/bin/file conftest.o` in + *32-bit*) + case $host in + x86_64-*kfreebsd*-gnu) + LD="${LD-ld} -m elf_i386_fbsd" + ;; + x86_64-*linux*) + case `/usr/bin/file conftest.o` in + *x86-64*) + LD="${LD-ld} -m elf32_x86_64" + ;; + *) + LD="${LD-ld} -m elf_i386" + ;; + esac + ;; + powerpc64le-*linux*) + LD="${LD-ld} -m elf32lppclinux" + ;; + powerpc64-*linux*) + LD="${LD-ld} -m elf32ppclinux" + ;; + s390x-*linux*) + LD="${LD-ld} -m elf_s390" + ;; + sparc64-*linux*) + LD="${LD-ld} -m elf32_sparc" + ;; + esac + ;; + *64-bit*) + case $host in + x86_64-*kfreebsd*-gnu) + LD="${LD-ld} -m elf_x86_64_fbsd" + ;; + x86_64-*linux*) + LD="${LD-ld} -m elf_x86_64" + ;; + powerpcle-*linux*) + LD="${LD-ld} -m elf64lppc" + ;; + powerpc-*linux*) + LD="${LD-ld} -m elf64ppc" + ;; + s390*-*linux*|s390*-*tpf*) + LD="${LD-ld} -m elf64_s390" + ;; + sparc*-*linux*) + LD="${LD-ld} -m elf64_sparc" + ;; + esac + ;; + esac + fi + rm -rf conftest* + ;; + +*-*-sco3.2v5*) + # On SCO OpenServer 5, we need -belf to get full-featured binaries. + SAVE_CFLAGS=$CFLAGS + CFLAGS="$CFLAGS -belf" + { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler needs -belf" >&5 +$as_echo_n "checking whether the C compiler needs -belf... " >&6; } +if ${lt_cv_cc_needs_belf+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + lt_cv_cc_needs_belf=yes +else + lt_cv_cc_needs_belf=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_cc_needs_belf" >&5 +$as_echo "$lt_cv_cc_needs_belf" >&6; } + if test yes != "$lt_cv_cc_needs_belf"; then + # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf + CFLAGS=$SAVE_CFLAGS + fi + ;; +*-*solaris*) + # Find out what ABI is being produced by ac_compile, and set linker + # options accordingly. + echo 'int i;' > conftest.$ac_ext + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then + case `/usr/bin/file conftest.o` in + *64-bit*) + case $lt_cv_prog_gnu_ld in + yes*) + case $host in + i?86-*-solaris*|x86_64-*-solaris*) + LD="${LD-ld} -m elf_x86_64" + ;; + sparc*-*-solaris*) + LD="${LD-ld} -m elf64_sparc" + ;; + esac + # GNU ld 2.21 introduced _sol2 emulations. Use them if available. + if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then + LD=${LD-ld}_sol2 + fi + ;; + *) + if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then + LD="${LD-ld} -64" + fi + ;; + esac + ;; + esac + fi + rm -rf conftest* + ;; +esac + +need_locks=$enable_libtool_lock + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}mt", so it can be a program name with args. +set dummy ${ac_tool_prefix}mt; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_MANIFEST_TOOL+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$MANIFEST_TOOL"; then + ac_cv_prog_MANIFEST_TOOL="$MANIFEST_TOOL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_MANIFEST_TOOL="${ac_tool_prefix}mt" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +MANIFEST_TOOL=$ac_cv_prog_MANIFEST_TOOL +if test -n "$MANIFEST_TOOL"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MANIFEST_TOOL" >&5 +$as_echo "$MANIFEST_TOOL" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_MANIFEST_TOOL"; then + ac_ct_MANIFEST_TOOL=$MANIFEST_TOOL + # Extract the first word of "mt", so it can be a program name with args. +set dummy mt; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_MANIFEST_TOOL+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_MANIFEST_TOOL"; then + ac_cv_prog_ac_ct_MANIFEST_TOOL="$ac_ct_MANIFEST_TOOL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_MANIFEST_TOOL="mt" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_MANIFEST_TOOL=$ac_cv_prog_ac_ct_MANIFEST_TOOL +if test -n "$ac_ct_MANIFEST_TOOL"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_MANIFEST_TOOL" >&5 +$as_echo "$ac_ct_MANIFEST_TOOL" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_MANIFEST_TOOL" = x; then + MANIFEST_TOOL=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + MANIFEST_TOOL=$ac_ct_MANIFEST_TOOL + fi +else + MANIFEST_TOOL="$ac_cv_prog_MANIFEST_TOOL" +fi + +test -z "$MANIFEST_TOOL" && MANIFEST_TOOL=mt +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if $MANIFEST_TOOL is a manifest tool" >&5 +$as_echo_n "checking if $MANIFEST_TOOL is a manifest tool... " >&6; } +if ${lt_cv_path_mainfest_tool+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_path_mainfest_tool=no + echo "$as_me:$LINENO: $MANIFEST_TOOL '-?'" >&5 + $MANIFEST_TOOL '-?' 2>conftest.err > conftest.out + cat conftest.err >&5 + if $GREP 'Manifest Tool' conftest.out > /dev/null; then + lt_cv_path_mainfest_tool=yes + fi + rm -f conftest* +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_mainfest_tool" >&5 +$as_echo "$lt_cv_path_mainfest_tool" >&6; } +if test yes != "$lt_cv_path_mainfest_tool"; then + MANIFEST_TOOL=: +fi + + + + + + + case $host_os in + rhapsody* | darwin*) + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}dsymutil", so it can be a program name with args. +set dummy ${ac_tool_prefix}dsymutil; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_DSYMUTIL+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$DSYMUTIL"; then + ac_cv_prog_DSYMUTIL="$DSYMUTIL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_DSYMUTIL="${ac_tool_prefix}dsymutil" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +DSYMUTIL=$ac_cv_prog_DSYMUTIL +if test -n "$DSYMUTIL"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DSYMUTIL" >&5 +$as_echo "$DSYMUTIL" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_DSYMUTIL"; then + ac_ct_DSYMUTIL=$DSYMUTIL + # Extract the first word of "dsymutil", so it can be a program name with args. +set dummy dsymutil; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_DSYMUTIL+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_DSYMUTIL"; then + ac_cv_prog_ac_ct_DSYMUTIL="$ac_ct_DSYMUTIL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_DSYMUTIL="dsymutil" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_DSYMUTIL=$ac_cv_prog_ac_ct_DSYMUTIL +if test -n "$ac_ct_DSYMUTIL"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DSYMUTIL" >&5 +$as_echo "$ac_ct_DSYMUTIL" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_DSYMUTIL" = x; then + DSYMUTIL=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + DSYMUTIL=$ac_ct_DSYMUTIL + fi +else + DSYMUTIL="$ac_cv_prog_DSYMUTIL" +fi + + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}nmedit", so it can be a program name with args. +set dummy ${ac_tool_prefix}nmedit; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_NMEDIT+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$NMEDIT"; then + ac_cv_prog_NMEDIT="$NMEDIT" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_NMEDIT="${ac_tool_prefix}nmedit" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +NMEDIT=$ac_cv_prog_NMEDIT +if test -n "$NMEDIT"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $NMEDIT" >&5 +$as_echo "$NMEDIT" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_NMEDIT"; then + ac_ct_NMEDIT=$NMEDIT + # Extract the first word of "nmedit", so it can be a program name with args. +set dummy nmedit; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_NMEDIT+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_NMEDIT"; then + ac_cv_prog_ac_ct_NMEDIT="$ac_ct_NMEDIT" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_NMEDIT="nmedit" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_NMEDIT=$ac_cv_prog_ac_ct_NMEDIT +if test -n "$ac_ct_NMEDIT"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_NMEDIT" >&5 +$as_echo "$ac_ct_NMEDIT" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_NMEDIT" = x; then + NMEDIT=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + NMEDIT=$ac_ct_NMEDIT + fi +else + NMEDIT="$ac_cv_prog_NMEDIT" +fi + + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}lipo", so it can be a program name with args. +set dummy ${ac_tool_prefix}lipo; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_LIPO+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$LIPO"; then + ac_cv_prog_LIPO="$LIPO" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_LIPO="${ac_tool_prefix}lipo" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +LIPO=$ac_cv_prog_LIPO +if test -n "$LIPO"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $LIPO" >&5 +$as_echo "$LIPO" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_LIPO"; then + ac_ct_LIPO=$LIPO + # Extract the first word of "lipo", so it can be a program name with args. +set dummy lipo; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_LIPO+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_LIPO"; then + ac_cv_prog_ac_ct_LIPO="$ac_ct_LIPO" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_LIPO="lipo" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_LIPO=$ac_cv_prog_ac_ct_LIPO +if test -n "$ac_ct_LIPO"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_LIPO" >&5 +$as_echo "$ac_ct_LIPO" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_LIPO" = x; then + LIPO=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + LIPO=$ac_ct_LIPO + fi +else + LIPO="$ac_cv_prog_LIPO" +fi + + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}otool", so it can be a program name with args. +set dummy ${ac_tool_prefix}otool; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_OTOOL+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$OTOOL"; then + ac_cv_prog_OTOOL="$OTOOL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_OTOOL="${ac_tool_prefix}otool" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +OTOOL=$ac_cv_prog_OTOOL +if test -n "$OTOOL"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OTOOL" >&5 +$as_echo "$OTOOL" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_OTOOL"; then + ac_ct_OTOOL=$OTOOL + # Extract the first word of "otool", so it can be a program name with args. +set dummy otool; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_OTOOL+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_OTOOL"; then + ac_cv_prog_ac_ct_OTOOL="$ac_ct_OTOOL" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_OTOOL="otool" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_OTOOL=$ac_cv_prog_ac_ct_OTOOL +if test -n "$ac_ct_OTOOL"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OTOOL" >&5 +$as_echo "$ac_ct_OTOOL" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_OTOOL" = x; then + OTOOL=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + OTOOL=$ac_ct_OTOOL + fi +else + OTOOL="$ac_cv_prog_OTOOL" +fi + + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}otool64", so it can be a program name with args. +set dummy ${ac_tool_prefix}otool64; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_OTOOL64+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$OTOOL64"; then + ac_cv_prog_OTOOL64="$OTOOL64" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_OTOOL64="${ac_tool_prefix}otool64" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +OTOOL64=$ac_cv_prog_OTOOL64 +if test -n "$OTOOL64"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OTOOL64" >&5 +$as_echo "$OTOOL64" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_OTOOL64"; then + ac_ct_OTOOL64=$OTOOL64 + # Extract the first word of "otool64", so it can be a program name with args. +set dummy otool64; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_OTOOL64+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_OTOOL64"; then + ac_cv_prog_ac_ct_OTOOL64="$ac_ct_OTOOL64" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_OTOOL64="otool64" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_OTOOL64=$ac_cv_prog_ac_ct_OTOOL64 +if test -n "$ac_ct_OTOOL64"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OTOOL64" >&5 +$as_echo "$ac_ct_OTOOL64" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_OTOOL64" = x; then + OTOOL64=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + OTOOL64=$ac_ct_OTOOL64 + fi +else + OTOOL64="$ac_cv_prog_OTOOL64" +fi + + + + + + + + + + + + + + + + + + + + + + + + + + + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -single_module linker flag" >&5 +$as_echo_n "checking for -single_module linker flag... " >&6; } +if ${lt_cv_apple_cc_single_mod+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_apple_cc_single_mod=no + if test -z "$LT_MULTI_MODULE"; then + # By default we will add the -single_module flag. You can override + # by either setting the environment variable LT_MULTI_MODULE + # non-empty at configure time, or by adding -multi_module to the + # link flags. + rm -rf libconftest.dylib* + echo "int foo(void){return 1;}" > conftest.c + echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ +-dynamiclib -Wl,-single_module conftest.c" >&5 + $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ + -dynamiclib -Wl,-single_module conftest.c 2>conftest.err + _lt_result=$? + # If there is a non-empty error log, and "single_module" + # appears in it, assume the flag caused a linker warning + if test -s conftest.err && $GREP single_module conftest.err; then + cat conftest.err >&5 + # Otherwise, if the output was created with a 0 exit code from + # the compiler, it worked. + elif test -f libconftest.dylib && test 0 = "$_lt_result"; then + lt_cv_apple_cc_single_mod=yes + else + cat conftest.err >&5 + fi + rm -rf libconftest.dylib* + rm -f conftest.* + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_apple_cc_single_mod" >&5 +$as_echo "$lt_cv_apple_cc_single_mod" >&6; } + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -exported_symbols_list linker flag" >&5 +$as_echo_n "checking for -exported_symbols_list linker flag... " >&6; } +if ${lt_cv_ld_exported_symbols_list+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_ld_exported_symbols_list=no + save_LDFLAGS=$LDFLAGS + echo "_main" > conftest.sym + LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + lt_cv_ld_exported_symbols_list=yes +else + lt_cv_ld_exported_symbols_list=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + LDFLAGS=$save_LDFLAGS + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_exported_symbols_list" >&5 +$as_echo "$lt_cv_ld_exported_symbols_list" >&6; } + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for -force_load linker flag" >&5 +$as_echo_n "checking for -force_load linker flag... " >&6; } +if ${lt_cv_ld_force_load+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_ld_force_load=no + cat > conftest.c << _LT_EOF +int forced_loaded() { return 2;} +_LT_EOF + echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&5 + $LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&5 + echo "$AR $AR_FLAGS libconftest.a conftest.o" >&5 + $AR $AR_FLAGS libconftest.a conftest.o 2>&5 + echo "$RANLIB libconftest.a" >&5 + $RANLIB libconftest.a 2>&5 + cat > conftest.c << _LT_EOF +int main() { return 0;} +_LT_EOF + echo "$LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a" >&5 + $LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a 2>conftest.err + _lt_result=$? + if test -s conftest.err && $GREP force_load conftest.err; then + cat conftest.err >&5 + elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then + lt_cv_ld_force_load=yes + else + cat conftest.err >&5 + fi + rm -f conftest.err libconftest.a conftest conftest.c + rm -rf conftest.dSYM + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_force_load" >&5 +$as_echo "$lt_cv_ld_force_load" >&6; } + case $host_os in + rhapsody* | darwin1.[012]) + _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;; + darwin1.*) + _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; + darwin*) # darwin 5.x on + # if running on 10.5 or later, the deployment target defaults + # to the OS version, if on x86, and 10.4, the deployment + # target defaults to 10.4. Don't you love it? + case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in + 10.0,*86*-darwin8*|10.0,*-darwin[91]*) + _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; + 10.[012][,.]*) + _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; + 10.*) + _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; + esac + ;; + esac + if test yes = "$lt_cv_apple_cc_single_mod"; then + _lt_dar_single_mod='$single_module' + fi + if test yes = "$lt_cv_ld_exported_symbols_list"; then + _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym' + else + _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib' + fi + if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then + _lt_dsymutil='~$DSYMUTIL $lib || :' + else + _lt_dsymutil= + fi + ;; + esac + +# func_munge_path_list VARIABLE PATH +# ----------------------------------- +# VARIABLE is name of variable containing _space_ separated list of +# directories to be munged by the contents of PATH, which is string +# having a format: +# "DIR[:DIR]:" +# string "DIR[ DIR]" will be prepended to VARIABLE +# ":DIR[:DIR]" +# string "DIR[ DIR]" will be appended to VARIABLE +# "DIRP[:DIRP]::[DIRA:]DIRA" +# string "DIRP[ DIRP]" will be prepended to VARIABLE and string +# "DIRA[ DIRA]" will be appended to VARIABLE +# "DIR[:DIR]" +# VARIABLE will be replaced by "DIR[ DIR]" +func_munge_path_list () +{ + case x$2 in + x) + ;; + *:) + eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\" + ;; + x:*) + eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\" + ;; + *::*) + eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" + eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\" + ;; + *) + eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\" + ;; + esac +} + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to run the C preprocessor" >&5 +$as_echo_n "checking how to run the C preprocessor... " >&6; } +# On Suns, sometimes $CPP names a directory. +if test -n "$CPP" && test -d "$CPP"; then + CPP= +fi +if test -z "$CPP"; then + if ${ac_cv_prog_CPP+:} false; then : + $as_echo_n "(cached) " >&6 +else + # Double quotes because CPP needs to be expanded + for CPP in "$CC -E" "$CC -E -traditional-cpp" "/lib/cpp" + do + ac_preproc_ok=false +for ac_c_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if ac_fn_c_try_cpp "$LINENO"; then : + +else + # Broken: fails on valid input. +continue +fi +rm -f conftest.err conftest.i conftest.$ac_ext + + # OK, works on sane cases. Now check whether nonexistent headers + # can be detected and how. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +_ACEOF +if ac_fn_c_try_cpp "$LINENO"; then : + # Broken: success on invalid input. +continue +else + # Passes both tests. +ac_preproc_ok=: +break +fi +rm -f conftest.err conftest.i conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.i conftest.err conftest.$ac_ext +if $ac_preproc_ok; then : + break +fi + + done + ac_cv_prog_CPP=$CPP + +fi + CPP=$ac_cv_prog_CPP +else + ac_cv_prog_CPP=$CPP +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $CPP" >&5 +$as_echo "$CPP" >&6; } +ac_preproc_ok=false +for ac_c_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if ac_fn_c_try_cpp "$LINENO"; then : + +else + # Broken: fails on valid input. +continue +fi +rm -f conftest.err conftest.i conftest.$ac_ext + + # OK, works on sane cases. Now check whether nonexistent headers + # can be detected and how. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +_ACEOF +if ac_fn_c_try_cpp "$LINENO"; then : + # Broken: success on invalid input. +continue +else + # Passes both tests. +ac_preproc_ok=: +break +fi +rm -f conftest.err conftest.i conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.i conftest.err conftest.$ac_ext +if $ac_preproc_ok; then : + +else + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "C preprocessor \"$CPP\" fails sanity check +See \`config.log' for more details" "$LINENO" 5; } +fi + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for ANSI C header files" >&5 +$as_echo_n "checking for ANSI C header files... " >&6; } +if ${ac_cv_header_stdc+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +#include +#include +#include + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_header_stdc=yes +else + ac_cv_header_stdc=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + +if test $ac_cv_header_stdc = yes; then + # SunOS 4.x string.h does not declare mem*, contrary to ANSI. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "memchr" >/dev/null 2>&1; then : + +else + ac_cv_header_stdc=no +fi +rm -f conftest* + +fi + +if test $ac_cv_header_stdc = yes; then + # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "free" >/dev/null 2>&1; then : + +else + ac_cv_header_stdc=no +fi +rm -f conftest* + +fi + +if test $ac_cv_header_stdc = yes; then + # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi. + if test "$cross_compiling" = yes; then : + : +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +#include +#if ((' ' & 0x0FF) == 0x020) +# define ISLOWER(c) ('a' <= (c) && (c) <= 'z') +# define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c)) +#else +# define ISLOWER(c) \ + (('a' <= (c) && (c) <= 'i') \ + || ('j' <= (c) && (c) <= 'r') \ + || ('s' <= (c) && (c) <= 'z')) +# define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c)) +#endif + +#define XOR(e, f) (((e) && !(f)) || (!(e) && (f))) +int +main () +{ + int i; + for (i = 0; i < 256; i++) + if (XOR (islower (i), ISLOWER (i)) + || toupper (i) != TOUPPER (i)) + return 2; + return 0; +} +_ACEOF +if ac_fn_c_try_run "$LINENO"; then : + +else + ac_cv_header_stdc=no +fi +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ + conftest.$ac_objext conftest.beam conftest.$ac_ext +fi + +fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_header_stdc" >&5 +$as_echo "$ac_cv_header_stdc" >&6; } +if test $ac_cv_header_stdc = yes; then + +$as_echo "#define STDC_HEADERS 1" >>confdefs.h + +fi + +# On IRIX 5.3, sys/types and inttypes.h are conflicting. +for ac_header in sys/types.h sys/stat.h stdlib.h string.h memory.h strings.h \ + inttypes.h stdint.h unistd.h +do : + as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` +ac_fn_c_check_header_compile "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default +" +if eval test \"x\$"$as_ac_Header"\" = x"yes"; then : + cat >>confdefs.h <<_ACEOF +#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + +for ac_header in dlfcn.h +do : + ac_fn_c_check_header_compile "$LINENO" "dlfcn.h" "ac_cv_header_dlfcn_h" "$ac_includes_default +" +if test "x$ac_cv_header_dlfcn_h" = xyes; then : + cat >>confdefs.h <<_ACEOF +#define HAVE_DLFCN_H 1 +_ACEOF + +fi + +done + + + + + +# Set options + + + + enable_dlopen=no + + + enable_win32_dll=no + + + # Check whether --enable-shared was given. +if test "${enable_shared+set}" = set; then : + enableval=$enable_shared; p=${PACKAGE-default} + case $enableval in + yes) enable_shared=yes ;; + no) enable_shared=no ;; + *) + enable_shared=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, + for pkg in $enableval; do + IFS=$lt_save_ifs + if test "X$pkg" = "X$p"; then + enable_shared=yes + fi + done + IFS=$lt_save_ifs + ;; + esac +else + enable_shared=yes +fi + + + + + + + + + + # Check whether --enable-static was given. +if test "${enable_static+set}" = set; then : + enableval=$enable_static; p=${PACKAGE-default} + case $enableval in + yes) enable_static=yes ;; + no) enable_static=no ;; + *) + enable_static=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, + for pkg in $enableval; do + IFS=$lt_save_ifs + if test "X$pkg" = "X$p"; then + enable_static=yes + fi + done + IFS=$lt_save_ifs + ;; + esac +else + enable_static=yes +fi + + + + + + + + + + +# Check whether --with-pic was given. +if test "${with_pic+set}" = set; then : + withval=$with_pic; lt_p=${PACKAGE-default} + case $withval in + yes|no) pic_mode=$withval ;; + *) + pic_mode=default + # Look at the argument we got. We use all the common list separators. + lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, + for lt_pkg in $withval; do + IFS=$lt_save_ifs + if test "X$lt_pkg" = "X$lt_p"; then + pic_mode=yes + fi + done + IFS=$lt_save_ifs + ;; + esac +else + pic_mode=default +fi + + + + + + + + + # Check whether --enable-fast-install was given. +if test "${enable_fast_install+set}" = set; then : + enableval=$enable_fast_install; p=${PACKAGE-default} + case $enableval in + yes) enable_fast_install=yes ;; + no) enable_fast_install=no ;; + *) + enable_fast_install=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, + for pkg in $enableval; do + IFS=$lt_save_ifs + if test "X$pkg" = "X$p"; then + enable_fast_install=yes + fi + done + IFS=$lt_save_ifs + ;; + esac +else + enable_fast_install=yes +fi + + + + + + + + + shared_archive_member_spec= +case $host,$enable_shared in +power*-*-aix[5-9]*,yes) + { $as_echo "$as_me:${as_lineno-$LINENO}: checking which variant of shared library versioning to provide" >&5 +$as_echo_n "checking which variant of shared library versioning to provide... " >&6; } + +# Check whether --with-aix-soname was given. +if test "${with_aix_soname+set}" = set; then : + withval=$with_aix_soname; case $withval in + aix|svr4|both) + ;; + *) + as_fn_error $? "Unknown argument to --with-aix-soname" "$LINENO" 5 + ;; + esac + lt_cv_with_aix_soname=$with_aix_soname +else + if ${lt_cv_with_aix_soname+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_with_aix_soname=aix +fi + + with_aix_soname=$lt_cv_with_aix_soname +fi + + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $with_aix_soname" >&5 +$as_echo "$with_aix_soname" >&6; } + if test aix != "$with_aix_soname"; then + # For the AIX way of multilib, we name the shared archive member + # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o', + # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File. + # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag, + # the AIX toolchain works better with OBJECT_MODE set (default 32). + if test 64 = "${OBJECT_MODE-32}"; then + shared_archive_member_spec=shr_64 + else + shared_archive_member_spec=shr + fi + fi + ;; +*) + with_aix_soname=aix + ;; +esac + + + + + + + + + + +# This can be used to rebuild libtool when needed +LIBTOOL_DEPS=$ltmain + +# Always use our own libtool. +LIBTOOL='$(SHELL) $(top_builddir)/libtool' + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +test -z "$LN_S" && LN_S="ln -s" + + + + + + + + + + + + + + +if test -n "${ZSH_VERSION+set}"; then + setopt NO_GLOB_SUBST +fi + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for objdir" >&5 +$as_echo_n "checking for objdir... " >&6; } +if ${lt_cv_objdir+:} false; then : + $as_echo_n "(cached) " >&6 +else + rm -f .libs 2>/dev/null +mkdir .libs 2>/dev/null +if test -d .libs; then + lt_cv_objdir=.libs +else + # MS-DOS does not allow filenames that begin with a dot. + lt_cv_objdir=_libs +fi +rmdir .libs 2>/dev/null +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_objdir" >&5 +$as_echo "$lt_cv_objdir" >&6; } +objdir=$lt_cv_objdir + + + + + +cat >>confdefs.h <<_ACEOF +#define LT_OBJDIR "$lt_cv_objdir/" +_ACEOF + + + + +case $host_os in +aix3*) + # AIX sometimes has problems with the GCC collect2 program. For some + # reason, if we set the COLLECT_NAMES environment variable, the problems + # vanish in a puff of smoke. + if test set != "${COLLECT_NAMES+set}"; then + COLLECT_NAMES= + export COLLECT_NAMES + fi + ;; +esac + +# Global variables: +ofile=libtool +can_build_shared=yes + +# All known linkers require a '.a' archive for static linking (except MSVC and +# ICC, which need '.lib'). +libext=a + +with_gnu_ld=$lt_cv_prog_gnu_ld + +old_CC=$CC +old_CFLAGS=$CFLAGS + +# Set sane defaults for various variables +test -z "$CC" && CC=cc +test -z "$LTCC" && LTCC=$CC +test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS +test -z "$LD" && LD=ld +test -z "$ac_objext" && ac_objext=o + +func_cc_basename $compiler +cc_basename=$func_cc_basename_result + + +# Only perform the check for file, if the check method requires it +test -z "$MAGIC_CMD" && MAGIC_CMD=file +case $deplibs_check_method in +file_magic*) + if test "$file_magic_cmd" = '$MAGIC_CMD'; then + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ${ac_tool_prefix}file" >&5 +$as_echo_n "checking for ${ac_tool_prefix}file... " >&6; } +if ${lt_cv_path_MAGIC_CMD+:} false; then : + $as_echo_n "(cached) " >&6 +else + case $MAGIC_CMD in +[\\/*] | ?:[\\/]*) + lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. + ;; +*) + lt_save_MAGIC_CMD=$MAGIC_CMD + lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR + ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" + for ac_dir in $ac_dummy; do + IFS=$lt_save_ifs + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/${ac_tool_prefix}file"; then + lt_cv_path_MAGIC_CMD=$ac_dir/"${ac_tool_prefix}file" + if test -n "$file_magic_test_file"; then + case $deplibs_check_method in + "file_magic "*) + file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` + MAGIC_CMD=$lt_cv_path_MAGIC_CMD + if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | + $EGREP "$file_magic_regex" > /dev/null; then + : + else + cat <<_LT_EOF 1>&2 + +*** Warning: the command libtool uses to detect shared libraries, +*** $file_magic_cmd, produces output that libtool cannot recognize. +*** The result is that libtool may fail to recognize shared libraries +*** as such. This will affect the creation of libtool libraries that +*** depend on shared libraries, but programs linked with such libtool +*** libraries will work regardless of this problem. Nevertheless, you +*** may want to report the problem to your system manager and/or to +*** bug-libtool@gnu.org + +_LT_EOF + fi ;; + esac + fi + break + fi + done + IFS=$lt_save_ifs + MAGIC_CMD=$lt_save_MAGIC_CMD + ;; +esac +fi + +MAGIC_CMD=$lt_cv_path_MAGIC_CMD +if test -n "$MAGIC_CMD"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5 +$as_echo "$MAGIC_CMD" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + + + +if test -z "$lt_cv_path_MAGIC_CMD"; then + if test -n "$ac_tool_prefix"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for file" >&5 +$as_echo_n "checking for file... " >&6; } +if ${lt_cv_path_MAGIC_CMD+:} false; then : + $as_echo_n "(cached) " >&6 +else + case $MAGIC_CMD in +[\\/*] | ?:[\\/]*) + lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. + ;; +*) + lt_save_MAGIC_CMD=$MAGIC_CMD + lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR + ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" + for ac_dir in $ac_dummy; do + IFS=$lt_save_ifs + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/file"; then + lt_cv_path_MAGIC_CMD=$ac_dir/"file" + if test -n "$file_magic_test_file"; then + case $deplibs_check_method in + "file_magic "*) + file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` + MAGIC_CMD=$lt_cv_path_MAGIC_CMD + if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | + $EGREP "$file_magic_regex" > /dev/null; then + : + else + cat <<_LT_EOF 1>&2 + +*** Warning: the command libtool uses to detect shared libraries, +*** $file_magic_cmd, produces output that libtool cannot recognize. +*** The result is that libtool may fail to recognize shared libraries +*** as such. This will affect the creation of libtool libraries that +*** depend on shared libraries, but programs linked with such libtool +*** libraries will work regardless of this problem. Nevertheless, you +*** may want to report the problem to your system manager and/or to +*** bug-libtool@gnu.org + +_LT_EOF + fi ;; + esac + fi + break + fi + done + IFS=$lt_save_ifs + MAGIC_CMD=$lt_save_MAGIC_CMD + ;; +esac +fi + +MAGIC_CMD=$lt_cv_path_MAGIC_CMD +if test -n "$MAGIC_CMD"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5 +$as_echo "$MAGIC_CMD" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + else + MAGIC_CMD=: + fi +fi + + fi + ;; +esac + +# Use C for the default configuration in the libtool script + +lt_save_CC=$CC +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +# Source file extension for C test sources. +ac_ext=c + +# Object file extension for compiled C test sources. +objext=o +objext=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="int some_variable = 0;" + +# Code to be used in simple link tests +lt_simple_link_test_code='int main(){return(0);}' + + + + + + + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# If no C compiler flags were specified, use CFLAGS. +LTCFLAGS=${LTCFLAGS-"$CFLAGS"} + +# Allow CC to be a program name with arguments. +compiler=$CC + +# Save the default compiler, since it gets overwritten when the other +# tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. +compiler_DEFAULT=$CC + +# save warnings/boilerplate of simple test code +ac_outfile=conftest.$ac_objext +echo "$lt_simple_compile_test_code" >conftest.$ac_ext +eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err +_lt_compiler_boilerplate=`cat conftest.err` +$RM conftest* + +ac_outfile=conftest.$ac_objext +echo "$lt_simple_link_test_code" >conftest.$ac_ext +eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err +_lt_linker_boilerplate=`cat conftest.err` +$RM -r conftest* + + +if test -n "$compiler"; then + +lt_prog_compiler_no_builtin_flag= + +if test yes = "$GCC"; then + case $cc_basename in + nvcc*) + lt_prog_compiler_no_builtin_flag=' -Xcompiler -fno-builtin' ;; + *) + lt_prog_compiler_no_builtin_flag=' -fno-builtin' ;; + esac + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -fno-rtti -fno-exceptions" >&5 +$as_echo_n "checking if $compiler supports -fno-rtti -fno-exceptions... " >&6; } +if ${lt_cv_prog_compiler_rtti_exceptions+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_rtti_exceptions=no + ac_outfile=conftest.$ac_objext + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="-fno-rtti -fno-exceptions" ## exclude from sc_useless_quotes_in_assignment + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then + lt_cv_prog_compiler_rtti_exceptions=yes + fi + fi + $RM conftest* + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_rtti_exceptions" >&5 +$as_echo "$lt_cv_prog_compiler_rtti_exceptions" >&6; } + +if test yes = "$lt_cv_prog_compiler_rtti_exceptions"; then + lt_prog_compiler_no_builtin_flag="$lt_prog_compiler_no_builtin_flag -fno-rtti -fno-exceptions" +else + : +fi + +fi + + + + + + + lt_prog_compiler_wl= +lt_prog_compiler_pic= +lt_prog_compiler_static= + + + if test yes = "$GCC"; then + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_static='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test ia64 = "$host_cpu"; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static='-Bstatic' + fi + lt_prog_compiler_pic='-fPIC' + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + lt_prog_compiler_pic='-fPIC' + ;; + m68k) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the '-m68020' flag to GCC prevents building anything better, + # like '-m68040'. + lt_prog_compiler_pic='-m68020 -resident32 -malways-restore-a4' + ;; + esac + ;; + + beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + + mingw* | cygwin* | pw32* | os2* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + # Although the cygwin gcc ignores -fPIC, still need this for old-style + # (--disable-auto-import) libraries + lt_prog_compiler_pic='-DDLL_EXPORT' + case $host_os in + os2*) + lt_prog_compiler_static='$wl-static' + ;; + esac + ;; + + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + lt_prog_compiler_pic='-fno-common' + ;; + + haiku*) + # PIC is the default for Haiku. + # The "-static" flag exists, but is broken. + lt_prog_compiler_static= + ;; + + hpux*) + # PIC is the default for 64-bit PA HP-UX, but not for 32-bit + # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag + # sets the default TLS model and affects inlining. + case $host_cpu in + hppa*64*) + # +Z the default + ;; + *) + lt_prog_compiler_pic='-fPIC' + ;; + esac + ;; + + interix[3-9]*) + # Interix 3.x gcc -fpic/-fPIC options generate broken code. + # Instead, we relocate shared libraries at runtime. + ;; + + msdosdjgpp*) + # Just because we use GCC doesn't mean we suddenly get shared libraries + # on systems that don't support them. + lt_prog_compiler_can_build_shared=no + enable_shared=no + ;; + + *nto* | *qnx*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + lt_prog_compiler_pic='-fPIC -shared' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + lt_prog_compiler_pic=-Kconform_pic + fi + ;; + + *) + lt_prog_compiler_pic='-fPIC' + ;; + esac + + case $cc_basename in + nvcc*) # Cuda Compiler Driver 2.2 + lt_prog_compiler_wl='-Xlinker ' + if test -n "$lt_prog_compiler_pic"; then + lt_prog_compiler_pic="-Xcompiler $lt_prog_compiler_pic" + fi + ;; + esac + else + # PORTME Check for flag to pass linker flags through the system compiler. + case $host_os in + aix*) + lt_prog_compiler_wl='-Wl,' + if test ia64 = "$host_cpu"; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static='-Bstatic' + else + lt_prog_compiler_static='-bnso -bI:/lib/syscalls.exp' + fi + ;; + + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + lt_prog_compiler_pic='-fno-common' + case $cc_basename in + nagfor*) + # NAG Fortran compiler + lt_prog_compiler_wl='-Wl,-Wl,,' + lt_prog_compiler_pic='-PIC' + lt_prog_compiler_static='-Bstatic' + ;; + esac + ;; + + mingw* | cygwin* | pw32* | os2* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + lt_prog_compiler_pic='-DDLL_EXPORT' + case $host_os in + os2*) + lt_prog_compiler_static='$wl-static' + ;; + esac + ;; + + hpux9* | hpux10* | hpux11*) + lt_prog_compiler_wl='-Wl,' + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + lt_prog_compiler_pic='+Z' + ;; + esac + # Is there a better lt_prog_compiler_static that works with the bundled CC? + lt_prog_compiler_static='$wl-a ${wl}archive' + ;; + + irix5* | irix6* | nonstopux*) + lt_prog_compiler_wl='-Wl,' + # PIC (with -KPIC) is the default. + lt_prog_compiler_static='-non_shared' + ;; + + linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) + case $cc_basename in + # old Intel for x86_64, which still supported -KPIC. + ecc*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-static' + ;; + # icc used to be incompatible with GCC. + # ICC 10 doesn't accept -KPIC any more. + icc* | ifort*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-fPIC' + lt_prog_compiler_static='-static' + ;; + # Lahey Fortran 8.1. + lf95*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='--shared' + lt_prog_compiler_static='--static' + ;; + nagfor*) + # NAG Fortran compiler + lt_prog_compiler_wl='-Wl,-Wl,,' + lt_prog_compiler_pic='-PIC' + lt_prog_compiler_static='-Bstatic' + ;; + tcc*) + # Fabrice Bellard et al's Tiny C Compiler + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-fPIC' + lt_prog_compiler_static='-static' + ;; + pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) + # Portland Group compilers (*not* the Pentium gcc compiler, + # which looks to be a dead project) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-fpic' + lt_prog_compiler_static='-Bstatic' + ;; + ccc*) + lt_prog_compiler_wl='-Wl,' + # All Alpha code is PIC. + lt_prog_compiler_static='-non_shared' + ;; + xl* | bgxl* | bgf* | mpixl*) + # IBM XL C 8.0/Fortran 10.1, 11.1 on PPC and BlueGene + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-qpic' + lt_prog_compiler_static='-qstaticlink' + ;; + *) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ Ceres\ Fortran* | *Sun*Fortran*\ [1-7].* | *Sun*Fortran*\ 8.[0-3]*) + # Sun Fortran 8.3 passes all unrecognized flags to the linker + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + lt_prog_compiler_wl='' + ;; + *Sun\ F* | *Sun*Fortran*) + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + lt_prog_compiler_wl='-Qoption ld ' + ;; + *Sun\ C*) + # Sun C 5.9 + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + lt_prog_compiler_wl='-Wl,' + ;; + *Intel*\ [CF]*Compiler*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-fPIC' + lt_prog_compiler_static='-static' + ;; + *Portland\ Group*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-fpic' + lt_prog_compiler_static='-Bstatic' + ;; + esac + ;; + esac + ;; + + newsos6) + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + ;; + + *nto* | *qnx*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + lt_prog_compiler_pic='-fPIC -shared' + ;; + + osf3* | osf4* | osf5*) + lt_prog_compiler_wl='-Wl,' + # All OSF/1 code is PIC. + lt_prog_compiler_static='-non_shared' + ;; + + rdos*) + lt_prog_compiler_static='-non_shared' + ;; + + solaris*) + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + case $cc_basename in + f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) + lt_prog_compiler_wl='-Qoption ld ';; + *) + lt_prog_compiler_wl='-Wl,';; + esac + ;; + + sunos4*) + lt_prog_compiler_wl='-Qoption ld ' + lt_prog_compiler_pic='-PIC' + lt_prog_compiler_static='-Bstatic' + ;; + + sysv4 | sysv4.2uw2* | sysv4.3*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + lt_prog_compiler_pic='-Kconform_pic' + lt_prog_compiler_static='-Bstatic' + fi + ;; + + sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_pic='-KPIC' + lt_prog_compiler_static='-Bstatic' + ;; + + unicos*) + lt_prog_compiler_wl='-Wl,' + lt_prog_compiler_can_build_shared=no + ;; + + uts4*) + lt_prog_compiler_pic='-pic' + lt_prog_compiler_static='-Bstatic' + ;; + + *) + lt_prog_compiler_can_build_shared=no + ;; + esac + fi + +case $host_os in + # For platforms that do not support PIC, -DPIC is meaningless: + *djgpp*) + lt_prog_compiler_pic= + ;; + *) + lt_prog_compiler_pic="$lt_prog_compiler_pic -DPIC" + ;; +esac + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $compiler option to produce PIC" >&5 +$as_echo_n "checking for $compiler option to produce PIC... " >&6; } +if ${lt_cv_prog_compiler_pic+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_pic=$lt_prog_compiler_pic +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic" >&5 +$as_echo "$lt_cv_prog_compiler_pic" >&6; } +lt_prog_compiler_pic=$lt_cv_prog_compiler_pic + +# +# Check to make sure the PIC flag actually works. +# +if test -n "$lt_prog_compiler_pic"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler PIC flag $lt_prog_compiler_pic works" >&5 +$as_echo_n "checking if $compiler PIC flag $lt_prog_compiler_pic works... " >&6; } +if ${lt_cv_prog_compiler_pic_works+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_pic_works=no + ac_outfile=conftest.$ac_objext + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="$lt_prog_compiler_pic -DPIC" ## exclude from sc_useless_quotes_in_assignment + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then + lt_cv_prog_compiler_pic_works=yes + fi + fi + $RM conftest* + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_works" >&5 +$as_echo "$lt_cv_prog_compiler_pic_works" >&6; } + +if test yes = "$lt_cv_prog_compiler_pic_works"; then + case $lt_prog_compiler_pic in + "" | " "*) ;; + *) lt_prog_compiler_pic=" $lt_prog_compiler_pic" ;; + esac +else + lt_prog_compiler_pic= + lt_prog_compiler_can_build_shared=no +fi + +fi + + + + + + + + + + + +# +# Check to make sure the static flag actually works. +# +wl=$lt_prog_compiler_wl eval lt_tmp_static_flag=\"$lt_prog_compiler_static\" +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler static flag $lt_tmp_static_flag works" >&5 +$as_echo_n "checking if $compiler static flag $lt_tmp_static_flag works... " >&6; } +if ${lt_cv_prog_compiler_static_works+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_static_works=no + save_LDFLAGS=$LDFLAGS + LDFLAGS="$LDFLAGS $lt_tmp_static_flag" + echo "$lt_simple_link_test_code" > conftest.$ac_ext + if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then + # The linker can only warn and ignore the option if not recognized + # So say no if there are warnings + if test -s conftest.err; then + # Append any errors to the config.log. + cat conftest.err 1>&5 + $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if diff conftest.exp conftest.er2 >/dev/null; then + lt_cv_prog_compiler_static_works=yes + fi + else + lt_cv_prog_compiler_static_works=yes + fi + fi + $RM -r conftest* + LDFLAGS=$save_LDFLAGS + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_static_works" >&5 +$as_echo "$lt_cv_prog_compiler_static_works" >&6; } + +if test yes = "$lt_cv_prog_compiler_static_works"; then + : +else + lt_prog_compiler_static= +fi + + + + + + + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 +$as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } +if ${lt_cv_prog_compiler_c_o+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_c_o=no + $RM -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp + $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then + lt_cv_prog_compiler_c_o=yes + fi + fi + chmod u+w . 2>&5 + $RM conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files + $RM out/* && rmdir out + cd .. + $RM -r conftest + $RM conftest* + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o" >&5 +$as_echo "$lt_cv_prog_compiler_c_o" >&6; } + + + + + + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 +$as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } +if ${lt_cv_prog_compiler_c_o+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_c_o=no + $RM -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp + $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then + lt_cv_prog_compiler_c_o=yes + fi + fi + chmod u+w . 2>&5 + $RM conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files + $RM out/* && rmdir out + cd .. + $RM -r conftest + $RM conftest* + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o" >&5 +$as_echo "$lt_cv_prog_compiler_c_o" >&6; } + + + + +hard_links=nottested +if test no = "$lt_cv_prog_compiler_c_o" && test no != "$need_locks"; then + # do not overwrite the value of need_locks provided by the user + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if we can lock with hard links" >&5 +$as_echo_n "checking if we can lock with hard links... " >&6; } + hard_links=yes + $RM conftest* + ln conftest.a conftest.b 2>/dev/null && hard_links=no + touch conftest.a + ln conftest.a conftest.b 2>&5 || hard_links=no + ln conftest.a conftest.b 2>/dev/null && hard_links=no + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hard_links" >&5 +$as_echo "$hard_links" >&6; } + if test no = "$hard_links"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&5 +$as_echo "$as_me: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&2;} + need_locks=warn + fi +else + need_locks=no +fi + + + + + + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $compiler linker ($LD) supports shared libraries" >&5 +$as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } + + runpath_var= + allow_undefined_flag= + always_export_symbols=no + archive_cmds= + archive_expsym_cmds= + compiler_needs_object=no + enable_shared_with_static_runtimes=no + export_dynamic_flag_spec= + export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + hardcode_automatic=no + hardcode_direct=no + hardcode_direct_absolute=no + hardcode_libdir_flag_spec= + hardcode_libdir_separator= + hardcode_minus_L=no + hardcode_shlibpath_var=unsupported + inherit_rpath=no + link_all_deplibs=unknown + module_cmds= + module_expsym_cmds= + old_archive_from_new_cmds= + old_archive_from_expsyms_cmds= + thread_safe_flag_spec= + whole_archive_flag_spec= + # include_expsyms should be a list of space-separated symbols to be *always* + # included in the symbol list + include_expsyms= + # exclude_expsyms can be an extended regexp of symbols to exclude + # it will be wrapped by ' (' and ')$', so one must not match beginning or + # end of line. Example: 'a|bc|.*d.*' will exclude the symbols 'a' and 'bc', + # as well as any symbol that contains 'd'. + exclude_expsyms='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*' + # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out + # platforms (ab)use it in PIC code, but their linkers get confused if + # the symbol is explicitly referenced. Since portable code cannot + # rely on this symbol name, it's probably fine to never include it in + # preloaded symbol tables. + # Exclude shared library initialization/finalization symbols. + extract_expsyms_cmds= + + case $host_os in + cygwin* | mingw* | pw32* | cegcc*) + # FIXME: the MSVC++ and ICC port hasn't been tested in a loooong time + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++ or Intel C++ Compiler. + if test yes != "$GCC"; then + with_gnu_ld=no + fi + ;; + interix*) + # we just hope/assume this is gcc and not c89 (= MSVC++ or ICC) + with_gnu_ld=yes + ;; + openbsd* | bitrig*) + with_gnu_ld=no + ;; + esac + + ld_shlibs=yes + + # On some targets, GNU ld is compatible enough with the native linker + # that we're better off using the native interface for both. + lt_use_gnu_ld_interface=no + if test yes = "$with_gnu_ld"; then + case $host_os in + aix*) + # The AIX port of GNU ld has always aspired to compatibility + # with the native linker. However, as the warning in the GNU ld + # block says, versions before 2.19.5* couldn't really create working + # shared libraries, regardless of the interface used. + case `$LD -v 2>&1` in + *\ \(GNU\ Binutils\)\ 2.19.5*) ;; + *\ \(GNU\ Binutils\)\ 2.[2-9]*) ;; + *\ \(GNU\ Binutils\)\ [3-9]*) ;; + *) + lt_use_gnu_ld_interface=yes + ;; + esac + ;; + *) + lt_use_gnu_ld_interface=yes + ;; + esac + fi + + if test yes = "$lt_use_gnu_ld_interface"; then + # If archive_cmds runs LD, not CC, wlarc should be empty + wlarc='$wl' + + # Set some defaults for GNU ld with shared library support. These + # are reset later if shared libraries are not supported. Putting them + # here allows them to be overridden if necessary. + runpath_var=LD_RUN_PATH + hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' + export_dynamic_flag_spec='$wl--export-dynamic' + # ancient GNU ld didn't support --whole-archive et. al. + if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then + whole_archive_flag_spec=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' + else + whole_archive_flag_spec= + fi + supports_anon_versioning=no + case `$LD -v | $SED -e 's/(^)\+)\s\+//' 2>&1` in + *GNU\ gold*) supports_anon_versioning=yes ;; + *\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11 + *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... + *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... + *\ 2.11.*) ;; # other 2.11 versions + *) supports_anon_versioning=yes ;; + esac + + # See if GNU ld supports shared libraries. + case $host_os in + aix[3-9]*) + # On AIX/PPC, the GNU linker is very broken + if test ia64 != "$host_cpu"; then + ld_shlibs=no + cat <<_LT_EOF 1>&2 + +*** Warning: the GNU linker, at least up to release 2.19, is reported +*** to be unable to reliably create shared libraries on AIX. +*** Therefore, libtool is disabling shared libraries support. If you +*** really care for shared libraries, you may want to install binutils +*** 2.20 or above, or modify your PATH so that a non-GNU linker is found. +*** You will then need to restart the configuration process. + +_LT_EOF + fi + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + archive_expsym_cmds='' + ;; + m68k) + archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + ;; + esac + ;; + + beos*) + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + allow_undefined_flag=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + archive_cmds='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + else + ld_shlibs=no + fi + ;; + + cygwin* | mingw* | pw32* | cegcc*) + # _LT_TAGVAR(hardcode_libdir_flag_spec, ) is actually meaningless, + # as there is no search path for DLLs. + hardcode_libdir_flag_spec='-L$libdir' + export_dynamic_flag_spec='$wl--export-all-symbols' + allow_undefined_flag=unsupported + always_export_symbols=no + enable_shared_with_static_runtimes=yes + export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1 DATA/;s/^.*[ ]__nm__\([^ ]*\)[ ][^ ]*/\1 DATA/;/^I[ ]/d;/^[AITW][ ]/s/.* //'\'' | sort | uniq > $export_symbols' + exclude_expsyms='[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname' + + if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + # If the export-symbols file already is a .def file, use it as + # is; otherwise, prepend EXPORTS... + archive_expsym_cmds='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + else + ld_shlibs=no + fi + ;; + + haiku*) + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + link_all_deplibs=yes + ;; + + os2*) + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + allow_undefined_flag=unsupported + shrext_cmds=.dll + archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + prefix_cmds="$SED"~ + if test EXPORTS = "`$SED 1q $export_symbols`"; then + prefix_cmds="$prefix_cmds -e 1d"; + fi~ + prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ + cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' + enable_shared_with_static_runtimes=yes + file_list_spec='@' + ;; + + interix[3-9]*) + hardcode_direct=no + hardcode_shlibpath_var=no + hardcode_libdir_flag_spec='$wl-rpath,$libdir' + export_dynamic_flag_spec='$wl-E' + # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. + # Instead, shared libraries are loaded at an image base (0x10000000 by + # default) and relocated if they conflict, which is a slow very memory + # consuming and fragmenting process. To avoid this, we pick a random, + # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link + # time. Moving up from 0x10000000 also allows more sbrk(2) space. + archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + archive_expsym_cmds='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + ;; + + gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) + tmp_diet=no + if test linux-dietlibc = "$host_os"; then + case $cc_basename in + diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) + esac + fi + if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ + && test no = "$tmp_diet" + then + tmp_addflag=' $pic_flag' + tmp_sharedflag='-shared' + case $cc_basename,$host_cpu in + pgcc*) # Portland Group C compiler + whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' + tmp_addflag=' $pic_flag' + ;; + pgf77* | pgf90* | pgf95* | pgfortran*) + # Portland Group f77 and f90 compilers + whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' + tmp_addflag=' $pic_flag -Mnomain' ;; + ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 + tmp_addflag=' -i_dynamic' ;; + efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 + tmp_addflag=' -i_dynamic -nofor_main' ;; + ifc* | ifort*) # Intel Fortran compiler + tmp_addflag=' -nofor_main' ;; + lf95*) # Lahey Fortran 8.1 + whole_archive_flag_spec= + tmp_sharedflag='--shared' ;; + nagfor*) # NAGFOR 5.3 + tmp_sharedflag='-Wl,-shared' ;; + xl[cC]* | bgxl[cC]* | mpixl[cC]*) # IBM XL C 8.0 on PPC (deal with xlf below) + tmp_sharedflag='-qmkshrobj' + tmp_addflag= ;; + nvcc*) # Cuda Compiler Driver 2.2 + whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' + compiler_needs_object=yes + ;; + esac + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) # Sun C 5.9 + whole_archive_flag_spec='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' + compiler_needs_object=yes + tmp_sharedflag='-G' ;; + *Sun\ F*) # Sun Fortran 8.3 + tmp_sharedflag='-G' ;; + esac + archive_cmds='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + + if test yes = "$supports_anon_versioning"; then + archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + echo "local: *; };" >> $output_objdir/$libname.ver~ + $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' + fi + + case $cc_basename in + tcc*) + export_dynamic_flag_spec='-rdynamic' + ;; + xlf* | bgf* | bgxlf* | mpixlf*) + # IBM XL Fortran 10.1 on PPC cannot create shared libs itself + whole_archive_flag_spec='--whole-archive$convenience --no-whole-archive' + hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' + archive_cmds='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib' + if test yes = "$supports_anon_versioning"; then + archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + echo "local: *; };" >> $output_objdir/$libname.ver~ + $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' + fi + ;; + esac + else + ld_shlibs=no + fi + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + archive_cmds='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' + wlarc= + else + archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + fi + ;; + + solaris*) + if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then + ld_shlibs=no + cat <<_LT_EOF 1>&2 + +*** Warning: The releases 2.8.* of the GNU linker cannot reliably +*** create shared libraries on Solaris systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.9.1 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +_LT_EOF + elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs=no + fi + ;; + + sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) + case `$LD -v 2>&1` in + *\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*) + ld_shlibs=no + cat <<_LT_EOF 1>&2 + +*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot +*** reliably create shared libraries on SCO systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.16.91.0.3 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +_LT_EOF + ;; + *) + # For security reasons, it is highly recommended that you always + # use absolute paths for naming shared libraries, and exclude the + # DT_RUNPATH tag from executables and libraries. But doing so + # requires that you compile everything twice, which is a pain. + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs=no + fi + ;; + esac + ;; + + sunos4*) + archive_cmds='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' + wlarc= + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + *) + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + else + ld_shlibs=no + fi + ;; + esac + + if test no = "$ld_shlibs"; then + runpath_var= + hardcode_libdir_flag_spec= + export_dynamic_flag_spec= + whole_archive_flag_spec= + fi + else + # PORTME fill in a description of your system's linker (not GNU ld) + case $host_os in + aix3*) + allow_undefined_flag=unsupported + always_export_symbols=yes + archive_expsym_cmds='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' + # Note: this linker hardcodes the directories in LIBPATH if there + # are no directories specified by -L. + hardcode_minus_L=yes + if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then + # Neither direct hardcoding nor static linking is supported with a + # broken collect2. + hardcode_direct=unsupported + fi + ;; + + aix[4-9]*) + if test ia64 = "$host_cpu"; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag= + else + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to GNU nm, but means don't demangle to AIX nm. + # Without the "-l" option, or with the "-B" option, AIX nm treats + # weak defined symbols like other global defined symbols, whereas + # GNU nm marks them as "W". + # While the 'weak' keyword is ignored in the Export File, we need + # it in the Import File for the 'aix-soname' feature, so we have + # to replace the "-B" option with "-P" for AIX nm. + if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then + export_symbols_cmds='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' + else + export_symbols_cmds='`func_echo_all $NM | $SED -e '\''s/B\([^B]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "L") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' + fi + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # have runtime linking enabled, and use it for executables. + # For shared libraries, we enable/disable runtime linking + # depending on the kind of the shared library created - + # when "with_aix_soname,aix_use_runtimelinking" is: + # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables + # "aix,yes" lib.so shared, rtl:yes, for executables + # lib.a static archive + # "both,no" lib.so.V(shr.o) shared, rtl:yes + # lib.a(lib.so.V) shared, rtl:no, for executables + # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables + # lib.a(lib.so.V) shared, rtl:no + # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables + # lib.a static archive + case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) + for ld_flag in $LDFLAGS; do + if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then + aix_use_runtimelinking=yes + break + fi + done + if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then + # With aix-soname=svr4, we create the lib.so.V shared archives only, + # so we don't have lib.a shared libs to link our executables. + # We have to force runtime linking in this case. + aix_use_runtimelinking=yes + LDFLAGS="$LDFLAGS -Wl,-brtl" + fi + ;; + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + archive_cmds='' + hardcode_direct=yes + hardcode_direct_absolute=yes + hardcode_libdir_separator=':' + link_all_deplibs=yes + file_list_spec='$wl-f,' + case $with_aix_soname,$aix_use_runtimelinking in + aix,*) ;; # traditional, no import file + svr4,* | *,yes) # use import file + # The Import File defines what to hardcode. + hardcode_direct=no + hardcode_direct_absolute=no + ;; + esac + + if test yes = "$GCC"; then + case $host_os in aix4.[012]|aix4.[012].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`$CC -print-prog-name=collect2` + if test -f "$collect2name" && + strings "$collect2name" | $GREP resolve_lib_name >/dev/null + then + # We have reworked collect2 + : + else + # We have old collect2 + hardcode_direct=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + hardcode_minus_L=yes + hardcode_libdir_flag_spec='-L$libdir' + hardcode_libdir_separator= + fi + ;; + esac + shared_flag='-shared' + if test yes = "$aix_use_runtimelinking"; then + shared_flag="$shared_flag "'$wl-G' + fi + # Need to ensure runtime linking is disabled for the traditional + # shared library, or the linker may eventually find shared libraries + # /with/ Import File - we do not want to mix them. + shared_flag_aix='-shared' + shared_flag_svr4='-shared $wl-G' + else + # not using gcc + if test ia64 = "$host_cpu"; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test yes = "$aix_use_runtimelinking"; then + shared_flag='$wl-G' + else + shared_flag='$wl-bM:SRE' + fi + shared_flag_aix='$wl-bM:SRE' + shared_flag_svr4='$wl-G' + fi + fi + + export_dynamic_flag_spec='$wl-bexpall' + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to export. + always_export_symbols=yes + if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + allow_undefined_flag='-berok' + # Determine the default libpath from the value encoded in an + # empty executable. + if test set = "${lt_cv_aix_libpath+set}"; then + aix_libpath=$lt_cv_aix_libpath +else + if ${lt_cv_aix_libpath_+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + + lt_aix_libpath_sed=' + /Import File Strings/,/^$/ { + /^0/ { + s/^0 *\([^ ]*\) *$/\1/ + p + } + }' + lt_cv_aix_libpath_=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` + # Check for a 64-bit object if we didn't find anything. + if test -z "$lt_cv_aix_libpath_"; then + lt_cv_aix_libpath_=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` + fi +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + if test -z "$lt_cv_aix_libpath_"; then + lt_cv_aix_libpath_=/usr/lib:/lib + fi + +fi + + aix_libpath=$lt_cv_aix_libpath_ +fi + + hardcode_libdir_flag_spec='$wl-blibpath:$libdir:'"$aix_libpath" + archive_expsym_cmds='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag + else + if test ia64 = "$host_cpu"; then + hardcode_libdir_flag_spec='$wl-R $libdir:/usr/lib:/lib' + allow_undefined_flag="-z nodefs" + archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an + # empty executable. + if test set = "${lt_cv_aix_libpath+set}"; then + aix_libpath=$lt_cv_aix_libpath +else + if ${lt_cv_aix_libpath_+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + + lt_aix_libpath_sed=' + /Import File Strings/,/^$/ { + /^0/ { + s/^0 *\([^ ]*\) *$/\1/ + p + } + }' + lt_cv_aix_libpath_=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` + # Check for a 64-bit object if we didn't find anything. + if test -z "$lt_cv_aix_libpath_"; then + lt_cv_aix_libpath_=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` + fi +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + if test -z "$lt_cv_aix_libpath_"; then + lt_cv_aix_libpath_=/usr/lib:/lib + fi + +fi + + aix_libpath=$lt_cv_aix_libpath_ +fi + + hardcode_libdir_flag_spec='$wl-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + no_undefined_flag=' $wl-bernotok' + allow_undefined_flag=' $wl-berok' + if test yes = "$with_gnu_ld"; then + # We only use this code for GNU lds that support --whole-archive. + whole_archive_flag_spec='$wl--whole-archive$convenience $wl--no-whole-archive' + else + # Exported symbols can be pulled into shared objects from archives + whole_archive_flag_spec='$convenience' + fi + archive_cmds_need_lc=yes + archive_expsym_cmds='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' + # -brtl affects multiple linker settings, -berok does not and is overridden later + compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([, ]\\)%-berok\\1%g"`' + if test svr4 != "$with_aix_soname"; then + # This is similar to how AIX traditionally builds its shared libraries. + archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' + fi + if test aix != "$with_aix_soname"; then + archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' + else + # used by -dlpreopen to get the symbols + archive_expsym_cmds="$archive_expsym_cmds"'~$MV $output_objdir/$realname.d/$soname $output_objdir' + fi + archive_expsym_cmds="$archive_expsym_cmds"'~$RM -r $output_objdir/$realname.d' + fi + fi + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + archive_expsym_cmds='' + ;; + m68k) + archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + ;; + esac + ;; + + bsdi[45]*) + export_dynamic_flag_spec=-rdynamic + ;; + + cygwin* | mingw* | pw32* | cegcc*) + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++ or Intel C++ Compiler. + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + case $cc_basename in + cl* | icl*) + # Native MSVC or ICC + hardcode_libdir_flag_spec=' ' + allow_undefined_flag=unsupported + always_export_symbols=yes + file_list_spec='@' + # Tell ltmain to make .lib files, not .a files. + libext=lib + # Tell ltmain to make .dll files, not .so files. + shrext_cmds=.dll + # FIXME: Setting linknames here is a bad hack. + archive_cmds='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' + archive_expsym_cmds='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then + cp "$export_symbols" "$output_objdir/$soname.def"; + echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; + else + $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; + fi~ + $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ + linknames=' + # The linker will not automatically build a static lib if we build a DLL. + # _LT_TAGVAR(old_archive_from_new_cmds, )='true' + enable_shared_with_static_runtimes=yes + exclude_expsyms='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' + export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1,DATA/'\'' | $SED -e '\''/^[AITW][ ]/s/.*[ ]//'\'' | sort | uniq > $export_symbols' + # Don't use ranlib + old_postinstall_cmds='chmod 644 $oldlib' + postlink_cmds='lt_outputfile="@OUTPUT@"~ + lt_tool_outputfile="@TOOL_OUTPUT@"~ + case $lt_outputfile in + *.exe|*.EXE) ;; + *) + lt_outputfile=$lt_outputfile.exe + lt_tool_outputfile=$lt_tool_outputfile.exe + ;; + esac~ + if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then + $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; + $RM "$lt_outputfile.manifest"; + fi' + ;; + *) + # Assume MSVC and ICC wrapper + hardcode_libdir_flag_spec=' ' + allow_undefined_flag=unsupported + # Tell ltmain to make .lib files, not .a files. + libext=lib + # Tell ltmain to make .dll files, not .so files. + shrext_cmds=.dll + # FIXME: Setting linknames here is a bad hack. + archive_cmds='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames=' + # The linker will automatically build a .lib file if we build a DLL. + old_archive_from_new_cmds='true' + # FIXME: Should let the user specify the lib program. + old_archive_cmds='lib -OUT:$oldlib$oldobjs$old_deplibs' + enable_shared_with_static_runtimes=yes + ;; + esac + ;; + + darwin* | rhapsody*) + + + archive_cmds_need_lc=no + hardcode_direct=no + hardcode_automatic=yes + hardcode_shlibpath_var=unsupported + if test yes = "$lt_cv_ld_force_load"; then + whole_archive_flag_spec='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' + + else + whole_archive_flag_spec='' + fi + link_all_deplibs=yes + allow_undefined_flag=$_lt_dar_allow_undefined + case $cc_basename in + ifort*|nagfor*) _lt_dar_can_shared=yes ;; + *) _lt_dar_can_shared=$GCC ;; + esac + if test yes = "$_lt_dar_can_shared"; then + output_verbose_link_cmd=func_echo_all + archive_cmds="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil" + module_cmds="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil" + archive_expsym_cmds="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil" + module_expsym_cmds="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil" + + else + ld_shlibs=no + fi + + ;; + + dgux*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_shlibpath_var=no + ;; + + # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor + # support. Future versions do this automatically, but an explicit c++rt0.o + # does not break anything, and helps significantly (at the cost of a little + # extra space). + freebsd2.2*) + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + # Unfortunately, older versions of FreeBSD 2 do not have this feature. + freebsd2.*) + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct=yes + hardcode_minus_L=yes + hardcode_shlibpath_var=no + ;; + + # FreeBSD 3 and greater uses gcc -shared to do shared libraries. + freebsd* | dragonfly*) + archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + hpux9*) + if test yes = "$GCC"; then + archive_cmds='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' + else + archive_cmds='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' + fi + hardcode_libdir_flag_spec='$wl+b $wl$libdir' + hardcode_libdir_separator=: + hardcode_direct=yes + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L=yes + export_dynamic_flag_spec='$wl-E' + ;; + + hpux10*) + if test yes,no = "$GCC,$with_gnu_ld"; then + archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' + fi + if test no = "$with_gnu_ld"; then + hardcode_libdir_flag_spec='$wl+b $wl$libdir' + hardcode_libdir_separator=: + hardcode_direct=yes + hardcode_direct_absolute=yes + export_dynamic_flag_spec='$wl-E' + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L=yes + fi + ;; + + hpux11*) + if test yes,no = "$GCC,$with_gnu_ld"; then + case $host_cpu in + hppa*64*) + archive_cmds='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + ia64*) + archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + else + case $host_cpu in + hppa*64*) + archive_cmds='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + ia64*) + archive_cmds='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + + # Older versions of the 11.00 compiler do not understand -b yet + # (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does) + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $CC understands -b" >&5 +$as_echo_n "checking if $CC understands -b... " >&6; } +if ${lt_cv_prog_compiler__b+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler__b=no + save_LDFLAGS=$LDFLAGS + LDFLAGS="$LDFLAGS -b" + echo "$lt_simple_link_test_code" > conftest.$ac_ext + if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then + # The linker can only warn and ignore the option if not recognized + # So say no if there are warnings + if test -s conftest.err; then + # Append any errors to the config.log. + cat conftest.err 1>&5 + $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if diff conftest.exp conftest.er2 >/dev/null; then + lt_cv_prog_compiler__b=yes + fi + else + lt_cv_prog_compiler__b=yes + fi + fi + $RM -r conftest* + LDFLAGS=$save_LDFLAGS + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler__b" >&5 +$as_echo "$lt_cv_prog_compiler__b" >&6; } + +if test yes = "$lt_cv_prog_compiler__b"; then + archive_cmds='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' +else + archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' +fi + + ;; + esac + fi + if test no = "$with_gnu_ld"; then + hardcode_libdir_flag_spec='$wl+b $wl$libdir' + hardcode_libdir_separator=: + + case $host_cpu in + hppa*64*|ia64*) + hardcode_direct=no + hardcode_shlibpath_var=no + ;; + *) + hardcode_direct=yes + hardcode_direct_absolute=yes + export_dynamic_flag_spec='$wl-E' + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + hardcode_minus_L=yes + ;; + esac + fi + ;; + + irix5* | irix6* | nonstopux*) + if test yes = "$GCC"; then + archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' + # Try to use the -exported_symbol ld option, if it does not + # work, assume that -exports_file does not work either and + # implicitly export all symbols. + # This should be the same for all languages, so no per-tag cache variable. + { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $host_os linker accepts -exported_symbol" >&5 +$as_echo_n "checking whether the $host_os linker accepts -exported_symbol... " >&6; } +if ${lt_cv_irix_exported_symbol+:} false; then : + $as_echo_n "(cached) " >&6 +else + save_LDFLAGS=$LDFLAGS + LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +int foo (void) { return 0; } +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + lt_cv_irix_exported_symbol=yes +else + lt_cv_irix_exported_symbol=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + LDFLAGS=$save_LDFLAGS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_irix_exported_symbol" >&5 +$as_echo "$lt_cv_irix_exported_symbol" >&6; } + if test yes = "$lt_cv_irix_exported_symbol"; then + archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib' + fi + else + archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' + archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib' + fi + archive_cmds_need_lc='no' + hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' + hardcode_libdir_separator=: + inherit_rpath=yes + link_all_deplibs=yes + ;; + + linux*) + case $cc_basename in + tcc*) + # Fabrice Bellard et al's Tiny C Compiler + ld_shlibs=yes + archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out + else + archive_cmds='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF + fi + hardcode_libdir_flag_spec='-R$libdir' + hardcode_direct=yes + hardcode_shlibpath_var=no + ;; + + newsos6) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct=yes + hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' + hardcode_libdir_separator=: + hardcode_shlibpath_var=no + ;; + + *nto* | *qnx*) + ;; + + openbsd* | bitrig*) + if test -f /usr/libexec/ld.so; then + hardcode_direct=yes + hardcode_shlibpath_var=no + hardcode_direct_absolute=yes + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then + archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags $wl-retain-symbols-file,$export_symbols' + hardcode_libdir_flag_spec='$wl-rpath,$libdir' + export_dynamic_flag_spec='$wl-E' + else + archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + hardcode_libdir_flag_spec='$wl-rpath,$libdir' + fi + else + ld_shlibs=no + fi + ;; + + os2*) + hardcode_libdir_flag_spec='-L$libdir' + hardcode_minus_L=yes + allow_undefined_flag=unsupported + shrext_cmds=.dll + archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + prefix_cmds="$SED"~ + if test EXPORTS = "`$SED 1q $export_symbols`"; then + prefix_cmds="$prefix_cmds -e 1d"; + fi~ + prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ + cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' + enable_shared_with_static_runtimes=yes + file_list_spec='@' + ;; + + osf3*) + if test yes = "$GCC"; then + allow_undefined_flag=' $wl-expect_unresolved $wl\*' + archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' + else + allow_undefined_flag=' -expect_unresolved \*' + archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' + fi + archive_cmds_need_lc='no' + hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' + hardcode_libdir_separator=: + ;; + + osf4* | osf5*) # as osf3* with the addition of -msym flag + if test yes = "$GCC"; then + allow_undefined_flag=' $wl-expect_unresolved $wl\*' + archive_cmds='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' + hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' + else + allow_undefined_flag=' -expect_unresolved \*' + archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' + archive_expsym_cmds='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ + $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~$RM $lib.exp' + + # Both c and cxx compiler support -rpath directly + hardcode_libdir_flag_spec='-rpath $libdir' + fi + archive_cmds_need_lc='no' + hardcode_libdir_separator=: + ;; + + solaris*) + no_undefined_flag=' -z defs' + if test yes = "$GCC"; then + wlarc='$wl' + archive_cmds='$CC -shared $pic_flag $wl-z ${wl}text $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' + else + case `$CC -V 2>&1` in + *"Compilers 5.0"*) + wlarc='' + archive_cmds='$LD -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $linker_flags' + archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' + ;; + *) + wlarc='$wl' + archive_cmds='$CC -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' + ;; + esac + fi + hardcode_libdir_flag_spec='-R$libdir' + hardcode_shlibpath_var=no + case $host_os in + solaris2.[0-5] | solaris2.[0-5].*) ;; + *) + # The compiler driver will combine and reorder linker options, + # but understands '-z linker_flag'. GCC discards it without '$wl', + # but is careful enough not to reorder. + # Supported since Solaris 2.6 (maybe 2.5.1?) + if test yes = "$GCC"; then + whole_archive_flag_spec='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' + else + whole_archive_flag_spec='-z allextract$convenience -z defaultextract' + fi + ;; + esac + link_all_deplibs=yes + ;; + + sunos4*) + if test sequent = "$host_vendor"; then + # Use $CC to link under sequent, because it throws in some extra .o + # files that make .init and .fini sections work. + archive_cmds='$CC -G $wl-h $soname -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' + fi + hardcode_libdir_flag_spec='-L$libdir' + hardcode_direct=yes + hardcode_minus_L=yes + hardcode_shlibpath_var=no + ;; + + sysv4) + case $host_vendor in + sni) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct=yes # is this really true??? + ;; + siemens) + ## LD is ld it makes a PLAMLIB + ## CC just makes a GrossModule. + archive_cmds='$LD -G -o $lib $libobjs $deplibs $linker_flags' + reload_cmds='$CC -r -o $output$reload_objs' + hardcode_direct=no + ;; + motorola) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_direct=no #Motorola manual says yes, but my tests say they lie + ;; + esac + runpath_var='LD_RUN_PATH' + hardcode_shlibpath_var=no + ;; + + sysv4.3*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_shlibpath_var=no + export_dynamic_flag_spec='-Bexport' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_shlibpath_var=no + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + ld_shlibs=yes + fi + ;; + + sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) + no_undefined_flag='$wl-z,text' + archive_cmds_need_lc=no + hardcode_shlibpath_var=no + runpath_var='LD_RUN_PATH' + + if test yes = "$GCC"; then + archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + fi + ;; + + sysv5* | sco3.2v5* | sco5v6*) + # Note: We CANNOT use -z defs as we might desire, because we do not + # link with -lc, and that would cause any symbols used from libc to + # always be unresolved, which means just about no library would + # ever link correctly. If we're not using GNU ld we use -z text + # though, which does catch some bad symbols but isn't as heavy-handed + # as -z defs. + no_undefined_flag='$wl-z,text' + allow_undefined_flag='$wl-z,nodefs' + archive_cmds_need_lc=no + hardcode_shlibpath_var=no + hardcode_libdir_flag_spec='$wl-R,$libdir' + hardcode_libdir_separator=':' + link_all_deplibs=yes + export_dynamic_flag_spec='$wl-Bexport' + runpath_var='LD_RUN_PATH' + + if test yes = "$GCC"; then + archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + else + archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + fi + ;; + + uts4*) + archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + hardcode_libdir_flag_spec='-L$libdir' + hardcode_shlibpath_var=no + ;; + + *) + ld_shlibs=no + ;; + esac + + if test sni = "$host_vendor"; then + case $host in + sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + export_dynamic_flag_spec='$wl-Blargedynsym' + ;; + esac + fi + fi + +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs" >&5 +$as_echo "$ld_shlibs" >&6; } +test no = "$ld_shlibs" && can_build_shared=no + +with_gnu_ld=$with_gnu_ld + + + + + + + + + + + + + + + +# +# Do we need to explicitly link libc? +# +case "x$archive_cmds_need_lc" in +x|xyes) + # Assume -lc should be added + archive_cmds_need_lc=yes + + if test yes,yes = "$GCC,$enable_shared"; then + case $archive_cmds in + *'~'*) + # FIXME: we may have to deal with multi-command sequences. + ;; + '$CC '*) + # Test whether the compiler implicitly links with -lc since on some + # systems, -lgcc has to come before -lc. If gcc already passes -lc + # to ld, don't add -lc before -lgcc. + { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether -lc should be explicitly linked in" >&5 +$as_echo_n "checking whether -lc should be explicitly linked in... " >&6; } +if ${lt_cv_archive_cmds_need_lc+:} false; then : + $as_echo_n "(cached) " >&6 +else + $RM conftest* + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } 2>conftest.err; then + soname=conftest + lib=conftest + libobjs=conftest.$ac_objext + deplibs= + wl=$lt_prog_compiler_wl + pic_flag=$lt_prog_compiler_pic + compiler_flags=-v + linker_flags=-v + verstring= + output_objdir=. + libname=conftest + lt_save_allow_undefined_flag=$allow_undefined_flag + allow_undefined_flag= + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1\""; } >&5 + (eval $archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } + then + lt_cv_archive_cmds_need_lc=no + else + lt_cv_archive_cmds_need_lc=yes + fi + allow_undefined_flag=$lt_save_allow_undefined_flag + else + cat conftest.err 1>&5 + fi + $RM conftest* + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_archive_cmds_need_lc" >&5 +$as_echo "$lt_cv_archive_cmds_need_lc" >&6; } + archive_cmds_need_lc=$lt_cv_archive_cmds_need_lc + ;; + esac + fi + ;; +esac + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking dynamic linker characteristics" >&5 +$as_echo_n "checking dynamic linker characteristics... " >&6; } + +if test yes = "$GCC"; then + case $host_os in + darwin*) lt_awk_arg='/^libraries:/,/LR/' ;; + *) lt_awk_arg='/^libraries:/' ;; + esac + case $host_os in + mingw* | cegcc*) lt_sed_strip_eq='s|=\([A-Za-z]:\)|\1|g' ;; + *) lt_sed_strip_eq='s|=/|/|g' ;; + esac + lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq` + case $lt_search_path_spec in + *\;*) + # if the path contains ";" then we assume it to be the separator + # otherwise default to the standard path separator (i.e. ":") - it is + # assumed that no part of a normal pathname contains ";" but that should + # okay in the real world where ";" in dirpaths is itself problematic. + lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED 's/;/ /g'` + ;; + *) + lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED "s/$PATH_SEPARATOR/ /g"` + ;; + esac + # Ok, now we have the path, separated by spaces, we can step through it + # and add multilib dir if necessary... + lt_tmp_lt_search_path_spec= + lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` + # ...but if some path component already ends with the multilib dir we assume + # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer). + case "$lt_multi_os_dir; $lt_search_path_spec " in + "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*) + lt_multi_os_dir= + ;; + esac + for lt_sys_path in $lt_search_path_spec; do + if test -d "$lt_sys_path$lt_multi_os_dir"; then + lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir" + elif test -n "$lt_multi_os_dir"; then + test -d "$lt_sys_path" && \ + lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" + fi + done + lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk ' +BEGIN {RS = " "; FS = "/|\n";} { + lt_foo = ""; + lt_count = 0; + for (lt_i = NF; lt_i > 0; lt_i--) { + if ($lt_i != "" && $lt_i != ".") { + if ($lt_i == "..") { + lt_count++; + } else { + if (lt_count == 0) { + lt_foo = "/" $lt_i lt_foo; + } else { + lt_count--; + } + } + } + } + if (lt_foo != "") { lt_freq[lt_foo]++; } + if (lt_freq[lt_foo] == 1) { print lt_foo; } +}'` + # AWK program above erroneously prepends '/' to C:/dos/paths + # for these hosts. + case $host_os in + mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\ + $SED 's|/\([A-Za-z]:\)|\1|g'` ;; + esac + sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP` +else + sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" +fi +library_names_spec= +libname_spec='lib$name' +soname_spec= +shrext_cmds=.so +postinstall_cmds= +postuninstall_cmds= +finish_cmds= +finish_eval= +shlibpath_var= +shlibpath_overrides_runpath=unknown +version_type=none +dynamic_linker="$host_os ld.so" +sys_lib_dlsearch_path_spec="/lib /usr/lib" +need_lib_prefix=unknown +hardcode_into_libs=no + +# when you set need_version to no, make sure it does not cause -set_version +# flags to be left without arguments +need_version=unknown + + + +case $host_os in +aix3*) + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$release$shared_ext$versuffix $libname.a' + shlibpath_var=LIBPATH + + # AIX 3 has no versioning support, so we append a major version to the name. + soname_spec='$libname$release$shared_ext$major' + ;; + +aix[4-9]*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + hardcode_into_libs=yes + if test ia64 = "$host_cpu"; then + # AIX 5 supports IA64 + library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext' + shlibpath_var=LD_LIBRARY_PATH + else + # With GCC up to 2.95.x, collect2 would create an import file + # for dependence libraries. The import file would start with + # the line '#! .'. This would cause the generated library to + # depend on '.', always an invalid library. This was fixed in + # development snapshots of GCC prior to 3.0. + case $host_os in + aix4 | aix4.[01] | aix4.[01].*) + if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' + echo ' yes ' + echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then + : + else + can_build_shared=no + fi + ;; + esac + # Using Import Files as archive members, it is possible to support + # filename-based versioning of shared library archives on AIX. While + # this would work for both with and without runtime linking, it will + # prevent static linking of such archives. So we do filename-based + # shared library versioning with .so extension only, which is used + # when both runtime linking and shared linking is enabled. + # Unfortunately, runtime linking may impact performance, so we do + # not want this to be the default eventually. Also, we use the + # versioned .so libs for executables only if there is the -brtl + # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. + # To allow for filename-based versioning support, we need to create + # libNAME.so.V as an archive file, containing: + # *) an Import File, referring to the versioned filename of the + # archive as well as the shared archive member, telling the + # bitwidth (32 or 64) of that shared object, and providing the + # list of exported symbols of that shared object, eventually + # decorated with the 'weak' keyword + # *) the shared object with the F_LOADONLY flag set, to really avoid + # it being seen by the linker. + # At run time we better use the real file rather than another symlink, + # but for link time we create the symlink libNAME.so -> libNAME.so.V + + case $with_aix_soname,$aix_use_runtimelinking in + # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + aix,yes) # traditional libtool + dynamic_linker='AIX unversionable lib.so' + # If using run time linking (on AIX 4.2 or later) use lib.so + # instead of lib.a to let people know that these are not + # typical AIX shared libraries. + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + ;; + aix,no) # traditional AIX only + dynamic_linker='AIX lib.a(lib.so.V)' + # We preserve .a as extension for shared libraries through AIX4.2 + # and later when we are not doing run time linking. + library_names_spec='$libname$release.a $libname.a' + soname_spec='$libname$release$shared_ext$major' + ;; + svr4,*) # full svr4 only + dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o)" + library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' + # We do not specify a path in Import Files, so LIBPATH fires. + shlibpath_overrides_runpath=yes + ;; + *,yes) # both, prefer svr4 + dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o), lib.a(lib.so.V)" + library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' + # unpreferred sharedlib libNAME.a needs extra handling + postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' + postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' + # We do not specify a path in Import Files, so LIBPATH fires. + shlibpath_overrides_runpath=yes + ;; + *,no) # both, prefer aix + dynamic_linker="AIX lib.a(lib.so.V), lib.so.V($shared_archive_member_spec.o)" + library_names_spec='$libname$release.a $libname.a' + soname_spec='$libname$release$shared_ext$major' + # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling + postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' + postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' + ;; + esac + shlibpath_var=LIBPATH + fi + ;; + +amigaos*) + case $host_cpu in + powerpc) + # Since July 2007 AmigaOS4 officially supports .so libraries. + # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + ;; + m68k) + library_names_spec='$libname.ixlibrary $libname.a' + # Create ${libname}_ixlibrary.a entries in /sys/libs. + finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' + ;; + esac + ;; + +beos*) + library_names_spec='$libname$shared_ext' + dynamic_linker="$host_os ld.so" + shlibpath_var=LIBRARY_PATH + ;; + +bsdi[45]*) + version_type=linux # correct to gnu/linux during the next big refactor + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + # the default ld.so.conf also contains /usr/contrib/lib and + # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow + # libtool to hard-code these into programs + ;; + +cygwin* | mingw* | pw32* | cegcc*) + version_type=windows + shrext_cmds=.dll + need_version=no + need_lib_prefix=no + + case $GCC,$cc_basename in + yes,*) + # gcc + library_names_spec='$libname.dll.a' + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \$file`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname~ + if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then + eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; + fi' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $RM \$dlpath' + shlibpath_overrides_runpath=yes + + case $host_os in + cygwin*) + # Cygwin DLLs use 'cyg' prefix rather than 'lib' + soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' + + sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api" + ;; + mingw* | cegcc*) + # MinGW DLLs use traditional 'lib' prefix + soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' + ;; + pw32*) + # pw32 DLLs use 'pw' prefix rather than 'lib' + library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' + ;; + esac + dynamic_linker='Win32 ld.exe' + ;; + + *,cl* | *,icl*) + # Native MSVC or ICC + libname_spec='$name' + soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' + library_names_spec='$libname.dll.lib' + + case $build_os in + mingw*) + sys_lib_search_path_spec= + lt_save_ifs=$IFS + IFS=';' + for lt_path in $LIB + do + IFS=$lt_save_ifs + # Let DOS variable expansion print the short 8.3 style file name. + lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` + sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" + done + IFS=$lt_save_ifs + # Convert to MSYS style. + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | sed -e 's|\\\\|/|g' -e 's| \\([a-zA-Z]\\):| /\\1|g' -e 's|^ ||'` + ;; + cygwin*) + # Convert to unix form, then to dos form, then back to unix form + # but this time dos style (no spaces!) so that the unix form looks + # like /cygdrive/c/PROGRA~1:/cygdr... + sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` + sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` + sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + ;; + *) + sys_lib_search_path_spec=$LIB + if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then + # It is most probably a Windows format PATH. + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + # FIXME: find the short name or the path components, as spaces are + # common. (e.g. "Program Files" -> "PROGRA~1") + ;; + esac + + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \$file`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $RM \$dlpath' + shlibpath_overrides_runpath=yes + dynamic_linker='Win32 link.exe' + ;; + + *) + # Assume MSVC and ICC wrapper + library_names_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext $libname.lib' + dynamic_linker='Win32 ld.exe' + ;; + esac + # FIXME: first we should search . and the directory the executable is in + shlibpath_var=PATH + ;; + +darwin* | rhapsody*) + dynamic_linker="$host_os dyld" + version_type=darwin + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$major$shared_ext $libname$shared_ext' + soname_spec='$libname$release$major$shared_ext' + shlibpath_overrides_runpath=yes + shlibpath_var=DYLD_LIBRARY_PATH + shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' + + sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib" + sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' + ;; + +dgux*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +freebsd* | dragonfly*) + # DragonFly does not have aout. When/if they implement a new + # versioning mechanism, adjust this. + if test -x /usr/bin/objformat; then + objformat=`/usr/bin/objformat` + else + case $host_os in + freebsd[23].*) objformat=aout ;; + *) objformat=elf ;; + esac + fi + version_type=freebsd-$objformat + case $version_type in + freebsd-elf*) + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + need_version=no + need_lib_prefix=no + ;; + freebsd-*) + library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' + need_version=yes + ;; + esac + shlibpath_var=LD_LIBRARY_PATH + case $host_os in + freebsd2.*) + shlibpath_overrides_runpath=yes + ;; + freebsd3.[01]* | freebsdelf3.[01]*) + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + freebsd3.[2-9]* | freebsdelf3.[2-9]* | \ + freebsd4.[0-5] | freebsdelf4.[0-5] | freebsd4.1.1 | freebsdelf4.1.1) + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + *) # from 4.6 on, and DragonFly + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + esac + ;; + +haiku*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + dynamic_linker="$host_os runtime_loader" + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LIBRARY_PATH + shlibpath_overrides_runpath=no + sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' + hardcode_into_libs=yes + ;; + +hpux9* | hpux10* | hpux11*) + # Give a soname corresponding to the major version so that dld.sl refuses to + # link against other versions. + version_type=sunos + need_lib_prefix=no + need_version=no + case $host_cpu in + ia64*) + shrext_cmds='.so' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.so" + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + if test 32 = "$HPUX_IA64_MODE"; then + sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" + sys_lib_dlsearch_path_spec=/usr/lib/hpux32 + else + sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" + sys_lib_dlsearch_path_spec=/usr/lib/hpux64 + fi + ;; + hppa*64*) + shrext_cmds='.sl' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.sl" + shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + *) + shrext_cmds='.sl' + dynamic_linker="$host_os dld.sl" + shlibpath_var=SHLIB_PATH + shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + ;; + esac + # HP-UX runs *really* slowly unless shared libraries are mode 555, ... + postinstall_cmds='chmod 555 $lib' + # or fails outright, so override atomically: + install_override_mode=555 + ;; + +interix[3-9]*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + +irix5* | irix6* | nonstopux*) + case $host_os in + nonstopux*) version_type=nonstopux ;; + *) + if test yes = "$lt_cv_prog_gnu_ld"; then + version_type=linux # correct to gnu/linux during the next big refactor + else + version_type=irix + fi ;; + esac + need_lib_prefix=no + need_version=no + soname_spec='$libname$release$shared_ext$major' + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext' + case $host_os in + irix5* | nonstopux*) + libsuff= shlibsuff= + ;; + *) + case $LD in # libtool.m4 will add one of these switches to LD + *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") + libsuff= shlibsuff= libmagic=32-bit;; + *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") + libsuff=32 shlibsuff=N32 libmagic=N32;; + *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") + libsuff=64 shlibsuff=64 libmagic=64-bit;; + *) libsuff= shlibsuff= libmagic=never-match;; + esac + ;; + esac + shlibpath_var=LD_LIBRARY${shlibsuff}_PATH + shlibpath_overrides_runpath=no + sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff" + sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff" + hardcode_into_libs=yes + ;; + +# No shared lib support for Linux oldld, aout, or coff. +linux*oldld* | linux*aout* | linux*coff*) + dynamic_linker=no + ;; + +linux*android*) + version_type=none # Android doesn't support versioned libraries. + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext' + soname_spec='$libname$release$shared_ext' + finish_cmds= + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + dynamic_linker='Android linker' + # Don't embed -rpath directories since the linker doesn't support them. + hardcode_libdir_flag_spec='-L$libdir' + ;; + +# This must be glibc/ELF. +linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + + # Some binutils ld are patched to set DT_RUNPATH + if ${lt_cv_shlibpath_overrides_runpath+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_shlibpath_overrides_runpath=no + save_LDFLAGS=$LDFLAGS + save_libdir=$libdir + eval "libdir=/foo; wl=\"$lt_prog_compiler_wl\"; \ + LDFLAGS=\"\$LDFLAGS $hardcode_libdir_flag_spec\"" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + if ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null; then : + lt_cv_shlibpath_overrides_runpath=yes +fi +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + LDFLAGS=$save_LDFLAGS + libdir=$save_libdir + +fi + + shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath + + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + # Ideally, we could use ldconfig to report *all* directores which are + # searched for libraries, however this is still not possible. Aside from not + # being certain /sbin/ldconfig is available, command + # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, + # even though it is searched at run-time. Try to do the best guess by + # appending ld.so.conf contents (and includes) to the search path. + if test -f /etc/ld.so.conf; then + lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` + sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" + fi + + # We used to test for /lib/ld.so.1 and disable shared libraries on + # powerpc, because MkLinux only supported shared libraries with the + # GNU dynamic linker. Since this was broken with cross compilers, + # most powerpc-linux boxes support dynamic linking these days and + # people can always --disable-shared, the test was removed, and we + # assume the GNU/Linux dynamic linker is in use. + dynamic_linker='GNU/Linux ld.so' + ;; + +netbsd*) + version_type=sunos + need_lib_prefix=no + need_version=no + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + dynamic_linker='NetBSD (a.out) ld.so' + else + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + dynamic_linker='NetBSD ld.elf_so' + fi + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + +newsos6) + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +*nto* | *qnx*) + version_type=qnx + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='ldqnx.so' + ;; + +openbsd* | bitrig*) + version_type=sunos + sys_lib_dlsearch_path_spec=/usr/lib + need_lib_prefix=no + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then + need_version=no + else + need_version=yes + fi + library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +os2*) + libname_spec='$name' + version_type=windows + shrext_cmds=.dll + need_version=no + need_lib_prefix=no + # OS/2 can only load a DLL with a base name of 8 characters or less. + soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; + v=$($ECHO $release$versuffix | tr -d .-); + n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); + $ECHO $n$v`$shared_ext' + library_names_spec='${libname}_dll.$libext' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=BEGINLIBPATH + sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + postinstall_cmds='base_file=`basename \$file`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname~ + if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then + eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; + fi' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $RM \$dlpath' + ;; + +osf3* | osf4* | osf5*) + version_type=osf + need_lib_prefix=no + need_version=no + soname_spec='$libname$release$shared_ext$major' + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + +rdos*) + dynamic_linker=no + ;; + +solaris*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + # ldd complains unless libraries are executable + postinstall_cmds='chmod +x $lib' + ;; + +sunos4*) + version_type=sunos + library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' + finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + if test yes = "$with_gnu_ld"; then + need_lib_prefix=no + fi + need_version=yes + ;; + +sysv4 | sysv4.3*) + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + case $host_vendor in + sni) + shlibpath_overrides_runpath=no + need_lib_prefix=no + runpath_var=LD_RUN_PATH + ;; + siemens) + need_lib_prefix=no + ;; + motorola) + need_lib_prefix=no + need_version=no + shlibpath_overrides_runpath=no + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + ;; + esac + ;; + +sysv4*MP*) + if test -d /usr/nec; then + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext' + soname_spec='$libname$shared_ext.$major' + shlibpath_var=LD_LIBRARY_PATH + fi + ;; + +sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) + version_type=sco + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + if test yes = "$with_gnu_ld"; then + sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' + else + sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' + case $host_os in + sco3.2v5*) + sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" + ;; + esac + fi + sys_lib_dlsearch_path_spec='/usr/lib' + ;; + +tpf*) + # TPF is a cross-target only. Preferred cross-host = GNU/Linux. + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + +uts4*) + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +*) + dynamic_linker=no + ;; +esac +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $dynamic_linker" >&5 +$as_echo "$dynamic_linker" >&6; } +test no = "$dynamic_linker" && can_build_shared=no + +variables_saved_for_relink="PATH $shlibpath_var $runpath_var" +if test yes = "$GCC"; then + variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" +fi + +if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then + sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec +fi + +if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then + sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec +fi + +# remember unaugmented sys_lib_dlsearch_path content for libtool script decls... +configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec + +# ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code +func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" + +# to be used as default LT_SYS_LIBRARY_PATH value in generated libtool +configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to hardcode library paths into programs" >&5 +$as_echo_n "checking how to hardcode library paths into programs... " >&6; } +hardcode_action= +if test -n "$hardcode_libdir_flag_spec" || + test -n "$runpath_var" || + test yes = "$hardcode_automatic"; then + + # We can hardcode non-existent directories. + if test no != "$hardcode_direct" && + # If the only mechanism to avoid hardcoding is shlibpath_var, we + # have to relink, otherwise we might link with an installed library + # when we should be linking with a yet-to-be-installed one + ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, )" && + test no != "$hardcode_minus_L"; then + # Linking always hardcodes the temporary library directory. + hardcode_action=relink + else + # We can link without hardcoding, and we can hardcode nonexisting dirs. + hardcode_action=immediate + fi +else + # We cannot hardcode anything, or else we can only hardcode existing + # directories. + hardcode_action=unsupported +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $hardcode_action" >&5 +$as_echo "$hardcode_action" >&6; } + +if test relink = "$hardcode_action" || + test yes = "$inherit_rpath"; then + # Fast installation is not supported + enable_fast_install=no +elif test yes = "$shlibpath_overrides_runpath" || + test no = "$enable_shared"; then + # Fast installation is not necessary + enable_fast_install=needless +fi + + + + + + + if test yes != "$enable_dlopen"; then + enable_dlopen=unknown + enable_dlopen_self=unknown + enable_dlopen_self_static=unknown +else + lt_cv_dlopen=no + lt_cv_dlopen_libs= + + case $host_os in + beos*) + lt_cv_dlopen=load_add_on + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ;; + + mingw* | pw32* | cegcc*) + lt_cv_dlopen=LoadLibrary + lt_cv_dlopen_libs= + ;; + + cygwin*) + lt_cv_dlopen=dlopen + lt_cv_dlopen_libs= + ;; + + darwin*) + # if libdl is installed we need to link against it + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 +$as_echo_n "checking for dlopen in -ldl... " >&6; } +if ${ac_cv_lib_dl_dlopen+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldl $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char dlopen (); +int +main () +{ +return dlopen (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_dl_dlopen=yes +else + ac_cv_lib_dl_dlopen=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 +$as_echo "$ac_cv_lib_dl_dlopen" >&6; } +if test "x$ac_cv_lib_dl_dlopen" = xyes; then : + lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl +else + + lt_cv_dlopen=dyld + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + +fi + + ;; + + tpf*) + # Don't try to run any link tests for TPF. We know it's impossible + # because TPF is a cross-compiler, and we know how we open DSOs. + lt_cv_dlopen=dlopen + lt_cv_dlopen_libs= + lt_cv_dlopen_self=no + ;; + + *) + ac_fn_c_check_func "$LINENO" "shl_load" "ac_cv_func_shl_load" +if test "x$ac_cv_func_shl_load" = xyes; then : + lt_cv_dlopen=shl_load +else + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for shl_load in -ldld" >&5 +$as_echo_n "checking for shl_load in -ldld... " >&6; } +if ${ac_cv_lib_dld_shl_load+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldld $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char shl_load (); +int +main () +{ +return shl_load (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_dld_shl_load=yes +else + ac_cv_lib_dld_shl_load=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_shl_load" >&5 +$as_echo "$ac_cv_lib_dld_shl_load" >&6; } +if test "x$ac_cv_lib_dld_shl_load" = xyes; then : + lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld +else + ac_fn_c_check_func "$LINENO" "dlopen" "ac_cv_func_dlopen" +if test "x$ac_cv_func_dlopen" = xyes; then : + lt_cv_dlopen=dlopen +else + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 +$as_echo_n "checking for dlopen in -ldl... " >&6; } +if ${ac_cv_lib_dl_dlopen+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldl $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char dlopen (); +int +main () +{ +return dlopen (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_dl_dlopen=yes +else + ac_cv_lib_dl_dlopen=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 +$as_echo "$ac_cv_lib_dl_dlopen" >&6; } +if test "x$ac_cv_lib_dl_dlopen" = xyes; then : + lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl +else + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -lsvld" >&5 +$as_echo_n "checking for dlopen in -lsvld... " >&6; } +if ${ac_cv_lib_svld_dlopen+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lsvld $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char dlopen (); +int +main () +{ +return dlopen (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_svld_dlopen=yes +else + ac_cv_lib_svld_dlopen=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_svld_dlopen" >&5 +$as_echo "$ac_cv_lib_svld_dlopen" >&6; } +if test "x$ac_cv_lib_svld_dlopen" = xyes; then : + lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld +else + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dld_link in -ldld" >&5 +$as_echo_n "checking for dld_link in -ldld... " >&6; } +if ${ac_cv_lib_dld_dld_link+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldld $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char dld_link (); +int +main () +{ +return dld_link (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_dld_dld_link=yes +else + ac_cv_lib_dld_dld_link=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_dld_link" >&5 +$as_echo "$ac_cv_lib_dld_dld_link" >&6; } +if test "x$ac_cv_lib_dld_dld_link" = xyes; then : + lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld +fi + + +fi + + +fi + + +fi + + +fi + + +fi + + ;; + esac + + if test no = "$lt_cv_dlopen"; then + enable_dlopen=no + else + enable_dlopen=yes + fi + + case $lt_cv_dlopen in + dlopen) + save_CPPFLAGS=$CPPFLAGS + test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" + + save_LDFLAGS=$LDFLAGS + wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" + + save_LIBS=$LIBS + LIBS="$lt_cv_dlopen_libs $LIBS" + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a program can dlopen itself" >&5 +$as_echo_n "checking whether a program can dlopen itself... " >&6; } +if ${lt_cv_dlopen_self+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test yes = "$cross_compiling"; then : + lt_cv_dlopen_self=cross +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext <<_LT_EOF +#line $LINENO "configure" +#include "confdefs.h" + +#if HAVE_DLFCN_H +#include +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +/* When -fvisibility=hidden is used, assume the code has been annotated + correspondingly for the symbols needed. */ +#if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) +int fnord () __attribute__((visibility("default"))); +#endif + +int fnord () { return 42; } +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else + { + if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + else puts (dlerror ()); + } + /* dlclose (self); */ + } + else + puts (dlerror ()); + + return status; +} +_LT_EOF + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 + (eval $ac_link) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then + (./conftest; exit; ) >&5 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) lt_cv_dlopen_self=yes ;; + x$lt_dlneed_uscore) lt_cv_dlopen_self=yes ;; + x$lt_dlunknown|x*) lt_cv_dlopen_self=no ;; + esac + else : + # compilation failed + lt_cv_dlopen_self=no + fi +fi +rm -fr conftest* + + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self" >&5 +$as_echo "$lt_cv_dlopen_self" >&6; } + + if test yes = "$lt_cv_dlopen_self"; then + wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" + { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a statically linked program can dlopen itself" >&5 +$as_echo_n "checking whether a statically linked program can dlopen itself... " >&6; } +if ${lt_cv_dlopen_self_static+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test yes = "$cross_compiling"; then : + lt_cv_dlopen_self_static=cross +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext <<_LT_EOF +#line $LINENO "configure" +#include "confdefs.h" + +#if HAVE_DLFCN_H +#include +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +/* When -fvisibility=hidden is used, assume the code has been annotated + correspondingly for the symbols needed. */ +#if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) +int fnord () __attribute__((visibility("default"))); +#endif + +int fnord () { return 42; } +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else + { + if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + else puts (dlerror ()); + } + /* dlclose (self); */ + } + else + puts (dlerror ()); + + return status; +} +_LT_EOF + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 + (eval $ac_link) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then + (./conftest; exit; ) >&5 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) lt_cv_dlopen_self_static=yes ;; + x$lt_dlneed_uscore) lt_cv_dlopen_self_static=yes ;; + x$lt_dlunknown|x*) lt_cv_dlopen_self_static=no ;; + esac + else : + # compilation failed + lt_cv_dlopen_self_static=no + fi +fi +rm -fr conftest* + + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self_static" >&5 +$as_echo "$lt_cv_dlopen_self_static" >&6; } + fi + + CPPFLAGS=$save_CPPFLAGS + LDFLAGS=$save_LDFLAGS + LIBS=$save_LIBS + ;; + esac + + case $lt_cv_dlopen_self in + yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; + *) enable_dlopen_self=unknown ;; + esac + + case $lt_cv_dlopen_self_static in + yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; + *) enable_dlopen_self_static=unknown ;; + esac +fi + + + + + + + + + + + + + + + + + +striplib= +old_striplib= +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether stripping libraries is possible" >&5 +$as_echo_n "checking whether stripping libraries is possible... " >&6; } +if test -z "$STRIP"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +else + if $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then + old_striplib="$STRIP --strip-debug" + striplib="$STRIP --strip-unneeded" + { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 +$as_echo "yes" >&6; } + else + case $host_os in + darwin*) + # FIXME - insert some real tests, host_os isn't really good enough + striplib="$STRIP -x" + old_striplib="$STRIP -S" + { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 +$as_echo "yes" >&6; } + ;; + freebsd*) + if $STRIP -V 2>&1 | $GREP "elftoolchain" >/dev/null; then + old_striplib="$STRIP --strip-debug" + striplib="$STRIP --strip-unneeded" + { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 +$as_echo "yes" >&6; } + else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } + fi + ;; + *) + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } + ;; + esac + fi +fi + + + + + + + + + + + + + # Report what library types will actually be built + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if libtool supports shared libraries" >&5 +$as_echo_n "checking if libtool supports shared libraries... " >&6; } + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $can_build_shared" >&5 +$as_echo "$can_build_shared" >&6; } + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build shared libraries" >&5 +$as_echo_n "checking whether to build shared libraries... " >&6; } + test no = "$can_build_shared" && enable_shared=no + + # On AIX, shared libraries and static libraries use the same namespace, and + # are all built from PIC. + case $host_os in + aix3*) + test yes = "$enable_shared" && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + + aix[4-9]*) + if test ia64 != "$host_cpu"; then + case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in + yes,aix,yes) ;; # shared object as lib.so file only + yes,svr4,*) ;; # shared object as lib.so archive member only + yes,*) enable_static=no ;; # shared object in lib.a archive as well + esac + fi + ;; + esac + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_shared" >&5 +$as_echo "$enable_shared" >&6; } + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build static libraries" >&5 +$as_echo_n "checking whether to build static libraries... " >&6; } + # Make sure either enable_shared or enable_static is yes. + test yes = "$enable_shared" || enable_static=yes + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_static" >&5 +$as_echo "$enable_static" >&6; } + + + + +fi +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +CC=$lt_save_CC + + + + + + + + + + + + + + + + ac_config_commands="$ac_config_commands libtool" + + + + +# Only expand once: + + + +# Checks for programs. +ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu +if test -z "$CXX"; then + if test -n "$CCC"; then + CXX=$CCC + else + if test -n "$ac_tool_prefix"; then + for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CXX"; then + ac_cv_prog_CXX="$CXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_CXX="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CXX=$ac_cv_prog_CXX +if test -n "$CXX"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CXX" >&5 +$as_echo "$CXX" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$CXX" && break + done +fi +if test -z "$CXX"; then + ac_ct_CXX=$CXX + for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_CXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CXX"; then + ac_cv_prog_ac_ct_CXX="$ac_ct_CXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_CXX="$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_CXX=$ac_cv_prog_ac_ct_CXX +if test -n "$ac_ct_CXX"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CXX" >&5 +$as_echo "$ac_ct_CXX" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_CXX" && break +done + + if test "x$ac_ct_CXX" = x; then + CXX="g++" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CXX=$ac_ct_CXX + fi +fi + + fi +fi +# Provide some information about the compiler. +$as_echo "$as_me:${as_lineno-$LINENO}: checking for C++ compiler version" >&5 +set X $ac_compile +ac_compiler=$2 +for ac_option in --version -v -V -qversion; do + { { ac_try="$ac_compiler $ac_option >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compiler $ac_option >&5") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + sed '10a\ +... rest of stderr output deleted ... + 10q' conftest.err >conftest.er1 + cat conftest.er1 >&5 + fi + rm -f conftest.er1 conftest.err + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } +done + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C++ compiler" >&5 +$as_echo_n "checking whether we are using the GNU C++ compiler... " >&6; } +if ${ac_cv_cxx_compiler_gnu+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + ac_compiler_gnu=yes +else + ac_compiler_gnu=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_cxx_compiler_gnu=$ac_compiler_gnu + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_cxx_compiler_gnu" >&5 +$as_echo "$ac_cv_cxx_compiler_gnu" >&6; } +if test $ac_compiler_gnu = yes; then + GXX=yes +else + GXX= +fi +ac_test_CXXFLAGS=${CXXFLAGS+set} +ac_save_CXXFLAGS=$CXXFLAGS +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CXX accepts -g" >&5 +$as_echo_n "checking whether $CXX accepts -g... " >&6; } +if ${ac_cv_prog_cxx_g+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_save_cxx_werror_flag=$ac_cxx_werror_flag + ac_cxx_werror_flag=yes + ac_cv_prog_cxx_g=no + CXXFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + ac_cv_prog_cxx_g=yes +else + CXXFLAGS="" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + +else + ac_cxx_werror_flag=$ac_save_cxx_werror_flag + CXXFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + ac_cv_prog_cxx_g=yes +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_cxx_werror_flag=$ac_save_cxx_werror_flag +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cxx_g" >&5 +$as_echo "$ac_cv_prog_cxx_g" >&6; } +if test "$ac_test_CXXFLAGS" = set; then + CXXFLAGS=$ac_save_CXXFLAGS +elif test $ac_cv_prog_cxx_g = yes; then + if test "$GXX" = yes; then + CXXFLAGS="-g -O2" + else + CXXFLAGS="-g" + fi +else + if test "$GXX" = yes; then + CXXFLAGS="-O2" + else + CXXFLAGS= + fi +fi +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +depcc="$CXX" am_compiler_list= + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 +$as_echo_n "checking dependency style of $depcc... " >&6; } +if ${am_cv_CXX_dependencies_compiler_type+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named 'D' -- because '-MD' means "put the output + # in D". + rm -rf conftest.dir + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_CXX_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` + fi + am__universal=false + case " $depcc " in #( + *\ -arch\ *\ -arch\ *) am__universal=true ;; + esac + + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with + # Solaris 10 /bin/sh. + echo '/* dummy */' > sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + # We check with '-c' and '-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle '-M -o', and we need to detect this. Also, some Intel + # versions had trouble with output in subdirs. + am__obj=sub/conftest.${OBJEXT-o} + am__minus_obj="-o $am__obj" + case $depmode in + gcc) + # This depmode causes a compiler race in universal mode. + test "$am__universal" = false || continue + ;; + nosideeffect) + # After this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested. + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + msvc7 | msvc7msys | msvisualcpp | msvcmsys) + # This compiler won't grok '-c -o', but also, the minuso test has + # not run yet. These depmodes are late enough in the game, and + # so weak that their functioning should not be impacted. + am__obj=conftest.${OBJEXT-o} + am__minus_obj= + ;; + none) break ;; + esac + if depmode=$depmode \ + source=sub/conftest.c object=$am__obj \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep $am__obj sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_CXX_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_CXX_dependencies_compiler_type=none +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_CXX_dependencies_compiler_type" >&5 +$as_echo "$am_cv_CXX_dependencies_compiler_type" >&6; } +CXXDEPMODE=depmode=$am_cv_CXX_dependencies_compiler_type + + if + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_CXX_dependencies_compiler_type" = gcc3; then + am__fastdepCXX_TRUE= + am__fastdepCXX_FALSE='#' +else + am__fastdepCXX_TRUE='#' + am__fastdepCXX_FALSE= +fi + + + + +func_stripname_cnf () +{ + case $2 in + .*) func_stripname_result=`$ECHO "$3" | $SED "s%^$1%%; s%\\\\$2\$%%"`;; + *) func_stripname_result=`$ECHO "$3" | $SED "s%^$1%%; s%$2\$%%"`;; + esac +} # func_stripname_cnf + + if test -n "$CXX" && ( test no != "$CXX" && + ( (test g++ = "$CXX" && `g++ -v >/dev/null 2>&1` ) || + (test g++ != "$CXX"))); then + ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to run the C++ preprocessor" >&5 +$as_echo_n "checking how to run the C++ preprocessor... " >&6; } +if test -z "$CXXCPP"; then + if ${ac_cv_prog_CXXCPP+:} false; then : + $as_echo_n "(cached) " >&6 +else + # Double quotes because CXXCPP needs to be expanded + for CXXCPP in "$CXX -E" "/lib/cpp" + do + ac_preproc_ok=false +for ac_cxx_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if ac_fn_cxx_try_cpp "$LINENO"; then : + +else + # Broken: fails on valid input. +continue +fi +rm -f conftest.err conftest.i conftest.$ac_ext + + # OK, works on sane cases. Now check whether nonexistent headers + # can be detected and how. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +_ACEOF +if ac_fn_cxx_try_cpp "$LINENO"; then : + # Broken: success on invalid input. +continue +else + # Passes both tests. +ac_preproc_ok=: +break +fi +rm -f conftest.err conftest.i conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.i conftest.err conftest.$ac_ext +if $ac_preproc_ok; then : + break +fi + + done + ac_cv_prog_CXXCPP=$CXXCPP + +fi + CXXCPP=$ac_cv_prog_CXXCPP +else + ac_cv_prog_CXXCPP=$CXXCPP +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $CXXCPP" >&5 +$as_echo "$CXXCPP" >&6; } +ac_preproc_ok=false +for ac_cxx_preproc_warn_flag in '' yes +do + # Use a header file that comes with gcc, so configuring glibc + # with a fresh cross-compiler works. + # Prefer to if __STDC__ is defined, since + # exists even on freestanding compilers. + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. "Syntax error" is here to catch this case. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#ifdef __STDC__ +# include +#else +# include +#endif + Syntax error +_ACEOF +if ac_fn_cxx_try_cpp "$LINENO"; then : + +else + # Broken: fails on valid input. +continue +fi +rm -f conftest.err conftest.i conftest.$ac_ext + + # OK, works on sane cases. Now check whether nonexistent headers + # can be detected and how. + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +_ACEOF +if ac_fn_cxx_try_cpp "$LINENO"; then : + # Broken: success on invalid input. +continue +else + # Passes both tests. +ac_preproc_ok=: +break +fi +rm -f conftest.err conftest.i conftest.$ac_ext + +done +# Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. +rm -f conftest.i conftest.err conftest.$ac_ext +if $ac_preproc_ok; then : + +else + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "C++ preprocessor \"$CXXCPP\" fails sanity check +See \`config.log' for more details" "$LINENO" 5; } +fi + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +else + _lt_caught_CXX_error=yes +fi + +ac_ext=cpp +ac_cpp='$CXXCPP $CPPFLAGS' +ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_cxx_compiler_gnu + +archive_cmds_need_lc_CXX=no +allow_undefined_flag_CXX= +always_export_symbols_CXX=no +archive_expsym_cmds_CXX= +compiler_needs_object_CXX=no +export_dynamic_flag_spec_CXX= +hardcode_direct_CXX=no +hardcode_direct_absolute_CXX=no +hardcode_libdir_flag_spec_CXX= +hardcode_libdir_separator_CXX= +hardcode_minus_L_CXX=no +hardcode_shlibpath_var_CXX=unsupported +hardcode_automatic_CXX=no +inherit_rpath_CXX=no +module_cmds_CXX= +module_expsym_cmds_CXX= +link_all_deplibs_CXX=unknown +old_archive_cmds_CXX=$old_archive_cmds +reload_flag_CXX=$reload_flag +reload_cmds_CXX=$reload_cmds +no_undefined_flag_CXX= +whole_archive_flag_spec_CXX= +enable_shared_with_static_runtimes_CXX=no + +# Source file extension for C++ test sources. +ac_ext=cpp + +# Object file extension for compiled C++ test sources. +objext=o +objext_CXX=$objext + +# No sense in running all these tests if we already determined that +# the CXX compiler isn't working. Some variables (like enable_shared) +# are currently assumed to apply to all compilers on this platform, +# and will be corrupted by setting them based on a non-working compiler. +if test yes != "$_lt_caught_CXX_error"; then + # Code to be used in simple compile tests + lt_simple_compile_test_code="int some_variable = 0;" + + # Code to be used in simple link tests + lt_simple_link_test_code='int main(int, char *[]) { return(0); }' + + # ltmain only uses $CC for tagged configurations so make sure $CC is set. + + + + + + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# If no C compiler flags were specified, use CFLAGS. +LTCFLAGS=${LTCFLAGS-"$CFLAGS"} + +# Allow CC to be a program name with arguments. +compiler=$CC + + + # save warnings/boilerplate of simple test code + ac_outfile=conftest.$ac_objext +echo "$lt_simple_compile_test_code" >conftest.$ac_ext +eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err +_lt_compiler_boilerplate=`cat conftest.err` +$RM conftest* + + ac_outfile=conftest.$ac_objext +echo "$lt_simple_link_test_code" >conftest.$ac_ext +eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err +_lt_linker_boilerplate=`cat conftest.err` +$RM -r conftest* + + + # Allow CC to be a program name with arguments. + lt_save_CC=$CC + lt_save_CFLAGS=$CFLAGS + lt_save_LD=$LD + lt_save_GCC=$GCC + GCC=$GXX + lt_save_with_gnu_ld=$with_gnu_ld + lt_save_path_LD=$lt_cv_path_LD + if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then + lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx + else + $as_unset lt_cv_prog_gnu_ld + fi + if test -n "${lt_cv_path_LDCXX+set}"; then + lt_cv_path_LD=$lt_cv_path_LDCXX + else + $as_unset lt_cv_path_LD + fi + test -z "${LDCXX+set}" || LD=$LDCXX + CC=${CXX-"c++"} + CFLAGS=$CXXFLAGS + compiler=$CC + compiler_CXX=$CC + func_cc_basename $compiler +cc_basename=$func_cc_basename_result + + + if test -n "$compiler"; then + # We don't want -fno-exception when compiling C++ code, so set the + # no_builtin_flag separately + if test yes = "$GXX"; then + lt_prog_compiler_no_builtin_flag_CXX=' -fno-builtin' + else + lt_prog_compiler_no_builtin_flag_CXX= + fi + + if test yes = "$GXX"; then + # Set up default GNU C++ configuration + + + +# Check whether --with-gnu-ld was given. +if test "${with_gnu_ld+set}" = set; then : + withval=$with_gnu_ld; test no = "$withval" || with_gnu_ld=yes +else + with_gnu_ld=no +fi + +ac_prog=ld +if test yes = "$GCC"; then + # Check if gcc -print-prog-name=ld gives a path. + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ld used by $CC" >&5 +$as_echo_n "checking for ld used by $CC... " >&6; } + case $host in + *-*-mingw*) + # gcc leaves a trailing carriage return, which upsets mingw + ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; + *) + ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; + esac + case $ac_prog in + # Accept absolute paths. + [\\/]* | ?:[\\/]*) + re_direlt='/[^/][^/]*/\.\./' + # Canonicalize the pathname of ld + ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` + while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do + ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` + done + test -z "$LD" && LD=$ac_prog + ;; + "") + # If it fails, then pretend we aren't using GCC. + ac_prog=ld + ;; + *) + # If it is relative, then search for the first ld in PATH. + with_gnu_ld=unknown + ;; + esac +elif test yes = "$with_gnu_ld"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for GNU ld" >&5 +$as_echo_n "checking for GNU ld... " >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for non-GNU ld" >&5 +$as_echo_n "checking for non-GNU ld... " >&6; } +fi +if ${lt_cv_path_LD+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -z "$LD"; then + lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR + for ac_dir in $PATH; do + IFS=$lt_save_ifs + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then + lt_cv_path_LD=$ac_dir/$ac_prog + # Check to see if the program is GNU ld. I'd rather use --version, + # but apparently some variants of GNU ld only accept -v. + # Break only if it was the GNU/non-GNU ld that we prefer. + case `"$lt_cv_path_LD" -v 2>&1 &5 +$as_echo "$LD" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi +test -z "$LD" && as_fn_error $? "no acceptable ld found in \$PATH" "$LINENO" 5 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if the linker ($LD) is GNU ld" >&5 +$as_echo_n "checking if the linker ($LD) is GNU ld... " >&6; } +if ${lt_cv_prog_gnu_ld+:} false; then : + $as_echo_n "(cached) " >&6 +else + # I'd rather use --version here, but apparently some GNU lds only accept -v. +case `$LD -v 2>&1 &5 +$as_echo "$lt_cv_prog_gnu_ld" >&6; } +with_gnu_ld=$lt_cv_prog_gnu_ld + + + + + + + + # Check if GNU C++ uses GNU ld as the underlying linker, since the + # archiving commands below assume that GNU ld is being used. + if test yes = "$with_gnu_ld"; then + archive_cmds_CXX='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + + hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir' + export_dynamic_flag_spec_CXX='$wl--export-dynamic' + + # If archive_cmds runs LD, not CC, wlarc should be empty + # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to + # investigate it a little bit more. (MM) + wlarc='$wl' + + # ancient GNU ld didn't support --whole-archive et. al. + if eval "`$CC -print-prog-name=ld` --help 2>&1" | + $GREP 'no-whole-archive' > /dev/null; then + whole_archive_flag_spec_CXX=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' + else + whole_archive_flag_spec_CXX= + fi + else + with_gnu_ld=no + wlarc= + + # A generic and very simple default shared library creation + # command for GNU C++ for the case where it uses the native + # linker, instead of GNU ld. If possible, this setting should + # overridden to take advantage of the native linker features on + # the platform it is being used on. + archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' + fi + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' + + else + GXX=no + with_gnu_ld=no + wlarc= + fi + + # PORTME: fill in a description of your system's C++ link characteristics + { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $compiler linker ($LD) supports shared libraries" >&5 +$as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } + ld_shlibs_CXX=yes + case $host_os in + aix3*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + aix[4-9]*) + if test ia64 = "$host_cpu"; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag= + else + aix_use_runtimelinking=no + + # Test if we are trying to use run time linking or normal + # AIX style linking. If -brtl is somewhere in LDFLAGS, we + # have runtime linking enabled, and use it for executables. + # For shared libraries, we enable/disable runtime linking + # depending on the kind of the shared library created - + # when "with_aix_soname,aix_use_runtimelinking" is: + # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables + # "aix,yes" lib.so shared, rtl:yes, for executables + # lib.a static archive + # "both,no" lib.so.V(shr.o) shared, rtl:yes + # lib.a(lib.so.V) shared, rtl:no, for executables + # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables + # lib.a(lib.so.V) shared, rtl:no + # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables + # lib.a static archive + case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) + for ld_flag in $LDFLAGS; do + case $ld_flag in + *-brtl*) + aix_use_runtimelinking=yes + break + ;; + esac + done + if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then + # With aix-soname=svr4, we create the lib.so.V shared archives only, + # so we don't have lib.a shared libs to link our executables. + # We have to force runtime linking in this case. + aix_use_runtimelinking=yes + LDFLAGS="$LDFLAGS -Wl,-brtl" + fi + ;; + esac + + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + archive_cmds_CXX='' + hardcode_direct_CXX=yes + hardcode_direct_absolute_CXX=yes + hardcode_libdir_separator_CXX=':' + link_all_deplibs_CXX=yes + file_list_spec_CXX='$wl-f,' + case $with_aix_soname,$aix_use_runtimelinking in + aix,*) ;; # no import file + svr4,* | *,yes) # use import file + # The Import File defines what to hardcode. + hardcode_direct_CXX=no + hardcode_direct_absolute_CXX=no + ;; + esac + + if test yes = "$GXX"; then + case $host_os in aix4.[012]|aix4.[012].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`$CC -print-prog-name=collect2` + if test -f "$collect2name" && + strings "$collect2name" | $GREP resolve_lib_name >/dev/null + then + # We have reworked collect2 + : + else + # We have old collect2 + hardcode_direct_CXX=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + hardcode_minus_L_CXX=yes + hardcode_libdir_flag_spec_CXX='-L$libdir' + hardcode_libdir_separator_CXX= + fi + esac + shared_flag='-shared' + if test yes = "$aix_use_runtimelinking"; then + shared_flag=$shared_flag' $wl-G' + fi + # Need to ensure runtime linking is disabled for the traditional + # shared library, or the linker may eventually find shared libraries + # /with/ Import File - we do not want to mix them. + shared_flag_aix='-shared' + shared_flag_svr4='-shared $wl-G' + else + # not using gcc + if test ia64 = "$host_cpu"; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test yes = "$aix_use_runtimelinking"; then + shared_flag='$wl-G' + else + shared_flag='$wl-bM:SRE' + fi + shared_flag_aix='$wl-bM:SRE' + shared_flag_svr4='$wl-G' + fi + fi + + export_dynamic_flag_spec_CXX='$wl-bexpall' + # It seems that -bexpall does not export symbols beginning with + # underscore (_), so it is better to generate a list of symbols to + # export. + always_export_symbols_CXX=yes + if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + # The "-G" linker flag allows undefined symbols. + no_undefined_flag_CXX='-bernotok' + # Determine the default libpath from the value encoded in an empty + # executable. + if test set = "${lt_cv_aix_libpath+set}"; then + aix_libpath=$lt_cv_aix_libpath +else + if ${lt_cv_aix_libpath__CXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_link "$LINENO"; then : + + lt_aix_libpath_sed=' + /Import File Strings/,/^$/ { + /^0/ { + s/^0 *\([^ ]*\) *$/\1/ + p + } + }' + lt_cv_aix_libpath__CXX=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` + # Check for a 64-bit object if we didn't find anything. + if test -z "$lt_cv_aix_libpath__CXX"; then + lt_cv_aix_libpath__CXX=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` + fi +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + if test -z "$lt_cv_aix_libpath__CXX"; then + lt_cv_aix_libpath__CXX=/usr/lib:/lib + fi + +fi + + aix_libpath=$lt_cv_aix_libpath__CXX +fi + + hardcode_libdir_flag_spec_CXX='$wl-blibpath:$libdir:'"$aix_libpath" + + archive_expsym_cmds_CXX='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag + else + if test ia64 = "$host_cpu"; then + hardcode_libdir_flag_spec_CXX='$wl-R $libdir:/usr/lib:/lib' + allow_undefined_flag_CXX="-z nodefs" + archive_expsym_cmds_CXX="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an + # empty executable. + if test set = "${lt_cv_aix_libpath+set}"; then + aix_libpath=$lt_cv_aix_libpath +else + if ${lt_cv_aix_libpath__CXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_link "$LINENO"; then : + + lt_aix_libpath_sed=' + /Import File Strings/,/^$/ { + /^0/ { + s/^0 *\([^ ]*\) *$/\1/ + p + } + }' + lt_cv_aix_libpath__CXX=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` + # Check for a 64-bit object if we didn't find anything. + if test -z "$lt_cv_aix_libpath__CXX"; then + lt_cv_aix_libpath__CXX=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` + fi +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + if test -z "$lt_cv_aix_libpath__CXX"; then + lt_cv_aix_libpath__CXX=/usr/lib:/lib + fi + +fi + + aix_libpath=$lt_cv_aix_libpath__CXX +fi + + hardcode_libdir_flag_spec_CXX='$wl-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + no_undefined_flag_CXX=' $wl-bernotok' + allow_undefined_flag_CXX=' $wl-berok' + if test yes = "$with_gnu_ld"; then + # We only use this code for GNU lds that support --whole-archive. + whole_archive_flag_spec_CXX='$wl--whole-archive$convenience $wl--no-whole-archive' + else + # Exported symbols can be pulled into shared objects from archives + whole_archive_flag_spec_CXX='$convenience' + fi + archive_cmds_need_lc_CXX=yes + archive_expsym_cmds_CXX='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' + # -brtl affects multiple linker settings, -berok does not and is overridden later + compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([, ]\\)%-berok\\1%g"`' + if test svr4 != "$with_aix_soname"; then + # This is similar to how AIX traditionally builds its shared + # libraries. Need -bnortl late, we may have -brtl in LDFLAGS. + archive_expsym_cmds_CXX="$archive_expsym_cmds_CXX"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' + fi + if test aix != "$with_aix_soname"; then + archive_expsym_cmds_CXX="$archive_expsym_cmds_CXX"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' + else + # used by -dlpreopen to get the symbols + archive_expsym_cmds_CXX="$archive_expsym_cmds_CXX"'~$MV $output_objdir/$realname.d/$soname $output_objdir' + fi + archive_expsym_cmds_CXX="$archive_expsym_cmds_CXX"'~$RM -r $output_objdir/$realname.d' + fi + fi + ;; + + beos*) + if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then + allow_undefined_flag_CXX=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + archive_cmds_CXX='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + else + ld_shlibs_CXX=no + fi + ;; + + chorus*) + case $cc_basename in + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + + cygwin* | mingw* | pw32* | cegcc*) + case $GXX,$cc_basename in + ,cl* | no,cl* | ,icl* | no,icl*) + # Native MSVC or ICC + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + hardcode_libdir_flag_spec_CXX=' ' + allow_undefined_flag_CXX=unsupported + always_export_symbols_CXX=yes + file_list_spec_CXX='@' + # Tell ltmain to make .lib files, not .a files. + libext=lib + # Tell ltmain to make .dll files, not .so files. + shrext_cmds=.dll + # FIXME: Setting linknames here is a bad hack. + archive_cmds_CXX='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' + archive_expsym_cmds_CXX='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then + cp "$export_symbols" "$output_objdir/$soname.def"; + echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; + else + $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; + fi~ + $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ + linknames=' + # The linker will not automatically build a static lib if we build a DLL. + # _LT_TAGVAR(old_archive_from_new_cmds, CXX)='true' + enable_shared_with_static_runtimes_CXX=yes + # Don't use ranlib + old_postinstall_cmds_CXX='chmod 644 $oldlib' + postlink_cmds_CXX='lt_outputfile="@OUTPUT@"~ + lt_tool_outputfile="@TOOL_OUTPUT@"~ + case $lt_outputfile in + *.exe|*.EXE) ;; + *) + lt_outputfile=$lt_outputfile.exe + lt_tool_outputfile=$lt_tool_outputfile.exe + ;; + esac~ + func_to_tool_file "$lt_outputfile"~ + if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then + $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; + $RM "$lt_outputfile.manifest"; + fi' + ;; + *) + # g++ + # _LT_TAGVAR(hardcode_libdir_flag_spec, CXX) is actually meaningless, + # as there is no search path for DLLs. + hardcode_libdir_flag_spec_CXX='-L$libdir' + export_dynamic_flag_spec_CXX='$wl--export-all-symbols' + allow_undefined_flag_CXX=unsupported + always_export_symbols_CXX=no + enable_shared_with_static_runtimes_CXX=yes + + if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then + archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + # If the export-symbols file already is a .def file, use it as + # is; otherwise, prepend EXPORTS... + archive_expsym_cmds_CXX='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' + else + ld_shlibs_CXX=no + fi + ;; + esac + ;; + darwin* | rhapsody*) + + + archive_cmds_need_lc_CXX=no + hardcode_direct_CXX=no + hardcode_automatic_CXX=yes + hardcode_shlibpath_var_CXX=unsupported + if test yes = "$lt_cv_ld_force_load"; then + whole_archive_flag_spec_CXX='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' + + else + whole_archive_flag_spec_CXX='' + fi + link_all_deplibs_CXX=yes + allow_undefined_flag_CXX=$_lt_dar_allow_undefined + case $cc_basename in + ifort*|nagfor*) _lt_dar_can_shared=yes ;; + *) _lt_dar_can_shared=$GCC ;; + esac + if test yes = "$_lt_dar_can_shared"; then + output_verbose_link_cmd=func_echo_all + archive_cmds_CXX="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil" + module_cmds_CXX="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil" + archive_expsym_cmds_CXX="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil" + module_expsym_cmds_CXX="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil" + if test yes != "$lt_cv_apple_cc_single_mod"; then + archive_cmds_CXX="\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dsymutil" + archive_expsym_cmds_CXX="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dar_export_syms$_lt_dsymutil" + fi + + else + ld_shlibs_CXX=no + fi + + ;; + + os2*) + hardcode_libdir_flag_spec_CXX='-L$libdir' + hardcode_minus_L_CXX=yes + allow_undefined_flag_CXX=unsupported + shrext_cmds=.dll + archive_cmds_CXX='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + archive_expsym_cmds_CXX='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ + $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ + $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ + $ECHO EXPORTS >> $output_objdir/$libname.def~ + prefix_cmds="$SED"~ + if test EXPORTS = "`$SED 1q $export_symbols`"; then + prefix_cmds="$prefix_cmds -e 1d"; + fi~ + prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ + cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ + $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ + emximp -o $lib $output_objdir/$libname.def' + old_archive_From_new_cmds_CXX='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' + enable_shared_with_static_runtimes_CXX=yes + file_list_spec_CXX='@' + ;; + + dgux*) + case $cc_basename in + ec++*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + ghcx*) + # Green Hills C++ Compiler + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + + freebsd2.*) + # C++ shared libraries reported to be fairly broken before + # switch to ELF + ld_shlibs_CXX=no + ;; + + freebsd-elf*) + archive_cmds_need_lc_CXX=no + ;; + + freebsd* | dragonfly*) + # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF + # conventions + ld_shlibs_CXX=yes + ;; + + haiku*) + archive_cmds_CXX='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + link_all_deplibs_CXX=yes + ;; + + hpux9*) + hardcode_libdir_flag_spec_CXX='$wl+b $wl$libdir' + hardcode_libdir_separator_CXX=: + export_dynamic_flag_spec_CXX='$wl-E' + hardcode_direct_CXX=yes + hardcode_minus_L_CXX=yes # Not in the search PATH, + # but as the default + # location of the library. + + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + aCC*) + archive_cmds_CXX='$RM $output_objdir/$soname~$CC -b $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' + ;; + *) + if test yes = "$GXX"; then + archive_cmds_CXX='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' + else + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + fi + ;; + esac + ;; + + hpux10*|hpux11*) + if test no = "$with_gnu_ld"; then + hardcode_libdir_flag_spec_CXX='$wl+b $wl$libdir' + hardcode_libdir_separator_CXX=: + + case $host_cpu in + hppa*64*|ia64*) + ;; + *) + export_dynamic_flag_spec_CXX='$wl-E' + ;; + esac + fi + case $host_cpu in + hppa*64*|ia64*) + hardcode_direct_CXX=no + hardcode_shlibpath_var_CXX=no + ;; + *) + hardcode_direct_CXX=yes + hardcode_direct_absolute_CXX=yes + hardcode_minus_L_CXX=yes # Not in the search PATH, + # but as the default + # location of the library. + ;; + esac + + case $cc_basename in + CC*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + aCC*) + case $host_cpu in + hppa*64*) + archive_cmds_CXX='$CC -b $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + ia64*) + archive_cmds_CXX='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + *) + archive_cmds_CXX='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' + ;; + *) + if test yes = "$GXX"; then + if test no = "$with_gnu_ld"; then + case $host_cpu in + hppa*64*) + archive_cmds_CXX='$CC -shared -nostdlib -fPIC $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + ia64*) + archive_cmds_CXX='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + *) + archive_cmds_CXX='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + fi + else + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + fi + ;; + esac + ;; + + interix[3-9]*) + hardcode_direct_CXX=no + hardcode_shlibpath_var_CXX=no + hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir' + export_dynamic_flag_spec_CXX='$wl-E' + # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. + # Instead, shared libraries are loaded at an image base (0x10000000 by + # default) and relocated if they conflict, which is a slow very memory + # consuming and fragmenting process. To avoid this, we pick a random, + # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link + # time. Moving up from 0x10000000 also allows more sbrk(2) space. + archive_cmds_CXX='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + archive_expsym_cmds_CXX='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' + ;; + irix5* | irix6*) + case $cc_basename in + CC*) + # SGI C++ + archive_cmds_CXX='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' + + # Archives containing C++ object files must be created using + # "CC -ar", where "CC" is the IRIX C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + old_archive_cmds_CXX='$CC -ar -WR,-u -o $oldlib $oldobjs' + ;; + *) + if test yes = "$GXX"; then + if test no = "$with_gnu_ld"; then + archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' + else + archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` -o $lib' + fi + fi + link_all_deplibs_CXX=yes + ;; + esac + hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir' + hardcode_libdir_separator_CXX=: + inherit_rpath_CXX=yes + ;; + + linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + archive_expsym_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib $wl-retain-symbols-file,$export_symbols; mv \$templib $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' + + hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir' + export_dynamic_flag_spec_CXX='$wl--export-dynamic' + + # Archives containing C++ object files must be created using + # "CC -Bstatic", where "CC" is the KAI C++ compiler. + old_archive_cmds_CXX='$CC -Bstatic -o $oldlib $oldobjs' + ;; + icpc* | ecpc* ) + # Intel C++ + with_gnu_ld=yes + # version 8.0 and above of icpc choke on multiply defined symbols + # if we add $predep_objects and $postdep_objects, however 7.1 and + # earlier do not add the objects themselves. + case `$CC -V 2>&1` in + *"Version 7."*) + archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + ;; + *) # Version 8.0 or newer + tmp_idyn= + case $host_cpu in + ia64*) tmp_idyn=' -i_dynamic';; + esac + archive_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + ;; + esac + archive_cmds_need_lc_CXX=no + hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir' + export_dynamic_flag_spec_CXX='$wl--export-dynamic' + whole_archive_flag_spec_CXX='$wl--whole-archive$convenience $wl--no-whole-archive' + ;; + pgCC* | pgcpp*) + # Portland Group C++ compiler + case `$CC -V` in + *pgCC\ [1-5].* | *pgcpp\ [1-5].*) + prelink_cmds_CXX='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~ + compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"' + old_archive_cmds_CXX='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~ + $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~ + $RANLIB $oldlib' + archive_cmds_CXX='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ + $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='tpldir=Template.dir~ + rm -rf $tpldir~ + $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ + $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + ;; + *) # Version 6 and above use weak symbols + archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' + ;; + esac + + hardcode_libdir_flag_spec_CXX='$wl--rpath $wl$libdir' + export_dynamic_flag_spec_CXX='$wl--export-dynamic' + whole_archive_flag_spec_CXX='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' + ;; + cxx*) + # Compaq C++ + archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' + archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib $wl-retain-symbols-file $wl$export_symbols' + + runpath_var=LD_RUN_PATH + hardcode_libdir_flag_spec_CXX='-rpath $libdir' + hardcode_libdir_separator_CXX=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "X$list" | $Xsed' + ;; + xl* | mpixl* | bgxl*) + # IBM XL 8.0 on PPC, with GNU ld + hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir' + export_dynamic_flag_spec_CXX='$wl--export-dynamic' + archive_cmds_CXX='$CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' + if test yes = "$supports_anon_versioning"; then + archive_expsym_cmds_CXX='echo "{ global:" > $output_objdir/$libname.ver~ + cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ + echo "local: *; };" >> $output_objdir/$libname.ver~ + $CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' + fi + ;; + *) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) + # Sun C++ 5.9 + no_undefined_flag_CXX=' -zdefs' + archive_cmds_CXX='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + archive_expsym_cmds_CXX='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file $wl$export_symbols' + hardcode_libdir_flag_spec_CXX='-R$libdir' + whole_archive_flag_spec_CXX='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' + compiler_needs_object_CXX=yes + + # Not sure whether something based on + # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 + # would be better. + output_verbose_link_cmd='func_echo_all' + + # Archives containing C++ object files must be created using + # "CC -xar", where "CC" is the Sun C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + old_archive_cmds_CXX='$CC -xar -o $oldlib $oldobjs' + ;; + esac + ;; + esac + ;; + + lynxos*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + + m88k*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + + mvs*) + case $cc_basename in + cxx*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + archive_cmds_CXX='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' + wlarc= + hardcode_libdir_flag_spec_CXX='-R$libdir' + hardcode_direct_CXX=yes + hardcode_shlibpath_var_CXX=no + fi + # Workaround some broken pre-1.5 toolchains + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' + ;; + + *nto* | *qnx*) + ld_shlibs_CXX=yes + ;; + + openbsd* | bitrig*) + if test -f /usr/libexec/ld.so; then + hardcode_direct_CXX=yes + hardcode_shlibpath_var_CXX=no + hardcode_direct_absolute_CXX=yes + archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' + hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir' + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`"; then + archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file,$export_symbols -o $lib' + export_dynamic_flag_spec_CXX='$wl-E' + whole_archive_flag_spec_CXX=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' + fi + output_verbose_link_cmd=func_echo_all + else + ld_shlibs_CXX=no + fi + ;; + + osf3* | osf4* | osf5*) + case $cc_basename in + KCC*) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + + hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir' + hardcode_libdir_separator_CXX=: + + # Archives containing C++ object files must be created using + # the KAI C++ compiler. + case $host in + osf3*) old_archive_cmds_CXX='$CC -Bstatic -o $oldlib $oldobjs' ;; + *) old_archive_cmds_CXX='$CC -o $oldlib $oldobjs' ;; + esac + ;; + RCC*) + # Rational C++ 2.4.1 + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + cxx*) + case $host in + osf3*) + allow_undefined_flag_CXX=' $wl-expect_unresolved $wl\*' + archive_cmds_CXX='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $soname `test -n "$verstring" && func_echo_all "$wl-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' + hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir' + ;; + *) + allow_undefined_flag_CXX=' -expect_unresolved \*' + archive_cmds_CXX='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' + archive_expsym_cmds_CXX='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ + echo "-hidden">> $lib.exp~ + $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname $wl-input $wl$lib.exp `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~ + $RM $lib.exp' + hardcode_libdir_flag_spec_CXX='-rpath $libdir' + ;; + esac + + hardcode_libdir_separator_CXX=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' + ;; + *) + if test yes,no = "$GXX,$with_gnu_ld"; then + allow_undefined_flag_CXX=' $wl-expect_unresolved $wl\*' + case $host in + osf3*) + archive_cmds_CXX='$CC -shared -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' + ;; + *) + archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' + ;; + esac + + hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir' + hardcode_libdir_separator_CXX=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' + + else + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + fi + ;; + esac + ;; + + psos*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + + sunos4*) + case $cc_basename in + CC*) + # Sun C++ 4.x + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + lcc*) + # Lucid + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + + solaris*) + case $cc_basename in + CC* | sunCC*) + # Sun C++ 4.2, 5.x and Centerline C++ + archive_cmds_need_lc_CXX=yes + no_undefined_flag_CXX=' -zdefs' + archive_cmds_CXX='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -G$allow_undefined_flag $wl-M $wl$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' + + hardcode_libdir_flag_spec_CXX='-R$libdir' + hardcode_shlibpath_var_CXX=no + case $host_os in + solaris2.[0-5] | solaris2.[0-5].*) ;; + *) + # The compiler driver will combine and reorder linker options, + # but understands '-z linker_flag'. + # Supported since Solaris 2.6 (maybe 2.5.1?) + whole_archive_flag_spec_CXX='-z allextract$convenience -z defaultextract' + ;; + esac + link_all_deplibs_CXX=yes + + output_verbose_link_cmd='func_echo_all' + + # Archives containing C++ object files must be created using + # "CC -xar", where "CC" is the Sun C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + old_archive_cmds_CXX='$CC -xar -o $oldlib $oldobjs' + ;; + gcx*) + # Green Hills C++ Compiler + archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' + + # The C++ compiler must be used to create the archive. + old_archive_cmds_CXX='$CC $LDFLAGS -archive -o $oldlib $oldobjs' + ;; + *) + # GNU C++ compiler with Solaris linker + if test yes,no = "$GXX,$with_gnu_ld"; then + no_undefined_flag_CXX=' $wl-z ${wl}defs' + if $CC --version | $GREP -v '^2\.7' > /dev/null; then + archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' + archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -shared $pic_flag -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' + else + # g++ 2.7 appears to require '-G' NOT '-shared' on this + # platform. + archive_cmds_CXX='$CC -G -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' + archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ + $CC -G -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' + fi + + hardcode_libdir_flag_spec_CXX='$wl-R $wl$libdir' + case $host_os in + solaris2.[0-5] | solaris2.[0-5].*) ;; + *) + whole_archive_flag_spec_CXX='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' + ;; + esac + fi + ;; + esac + ;; + + sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) + no_undefined_flag_CXX='$wl-z,text' + archive_cmds_need_lc_CXX=no + hardcode_shlibpath_var_CXX=no + runpath_var='LD_RUN_PATH' + + case $cc_basename in + CC*) + archive_cmds_CXX='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds_CXX='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + archive_cmds_CXX='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds_CXX='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + ;; + + sysv5* | sco3.2v5* | sco5v6*) + # Note: We CANNOT use -z defs as we might desire, because we do not + # link with -lc, and that would cause any symbols used from libc to + # always be unresolved, which means just about no library would + # ever link correctly. If we're not using GNU ld we use -z text + # though, which does catch some bad symbols but isn't as heavy-handed + # as -z defs. + no_undefined_flag_CXX='$wl-z,text' + allow_undefined_flag_CXX='$wl-z,nodefs' + archive_cmds_need_lc_CXX=no + hardcode_shlibpath_var_CXX=no + hardcode_libdir_flag_spec_CXX='$wl-R,$libdir' + hardcode_libdir_separator_CXX=':' + link_all_deplibs_CXX=yes + export_dynamic_flag_spec_CXX='$wl-Bexport' + runpath_var='LD_RUN_PATH' + + case $cc_basename in + CC*) + archive_cmds_CXX='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds_CXX='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + old_archive_cmds_CXX='$CC -Tprelink_objects $oldobjs~ + '"$old_archive_cmds_CXX" + reload_cmds_CXX='$CC -Tprelink_objects $reload_objs~ + '"$reload_cmds_CXX" + ;; + *) + archive_cmds_CXX='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + archive_expsym_cmds_CXX='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + ;; + + tandem*) + case $cc_basename in + NCC*) + # NonStop-UX NCC 3.20 + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + ;; + + vxworks*) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + + *) + # FIXME: insert proper C++ library support + ld_shlibs_CXX=no + ;; + esac + + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs_CXX" >&5 +$as_echo "$ld_shlibs_CXX" >&6; } + test no = "$ld_shlibs_CXX" && can_build_shared=no + + GCC_CXX=$GXX + LD_CXX=$LD + + ## CAVEAT EMPTOR: + ## There is no encapsulation within the following macros, do not change + ## the running order or otherwise move them around unless you know exactly + ## what you are doing... + # Dependencies to place before and after the object being linked: +predep_objects_CXX= +postdep_objects_CXX= +predeps_CXX= +postdeps_CXX= +compiler_lib_search_path_CXX= + +cat > conftest.$ac_ext <<_LT_EOF +class Foo +{ +public: + Foo (void) { a = 0; } +private: + int a; +}; +_LT_EOF + + +_lt_libdeps_save_CFLAGS=$CFLAGS +case "$CC $CFLAGS " in #( +*\ -flto*\ *) CFLAGS="$CFLAGS -fno-lto" ;; +*\ -fwhopr*\ *) CFLAGS="$CFLAGS -fno-whopr" ;; +*\ -fuse-linker-plugin*\ *) CFLAGS="$CFLAGS -fno-use-linker-plugin" ;; +esac + +if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; }; then + # Parse the compiler output and extract the necessary + # objects, libraries and library flags. + + # Sentinel used to keep track of whether or not we are before + # the conftest object file. + pre_test_object_deps_done=no + + for p in `eval "$output_verbose_link_cmd"`; do + case $prev$p in + + -L* | -R* | -l*) + # Some compilers place space between "-{L,R}" and the path. + # Remove the space. + if test x-L = "$p" || + test x-R = "$p"; then + prev=$p + continue + fi + + # Expand the sysroot to ease extracting the directories later. + if test -z "$prev"; then + case $p in + -L*) func_stripname_cnf '-L' '' "$p"; prev=-L; p=$func_stripname_result ;; + -R*) func_stripname_cnf '-R' '' "$p"; prev=-R; p=$func_stripname_result ;; + -l*) func_stripname_cnf '-l' '' "$p"; prev=-l; p=$func_stripname_result ;; + esac + fi + case $p in + =*) func_stripname_cnf '=' '' "$p"; p=$lt_sysroot$func_stripname_result ;; + esac + if test no = "$pre_test_object_deps_done"; then + case $prev in + -L | -R) + # Internal compiler library paths should come after those + # provided the user. The postdeps already come after the + # user supplied libs so there is no need to process them. + if test -z "$compiler_lib_search_path_CXX"; then + compiler_lib_search_path_CXX=$prev$p + else + compiler_lib_search_path_CXX="${compiler_lib_search_path_CXX} $prev$p" + fi + ;; + # The "-l" case would never come before the object being + # linked, so don't bother handling this case. + esac + else + if test -z "$postdeps_CXX"; then + postdeps_CXX=$prev$p + else + postdeps_CXX="${postdeps_CXX} $prev$p" + fi + fi + prev= + ;; + + *.lto.$objext) ;; # Ignore GCC LTO objects + *.$objext) + # This assumes that the test object file only shows up + # once in the compiler output. + if test "$p" = "conftest.$objext"; then + pre_test_object_deps_done=yes + continue + fi + + if test no = "$pre_test_object_deps_done"; then + if test -z "$predep_objects_CXX"; then + predep_objects_CXX=$p + else + predep_objects_CXX="$predep_objects_CXX $p" + fi + else + if test -z "$postdep_objects_CXX"; then + postdep_objects_CXX=$p + else + postdep_objects_CXX="$postdep_objects_CXX $p" + fi + fi + ;; + + *) ;; # Ignore the rest. + + esac + done + + # Clean up. + rm -f a.out a.exe +else + echo "libtool.m4: error: problem compiling CXX test program" +fi + +$RM -f confest.$objext +CFLAGS=$_lt_libdeps_save_CFLAGS + +# PORTME: override above test on systems where it is broken +case $host_os in +interix[3-9]*) + # Interix 3.5 installs completely hosed .la files for C++, so rather than + # hack all around it, let's just trust "g++" to DTRT. + predep_objects_CXX= + postdep_objects_CXX= + postdeps_CXX= + ;; +esac + + +case " $postdeps_CXX " in +*" -lc "*) archive_cmds_need_lc_CXX=no ;; +esac + compiler_lib_search_dirs_CXX= +if test -n "${compiler_lib_search_path_CXX}"; then + compiler_lib_search_dirs_CXX=`echo " ${compiler_lib_search_path_CXX}" | $SED -e 's! -L! !g' -e 's!^ !!'` +fi + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + lt_prog_compiler_wl_CXX= +lt_prog_compiler_pic_CXX= +lt_prog_compiler_static_CXX= + + + # C++ specific cases for pic, static, wl, etc. + if test yes = "$GXX"; then + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_static_CXX='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test ia64 = "$host_cpu"; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static_CXX='-Bstatic' + fi + lt_prog_compiler_pic_CXX='-fPIC' + ;; + + amigaos*) + case $host_cpu in + powerpc) + # see comment about AmigaOS4 .so support + lt_prog_compiler_pic_CXX='-fPIC' + ;; + m68k) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the '-m68020' flag to GCC prevents building anything better, + # like '-m68040'. + lt_prog_compiler_pic_CXX='-m68020 -resident32 -malways-restore-a4' + ;; + esac + ;; + + beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + mingw* | cygwin* | os2* | pw32* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + # Although the cygwin gcc ignores -fPIC, still need this for old-style + # (--disable-auto-import) libraries + lt_prog_compiler_pic_CXX='-DDLL_EXPORT' + case $host_os in + os2*) + lt_prog_compiler_static_CXX='$wl-static' + ;; + esac + ;; + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + lt_prog_compiler_pic_CXX='-fno-common' + ;; + *djgpp*) + # DJGPP does not support shared libraries at all + lt_prog_compiler_pic_CXX= + ;; + haiku*) + # PIC is the default for Haiku. + # The "-static" flag exists, but is broken. + lt_prog_compiler_static_CXX= + ;; + interix[3-9]*) + # Interix 3.x gcc -fpic/-fPIC options generate broken code. + # Instead, we relocate shared libraries at runtime. + ;; + sysv4*MP*) + if test -d /usr/nec; then + lt_prog_compiler_pic_CXX=-Kconform_pic + fi + ;; + hpux*) + # PIC is the default for 64-bit PA HP-UX, but not for 32-bit + # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag + # sets the default TLS model and affects inlining. + case $host_cpu in + hppa*64*) + ;; + *) + lt_prog_compiler_pic_CXX='-fPIC' + ;; + esac + ;; + *qnx* | *nto*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + lt_prog_compiler_pic_CXX='-fPIC -shared' + ;; + *) + lt_prog_compiler_pic_CXX='-fPIC' + ;; + esac + else + case $host_os in + aix[4-9]*) + # All AIX code is PIC. + if test ia64 = "$host_cpu"; then + # AIX 5 now supports IA64 processor + lt_prog_compiler_static_CXX='-Bstatic' + else + lt_prog_compiler_static_CXX='-bnso -bI:/lib/syscalls.exp' + fi + ;; + chorus*) + case $cc_basename in + cxch68*) + # Green Hills C++ Compiler + # _LT_TAGVAR(lt_prog_compiler_static, CXX)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" + ;; + esac + ;; + mingw* | cygwin* | os2* | pw32* | cegcc*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + lt_prog_compiler_pic_CXX='-DDLL_EXPORT' + ;; + dgux*) + case $cc_basename in + ec++*) + lt_prog_compiler_pic_CXX='-KPIC' + ;; + ghcx*) + # Green Hills C++ Compiler + lt_prog_compiler_pic_CXX='-pic' + ;; + *) + ;; + esac + ;; + freebsd* | dragonfly*) + # FreeBSD uses GNU C++ + ;; + hpux9* | hpux10* | hpux11*) + case $cc_basename in + CC*) + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_static_CXX='$wl-a ${wl}archive' + if test ia64 != "$host_cpu"; then + lt_prog_compiler_pic_CXX='+Z' + fi + ;; + aCC*) + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_static_CXX='$wl-a ${wl}archive' + case $host_cpu in + hppa*64*|ia64*) + # +Z the default + ;; + *) + lt_prog_compiler_pic_CXX='+Z' + ;; + esac + ;; + *) + ;; + esac + ;; + interix*) + # This is c89, which is MS Visual C++ (no shared libs) + # Anyone wants to do a port? + ;; + irix5* | irix6* | nonstopux*) + case $cc_basename in + CC*) + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_static_CXX='-non_shared' + # CC pic flag -KPIC is the default. + ;; + *) + ;; + esac + ;; + linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) + case $cc_basename in + KCC*) + # KAI C++ Compiler + lt_prog_compiler_wl_CXX='--backend -Wl,' + lt_prog_compiler_pic_CXX='-fPIC' + ;; + ecpc* ) + # old Intel C++ for x86_64, which still supported -KPIC. + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_pic_CXX='-KPIC' + lt_prog_compiler_static_CXX='-static' + ;; + icpc* ) + # Intel C++, used to be incompatible with GCC. + # ICC 10 doesn't accept -KPIC any more. + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_pic_CXX='-fPIC' + lt_prog_compiler_static_CXX='-static' + ;; + pgCC* | pgcpp*) + # Portland Group C++ compiler + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_pic_CXX='-fpic' + lt_prog_compiler_static_CXX='-Bstatic' + ;; + cxx*) + # Compaq C++ + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + lt_prog_compiler_pic_CXX= + lt_prog_compiler_static_CXX='-non_shared' + ;; + xlc* | xlC* | bgxl[cC]* | mpixl[cC]*) + # IBM XL 8.0, 9.0 on PPC and BlueGene + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_pic_CXX='-qpic' + lt_prog_compiler_static_CXX='-qstaticlink' + ;; + *) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) + # Sun C++ 5.9 + lt_prog_compiler_pic_CXX='-KPIC' + lt_prog_compiler_static_CXX='-Bstatic' + lt_prog_compiler_wl_CXX='-Qoption ld ' + ;; + esac + ;; + esac + ;; + lynxos*) + ;; + m88k*) + ;; + mvs*) + case $cc_basename in + cxx*) + lt_prog_compiler_pic_CXX='-W c,exportall' + ;; + *) + ;; + esac + ;; + netbsd*) + ;; + *qnx* | *nto*) + # QNX uses GNU C++, but need to define -shared option too, otherwise + # it will coredump. + lt_prog_compiler_pic_CXX='-fPIC -shared' + ;; + osf3* | osf4* | osf5*) + case $cc_basename in + KCC*) + lt_prog_compiler_wl_CXX='--backend -Wl,' + ;; + RCC*) + # Rational C++ 2.4.1 + lt_prog_compiler_pic_CXX='-pic' + ;; + cxx*) + # Digital/Compaq C++ + lt_prog_compiler_wl_CXX='-Wl,' + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + lt_prog_compiler_pic_CXX= + lt_prog_compiler_static_CXX='-non_shared' + ;; + *) + ;; + esac + ;; + psos*) + ;; + solaris*) + case $cc_basename in + CC* | sunCC*) + # Sun C++ 4.2, 5.x and Centerline C++ + lt_prog_compiler_pic_CXX='-KPIC' + lt_prog_compiler_static_CXX='-Bstatic' + lt_prog_compiler_wl_CXX='-Qoption ld ' + ;; + gcx*) + # Green Hills C++ Compiler + lt_prog_compiler_pic_CXX='-PIC' + ;; + *) + ;; + esac + ;; + sunos4*) + case $cc_basename in + CC*) + # Sun C++ 4.x + lt_prog_compiler_pic_CXX='-pic' + lt_prog_compiler_static_CXX='-Bstatic' + ;; + lcc*) + # Lucid + lt_prog_compiler_pic_CXX='-pic' + ;; + *) + ;; + esac + ;; + sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) + case $cc_basename in + CC*) + lt_prog_compiler_wl_CXX='-Wl,' + lt_prog_compiler_pic_CXX='-KPIC' + lt_prog_compiler_static_CXX='-Bstatic' + ;; + esac + ;; + tandem*) + case $cc_basename in + NCC*) + # NonStop-UX NCC 3.20 + lt_prog_compiler_pic_CXX='-KPIC' + ;; + *) + ;; + esac + ;; + vxworks*) + ;; + *) + lt_prog_compiler_can_build_shared_CXX=no + ;; + esac + fi + +case $host_os in + # For platforms that do not support PIC, -DPIC is meaningless: + *djgpp*) + lt_prog_compiler_pic_CXX= + ;; + *) + lt_prog_compiler_pic_CXX="$lt_prog_compiler_pic_CXX -DPIC" + ;; +esac + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $compiler option to produce PIC" >&5 +$as_echo_n "checking for $compiler option to produce PIC... " >&6; } +if ${lt_cv_prog_compiler_pic_CXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_pic_CXX=$lt_prog_compiler_pic_CXX +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_CXX" >&5 +$as_echo "$lt_cv_prog_compiler_pic_CXX" >&6; } +lt_prog_compiler_pic_CXX=$lt_cv_prog_compiler_pic_CXX + +# +# Check to make sure the PIC flag actually works. +# +if test -n "$lt_prog_compiler_pic_CXX"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler PIC flag $lt_prog_compiler_pic_CXX works" >&5 +$as_echo_n "checking if $compiler PIC flag $lt_prog_compiler_pic_CXX works... " >&6; } +if ${lt_cv_prog_compiler_pic_works_CXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_pic_works_CXX=no + ac_outfile=conftest.$ac_objext + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="$lt_prog_compiler_pic_CXX -DPIC" ## exclude from sc_useless_quotes_in_assignment + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings other than the usual output. + $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then + lt_cv_prog_compiler_pic_works_CXX=yes + fi + fi + $RM conftest* + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_works_CXX" >&5 +$as_echo "$lt_cv_prog_compiler_pic_works_CXX" >&6; } + +if test yes = "$lt_cv_prog_compiler_pic_works_CXX"; then + case $lt_prog_compiler_pic_CXX in + "" | " "*) ;; + *) lt_prog_compiler_pic_CXX=" $lt_prog_compiler_pic_CXX" ;; + esac +else + lt_prog_compiler_pic_CXX= + lt_prog_compiler_can_build_shared_CXX=no +fi + +fi + + + + + +# +# Check to make sure the static flag actually works. +# +wl=$lt_prog_compiler_wl_CXX eval lt_tmp_static_flag=\"$lt_prog_compiler_static_CXX\" +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler static flag $lt_tmp_static_flag works" >&5 +$as_echo_n "checking if $compiler static flag $lt_tmp_static_flag works... " >&6; } +if ${lt_cv_prog_compiler_static_works_CXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_static_works_CXX=no + save_LDFLAGS=$LDFLAGS + LDFLAGS="$LDFLAGS $lt_tmp_static_flag" + echo "$lt_simple_link_test_code" > conftest.$ac_ext + if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then + # The linker can only warn and ignore the option if not recognized + # So say no if there are warnings + if test -s conftest.err; then + # Append any errors to the config.log. + cat conftest.err 1>&5 + $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp + $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 + if diff conftest.exp conftest.er2 >/dev/null; then + lt_cv_prog_compiler_static_works_CXX=yes + fi + else + lt_cv_prog_compiler_static_works_CXX=yes + fi + fi + $RM -r conftest* + LDFLAGS=$save_LDFLAGS + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_static_works_CXX" >&5 +$as_echo "$lt_cv_prog_compiler_static_works_CXX" >&6; } + +if test yes = "$lt_cv_prog_compiler_static_works_CXX"; then + : +else + lt_prog_compiler_static_CXX= +fi + + + + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 +$as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } +if ${lt_cv_prog_compiler_c_o_CXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_c_o_CXX=no + $RM -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp + $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then + lt_cv_prog_compiler_c_o_CXX=yes + fi + fi + chmod u+w . 2>&5 + $RM conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files + $RM out/* && rmdir out + cd .. + $RM -r conftest + $RM conftest* + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o_CXX" >&5 +$as_echo "$lt_cv_prog_compiler_c_o_CXX" >&6; } + + + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 +$as_echo_n "checking if $compiler supports -c -o file.$ac_objext... " >&6; } +if ${lt_cv_prog_compiler_c_o_CXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_prog_compiler_c_o_CXX=no + $RM -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ + -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp + $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 + if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then + lt_cv_prog_compiler_c_o_CXX=yes + fi + fi + chmod u+w . 2>&5 + $RM conftest* + # SGI C++ compiler will create directory out/ii_files/ for + # template instantiation + test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files + $RM out/* && rmdir out + cd .. + $RM -r conftest + $RM conftest* + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o_CXX" >&5 +$as_echo "$lt_cv_prog_compiler_c_o_CXX" >&6; } + + + + +hard_links=nottested +if test no = "$lt_cv_prog_compiler_c_o_CXX" && test no != "$need_locks"; then + # do not overwrite the value of need_locks provided by the user + { $as_echo "$as_me:${as_lineno-$LINENO}: checking if we can lock with hard links" >&5 +$as_echo_n "checking if we can lock with hard links... " >&6; } + hard_links=yes + $RM conftest* + ln conftest.a conftest.b 2>/dev/null && hard_links=no + touch conftest.a + ln conftest.a conftest.b 2>&5 || hard_links=no + ln conftest.a conftest.b 2>/dev/null && hard_links=no + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $hard_links" >&5 +$as_echo "$hard_links" >&6; } + if test no = "$hard_links"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&5 +$as_echo "$as_me: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&2;} + need_locks=warn + fi +else + need_locks=no +fi + + + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the $compiler linker ($LD) supports shared libraries" >&5 +$as_echo_n "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } + + export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + exclude_expsyms_CXX='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*' + case $host_os in + aix[4-9]*) + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to GNU nm, but means don't demangle to AIX nm. + # Without the "-l" option, or with the "-B" option, AIX nm treats + # weak defined symbols like other global defined symbols, whereas + # GNU nm marks them as "W". + # While the 'weak' keyword is ignored in the Export File, we need + # it in the Import File for the 'aix-soname' feature, so we have + # to replace the "-B" option with "-P" for AIX nm. + if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then + export_symbols_cmds_CXX='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' + else + export_symbols_cmds_CXX='`func_echo_all $NM | $SED -e '\''s/B\([^B]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "L") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' + fi + ;; + pw32*) + export_symbols_cmds_CXX=$ltdll_cmds + ;; + cygwin* | mingw* | cegcc*) + case $cc_basename in + cl* | icl*) + exclude_expsyms_CXX='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' + ;; + *) + export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1 DATA/;s/^.*[ ]__nm__\([^ ]*\)[ ][^ ]*/\1 DATA/;/^I[ ]/d;/^[AITW][ ]/s/.* //'\'' | sort | uniq > $export_symbols' + exclude_expsyms_CXX='[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname' + ;; + esac + ;; + *) + export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + ;; + esac + +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs_CXX" >&5 +$as_echo "$ld_shlibs_CXX" >&6; } +test no = "$ld_shlibs_CXX" && can_build_shared=no + +with_gnu_ld_CXX=$with_gnu_ld + + + + + + +# +# Do we need to explicitly link libc? +# +case "x$archive_cmds_need_lc_CXX" in +x|xyes) + # Assume -lc should be added + archive_cmds_need_lc_CXX=yes + + if test yes,yes = "$GCC,$enable_shared"; then + case $archive_cmds_CXX in + *'~'*) + # FIXME: we may have to deal with multi-command sequences. + ;; + '$CC '*) + # Test whether the compiler implicitly links with -lc since on some + # systems, -lgcc has to come before -lc. If gcc already passes -lc + # to ld, don't add -lc before -lgcc. + { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether -lc should be explicitly linked in" >&5 +$as_echo_n "checking whether -lc should be explicitly linked in... " >&6; } +if ${lt_cv_archive_cmds_need_lc_CXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + $RM conftest* + echo "$lt_simple_compile_test_code" > conftest.$ac_ext + + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 + (eval $ac_compile) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } 2>conftest.err; then + soname=conftest + lib=conftest + libobjs=conftest.$ac_objext + deplibs= + wl=$lt_prog_compiler_wl_CXX + pic_flag=$lt_prog_compiler_pic_CXX + compiler_flags=-v + linker_flags=-v + verstring= + output_objdir=. + libname=conftest + lt_save_allow_undefined_flag=$allow_undefined_flag_CXX + allow_undefined_flag_CXX= + if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$archive_cmds_CXX 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1\""; } >&5 + (eval $archive_cmds_CXX 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) 2>&5 + ac_status=$? + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } + then + lt_cv_archive_cmds_need_lc_CXX=no + else + lt_cv_archive_cmds_need_lc_CXX=yes + fi + allow_undefined_flag_CXX=$lt_save_allow_undefined_flag + else + cat conftest.err 1>&5 + fi + $RM conftest* + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_archive_cmds_need_lc_CXX" >&5 +$as_echo "$lt_cv_archive_cmds_need_lc_CXX" >&6; } + archive_cmds_need_lc_CXX=$lt_cv_archive_cmds_need_lc_CXX + ;; + esac + fi + ;; +esac + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking dynamic linker characteristics" >&5 +$as_echo_n "checking dynamic linker characteristics... " >&6; } + +library_names_spec= +libname_spec='lib$name' +soname_spec= +shrext_cmds=.so +postinstall_cmds= +postuninstall_cmds= +finish_cmds= +finish_eval= +shlibpath_var= +shlibpath_overrides_runpath=unknown +version_type=none +dynamic_linker="$host_os ld.so" +sys_lib_dlsearch_path_spec="/lib /usr/lib" +need_lib_prefix=unknown +hardcode_into_libs=no + +# when you set need_version to no, make sure it does not cause -set_version +# flags to be left without arguments +need_version=unknown + + + +case $host_os in +aix3*) + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$release$shared_ext$versuffix $libname.a' + shlibpath_var=LIBPATH + + # AIX 3 has no versioning support, so we append a major version to the name. + soname_spec='$libname$release$shared_ext$major' + ;; + +aix[4-9]*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + hardcode_into_libs=yes + if test ia64 = "$host_cpu"; then + # AIX 5 supports IA64 + library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext' + shlibpath_var=LD_LIBRARY_PATH + else + # With GCC up to 2.95.x, collect2 would create an import file + # for dependence libraries. The import file would start with + # the line '#! .'. This would cause the generated library to + # depend on '.', always an invalid library. This was fixed in + # development snapshots of GCC prior to 3.0. + case $host_os in + aix4 | aix4.[01] | aix4.[01].*) + if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' + echo ' yes ' + echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then + : + else + can_build_shared=no + fi + ;; + esac + # Using Import Files as archive members, it is possible to support + # filename-based versioning of shared library archives on AIX. While + # this would work for both with and without runtime linking, it will + # prevent static linking of such archives. So we do filename-based + # shared library versioning with .so extension only, which is used + # when both runtime linking and shared linking is enabled. + # Unfortunately, runtime linking may impact performance, so we do + # not want this to be the default eventually. Also, we use the + # versioned .so libs for executables only if there is the -brtl + # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. + # To allow for filename-based versioning support, we need to create + # libNAME.so.V as an archive file, containing: + # *) an Import File, referring to the versioned filename of the + # archive as well as the shared archive member, telling the + # bitwidth (32 or 64) of that shared object, and providing the + # list of exported symbols of that shared object, eventually + # decorated with the 'weak' keyword + # *) the shared object with the F_LOADONLY flag set, to really avoid + # it being seen by the linker. + # At run time we better use the real file rather than another symlink, + # but for link time we create the symlink libNAME.so -> libNAME.so.V + + case $with_aix_soname,$aix_use_runtimelinking in + # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + aix,yes) # traditional libtool + dynamic_linker='AIX unversionable lib.so' + # If using run time linking (on AIX 4.2 or later) use lib.so + # instead of lib.a to let people know that these are not + # typical AIX shared libraries. + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + ;; + aix,no) # traditional AIX only + dynamic_linker='AIX lib.a(lib.so.V)' + # We preserve .a as extension for shared libraries through AIX4.2 + # and later when we are not doing run time linking. + library_names_spec='$libname$release.a $libname.a' + soname_spec='$libname$release$shared_ext$major' + ;; + svr4,*) # full svr4 only + dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o)" + library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' + # We do not specify a path in Import Files, so LIBPATH fires. + shlibpath_overrides_runpath=yes + ;; + *,yes) # both, prefer svr4 + dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o), lib.a(lib.so.V)" + library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' + # unpreferred sharedlib libNAME.a needs extra handling + postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' + postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' + # We do not specify a path in Import Files, so LIBPATH fires. + shlibpath_overrides_runpath=yes + ;; + *,no) # both, prefer aix + dynamic_linker="AIX lib.a(lib.so.V), lib.so.V($shared_archive_member_spec.o)" + library_names_spec='$libname$release.a $libname.a' + soname_spec='$libname$release$shared_ext$major' + # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling + postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' + postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' + ;; + esac + shlibpath_var=LIBPATH + fi + ;; + +amigaos*) + case $host_cpu in + powerpc) + # Since July 2007 AmigaOS4 officially supports .so libraries. + # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + ;; + m68k) + library_names_spec='$libname.ixlibrary $libname.a' + # Create ${libname}_ixlibrary.a entries in /sys/libs. + finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' + ;; + esac + ;; + +beos*) + library_names_spec='$libname$shared_ext' + dynamic_linker="$host_os ld.so" + shlibpath_var=LIBRARY_PATH + ;; + +bsdi[45]*) + version_type=linux # correct to gnu/linux during the next big refactor + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + # the default ld.so.conf also contains /usr/contrib/lib and + # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow + # libtool to hard-code these into programs + ;; + +cygwin* | mingw* | pw32* | cegcc*) + version_type=windows + shrext_cmds=.dll + need_version=no + need_lib_prefix=no + + case $GCC,$cc_basename in + yes,*) + # gcc + library_names_spec='$libname.dll.a' + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \$file`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname~ + if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then + eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; + fi' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $RM \$dlpath' + shlibpath_overrides_runpath=yes + + case $host_os in + cygwin*) + # Cygwin DLLs use 'cyg' prefix rather than 'lib' + soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' + + ;; + mingw* | cegcc*) + # MinGW DLLs use traditional 'lib' prefix + soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' + ;; + pw32*) + # pw32 DLLs use 'pw' prefix rather than 'lib' + library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' + ;; + esac + dynamic_linker='Win32 ld.exe' + ;; + + *,cl* | *,icl*) + # Native MSVC or ICC + libname_spec='$name' + soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' + library_names_spec='$libname.dll.lib' + + case $build_os in + mingw*) + sys_lib_search_path_spec= + lt_save_ifs=$IFS + IFS=';' + for lt_path in $LIB + do + IFS=$lt_save_ifs + # Let DOS variable expansion print the short 8.3 style file name. + lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` + sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" + done + IFS=$lt_save_ifs + # Convert to MSYS style. + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | sed -e 's|\\\\|/|g' -e 's| \\([a-zA-Z]\\):| /\\1|g' -e 's|^ ||'` + ;; + cygwin*) + # Convert to unix form, then to dos form, then back to unix form + # but this time dos style (no spaces!) so that the unix form looks + # like /cygdrive/c/PROGRA~1:/cygdr... + sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` + sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` + sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + ;; + *) + sys_lib_search_path_spec=$LIB + if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then + # It is most probably a Windows format PATH. + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + # FIXME: find the short name or the path components, as spaces are + # common. (e.g. "Program Files" -> "PROGRA~1") + ;; + esac + + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \$file`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $RM \$dlpath' + shlibpath_overrides_runpath=yes + dynamic_linker='Win32 link.exe' + ;; + + *) + # Assume MSVC and ICC wrapper + library_names_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext $libname.lib' + dynamic_linker='Win32 ld.exe' + ;; + esac + # FIXME: first we should search . and the directory the executable is in + shlibpath_var=PATH + ;; + +darwin* | rhapsody*) + dynamic_linker="$host_os dyld" + version_type=darwin + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$major$shared_ext $libname$shared_ext' + soname_spec='$libname$release$major$shared_ext' + shlibpath_overrides_runpath=yes + shlibpath_var=DYLD_LIBRARY_PATH + shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' + + sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' + ;; + +dgux*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +freebsd* | dragonfly*) + # DragonFly does not have aout. When/if they implement a new + # versioning mechanism, adjust this. + if test -x /usr/bin/objformat; then + objformat=`/usr/bin/objformat` + else + case $host_os in + freebsd[23].*) objformat=aout ;; + *) objformat=elf ;; + esac + fi + version_type=freebsd-$objformat + case $version_type in + freebsd-elf*) + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + need_version=no + need_lib_prefix=no + ;; + freebsd-*) + library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' + need_version=yes + ;; + esac + shlibpath_var=LD_LIBRARY_PATH + case $host_os in + freebsd2.*) + shlibpath_overrides_runpath=yes + ;; + freebsd3.[01]* | freebsdelf3.[01]*) + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + freebsd3.[2-9]* | freebsdelf3.[2-9]* | \ + freebsd4.[0-5] | freebsdelf4.[0-5] | freebsd4.1.1 | freebsdelf4.1.1) + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + *) # from 4.6 on, and DragonFly + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + esac + ;; + +haiku*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + dynamic_linker="$host_os runtime_loader" + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LIBRARY_PATH + shlibpath_overrides_runpath=no + sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' + hardcode_into_libs=yes + ;; + +hpux9* | hpux10* | hpux11*) + # Give a soname corresponding to the major version so that dld.sl refuses to + # link against other versions. + version_type=sunos + need_lib_prefix=no + need_version=no + case $host_cpu in + ia64*) + shrext_cmds='.so' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.so" + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + if test 32 = "$HPUX_IA64_MODE"; then + sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" + sys_lib_dlsearch_path_spec=/usr/lib/hpux32 + else + sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" + sys_lib_dlsearch_path_spec=/usr/lib/hpux64 + fi + ;; + hppa*64*) + shrext_cmds='.sl' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.sl" + shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + *) + shrext_cmds='.sl' + dynamic_linker="$host_os dld.sl" + shlibpath_var=SHLIB_PATH + shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + ;; + esac + # HP-UX runs *really* slowly unless shared libraries are mode 555, ... + postinstall_cmds='chmod 555 $lib' + # or fails outright, so override atomically: + install_override_mode=555 + ;; + +interix[3-9]*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + +irix5* | irix6* | nonstopux*) + case $host_os in + nonstopux*) version_type=nonstopux ;; + *) + if test yes = "$lt_cv_prog_gnu_ld"; then + version_type=linux # correct to gnu/linux during the next big refactor + else + version_type=irix + fi ;; + esac + need_lib_prefix=no + need_version=no + soname_spec='$libname$release$shared_ext$major' + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext' + case $host_os in + irix5* | nonstopux*) + libsuff= shlibsuff= + ;; + *) + case $LD in # libtool.m4 will add one of these switches to LD + *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") + libsuff= shlibsuff= libmagic=32-bit;; + *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") + libsuff=32 shlibsuff=N32 libmagic=N32;; + *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") + libsuff=64 shlibsuff=64 libmagic=64-bit;; + *) libsuff= shlibsuff= libmagic=never-match;; + esac + ;; + esac + shlibpath_var=LD_LIBRARY${shlibsuff}_PATH + shlibpath_overrides_runpath=no + sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff" + sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff" + hardcode_into_libs=yes + ;; + +# No shared lib support for Linux oldld, aout, or coff. +linux*oldld* | linux*aout* | linux*coff*) + dynamic_linker=no + ;; + +linux*android*) + version_type=none # Android doesn't support versioned libraries. + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext' + soname_spec='$libname$release$shared_ext' + finish_cmds= + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + dynamic_linker='Android linker' + # Don't embed -rpath directories since the linker doesn't support them. + hardcode_libdir_flag_spec_CXX='-L$libdir' + ;; + +# This must be glibc/ELF. +linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + + # Some binutils ld are patched to set DT_RUNPATH + if ${lt_cv_shlibpath_overrides_runpath+:} false; then : + $as_echo_n "(cached) " >&6 +else + lt_cv_shlibpath_overrides_runpath=no + save_LDFLAGS=$LDFLAGS + save_libdir=$libdir + eval "libdir=/foo; wl=\"$lt_prog_compiler_wl_CXX\"; \ + LDFLAGS=\"\$LDFLAGS $hardcode_libdir_flag_spec_CXX\"" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_link "$LINENO"; then : + if ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null; then : + lt_cv_shlibpath_overrides_runpath=yes +fi +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + LDFLAGS=$save_LDFLAGS + libdir=$save_libdir + +fi + + shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath + + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + # Ideally, we could use ldconfig to report *all* directores which are + # searched for libraries, however this is still not possible. Aside from not + # being certain /sbin/ldconfig is available, command + # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, + # even though it is searched at run-time. Try to do the best guess by + # appending ld.so.conf contents (and includes) to the search path. + if test -f /etc/ld.so.conf; then + lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` + sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra" + fi + + # We used to test for /lib/ld.so.1 and disable shared libraries on + # powerpc, because MkLinux only supported shared libraries with the + # GNU dynamic linker. Since this was broken with cross compilers, + # most powerpc-linux boxes support dynamic linking these days and + # people can always --disable-shared, the test was removed, and we + # assume the GNU/Linux dynamic linker is in use. + dynamic_linker='GNU/Linux ld.so' + ;; + +netbsd*) + version_type=sunos + need_lib_prefix=no + need_version=no + if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then + library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + dynamic_linker='NetBSD (a.out) ld.so' + else + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + dynamic_linker='NetBSD ld.elf_so' + fi + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + +newsos6) + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +*nto* | *qnx*) + version_type=qnx + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='ldqnx.so' + ;; + +openbsd* | bitrig*) + version_type=sunos + sys_lib_dlsearch_path_spec=/usr/lib + need_lib_prefix=no + if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then + need_version=no + else + need_version=yes + fi + library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +os2*) + libname_spec='$name' + version_type=windows + shrext_cmds=.dll + need_version=no + need_lib_prefix=no + # OS/2 can only load a DLL with a base name of 8 characters or less. + soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; + v=$($ECHO $release$versuffix | tr -d .-); + n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); + $ECHO $n$v`$shared_ext' + library_names_spec='${libname}_dll.$libext' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=BEGINLIBPATH + sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + postinstall_cmds='base_file=`basename \$file`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname~ + chmod a+x \$dldir/$dlname~ + if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then + eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; + fi' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $RM \$dlpath' + ;; + +osf3* | osf4* | osf5*) + version_type=osf + need_lib_prefix=no + need_version=no + soname_spec='$libname$release$shared_ext$major' + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + +rdos*) + dynamic_linker=no + ;; + +solaris*) + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + # ldd complains unless libraries are executable + postinstall_cmds='chmod +x $lib' + ;; + +sunos4*) + version_type=sunos + library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' + finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + if test yes = "$with_gnu_ld"; then + need_lib_prefix=no + fi + need_version=yes + ;; + +sysv4 | sysv4.3*) + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + case $host_vendor in + sni) + shlibpath_overrides_runpath=no + need_lib_prefix=no + runpath_var=LD_RUN_PATH + ;; + siemens) + need_lib_prefix=no + ;; + motorola) + need_lib_prefix=no + need_version=no + shlibpath_overrides_runpath=no + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + ;; + esac + ;; + +sysv4*MP*) + if test -d /usr/nec; then + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext' + soname_spec='$libname$shared_ext.$major' + shlibpath_var=LD_LIBRARY_PATH + fi + ;; + +sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) + version_type=sco + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + if test yes = "$with_gnu_ld"; then + sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' + else + sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' + case $host_os in + sco3.2v5*) + sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" + ;; + esac + fi + sys_lib_dlsearch_path_spec='/usr/lib' + ;; + +tpf*) + # TPF is a cross-target only. Preferred cross-host = GNU/Linux. + version_type=linux # correct to gnu/linux during the next big refactor + need_lib_prefix=no + need_version=no + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + +uts4*) + version_type=linux # correct to gnu/linux during the next big refactor + library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' + soname_spec='$libname$release$shared_ext$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +*) + dynamic_linker=no + ;; +esac +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $dynamic_linker" >&5 +$as_echo "$dynamic_linker" >&6; } +test no = "$dynamic_linker" && can_build_shared=no + +variables_saved_for_relink="PATH $shlibpath_var $runpath_var" +if test yes = "$GCC"; then + variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" +fi + +if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then + sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec +fi + +if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then + sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec +fi + +# remember unaugmented sys_lib_dlsearch_path content for libtool script decls... +configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec + +# ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code +func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" + +# to be used as default LT_SYS_LIBRARY_PATH value in generated libtool +configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to hardcode library paths into programs" >&5 +$as_echo_n "checking how to hardcode library paths into programs... " >&6; } +hardcode_action_CXX= +if test -n "$hardcode_libdir_flag_spec_CXX" || + test -n "$runpath_var_CXX" || + test yes = "$hardcode_automatic_CXX"; then + + # We can hardcode non-existent directories. + if test no != "$hardcode_direct_CXX" && + # If the only mechanism to avoid hardcoding is shlibpath_var, we + # have to relink, otherwise we might link with an installed library + # when we should be linking with a yet-to-be-installed one + ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, CXX)" && + test no != "$hardcode_minus_L_CXX"; then + # Linking always hardcodes the temporary library directory. + hardcode_action_CXX=relink + else + # We can link without hardcoding, and we can hardcode nonexisting dirs. + hardcode_action_CXX=immediate + fi +else + # We cannot hardcode anything, or else we can only hardcode existing + # directories. + hardcode_action_CXX=unsupported +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $hardcode_action_CXX" >&5 +$as_echo "$hardcode_action_CXX" >&6; } + +if test relink = "$hardcode_action_CXX" || + test yes = "$inherit_rpath_CXX"; then + # Fast installation is not supported + enable_fast_install=no +elif test yes = "$shlibpath_overrides_runpath" || + test no = "$enable_shared"; then + # Fast installation is not necessary + enable_fast_install=needless +fi + + + + + + + + fi # test -n "$compiler" + + CC=$lt_save_CC + CFLAGS=$lt_save_CFLAGS + LDCXX=$LD + LD=$lt_save_LD + GCC=$lt_save_GCC + with_gnu_ld=$lt_save_with_gnu_ld + lt_cv_path_LDCXX=$lt_cv_path_LD + lt_cv_path_LD=$lt_save_path_LD + lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld + lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld +fi # test yes != "$_lt_caught_CXX_error" + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. +set dummy ${ac_tool_prefix}gcc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_CC="${ac_tool_prefix}gcc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_CC"; then + ac_ct_CC=$CC + # Extract the first word of "gcc", so it can be a program name with args. +set dummy gcc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_CC="gcc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 +$as_echo "$ac_ct_CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_CC" = x; then + CC="" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CC=$ac_ct_CC + fi +else + CC="$ac_cv_prog_CC" +fi + +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. +set dummy ${ac_tool_prefix}cc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_CC="${ac_tool_prefix}cc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + fi +fi +if test -z "$CC"; then + # Extract the first word of "cc", so it can be a program name with args. +set dummy cc; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else + ac_prog_rejected=no +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then + ac_prog_rejected=yes + continue + fi + ac_cv_prog_CC="cc" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +if test $ac_prog_rejected = yes; then + # We found a bogon in the path, so make sure we never use it. + set dummy $ac_cv_prog_CC + shift + if test $# != 0; then + # We chose a different compiler from the bogus one. + # However, it has the same basename, so the bogon will be chosen + # first if we set CC to just the basename; use the full file name. + shift + ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@" + fi +fi +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$CC"; then + if test -n "$ac_tool_prefix"; then + for ac_prog in cl.exe + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_CC="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +CC=$ac_cv_prog_CC +if test -n "$CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 +$as_echo "$CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$CC" && break + done +fi +if test -z "$CC"; then + ac_ct_CC=$CC + for ac_prog in cl.exe +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_CC+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_CC"; then + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_CC="$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_CC=$ac_cv_prog_ac_ct_CC +if test -n "$ac_ct_CC"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 +$as_echo "$ac_ct_CC" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_CC" && break +done + + if test "x$ac_ct_CC" = x; then + CC="" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + CC=$ac_ct_CC + fi +fi + +fi + + +test -z "$CC" && { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "no acceptable C compiler found in \$PATH +See \`config.log' for more details" "$LINENO" 5; } + +# Provide some information about the compiler. +$as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 +set X $ac_compile +ac_compiler=$2 +for ac_option in --version -v -V -qversion; do + { { ac_try="$ac_compiler $ac_option >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compiler $ac_option >&5") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + sed '10a\ +... rest of stderr output deleted ... + 10q' conftest.err >conftest.er1 + cat conftest.er1 >&5 + fi + rm -f conftest.er1 conftest.err + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } +done + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C compiler" >&5 +$as_echo_n "checking whether we are using the GNU C compiler... " >&6; } +if ${ac_cv_c_compiler_gnu+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_compiler_gnu=yes +else + ac_compiler_gnu=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_c_compiler_gnu=$ac_compiler_gnu + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_compiler_gnu" >&5 +$as_echo "$ac_cv_c_compiler_gnu" >&6; } +if test $ac_compiler_gnu = yes; then + GCC=yes +else + GCC= +fi +ac_test_CFLAGS=${CFLAGS+set} +ac_save_CFLAGS=$CFLAGS +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 +$as_echo_n "checking whether $CC accepts -g... " >&6; } +if ${ac_cv_prog_cc_g+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_save_c_werror_flag=$ac_c_werror_flag + ac_c_werror_flag=yes + ac_cv_prog_cc_g=no + CFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_prog_cc_g=yes +else + CFLAGS="" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + +else + ac_c_werror_flag=$ac_save_c_werror_flag + CFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_prog_cc_g=yes +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_c_werror_flag=$ac_save_c_werror_flag +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_g" >&5 +$as_echo "$ac_cv_prog_cc_g" >&6; } +if test "$ac_test_CFLAGS" = set; then + CFLAGS=$ac_save_CFLAGS +elif test $ac_cv_prog_cc_g = yes; then + if test "$GCC" = yes; then + CFLAGS="-g -O2" + else + CFLAGS="-g" + fi +else + if test "$GCC" = yes; then + CFLAGS="-O2" + else + CFLAGS= + fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $CC option to accept ISO C89" >&5 +$as_echo_n "checking for $CC option to accept ISO C89... " >&6; } +if ${ac_cv_prog_cc_c89+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_cv_prog_cc_c89=no +ac_save_CC=$CC +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +#include +struct stat; +/* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */ +struct buf { int x; }; +FILE * (*rcsopen) (struct buf *, struct stat *, int); +static char *e (p, i) + char **p; + int i; +{ + return p[i]; +} +static char *f (char * (*g) (char **, int), char **p, ...) +{ + char *s; + va_list v; + va_start (v,p); + s = g (p, va_arg (v,int)); + va_end (v); + return s; +} + +/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has + function prototypes and stuff, but not '\xHH' hex character constants. + These don't provoke an error unfortunately, instead are silently treated + as 'x'. The following induces an error, until -std is added to get + proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an + array size at least. It's necessary to write '\x00'==0 to get something + that's true only with -std. */ +int osf4_cc_array ['\x00' == 0 ? 1 : -1]; + +/* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters + inside strings and character constants. */ +#define FOO(x) 'x' +int xlc6_cc_array[FOO(a) == 'x' ? 1 : -1]; + +int test (int i, double x); +struct s1 {int (*f) (int a);}; +struct s2 {int (*f) (double a);}; +int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int); +int argc; +char **argv; +int +main () +{ +return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]; + ; + return 0; +} +_ACEOF +for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std \ + -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" +do + CC="$ac_save_CC $ac_arg" + if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_prog_cc_c89=$ac_arg +fi +rm -f core conftest.err conftest.$ac_objext + test "x$ac_cv_prog_cc_c89" != "xno" && break +done +rm -f conftest.$ac_ext +CC=$ac_save_CC + +fi +# AC_CACHE_VAL +case "x$ac_cv_prog_cc_c89" in + x) + { $as_echo "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 +$as_echo "none needed" >&6; } ;; + xno) + { $as_echo "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 +$as_echo "unsupported" >&6; } ;; + *) + CC="$CC $ac_cv_prog_cc_c89" + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c89" >&5 +$as_echo "$ac_cv_prog_cc_c89" >&6; } ;; +esac +if test "x$ac_cv_prog_cc_c89" != xno; then : + +fi + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC understands -c and -o together" >&5 +$as_echo_n "checking whether $CC understands -c and -o together... " >&6; } +if ${am_cv_prog_cc_c_o+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF + # Make sure it works both with $CC and with simple cc. + # Following AC_PROG_CC_C_O, we do the test twice because some + # compilers refuse to overwrite an existing .o file with -o, + # though they will create one. + am_cv_prog_cc_c_o=yes + for am_i in 1 2; do + if { echo "$as_me:$LINENO: $CC -c conftest.$ac_ext -o conftest2.$ac_objext" >&5 + ($CC -c conftest.$ac_ext -o conftest2.$ac_objext) >&5 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } \ + && test -f conftest2.$ac_objext; then + : OK + else + am_cv_prog_cc_c_o=no + break + fi + done + rm -f core conftest* + unset am_i +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_prog_cc_c_o" >&5 +$as_echo "$am_cv_prog_cc_c_o" >&6; } +if test "$am_cv_prog_cc_c_o" != yes; then + # Losing compiler, so override with the script. + # FIXME: It is wrong to rewrite CC. + # But if we don't then we get into trouble of one sort or another. + # A longer-term fix would be to have automake use am__CC in this case, + # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" + CC="$am_aux_dir/compile $CC" +fi +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + + +depcc="$CC" am_compiler_list= + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 +$as_echo_n "checking dependency style of $depcc... " >&6; } +if ${am_cv_CC_dependencies_compiler_type+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named 'D' -- because '-MD' means "put the output + # in D". + rm -rf conftest.dir + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_CC_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` + fi + am__universal=false + case " $depcc " in #( + *\ -arch\ *\ -arch\ *) am__universal=true ;; + esac + + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with + # Solaris 10 /bin/sh. + echo '/* dummy */' > sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + # We check with '-c' and '-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle '-M -o', and we need to detect this. Also, some Intel + # versions had trouble with output in subdirs. + am__obj=sub/conftest.${OBJEXT-o} + am__minus_obj="-o $am__obj" + case $depmode in + gcc) + # This depmode causes a compiler race in universal mode. + test "$am__universal" = false || continue + ;; + nosideeffect) + # After this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested. + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + msvc7 | msvc7msys | msvisualcpp | msvcmsys) + # This compiler won't grok '-c -o', but also, the minuso test has + # not run yet. These depmodes are late enough in the game, and + # so weak that their functioning should not be impacted. + am__obj=conftest.${OBJEXT-o} + am__minus_obj= + ;; + none) break ;; + esac + if depmode=$depmode \ + source=sub/conftest.c object=$am__obj \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep $am__obj sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_CC_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_CC_dependencies_compiler_type=none +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_CC_dependencies_compiler_type" >&5 +$as_echo "$am_cv_CC_dependencies_compiler_type" >&6; } +CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type + + if + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then + am__fastdepCC_TRUE= + am__fastdepCC_FALSE='#' +else + am__fastdepCC_TRUE='#' + am__fastdepCC_FALSE= +fi + + +ac_ext=mm +ac_cpp='$OBJCXXCPP $CPPFLAGS' +ac_compile='$OBJCXX -c $OBJCXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$OBJCXX -o conftest$ac_exeext $OBJCXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_objcxx_compiler_gnu +if test -n "$ac_tool_prefix"; then + for ac_prog in g++ objc++ objcxx c++ CXX + do + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. +set dummy $ac_tool_prefix$ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_OBJCXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$OBJCXX"; then + ac_cv_prog_OBJCXX="$OBJCXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_OBJCXX="$ac_tool_prefix$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +OBJCXX=$ac_cv_prog_OBJCXX +if test -n "$OBJCXX"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OBJCXX" >&5 +$as_echo "$OBJCXX" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$OBJCXX" && break + done +fi +if test -z "$OBJCXX"; then + ac_ct_OBJCXX=$OBJCXX + for ac_prog in g++ objc++ objcxx c++ CXX +do + # Extract the first word of "$ac_prog", so it can be a program name with args. +set dummy $ac_prog; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_OBJCXX+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_OBJCXX"; then + ac_cv_prog_ac_ct_OBJCXX="$ac_ct_OBJCXX" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_OBJCXX="$ac_prog" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_OBJCXX=$ac_cv_prog_ac_ct_OBJCXX +if test -n "$ac_ct_OBJCXX"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OBJCXX" >&5 +$as_echo "$ac_ct_OBJCXX" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + test -n "$ac_ct_OBJCXX" && break +done + + if test "x$ac_ct_OBJCXX" = x; then + OBJCXX="g++" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + OBJCXX=$ac_ct_OBJCXX + fi +fi + +# Provide some information about the compiler. +$as_echo "$as_me:${as_lineno-$LINENO}: checking for Objective C++ compiler version" >&5 +set X $ac_compile +ac_compiler=$2 +for ac_option in --version -v -V -qversion; do + { { ac_try="$ac_compiler $ac_option >&5" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" +$as_echo "$ac_try_echo"; } >&5 + (eval "$ac_compiler $ac_option >&5") 2>conftest.err + ac_status=$? + if test -s conftest.err; then + sed '10a\ +... rest of stderr output deleted ... + 10q' conftest.err >conftest.er1 + cat conftest.er1 >&5 + fi + rm -f conftest.er1 conftest.err + $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 + test $ac_status = 0; } +done + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU Objective C++ compiler" >&5 +$as_echo_n "checking whether we are using the GNU Objective C++ compiler... " >&6; } +if ${ac_cv_objcxx_compiler_gnu+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ +#ifndef __GNUC__ + choke me +#endif + + ; + return 0; +} +_ACEOF +if ac_fn_objcxx_try_compile "$LINENO"; then : + ac_compiler_gnu=yes +else + ac_compiler_gnu=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +ac_cv_objcxx_compiler_gnu=$ac_compiler_gnu + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objcxx_compiler_gnu" >&5 +$as_echo "$ac_cv_objcxx_compiler_gnu" >&6; } +if test $ac_compiler_gnu = yes; then + GOBJCXX=yes +else + GOBJCXX= +fi +ac_test_OBJCXXFLAGS=${OBJCXXFLAGS+set} +ac_save_OBJCXXFLAGS=$OBJCXXFLAGS +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $OBJCXX accepts -g" >&5 +$as_echo_n "checking whether $OBJCXX accepts -g... " >&6; } +if ${ac_cv_prog_objcxx_g+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_save_objcxx_werror_flag=$ac_objcxx_werror_flag + ac_objcxx_werror_flag=yes + ac_cv_prog_objcxx_g=no + OBJCXXFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_objcxx_try_compile "$LINENO"; then : + ac_cv_prog_objcxx_g=yes +else + OBJCXXFLAGS="" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_objcxx_try_compile "$LINENO"; then : + +else + ac_objcxx_werror_flag=$ac_save_objcxx_werror_flag + OBJCXXFLAGS="-g" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +int +main () +{ + + ; + return 0; +} +_ACEOF +if ac_fn_objcxx_try_compile "$LINENO"; then : + ac_cv_prog_objcxx_g=yes +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + ac_objcxx_werror_flag=$ac_save_objcx_werror_flag +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_objcxx_g" >&5 +$as_echo "$ac_cv_prog_objcxx_g" >&6; } +if test "$ac_test_OBJCXXFLAGS" = set; then + OBJCXXFLAGS=$ac_save_OBJCXXFLAGS +elif test $ac_cv_prog_objcxx_g = yes; then + if test "$GOBJCXX" = yes; then + OBJCXXFLAGS="-g -O2" + else + OBJCXXFLAGS="-g" + fi +else + if test "$GOBJCXX" = yes; then + OBJCXXFLAGS="-O2" + else + OBJCXXFLAGS= + fi +fi +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +depcc="$OBJCXX" am_compiler_list='gcc3 gcc' + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 +$as_echo_n "checking dependency style of $depcc... " >&6; } +if ${am_cv_OBJCXX_dependencies_compiler_type+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named 'D' -- because '-MD' means "put the output + # in D". + rm -rf conftest.dir + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_OBJCXX_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` + fi + am__universal=false + + + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with + # Solaris 10 /bin/sh. + echo '/* dummy */' > sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + # We check with '-c' and '-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle '-M -o', and we need to detect this. Also, some Intel + # versions had trouble with output in subdirs. + am__obj=sub/conftest.${OBJEXT-o} + am__minus_obj="-o $am__obj" + case $depmode in + gcc) + # This depmode causes a compiler race in universal mode. + test "$am__universal" = false || continue + ;; + nosideeffect) + # After this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested. + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + msvc7 | msvc7msys | msvisualcpp | msvcmsys) + # This compiler won't grok '-c -o', but also, the minuso test has + # not run yet. These depmodes are late enough in the game, and + # so weak that their functioning should not be impacted. + am__obj=conftest.${OBJEXT-o} + am__minus_obj= + ;; + none) break ;; + esac + if depmode=$depmode \ + source=sub/conftest.c object=$am__obj \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep $am__obj sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_OBJCXX_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_OBJCXX_dependencies_compiler_type=none +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_OBJCXX_dependencies_compiler_type" >&5 +$as_echo "$am_cv_OBJCXX_dependencies_compiler_type" >&6; } +OBJCXXDEPMODE=depmode=$am_cv_OBJCXX_dependencies_compiler_type + + if + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_OBJCXX_dependencies_compiler_type" = gcc3; then + am__fastdepOBJCXX_TRUE= + am__fastdepOBJCXX_FALSE='#' +else + am__fastdepOBJCXX_TRUE='#' + am__fastdepOBJCXX_FALSE= +fi + + +# By default we simply use the C compiler to build assembly code. + +test "${CCAS+set}" = set || CCAS=$CC +test "${CCASFLAGS+set}" = set || CCASFLAGS=$CFLAGS + + + +depcc="$CCAS" am_compiler_list= + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 +$as_echo_n "checking dependency style of $depcc... " >&6; } +if ${am_cv_CCAS_dependencies_compiler_type+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named 'D' -- because '-MD' means "put the output + # in D". + rm -rf conftest.dir + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_CCAS_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` + fi + am__universal=false + + + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with + # Solaris 10 /bin/sh. + echo '/* dummy */' > sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + # We check with '-c' and '-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle '-M -o', and we need to detect this. Also, some Intel + # versions had trouble with output in subdirs. + am__obj=sub/conftest.${OBJEXT-o} + am__minus_obj="-o $am__obj" + case $depmode in + gcc) + # This depmode causes a compiler race in universal mode. + test "$am__universal" = false || continue + ;; + nosideeffect) + # After this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested. + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + msvc7 | msvc7msys | msvisualcpp | msvcmsys) + # This compiler won't grok '-c -o', but also, the minuso test has + # not run yet. These depmodes are late enough in the game, and + # so weak that their functioning should not be impacted. + am__obj=conftest.${OBJEXT-o} + am__minus_obj= + ;; + none) break ;; + esac + if depmode=$depmode \ + source=sub/conftest.c object=$am__obj \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep $am__obj sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_CCAS_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_CCAS_dependencies_compiler_type=none +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_CCAS_dependencies_compiler_type" >&5 +$as_echo "$am_cv_CCAS_dependencies_compiler_type" >&6; } +CCASDEPMODE=depmode=$am_cv_CCAS_dependencies_compiler_type + + if + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_CCAS_dependencies_compiler_type" = gcc3; then + am__fastdepCCAS_TRUE= + am__fastdepCCAS_FALSE='#' +else + am__fastdepCCAS_TRUE='#' + am__fastdepCCAS_FALSE= +fi + + +if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. +set dummy ${ac_tool_prefix}ranlib; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_RANLIB+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$RANLIB"; then + ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +RANLIB=$ac_cv_prog_RANLIB +if test -n "$RANLIB"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $RANLIB" >&5 +$as_echo "$RANLIB" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + +fi +if test -z "$ac_cv_prog_RANLIB"; then + ac_ct_RANLIB=$RANLIB + # Extract the first word of "ranlib", so it can be a program name with args. +set dummy ranlib; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_prog_ac_ct_RANLIB+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test -n "$ac_ct_RANLIB"; then + ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test. +else +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_prog_ac_ct_RANLIB="ranlib" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + +fi +fi +ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB +if test -n "$ac_ct_RANLIB"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_RANLIB" >&5 +$as_echo "$ac_ct_RANLIB" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + if test "x$ac_ct_RANLIB" = x; then + RANLIB=":" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 +$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} +ac_tool_warned=yes ;; +esac + RANLIB=$ac_ct_RANLIB + fi +else + RANLIB="$ac_cv_prog_RANLIB" +fi + + +# Checks for libraries. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for SHA1 in -lcrypto" >&5 +$as_echo_n "checking for SHA1 in -lcrypto... " >&6; } +if ${ac_cv_lib_crypto_SHA1+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lcrypto $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char SHA1 (); +int +main () +{ +return SHA1 (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_crypto_SHA1=yes +else + ac_cv_lib_crypto_SHA1=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_SHA1" >&5 +$as_echo "$ac_cv_lib_crypto_SHA1" >&6; } +if test "x$ac_cv_lib_crypto_SHA1" = xyes; then : + cat >>confdefs.h <<_ACEOF +#define HAVE_LIBCRYPTO 1 +_ACEOF + + LIBS="-lcrypto $LIBS" + +else + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "libssl-dev is required but not found +See \`config.log' for more details" "$LINENO" 5; } +fi + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for floorf in -lm" >&5 +$as_echo_n "checking for floorf in -lm... " >&6; } +if ${ac_cv_lib_m_floorf+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lm $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char floorf (); +int +main () +{ +return floorf (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_m_floorf=yes +else + ac_cv_lib_m_floorf=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_m_floorf" >&5 +$as_echo "$ac_cv_lib_m_floorf" >&6; } +if test "x$ac_cv_lib_m_floorf" = xyes; then : + cat >>confdefs.h <<_ACEOF +#define HAVE_LIBM 1 +_ACEOF + + LIBS="-lm $LIBS" + +fi + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for opus_decoder_create in -lopus" >&5 +$as_echo_n "checking for opus_decoder_create in -lopus... " >&6; } +if ${ac_cv_lib_opus_opus_decoder_create+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lopus $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char opus_decoder_create (); +int +main () +{ +return opus_decoder_create (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_opus_opus_decoder_create=yes +else + ac_cv_lib_opus_opus_decoder_create=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_opus_opus_decoder_create" >&5 +$as_echo "$ac_cv_lib_opus_opus_decoder_create" >&6; } +if test "x$ac_cv_lib_opus_opus_decoder_create" = xyes; then : + cat >>confdefs.h <<_ACEOF +#define HAVE_LIBOPUS 1 +_ACEOF + + LIBS="-lopus $LIBS" + +else + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "libopus-dev is required but not found +See \`config.log' for more details" "$LINENO" 5; } +fi + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for pthread_create in -lpthread" >&5 +$as_echo_n "checking for pthread_create in -lpthread... " >&6; } +if ${ac_cv_lib_pthread_pthread_create+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lpthread $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char pthread_create (); +int +main () +{ +return pthread_create (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_pthread_pthread_create=yes +else + ac_cv_lib_pthread_pthread_create=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_pthread_pthread_create" >&5 +$as_echo "$ac_cv_lib_pthread_pthread_create" >&6; } +if test "x$ac_cv_lib_pthread_pthread_create" = xyes; then : + cat >>confdefs.h <<_ACEOF +#define HAVE_LIBPTHREAD 1 +_ACEOF + + LIBS="-lpthread $LIBS" + +fi + + + + +case $host_cpu in #( + i?86) : + cpu_x86=yes ;; #( + x86_64) : + cpu_x86=yes ;; #( + arm*) : + cpu_arm=yes ;; #( + *) : + $as_echo "!! WARNING: libtgvoip wasn't tested with your CPU architecture ($host_cpu)" + ;; +esac +case $host_cpu in #( + armv7*) : + cpu_armv7=yes + ;; #( + *) : + ;; +esac +$as_echo "Detected CPU: $host_cpu" + if test "x$cpu_x86" == xyes; then + TARGET_CPU_X86_TRUE= + TARGET_CPU_X86_FALSE='#' +else + TARGET_CPU_X86_TRUE='#' + TARGET_CPU_X86_FALSE= +fi + + if test "x$cpu_arm" == xyes; then + TARGET_CPU_ARM_TRUE= + TARGET_CPU_ARM_FALSE='#' +else + TARGET_CPU_ARM_TRUE='#' + TARGET_CPU_ARM_FALSE= +fi + + if test "x$cpu_armv7" == xyes; then + TARGET_CPU_ARMV7_TRUE= + TARGET_CPU_ARMV7_FALSE='#' +else + TARGET_CPU_ARMV7_TRUE='#' + TARGET_CPU_ARMV7_FALSE= +fi + +$as_echo "Detected OS: $host_os" + +case $host_os in #( + darwin*) : + os_osx=yes + ;; #( + *) : + ;; +esac + if test "x$os_osx" == xyes; then + TARGET_OS_OSX_TRUE= + TARGET_OS_OSX_FALSE='#' +else + TARGET_OS_OSX_TRUE='#' + TARGET_OS_OSX_FALSE= +fi + + +# Check whether --enable-audio-callback was given. +if test "${enable_audio_callback+set}" = set; then : + enableval=$enable_audio_callback; +else + enable_audio_callback=no +fi + + if test "x$enable_audio_callback" == xyes; then + ENABLE_AUDIO_CALLBACK_TRUE= + ENABLE_AUDIO_CALLBACK_FALSE='#' +else + ENABLE_AUDIO_CALLBACK_TRUE='#' + ENABLE_AUDIO_CALLBACK_FALSE= +fi + + +if test "x$os_osx" != xyes && test "x$enable_audio_callback" != xyes; then : + # Linux + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 +$as_echo_n "checking for dlopen in -ldl... " >&6; } +if ${ac_cv_lib_dl_dlopen+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-ldl $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char dlopen (); +int +main () +{ +return dlopen (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_dl_dlopen=yes +else + ac_cv_lib_dl_dlopen=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 +$as_echo "$ac_cv_lib_dl_dlopen" >&6; } +if test "x$ac_cv_lib_dl_dlopen" = xyes; then : + cat >>confdefs.h <<_ACEOF +#define HAVE_LIBDL 1 +_ACEOF + + LIBS="-ldl $LIBS" + +fi + + + +# Check whether --with-pulse was given. +if test "${with_pulse+set}" = set; then : + withval=$with_pulse; +else + with_pulse=yes +fi + + +# Check whether --with-alsa was given. +if test "${with_alsa+set}" = set; then : + withval=$with_alsa; +else + with_alsa=yes +fi + + + if test "x$with_pulse" == xno && test "x$with_alsa" == xno; then : + + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "You can only disable either ALSA or PulseAudio, not both +See \`config.log' for more details" "$LINENO" 5; }; + +fi + + if test "x$with_pulse" != xno; then : + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for pa_context_new in -lpulse" >&5 +$as_echo_n "checking for pa_context_new in -lpulse... " >&6; } +if ${ac_cv_lib_pulse_pa_context_new+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lpulse $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char pa_context_new (); +int +main () +{ +return pa_context_new (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_pulse_pa_context_new=yes +else + ac_cv_lib_pulse_pa_context_new=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_pulse_pa_context_new" >&5 +$as_echo "$ac_cv_lib_pulse_pa_context_new" >&6; } +if test "x$ac_cv_lib_pulse_pa_context_new" = xyes; then : + + $as_echo_n # what is the proper way to check for a library without linking it? + +else + + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "libpulse-dev is required during build, but you don't have it installed. Use --without-pulse to disable PulseAudio support. +See \`config.log' for more details" "$LINENO" 5; } + +fi + + +else + + +$as_echo "#define WITHOUT_PULSE 1" >>confdefs.h + + +fi + + if test "x$with_alsa" != xno; then : + + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for snd_pcm_open in -lasound" >&5 +$as_echo_n "checking for snd_pcm_open in -lasound... " >&6; } +if ${ac_cv_lib_asound_snd_pcm_open+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_check_lib_save_LIBS=$LIBS +LIBS="-lasound $LIBS" +cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + +/* Override any GCC internal prototype to avoid an error. + Use char because int might match the return type of a GCC + builtin and then its argument prototype would still apply. */ +#ifdef __cplusplus +extern "C" +#endif +char snd_pcm_open (); +int +main () +{ +return snd_pcm_open (); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_asound_snd_pcm_open=yes +else + ac_cv_lib_asound_snd_pcm_open=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +LIBS=$ac_check_lib_save_LIBS +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_asound_snd_pcm_open" >&5 +$as_echo "$ac_cv_lib_asound_snd_pcm_open" >&6; } +if test "x$ac_cv_lib_asound_snd_pcm_open" = xyes; then : + + $as_echo_n # what is the proper way to check for a library without linking it? + +else + + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "libasound-dev is required during build, but you don't have it installed. Use --without-alsa to disable ALSA support. +See \`config.log' for more details" "$LINENO" 5; } + +fi + + +else + + +$as_echo "#define WITHOUT_ALSA 1" >>confdefs.h + + +fi + +fi; + + if test "x$with_pulse" == xyes; then + WITH_PULSE_TRUE= + WITH_PULSE_FALSE='#' +else + WITH_PULSE_TRUE='#' + WITH_PULSE_FALSE= +fi + + if test "x$with_alsa" == xyes; then + WITH_ALSA_TRUE= + WITH_ALSA_FALSE='#' +else + WITH_ALSA_TRUE='#' + WITH_ALSA_FALSE= +fi + + +# Check whether --enable-dsp was given. +if test "${enable_dsp+set}" = set; then : + enableval=$enable_dsp; +else + enable_dsp=yes +fi + + if test "x$enable_dsp" == xyes; then + ENABLE_DSP_TRUE= + ENABLE_DSP_FALSE='#' +else + ENABLE_DSP_TRUE='#' + ENABLE_DSP_FALSE= +fi + + +# Checks for header files. +ac_fn_c_check_type "$LINENO" "size_t" "ac_cv_type_size_t" "$ac_includes_default" +if test "x$ac_cv_type_size_t" = xyes; then : + +else + +cat >>confdefs.h <<_ACEOF +#define size_t unsigned int +_ACEOF + +fi + +# The Ultrix 4.2 mips builtin alloca declared by alloca.h only works +# for constant arguments. Useless! +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for working alloca.h" >&5 +$as_echo_n "checking for working alloca.h... " >&6; } +if ${ac_cv_working_alloca_h+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +int +main () +{ +char *p = (char *) alloca (2 * sizeof (int)); + if (p) return 0; + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_working_alloca_h=yes +else + ac_cv_working_alloca_h=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_working_alloca_h" >&5 +$as_echo "$ac_cv_working_alloca_h" >&6; } +if test $ac_cv_working_alloca_h = yes; then + +$as_echo "#define HAVE_ALLOCA_H 1" >>confdefs.h + +fi + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for alloca" >&5 +$as_echo_n "checking for alloca... " >&6; } +if ${ac_cv_func_alloca_works+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#ifdef __GNUC__ +# define alloca __builtin_alloca +#else +# ifdef _MSC_VER +# include +# define alloca _alloca +# else +# ifdef HAVE_ALLOCA_H +# include +# else +# ifdef _AIX + #pragma alloca +# else +# ifndef alloca /* predefined by HP cc +Olibcalls */ +void *alloca (size_t); +# endif +# endif +# endif +# endif +#endif + +int +main () +{ +char *p = (char *) alloca (1); + if (p) return 0; + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_func_alloca_works=yes +else + ac_cv_func_alloca_works=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_func_alloca_works" >&5 +$as_echo "$ac_cv_func_alloca_works" >&6; } + +if test $ac_cv_func_alloca_works = yes; then + +$as_echo "#define HAVE_ALLOCA 1" >>confdefs.h + +else + # The SVR3 libPW and SVR4 libucb both contain incompatible functions +# that cause trouble. Some versions do not even contain alloca or +# contain a buggy version. If you still want to use their alloca, +# use ar to extract alloca.o from them instead of compiling alloca.c. + +ALLOCA=\${LIBOBJDIR}alloca.$ac_objext + +$as_echo "#define C_ALLOCA 1" >>confdefs.h + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether \`alloca.c' needs Cray hooks" >&5 +$as_echo_n "checking whether \`alloca.c' needs Cray hooks... " >&6; } +if ${ac_cv_os_cray+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#if defined CRAY && ! defined CRAY2 +webecray +#else +wenotbecray +#endif + +_ACEOF +if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | + $EGREP "webecray" >/dev/null 2>&1; then : + ac_cv_os_cray=yes +else + ac_cv_os_cray=no +fi +rm -f conftest* + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_os_cray" >&5 +$as_echo "$ac_cv_os_cray" >&6; } +if test $ac_cv_os_cray = yes; then + for ac_func in _getb67 GETB67 getb67; do + as_ac_var=`$as_echo "ac_cv_func_$ac_func" | $as_tr_sh` +ac_fn_c_check_func "$LINENO" "$ac_func" "$as_ac_var" +if eval test \"x\$"$as_ac_var"\" = x"yes"; then : + +cat >>confdefs.h <<_ACEOF +#define CRAY_STACKSEG_END $ac_func +_ACEOF + + break +fi + + done +fi + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking stack direction for C alloca" >&5 +$as_echo_n "checking stack direction for C alloca... " >&6; } +if ${ac_cv_c_stack_direction+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test "$cross_compiling" = yes; then : + ac_cv_c_stack_direction=0 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +$ac_includes_default +int +find_stack_direction (int *addr, int depth) +{ + int dir, dummy = 0; + if (! addr) + addr = &dummy; + *addr = addr < &dummy ? 1 : addr == &dummy ? 0 : -1; + dir = depth ? find_stack_direction (addr, depth - 1) : 0; + return dir + dummy; +} + +int +main (int argc, char **argv) +{ + return find_stack_direction (0, argc + !argv + 20) < 0; +} +_ACEOF +if ac_fn_c_try_run "$LINENO"; then : + ac_cv_c_stack_direction=1 +else + ac_cv_c_stack_direction=-1 +fi +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ + conftest.$ac_objext conftest.beam conftest.$ac_ext +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_stack_direction" >&5 +$as_echo "$ac_cv_c_stack_direction" >&6; } +cat >>confdefs.h <<_ACEOF +#define STACK_DIRECTION $ac_cv_c_stack_direction +_ACEOF + + +fi + +for ac_header in arpa/inet.h float.h malloc.h netdb.h netinet/in.h stddef.h stdint.h stdlib.h string.h sys/ioctl.h sys/socket.h sys/time.h unistd.h wchar.h +do : + as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh` +ac_fn_c_check_header_mongrel "$LINENO" "$ac_header" "$as_ac_Header" "$ac_includes_default" +if eval test \"x\$"$as_ac_Header"\" = x"yes"; then : + cat >>confdefs.h <<_ACEOF +#define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1 +_ACEOF + +fi + +done + + +# Checks for typedefs, structures, and compiler characteristics. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for stdbool.h that conforms to C99" >&5 +$as_echo_n "checking for stdbool.h that conforms to C99... " >&6; } +if ${ac_cv_header_stdbool_h+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + + #include + #ifndef bool + "error: bool is not defined" + #endif + #ifndef false + "error: false is not defined" + #endif + #if false + "error: false is not 0" + #endif + #ifndef true + "error: true is not defined" + #endif + #if true != 1 + "error: true is not 1" + #endif + #ifndef __bool_true_false_are_defined + "error: __bool_true_false_are_defined is not defined" + #endif + + struct s { _Bool s: 1; _Bool t; } s; + + char a[true == 1 ? 1 : -1]; + char b[false == 0 ? 1 : -1]; + char c[__bool_true_false_are_defined == 1 ? 1 : -1]; + char d[(bool) 0.5 == true ? 1 : -1]; + /* See body of main program for 'e'. */ + char f[(_Bool) 0.0 == false ? 1 : -1]; + char g[true]; + char h[sizeof (_Bool)]; + char i[sizeof s.t]; + enum { j = false, k = true, l = false * true, m = true * 256 }; + /* The following fails for + HP aC++/ANSI C B3910B A.05.55 [Dec 04 2003]. */ + _Bool n[m]; + char o[sizeof n == m * sizeof n[0] ? 1 : -1]; + char p[-1 - (_Bool) 0 < 0 && -1 - (bool) 0 < 0 ? 1 : -1]; + /* Catch a bug in an HP-UX C compiler. See + http://gcc.gnu.org/ml/gcc-patches/2003-12/msg02303.html + http://lists.gnu.org/archive/html/bug-coreutils/2005-11/msg00161.html + */ + _Bool q = true; + _Bool *pq = &q; + +int +main () +{ + + bool e = &s; + *pq |= q; + *pq |= ! q; + /* Refer to every declared value, to avoid compiler optimizations. */ + return (!a + !b + !c + !d + !e + !f + !g + !h + !i + !!j + !k + !!l + + !m + !n + !o + !p + !q + !pq); + + ; + return 0; +} +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_header_stdbool_h=yes +else + ac_cv_header_stdbool_h=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_header_stdbool_h" >&5 +$as_echo "$ac_cv_header_stdbool_h" >&6; } + ac_fn_c_check_type "$LINENO" "_Bool" "ac_cv_type__Bool" "$ac_includes_default" +if test "x$ac_cv_type__Bool" = xyes; then : + +cat >>confdefs.h <<_ACEOF +#define HAVE__BOOL 1 +_ACEOF + + +fi + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for inline" >&5 +$as_echo_n "checking for inline... " >&6; } +if ${ac_cv_c_inline+:} false; then : + $as_echo_n "(cached) " >&6 +else + ac_cv_c_inline=no +for ac_kw in inline __inline__ __inline; do + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#ifndef __cplusplus +typedef int foo_t; +static $ac_kw foo_t static_foo () {return 0; } +$ac_kw foo_t foo () {return 0; } +#endif + +_ACEOF +if ac_fn_c_try_compile "$LINENO"; then : + ac_cv_c_inline=$ac_kw +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + test "$ac_cv_c_inline" != no && break +done + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_inline" >&5 +$as_echo "$ac_cv_c_inline" >&6; } + +case $ac_cv_c_inline in + inline | yes) ;; + *) + case $ac_cv_c_inline in + no) ac_val=;; + *) ac_val=$ac_cv_c_inline;; + esac + cat >>confdefs.h <<_ACEOF +#ifndef __cplusplus +#define inline $ac_val +#endif +_ACEOF + ;; +esac + +ac_fn_c_find_intX_t "$LINENO" "16" "ac_cv_c_int16_t" +case $ac_cv_c_int16_t in #( + no|yes) ;; #( + *) + +cat >>confdefs.h <<_ACEOF +#define int16_t $ac_cv_c_int16_t +_ACEOF +;; +esac + +ac_fn_c_find_intX_t "$LINENO" "32" "ac_cv_c_int32_t" +case $ac_cv_c_int32_t in #( + no|yes) ;; #( + *) + +cat >>confdefs.h <<_ACEOF +#define int32_t $ac_cv_c_int32_t +_ACEOF +;; +esac + +ac_fn_c_find_intX_t "$LINENO" "64" "ac_cv_c_int64_t" +case $ac_cv_c_int64_t in #( + no|yes) ;; #( + *) + +cat >>confdefs.h <<_ACEOF +#define int64_t $ac_cv_c_int64_t +_ACEOF +;; +esac + +ac_fn_c_find_intX_t "$LINENO" "8" "ac_cv_c_int8_t" +case $ac_cv_c_int8_t in #( + no|yes) ;; #( + *) + +cat >>confdefs.h <<_ACEOF +#define int8_t $ac_cv_c_int8_t +_ACEOF +;; +esac + +ac_fn_c_check_type "$LINENO" "size_t" "ac_cv_type_size_t" "$ac_includes_default" +if test "x$ac_cv_type_size_t" = xyes; then : + +else + +cat >>confdefs.h <<_ACEOF +#define size_t unsigned int +_ACEOF + +fi + +ac_fn_c_check_type "$LINENO" "ssize_t" "ac_cv_type_ssize_t" "$ac_includes_default" +if test "x$ac_cv_type_ssize_t" = xyes; then : + +else + +cat >>confdefs.h <<_ACEOF +#define ssize_t int +_ACEOF + +fi + +ac_fn_c_find_uintX_t "$LINENO" "16" "ac_cv_c_uint16_t" +case $ac_cv_c_uint16_t in #( + no|yes) ;; #( + *) + + +cat >>confdefs.h <<_ACEOF +#define uint16_t $ac_cv_c_uint16_t +_ACEOF +;; + esac + +ac_fn_c_find_uintX_t "$LINENO" "32" "ac_cv_c_uint32_t" +case $ac_cv_c_uint32_t in #( + no|yes) ;; #( + *) + +$as_echo "#define _UINT32_T 1" >>confdefs.h + + +cat >>confdefs.h <<_ACEOF +#define uint32_t $ac_cv_c_uint32_t +_ACEOF +;; + esac + +ac_fn_c_find_uintX_t "$LINENO" "64" "ac_cv_c_uint64_t" +case $ac_cv_c_uint64_t in #( + no|yes) ;; #( + *) + +$as_echo "#define _UINT64_T 1" >>confdefs.h + + +cat >>confdefs.h <<_ACEOF +#define uint64_t $ac_cv_c_uint64_t +_ACEOF +;; + esac + +ac_fn_c_find_uintX_t "$LINENO" "8" "ac_cv_c_uint8_t" +case $ac_cv_c_uint8_t in #( + no|yes) ;; #( + *) + +$as_echo "#define _UINT8_T 1" >>confdefs.h + + +cat >>confdefs.h <<_ACEOF +#define uint8_t $ac_cv_c_uint8_t +_ACEOF +;; + esac + +ac_fn_c_check_type "$LINENO" "ptrdiff_t" "ac_cv_type_ptrdiff_t" "$ac_includes_default" +if test "x$ac_cv_type_ptrdiff_t" = xyes; then : + +cat >>confdefs.h <<_ACEOF +#define HAVE_PTRDIFF_T 1 +_ACEOF + + +fi + + +# Checks for library functions. +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for error_at_line" >&5 +$as_echo_n "checking for error_at_line... " >&6; } +if ${ac_cv_lib_error_at_line+:} false; then : + $as_echo_n "(cached) " >&6 +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#include +int +main () +{ +error_at_line (0, 0, "", 0, "an error occurred"); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_link "$LINENO"; then : + ac_cv_lib_error_at_line=yes +else + ac_cv_lib_error_at_line=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_error_at_line" >&5 +$as_echo "$ac_cv_lib_error_at_line" >&6; } +if test $ac_cv_lib_error_at_line = no; then + case " $LIBOBJS " in + *" error.$ac_objext "* ) ;; + *) LIBOBJS="$LIBOBJS error.$ac_objext" + ;; +esac + +fi + +for ac_header in stdlib.h +do : + ac_fn_c_check_header_mongrel "$LINENO" "stdlib.h" "ac_cv_header_stdlib_h" "$ac_includes_default" +if test "x$ac_cv_header_stdlib_h" = xyes; then : + cat >>confdefs.h <<_ACEOF +#define HAVE_STDLIB_H 1 +_ACEOF + +fi + +done + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for GNU libc compatible malloc" >&5 +$as_echo_n "checking for GNU libc compatible malloc... " >&6; } +if ${ac_cv_func_malloc_0_nonnull+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test "$cross_compiling" = yes; then : + ac_cv_func_malloc_0_nonnull=no +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#if defined STDC_HEADERS || defined HAVE_STDLIB_H +# include +#else +char *malloc (); +#endif + +int +main () +{ +return ! malloc (0); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_run "$LINENO"; then : + ac_cv_func_malloc_0_nonnull=yes +else + ac_cv_func_malloc_0_nonnull=no +fi +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ + conftest.$ac_objext conftest.beam conftest.$ac_ext +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_func_malloc_0_nonnull" >&5 +$as_echo "$ac_cv_func_malloc_0_nonnull" >&6; } +if test $ac_cv_func_malloc_0_nonnull = yes; then : + +$as_echo "#define HAVE_MALLOC 1" >>confdefs.h + +else + $as_echo "#define HAVE_MALLOC 0" >>confdefs.h + + case " $LIBOBJS " in + *" malloc.$ac_objext "* ) ;; + *) LIBOBJS="$LIBOBJS malloc.$ac_objext" + ;; +esac + + +$as_echo "#define malloc rpl_malloc" >>confdefs.h + +fi + + +for ac_header in stdlib.h +do : + ac_fn_c_check_header_mongrel "$LINENO" "stdlib.h" "ac_cv_header_stdlib_h" "$ac_includes_default" +if test "x$ac_cv_header_stdlib_h" = xyes; then : + cat >>confdefs.h <<_ACEOF +#define HAVE_STDLIB_H 1 +_ACEOF + +fi + +done + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for GNU libc compatible realloc" >&5 +$as_echo_n "checking for GNU libc compatible realloc... " >&6; } +if ${ac_cv_func_realloc_0_nonnull+:} false; then : + $as_echo_n "(cached) " >&6 +else + if test "$cross_compiling" = yes; then : + ac_cv_func_realloc_0_nonnull=no +else + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ +#if defined STDC_HEADERS || defined HAVE_STDLIB_H +# include +#else +char *realloc (); +#endif + +int +main () +{ +return ! realloc (0, 0); + ; + return 0; +} +_ACEOF +if ac_fn_c_try_run "$LINENO"; then : + ac_cv_func_realloc_0_nonnull=yes +else + ac_cv_func_realloc_0_nonnull=no +fi +rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ + conftest.$ac_objext conftest.beam conftest.$ac_ext +fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_func_realloc_0_nonnull" >&5 +$as_echo "$ac_cv_func_realloc_0_nonnull" >&6; } +if test $ac_cv_func_realloc_0_nonnull = yes; then : + +$as_echo "#define HAVE_REALLOC 1" >>confdefs.h + +else + $as_echo "#define HAVE_REALLOC 0" >>confdefs.h + + case " $LIBOBJS " in + *" realloc.$ac_objext "* ) ;; + *) LIBOBJS="$LIBOBJS realloc.$ac_objext" + ;; +esac + + +$as_echo "#define realloc rpl_realloc" >>confdefs.h + +fi + + +for ac_func in clock_gettime floor gettimeofday inet_ntoa memmove memset select socket sqrt strcasecmp strchr strerror strncasecmp strstr strtol strtoul uname +do : + as_ac_var=`$as_echo "ac_cv_func_$ac_func" | $as_tr_sh` +ac_fn_c_check_func "$LINENO" "$ac_func" "$as_ac_var" +if eval test \"x\$"$as_ac_var"\" = x"yes"; then : + cat >>confdefs.h <<_ACEOF +#define `$as_echo "HAVE_$ac_func" | $as_tr_cpp` 1 +_ACEOF + +fi +done + + +ac_config_files="$ac_config_files Makefile" + +cat >confcache <<\_ACEOF +# This file is a shell script that caches the results of configure +# tests run on this system so they can be shared between configure +# scripts and configure runs, see configure's option --config-cache. +# It is not useful on other systems. If it contains results you don't +# want to keep, you may remove or edit it. +# +# config.status only pays attention to the cache file if you give it +# the --recheck option to rerun configure. +# +# `ac_cv_env_foo' variables (set or unset) will be overridden when +# loading this file, other *unset* `ac_cv_foo' will be assigned the +# following values. + +_ACEOF + +# The following way of writing the cache mishandles newlines in values, +# but we know of no workaround that is simple, portable, and efficient. +# So, we kill variables containing newlines. +# Ultrix sh set writes to stderr and can't be redirected directly, +# and sets the high bit in the cache file unless we assign to the vars. +( + for ac_var in `(set) 2>&1 | sed -n 's/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'`; do + eval ac_val=\$$ac_var + case $ac_val in #( + *${as_nl}*) + case $ac_var in #( + *_cv_*) { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 +$as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; + esac + case $ac_var in #( + _ | IFS | as_nl) ;; #( + BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( + *) { eval $ac_var=; unset $ac_var;} ;; + esac ;; + esac + done + + (set) 2>&1 | + case $as_nl`(ac_space=' '; set) 2>&1` in #( + *${as_nl}ac_space=\ *) + # `set' does not quote correctly, so add quotes: double-quote + # substitution turns \\\\ into \\, and sed turns \\ into \. + sed -n \ + "s/'/'\\\\''/g; + s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\\2'/p" + ;; #( + *) + # `set' quotes correctly as required by POSIX, so do not add quotes. + sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" + ;; + esac | + sort +) | + sed ' + /^ac_cv_env_/b end + t clear + :clear + s/^\([^=]*\)=\(.*[{}].*\)$/test "${\1+set}" = set || &/ + t end + s/^\([^=]*\)=\(.*\)$/\1=${\1=\2}/ + :end' >>confcache +if diff "$cache_file" confcache >/dev/null 2>&1; then :; else + if test -w "$cache_file"; then + if test "x$cache_file" != "x/dev/null"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: updating cache $cache_file" >&5 +$as_echo "$as_me: updating cache $cache_file" >&6;} + if test ! -f "$cache_file" || test -h "$cache_file"; then + cat confcache >"$cache_file" + else + case $cache_file in #( + */* | ?:*) + mv -f confcache "$cache_file"$$ && + mv -f "$cache_file"$$ "$cache_file" ;; #( + *) + mv -f confcache "$cache_file" ;; + esac + fi + fi + else + { $as_echo "$as_me:${as_lineno-$LINENO}: not updating unwritable cache $cache_file" >&5 +$as_echo "$as_me: not updating unwritable cache $cache_file" >&6;} + fi +fi +rm -f confcache + +test "x$prefix" = xNONE && prefix=$ac_default_prefix +# Let make expand exec_prefix. +test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' + +DEFS=-DHAVE_CONFIG_H + +ac_libobjs= +ac_ltlibobjs= +U= +for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue + # 1. Remove the extension, and $U if already installed. + ac_script='s/\$U\././;s/\.o$//;s/\.obj$//' + ac_i=`$as_echo "$ac_i" | sed "$ac_script"` + # 2. Prepend LIBOBJDIR. When used with automake>=1.10 LIBOBJDIR + # will be set to the directory where LIBOBJS objects are built. + as_fn_append ac_libobjs " \${LIBOBJDIR}$ac_i\$U.$ac_objext" + as_fn_append ac_ltlibobjs " \${LIBOBJDIR}$ac_i"'$U.lo' +done +LIBOBJS=$ac_libobjs + +LTLIBOBJS=$ac_ltlibobjs + + +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking that generated files are newer than configure" >&5 +$as_echo_n "checking that generated files are newer than configure... " >&6; } + if test -n "$am_sleep_pid"; then + # Hide warnings about reused PIDs. + wait $am_sleep_pid 2>/dev/null + fi + { $as_echo "$as_me:${as_lineno-$LINENO}: result: done" >&5 +$as_echo "done" >&6; } + if test -n "$EXEEXT"; then + am__EXEEXT_TRUE= + am__EXEEXT_FALSE='#' +else + am__EXEEXT_TRUE='#' + am__EXEEXT_FALSE= +fi + +if test -z "${AMDEP_TRUE}" && test -z "${AMDEP_FALSE}"; then + as_fn_error $? "conditional \"AMDEP\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then + as_fn_error $? "conditional \"am__fastdepCC\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${am__fastdepCXX_TRUE}" && test -z "${am__fastdepCXX_FALSE}"; then + as_fn_error $? "conditional \"am__fastdepCXX\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then + as_fn_error $? "conditional \"am__fastdepCC\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${am__fastdepOBJCXX_TRUE}" && test -z "${am__fastdepOBJCXX_FALSE}"; then + as_fn_error $? "conditional \"am__fastdepOBJCXX\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${am__fastdepCCAS_TRUE}" && test -z "${am__fastdepCCAS_FALSE}"; then + as_fn_error $? "conditional \"am__fastdepCCAS\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${TARGET_CPU_X86_TRUE}" && test -z "${TARGET_CPU_X86_FALSE}"; then + as_fn_error $? "conditional \"TARGET_CPU_X86\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${TARGET_CPU_ARM_TRUE}" && test -z "${TARGET_CPU_ARM_FALSE}"; then + as_fn_error $? "conditional \"TARGET_CPU_ARM\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${TARGET_CPU_ARMV7_TRUE}" && test -z "${TARGET_CPU_ARMV7_FALSE}"; then + as_fn_error $? "conditional \"TARGET_CPU_ARMV7\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${TARGET_OS_OSX_TRUE}" && test -z "${TARGET_OS_OSX_FALSE}"; then + as_fn_error $? "conditional \"TARGET_OS_OSX\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${ENABLE_AUDIO_CALLBACK_TRUE}" && test -z "${ENABLE_AUDIO_CALLBACK_FALSE}"; then + as_fn_error $? "conditional \"ENABLE_AUDIO_CALLBACK\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${WITH_PULSE_TRUE}" && test -z "${WITH_PULSE_FALSE}"; then + as_fn_error $? "conditional \"WITH_PULSE\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${WITH_ALSA_TRUE}" && test -z "${WITH_ALSA_FALSE}"; then + as_fn_error $? "conditional \"WITH_ALSA\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${ENABLE_DSP_TRUE}" && test -z "${ENABLE_DSP_FALSE}"; then + as_fn_error $? "conditional \"ENABLE_DSP\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi + +: "${CONFIG_STATUS=./config.status}" +ac_write_fail=0 +ac_clean_files_save=$ac_clean_files +ac_clean_files="$ac_clean_files $CONFIG_STATUS" +{ $as_echo "$as_me:${as_lineno-$LINENO}: creating $CONFIG_STATUS" >&5 +$as_echo "$as_me: creating $CONFIG_STATUS" >&6;} +as_write_fail=0 +cat >$CONFIG_STATUS <<_ASEOF || as_write_fail=1 +#! $SHELL +# Generated by $as_me. +# Run this file to recreate the current configuration. +# Compiler output produced by configure, useful for debugging +# configure, is in config.log if it exists. + +debug=false +ac_cs_recheck=false +ac_cs_silent=false + +SHELL=\${CONFIG_SHELL-$SHELL} +export SHELL +_ASEOF +cat >>$CONFIG_STATUS <<\_ASEOF || as_write_fail=1 +## -------------------- ## +## M4sh Initialization. ## +## -------------------- ## + +# Be more Bourne compatible +DUALCASE=1; export DUALCASE # for MKS sh +if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : + emulate sh + NULLCMD=: + # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which + # is contrary to our usage. Disable this feature. + alias -g '${1+"$@"}'='"$@"' + setopt NO_GLOB_SUBST +else + case `(set -o) 2>/dev/null` in #( + *posix*) : + set -o posix ;; #( + *) : + ;; +esac +fi + + +as_nl=' +' +export as_nl +# Printing a long string crashes Solaris 7 /usr/bin/printf. +as_echo='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' +as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo +as_echo=$as_echo$as_echo$as_echo$as_echo$as_echo$as_echo +# Prefer a ksh shell builtin over an external printf program on Solaris, +# but without wasting forks for bash or zsh. +if test -z "$BASH_VERSION$ZSH_VERSION" \ + && (test "X`print -r -- $as_echo`" = "X$as_echo") 2>/dev/null; then + as_echo='print -r --' + as_echo_n='print -rn --' +elif (test "X`printf %s $as_echo`" = "X$as_echo") 2>/dev/null; then + as_echo='printf %s\n' + as_echo_n='printf %s' +else + if test "X`(/usr/ucb/echo -n -n $as_echo) 2>/dev/null`" = "X-n $as_echo"; then + as_echo_body='eval /usr/ucb/echo -n "$1$as_nl"' + as_echo_n='/usr/ucb/echo -n' + else + as_echo_body='eval expr "X$1" : "X\\(.*\\)"' + as_echo_n_body='eval + arg=$1; + case $arg in #( + *"$as_nl"*) + expr "X$arg" : "X\\(.*\\)$as_nl"; + arg=`expr "X$arg" : ".*$as_nl\\(.*\\)"`;; + esac; + expr "X$arg" : "X\\(.*\\)" | tr -d "$as_nl" + ' + export as_echo_n_body + as_echo_n='sh -c $as_echo_n_body as_echo' + fi + export as_echo_body + as_echo='sh -c $as_echo_body as_echo' +fi + +# The user is always right. +if test "${PATH_SEPARATOR+set}" != set; then + PATH_SEPARATOR=: + (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { + (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || + PATH_SEPARATOR=';' + } +fi + + +# IFS +# We need space, tab and new line, in precisely that order. Quoting is +# there to prevent editors from complaining about space-tab. +# (If _AS_PATH_WALK were called with IFS unset, it would disable word +# splitting by setting IFS to empty value.) +IFS=" "" $as_nl" + +# Find who we are. Look in the path if we contain no directory separator. +as_myself= +case $0 in #(( + *[\\/]* ) as_myself=$0 ;; + *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break + done +IFS=$as_save_IFS + + ;; +esac +# We did not find ourselves, most probably we were run as `sh COMMAND' +# in which case we are not to be found in the path. +if test "x$as_myself" = x; then + as_myself=$0 +fi +if test ! -f "$as_myself"; then + $as_echo "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 + exit 1 +fi + +# Unset variables that we do not need and which cause bugs (e.g. in +# pre-3.0 UWIN ksh). But do not cause bugs in bash 2.01; the "|| exit 1" +# suppresses any "Segmentation fault" message there. '((' could +# trigger a bug in pdksh 5.2.14. +for as_var in BASH_ENV ENV MAIL MAILPATH +do eval test x\${$as_var+set} = xset \ + && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : +done +PS1='$ ' +PS2='> ' +PS4='+ ' + +# NLS nuisances. +LC_ALL=C +export LC_ALL +LANGUAGE=C +export LANGUAGE + +# CDPATH. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + + +# as_fn_error STATUS ERROR [LINENO LOG_FD] +# ---------------------------------------- +# Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are +# provided, also output the error to LOG_FD, referencing LINENO. Then exit the +# script with STATUS, using 1 if that was 0. +as_fn_error () +{ + as_status=$1; test $as_status -eq 0 && as_status=1 + if test "$4"; then + as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack + $as_echo "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 + fi + $as_echo "$as_me: error: $2" >&2 + as_fn_exit $as_status +} # as_fn_error + + +# as_fn_set_status STATUS +# ----------------------- +# Set $? to STATUS, without forking. +as_fn_set_status () +{ + return $1 +} # as_fn_set_status + +# as_fn_exit STATUS +# ----------------- +# Exit the shell with STATUS, even in a "trap 0" or "set -e" context. +as_fn_exit () +{ + set +e + as_fn_set_status $1 + exit $1 +} # as_fn_exit + +# as_fn_unset VAR +# --------------- +# Portably unset VAR. +as_fn_unset () +{ + { eval $1=; unset $1;} +} +as_unset=as_fn_unset +# as_fn_append VAR VALUE +# ---------------------- +# Append the text in VALUE to the end of the definition contained in VAR. Take +# advantage of any shell optimizations that allow amortized linear growth over +# repeated appends, instead of the typical quadratic growth present in naive +# implementations. +if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null; then : + eval 'as_fn_append () + { + eval $1+=\$2 + }' +else + as_fn_append () + { + eval $1=\$$1\$2 + } +fi # as_fn_append + +# as_fn_arith ARG... +# ------------------ +# Perform arithmetic evaluation on the ARGs, and store the result in the +# global $as_val. Take advantage of shells that can avoid forks. The arguments +# must be portable across $(()) and expr. +if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null; then : + eval 'as_fn_arith () + { + as_val=$(( $* )) + }' +else + as_fn_arith () + { + as_val=`expr "$@" || test $? -eq 1` + } +fi # as_fn_arith + + +if expr a : '\(a\)' >/dev/null 2>&1 && + test "X`expr 00001 : '.*\(...\)'`" = X001; then + as_expr=expr +else + as_expr=false +fi + +if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then + as_basename=basename +else + as_basename=false +fi + +if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then + as_dirname=dirname +else + as_dirname=false +fi + +as_me=`$as_basename -- "$0" || +$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ + X"$0" : 'X\(//\)$' \| \ + X"$0" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X/"$0" | + sed '/^.*\/\([^/][^/]*\)\/*$/{ + s//\1/ + q + } + /^X\/\(\/\/\)$/{ + s//\1/ + q + } + /^X\/\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + +# Avoid depending upon Character Ranges. +as_cr_letters='abcdefghijklmnopqrstuvwxyz' +as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' +as_cr_Letters=$as_cr_letters$as_cr_LETTERS +as_cr_digits='0123456789' +as_cr_alnum=$as_cr_Letters$as_cr_digits + +ECHO_C= ECHO_N= ECHO_T= +case `echo -n x` in #((((( +-n*) + case `echo 'xy\c'` in + *c*) ECHO_T=' ';; # ECHO_T is single tab character. + xy) ECHO_C='\c';; + *) echo `echo ksh88 bug on AIX 6.1` > /dev/null + ECHO_T=' ';; + esac;; +*) + ECHO_N='-n';; +esac + +rm -f conf$$ conf$$.exe conf$$.file +if test -d conf$$.dir; then + rm -f conf$$.dir/conf$$.file +else + rm -f conf$$.dir + mkdir conf$$.dir 2>/dev/null +fi +if (echo >conf$$.file) 2>/dev/null; then + if ln -s conf$$.file conf$$ 2>/dev/null; then + as_ln_s='ln -s' + # ... but there are two gotchas: + # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. + # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. + # In both cases, we have to default to `cp -pR'. + ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || + as_ln_s='cp -pR' + elif ln conf$$.file conf$$ 2>/dev/null; then + as_ln_s=ln + else + as_ln_s='cp -pR' + fi +else + as_ln_s='cp -pR' +fi +rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file +rmdir conf$$.dir 2>/dev/null + + +# as_fn_mkdir_p +# ------------- +# Create "$as_dir" as a directory, including parents if necessary. +as_fn_mkdir_p () +{ + + case $as_dir in #( + -*) as_dir=./$as_dir;; + esac + test -d "$as_dir" || eval $as_mkdir_p || { + as_dirs= + while :; do + case $as_dir in #( + *\'*) as_qdir=`$as_echo "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( + *) as_qdir=$as_dir;; + esac + as_dirs="'$as_qdir' $as_dirs" + as_dir=`$as_dirname -- "$as_dir" || +$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$as_dir" : 'X\(//\)[^/]' \| \ + X"$as_dir" : 'X\(//\)$' \| \ + X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$as_dir" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + test -d "$as_dir" && break + done + test -z "$as_dirs" || eval "mkdir $as_dirs" + } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" + + +} # as_fn_mkdir_p +if mkdir -p . 2>/dev/null; then + as_mkdir_p='mkdir -p "$as_dir"' +else + test -d ./-p && rmdir ./-p + as_mkdir_p=false +fi + + +# as_fn_executable_p FILE +# ----------------------- +# Test if FILE is an executable regular file. +as_fn_executable_p () +{ + test -f "$1" && test -x "$1" +} # as_fn_executable_p +as_test_x='test -x' +as_executable_p=as_fn_executable_p + +# Sed expression to map a string onto a valid CPP name. +as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" + +# Sed expression to map a string onto a valid variable name. +as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" + + +exec 6>&1 +## ----------------------------------- ## +## Main body of $CONFIG_STATUS script. ## +## ----------------------------------- ## +_ASEOF +test $as_write_fail = 0 && chmod +x $CONFIG_STATUS || ac_write_fail=1 + +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +# Save the log message, to keep $0 and so on meaningful, and to +# report actual input values of CONFIG_FILES etc. instead of their +# values after options handling. +ac_log=" +This file was extended by libtgvoip $as_me 2.6, which was +generated by GNU Autoconf 2.69. Invocation command line was + + CONFIG_FILES = $CONFIG_FILES + CONFIG_HEADERS = $CONFIG_HEADERS + CONFIG_LINKS = $CONFIG_LINKS + CONFIG_COMMANDS = $CONFIG_COMMANDS + $ $0 $@ + +on `(hostname || uname -n) 2>/dev/null | sed 1q` +" + +_ACEOF + +case $ac_config_files in *" +"*) set x $ac_config_files; shift; ac_config_files=$*;; +esac + +case $ac_config_headers in *" +"*) set x $ac_config_headers; shift; ac_config_headers=$*;; +esac + + +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +# Files that config.status was made for. +config_files="$ac_config_files" +config_headers="$ac_config_headers" +config_commands="$ac_config_commands" + +_ACEOF + +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +ac_cs_usage="\ +\`$as_me' instantiates files and other configuration actions +from templates according to the current configuration. Unless the files +and actions are specified as TAGs, all are instantiated by default. + +Usage: $0 [OPTION]... [TAG]... + + -h, --help print this help, then exit + -V, --version print version number and configuration settings, then exit + --config print configuration, then exit + -q, --quiet, --silent + do not print progress messages + -d, --debug don't remove temporary files + --recheck update $as_me by reconfiguring in the same conditions + --file=FILE[:TEMPLATE] + instantiate the configuration file FILE + --header=FILE[:TEMPLATE] + instantiate the configuration header FILE + +Configuration files: +$config_files + +Configuration headers: +$config_headers + +Configuration commands: +$config_commands + +Report bugs to ." + +_ACEOF +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" +ac_cs_version="\\ +libtgvoip config.status 2.6 +configured by $0, generated by GNU Autoconf 2.69, + with options \\"\$ac_cs_config\\" + +Copyright (C) 2012 Free Software Foundation, Inc. +This config.status script is free software; the Free Software Foundation +gives unlimited permission to copy, distribute and modify it." + +ac_pwd='$ac_pwd' +srcdir='$srcdir' +INSTALL='$INSTALL' +MKDIR_P='$MKDIR_P' +AWK='$AWK' +test -n "\$AWK" || AWK=awk +_ACEOF + +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +# The default lists apply if the user does not specify any file. +ac_need_defaults=: +while test $# != 0 +do + case $1 in + --*=?*) + ac_option=`expr "X$1" : 'X\([^=]*\)='` + ac_optarg=`expr "X$1" : 'X[^=]*=\(.*\)'` + ac_shift=: + ;; + --*=) + ac_option=`expr "X$1" : 'X\([^=]*\)='` + ac_optarg= + ac_shift=: + ;; + *) + ac_option=$1 + ac_optarg=$2 + ac_shift=shift + ;; + esac + + case $ac_option in + # Handling of the options. + -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) + ac_cs_recheck=: ;; + --version | --versio | --versi | --vers | --ver | --ve | --v | -V ) + $as_echo "$ac_cs_version"; exit ;; + --config | --confi | --conf | --con | --co | --c ) + $as_echo "$ac_cs_config"; exit ;; + --debug | --debu | --deb | --de | --d | -d ) + debug=: ;; + --file | --fil | --fi | --f ) + $ac_shift + case $ac_optarg in + *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; + '') as_fn_error $? "missing file argument" ;; + esac + as_fn_append CONFIG_FILES " '$ac_optarg'" + ac_need_defaults=false;; + --header | --heade | --head | --hea ) + $ac_shift + case $ac_optarg in + *\'*) ac_optarg=`$as_echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; + esac + as_fn_append CONFIG_HEADERS " '$ac_optarg'" + ac_need_defaults=false;; + --he | --h) + # Conflict between --help and --header + as_fn_error $? "ambiguous option: \`$1' +Try \`$0 --help' for more information.";; + --help | --hel | -h ) + $as_echo "$ac_cs_usage"; exit ;; + -q | -quiet | --quiet | --quie | --qui | --qu | --q \ + | -silent | --silent | --silen | --sile | --sil | --si | --s) + ac_cs_silent=: ;; + + # This is an error. + -*) as_fn_error $? "unrecognized option: \`$1' +Try \`$0 --help' for more information." ;; + + *) as_fn_append ac_config_targets " $1" + ac_need_defaults=false ;; + + esac + shift +done + +ac_configure_extra_args= + +if $ac_cs_silent; then + exec 6>/dev/null + ac_configure_extra_args="$ac_configure_extra_args --silent" +fi + +_ACEOF +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +if \$ac_cs_recheck; then + set X $SHELL '$0' $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion + shift + \$as_echo "running CONFIG_SHELL=$SHELL \$*" >&6 + CONFIG_SHELL='$SHELL' + export CONFIG_SHELL + exec "\$@" +fi + +_ACEOF +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +exec 5>>config.log +{ + echo + sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX +## Running $as_me. ## +_ASBOX + $as_echo "$ac_log" +} >&5 + +_ACEOF +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +# +# INIT-COMMANDS +# +AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}" + + +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + +sed_quote_subst='$sed_quote_subst' +double_quote_subst='$double_quote_subst' +delay_variable_subst='$delay_variable_subst' +macro_version='`$ECHO "$macro_version" | $SED "$delay_single_quote_subst"`' +macro_revision='`$ECHO "$macro_revision" | $SED "$delay_single_quote_subst"`' +enable_shared='`$ECHO "$enable_shared" | $SED "$delay_single_quote_subst"`' +enable_static='`$ECHO "$enable_static" | $SED "$delay_single_quote_subst"`' +pic_mode='`$ECHO "$pic_mode" | $SED "$delay_single_quote_subst"`' +enable_fast_install='`$ECHO "$enable_fast_install" | $SED "$delay_single_quote_subst"`' +shared_archive_member_spec='`$ECHO "$shared_archive_member_spec" | $SED "$delay_single_quote_subst"`' +SHELL='`$ECHO "$SHELL" | $SED "$delay_single_quote_subst"`' +ECHO='`$ECHO "$ECHO" | $SED "$delay_single_quote_subst"`' +PATH_SEPARATOR='`$ECHO "$PATH_SEPARATOR" | $SED "$delay_single_quote_subst"`' +host_alias='`$ECHO "$host_alias" | $SED "$delay_single_quote_subst"`' +host='`$ECHO "$host" | $SED "$delay_single_quote_subst"`' +host_os='`$ECHO "$host_os" | $SED "$delay_single_quote_subst"`' +build_alias='`$ECHO "$build_alias" | $SED "$delay_single_quote_subst"`' +build='`$ECHO "$build" | $SED "$delay_single_quote_subst"`' +build_os='`$ECHO "$build_os" | $SED "$delay_single_quote_subst"`' +SED='`$ECHO "$SED" | $SED "$delay_single_quote_subst"`' +Xsed='`$ECHO "$Xsed" | $SED "$delay_single_quote_subst"`' +GREP='`$ECHO "$GREP" | $SED "$delay_single_quote_subst"`' +EGREP='`$ECHO "$EGREP" | $SED "$delay_single_quote_subst"`' +FGREP='`$ECHO "$FGREP" | $SED "$delay_single_quote_subst"`' +LD='`$ECHO "$LD" | $SED "$delay_single_quote_subst"`' +NM='`$ECHO "$NM" | $SED "$delay_single_quote_subst"`' +LN_S='`$ECHO "$LN_S" | $SED "$delay_single_quote_subst"`' +max_cmd_len='`$ECHO "$max_cmd_len" | $SED "$delay_single_quote_subst"`' +ac_objext='`$ECHO "$ac_objext" | $SED "$delay_single_quote_subst"`' +exeext='`$ECHO "$exeext" | $SED "$delay_single_quote_subst"`' +lt_unset='`$ECHO "$lt_unset" | $SED "$delay_single_quote_subst"`' +lt_SP2NL='`$ECHO "$lt_SP2NL" | $SED "$delay_single_quote_subst"`' +lt_NL2SP='`$ECHO "$lt_NL2SP" | $SED "$delay_single_quote_subst"`' +lt_cv_to_host_file_cmd='`$ECHO "$lt_cv_to_host_file_cmd" | $SED "$delay_single_quote_subst"`' +lt_cv_to_tool_file_cmd='`$ECHO "$lt_cv_to_tool_file_cmd" | $SED "$delay_single_quote_subst"`' +reload_flag='`$ECHO "$reload_flag" | $SED "$delay_single_quote_subst"`' +reload_cmds='`$ECHO "$reload_cmds" | $SED "$delay_single_quote_subst"`' +OBJDUMP='`$ECHO "$OBJDUMP" | $SED "$delay_single_quote_subst"`' +deplibs_check_method='`$ECHO "$deplibs_check_method" | $SED "$delay_single_quote_subst"`' +file_magic_cmd='`$ECHO "$file_magic_cmd" | $SED "$delay_single_quote_subst"`' +file_magic_glob='`$ECHO "$file_magic_glob" | $SED "$delay_single_quote_subst"`' +want_nocaseglob='`$ECHO "$want_nocaseglob" | $SED "$delay_single_quote_subst"`' +DLLTOOL='`$ECHO "$DLLTOOL" | $SED "$delay_single_quote_subst"`' +sharedlib_from_linklib_cmd='`$ECHO "$sharedlib_from_linklib_cmd" | $SED "$delay_single_quote_subst"`' +AR='`$ECHO "$AR" | $SED "$delay_single_quote_subst"`' +lt_ar_flags='`$ECHO "$lt_ar_flags" | $SED "$delay_single_quote_subst"`' +AR_FLAGS='`$ECHO "$AR_FLAGS" | $SED "$delay_single_quote_subst"`' +archiver_list_spec='`$ECHO "$archiver_list_spec" | $SED "$delay_single_quote_subst"`' +STRIP='`$ECHO "$STRIP" | $SED "$delay_single_quote_subst"`' +RANLIB='`$ECHO "$RANLIB" | $SED "$delay_single_quote_subst"`' +old_postinstall_cmds='`$ECHO "$old_postinstall_cmds" | $SED "$delay_single_quote_subst"`' +old_postuninstall_cmds='`$ECHO "$old_postuninstall_cmds" | $SED "$delay_single_quote_subst"`' +old_archive_cmds='`$ECHO "$old_archive_cmds" | $SED "$delay_single_quote_subst"`' +lock_old_archive_extraction='`$ECHO "$lock_old_archive_extraction" | $SED "$delay_single_quote_subst"`' +CC='`$ECHO "$CC" | $SED "$delay_single_quote_subst"`' +CFLAGS='`$ECHO "$CFLAGS" | $SED "$delay_single_quote_subst"`' +compiler='`$ECHO "$compiler" | $SED "$delay_single_quote_subst"`' +GCC='`$ECHO "$GCC" | $SED "$delay_single_quote_subst"`' +lt_cv_sys_global_symbol_pipe='`$ECHO "$lt_cv_sys_global_symbol_pipe" | $SED "$delay_single_quote_subst"`' +lt_cv_sys_global_symbol_to_cdecl='`$ECHO "$lt_cv_sys_global_symbol_to_cdecl" | $SED "$delay_single_quote_subst"`' +lt_cv_sys_global_symbol_to_import='`$ECHO "$lt_cv_sys_global_symbol_to_import" | $SED "$delay_single_quote_subst"`' +lt_cv_sys_global_symbol_to_c_name_address='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address" | $SED "$delay_single_quote_subst"`' +lt_cv_sys_global_symbol_to_c_name_address_lib_prefix='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address_lib_prefix" | $SED "$delay_single_quote_subst"`' +lt_cv_nm_interface='`$ECHO "$lt_cv_nm_interface" | $SED "$delay_single_quote_subst"`' +nm_file_list_spec='`$ECHO "$nm_file_list_spec" | $SED "$delay_single_quote_subst"`' +lt_sysroot='`$ECHO "$lt_sysroot" | $SED "$delay_single_quote_subst"`' +lt_cv_truncate_bin='`$ECHO "$lt_cv_truncate_bin" | $SED "$delay_single_quote_subst"`' +objdir='`$ECHO "$objdir" | $SED "$delay_single_quote_subst"`' +MAGIC_CMD='`$ECHO "$MAGIC_CMD" | $SED "$delay_single_quote_subst"`' +lt_prog_compiler_no_builtin_flag='`$ECHO "$lt_prog_compiler_no_builtin_flag" | $SED "$delay_single_quote_subst"`' +lt_prog_compiler_pic='`$ECHO "$lt_prog_compiler_pic" | $SED "$delay_single_quote_subst"`' +lt_prog_compiler_wl='`$ECHO "$lt_prog_compiler_wl" | $SED "$delay_single_quote_subst"`' +lt_prog_compiler_static='`$ECHO "$lt_prog_compiler_static" | $SED "$delay_single_quote_subst"`' +lt_cv_prog_compiler_c_o='`$ECHO "$lt_cv_prog_compiler_c_o" | $SED "$delay_single_quote_subst"`' +need_locks='`$ECHO "$need_locks" | $SED "$delay_single_quote_subst"`' +MANIFEST_TOOL='`$ECHO "$MANIFEST_TOOL" | $SED "$delay_single_quote_subst"`' +DSYMUTIL='`$ECHO "$DSYMUTIL" | $SED "$delay_single_quote_subst"`' +NMEDIT='`$ECHO "$NMEDIT" | $SED "$delay_single_quote_subst"`' +LIPO='`$ECHO "$LIPO" | $SED "$delay_single_quote_subst"`' +OTOOL='`$ECHO "$OTOOL" | $SED "$delay_single_quote_subst"`' +OTOOL64='`$ECHO "$OTOOL64" | $SED "$delay_single_quote_subst"`' +libext='`$ECHO "$libext" | $SED "$delay_single_quote_subst"`' +shrext_cmds='`$ECHO "$shrext_cmds" | $SED "$delay_single_quote_subst"`' +extract_expsyms_cmds='`$ECHO "$extract_expsyms_cmds" | $SED "$delay_single_quote_subst"`' +archive_cmds_need_lc='`$ECHO "$archive_cmds_need_lc" | $SED "$delay_single_quote_subst"`' +enable_shared_with_static_runtimes='`$ECHO "$enable_shared_with_static_runtimes" | $SED "$delay_single_quote_subst"`' +export_dynamic_flag_spec='`$ECHO "$export_dynamic_flag_spec" | $SED "$delay_single_quote_subst"`' +whole_archive_flag_spec='`$ECHO "$whole_archive_flag_spec" | $SED "$delay_single_quote_subst"`' +compiler_needs_object='`$ECHO "$compiler_needs_object" | $SED "$delay_single_quote_subst"`' +old_archive_from_new_cmds='`$ECHO "$old_archive_from_new_cmds" | $SED "$delay_single_quote_subst"`' +old_archive_from_expsyms_cmds='`$ECHO "$old_archive_from_expsyms_cmds" | $SED "$delay_single_quote_subst"`' +archive_cmds='`$ECHO "$archive_cmds" | $SED "$delay_single_quote_subst"`' +archive_expsym_cmds='`$ECHO "$archive_expsym_cmds" | $SED "$delay_single_quote_subst"`' +module_cmds='`$ECHO "$module_cmds" | $SED "$delay_single_quote_subst"`' +module_expsym_cmds='`$ECHO "$module_expsym_cmds" | $SED "$delay_single_quote_subst"`' +with_gnu_ld='`$ECHO "$with_gnu_ld" | $SED "$delay_single_quote_subst"`' +allow_undefined_flag='`$ECHO "$allow_undefined_flag" | $SED "$delay_single_quote_subst"`' +no_undefined_flag='`$ECHO "$no_undefined_flag" | $SED "$delay_single_quote_subst"`' +hardcode_libdir_flag_spec='`$ECHO "$hardcode_libdir_flag_spec" | $SED "$delay_single_quote_subst"`' +hardcode_libdir_separator='`$ECHO "$hardcode_libdir_separator" | $SED "$delay_single_quote_subst"`' +hardcode_direct='`$ECHO "$hardcode_direct" | $SED "$delay_single_quote_subst"`' +hardcode_direct_absolute='`$ECHO "$hardcode_direct_absolute" | $SED "$delay_single_quote_subst"`' +hardcode_minus_L='`$ECHO "$hardcode_minus_L" | $SED "$delay_single_quote_subst"`' +hardcode_shlibpath_var='`$ECHO "$hardcode_shlibpath_var" | $SED "$delay_single_quote_subst"`' +hardcode_automatic='`$ECHO "$hardcode_automatic" | $SED "$delay_single_quote_subst"`' +inherit_rpath='`$ECHO "$inherit_rpath" | $SED "$delay_single_quote_subst"`' +link_all_deplibs='`$ECHO "$link_all_deplibs" | $SED "$delay_single_quote_subst"`' +always_export_symbols='`$ECHO "$always_export_symbols" | $SED "$delay_single_quote_subst"`' +export_symbols_cmds='`$ECHO "$export_symbols_cmds" | $SED "$delay_single_quote_subst"`' +exclude_expsyms='`$ECHO "$exclude_expsyms" | $SED "$delay_single_quote_subst"`' +include_expsyms='`$ECHO "$include_expsyms" | $SED "$delay_single_quote_subst"`' +prelink_cmds='`$ECHO "$prelink_cmds" | $SED "$delay_single_quote_subst"`' +postlink_cmds='`$ECHO "$postlink_cmds" | $SED "$delay_single_quote_subst"`' +file_list_spec='`$ECHO "$file_list_spec" | $SED "$delay_single_quote_subst"`' +variables_saved_for_relink='`$ECHO "$variables_saved_for_relink" | $SED "$delay_single_quote_subst"`' +need_lib_prefix='`$ECHO "$need_lib_prefix" | $SED "$delay_single_quote_subst"`' +need_version='`$ECHO "$need_version" | $SED "$delay_single_quote_subst"`' +version_type='`$ECHO "$version_type" | $SED "$delay_single_quote_subst"`' +runpath_var='`$ECHO "$runpath_var" | $SED "$delay_single_quote_subst"`' +shlibpath_var='`$ECHO "$shlibpath_var" | $SED "$delay_single_quote_subst"`' +shlibpath_overrides_runpath='`$ECHO "$shlibpath_overrides_runpath" | $SED "$delay_single_quote_subst"`' +libname_spec='`$ECHO "$libname_spec" | $SED "$delay_single_quote_subst"`' +library_names_spec='`$ECHO "$library_names_spec" | $SED "$delay_single_quote_subst"`' +soname_spec='`$ECHO "$soname_spec" | $SED "$delay_single_quote_subst"`' +install_override_mode='`$ECHO "$install_override_mode" | $SED "$delay_single_quote_subst"`' +postinstall_cmds='`$ECHO "$postinstall_cmds" | $SED "$delay_single_quote_subst"`' +postuninstall_cmds='`$ECHO "$postuninstall_cmds" | $SED "$delay_single_quote_subst"`' +finish_cmds='`$ECHO "$finish_cmds" | $SED "$delay_single_quote_subst"`' +finish_eval='`$ECHO "$finish_eval" | $SED "$delay_single_quote_subst"`' +hardcode_into_libs='`$ECHO "$hardcode_into_libs" | $SED "$delay_single_quote_subst"`' +sys_lib_search_path_spec='`$ECHO "$sys_lib_search_path_spec" | $SED "$delay_single_quote_subst"`' +configure_time_dlsearch_path='`$ECHO "$configure_time_dlsearch_path" | $SED "$delay_single_quote_subst"`' +configure_time_lt_sys_library_path='`$ECHO "$configure_time_lt_sys_library_path" | $SED "$delay_single_quote_subst"`' +hardcode_action='`$ECHO "$hardcode_action" | $SED "$delay_single_quote_subst"`' +enable_dlopen='`$ECHO "$enable_dlopen" | $SED "$delay_single_quote_subst"`' +enable_dlopen_self='`$ECHO "$enable_dlopen_self" | $SED "$delay_single_quote_subst"`' +enable_dlopen_self_static='`$ECHO "$enable_dlopen_self_static" | $SED "$delay_single_quote_subst"`' +old_striplib='`$ECHO "$old_striplib" | $SED "$delay_single_quote_subst"`' +striplib='`$ECHO "$striplib" | $SED "$delay_single_quote_subst"`' +compiler_lib_search_dirs='`$ECHO "$compiler_lib_search_dirs" | $SED "$delay_single_quote_subst"`' +predep_objects='`$ECHO "$predep_objects" | $SED "$delay_single_quote_subst"`' +postdep_objects='`$ECHO "$postdep_objects" | $SED "$delay_single_quote_subst"`' +predeps='`$ECHO "$predeps" | $SED "$delay_single_quote_subst"`' +postdeps='`$ECHO "$postdeps" | $SED "$delay_single_quote_subst"`' +compiler_lib_search_path='`$ECHO "$compiler_lib_search_path" | $SED "$delay_single_quote_subst"`' +LD_CXX='`$ECHO "$LD_CXX" | $SED "$delay_single_quote_subst"`' +reload_flag_CXX='`$ECHO "$reload_flag_CXX" | $SED "$delay_single_quote_subst"`' +reload_cmds_CXX='`$ECHO "$reload_cmds_CXX" | $SED "$delay_single_quote_subst"`' +old_archive_cmds_CXX='`$ECHO "$old_archive_cmds_CXX" | $SED "$delay_single_quote_subst"`' +compiler_CXX='`$ECHO "$compiler_CXX" | $SED "$delay_single_quote_subst"`' +GCC_CXX='`$ECHO "$GCC_CXX" | $SED "$delay_single_quote_subst"`' +lt_prog_compiler_no_builtin_flag_CXX='`$ECHO "$lt_prog_compiler_no_builtin_flag_CXX" | $SED "$delay_single_quote_subst"`' +lt_prog_compiler_pic_CXX='`$ECHO "$lt_prog_compiler_pic_CXX" | $SED "$delay_single_quote_subst"`' +lt_prog_compiler_wl_CXX='`$ECHO "$lt_prog_compiler_wl_CXX" | $SED "$delay_single_quote_subst"`' +lt_prog_compiler_static_CXX='`$ECHO "$lt_prog_compiler_static_CXX" | $SED "$delay_single_quote_subst"`' +lt_cv_prog_compiler_c_o_CXX='`$ECHO "$lt_cv_prog_compiler_c_o_CXX" | $SED "$delay_single_quote_subst"`' +archive_cmds_need_lc_CXX='`$ECHO "$archive_cmds_need_lc_CXX" | $SED "$delay_single_quote_subst"`' +enable_shared_with_static_runtimes_CXX='`$ECHO "$enable_shared_with_static_runtimes_CXX" | $SED "$delay_single_quote_subst"`' +export_dynamic_flag_spec_CXX='`$ECHO "$export_dynamic_flag_spec_CXX" | $SED "$delay_single_quote_subst"`' +whole_archive_flag_spec_CXX='`$ECHO "$whole_archive_flag_spec_CXX" | $SED "$delay_single_quote_subst"`' +compiler_needs_object_CXX='`$ECHO "$compiler_needs_object_CXX" | $SED "$delay_single_quote_subst"`' +old_archive_from_new_cmds_CXX='`$ECHO "$old_archive_from_new_cmds_CXX" | $SED "$delay_single_quote_subst"`' +old_archive_from_expsyms_cmds_CXX='`$ECHO "$old_archive_from_expsyms_cmds_CXX" | $SED "$delay_single_quote_subst"`' +archive_cmds_CXX='`$ECHO "$archive_cmds_CXX" | $SED "$delay_single_quote_subst"`' +archive_expsym_cmds_CXX='`$ECHO "$archive_expsym_cmds_CXX" | $SED "$delay_single_quote_subst"`' +module_cmds_CXX='`$ECHO "$module_cmds_CXX" | $SED "$delay_single_quote_subst"`' +module_expsym_cmds_CXX='`$ECHO "$module_expsym_cmds_CXX" | $SED "$delay_single_quote_subst"`' +with_gnu_ld_CXX='`$ECHO "$with_gnu_ld_CXX" | $SED "$delay_single_quote_subst"`' +allow_undefined_flag_CXX='`$ECHO "$allow_undefined_flag_CXX" | $SED "$delay_single_quote_subst"`' +no_undefined_flag_CXX='`$ECHO "$no_undefined_flag_CXX" | $SED "$delay_single_quote_subst"`' +hardcode_libdir_flag_spec_CXX='`$ECHO "$hardcode_libdir_flag_spec_CXX" | $SED "$delay_single_quote_subst"`' +hardcode_libdir_separator_CXX='`$ECHO "$hardcode_libdir_separator_CXX" | $SED "$delay_single_quote_subst"`' +hardcode_direct_CXX='`$ECHO "$hardcode_direct_CXX" | $SED "$delay_single_quote_subst"`' +hardcode_direct_absolute_CXX='`$ECHO "$hardcode_direct_absolute_CXX" | $SED "$delay_single_quote_subst"`' +hardcode_minus_L_CXX='`$ECHO "$hardcode_minus_L_CXX" | $SED "$delay_single_quote_subst"`' +hardcode_shlibpath_var_CXX='`$ECHO "$hardcode_shlibpath_var_CXX" | $SED "$delay_single_quote_subst"`' +hardcode_automatic_CXX='`$ECHO "$hardcode_automatic_CXX" | $SED "$delay_single_quote_subst"`' +inherit_rpath_CXX='`$ECHO "$inherit_rpath_CXX" | $SED "$delay_single_quote_subst"`' +link_all_deplibs_CXX='`$ECHO "$link_all_deplibs_CXX" | $SED "$delay_single_quote_subst"`' +always_export_symbols_CXX='`$ECHO "$always_export_symbols_CXX" | $SED "$delay_single_quote_subst"`' +export_symbols_cmds_CXX='`$ECHO "$export_symbols_cmds_CXX" | $SED "$delay_single_quote_subst"`' +exclude_expsyms_CXX='`$ECHO "$exclude_expsyms_CXX" | $SED "$delay_single_quote_subst"`' +include_expsyms_CXX='`$ECHO "$include_expsyms_CXX" | $SED "$delay_single_quote_subst"`' +prelink_cmds_CXX='`$ECHO "$prelink_cmds_CXX" | $SED "$delay_single_quote_subst"`' +postlink_cmds_CXX='`$ECHO "$postlink_cmds_CXX" | $SED "$delay_single_quote_subst"`' +file_list_spec_CXX='`$ECHO "$file_list_spec_CXX" | $SED "$delay_single_quote_subst"`' +hardcode_action_CXX='`$ECHO "$hardcode_action_CXX" | $SED "$delay_single_quote_subst"`' +compiler_lib_search_dirs_CXX='`$ECHO "$compiler_lib_search_dirs_CXX" | $SED "$delay_single_quote_subst"`' +predep_objects_CXX='`$ECHO "$predep_objects_CXX" | $SED "$delay_single_quote_subst"`' +postdep_objects_CXX='`$ECHO "$postdep_objects_CXX" | $SED "$delay_single_quote_subst"`' +predeps_CXX='`$ECHO "$predeps_CXX" | $SED "$delay_single_quote_subst"`' +postdeps_CXX='`$ECHO "$postdeps_CXX" | $SED "$delay_single_quote_subst"`' +compiler_lib_search_path_CXX='`$ECHO "$compiler_lib_search_path_CXX" | $SED "$delay_single_quote_subst"`' + +LTCC='$LTCC' +LTCFLAGS='$LTCFLAGS' +compiler='$compiler_DEFAULT' + +# A function that is used when there is no print builtin or printf. +func_fallback_echo () +{ + eval 'cat <<_LTECHO_EOF +\$1 +_LTECHO_EOF' +} + +# Quote evaled strings. +for var in SHELL \ +ECHO \ +PATH_SEPARATOR \ +SED \ +GREP \ +EGREP \ +FGREP \ +LD \ +NM \ +LN_S \ +lt_SP2NL \ +lt_NL2SP \ +reload_flag \ +OBJDUMP \ +deplibs_check_method \ +file_magic_cmd \ +file_magic_glob \ +want_nocaseglob \ +DLLTOOL \ +sharedlib_from_linklib_cmd \ +AR \ +archiver_list_spec \ +STRIP \ +RANLIB \ +CC \ +CFLAGS \ +compiler \ +lt_cv_sys_global_symbol_pipe \ +lt_cv_sys_global_symbol_to_cdecl \ +lt_cv_sys_global_symbol_to_import \ +lt_cv_sys_global_symbol_to_c_name_address \ +lt_cv_sys_global_symbol_to_c_name_address_lib_prefix \ +lt_cv_nm_interface \ +nm_file_list_spec \ +lt_cv_truncate_bin \ +lt_prog_compiler_no_builtin_flag \ +lt_prog_compiler_pic \ +lt_prog_compiler_wl \ +lt_prog_compiler_static \ +lt_cv_prog_compiler_c_o \ +need_locks \ +MANIFEST_TOOL \ +DSYMUTIL \ +NMEDIT \ +LIPO \ +OTOOL \ +OTOOL64 \ +shrext_cmds \ +export_dynamic_flag_spec \ +whole_archive_flag_spec \ +compiler_needs_object \ +with_gnu_ld \ +allow_undefined_flag \ +no_undefined_flag \ +hardcode_libdir_flag_spec \ +hardcode_libdir_separator \ +exclude_expsyms \ +include_expsyms \ +file_list_spec \ +variables_saved_for_relink \ +libname_spec \ +library_names_spec \ +soname_spec \ +install_override_mode \ +finish_eval \ +old_striplib \ +striplib \ +compiler_lib_search_dirs \ +predep_objects \ +postdep_objects \ +predeps \ +postdeps \ +compiler_lib_search_path \ +LD_CXX \ +reload_flag_CXX \ +compiler_CXX \ +lt_prog_compiler_no_builtin_flag_CXX \ +lt_prog_compiler_pic_CXX \ +lt_prog_compiler_wl_CXX \ +lt_prog_compiler_static_CXX \ +lt_cv_prog_compiler_c_o_CXX \ +export_dynamic_flag_spec_CXX \ +whole_archive_flag_spec_CXX \ +compiler_needs_object_CXX \ +with_gnu_ld_CXX \ +allow_undefined_flag_CXX \ +no_undefined_flag_CXX \ +hardcode_libdir_flag_spec_CXX \ +hardcode_libdir_separator_CXX \ +exclude_expsyms_CXX \ +include_expsyms_CXX \ +file_list_spec_CXX \ +compiler_lib_search_dirs_CXX \ +predep_objects_CXX \ +postdep_objects_CXX \ +predeps_CXX \ +postdeps_CXX \ +compiler_lib_search_path_CXX; do + case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in + *[\\\\\\\`\\"\\\$]*) + eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes + ;; + *) + eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" + ;; + esac +done + +# Double-quote double-evaled strings. +for var in reload_cmds \ +old_postinstall_cmds \ +old_postuninstall_cmds \ +old_archive_cmds \ +extract_expsyms_cmds \ +old_archive_from_new_cmds \ +old_archive_from_expsyms_cmds \ +archive_cmds \ +archive_expsym_cmds \ +module_cmds \ +module_expsym_cmds \ +export_symbols_cmds \ +prelink_cmds \ +postlink_cmds \ +postinstall_cmds \ +postuninstall_cmds \ +finish_cmds \ +sys_lib_search_path_spec \ +configure_time_dlsearch_path \ +configure_time_lt_sys_library_path \ +reload_cmds_CXX \ +old_archive_cmds_CXX \ +old_archive_from_new_cmds_CXX \ +old_archive_from_expsyms_cmds_CXX \ +archive_cmds_CXX \ +archive_expsym_cmds_CXX \ +module_cmds_CXX \ +module_expsym_cmds_CXX \ +export_symbols_cmds_CXX \ +prelink_cmds_CXX \ +postlink_cmds_CXX; do + case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in + *[\\\\\\\`\\"\\\$]*) + eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes + ;; + *) + eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" + ;; + esac +done + +ac_aux_dir='$ac_aux_dir' + +# See if we are running on zsh, and set the options that allow our +# commands through without removal of \ escapes INIT. +if test -n "\${ZSH_VERSION+set}"; then + setopt NO_GLOB_SUBST +fi + + + PACKAGE='$PACKAGE' + VERSION='$VERSION' + RM='$RM' + ofile='$ofile' + + + + + + +_ACEOF + +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 + +# Handling of arguments. +for ac_config_target in $ac_config_targets +do + case $ac_config_target in + "config.h") CONFIG_HEADERS="$CONFIG_HEADERS config.h" ;; + "depfiles") CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;; + "libtool") CONFIG_COMMANDS="$CONFIG_COMMANDS libtool" ;; + "Makefile") CONFIG_FILES="$CONFIG_FILES Makefile" ;; + + *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;; + esac +done + + +# If the user did not use the arguments to specify the items to instantiate, +# then the envvar interface is used. Set only those that are not. +# We use the long form for the default assignment because of an extremely +# bizarre bug on SunOS 4.1.3. +if $ac_need_defaults; then + test "${CONFIG_FILES+set}" = set || CONFIG_FILES=$config_files + test "${CONFIG_HEADERS+set}" = set || CONFIG_HEADERS=$config_headers + test "${CONFIG_COMMANDS+set}" = set || CONFIG_COMMANDS=$config_commands +fi + +# Have a temporary directory for convenience. Make it in the build tree +# simply because there is no reason against having it here, and in addition, +# creating and moving files from /tmp can sometimes cause problems. +# Hook for its removal unless debugging. +# Note that there is a small window in which the directory will not be cleaned: +# after its creation but before its name has been assigned to `$tmp'. +$debug || +{ + tmp= ac_tmp= + trap 'exit_status=$? + : "${ac_tmp:=$tmp}" + { test ! -d "$ac_tmp" || rm -fr "$ac_tmp"; } && exit $exit_status +' 0 + trap 'as_fn_exit 1' 1 2 13 15 +} +# Create a (secure) tmp directory for tmp files. + +{ + tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` && + test -d "$tmp" +} || +{ + tmp=./conf$$-$RANDOM + (umask 077 && mkdir "$tmp") +} || as_fn_error $? "cannot create a temporary directory in ." "$LINENO" 5 +ac_tmp=$tmp + +# Set up the scripts for CONFIG_FILES section. +# No need to generate them if there are no CONFIG_FILES. +# This happens for instance with `./config.status config.h'. +if test -n "$CONFIG_FILES"; then + + +ac_cr=`echo X | tr X '\015'` +# On cygwin, bash can eat \r inside `` if the user requested igncr. +# But we know of no other shell where ac_cr would be empty at this +# point, so we can use a bashism as a fallback. +if test "x$ac_cr" = x; then + eval ac_cr=\$\'\\r\' +fi +ac_cs_awk_cr=`$AWK 'BEGIN { print "a\rb" }' /dev/null` +if test "$ac_cs_awk_cr" = "a${ac_cr}b"; then + ac_cs_awk_cr='\\r' +else + ac_cs_awk_cr=$ac_cr +fi + +echo 'BEGIN {' >"$ac_tmp/subs1.awk" && +_ACEOF + + +{ + echo "cat >conf$$subs.awk <<_ACEOF" && + echo "$ac_subst_vars" | sed 's/.*/&!$&$ac_delim/' && + echo "_ACEOF" +} >conf$$subs.sh || + as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 +ac_delim_num=`echo "$ac_subst_vars" | grep -c '^'` +ac_delim='%!_!# ' +for ac_last_try in false false false false false :; do + . ./conf$$subs.sh || + as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 + + ac_delim_n=`sed -n "s/.*$ac_delim\$/X/p" conf$$subs.awk | grep -c X` + if test $ac_delim_n = $ac_delim_num; then + break + elif $ac_last_try; then + as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 + else + ac_delim="$ac_delim!$ac_delim _$ac_delim!! " + fi +done +rm -f conf$$subs.sh + +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +cat >>"\$ac_tmp/subs1.awk" <<\\_ACAWK && +_ACEOF +sed -n ' +h +s/^/S["/; s/!.*/"]=/ +p +g +s/^[^!]*!// +:repl +t repl +s/'"$ac_delim"'$// +t delim +:nl +h +s/\(.\{148\}\)..*/\1/ +t more1 +s/["\\]/\\&/g; s/^/"/; s/$/\\n"\\/ +p +n +b repl +:more1 +s/["\\]/\\&/g; s/^/"/; s/$/"\\/ +p +g +s/.\{148\}// +t nl +:delim +h +s/\(.\{148\}\)..*/\1/ +t more2 +s/["\\]/\\&/g; s/^/"/; s/$/"/ +p +b +:more2 +s/["\\]/\\&/g; s/^/"/; s/$/"\\/ +p +g +s/.\{148\}// +t delim +' >$CONFIG_STATUS || ac_write_fail=1 +rm -f conf$$subs.awk +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +_ACAWK +cat >>"\$ac_tmp/subs1.awk" <<_ACAWK && + for (key in S) S_is_set[key] = 1 + FS = "" + +} +{ + line = $ 0 + nfields = split(line, field, "@") + substed = 0 + len = length(field[1]) + for (i = 2; i < nfields; i++) { + key = field[i] + keylen = length(key) + if (S_is_set[key]) { + value = S[key] + line = substr(line, 1, len) "" value "" substr(line, len + keylen + 3) + len += length(value) + length(field[++i]) + substed = 1 + } else + len += 1 + keylen + } + + print line +} + +_ACAWK +_ACEOF +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +if sed "s/$ac_cr//" < /dev/null > /dev/null 2>&1; then + sed "s/$ac_cr\$//; s/$ac_cr/$ac_cs_awk_cr/g" +else + cat +fi < "$ac_tmp/subs1.awk" > "$ac_tmp/subs.awk" \ + || as_fn_error $? "could not setup config files machinery" "$LINENO" 5 +_ACEOF + +# VPATH may cause trouble with some makes, so we remove sole $(srcdir), +# ${srcdir} and @srcdir@ entries from VPATH if srcdir is ".", strip leading and +# trailing colons and then remove the whole line if VPATH becomes empty +# (actually we leave an empty line to preserve line numbers). +if test "x$srcdir" = x.; then + ac_vpsub='/^[ ]*VPATH[ ]*=[ ]*/{ +h +s/// +s/^/:/ +s/[ ]*$/:/ +s/:\$(srcdir):/:/g +s/:\${srcdir}:/:/g +s/:@srcdir@:/:/g +s/^:*// +s/:*$// +x +s/\(=[ ]*\).*/\1/ +G +s/\n// +s/^[^=]*=[ ]*$// +}' +fi + +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +fi # test -n "$CONFIG_FILES" + +# Set up the scripts for CONFIG_HEADERS section. +# No need to generate them if there are no CONFIG_HEADERS. +# This happens for instance with `./config.status Makefile'. +if test -n "$CONFIG_HEADERS"; then +cat >"$ac_tmp/defines.awk" <<\_ACAWK || +BEGIN { +_ACEOF + +# Transform confdefs.h into an awk script `defines.awk', embedded as +# here-document in config.status, that substitutes the proper values into +# config.h.in to produce config.h. + +# Create a delimiter string that does not exist in confdefs.h, to ease +# handling of long lines. +ac_delim='%!_!# ' +for ac_last_try in false false :; do + ac_tt=`sed -n "/$ac_delim/p" confdefs.h` + if test -z "$ac_tt"; then + break + elif $ac_last_try; then + as_fn_error $? "could not make $CONFIG_HEADERS" "$LINENO" 5 + else + ac_delim="$ac_delim!$ac_delim _$ac_delim!! " + fi +done + +# For the awk script, D is an array of macro values keyed by name, +# likewise P contains macro parameters if any. Preserve backslash +# newline sequences. + +ac_word_re=[_$as_cr_Letters][_$as_cr_alnum]* +sed -n ' +s/.\{148\}/&'"$ac_delim"'/g +t rset +:rset +s/^[ ]*#[ ]*define[ ][ ]*/ / +t def +d +:def +s/\\$// +t bsnl +s/["\\]/\\&/g +s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ +D["\1"]=" \3"/p +s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2"/p +d +:bsnl +s/["\\]/\\&/g +s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ +D["\1"]=" \3\\\\\\n"\\/p +t cont +s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2\\\\\\n"\\/p +t cont +d +:cont +n +s/.\{148\}/&'"$ac_delim"'/g +t clear +:clear +s/\\$// +t bsnlc +s/["\\]/\\&/g; s/^/"/; s/$/"/p +d +:bsnlc +s/["\\]/\\&/g; s/^/"/; s/$/\\\\\\n"\\/p +b cont +' >$CONFIG_STATUS || ac_write_fail=1 + +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 + for (key in D) D_is_set[key] = 1 + FS = "" +} +/^[\t ]*#[\t ]*(define|undef)[\t ]+$ac_word_re([\t (]|\$)/ { + line = \$ 0 + split(line, arg, " ") + if (arg[1] == "#") { + defundef = arg[2] + mac1 = arg[3] + } else { + defundef = substr(arg[1], 2) + mac1 = arg[2] + } + split(mac1, mac2, "(") #) + macro = mac2[1] + prefix = substr(line, 1, index(line, defundef) - 1) + if (D_is_set[macro]) { + # Preserve the white space surrounding the "#". + print prefix "define", macro P[macro] D[macro] + next + } else { + # Replace #undef with comments. This is necessary, for example, + # in the case of _POSIX_SOURCE, which is predefined and required + # on some systems where configure will not decide to define it. + if (defundef == "undef") { + print "/*", prefix defundef, macro, "*/" + next + } + } +} +{ print } +_ACAWK +_ACEOF +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 + as_fn_error $? "could not setup config headers machinery" "$LINENO" 5 +fi # test -n "$CONFIG_HEADERS" + + +eval set X " :F $CONFIG_FILES :H $CONFIG_HEADERS :C $CONFIG_COMMANDS" +shift +for ac_tag +do + case $ac_tag in + :[FHLC]) ac_mode=$ac_tag; continue;; + esac + case $ac_mode$ac_tag in + :[FHL]*:*);; + :L* | :C*:*) as_fn_error $? "invalid tag \`$ac_tag'" "$LINENO" 5;; + :[FH]-) ac_tag=-:-;; + :[FH]*) ac_tag=$ac_tag:$ac_tag.in;; + esac + ac_save_IFS=$IFS + IFS=: + set x $ac_tag + IFS=$ac_save_IFS + shift + ac_file=$1 + shift + + case $ac_mode in + :L) ac_source=$1;; + :[FH]) + ac_file_inputs= + for ac_f + do + case $ac_f in + -) ac_f="$ac_tmp/stdin";; + *) # Look for the file first in the build tree, then in the source tree + # (if the path is not absolute). The absolute path cannot be DOS-style, + # because $ac_f cannot contain `:'. + test -f "$ac_f" || + case $ac_f in + [\\/$]*) false;; + *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";; + esac || + as_fn_error 1 "cannot find input file: \`$ac_f'" "$LINENO" 5;; + esac + case $ac_f in *\'*) ac_f=`$as_echo "$ac_f" | sed "s/'/'\\\\\\\\''/g"`;; esac + as_fn_append ac_file_inputs " '$ac_f'" + done + + # Let's still pretend it is `configure' which instantiates (i.e., don't + # use $as_me), people would be surprised to read: + # /* config.h. Generated by config.status. */ + configure_input='Generated from '` + $as_echo "$*" | sed 's|^[^:]*/||;s|:[^:]*/|, |g' + `' by configure.' + if test x"$ac_file" != x-; then + configure_input="$ac_file. $configure_input" + { $as_echo "$as_me:${as_lineno-$LINENO}: creating $ac_file" >&5 +$as_echo "$as_me: creating $ac_file" >&6;} + fi + # Neutralize special characters interpreted by sed in replacement strings. + case $configure_input in #( + *\&* | *\|* | *\\* ) + ac_sed_conf_input=`$as_echo "$configure_input" | + sed 's/[\\\\&|]/\\\\&/g'`;; #( + *) ac_sed_conf_input=$configure_input;; + esac + + case $ac_tag in + *:-:* | *:-) cat >"$ac_tmp/stdin" \ + || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; + esac + ;; + esac + + ac_dir=`$as_dirname -- "$ac_file" || +$as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$ac_file" : 'X\(//\)[^/]' \| \ + X"$ac_file" : 'X\(//\)$' \| \ + X"$ac_file" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$ac_file" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + as_dir="$ac_dir"; as_fn_mkdir_p + ac_builddir=. + +case "$ac_dir" in +.) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; +*) + ac_dir_suffix=/`$as_echo "$ac_dir" | sed 's|^\.[\\/]||'` + # A ".." for each directory in $ac_dir_suffix. + ac_top_builddir_sub=`$as_echo "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` + case $ac_top_builddir_sub in + "") ac_top_builddir_sub=. ac_top_build_prefix= ;; + *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; + esac ;; +esac +ac_abs_top_builddir=$ac_pwd +ac_abs_builddir=$ac_pwd$ac_dir_suffix +# for backward compatibility: +ac_top_builddir=$ac_top_build_prefix + +case $srcdir in + .) # We are building in place. + ac_srcdir=. + ac_top_srcdir=$ac_top_builddir_sub + ac_abs_top_srcdir=$ac_pwd ;; + [\\/]* | ?:[\\/]* ) # Absolute name. + ac_srcdir=$srcdir$ac_dir_suffix; + ac_top_srcdir=$srcdir + ac_abs_top_srcdir=$srcdir ;; + *) # Relative name. + ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix + ac_top_srcdir=$ac_top_build_prefix$srcdir + ac_abs_top_srcdir=$ac_pwd/$srcdir ;; +esac +ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix + + + case $ac_mode in + :F) + # + # CONFIG_FILE + # + + case $INSTALL in + [\\/$]* | ?:[\\/]* ) ac_INSTALL=$INSTALL ;; + *) ac_INSTALL=$ac_top_build_prefix$INSTALL ;; + esac + ac_MKDIR_P=$MKDIR_P + case $MKDIR_P in + [\\/$]* | ?:[\\/]* ) ;; + */*) ac_MKDIR_P=$ac_top_build_prefix$MKDIR_P ;; + esac +_ACEOF + +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +# If the template does not know about datarootdir, expand it. +# FIXME: This hack should be removed a few years after 2.60. +ac_datarootdir_hack=; ac_datarootdir_seen= +ac_sed_dataroot=' +/datarootdir/ { + p + q +} +/@datadir@/p +/@docdir@/p +/@infodir@/p +/@localedir@/p +/@mandir@/p' +case `eval "sed -n \"\$ac_sed_dataroot\" $ac_file_inputs"` in +*datarootdir*) ac_datarootdir_seen=yes;; +*@datadir@*|*@docdir@*|*@infodir@*|*@localedir@*|*@mandir@*) + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&5 +$as_echo "$as_me: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&2;} +_ACEOF +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 + ac_datarootdir_hack=' + s&@datadir@&$datadir&g + s&@docdir@&$docdir&g + s&@infodir@&$infodir&g + s&@localedir@&$localedir&g + s&@mandir@&$mandir&g + s&\\\${datarootdir}&$datarootdir&g' ;; +esac +_ACEOF + +# Neutralize VPATH when `$srcdir' = `.'. +# Shell code in configure.ac might set extrasub. +# FIXME: do we really want to maintain this feature? +cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 +ac_sed_extra="$ac_vpsub +$extrasub +_ACEOF +cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 +:t +/@[a-zA-Z_][a-zA-Z_0-9]*@/!b +s|@configure_input@|$ac_sed_conf_input|;t t +s&@top_builddir@&$ac_top_builddir_sub&;t t +s&@top_build_prefix@&$ac_top_build_prefix&;t t +s&@srcdir@&$ac_srcdir&;t t +s&@abs_srcdir@&$ac_abs_srcdir&;t t +s&@top_srcdir@&$ac_top_srcdir&;t t +s&@abs_top_srcdir@&$ac_abs_top_srcdir&;t t +s&@builddir@&$ac_builddir&;t t +s&@abs_builddir@&$ac_abs_builddir&;t t +s&@abs_top_builddir@&$ac_abs_top_builddir&;t t +s&@INSTALL@&$ac_INSTALL&;t t +s&@MKDIR_P@&$ac_MKDIR_P&;t t +$ac_datarootdir_hack +" +eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$ac_tmp/subs.awk" \ + >$ac_tmp/out || as_fn_error $? "could not create $ac_file" "$LINENO" 5 + +test -z "$ac_datarootdir_hack$ac_datarootdir_seen" && + { ac_out=`sed -n '/\${datarootdir}/p' "$ac_tmp/out"`; test -n "$ac_out"; } && + { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' \ + "$ac_tmp/out"`; test -z "$ac_out"; } && + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file contains a reference to the variable \`datarootdir' +which seems to be undefined. Please make sure it is defined" >&5 +$as_echo "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir' +which seems to be undefined. Please make sure it is defined" >&2;} + + rm -f "$ac_tmp/stdin" + case $ac_file in + -) cat "$ac_tmp/out" && rm -f "$ac_tmp/out";; + *) rm -f "$ac_file" && mv "$ac_tmp/out" "$ac_file";; + esac \ + || as_fn_error $? "could not create $ac_file" "$LINENO" 5 + ;; + :H) + # + # CONFIG_HEADER + # + if test x"$ac_file" != x-; then + { + $as_echo "/* $configure_input */" \ + && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" + } >"$ac_tmp/config.h" \ + || as_fn_error $? "could not create $ac_file" "$LINENO" 5 + if diff "$ac_file" "$ac_tmp/config.h" >/dev/null 2>&1; then + { $as_echo "$as_me:${as_lineno-$LINENO}: $ac_file is unchanged" >&5 +$as_echo "$as_me: $ac_file is unchanged" >&6;} + else + rm -f "$ac_file" + mv "$ac_tmp/config.h" "$ac_file" \ + || as_fn_error $? "could not create $ac_file" "$LINENO" 5 + fi + else + $as_echo "/* $configure_input */" \ + && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" \ + || as_fn_error $? "could not create -" "$LINENO" 5 + fi +# Compute "$ac_file"'s index in $config_headers. +_am_arg="$ac_file" +_am_stamp_count=1 +for _am_header in $config_headers :; do + case $_am_header in + $_am_arg | $_am_arg:* ) + break ;; + * ) + _am_stamp_count=`expr $_am_stamp_count + 1` ;; + esac +done +echo "timestamp for $_am_arg" >`$as_dirname -- "$_am_arg" || +$as_expr X"$_am_arg" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$_am_arg" : 'X\(//\)[^/]' \| \ + X"$_am_arg" : 'X\(//\)$' \| \ + X"$_am_arg" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$_am_arg" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'`/stamp-h$_am_stamp_count + ;; + + :C) { $as_echo "$as_me:${as_lineno-$LINENO}: executing $ac_file commands" >&5 +$as_echo "$as_me: executing $ac_file commands" >&6;} + ;; + esac + + + case $ac_file$ac_mode in + "depfiles":C) test x"$AMDEP_TRUE" != x"" || { + # Older Autoconf quotes --file arguments for eval, but not when files + # are listed without --file. Let's play safe and only enable the eval + # if we detect the quoting. + # TODO: see whether this extra hack can be removed once we start + # requiring Autoconf 2.70 or later. + case $CONFIG_FILES in #( + *\'*) : + eval set x "$CONFIG_FILES" ;; #( + *) : + set x $CONFIG_FILES ;; #( + *) : + ;; +esac + shift + # Used to flag and report bootstrapping failures. + am_rc=0 + for am_mf + do + # Strip MF so we end up with the name of the file. + am_mf=`$as_echo "$am_mf" | sed -e 's/:.*$//'` + # Check whether this is an Automake generated Makefile which includes + # dependency-tracking related rules and includes. + # Grep'ing the whole file directly is not great: AIX grep has a line + # limit of 2048, but all sed's we know have understand at least 4000. + sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \ + || continue + am_dirpart=`$as_dirname -- "$am_mf" || +$as_expr X"$am_mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$am_mf" : 'X\(//\)[^/]' \| \ + X"$am_mf" : 'X\(//\)$' \| \ + X"$am_mf" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$am_mf" | + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + s//\1/ + q + } + /^X\(\/\/\)[^/].*/{ + s//\1/ + q + } + /^X\(\/\/\)$/{ + s//\1/ + q + } + /^X\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + am_filepart=`$as_basename -- "$am_mf" || +$as_expr X/"$am_mf" : '.*/\([^/][^/]*\)/*$' \| \ + X"$am_mf" : 'X\(//\)$' \| \ + X"$am_mf" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X/"$am_mf" | + sed '/^.*\/\([^/][^/]*\)\/*$/{ + s//\1/ + q + } + /^X\/\(\/\/\)$/{ + s//\1/ + q + } + /^X\/\(\/\).*/{ + s//\1/ + q + } + s/.*/./; q'` + { echo "$as_me:$LINENO: cd "$am_dirpart" \ + && sed -e '/# am--include-marker/d' "$am_filepart" \ + | $MAKE -f - am--depfiles" >&5 + (cd "$am_dirpart" \ + && sed -e '/# am--include-marker/d' "$am_filepart" \ + | $MAKE -f - am--depfiles) >&5 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } || am_rc=$? + done + if test $am_rc -ne 0; then + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "Something went wrong bootstrapping makefile fragments + for automatic dependency tracking. Try re-running configure with the + '--disable-dependency-tracking' option to at least be able to build + the package (albeit without support for automatic dependency tracking). +See \`config.log' for more details" "$LINENO" 5; } + fi + { am_dirpart=; unset am_dirpart;} + { am_filepart=; unset am_filepart;} + { am_mf=; unset am_mf;} + { am_rc=; unset am_rc;} + rm -f conftest-deps.mk +} + ;; + "libtool":C) + + # See if we are running on zsh, and set the options that allow our + # commands through without removal of \ escapes. + if test -n "${ZSH_VERSION+set}"; then + setopt NO_GLOB_SUBST + fi + + cfgfile=${ofile}T + trap "$RM \"$cfgfile\"; exit 1" 1 2 15 + $RM "$cfgfile" + + cat <<_LT_EOF >> "$cfgfile" +#! $SHELL +# Generated automatically by $as_me ($PACKAGE) $VERSION +# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: +# NOTE: Changes made to this file will be lost: look at ltmain.sh. + +# Provide generalized library-building support services. +# Written by Gordon Matzigkeit, 1996 + +# Copyright (C) 2014 Free Software Foundation, Inc. +# This is free software; see the source for copying conditions. There is NO +# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + +# GNU Libtool 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 2 of of the License, or +# (at your option) any later version. +# +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program or library that is built +# using GNU Libtool, you may include this file under the same +# distribution terms that you use for the rest of that program. +# +# GNU Libtool 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 this program. If not, see . + + +# The names of the tagged configurations supported by this script. +available_tags='CXX ' + +# Configured defaults for sys_lib_dlsearch_path munging. +: \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"} + +# ### BEGIN LIBTOOL CONFIG + +# Which release of libtool.m4 was used? +macro_version=$macro_version +macro_revision=$macro_revision + +# Whether or not to build shared libraries. +build_libtool_libs=$enable_shared + +# Whether or not to build static libraries. +build_old_libs=$enable_static + +# What type of objects to build. +pic_mode=$pic_mode + +# Whether or not to optimize for fast installation. +fast_install=$enable_fast_install + +# Shared archive member basename,for filename based shared library versioning on AIX. +shared_archive_member_spec=$shared_archive_member_spec + +# Shell to use when invoking shell scripts. +SHELL=$lt_SHELL + +# An echo program that protects backslashes. +ECHO=$lt_ECHO + +# The PATH separator for the build system. +PATH_SEPARATOR=$lt_PATH_SEPARATOR + +# The host system. +host_alias=$host_alias +host=$host +host_os=$host_os + +# The build system. +build_alias=$build_alias +build=$build +build_os=$build_os + +# A sed program that does not truncate output. +SED=$lt_SED + +# Sed that helps us avoid accidentally triggering echo(1) options like -n. +Xsed="\$SED -e 1s/^X//" + +# A grep program that handles long lines. +GREP=$lt_GREP + +# An ERE matcher. +EGREP=$lt_EGREP + +# A literal string matcher. +FGREP=$lt_FGREP + +# A BSD- or MS-compatible name lister. +NM=$lt_NM + +# Whether we need soft or hard links. +LN_S=$lt_LN_S + +# What is the maximum length of a command? +max_cmd_len=$max_cmd_len + +# Object file suffix (normally "o"). +objext=$ac_objext + +# Executable file suffix (normally ""). +exeext=$exeext + +# whether the shell understands "unset". +lt_unset=$lt_unset + +# turn spaces into newlines. +SP2NL=$lt_lt_SP2NL + +# turn newlines into spaces. +NL2SP=$lt_lt_NL2SP + +# convert \$build file names to \$host format. +to_host_file_cmd=$lt_cv_to_host_file_cmd + +# convert \$build files to toolchain format. +to_tool_file_cmd=$lt_cv_to_tool_file_cmd + +# An object symbol dumper. +OBJDUMP=$lt_OBJDUMP + +# Method to check whether dependent libraries are shared objects. +deplibs_check_method=$lt_deplibs_check_method + +# Command to use when deplibs_check_method = "file_magic". +file_magic_cmd=$lt_file_magic_cmd + +# How to find potential files when deplibs_check_method = "file_magic". +file_magic_glob=$lt_file_magic_glob + +# Find potential files using nocaseglob when deplibs_check_method = "file_magic". +want_nocaseglob=$lt_want_nocaseglob + +# DLL creation program. +DLLTOOL=$lt_DLLTOOL + +# Command to associate shared and link libraries. +sharedlib_from_linklib_cmd=$lt_sharedlib_from_linklib_cmd + +# The archiver. +AR=$lt_AR + +# Flags to create an archive (by configure). +lt_ar_flags=$lt_ar_flags + +# Flags to create an archive. +AR_FLAGS=\${ARFLAGS-"\$lt_ar_flags"} + +# How to feed a file listing to the archiver. +archiver_list_spec=$lt_archiver_list_spec + +# A symbol stripping program. +STRIP=$lt_STRIP + +# Commands used to install an old-style archive. +RANLIB=$lt_RANLIB +old_postinstall_cmds=$lt_old_postinstall_cmds +old_postuninstall_cmds=$lt_old_postuninstall_cmds + +# Whether to use a lock for old archive extraction. +lock_old_archive_extraction=$lock_old_archive_extraction + +# A C compiler. +LTCC=$lt_CC + +# LTCC compiler flags. +LTCFLAGS=$lt_CFLAGS + +# Take the output of nm and produce a listing of raw symbols and C names. +global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe + +# Transform the output of nm in a proper C declaration. +global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl + +# Transform the output of nm into a list of symbols to manually relocate. +global_symbol_to_import=$lt_lt_cv_sys_global_symbol_to_import + +# Transform the output of nm in a C name address pair. +global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address + +# Transform the output of nm in a C name address pair when lib prefix is needed. +global_symbol_to_c_name_address_lib_prefix=$lt_lt_cv_sys_global_symbol_to_c_name_address_lib_prefix + +# The name lister interface. +nm_interface=$lt_lt_cv_nm_interface + +# Specify filename containing input files for \$NM. +nm_file_list_spec=$lt_nm_file_list_spec + +# The root where to search for dependent libraries,and where our libraries should be installed. +lt_sysroot=$lt_sysroot + +# Command to truncate a binary pipe. +lt_truncate_bin=$lt_lt_cv_truncate_bin + +# The name of the directory that contains temporary libtool files. +objdir=$objdir + +# Used to examine libraries when file_magic_cmd begins with "file". +MAGIC_CMD=$MAGIC_CMD + +# Must we lock files when doing compilation? +need_locks=$lt_need_locks + +# Manifest tool. +MANIFEST_TOOL=$lt_MANIFEST_TOOL + +# Tool to manipulate archived DWARF debug symbol files on Mac OS X. +DSYMUTIL=$lt_DSYMUTIL + +# Tool to change global to local symbols on Mac OS X. +NMEDIT=$lt_NMEDIT + +# Tool to manipulate fat objects and archives on Mac OS X. +LIPO=$lt_LIPO + +# ldd/readelf like tool for Mach-O binaries on Mac OS X. +OTOOL=$lt_OTOOL + +# ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4. +OTOOL64=$lt_OTOOL64 + +# Old archive suffix (normally "a"). +libext=$libext + +# Shared library suffix (normally ".so"). +shrext_cmds=$lt_shrext_cmds + +# The commands to extract the exported symbol list from a shared archive. +extract_expsyms_cmds=$lt_extract_expsyms_cmds + +# Variables whose values should be saved in libtool wrapper scripts and +# restored at link time. +variables_saved_for_relink=$lt_variables_saved_for_relink + +# Do we need the "lib" prefix for modules? +need_lib_prefix=$need_lib_prefix + +# Do we need a version for libraries? +need_version=$need_version + +# Library versioning type. +version_type=$version_type + +# Shared library runtime path variable. +runpath_var=$runpath_var + +# Shared library path variable. +shlibpath_var=$shlibpath_var + +# Is shlibpath searched before the hard-coded library search path? +shlibpath_overrides_runpath=$shlibpath_overrides_runpath + +# Format of library name prefix. +libname_spec=$lt_libname_spec + +# List of archive names. First name is the real one, the rest are links. +# The last name is the one that the linker finds with -lNAME +library_names_spec=$lt_library_names_spec + +# The coded name of the library, if different from the real name. +soname_spec=$lt_soname_spec + +# Permission mode override for installation of shared libraries. +install_override_mode=$lt_install_override_mode + +# Command to use after installation of a shared archive. +postinstall_cmds=$lt_postinstall_cmds + +# Command to use after uninstallation of a shared archive. +postuninstall_cmds=$lt_postuninstall_cmds + +# Commands used to finish a libtool library installation in a directory. +finish_cmds=$lt_finish_cmds + +# As "finish_cmds", except a single script fragment to be evaled but +# not shown. +finish_eval=$lt_finish_eval + +# Whether we should hardcode library paths into libraries. +hardcode_into_libs=$hardcode_into_libs + +# Compile-time system search path for libraries. +sys_lib_search_path_spec=$lt_sys_lib_search_path_spec + +# Detected run-time system search path for libraries. +sys_lib_dlsearch_path_spec=$lt_configure_time_dlsearch_path + +# Explicit LT_SYS_LIBRARY_PATH set during ./configure time. +configure_time_lt_sys_library_path=$lt_configure_time_lt_sys_library_path + +# Whether dlopen is supported. +dlopen_support=$enable_dlopen + +# Whether dlopen of programs is supported. +dlopen_self=$enable_dlopen_self + +# Whether dlopen of statically linked programs is supported. +dlopen_self_static=$enable_dlopen_self_static + +# Commands to strip libraries. +old_striplib=$lt_old_striplib +striplib=$lt_striplib + + +# The linker used to build libraries. +LD=$lt_LD + +# How to create reloadable object files. +reload_flag=$lt_reload_flag +reload_cmds=$lt_reload_cmds + +# Commands used to build an old-style archive. +old_archive_cmds=$lt_old_archive_cmds + +# A language specific compiler. +CC=$lt_compiler + +# Is the compiler the GNU compiler? +with_gcc=$GCC + +# Compiler flag to turn off builtin functions. +no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag + +# Additional compiler flags for building library objects. +pic_flag=$lt_lt_prog_compiler_pic + +# How to pass a linker flag through the compiler. +wl=$lt_lt_prog_compiler_wl + +# Compiler flag to prevent dynamic linking. +link_static_flag=$lt_lt_prog_compiler_static + +# Does compiler simultaneously support -c and -o options? +compiler_c_o=$lt_lt_cv_prog_compiler_c_o + +# Whether or not to add -lc for building shared libraries. +build_libtool_need_lc=$archive_cmds_need_lc + +# Whether or not to disallow shared libs when runtime libs are static. +allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes + +# Compiler flag to allow reflexive dlopens. +export_dynamic_flag_spec=$lt_export_dynamic_flag_spec + +# Compiler flag to generate shared objects directly from archives. +whole_archive_flag_spec=$lt_whole_archive_flag_spec + +# Whether the compiler copes with passing no objects directly. +compiler_needs_object=$lt_compiler_needs_object + +# Create an old-style archive from a shared archive. +old_archive_from_new_cmds=$lt_old_archive_from_new_cmds + +# Create a temporary old-style archive to link instead of a shared archive. +old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds + +# Commands used to build a shared archive. +archive_cmds=$lt_archive_cmds +archive_expsym_cmds=$lt_archive_expsym_cmds + +# Commands used to build a loadable module if different from building +# a shared archive. +module_cmds=$lt_module_cmds +module_expsym_cmds=$lt_module_expsym_cmds + +# Whether we are building with GNU ld or not. +with_gnu_ld=$lt_with_gnu_ld + +# Flag that allows shared libraries with undefined symbols to be built. +allow_undefined_flag=$lt_allow_undefined_flag + +# Flag that enforces no undefined symbols. +no_undefined_flag=$lt_no_undefined_flag + +# Flag to hardcode \$libdir into a binary during linking. +# This must work even if \$libdir does not exist +hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec + +# Whether we need a single "-rpath" flag with a separated argument. +hardcode_libdir_separator=$lt_hardcode_libdir_separator + +# Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes +# DIR into the resulting binary. +hardcode_direct=$hardcode_direct + +# Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes +# DIR into the resulting binary and the resulting library dependency is +# "absolute",i.e impossible to change by setting \$shlibpath_var if the +# library is relocated. +hardcode_direct_absolute=$hardcode_direct_absolute + +# Set to "yes" if using the -LDIR flag during linking hardcodes DIR +# into the resulting binary. +hardcode_minus_L=$hardcode_minus_L + +# Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR +# into the resulting binary. +hardcode_shlibpath_var=$hardcode_shlibpath_var + +# Set to "yes" if building a shared library automatically hardcodes DIR +# into the library and all subsequent libraries and executables linked +# against it. +hardcode_automatic=$hardcode_automatic + +# Set to yes if linker adds runtime paths of dependent libraries +# to runtime path list. +inherit_rpath=$inherit_rpath + +# Whether libtool must link a program against all its dependency libraries. +link_all_deplibs=$link_all_deplibs + +# Set to "yes" if exported symbols are required. +always_export_symbols=$always_export_symbols + +# The commands to list exported symbols. +export_symbols_cmds=$lt_export_symbols_cmds + +# Symbols that should not be listed in the preloaded symbols. +exclude_expsyms=$lt_exclude_expsyms + +# Symbols that must always be exported. +include_expsyms=$lt_include_expsyms + +# Commands necessary for linking programs (against libraries) with templates. +prelink_cmds=$lt_prelink_cmds + +# Commands necessary for finishing linking programs. +postlink_cmds=$lt_postlink_cmds + +# Specify filename containing input files. +file_list_spec=$lt_file_list_spec + +# How to hardcode a shared library path into an executable. +hardcode_action=$hardcode_action + +# The directories searched by this compiler when creating a shared library. +compiler_lib_search_dirs=$lt_compiler_lib_search_dirs + +# Dependencies to place before and after the objects being linked to +# create a shared library. +predep_objects=$lt_predep_objects +postdep_objects=$lt_postdep_objects +predeps=$lt_predeps +postdeps=$lt_postdeps + +# The library search path used internally by the compiler when linking +# a shared library. +compiler_lib_search_path=$lt_compiler_lib_search_path + +# ### END LIBTOOL CONFIG + +_LT_EOF + + cat <<'_LT_EOF' >> "$cfgfile" + +# ### BEGIN FUNCTIONS SHARED WITH CONFIGURE + +# func_munge_path_list VARIABLE PATH +# ----------------------------------- +# VARIABLE is name of variable containing _space_ separated list of +# directories to be munged by the contents of PATH, which is string +# having a format: +# "DIR[:DIR]:" +# string "DIR[ DIR]" will be prepended to VARIABLE +# ":DIR[:DIR]" +# string "DIR[ DIR]" will be appended to VARIABLE +# "DIRP[:DIRP]::[DIRA:]DIRA" +# string "DIRP[ DIRP]" will be prepended to VARIABLE and string +# "DIRA[ DIRA]" will be appended to VARIABLE +# "DIR[:DIR]" +# VARIABLE will be replaced by "DIR[ DIR]" +func_munge_path_list () +{ + case x$2 in + x) + ;; + *:) + eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\" + ;; + x:*) + eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\" + ;; + *::*) + eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" + eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\" + ;; + *) + eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\" + ;; + esac +} + + +# Calculate cc_basename. Skip known compiler wrappers and cross-prefix. +func_cc_basename () +{ + for cc_temp in $*""; do + case $cc_temp in + compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; + distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; + \-*) ;; + *) break;; + esac + done + func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` +} + + +# ### END FUNCTIONS SHARED WITH CONFIGURE + +_LT_EOF + + case $host_os in + aix3*) + cat <<\_LT_EOF >> "$cfgfile" +# AIX sometimes has problems with the GCC collect2 program. For some +# reason, if we set the COLLECT_NAMES environment variable, the problems +# vanish in a puff of smoke. +if test set != "${COLLECT_NAMES+set}"; then + COLLECT_NAMES= + export COLLECT_NAMES +fi +_LT_EOF + ;; + esac + + +ltmain=$ac_aux_dir/ltmain.sh + + + # We use sed instead of cat because bash on DJGPP gets confused if + # if finds mixed CR/LF and LF-only lines. Since sed operates in + # text mode, it properly converts lines to CR/LF. This bash problem + # is reportedly fixed, but why not run on old versions too? + sed '$q' "$ltmain" >> "$cfgfile" \ + || (rm -f "$cfgfile"; exit 1) + + mv -f "$cfgfile" "$ofile" || + (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") + chmod +x "$ofile" + + + cat <<_LT_EOF >> "$ofile" + +# ### BEGIN LIBTOOL TAG CONFIG: CXX + +# The linker used to build libraries. +LD=$lt_LD_CXX + +# How to create reloadable object files. +reload_flag=$lt_reload_flag_CXX +reload_cmds=$lt_reload_cmds_CXX + +# Commands used to build an old-style archive. +old_archive_cmds=$lt_old_archive_cmds_CXX + +# A language specific compiler. +CC=$lt_compiler_CXX + +# Is the compiler the GNU compiler? +with_gcc=$GCC_CXX + +# Compiler flag to turn off builtin functions. +no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag_CXX + +# Additional compiler flags for building library objects. +pic_flag=$lt_lt_prog_compiler_pic_CXX + +# How to pass a linker flag through the compiler. +wl=$lt_lt_prog_compiler_wl_CXX + +# Compiler flag to prevent dynamic linking. +link_static_flag=$lt_lt_prog_compiler_static_CXX + +# Does compiler simultaneously support -c and -o options? +compiler_c_o=$lt_lt_cv_prog_compiler_c_o_CXX + +# Whether or not to add -lc for building shared libraries. +build_libtool_need_lc=$archive_cmds_need_lc_CXX + +# Whether or not to disallow shared libs when runtime libs are static. +allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes_CXX + +# Compiler flag to allow reflexive dlopens. +export_dynamic_flag_spec=$lt_export_dynamic_flag_spec_CXX + +# Compiler flag to generate shared objects directly from archives. +whole_archive_flag_spec=$lt_whole_archive_flag_spec_CXX + +# Whether the compiler copes with passing no objects directly. +compiler_needs_object=$lt_compiler_needs_object_CXX + +# Create an old-style archive from a shared archive. +old_archive_from_new_cmds=$lt_old_archive_from_new_cmds_CXX + +# Create a temporary old-style archive to link instead of a shared archive. +old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds_CXX + +# Commands used to build a shared archive. +archive_cmds=$lt_archive_cmds_CXX +archive_expsym_cmds=$lt_archive_expsym_cmds_CXX + +# Commands used to build a loadable module if different from building +# a shared archive. +module_cmds=$lt_module_cmds_CXX +module_expsym_cmds=$lt_module_expsym_cmds_CXX + +# Whether we are building with GNU ld or not. +with_gnu_ld=$lt_with_gnu_ld_CXX + +# Flag that allows shared libraries with undefined symbols to be built. +allow_undefined_flag=$lt_allow_undefined_flag_CXX + +# Flag that enforces no undefined symbols. +no_undefined_flag=$lt_no_undefined_flag_CXX + +# Flag to hardcode \$libdir into a binary during linking. +# This must work even if \$libdir does not exist +hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec_CXX + +# Whether we need a single "-rpath" flag with a separated argument. +hardcode_libdir_separator=$lt_hardcode_libdir_separator_CXX + +# Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes +# DIR into the resulting binary. +hardcode_direct=$hardcode_direct_CXX + +# Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes +# DIR into the resulting binary and the resulting library dependency is +# "absolute",i.e impossible to change by setting \$shlibpath_var if the +# library is relocated. +hardcode_direct_absolute=$hardcode_direct_absolute_CXX + +# Set to "yes" if using the -LDIR flag during linking hardcodes DIR +# into the resulting binary. +hardcode_minus_L=$hardcode_minus_L_CXX + +# Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR +# into the resulting binary. +hardcode_shlibpath_var=$hardcode_shlibpath_var_CXX + +# Set to "yes" if building a shared library automatically hardcodes DIR +# into the library and all subsequent libraries and executables linked +# against it. +hardcode_automatic=$hardcode_automatic_CXX + +# Set to yes if linker adds runtime paths of dependent libraries +# to runtime path list. +inherit_rpath=$inherit_rpath_CXX + +# Whether libtool must link a program against all its dependency libraries. +link_all_deplibs=$link_all_deplibs_CXX + +# Set to "yes" if exported symbols are required. +always_export_symbols=$always_export_symbols_CXX + +# The commands to list exported symbols. +export_symbols_cmds=$lt_export_symbols_cmds_CXX + +# Symbols that should not be listed in the preloaded symbols. +exclude_expsyms=$lt_exclude_expsyms_CXX + +# Symbols that must always be exported. +include_expsyms=$lt_include_expsyms_CXX + +# Commands necessary for linking programs (against libraries) with templates. +prelink_cmds=$lt_prelink_cmds_CXX + +# Commands necessary for finishing linking programs. +postlink_cmds=$lt_postlink_cmds_CXX + +# Specify filename containing input files. +file_list_spec=$lt_file_list_spec_CXX + +# How to hardcode a shared library path into an executable. +hardcode_action=$hardcode_action_CXX + +# The directories searched by this compiler when creating a shared library. +compiler_lib_search_dirs=$lt_compiler_lib_search_dirs_CXX + +# Dependencies to place before and after the objects being linked to +# create a shared library. +predep_objects=$lt_predep_objects_CXX +postdep_objects=$lt_postdep_objects_CXX +predeps=$lt_predeps_CXX +postdeps=$lt_postdeps_CXX + +# The library search path used internally by the compiler when linking +# a shared library. +compiler_lib_search_path=$lt_compiler_lib_search_path_CXX + +# ### END LIBTOOL TAG CONFIG: CXX +_LT_EOF + + ;; + + esac +done # for ac_tag + + +as_fn_exit 0 +_ACEOF +ac_clean_files=$ac_clean_files_save + +test $ac_write_fail = 0 || + as_fn_error $? "write failure creating $CONFIG_STATUS" "$LINENO" 5 + + +# configure is writing to config.log, and then calls config.status. +# config.status does its own redirection, appending to config.log. +# Unfortunately, on DOS this fails, as config.log is still kept open +# by configure, so config.status won't be able to write to it; its +# output is simply discarded. So we exec the FD to /dev/null, +# effectively closing config.log, so it can be properly (re)opened and +# appended to by config.status. When coming back to configure, we +# need to make the FD available again. +if test "$no_create" != yes; then + ac_cs_success=: + ac_config_status_args= + test "$silent" = yes && + ac_config_status_args="$ac_config_status_args --quiet" + exec 5>/dev/null + $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false + exec 5>>config.log + # Use ||, not &&, to avoid exiting from the if with $? = 1, which + # would make configure fail if this is the last instruction. + $ac_cs_success || as_fn_exit 1 +fi +if test -n "$ac_unrecognized_opts" && test "$enable_option_checking" != no; then + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: unrecognized options: $ac_unrecognized_opts" >&5 +$as_echo "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2;} +fi + diff --git a/TMessagesProj/jni/libtgvoip2/configure.ac b/TMessagesProj/jni/libtgvoip2/configure.ac new file mode 100644 index 000000000..8a3df4d02 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/configure.ac @@ -0,0 +1,125 @@ +# -*- Autoconf -*- +# Process this file with autoconf to produce a configure script. + +# Define version information +m4_define([libtgvoip_major_version], 2) +m4_define([libtgvoip_minor_version], 4) +m4_define([libtgvoip_patch_version], 4) +m4_define([libtgvoip_version],[libtgvoip_major_version.libtgvoip_minor_version.libtgvoip_patch_version]) + +AC_PREREQ([2.69]) +AC_INIT([libtgvoip], [libtgvoip_version], [https://github.com/grishka/libtgvoip/issues]) +AC_CONFIG_SRCDIR([config.h.in]) +AC_CONFIG_HEADERS([config.h]) +AM_INIT_AUTOMAKE([subdir-objects]) +AM_SILENT_RULES([yes]) +LT_INIT + +PKG_INSTALLDIR + +# Checks for programs. +AC_PROG_CXX +AC_PROG_CC +AC_PROG_OBJCXX +AM_PROG_AS +AC_PROG_RANLIB + +# Checks for libraries. +AC_CHECK_LIB([crypto], [SHA1], [], [AC_MSG_FAILURE([libssl-dev is required but not found])]) +AC_CHECK_LIB([m], [floorf]) +AC_CHECK_LIB([opus], [opus_decoder_create], [], [AC_MSG_FAILURE([libopus-dev is required but not found])]) +AC_CHECK_LIB([pthread], [pthread_create]) + +AC_CANONICAL_HOST + +AC_SUBST(LIBTGVOIP_MAJOR_VERSION, libtgvoip_major_version) +AC_SUBST(LIBTGVOIP_MINOR_VERSION, libtgvoip_minor_version) +AC_SUBST(LIBTGVOIP_PATCH_VERSION, libtgvoip_patch_version) + +AS_CASE([$host_cpu], + [i?86], [cpu_x86=yes], + [x86_64], [cpu_x86=yes], + [arm*], [cpu_arm=yes], + [AS_ECHO("!! WARNING: libtgvoip wasn't tested with your CPU architecture ($host_cpu)")] +) +AS_CASE([$host_cpu], + [armv7*], [cpu_armv7=yes] +) +AS_ECHO("Detected CPU: $host_cpu") +AM_CONDITIONAL(TARGET_CPU_X86, test "x$cpu_x86" == xyes) +AM_CONDITIONAL(TARGET_CPU_ARM, test "x$cpu_arm" == xyes) +AM_CONDITIONAL(TARGET_CPU_ARMV7, test "x$cpu_armv7" == xyes) +AS_ECHO("Detected OS: $host_os") + +AS_CASE([$host_os], + [darwin*], [os_osx=yes] +) +AM_CONDITIONAL(TARGET_OS_OSX, test "x$os_osx" == xyes) + +AC_ARG_ENABLE([audio-callback], [AS_HELP_STRING([--enable-audio-callback], [enable callback-based audio I/O])], [], [enable_audio_callback=no]) +AM_CONDITIONAL(ENABLE_AUDIO_CALLBACK, test "x$enable_audio_callback" == xyes) + +AS_IF([test "x$os_osx" != xyes && test "x$enable_audio_callback" != xyes], [ # Linux + AC_CHECK_LIB([dl], [dlopen]) + + AC_ARG_WITH([pulse], [AS_HELP_STRING([--without-pulse], [disable PulseAudio support])], [], [with_pulse=yes]) + AC_ARG_WITH([alsa], [AS_HELP_STRING([--without-alsa], [disable ALSA support])], [], [with_alsa=yes]) + + AS_IF([test "x$with_pulse" == xno && test "x$with_alsa" == xno], [ + AC_MSG_FAILURE([You can only disable either ALSA or PulseAudio, not both]); + ]) + + AS_IF([test "x$with_pulse" != xno], [ + AC_CHECK_LIB([pulse], [pa_context_new], [ + AS_ECHO_N( ) # what is the proper way to check for a library without linking it? + ], [ + AC_MSG_FAILURE([libpulse-dev is required during build, but you don't have it installed. Use --without-pulse to disable PulseAudio support.]) + ]) + ], [ + AC_DEFINE([WITHOUT_PULSE], [1], [Define to disable PulseAudio support]) + ]) + + AS_IF([test "x$with_alsa" != xno], [ + AC_CHECK_LIB([asound], [snd_pcm_open], [ + AS_ECHO_N( ) # what is the proper way to check for a library without linking it? + ], [ + AC_MSG_FAILURE([libasound-dev is required during build, but you don't have it installed. Use --without-alsa to disable ALSA support.]) + ]) + ], [ + AC_DEFINE([WITHOUT_ALSA], [1], [Define to disable ALSA support]) + ]) +]); + +AM_CONDITIONAL(WITH_PULSE, test "x$with_pulse" == xyes) +AM_CONDITIONAL(WITH_ALSA, test "x$with_alsa" == xyes) + +AC_ARG_ENABLE([dsp], [AS_HELP_STRING([--disable-dsp], [disable signal processing (echo cancellation, noise suppression, and automatic gain control)])], [], [enable_dsp=yes]) +AM_CONDITIONAL(ENABLE_DSP, test "x$enable_dsp" == xyes) + +# Checks for header files. +AC_FUNC_ALLOCA +AC_CHECK_HEADERS([arpa/inet.h float.h malloc.h netdb.h netinet/in.h stddef.h stdint.h stdlib.h string.h sys/ioctl.h sys/socket.h sys/time.h unistd.h wchar.h]) + +# Checks for typedefs, structures, and compiler characteristics. +AC_CHECK_HEADER_STDBOOL +AC_C_INLINE +AC_TYPE_INT16_T +AC_TYPE_INT32_T +AC_TYPE_INT64_T +AC_TYPE_INT8_T +AC_TYPE_SIZE_T +AC_TYPE_SSIZE_T +AC_TYPE_UINT16_T +AC_TYPE_UINT32_T +AC_TYPE_UINT64_T +AC_TYPE_UINT8_T +AC_CHECK_TYPES([ptrdiff_t]) + +# Checks for library functions. +AC_FUNC_ERROR_AT_LINE +AC_FUNC_MALLOC +AC_FUNC_REALLOC +AC_CHECK_FUNCS([clock_gettime floor gettimeofday inet_ntoa memmove memset select socket sqrt strcasecmp strchr strerror strncasecmp strstr strtol strtoul uname]) + +AC_CONFIG_FILES([Makefile tgvoip.pc]) +AC_OUTPUT diff --git a/TMessagesProj/jni/libtgvoip2/depcomp b/TMessagesProj/jni/libtgvoip2/depcomp new file mode 100644 index 000000000..65cbf7093 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/depcomp @@ -0,0 +1,791 @@ +#! /bin/sh +# depcomp - compile a program generating dependencies as side-effects + +scriptversion=2018-03-07.03; # UTC + +# Copyright (C) 1999-2018 Free Software Foundation, Inc. + +# This program 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 2, or (at your option) +# any later version. + +# This program 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 this program. If not, see . + +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + +# Originally written by Alexandre Oliva . + +case $1 in + '') + echo "$0: No command. Try '$0 --help' for more information." 1>&2 + exit 1; + ;; + -h | --h*) + cat <<\EOF +Usage: depcomp [--help] [--version] PROGRAM [ARGS] + +Run PROGRAMS ARGS to compile a file, generating dependencies +as side-effects. + +Environment variables: + depmode Dependency tracking mode. + source Source file read by 'PROGRAMS ARGS'. + object Object file output by 'PROGRAMS ARGS'. + DEPDIR directory where to store dependencies. + depfile Dependency file to output. + tmpdepfile Temporary file to use when outputting dependencies. + libtool Whether libtool is used (yes/no). + +Report bugs to . +EOF + exit $? + ;; + -v | --v*) + echo "depcomp $scriptversion" + exit $? + ;; +esac + +# Get the directory component of the given path, and save it in the +# global variables '$dir'. Note that this directory component will +# be either empty or ending with a '/' character. This is deliberate. +set_dir_from () +{ + case $1 in + */*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;; + *) dir=;; + esac +} + +# Get the suffix-stripped basename of the given path, and save it the +# global variable '$base'. +set_base_from () +{ + base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'` +} + +# If no dependency file was actually created by the compiler invocation, +# we still have to create a dummy depfile, to avoid errors with the +# Makefile "include basename.Plo" scheme. +make_dummy_depfile () +{ + echo "#dummy" > "$depfile" +} + +# Factor out some common post-processing of the generated depfile. +# Requires the auxiliary global variable '$tmpdepfile' to be set. +aix_post_process_depfile () +{ + # If the compiler actually managed to produce a dependency file, + # post-process it. + if test -f "$tmpdepfile"; then + # Each line is of the form 'foo.o: dependency.h'. + # Do two passes, one to just change these to + # $object: dependency.h + # and one to simply output + # dependency.h: + # which is needed to avoid the deleted-header problem. + { sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile" + sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile" + } > "$depfile" + rm -f "$tmpdepfile" + else + make_dummy_depfile + fi +} + +# A tabulation character. +tab=' ' +# A newline character. +nl=' +' +# Character ranges might be problematic outside the C locale. +# These definitions help. +upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ +lower=abcdefghijklmnopqrstuvwxyz +digits=0123456789 +alpha=${upper}${lower} + +if test -z "$depmode" || test -z "$source" || test -z "$object"; then + echo "depcomp: Variables source, object and depmode must be set" 1>&2 + exit 1 +fi + +# Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. +depfile=${depfile-`echo "$object" | + sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} +tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} + +rm -f "$tmpdepfile" + +# Avoid interferences from the environment. +gccflag= dashmflag= + +# Some modes work just like other modes, but use different flags. We +# parameterize here, but still list the modes in the big case below, +# to make depend.m4 easier to write. Note that we *cannot* use a case +# here, because this file can only contain one case statement. +if test "$depmode" = hp; then + # HP compiler uses -M and no extra arg. + gccflag=-M + depmode=gcc +fi + +if test "$depmode" = dashXmstdout; then + # This is just like dashmstdout with a different argument. + dashmflag=-xM + depmode=dashmstdout +fi + +cygpath_u="cygpath -u -f -" +if test "$depmode" = msvcmsys; then + # This is just like msvisualcpp but w/o cygpath translation. + # Just convert the backslash-escaped backslashes to single forward + # slashes to satisfy depend.m4 + cygpath_u='sed s,\\\\,/,g' + depmode=msvisualcpp +fi + +if test "$depmode" = msvc7msys; then + # This is just like msvc7 but w/o cygpath translation. + # Just convert the backslash-escaped backslashes to single forward + # slashes to satisfy depend.m4 + cygpath_u='sed s,\\\\,/,g' + depmode=msvc7 +fi + +if test "$depmode" = xlc; then + # IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information. + gccflag=-qmakedep=gcc,-MF + depmode=gcc +fi + +case "$depmode" in +gcc3) +## gcc 3 implements dependency tracking that does exactly what +## we want. Yay! Note: for some reason libtool 1.4 doesn't like +## it if -MD -MP comes after the -MF stuff. Hmm. +## Unfortunately, FreeBSD c89 acceptance of flags depends upon +## the command line argument order; so add the flags where they +## appear in depend2.am. Note that the slowdown incurred here +## affects only configure: in makefiles, %FASTDEP% shortcuts this. + for arg + do + case $arg in + -c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;; + *) set fnord "$@" "$arg" ;; + esac + shift # fnord + shift # $arg + done + "$@" + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile" + exit $stat + fi + mv "$tmpdepfile" "$depfile" + ;; + +gcc) +## Note that this doesn't just cater to obsosete pre-3.x GCC compilers. +## but also to in-use compilers like IMB xlc/xlC and the HP C compiler. +## (see the conditional assignment to $gccflag above). +## There are various ways to get dependency output from gcc. Here's +## why we pick this rather obscure method: +## - Don't want to use -MD because we'd like the dependencies to end +## up in a subdir. Having to rename by hand is ugly. +## (We might end up doing this anyway to support other compilers.) +## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like +## -MM, not -M (despite what the docs say). Also, it might not be +## supported by the other compilers which use the 'gcc' depmode. +## - Using -M directly means running the compiler twice (even worse +## than renaming). + if test -z "$gccflag"; then + gccflag=-MD, + fi + "$@" -Wp,"$gccflag$tmpdepfile" + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile" + exit $stat + fi + rm -f "$depfile" + echo "$object : \\" > "$depfile" + # The second -e expression handles DOS-style file names with drive + # letters. + sed -e 's/^[^:]*: / /' \ + -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" +## This next piece of magic avoids the "deleted header file" problem. +## The problem is that when a header file which appears in a .P file +## is deleted, the dependency causes make to die (because there is +## typically no way to rebuild the header). We avoid this by adding +## dummy dependencies for each header file. Too bad gcc doesn't do +## this for us directly. +## Some versions of gcc put a space before the ':'. On the theory +## that the space means something, we add a space to the output as +## well. hp depmode also adds that space, but also prefixes the VPATH +## to the object. Take care to not repeat it in the output. +## Some versions of the HPUX 10.20 sed can't process this invocation +## correctly. Breaking it into two sed invocations is a workaround. + tr ' ' "$nl" < "$tmpdepfile" \ + | sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \ + | sed -e 's/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +hp) + # This case exists only to let depend.m4 do its work. It works by + # looking at the text of this script. This case will never be run, + # since it is checked for above. + exit 1 + ;; + +sgi) + if test "$libtool" = yes; then + "$@" "-Wp,-MDupdate,$tmpdepfile" + else + "$@" -MDupdate "$tmpdepfile" + fi + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile" + exit $stat + fi + rm -f "$depfile" + + if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files + echo "$object : \\" > "$depfile" + # Clip off the initial element (the dependent). Don't try to be + # clever and replace this with sed code, as IRIX sed won't handle + # lines with more than a fixed number of characters (4096 in + # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; + # the IRIX cc adds comments like '#:fec' to the end of the + # dependency line. + tr ' ' "$nl" < "$tmpdepfile" \ + | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \ + | tr "$nl" ' ' >> "$depfile" + echo >> "$depfile" + # The second pass generates a dummy entry for each header file. + tr ' ' "$nl" < "$tmpdepfile" \ + | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ + >> "$depfile" + else + make_dummy_depfile + fi + rm -f "$tmpdepfile" + ;; + +xlc) + # This case exists only to let depend.m4 do its work. It works by + # looking at the text of this script. This case will never be run, + # since it is checked for above. + exit 1 + ;; + +aix) + # The C for AIX Compiler uses -M and outputs the dependencies + # in a .u file. In older versions, this file always lives in the + # current directory. Also, the AIX compiler puts '$object:' at the + # start of each line; $object doesn't have directory information. + # Version 6 uses the directory in both cases. + set_dir_from "$object" + set_base_from "$object" + if test "$libtool" = yes; then + tmpdepfile1=$dir$base.u + tmpdepfile2=$base.u + tmpdepfile3=$dir.libs/$base.u + "$@" -Wc,-M + else + tmpdepfile1=$dir$base.u + tmpdepfile2=$dir$base.u + tmpdepfile3=$dir$base.u + "$@" -M + fi + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" + exit $stat + fi + + for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" + do + test -f "$tmpdepfile" && break + done + aix_post_process_depfile + ;; + +tcc) + # tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26 + # FIXME: That version still under development at the moment of writing. + # Make that this statement remains true also for stable, released + # versions. + # It will wrap lines (doesn't matter whether long or short) with a + # trailing '\', as in: + # + # foo.o : \ + # foo.c \ + # foo.h \ + # + # It will put a trailing '\' even on the last line, and will use leading + # spaces rather than leading tabs (at least since its commit 0394caf7 + # "Emit spaces for -MD"). + "$@" -MD -MF "$tmpdepfile" + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile" + exit $stat + fi + rm -f "$depfile" + # Each non-empty line is of the form 'foo.o : \' or ' dep.h \'. + # We have to change lines of the first kind to '$object: \'. + sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile" + # And for each line of the second kind, we have to emit a 'dep.h:' + # dummy dependency, to avoid the deleted-header problem. + sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile" + rm -f "$tmpdepfile" + ;; + +## The order of this option in the case statement is important, since the +## shell code in configure will try each of these formats in the order +## listed in this file. A plain '-MD' option would be understood by many +## compilers, so we must ensure this comes after the gcc and icc options. +pgcc) + # Portland's C compiler understands '-MD'. + # Will always output deps to 'file.d' where file is the root name of the + # source file under compilation, even if file resides in a subdirectory. + # The object file name does not affect the name of the '.d' file. + # pgcc 10.2 will output + # foo.o: sub/foo.c sub/foo.h + # and will wrap long lines using '\' : + # foo.o: sub/foo.c ... \ + # sub/foo.h ... \ + # ... + set_dir_from "$object" + # Use the source, not the object, to determine the base name, since + # that's sadly what pgcc will do too. + set_base_from "$source" + tmpdepfile=$base.d + + # For projects that build the same source file twice into different object + # files, the pgcc approach of using the *source* file root name can cause + # problems in parallel builds. Use a locking strategy to avoid stomping on + # the same $tmpdepfile. + lockdir=$base.d-lock + trap " + echo '$0: caught signal, cleaning up...' >&2 + rmdir '$lockdir' + exit 1 + " 1 2 13 15 + numtries=100 + i=$numtries + while test $i -gt 0; do + # mkdir is a portable test-and-set. + if mkdir "$lockdir" 2>/dev/null; then + # This process acquired the lock. + "$@" -MD + stat=$? + # Release the lock. + rmdir "$lockdir" + break + else + # If the lock is being held by a different process, wait + # until the winning process is done or we timeout. + while test -d "$lockdir" && test $i -gt 0; do + sleep 1 + i=`expr $i - 1` + done + fi + i=`expr $i - 1` + done + trap - 1 2 13 15 + if test $i -le 0; then + echo "$0: failed to acquire lock after $numtries attempts" >&2 + echo "$0: check lockdir '$lockdir'" >&2 + exit 1 + fi + + if test $stat -ne 0; then + rm -f "$tmpdepfile" + exit $stat + fi + rm -f "$depfile" + # Each line is of the form `foo.o: dependent.h', + # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. + # Do two passes, one to just change these to + # `$object: dependent.h' and one to simply `dependent.h:'. + sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" + # Some versions of the HPUX 10.20 sed can't process this invocation + # correctly. Breaking it into two sed invocations is a workaround. + sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \ + | sed -e 's/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +hp2) + # The "hp" stanza above does not work with aCC (C++) and HP's ia64 + # compilers, which have integrated preprocessors. The correct option + # to use with these is +Maked; it writes dependencies to a file named + # 'foo.d', which lands next to the object file, wherever that + # happens to be. + # Much of this is similar to the tru64 case; see comments there. + set_dir_from "$object" + set_base_from "$object" + if test "$libtool" = yes; then + tmpdepfile1=$dir$base.d + tmpdepfile2=$dir.libs/$base.d + "$@" -Wc,+Maked + else + tmpdepfile1=$dir$base.d + tmpdepfile2=$dir$base.d + "$@" +Maked + fi + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile1" "$tmpdepfile2" + exit $stat + fi + + for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" + do + test -f "$tmpdepfile" && break + done + if test -f "$tmpdepfile"; then + sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile" + # Add 'dependent.h:' lines. + sed -ne '2,${ + s/^ *// + s/ \\*$// + s/$/:/ + p + }' "$tmpdepfile" >> "$depfile" + else + make_dummy_depfile + fi + rm -f "$tmpdepfile" "$tmpdepfile2" + ;; + +tru64) + # The Tru64 compiler uses -MD to generate dependencies as a side + # effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'. + # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put + # dependencies in 'foo.d' instead, so we check for that too. + # Subdirectories are respected. + set_dir_from "$object" + set_base_from "$object" + + if test "$libtool" = yes; then + # Libtool generates 2 separate objects for the 2 libraries. These + # two compilations output dependencies in $dir.libs/$base.o.d and + # in $dir$base.o.d. We have to check for both files, because + # one of the two compilations can be disabled. We should prefer + # $dir$base.o.d over $dir.libs/$base.o.d because the latter is + # automatically cleaned when .libs/ is deleted, while ignoring + # the former would cause a distcleancheck panic. + tmpdepfile1=$dir$base.o.d # libtool 1.5 + tmpdepfile2=$dir.libs/$base.o.d # Likewise. + tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504 + "$@" -Wc,-MD + else + tmpdepfile1=$dir$base.d + tmpdepfile2=$dir$base.d + tmpdepfile3=$dir$base.d + "$@" -MD + fi + + stat=$? + if test $stat -ne 0; then + rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" + exit $stat + fi + + for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" + do + test -f "$tmpdepfile" && break + done + # Same post-processing that is required for AIX mode. + aix_post_process_depfile + ;; + +msvc7) + if test "$libtool" = yes; then + showIncludes=-Wc,-showIncludes + else + showIncludes=-showIncludes + fi + "$@" $showIncludes > "$tmpdepfile" + stat=$? + grep -v '^Note: including file: ' "$tmpdepfile" + if test $stat -ne 0; then + rm -f "$tmpdepfile" + exit $stat + fi + rm -f "$depfile" + echo "$object : \\" > "$depfile" + # The first sed program below extracts the file names and escapes + # backslashes for cygpath. The second sed program outputs the file + # name when reading, but also accumulates all include files in the + # hold buffer in order to output them again at the end. This only + # works with sed implementations that can handle large buffers. + sed < "$tmpdepfile" -n ' +/^Note: including file: *\(.*\)/ { + s//\1/ + s/\\/\\\\/g + p +}' | $cygpath_u | sort -u | sed -n ' +s/ /\\ /g +s/\(.*\)/'"$tab"'\1 \\/p +s/.\(.*\) \\/\1:/ +H +$ { + s/.*/'"$tab"'/ + G + p +}' >> "$depfile" + echo >> "$depfile" # make sure the fragment doesn't end with a backslash + rm -f "$tmpdepfile" + ;; + +msvc7msys) + # This case exists only to let depend.m4 do its work. It works by + # looking at the text of this script. This case will never be run, + # since it is checked for above. + exit 1 + ;; + +#nosideeffect) + # This comment above is used by automake to tell side-effect + # dependency tracking mechanisms from slower ones. + +dashmstdout) + # Important note: in order to support this mode, a compiler *must* + # always write the preprocessed file to stdout, regardless of -o. + "$@" || exit $? + + # Remove the call to Libtool. + if test "$libtool" = yes; then + while test "X$1" != 'X--mode=compile'; do + shift + done + shift + fi + + # Remove '-o $object'. + IFS=" " + for arg + do + case $arg in + -o) + shift + ;; + $object) + shift + ;; + *) + set fnord "$@" "$arg" + shift # fnord + shift # $arg + ;; + esac + done + + test -z "$dashmflag" && dashmflag=-M + # Require at least two characters before searching for ':' + # in the target name. This is to cope with DOS-style filenames: + # a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise. + "$@" $dashmflag | + sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile" + rm -f "$depfile" + cat < "$tmpdepfile" > "$depfile" + # Some versions of the HPUX 10.20 sed can't process this sed invocation + # correctly. Breaking it into two sed invocations is a workaround. + tr ' ' "$nl" < "$tmpdepfile" \ + | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ + | sed -e 's/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +dashXmstdout) + # This case only exists to satisfy depend.m4. It is never actually + # run, as this mode is specially recognized in the preamble. + exit 1 + ;; + +makedepend) + "$@" || exit $? + # Remove any Libtool call + if test "$libtool" = yes; then + while test "X$1" != 'X--mode=compile'; do + shift + done + shift + fi + # X makedepend + shift + cleared=no eat=no + for arg + do + case $cleared in + no) + set ""; shift + cleared=yes ;; + esac + if test $eat = yes; then + eat=no + continue + fi + case "$arg" in + -D*|-I*) + set fnord "$@" "$arg"; shift ;; + # Strip any option that makedepend may not understand. Remove + # the object too, otherwise makedepend will parse it as a source file. + -arch) + eat=yes ;; + -*|$object) + ;; + *) + set fnord "$@" "$arg"; shift ;; + esac + done + obj_suffix=`echo "$object" | sed 's/^.*\././'` + touch "$tmpdepfile" + ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" + rm -f "$depfile" + # makedepend may prepend the VPATH from the source file name to the object. + # No need to regex-escape $object, excess matching of '.' is harmless. + sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile" + # Some versions of the HPUX 10.20 sed can't process the last invocation + # correctly. Breaking it into two sed invocations is a workaround. + sed '1,2d' "$tmpdepfile" \ + | tr ' ' "$nl" \ + | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ + | sed -e 's/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" "$tmpdepfile".bak + ;; + +cpp) + # Important note: in order to support this mode, a compiler *must* + # always write the preprocessed file to stdout. + "$@" || exit $? + + # Remove the call to Libtool. + if test "$libtool" = yes; then + while test "X$1" != 'X--mode=compile'; do + shift + done + shift + fi + + # Remove '-o $object'. + IFS=" " + for arg + do + case $arg in + -o) + shift + ;; + $object) + shift + ;; + *) + set fnord "$@" "$arg" + shift # fnord + shift # $arg + ;; + esac + done + + "$@" -E \ + | sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ + -e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ + | sed '$ s: \\$::' > "$tmpdepfile" + rm -f "$depfile" + echo "$object : \\" > "$depfile" + cat < "$tmpdepfile" >> "$depfile" + sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +msvisualcpp) + # Important note: in order to support this mode, a compiler *must* + # always write the preprocessed file to stdout. + "$@" || exit $? + + # Remove the call to Libtool. + if test "$libtool" = yes; then + while test "X$1" != 'X--mode=compile'; do + shift + done + shift + fi + + IFS=" " + for arg + do + case "$arg" in + -o) + shift + ;; + $object) + shift + ;; + "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") + set fnord "$@" + shift + shift + ;; + *) + set fnord "$@" "$arg" + shift + shift + ;; + esac + done + "$@" -E 2>/dev/null | + sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile" + rm -f "$depfile" + echo "$object : \\" > "$depfile" + sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile" + echo "$tab" >> "$depfile" + sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile" + rm -f "$tmpdepfile" + ;; + +msvcmsys) + # This case exists only to let depend.m4 do its work. It works by + # looking at the text of this script. This case will never be run, + # since it is checked for above. + exit 1 + ;; + +none) + exec "$@" + ;; + +*) + echo "Unknown depmode $depmode" 1>&2 + exit 1 + ;; +esac + +exit 0 + +# Local Variables: +# mode: shell-script +# sh-indentation: 2 +# eval: (add-hook 'before-save-hook 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-time-zone: "UTC0" +# time-stamp-end: "; # UTC" +# End: diff --git a/TMessagesProj/jni/libtgvoip2/install-sh b/TMessagesProj/jni/libtgvoip2/install-sh new file mode 100644 index 000000000..8175c640f --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/install-sh @@ -0,0 +1,518 @@ +#!/bin/sh +# install - install a program, script, or datafile + +scriptversion=2018-03-11.20; # UTC + +# This originates from X11R5 (mit/util/scripts/install.sh), which was +# later released in X11R6 (xc/config/util/install.sh) with the +# following copyright and license. +# +# Copyright (C) 1994 X Consortium +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to +# deal in the Software without restriction, including without limitation the +# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or +# sell copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in +# all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN +# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- +# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +# +# Except as contained in this notice, the name of the X Consortium shall not +# be used in advertising or otherwise to promote the sale, use or other deal- +# ings in this Software without prior written authorization from the X Consor- +# tium. +# +# +# FSF changes to this file are in the public domain. +# +# Calling this script install-sh is preferred over install.sh, to prevent +# 'make' implicit rules from creating a file called install from it +# when there is no Makefile. +# +# This script is compatible with the BSD install script, but was written +# from scratch. + +tab=' ' +nl=' +' +IFS=" $tab$nl" + +# Set DOITPROG to "echo" to test this script. + +doit=${DOITPROG-} +doit_exec=${doit:-exec} + +# Put in absolute file names if you don't have them in your path; +# or use environment vars. + +chgrpprog=${CHGRPPROG-chgrp} +chmodprog=${CHMODPROG-chmod} +chownprog=${CHOWNPROG-chown} +cmpprog=${CMPPROG-cmp} +cpprog=${CPPROG-cp} +mkdirprog=${MKDIRPROG-mkdir} +mvprog=${MVPROG-mv} +rmprog=${RMPROG-rm} +stripprog=${STRIPPROG-strip} + +posix_mkdir= + +# Desired mode of installed file. +mode=0755 + +chgrpcmd= +chmodcmd=$chmodprog +chowncmd= +mvcmd=$mvprog +rmcmd="$rmprog -f" +stripcmd= + +src= +dst= +dir_arg= +dst_arg= + +copy_on_change=false +is_target_a_directory=possibly + +usage="\ +Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE + or: $0 [OPTION]... SRCFILES... DIRECTORY + or: $0 [OPTION]... -t DIRECTORY SRCFILES... + or: $0 [OPTION]... -d DIRECTORIES... + +In the 1st form, copy SRCFILE to DSTFILE. +In the 2nd and 3rd, copy all SRCFILES to DIRECTORY. +In the 4th, create DIRECTORIES. + +Options: + --help display this help and exit. + --version display version info and exit. + + -c (ignored) + -C install only if different (preserve the last data modification time) + -d create directories instead of installing files. + -g GROUP $chgrpprog installed files to GROUP. + -m MODE $chmodprog installed files to MODE. + -o USER $chownprog installed files to USER. + -s $stripprog installed files. + -t DIRECTORY install into DIRECTORY. + -T report an error if DSTFILE is a directory. + +Environment variables override the default commands: + CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG + RMPROG STRIPPROG +" + +while test $# -ne 0; do + case $1 in + -c) ;; + + -C) copy_on_change=true;; + + -d) dir_arg=true;; + + -g) chgrpcmd="$chgrpprog $2" + shift;; + + --help) echo "$usage"; exit $?;; + + -m) mode=$2 + case $mode in + *' '* | *"$tab"* | *"$nl"* | *'*'* | *'?'* | *'['*) + echo "$0: invalid mode: $mode" >&2 + exit 1;; + esac + shift;; + + -o) chowncmd="$chownprog $2" + shift;; + + -s) stripcmd=$stripprog;; + + -t) + is_target_a_directory=always + dst_arg=$2 + # Protect names problematic for 'test' and other utilities. + case $dst_arg in + -* | [=\(\)!]) dst_arg=./$dst_arg;; + esac + shift;; + + -T) is_target_a_directory=never;; + + --version) echo "$0 $scriptversion"; exit $?;; + + --) shift + break;; + + -*) echo "$0: invalid option: $1" >&2 + exit 1;; + + *) break;; + esac + shift +done + +# We allow the use of options -d and -T together, by making -d +# take the precedence; this is for compatibility with GNU install. + +if test -n "$dir_arg"; then + if test -n "$dst_arg"; then + echo "$0: target directory not allowed when installing a directory." >&2 + exit 1 + fi +fi + +if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then + # When -d is used, all remaining arguments are directories to create. + # When -t is used, the destination is already specified. + # Otherwise, the last argument is the destination. Remove it from $@. + for arg + do + if test -n "$dst_arg"; then + # $@ is not empty: it contains at least $arg. + set fnord "$@" "$dst_arg" + shift # fnord + fi + shift # arg + dst_arg=$arg + # Protect names problematic for 'test' and other utilities. + case $dst_arg in + -* | [=\(\)!]) dst_arg=./$dst_arg;; + esac + done +fi + +if test $# -eq 0; then + if test -z "$dir_arg"; then + echo "$0: no input file specified." >&2 + exit 1 + fi + # It's OK to call 'install-sh -d' without argument. + # This can happen when creating conditional directories. + exit 0 +fi + +if test -z "$dir_arg"; then + if test $# -gt 1 || test "$is_target_a_directory" = always; then + if test ! -d "$dst_arg"; then + echo "$0: $dst_arg: Is not a directory." >&2 + exit 1 + fi + fi +fi + +if test -z "$dir_arg"; then + do_exit='(exit $ret); exit $ret' + trap "ret=129; $do_exit" 1 + trap "ret=130; $do_exit" 2 + trap "ret=141; $do_exit" 13 + trap "ret=143; $do_exit" 15 + + # Set umask so as not to create temps with too-generous modes. + # However, 'strip' requires both read and write access to temps. + case $mode in + # Optimize common cases. + *644) cp_umask=133;; + *755) cp_umask=22;; + + *[0-7]) + if test -z "$stripcmd"; then + u_plus_rw= + else + u_plus_rw='% 200' + fi + cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;; + *) + if test -z "$stripcmd"; then + u_plus_rw= + else + u_plus_rw=,u+rw + fi + cp_umask=$mode$u_plus_rw;; + esac +fi + +for src +do + # Protect names problematic for 'test' and other utilities. + case $src in + -* | [=\(\)!]) src=./$src;; + esac + + if test -n "$dir_arg"; then + dst=$src + dstdir=$dst + test -d "$dstdir" + dstdir_status=$? + else + + # Waiting for this to be detected by the "$cpprog $src $dsttmp" command + # might cause directories to be created, which would be especially bad + # if $src (and thus $dsttmp) contains '*'. + if test ! -f "$src" && test ! -d "$src"; then + echo "$0: $src does not exist." >&2 + exit 1 + fi + + if test -z "$dst_arg"; then + echo "$0: no destination specified." >&2 + exit 1 + fi + dst=$dst_arg + + # If destination is a directory, append the input filename. + if test -d "$dst"; then + if test "$is_target_a_directory" = never; then + echo "$0: $dst_arg: Is a directory" >&2 + exit 1 + fi + dstdir=$dst + dstbase=`basename "$src"` + case $dst in + */) dst=$dst$dstbase;; + *) dst=$dst/$dstbase;; + esac + dstdir_status=0 + else + dstdir=`dirname "$dst"` + test -d "$dstdir" + dstdir_status=$? + fi + fi + + case $dstdir in + */) dstdirslash=$dstdir;; + *) dstdirslash=$dstdir/;; + esac + + obsolete_mkdir_used=false + + if test $dstdir_status != 0; then + case $posix_mkdir in + '') + # Create intermediate dirs using mode 755 as modified by the umask. + # This is like FreeBSD 'install' as of 1997-10-28. + umask=`umask` + case $stripcmd.$umask in + # Optimize common cases. + *[2367][2367]) mkdir_umask=$umask;; + .*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;; + + *[0-7]) + mkdir_umask=`expr $umask + 22 \ + - $umask % 100 % 40 + $umask % 20 \ + - $umask % 10 % 4 + $umask % 2 + `;; + *) mkdir_umask=$umask,go-w;; + esac + + # With -d, create the new directory with the user-specified mode. + # Otherwise, rely on $mkdir_umask. + if test -n "$dir_arg"; then + mkdir_mode=-m$mode + else + mkdir_mode= + fi + + posix_mkdir=false + case $umask in + *[123567][0-7][0-7]) + # POSIX mkdir -p sets u+wx bits regardless of umask, which + # is incompatible with FreeBSD 'install' when (umask & 300) != 0. + ;; + *) + # Note that $RANDOM variable is not portable (e.g. dash); Use it + # here however when possible just to lower collision chance. + tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$ + + trap 'ret=$?; rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" 2>/dev/null; exit $ret' 0 + + # Because "mkdir -p" follows existing symlinks and we likely work + # directly in world-writeable /tmp, make sure that the '$tmpdir' + # directory is successfully created first before we actually test + # 'mkdir -p' feature. + if (umask $mkdir_umask && + $mkdirprog $mkdir_mode "$tmpdir" && + exec $mkdirprog $mkdir_mode -p -- "$tmpdir/a/b") >/dev/null 2>&1 + then + if test -z "$dir_arg" || { + # Check for POSIX incompatibilities with -m. + # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or + # other-writable bit of parent directory when it shouldn't. + # FreeBSD 6.1 mkdir -m -p sets mode of existing directory. + test_tmpdir="$tmpdir/a" + ls_ld_tmpdir=`ls -ld "$test_tmpdir"` + case $ls_ld_tmpdir in + d????-?r-*) different_mode=700;; + d????-?--*) different_mode=755;; + *) false;; + esac && + $mkdirprog -m$different_mode -p -- "$test_tmpdir" && { + ls_ld_tmpdir_1=`ls -ld "$test_tmpdir"` + test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1" + } + } + then posix_mkdir=: + fi + rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" + else + # Remove any dirs left behind by ancient mkdir implementations. + rmdir ./$mkdir_mode ./-p ./-- "$tmpdir" 2>/dev/null + fi + trap '' 0;; + esac;; + esac + + if + $posix_mkdir && ( + umask $mkdir_umask && + $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir" + ) + then : + else + + # The umask is ridiculous, or mkdir does not conform to POSIX, + # or it failed possibly due to a race condition. Create the + # directory the slow way, step by step, checking for races as we go. + + case $dstdir in + /*) prefix='/';; + [-=\(\)!]*) prefix='./';; + *) prefix='';; + esac + + oIFS=$IFS + IFS=/ + set -f + set fnord $dstdir + shift + set +f + IFS=$oIFS + + prefixes= + + for d + do + test X"$d" = X && continue + + prefix=$prefix$d + if test -d "$prefix"; then + prefixes= + else + if $posix_mkdir; then + (umask=$mkdir_umask && + $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break + # Don't fail if two instances are running concurrently. + test -d "$prefix" || exit 1 + else + case $prefix in + *\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;; + *) qprefix=$prefix;; + esac + prefixes="$prefixes '$qprefix'" + fi + fi + prefix=$prefix/ + done + + if test -n "$prefixes"; then + # Don't fail if two instances are running concurrently. + (umask $mkdir_umask && + eval "\$doit_exec \$mkdirprog $prefixes") || + test -d "$dstdir" || exit 1 + obsolete_mkdir_used=true + fi + fi + fi + + if test -n "$dir_arg"; then + { test -z "$chowncmd" || $doit $chowncmd "$dst"; } && + { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } && + { test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false || + test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1 + else + + # Make a couple of temp file names in the proper directory. + dsttmp=${dstdirslash}_inst.$$_ + rmtmp=${dstdirslash}_rm.$$_ + + # Trap to clean up those temp files at exit. + trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 + + # Copy the file name to the temp name. + (umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") && + + # and set any options; do chmod last to preserve setuid bits. + # + # If any of these fail, we abort the whole thing. If we want to + # ignore errors from any of these, just make sure not to ignore + # errors from the above "$doit $cpprog $src $dsttmp" command. + # + { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } && + { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } && + { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } && + { test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } && + + # If -C, don't bother to copy if it wouldn't change the file. + if $copy_on_change && + old=`LC_ALL=C ls -dlL "$dst" 2>/dev/null` && + new=`LC_ALL=C ls -dlL "$dsttmp" 2>/dev/null` && + set -f && + set X $old && old=:$2:$4:$5:$6 && + set X $new && new=:$2:$4:$5:$6 && + set +f && + test "$old" = "$new" && + $cmpprog "$dst" "$dsttmp" >/dev/null 2>&1 + then + rm -f "$dsttmp" + else + # Rename the file to the real destination. + $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null || + + # The rename failed, perhaps because mv can't rename something else + # to itself, or perhaps because mv is so ancient that it does not + # support -f. + { + # Now remove or move aside any old file at destination location. + # We try this two ways since rm can't unlink itself on some + # systems and the destination file might be busy for other + # reasons. In this case, the final cleanup might fail but the new + # file should still install successfully. + { + test ! -f "$dst" || + $doit $rmcmd -f "$dst" 2>/dev/null || + { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null && + { $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; } + } || + { echo "$0: cannot unlink or rename $dst" >&2 + (exit 1); exit 1 + } + } && + + # Now rename the file to the real destination. + $doit $mvcmd "$dsttmp" "$dst" + } + fi || exit 1 + + trap '' 0 + fi +done + +# Local variables: +# eval: (add-hook 'before-save-hook 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-time-zone: "UTC0" +# time-stamp-end: "; # UTC" +# End: diff --git a/TMessagesProj/jni/libtgvoip2/json11.cpp b/TMessagesProj/jni/libtgvoip2/json11.cpp new file mode 100644 index 000000000..812e61031 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/json11.cpp @@ -0,0 +1,795 @@ +/* Copyright (c) 2013 Dropbox, Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + +#include "json11.hpp" +#include +#include +#include +#include +#include +#include +#include + +namespace json11 { + +static const int max_depth = 200; + +using std::string; +using std::vector; +using std::map; +using std::make_shared; +using std::initializer_list; +using std::move; + +/* Helper for representing null - just a do-nothing struct, plus comparison + * operators so the helpers in JsonValue work. We can't use nullptr_t because + * it may not be orderable. + */ +struct NullStruct { + bool operator==(NullStruct) const { return true; } + bool operator<(NullStruct) const { return false; } +}; + +/* * * * * * * * * * * * * * * * * * * * + * Serialization + */ + +static void dump(NullStruct, string &out) { + out += "null"; +} + +static void dump(double value, string &out) { + if (std::isfinite(value)) { + std::ostringstream stm; + stm.imbue(std::locale("C")); + stm << value; + out += stm.str(); + } else { + out += "null"; + } +} + +static void dump(int value, string &out) { + char buf[32]; + snprintf(buf, sizeof buf, "%d", value); + out += buf; +} + +static void dump(bool value, string &out) { + out += value ? "true" : "false"; +} + +static void dump(const string &value, string &out) { + out += '"'; + for (size_t i = 0; i < value.length(); i++) { + const char ch = value[i]; + if (ch == '\\') { + out += "\\\\"; + } else if (ch == '"') { + out += "\\\""; + } else if (ch == '\b') { + out += "\\b"; + } else if (ch == '\f') { + out += "\\f"; + } else if (ch == '\n') { + out += "\\n"; + } else if (ch == '\r') { + out += "\\r"; + } else if (ch == '\t') { + out += "\\t"; + } else if (static_cast(ch) <= 0x1f) { + char buf[8]; + snprintf(buf, sizeof buf, "\\u%04x", ch); + out += buf; + } else if (static_cast(ch) == 0xe2 && static_cast(value[i+1]) == 0x80 + && static_cast(value[i+2]) == 0xa8) { + out += "\\u2028"; + i += 2; + } else if (static_cast(ch) == 0xe2 && static_cast(value[i+1]) == 0x80 + && static_cast(value[i+2]) == 0xa9) { + out += "\\u2029"; + i += 2; + } else { + out += ch; + } + } + out += '"'; +} + +static void dump(const Json::array &values, string &out) { + bool first = true; + out += "["; + for (const auto &value : values) { + if (!first) + out += ", "; + value.dump(out); + first = false; + } + out += "]"; +} + +static void dump(const Json::object &values, string &out) { + bool first = true; + out += "{"; + for (const auto &kv : values) { + if (!first) + out += ", "; + dump(kv.first, out); + out += ": "; + kv.second.dump(out); + first = false; + } + out += "}"; +} + +void Json::dump(string &out) const { + m_ptr->dump(out); +} + +/* * * * * * * * * * * * * * * * * * * * + * Value wrappers + */ + +template +class Value : public JsonValue { +protected: + + // Constructors + explicit Value(const T &value) : m_value(value) {} + explicit Value(T &&value) : m_value(move(value)) {} + + // Get type tag + Json::Type type() const override { + return tag; + } + + // Comparisons + bool equals(const JsonValue * other) const override { + return m_value == static_cast *>(other)->m_value; + } + bool less(const JsonValue * other) const override { + return m_value < static_cast *>(other)->m_value; + } + + const T m_value; + void dump(string &out) const override { json11::dump(m_value, out); } +}; + +class JsonDouble final : public Value { + double number_value() const override { return m_value; } + int int_value() const override { return static_cast(m_value); } + bool equals(const JsonValue * other) const override { return m_value == other->number_value(); } + bool less(const JsonValue * other) const override { return m_value < other->number_value(); } +public: + explicit JsonDouble(double value) : Value(value) {} +}; + +class JsonInt final : public Value { + double number_value() const override { return m_value; } + int int_value() const override { return m_value; } + bool equals(const JsonValue * other) const override { return m_value == other->number_value(); } + bool less(const JsonValue * other) const override { return m_value < other->number_value(); } +public: + explicit JsonInt(int value) : Value(value) {} +}; + +class JsonBoolean final : public Value { + bool bool_value() const override { return m_value; } +public: + explicit JsonBoolean(bool value) : Value(value) {} +}; + +class JsonString final : public Value { + const string &string_value() const override { return m_value; } +public: + explicit JsonString(const string &value) : Value(value) {} + explicit JsonString(string &&value) : Value(move(value)) {} +}; + +class JsonArray final : public Value { + const Json::array &array_items() const override { return m_value; } + const Json & operator[](size_t i) const override; +public: + explicit JsonArray(const Json::array &value) : Value(value) {} + explicit JsonArray(Json::array &&value) : Value(move(value)) {} +}; + +class JsonObject final : public Value { + const Json::object &object_items() const override { return m_value; } + const Json & operator[](const string &key) const override; +public: + explicit JsonObject(const Json::object &value) : Value(value) {} + explicit JsonObject(Json::object &&value) : Value(move(value)) {} +}; + +class JsonNull final : public Value { +public: + JsonNull() : Value({}) {} +}; + +/* * * * * * * * * * * * * * * * * * * * + * Static globals - static-init-safe + */ +struct Statics { + const std::shared_ptr null = make_shared(); + const std::shared_ptr t = make_shared(true); + const std::shared_ptr f = make_shared(false); + const string empty_string; + const vector empty_vector; + const map empty_map; + Statics() {} +}; + +static const Statics & statics() { + static const Statics s {}; + return s; +} + +static const Json & static_null() { + // This has to be separate, not in Statics, because Json() accesses statics().null. + static const Json json_null; + return json_null; +} + +/* * * * * * * * * * * * * * * * * * * * + * Constructors + */ + +Json::Json() noexcept : m_ptr(statics().null) {} +Json::Json(std::nullptr_t) noexcept : m_ptr(statics().null) {} +Json::Json(double value) : m_ptr(make_shared(value)) {} +Json::Json(int value) : m_ptr(make_shared(value)) {} +Json::Json(bool value) : m_ptr(value ? statics().t : statics().f) {} +Json::Json(const string &value) : m_ptr(make_shared(value)) {} +Json::Json(string &&value) : m_ptr(make_shared(move(value))) {} +Json::Json(const char * value) : m_ptr(make_shared(value)) {} +Json::Json(const Json::array &values) : m_ptr(make_shared(values)) {} +Json::Json(Json::array &&values) : m_ptr(make_shared(move(values))) {} +Json::Json(const Json::object &values) : m_ptr(make_shared(values)) {} +Json::Json(Json::object &&values) : m_ptr(make_shared(move(values))) {} + +/* * * * * * * * * * * * * * * * * * * * + * Accessors + */ + +Json::Type Json::type() const { return m_ptr->type(); } +double Json::number_value() const { return m_ptr->number_value(); } +int Json::int_value() const { return m_ptr->int_value(); } +bool Json::bool_value() const { return m_ptr->bool_value(); } +const string & Json::string_value() const { return m_ptr->string_value(); } +const vector & Json::array_items() const { return m_ptr->array_items(); } +const map & Json::object_items() const { return m_ptr->object_items(); } +const Json & Json::operator[] (size_t i) const { return (*m_ptr)[i]; } +const Json & Json::operator[] (const string &key) const { return (*m_ptr)[key]; } + +double JsonValue::number_value() const { return 0; } +int JsonValue::int_value() const { return 0; } +bool JsonValue::bool_value() const { return false; } +const string & JsonValue::string_value() const { return statics().empty_string; } +const vector & JsonValue::array_items() const { return statics().empty_vector; } +const map & JsonValue::object_items() const { return statics().empty_map; } +const Json & JsonValue::operator[] (size_t) const { return static_null(); } +const Json & JsonValue::operator[] (const string &) const { return static_null(); } + +const Json & JsonObject::operator[] (const string &key) const { + auto iter = m_value.find(key); + return (iter == m_value.end()) ? static_null() : iter->second; +} +const Json & JsonArray::operator[] (size_t i) const { + if (i >= m_value.size()) return static_null(); + else return m_value[i]; +} + +/* * * * * * * * * * * * * * * * * * * * + * Comparison + */ + +bool Json::operator== (const Json &other) const { + if (m_ptr == other.m_ptr) + return true; + if (m_ptr->type() != other.m_ptr->type()) + return false; + + return m_ptr->equals(other.m_ptr.get()); +} + +bool Json::operator< (const Json &other) const { + if (m_ptr == other.m_ptr) + return false; + if (m_ptr->type() != other.m_ptr->type()) + return m_ptr->type() < other.m_ptr->type(); + + return m_ptr->less(other.m_ptr.get()); +} + +/* * * * * * * * * * * * * * * * * * * * + * Parsing + */ + +/* esc(c) + * + * Format char c suitable for printing in an error message. + */ +static inline string esc(char c) { + char buf[12]; + if (static_cast(c) >= 0x20 && static_cast(c) <= 0x7f) { + snprintf(buf, sizeof buf, "'%c' (%d)", c, c); + } else { + snprintf(buf, sizeof buf, "(%d)", c); + } + return string(buf); +} + +static inline bool in_range(long x, long lower, long upper) { + return (x >= lower && x <= upper); +} + +namespace { +/* JsonParser + * + * Object that tracks all state of an in-progress parse. + */ +struct JsonParser final { + + /* State + */ + const string &str; + size_t i; + string &err; + bool failed; + const JsonParse strategy; + + /* fail(msg, err_ret = Json()) + * + * Mark this parse as failed. + */ + Json fail(string &&msg) { + return fail(move(msg), Json()); + } + + template + T fail(string &&msg, const T err_ret) { + if (!failed) + err = std::move(msg); + failed = true; + return err_ret; + } + + /* consume_whitespace() + * + * Advance until the current character is non-whitespace. + */ + void consume_whitespace() { + while (str[i] == ' ' || str[i] == '\r' || str[i] == '\n' || str[i] == '\t') + i++; + } + + /* consume_comment() + * + * Advance comments (c-style inline and multiline). + */ + bool consume_comment() { + bool comment_found = false; + if (str[i] == '/') { + i++; + if (i == str.size()) + return fail("unexpected end of input after start of comment", false); + if (str[i] == '/') { // inline comment + i++; + // advance until next line, or end of input + while (i < str.size() && str[i] != '\n') { + i++; + } + comment_found = true; + } + else if (str[i] == '*') { // multiline comment + i++; + if (i > str.size()-2) + return fail("unexpected end of input inside multi-line comment", false); + // advance until closing tokens + while (!(str[i] == '*' && str[i+1] == '/')) { + i++; + if (i > str.size()-2) + return fail( + "unexpected end of input inside multi-line comment", false); + } + i += 2; + comment_found = true; + } + else + return fail("malformed comment", false); + } + return comment_found; + } + + /* consume_garbage() + * + * Advance until the current character is non-whitespace and non-comment. + */ + void consume_garbage() { + consume_whitespace(); + if(strategy == JsonParse::COMMENTS) { + bool comment_found = false; + do { + comment_found = consume_comment(); + if (failed) return; + consume_whitespace(); + } + while(comment_found); + } + } + + /* get_next_token() + * + * Return the next non-whitespace character. If the end of the input is reached, + * flag an error and return 0. + */ + char get_next_token() { + consume_garbage(); + if (failed) return (char)0; + if (i == str.size()) + return fail("unexpected end of input", (char)0); + + return str[i++]; + } + + /* encode_utf8(pt, out) + * + * Encode pt as UTF-8 and add it to out. + */ + void encode_utf8(long pt, string & out) { + if (pt < 0) + return; + + if (pt < 0x80) { + out += static_cast(pt); + } else if (pt < 0x800) { + out += static_cast((pt >> 6) | 0xC0); + out += static_cast((pt & 0x3F) | 0x80); + } else if (pt < 0x10000) { + out += static_cast((pt >> 12) | 0xE0); + out += static_cast(((pt >> 6) & 0x3F) | 0x80); + out += static_cast((pt & 0x3F) | 0x80); + } else { + out += static_cast((pt >> 18) | 0xF0); + out += static_cast(((pt >> 12) & 0x3F) | 0x80); + out += static_cast(((pt >> 6) & 0x3F) | 0x80); + out += static_cast((pt & 0x3F) | 0x80); + } + } + + /* parse_string() + * + * Parse a string, starting at the current position. + */ + string parse_string() { + string out; + long last_escaped_codepoint = -1; + while (true) { + if (i == str.size()) + return fail("unexpected end of input in string", ""); + + char ch = str[i++]; + + if (ch == '"') { + encode_utf8(last_escaped_codepoint, out); + return out; + } + + if (in_range(ch, 0, 0x1f)) + return fail("unescaped " + esc(ch) + " in string", ""); + + // The usual case: non-escaped characters + if (ch != '\\') { + encode_utf8(last_escaped_codepoint, out); + last_escaped_codepoint = -1; + out += ch; + continue; + } + + // Handle escapes + if (i == str.size()) + return fail("unexpected end of input in string", ""); + + ch = str[i++]; + + if (ch == 'u') { + // Extract 4-byte escape sequence + string esc = str.substr(i, 4); + // Explicitly check length of the substring. The following loop + // relies on std::string returning the terminating NUL when + // accessing str[length]. Checking here reduces brittleness. + if (esc.length() < 4) { + return fail("bad \\u escape: " + esc, ""); + } + for (size_t j = 0; j < 4; j++) { + if (!in_range(esc[j], 'a', 'f') && !in_range(esc[j], 'A', 'F') + && !in_range(esc[j], '0', '9')) + return fail("bad \\u escape: " + esc, ""); + } + + long codepoint = strtol(esc.data(), nullptr, 16); + + // JSON specifies that characters outside the BMP shall be encoded as a pair + // of 4-hex-digit \u escapes encoding their surrogate pair components. Check + // whether we're in the middle of such a beast: the previous codepoint was an + // escaped lead (high) surrogate, and this is a trail (low) surrogate. + if (in_range(last_escaped_codepoint, 0xD800, 0xDBFF) + && in_range(codepoint, 0xDC00, 0xDFFF)) { + // Reassemble the two surrogate pairs into one astral-plane character, per + // the UTF-16 algorithm. + encode_utf8((((last_escaped_codepoint - 0xD800) << 10) + | (codepoint - 0xDC00)) + 0x10000, out); + last_escaped_codepoint = -1; + } else { + encode_utf8(last_escaped_codepoint, out); + last_escaped_codepoint = codepoint; + } + + i += 4; + continue; + } + + encode_utf8(last_escaped_codepoint, out); + last_escaped_codepoint = -1; + + if (ch == 'b') { + out += '\b'; + } else if (ch == 'f') { + out += '\f'; + } else if (ch == 'n') { + out += '\n'; + } else if (ch == 'r') { + out += '\r'; + } else if (ch == 't') { + out += '\t'; + } else if (ch == '"' || ch == '\\' || ch == '/') { + out += ch; + } else { + return fail("invalid escape character " + esc(ch), ""); + } + } + } + + /* parse_number() + * + * Parse a double. + */ + Json parse_number() { + size_t start_pos = i; + + if (str[i] == '-') + i++; + + // Integer part + if (str[i] == '0') { + i++; + if (in_range(str[i], '0', '9')) + return fail("leading 0s not permitted in numbers"); + } else if (in_range(str[i], '1', '9')) { + i++; + while (in_range(str[i], '0', '9')) + i++; + } else { + return fail("invalid " + esc(str[i]) + " in number"); + } + + if (str[i] != '.' && str[i] != 'e' && str[i] != 'E' + && (i - start_pos) <= static_cast(std::numeric_limits::digits10)) { + return std::atoi(str.c_str() + start_pos); + } + + // Decimal part + if (str[i] == '.') { + i++; + if (!in_range(str[i], '0', '9')) + return fail("at least one digit required in fractional part"); + + while (in_range(str[i], '0', '9')) + i++; + } + + // Exponent part + if (str[i] == 'e' || str[i] == 'E') { + i++; + + if (str[i] == '+' || str[i] == '-') + i++; + + if (!in_range(str[i], '0', '9')) + return fail("at least one digit required in exponent"); + + while (in_range(str[i], '0', '9')) + i++; + } + + std::istringstream stm(std::string(str.begin()+start_pos, str.end())); + stm.imbue(std::locale("C")); + double result; + stm >> result; + return result; + } + + /* expect(str, res) + * + * Expect that 'str' starts at the character that was just read. If it does, advance + * the input and return res. If not, flag an error. + */ + Json expect(const string &expected, Json res) { + assert(i != 0); + i--; + if (str.compare(i, expected.length(), expected) == 0) { + i += expected.length(); + return res; + } else { + return fail("parse error: expected " + expected + ", got " + str.substr(i, expected.length())); + } + } + + /* parse_json() + * + * Parse a JSON object. + */ + Json parse_json(int depth) { + if (depth > max_depth) { + return fail("exceeded maximum nesting depth"); + } + + char ch = get_next_token(); + if (failed) + return Json(); + + if (ch == '-' || (ch >= '0' && ch <= '9')) { + i--; + return parse_number(); + } + + if (ch == 't') + return expect("true", true); + + if (ch == 'f') + return expect("false", false); + + if (ch == 'n') + return expect("null", Json()); + + if (ch == '"') + return parse_string(); + + if (ch == '{') { + map data; + ch = get_next_token(); + if (ch == '}') + return data; + + while (1) { + if (ch != '"') + return fail("expected '\"' in object, got " + esc(ch)); + + string key = parse_string(); + if (failed) + return Json(); + + ch = get_next_token(); + if (ch != ':') + return fail("expected ':' in object, got " + esc(ch)); + + data[std::move(key)] = parse_json(depth + 1); + if (failed) + return Json(); + + ch = get_next_token(); + if (ch == '}') + break; + if (ch != ',') + return fail("expected ',' in object, got " + esc(ch)); + + ch = get_next_token(); + } + return data; + } + + if (ch == '[') { + vector data; + ch = get_next_token(); + if (ch == ']') + return data; + + while (1) { + i--; + data.push_back(parse_json(depth + 1)); + if (failed) + return Json(); + + ch = get_next_token(); + if (ch == ']') + break; + if (ch != ',') + return fail("expected ',' in list, got " + esc(ch)); + + ch = get_next_token(); + (void)ch; + } + return data; + } + + return fail("expected value, got " + esc(ch)); + } +}; +}//namespace { + +Json Json::parse(const string &in, string &err, JsonParse strategy) { + JsonParser parser { in, 0, err, false, strategy }; + Json result = parser.parse_json(0); + + // Check for any trailing garbage + parser.consume_garbage(); + if (parser.failed) + return Json(); + if (parser.i != in.size()) + return parser.fail("unexpected trailing " + esc(in[parser.i])); + + return result; +} + +// Documented in json11.hpp +vector Json::parse_multi(const string &in, + std::string::size_type &parser_stop_pos, + string &err, + JsonParse strategy) { + JsonParser parser { in, 0, err, false, strategy }; + parser_stop_pos = 0; + vector json_vec; + while (parser.i != in.size() && !parser.failed) { + json_vec.push_back(parser.parse_json(0)); + if (parser.failed) + break; + + // Check for another object + parser.consume_garbage(); + if (parser.failed) + break; + parser_stop_pos = parser.i; + } + return json_vec; +} + +/* * * * * * * * * * * * * * * * * * * * + * Shape-checking + */ + +bool Json::has_shape(const shape & types, string & err) const { + if (!is_object()) { + err = "expected JSON object, got " + dump(); + return false; + } + + for (auto & item : types) { + if ((*this)[item.first].type() != item.second) { + err = "bad type for " + item.first + " in " + dump(); + return false; + } + } + + return true; +} + +} // namespace json11 diff --git a/TMessagesProj/jni/libtgvoip2/json11.hpp b/TMessagesProj/jni/libtgvoip2/json11.hpp new file mode 100644 index 000000000..0c47d0509 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/json11.hpp @@ -0,0 +1,232 @@ +/* json11 + * + * json11 is a tiny JSON library for C++11, providing JSON parsing and serialization. + * + * The core object provided by the library is json11::Json. A Json object represents any JSON + * value: null, bool, number (int or double), string (std::string), array (std::vector), or + * object (std::map). + * + * Json objects act like values: they can be assigned, copied, moved, compared for equality or + * order, etc. There are also helper methods Json::dump, to serialize a Json to a string, and + * Json::parse (static) to parse a std::string as a Json object. + * + * Internally, the various types of Json object are represented by the JsonValue class + * hierarchy. + * + * A note on numbers - JSON specifies the syntax of number formatting but not its semantics, + * so some JSON implementations distinguish between integers and floating-point numbers, while + * some don't. In json11, we choose the latter. Because some JSON implementations (namely + * Javascript itself) treat all numbers as the same type, distinguishing the two leads + * to JSON that will be *silently* changed by a round-trip through those implementations. + * Dangerous! To avoid that risk, json11 stores all numbers as double internally, but also + * provides integer helpers. + * + * Fortunately, double-precision IEEE754 ('double') can precisely store any integer in the + * range +/-2^53, which includes every 'int' on most systems. (Timestamps often use int64 + * or long long to avoid the Y2038K problem; a double storing microseconds since some epoch + * will be exact for +/- 275 years.) + */ + +/* Copyright (c) 2013 Dropbox, Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + +#pragma once + +#include +#include +#include +#include +#include + +#ifdef _MSC_VER + #if _MSC_VER <= 1800 // VS 2013 + #ifndef noexcept + #define noexcept throw() + #endif + + #ifndef snprintf + #define snprintf _snprintf_s + #endif + #endif +#endif + +namespace json11 { + +enum JsonParse { + STANDARD, COMMENTS +}; + +class JsonValue; + +class Json final { +public: + // Types + enum Type { + NUL, NUMBER, BOOL, STRING, ARRAY, OBJECT + }; + + // Array and object typedefs + typedef std::vector array; + typedef std::map object; + + // Constructors for the various types of JSON value. + Json() noexcept; // NUL + Json(std::nullptr_t) noexcept; // NUL + Json(double value); // NUMBER + Json(int value); // NUMBER + Json(bool value); // BOOL + Json(const std::string &value); // STRING + Json(std::string &&value); // STRING + Json(const char * value); // STRING + Json(const array &values); // ARRAY + Json(array &&values); // ARRAY + Json(const object &values); // OBJECT + Json(object &&values); // OBJECT + + // Implicit constructor: anything with a to_json() function. + template + Json(const T & t) : Json(t.to_json()) {} + + // Implicit constructor: map-like objects (std::map, std::unordered_map, etc) + template ().begin()->first)>::value + && std::is_constructible().begin()->second)>::value, + int>::type = 0> + Json(const M & m) : Json(object(m.begin(), m.end())) {} + + // Implicit constructor: vector-like objects (std::list, std::vector, std::set, etc) + template ().begin())>::value, + int>::type = 0> + Json(const V & v) : Json(array(v.begin(), v.end())) {} + + // This prevents Json(some_pointer) from accidentally producing a bool. Use + // Json(bool(some_pointer)) if that behavior is desired. + Json(void *) = delete; + + // Accessors + Type type() const; + + bool is_null() const { return type() == NUL; } + bool is_number() const { return type() == NUMBER; } + bool is_bool() const { return type() == BOOL; } + bool is_string() const { return type() == STRING; } + bool is_array() const { return type() == ARRAY; } + bool is_object() const { return type() == OBJECT; } + + // Return the enclosed value if this is a number, 0 otherwise. Note that json11 does not + // distinguish between integer and non-integer numbers - number_value() and int_value() + // can both be applied to a NUMBER-typed object. + double number_value() const; + int int_value() const; + + // Return the enclosed value if this is a boolean, false otherwise. + bool bool_value() const; + // Return the enclosed string if this is a string, "" otherwise. + const std::string &string_value() const; + // Return the enclosed std::vector if this is an array, or an empty vector otherwise. + const array &array_items() const; + // Return the enclosed std::map if this is an object, or an empty map otherwise. + const object &object_items() const; + + // Return a reference to arr[i] if this is an array, Json() otherwise. + const Json & operator[](size_t i) const; + // Return a reference to obj[key] if this is an object, Json() otherwise. + const Json & operator[](const std::string &key) const; + + // Serialize. + void dump(std::string &out) const; + std::string dump() const { + std::string out; + dump(out); + return out; + } + + // Parse. If parse fails, return Json() and assign an error message to err. + static Json parse(const std::string & in, + std::string & err, + JsonParse strategy = JsonParse::STANDARD); + static Json parse(const char * in, + std::string & err, + JsonParse strategy = JsonParse::STANDARD) { + if (in) { + return parse(std::string(in), err, strategy); + } else { + err = "null input"; + return nullptr; + } + } + // Parse multiple objects, concatenated or separated by whitespace + static std::vector parse_multi( + const std::string & in, + std::string::size_type & parser_stop_pos, + std::string & err, + JsonParse strategy = JsonParse::STANDARD); + + static inline std::vector parse_multi( + const std::string & in, + std::string & err, + JsonParse strategy = JsonParse::STANDARD) { + std::string::size_type parser_stop_pos; + return parse_multi(in, parser_stop_pos, err, strategy); + } + + bool operator== (const Json &rhs) const; + bool operator< (const Json &rhs) const; + bool operator!= (const Json &rhs) const { return !(*this == rhs); } + bool operator<= (const Json &rhs) const { return !(rhs < *this); } + bool operator> (const Json &rhs) const { return (rhs < *this); } + bool operator>= (const Json &rhs) const { return !(*this < rhs); } + + /* has_shape(types, err) + * + * Return true if this is a JSON object and, for each item in types, has a field of + * the given type. If not, return false and set err to a descriptive message. + */ + typedef std::initializer_list> shape; + bool has_shape(const shape & types, std::string & err) const; + +private: + std::shared_ptr m_ptr; +}; + +// Internal class hierarchy - JsonValue objects are not exposed to users of this API. +class JsonValue { +protected: + friend class Json; + friend class JsonInt; + friend class JsonDouble; + virtual Json::Type type() const = 0; + virtual bool equals(const JsonValue * other) const = 0; + virtual bool less(const JsonValue * other) const = 0; + virtual void dump(std::string &out) const = 0; + virtual double number_value() const; + virtual int int_value() const; + virtual bool bool_value() const; + virtual const std::string &string_value() const; + virtual const Json::array &array_items() const; + virtual const Json &operator[](size_t i) const; + virtual const Json::object &object_items() const; + virtual const Json &operator[](const std::string &key) const; + virtual ~JsonValue() {} +}; + +} // namespace json11 diff --git a/TMessagesProj/jni/libtgvoip2/libtgvoip.UWP.vcxproj b/TMessagesProj/jni/libtgvoip2/libtgvoip.UWP.vcxproj new file mode 100644 index 000000000..197ebf7cd --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/libtgvoip.UWP.vcxproj @@ -0,0 +1,1069 @@ + + + + + Debug + Win32 + + + Release + Win32 + + + Debug + ARM + + + Release + ARM + + + Debug + x64 + + + Release + x64 + + + + {88803693-7606-484b-9d2f-4bb789d57c29} + WindowsRuntimeComponent + libtgvoip + en + 14.0 + true + Windows Store + 10.0.17134.0 + 10.0.10240.0 + 10.0 + libtgvoip + + + + DynamicLibrary + true + v141 + + + DynamicLibrary + true + v141 + + + DynamicLibrary + true + v141 + + + DynamicLibrary + false + true + v141 + + + DynamicLibrary + false + true + v141 + + + DynamicLibrary + false + true + v141 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + false + Debug + + + false + ARM\Debug + + + false + x64\Debug + + + false + Release + + + false + ARM\Release + + + false + x64\Release + + + + NotUsing + _WINRT_DLL;_CRT_SECURE_NO_WARNINGS;_WINSOCK_DEPRECATED_NO_WARNINGS;NOMINMAX;WEBRTC_APM_DEBUG_DUMP=0;TGVOIP_USE_CUSTOM_CRYPTO;WEBRTC_WIN;WEBRTC_UWP;WEBRTC_NS_FLOAT;%(PreprocessorDefinitions) + pch.h + $(IntDir)pch.pch + /bigobj %(AdditionalOptions) + 28204 + webrtc_dsp;../libopus/include;%(AdditionalIncludeDirectories) + true + $(IntDir)/%(RelativeDir)/ + + + Console + false + libopus.lib;ws2_32.lib;mmdevapi.lib;%(AdditionalDependencies) + $(SolutionDir)$(MappedPlatform)\libopus\;%(AdditionalLibraryDirectories) + + + + + NotUsing + _WINRT_DLL;_CRT_SECURE_NO_WARNINGS;_WINSOCK_DEPRECATED_NO_WARNINGS;NOMINMAX;WEBRTC_APM_DEBUG_DUMP=0;TGVOIP_USE_CUSTOM_CRYPTO;WEBRTC_WIN;WEBRTC_UWP;WEBRTC_NS_FLOAT;WEBRTC_HAS_NEON;%(PreprocessorDefinitions) + pch.h + $(IntDir)pch.pch + /bigobj %(AdditionalOptions) + 28204 + webrtc_dsp;../libopus/include;%(AdditionalIncludeDirectories) + $(IntDir)/%(RelativeDir)/ + + + Console + false + libopus.lib;ws2_32.lib;mmdevapi.lib;%(AdditionalDependencies) + $(SolutionDir)$(MappedPlatform)\libopus\;%(AdditionalLibraryDirectories) + + + + + NotUsing + _WINRT_DLL;_CRT_SECURE_NO_WARNINGS;_WINSOCK_DEPRECATED_NO_WARNINGS;NOMINMAX;WEBRTC_APM_DEBUG_DUMP=0;TGVOIP_USE_CUSTOM_CRYPTO;WEBRTC_WIN;WEBRTC_UWP;WEBRTC_NS_FLOAT;%(PreprocessorDefinitions) + pch.h + $(IntDir)pch.pch + /bigobj %(AdditionalOptions) + 28204 + webrtc_dsp;../libopus/include;%(AdditionalIncludeDirectories) + $(IntDir)/%(RelativeDir)/ + + + Console + false + libopus.lib;ws2_32.lib;mmdevapi.lib;%(AdditionalDependencies) + $(SolutionDir)$(MappedPlatform)\libopus\;%(AdditionalLibraryDirectories) + + + + + NotUsing + _WINRT_DLL;_CRT_SECURE_NO_WARNINGS;_WINSOCK_DEPRECATED_NO_WARNINGS;NOMINMAX;WEBRTC_APM_DEBUG_DUMP=0;NDEBUG;TGVOIP_USE_CUSTOM_CRYPTO;WEBRTC_WIN;WEBRTC_UWP;WEBRTC_NS_FLOAT;%(PreprocessorDefinitions) + pch.h + $(IntDir)pch.pch + /bigobj %(AdditionalOptions) + 28204 + webrtc_dsp;../libopus/include;%(AdditionalIncludeDirectories) + $(IntDir)/%(RelativeDir)/ + + + Console + false + libopus.lib;ws2_32.lib;mmdevapi.lib;%(AdditionalDependencies) + $(SolutionDir)$(MappedPlatform)\libopus\;%(AdditionalLibraryDirectories) + + + + + NotUsing + _WINRT_DLL;_CRT_SECURE_NO_WARNINGS;_WINSOCK_DEPRECATED_NO_WARNINGS;NOMINMAX;WEBRTC_APM_DEBUG_DUMP=0;NDEBUG;TGVOIP_USE_CUSTOM_CRYPTO;WEBRTC_WIN;WEBRTC_UWP;WEBRTC_NS_FLOAT;WEBRTC_HAS_NEON;%(PreprocessorDefinitions) + pch.h + $(IntDir)pch.pch + /bigobj %(AdditionalOptions) + 28204 + webrtc_dsp;../libopus/include;%(AdditionalIncludeDirectories) + $(IntDir)/%(RelativeDir)/ + + + Console + false + libopus.lib;ws2_32.lib;mmdevapi.lib;%(AdditionalDependencies) + $(SolutionDir)$(MappedPlatform)\libopus\;%(AdditionalLibraryDirectories) + + + + + NotUsing + _WINRT_DLL;_CRT_SECURE_NO_WARNINGS;_WINSOCK_DEPRECATED_NO_WARNINGS;NOMINMAX;WEBRTC_APM_DEBUG_DUMP=0;NDEBUG;TGVOIP_USE_CUSTOM_CRYPTO;WEBRTC_WIN;WEBRTC_UWP;WEBRTC_NS_FLOAT;%(PreprocessorDefinitions) + pch.h + $(IntDir)pch.pch + /bigobj %(AdditionalOptions) + 28204 + webrtc_dsp;../libopus/include;%(AdditionalIncludeDirectories) + $(IntDir)/%(RelativeDir)/ + + + Console + false + libopus.lib;ws2_32.lib;mmdevapi.lib;%(AdditionalDependencies) + $(SolutionDir)$(MappedPlatform)\libopus\;%(AdditionalLibraryDirectories) + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + + + false + + + false + + + + false + + + false + + + false + + + false + + + false + + + + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + false + + + false + + + + + + + + + + + + + + + + + + + + + + + + + + false + + + false + + + false + + + false + + + false + + + false + + + + + + + + + + + + + + + + + + + + + + + + + + + + false + + + + + + + + + + + + + + + + + + + + + + + + + + {904ac506-51a0-474e-9f55-ec3febbcccd9} + + + + + + + + \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/libtgvoip.UWP.vcxproj.filters b/TMessagesProj/jni/libtgvoip2/libtgvoip.UWP.vcxproj.filters new file mode 100644 index 000000000..1ccf0933f --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/libtgvoip.UWP.vcxproj.filters @@ -0,0 +1,1936 @@ + + + + + 11199e80-17a0-460f-a780-9bfde20eb11c + rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tga;tiff;tif;png;wav;mfcribbon-ms + + + {c5b75146-c75a-4c56-aeb2-2781658d7b0a} + + + {de1527d9-7564-4e96-9653-6e023b90d2bc} + + + {e4d2de92-03ad-43d9-8861-d69f64610ba5} + + + {365b5ef0-7ccb-4aca-bcd6-ae11baae57f6} + + + + + + + + + + + + + + + + + audio + + + audio + + + audio + + + windows + + + windows + + + windows + + + windows + + + windows + + + + + + audio + + + windows + + + video + + + video + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + + video + + + audio + + + + video + + + video + + + + + + + + + + + + + + + + + + audio + + + audio + + + audio + + + windows + + + windows + + + windows + + + windows + + + windows + + + + + audio + + + + windows + + + video + + + video + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + + video + + + audio + + + + + video + + + video + + + \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/libtgvoip.WP81.vcxproj b/TMessagesProj/jni/libtgvoip2/libtgvoip.WP81.vcxproj new file mode 100644 index 000000000..ab0ba4793 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/libtgvoip.WP81.vcxproj @@ -0,0 +1,423 @@ + + + + + Debug + Win32 + + + Release + Win32 + + + Debug + ARM + + + Release + ARM + + + + {21f10158-c078-4bd7-a82a-9c4aeb8e2f8e} + Win32Proj + libtgvoip + libtgvoip + en-US + 12.0 + true + Windows Phone Silverlight + 8.1 + + + + DynamicLibrary + true + v120 + + + DynamicLibrary + false + true + v120 + + + DynamicLibrary + true + v120 + + + DynamicLibrary + false + true + v120 + + + + + + + + + + + + + + + + + + + + + + + + + + + NotUsing + _WINRT_DLL;TGVOIP_WP_SILVERLIGHT;_CRT_SECURE_NO_WARNINGS;NOMINMAX;WEBRTC_APM_DEBUG_DUMP=0;TGVOIP_USE_CUSTOM_CRYPTO;%(PreprocessorDefinitions) + pch.h + $(IntDir)pch.pch + /bigobj %(AdditionalOptions) + true + webrtc_dsp;../TelegramClient/TelegramClient.Opus/opus/include;%(AdditionalIncludeDirectories) + + + Console + false + ws2_32.lib;phoneaudioses.lib;../TelegramClient/$(Platform)/$(Configuration)/TelegramClient.Opus/TelegramClient.Opus.lib;%(AdditionalDependencies) + + + + + NotUsing + _WINRT_DLL;TGVOIP_WP_SILVERLIGHT;NDEBUG;_CRT_SECURE_NO_WARNINGS;NOMINMAX;%(PreprocessorDefinitions) + pch.h + $(IntDir)pch.pch + /bigobj %(AdditionalOptions) + true + webrtc_dsp;../TelegramClient/TelegramClient.Opus/opus/include;%(AdditionalIncludeDirectories) + + + Console + false + ws2_32.lib;phoneaudioses.lib;../TelegramClient/$(Platform)/$(Configuration)/TelegramClient.Opus/TelegramClient.Opus.lib;%(AdditionalDependencies) + + + + + NotUsing + _WINRT_DLL;TGVOIP_WP_SILVERLIGHT;_CRT_SECURE_NO_WARNINGS;NOMINMAX;WEBRTC_APM_DEBUG_DUMP=0;TGVOIP_USE_CUSTOM_CRYPTO;noexcept=;_ALLOW_KEYWORD_MACROS;%(PreprocessorDefinitions) + pch.h + $(IntDir)pch.pch + /bigobj %(AdditionalOptions) + true + webrtc_dsp;../TelegramClient/TelegramClient.Opus/opus/include;%(AdditionalIncludeDirectories) + 4068;%(DisableSpecificWarnings) + + + Console + false + ws2_32.lib;phoneaudioses.lib;../TelegramClient/$(Platform)/$(Configuration)/TelegramClient.Opus/TelegramClient.Opus.lib;%(AdditionalDependencies) + + + + + NotUsing + _WINRT_DLL;TGVOIP_WP_SILVERLIGHT;NDEBUG;_CRT_SECURE_NO_WARNINGS;NOMINMAX;WEBRTC_APM_DEBUG_DUMP=0;TGVOIP_USE_CUSTOM_CRYPTO;noexcept=;_ALLOW_KEYWORD_MACROS;%(PreprocessorDefinitions) + pch.h + $(IntDir)pch.pch + /bigobj %(AdditionalOptions) + true + webrtc_dsp;../TelegramClient/TelegramClient.Opus/opus/include;%(AdditionalIncludeDirectories) + true + + + Console + false + ws2_32.lib;phoneaudioses.lib;../TelegramClient/$(Platform)/$(Configuration)/TelegramClient.Opus/TelegramClient.Opus.lib;%(AdditionalDependencies) + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + false + + + + + + + + + + + + + + + false + + + false + + + + false + + + false + + + false + + + false + + + false + + + false + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/libtgvoip.WP81.vcxproj.filters b/TMessagesProj/jni/libtgvoip2/libtgvoip.WP81.vcxproj.filters new file mode 100644 index 000000000..11034a411 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/libtgvoip.WP81.vcxproj.filters @@ -0,0 +1,488 @@ + + + + + 11199e80-17a0-460f-a780-9bfde20eb11c + rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tga;tiff;tif;png;wav;mfcribbon-ms + + + {c5b75146-c75a-4c56-aeb2-2781658d7b0a} + + + {de1527d9-7564-4e96-9653-6e023b90d2bc} + + + {3b15701a-65dd-4d52-92d4-a7b64a73b293} + + + + + + + + + + + + + + + + audio + + + audio + + + audio + + + windows + + + windows + + + windows + + + windows + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + windows + + + + + + + + + + + + + + + + + + audio + + + audio + + + audio + + + windows + + + windows + + + windows + + + windows + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + webrtc_dsp + + + windows + + + + \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/libtgvoip.xcodeproj/project.pbxproj b/TMessagesProj/jni/libtgvoip2/libtgvoip.xcodeproj/project.pbxproj new file mode 100644 index 000000000..2082459d5 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/libtgvoip.xcodeproj/project.pbxproj @@ -0,0 +1,3911 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 46; + objects = { + +/* Begin PBXBuildFile section */ + 69015D941E9D848700AC9763 /* NetworkSocket.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69015D921E9D848700AC9763 /* NetworkSocket.cpp */; }; + 6915307B1E6B5BAB004F643F /* logging.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6915307A1E6B5BAB004F643F /* logging.cpp */; }; + 6929CD102233ED81009B7378 /* PrivateDefines.h in Headers */ = {isa = PBXBuildFile; fileRef = 6929CD0F2233ED81009B7378 /* PrivateDefines.h */; }; + 692AB8CB1E6759DD00706ACC /* AudioInput.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8881E6759DD00706ACC /* AudioInput.cpp */; }; + 692AB8CD1E6759DD00706ACC /* AudioOutput.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB88A1E6759DD00706ACC /* AudioOutput.cpp */; }; + 692AB8CF1E6759DD00706ACC /* BlockingQueue.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB88C1E6759DD00706ACC /* BlockingQueue.cpp */; }; + 692AB8D81E6759DD00706ACC /* CongestionControl.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8971E6759DD00706ACC /* CongestionControl.cpp */; }; + 692AB8DA1E6759DD00706ACC /* EchoCanceller.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8991E6759DD00706ACC /* EchoCanceller.cpp */; }; + 692AB8E61E6759DD00706ACC /* JitterBuffer.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8A81E6759DD00706ACC /* JitterBuffer.cpp */; }; + 692AB8E91E6759DD00706ACC /* MediaStreamItf.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8AB1E6759DD00706ACC /* MediaStreamItf.cpp */; }; + 692AB8EB1E6759DD00706ACC /* OpusDecoder.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8AD1E6759DD00706ACC /* OpusDecoder.cpp */; }; + 692AB8ED1E6759DD00706ACC /* OpusEncoder.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8AF1E6759DD00706ACC /* OpusEncoder.cpp */; }; + 692AB8F91E6759DD00706ACC /* AudioInputAudioUnit.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8BE1E6759DD00706ACC /* AudioInputAudioUnit.cpp */; }; + 692AB8FB1E6759DD00706ACC /* AudioOutputAudioUnit.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8C01E6759DD00706ACC /* AudioOutputAudioUnit.cpp */; }; + 692AB8FD1E6759DD00706ACC /* AudioUnitIO.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8C21E6759DD00706ACC /* AudioUnitIO.cpp */; }; + 692AB9001E6759DD00706ACC /* TGLogWrapper.m in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8C51E6759DD00706ACC /* TGLogWrapper.m */; }; + 692AB9021E6759DD00706ACC /* VoIPController.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8C71E6759DD00706ACC /* VoIPController.cpp */; }; + 692AB9031E6759DD00706ACC /* VoIPController.h in Headers */ = {isa = PBXBuildFile; fileRef = 692AB8C81E6759DD00706ACC /* VoIPController.h */; }; + 692AB9041E6759DD00706ACC /* VoIPServerConfig.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8C91E6759DD00706ACC /* VoIPServerConfig.cpp */; }; + 692AB9051E6759DD00706ACC /* VoIPServerConfig.h in Headers */ = {isa = PBXBuildFile; fileRef = 692AB8CA1E6759DD00706ACC /* VoIPServerConfig.h */; }; + 692AB91F1E675F7000706ACC /* AudioToolbox.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 692AB91C1E675F7000706ACC /* AudioToolbox.framework */; }; + 692AB9201E675F7000706ACC /* AudioUnit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 692AB91D1E675F7000706ACC /* AudioUnit.framework */; }; + 692AB9211E675F7000706ACC /* CoreAudio.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 692AB91E1E675F7000706ACC /* CoreAudio.framework */; }; + 69719A7B224A627F00FE9B2A /* VideoPacketSender.h in Headers */ = {isa = PBXBuildFile; fileRef = 69719A77224A627E00FE9B2A /* VideoPacketSender.h */; }; + 69719A7C224A627F00FE9B2A /* VideoFEC.h in Headers */ = {isa = PBXBuildFile; fileRef = 69719A78224A627E00FE9B2A /* VideoFEC.h */; }; + 69719A7D224A627F00FE9B2A /* VideoFEC.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69719A79224A627F00FE9B2A /* VideoFEC.cpp */; }; + 69719A7E224A627F00FE9B2A /* VideoPacketSender.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69719A7A224A627F00FE9B2A /* VideoPacketSender.cpp */; }; + 69791A4D1EE8262400BB85FB /* NetworkSocketPosix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69791A4B1EE8262400BB85FB /* NetworkSocketPosix.cpp */; }; + 69791A571EE8272A00BB85FB /* Resampler.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69791A551EE8272A00BB85FB /* Resampler.cpp */; }; + 697E9B2721A4ED6B00E03846 /* field_trial.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E989221A4ED6800E03846 /* field_trial.cc */; }; + 697E9B2821A4ED6B00E03846 /* metrics.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E989321A4ED6800E03846 /* metrics.cc */; }; + 697E9B2921A4ED6B00E03846 /* cpu_features.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E989421A4ED6800E03846 /* cpu_features.cc */; }; + 697E9B2C21A4ED6B00E03846 /* window_generator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E989921A4ED6800E03846 /* window_generator.cc */; }; + 697E9B2D21A4ED6B00E03846 /* channel_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E989A21A4ED6800E03846 /* channel_buffer.cc */; }; + 697E9B2E21A4ED6B00E03846 /* fir_filter_factory.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E989B21A4ED6800E03846 /* fir_filter_factory.cc */; }; + 697E9B3521A4ED6B00E03846 /* wav_header.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98A321A4ED6800E03846 /* wav_header.cc */; }; + 697E9B3621A4ED6B00E03846 /* real_fourier_ooura.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98A421A4ED6800E03846 /* real_fourier_ooura.cc */; }; + 697E9B3721A4ED6B00E03846 /* fir_filter_neon.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98A521A4ED6800E03846 /* fir_filter_neon.cc */; }; + 697E9B3821A4ED6B00E03846 /* audio_util.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98A621A4ED6800E03846 /* audio_util.cc */; }; + 697E9B3A21A4ED6B00E03846 /* fir_filter_sse.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98A821A4ED6800E03846 /* fir_filter_sse.cc */; }; + 697E9B3C21A4ED6B00E03846 /* sinc_resampler_neon.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98AB21A4ED6800E03846 /* sinc_resampler_neon.cc */; }; + 697E9B3D21A4ED6B00E03846 /* push_sinc_resampler.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98AC21A4ED6800E03846 /* push_sinc_resampler.cc */; }; + 697E9B3F21A4ED6B00E03846 /* resampler.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98AE21A4ED6800E03846 /* resampler.cc */; }; + 697E9B4021A4ED6B00E03846 /* sinc_resampler_sse.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98AF21A4ED6800E03846 /* sinc_resampler_sse.cc */; }; + 697E9B4421A4ED6B00E03846 /* push_resampler.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98B421A4ED6800E03846 /* push_resampler.cc */; }; + 697E9B4621A4ED6B00E03846 /* sinc_resampler.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98B621A4ED6800E03846 /* sinc_resampler.cc */; }; + 697E9B4721A4ED6B00E03846 /* sinusoidal_linear_chirp_source.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98B721A4ED6800E03846 /* sinusoidal_linear_chirp_source.cc */; }; + 697E9B4A21A4ED6B00E03846 /* wav_file.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98BA21A4ED6800E03846 /* wav_file.cc */; }; + 697E9B4B21A4ED6B00E03846 /* spl_sqrt_floor.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98BD21A4ED6800E03846 /* spl_sqrt_floor.c */; }; + 697E9B4E21A4ED6B00E03846 /* fft4g.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98C121A4ED6800E03846 /* fft4g.c */; }; + 697E9B5021A4ED6B00E03846 /* audio_converter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98C321A4ED6800E03846 /* audio_converter.cc */; }; + 697E9B5121A4ED6B00E03846 /* real_fourier.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98C421A4ED6800E03846 /* real_fourier.cc */; }; + 697E9B5421A4ED6B00E03846 /* sparse_fir_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98C721A4ED6800E03846 /* sparse_fir_filter.cc */; }; + 697E9B5621A4ED6B00E03846 /* smoothing_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98C921A4ED6800E03846 /* smoothing_filter.cc */; }; + 697E9B5721A4ED6B00E03846 /* fir_filter_c.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98CA21A4ED6800E03846 /* fir_filter_c.cc */; }; + 697E9B5821A4ED6B00E03846 /* ring_buffer.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98CB21A4ED6800E03846 /* ring_buffer.c */; }; + 697E9B5B21A4ED6B00E03846 /* complex_fft.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98CF21A4ED6800E03846 /* complex_fft.c */; }; + 697E9B5C21A4ED6B00E03846 /* filter_ma_fast_q12.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98D021A4ED6800E03846 /* filter_ma_fast_q12.c */; }; + 697E9B5D21A4ED6B00E03846 /* splitting_filter1.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98D121A4ED6800E03846 /* splitting_filter1.c */; }; + 697E9B5E21A4ED6B00E03846 /* levinson_durbin.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98D221A4ED6800E03846 /* levinson_durbin.c */; }; + 697E9B5F21A4ED6B00E03846 /* downsample_fast_neon.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98D321A4ED6800E03846 /* downsample_fast_neon.c */; }; + 697E9B6021A4ED6B00E03846 /* dot_product_with_scale.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98D421A4ED6800E03846 /* dot_product_with_scale.cc */; }; + 697E9B6121A4ED6B00E03846 /* auto_corr_to_refl_coef.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98D521A4ED6800E03846 /* auto_corr_to_refl_coef.c */; }; + 697E9B6221A4ED6B00E03846 /* resample_by_2_internal.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98D621A4ED6800E03846 /* resample_by_2_internal.c */; }; + 697E9B6421A4ED6B00E03846 /* energy.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98D821A4ED6800E03846 /* energy.c */; }; + 697E9B6521A4ED6B00E03846 /* sqrt_of_one_minus_x_squared.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98D921A4ED6800E03846 /* sqrt_of_one_minus_x_squared.c */; }; + 697E9B6621A4ED6B00E03846 /* downsample_fast.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98DA21A4ED6800E03846 /* downsample_fast.c */; }; + 697E9B6721A4ED6B00E03846 /* filter_ar_fast_q12.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98DB21A4ED6800E03846 /* filter_ar_fast_q12.c */; }; + 697E9B6821A4ED6B00E03846 /* spl_init.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98DC21A4ED6800E03846 /* spl_init.c */; }; + 697E9B6921A4ED6B00E03846 /* lpc_to_refl_coef.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98DD21A4ED6800E03846 /* lpc_to_refl_coef.c */; }; + 697E9B6A21A4ED6B00E03846 /* cross_correlation.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98DE21A4ED6800E03846 /* cross_correlation.c */; }; + 697E9B6F21A4ED6B00E03846 /* division_operations.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98E421A4ED6800E03846 /* division_operations.c */; }; + 697E9B7021A4ED6B00E03846 /* auto_correlation.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98E521A4ED6800E03846 /* auto_correlation.c */; }; + 697E9B7121A4ED6B00E03846 /* get_scaling_square.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98E621A4ED6800E03846 /* get_scaling_square.c */; }; + 697E9B7221A4ED6B00E03846 /* min_max_operations_neon.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98E721A4ED6800E03846 /* min_max_operations_neon.c */; }; + 697E9B7521A4ED6B00E03846 /* resample.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98EA21A4ED6800E03846 /* resample.c */; }; + 697E9B7621A4ED6B00E03846 /* cross_correlation_neon.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98EB21A4ED6800E03846 /* cross_correlation_neon.c */; }; + 697E9B7721A4ED6B00E03846 /* min_max_operations.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98EC21A4ED6800E03846 /* min_max_operations.c */; }; + 697E9B7821A4ED6B00E03846 /* refl_coef_to_lpc.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98ED21A4ED6800E03846 /* refl_coef_to_lpc.c */; }; + 697E9B7921A4ED6B00E03846 /* filter_ar.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98EE21A4ED6800E03846 /* filter_ar.c */; }; + 697E9B7A21A4ED6B00E03846 /* vector_scaling_operations.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98EF21A4ED6800E03846 /* vector_scaling_operations.c */; }; + 697E9B7B21A4ED6B00E03846 /* resample_fractional.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98F021A4ED6800E03846 /* resample_fractional.c */; }; + 697E9B7C21A4ED6B00E03846 /* real_fft.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98F121A4ED6800E03846 /* real_fft.c */; }; + 697E9B7D21A4ED6B00E03846 /* ilbc_specific_functions.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98F221A4ED6800E03846 /* ilbc_specific_functions.c */; }; + 697E9B7E21A4ED6B00E03846 /* complex_bit_reverse.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98F321A4ED6800E03846 /* complex_bit_reverse.c */; }; + 697E9B7F21A4ED6B00E03846 /* randomization_functions.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98F421A4ED6800E03846 /* randomization_functions.c */; }; + 697E9B8121A4ED6B00E03846 /* copy_set_operations.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98F621A4ED6800E03846 /* copy_set_operations.c */; }; + 697E9B8221A4ED6B00E03846 /* resample_by_2.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98F721A4ED6800E03846 /* resample_by_2.c */; }; + 697E9B8321A4ED6B00E03846 /* get_hanning_window.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98F821A4ED6800E03846 /* get_hanning_window.c */; }; + 697E9B8421A4ED6B00E03846 /* resample_48khz.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98F921A4ED6800E03846 /* resample_48khz.c */; }; + 697E9B8521A4ED6B00E03846 /* spl_inl.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98FA21A4ED6800E03846 /* spl_inl.c */; }; + 697E9B8621A4ED6B00E03846 /* spl_sqrt.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98FB21A4ED6800E03846 /* spl_sqrt.c */; }; + 697E9B8821A4ED6B00E03846 /* vad_sp.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E98FE21A4ED6800E03846 /* vad_sp.c */; }; + 697E9B8921A4ED6B00E03846 /* vad.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E98FF21A4ED6800E03846 /* vad.cc */; }; + 697E9B8A21A4ED6B00E03846 /* webrtc_vad.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E990021A4ED6800E03846 /* webrtc_vad.c */; }; + 697E9B8F21A4ED6B00E03846 /* vad_filterbank.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E990621A4ED6800E03846 /* vad_filterbank.c */; }; + 697E9B9021A4ED6B00E03846 /* vad_core.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E990721A4ED6800E03846 /* vad_core.c */; }; + 697E9B9321A4ED6B00E03846 /* vad_gmm.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E990A21A4ED6800E03846 /* vad_gmm.c */; }; + 697E9B9521A4ED6B00E03846 /* memutil.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E990F21A4ED6800E03846 /* memutil.cc */; }; + 697E9B9621A4ED6B00E03846 /* string_view.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E991021A4ED6800E03846 /* string_view.cc */; }; + 697E9B9821A4ED6B00E03846 /* ascii.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E991221A4ED6800E03846 /* ascii.cc */; }; + 697E9B9C21A4ED6B00E03846 /* bad_optional_access.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E991721A4ED6800E03846 /* bad_optional_access.cc */; }; + 697E9B9D21A4ED6B00E03846 /* optional.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E991821A4ED6800E03846 /* optional.cc */; }; + 697E9BA521A4ED6B00E03846 /* raw_logging.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E992621A4ED6800E03846 /* raw_logging.cc */; }; + 697E9BA621A4ED6B00E03846 /* throw_delegate.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E992721A4ED6800E03846 /* throw_delegate.cc */; }; + 697E9BB221A4ED6B00E03846 /* audio_frame.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E993621A4ED6900E03846 /* audio_frame.cc */; }; + 697E9BB621A4ED6B00E03846 /* echo_canceller3_config.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E993A21A4ED6900E03846 /* echo_canceller3_config.cc */; }; + 697E9BB821A4ED6B00E03846 /* echo_canceller3_factory.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E993C21A4ED6900E03846 /* echo_canceller3_factory.cc */; }; + 697E9BBC21A4ED6B00E03846 /* race_checker.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E994121A4ED6900E03846 /* race_checker.cc */; }; + 697E9BBE21A4ED6B00E03846 /* string_builder.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E994421A4ED6900E03846 /* string_builder.cc */; }; + 697E9BC121A4ED6B00E03846 /* aligned_malloc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E994821A4ED6900E03846 /* aligned_malloc.cc */; }; + 697E9BC321A4ED6B00E03846 /* timeutils.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E994A21A4ED6900E03846 /* timeutils.cc */; }; + 697E9BC921A4ED6C00E03846 /* platform_file.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E995021A4ED6900E03846 /* platform_file.cc */; }; + 697E9BCB21A4ED6C00E03846 /* string_to_number.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E995221A4ED6900E03846 /* string_to_number.cc */; }; + 697E9BCF21A4ED6C00E03846 /* thread_checker_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E995621A4ED6900E03846 /* thread_checker_impl.cc */; }; + 697E9BD521A4ED6C00E03846 /* stringencode.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E995C21A4ED6900E03846 /* stringencode.cc */; }; + 697E9BD621A4ED6C00E03846 /* stringutils.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E995D21A4ED6900E03846 /* stringutils.cc */; }; + 697E9BD721A4ED6C00E03846 /* checks.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E995E21A4ED6900E03846 /* checks.cc */; }; + 697E9BE221A4ED6C00E03846 /* platform_thread.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E996B21A4ED6900E03846 /* platform_thread.cc */; }; + 697E9BE421A4ED6C00E03846 /* logging_webrtc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E996D21A4ED6900E03846 /* logging_webrtc.cc */; }; + 697E9BEB21A4ED6C00E03846 /* criticalsection.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E997421A4ED6900E03846 /* criticalsection.cc */; }; + 697E9BEC21A4ED6C00E03846 /* platform_thread_types.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E997521A4ED6900E03846 /* platform_thread_types.cc */; }; + 697E9BEE21A4ED6C00E03846 /* event.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E997721A4ED6900E03846 /* event.cc */; }; + 697E9BF021A4ED6C00E03846 /* event_tracer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E997921A4ED6900E03846 /* event_tracer.cc */; }; + 697E9BFA21A4ED6C00E03846 /* fft.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E998621A4ED6900E03846 /* fft.c */; }; + 697E9BFD21A4ED6C00E03846 /* pitch_estimator.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E998F21A4ED6900E03846 /* pitch_estimator.c */; }; + 697E9BFE21A4ED6C00E03846 /* lpc_shape_swb16_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E999021A4ED6900E03846 /* lpc_shape_swb16_tables.c */; }; + 697E9BFF21A4ED6C00E03846 /* pitch_gain_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E999121A4ED6900E03846 /* pitch_gain_tables.c */; }; + 697E9C0021A4ED6C00E03846 /* arith_routines_logist.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E999221A4ED6900E03846 /* arith_routines_logist.c */; }; + 697E9C0221A4ED6C00E03846 /* filterbanks.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E999421A4ED6900E03846 /* filterbanks.c */; }; + 697E9C0621A4ED6C00E03846 /* transform.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E999821A4ED6900E03846 /* transform.c */; }; + 697E9C0A21A4ED6C00E03846 /* pitch_filter.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E999C21A4ED6900E03846 /* pitch_filter.c */; }; + 697E9C0B21A4ED6C00E03846 /* encode_lpc_swb.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E999D21A4ED6900E03846 /* encode_lpc_swb.c */; }; + 697E9C0C21A4ED6C00E03846 /* filter_functions.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E999E21A4ED6900E03846 /* filter_functions.c */; }; + 697E9C0D21A4ED6C00E03846 /* decode.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E999F21A4ED6900E03846 /* decode.c */; }; + 697E9C0E21A4ED6C00E03846 /* lattice.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99A021A4ED6900E03846 /* lattice.c */; }; + 697E9C0F21A4ED6C00E03846 /* intialize.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99A121A4ED6900E03846 /* intialize.c */; }; + 697E9C1021A4ED6C00E03846 /* lpc_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99A221A4ED6900E03846 /* lpc_tables.c */; }; + 697E9C1121A4ED6C00E03846 /* lpc_gain_swb_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99A321A4ED6900E03846 /* lpc_gain_swb_tables.c */; }; + 697E9C1221A4ED6C00E03846 /* bandwidth_estimator.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99A421A4ED6900E03846 /* bandwidth_estimator.c */; }; + 697E9C1521A4ED6C00E03846 /* encode.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99A721A4ED6900E03846 /* encode.c */; }; + 697E9C1621A4ED6C00E03846 /* lpc_analysis.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99A821A4ED6900E03846 /* lpc_analysis.c */; }; + 697E9C1821A4ED6C00E03846 /* arith_routines_hist.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99AA21A4ED6900E03846 /* arith_routines_hist.c */; }; + 697E9C1D21A4ED6C00E03846 /* entropy_coding.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99AF21A4ED6900E03846 /* entropy_coding.c */; }; + 697E9C1E21A4ED6C00E03846 /* isac_vad.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99B021A4ED6900E03846 /* isac_vad.c */; }; + 697E9C2321A4ED6C00E03846 /* arith_routines.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99B521A4ED6900E03846 /* arith_routines.c */; }; + 697E9C2421A4ED6C00E03846 /* crc.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99B621A4ED6900E03846 /* crc.c */; }; + 697E9C2521A4ED6C00E03846 /* lpc_shape_swb12_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99B721A4ED6900E03846 /* lpc_shape_swb12_tables.c */; }; + 697E9C2721A4ED6C00E03846 /* decode_bwe.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99B921A4ED6900E03846 /* decode_bwe.c */; }; + 697E9C2821A4ED6C00E03846 /* spectrum_ar_model_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99BA21A4ED6900E03846 /* spectrum_ar_model_tables.c */; }; + 697E9C2A21A4ED6C00E03846 /* pitch_lag_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99BC21A4ED6900E03846 /* pitch_lag_tables.c */; }; + 697E9C2B21A4ED6C00E03846 /* isac.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99BD21A4ED6900E03846 /* isac.c */; }; + 697E9C2E21A4ED6C00E03846 /* rms_level.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99C121A4ED6900E03846 /* rms_level.cc */; }; + 697E9C3221A4ED6C00E03846 /* normalized_covariance_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99C621A4ED6900E03846 /* normalized_covariance_estimator.cc */; }; + 697E9C3321A4ED6C00E03846 /* moving_max.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99C721A4ED6900E03846 /* moving_max.cc */; }; + 697E9C3421A4ED6C00E03846 /* circular_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99C821A4ED6900E03846 /* circular_buffer.cc */; }; + 697E9C3521A4ED6C00E03846 /* mean_variance_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99C921A4ED6900E03846 /* mean_variance_estimator.cc */; }; + 697E9C3821A4ED6C00E03846 /* splitting_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99CC21A4ED6900E03846 /* splitting_filter.cc */; }; + 697E9C3921A4ED6C00E03846 /* gain_control_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99CD21A4ED6900E03846 /* gain_control_impl.cc */; }; + 697E9C3C21A4ED6C00E03846 /* nsx_core.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99D521A4ED6900E03846 /* nsx_core.c */; }; + 697E9C3D21A4ED6C00E03846 /* noise_suppression_x.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99D621A4ED6900E03846 /* noise_suppression_x.c */; }; + 697E9C3E21A4ED6C00E03846 /* nsx_core_c.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99D721A4ED6900E03846 /* nsx_core_c.c */; }; + 697E9C4121A4ED6C00E03846 /* ns_core.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99DA21A4ED6900E03846 /* ns_core.c */; }; + 697E9C4521A4ED6C00E03846 /* nsx_core_neon.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99DE21A4ED6900E03846 /* nsx_core_neon.c */; }; + 697E9C4621A4ED6C00E03846 /* noise_suppression.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E99DF21A4ED6900E03846 /* noise_suppression.c */; }; + 697E9C4A21A4ED6C00E03846 /* audio_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99E321A4ED6900E03846 /* audio_buffer.cc */; }; + 697E9C4B21A4ED6C00E03846 /* typing_detection.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99E421A4ED6900E03846 /* typing_detection.cc */; }; + 697E9C5321A4ED6C00E03846 /* audio_processing_statistics.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99EE21A4ED6900E03846 /* audio_processing_statistics.cc */; }; + 697E9C5421A4ED6C00E03846 /* audio_generator_factory.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99EF21A4ED6900E03846 /* audio_generator_factory.cc */; }; + 697E9C5521A4ED6C00E03846 /* aec_dump.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99F021A4ED6900E03846 /* aec_dump.cc */; }; + 697E9C5921A4ED6C00E03846 /* audio_processing.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99F421A4ED6900E03846 /* audio_processing.cc */; }; + 697E9C5A21A4ED6C00E03846 /* config.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99F521A4ED6900E03846 /* config.cc */; }; + 697E9C5D21A4ED6C00E03846 /* interpolated_gain_curve.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99F921A4ED6900E03846 /* interpolated_gain_curve.cc */; }; + 697E9C5E21A4ED6C00E03846 /* agc2_common.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99FA21A4ED6900E03846 /* agc2_common.cc */; }; + 697E9C6121A4ED6C00E03846 /* gain_applier.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99FD21A4ED6900E03846 /* gain_applier.cc */; }; + 697E9C6321A4ED6C00E03846 /* adaptive_agc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E99FF21A4ED6900E03846 /* adaptive_agc.cc */; }; + 697E9C6421A4ED6C00E03846 /* adaptive_digital_gain_applier.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A0021A4ED6900E03846 /* adaptive_digital_gain_applier.cc */; }; + 697E9C6521A4ED6C00E03846 /* limiter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A0121A4ED6900E03846 /* limiter.cc */; }; + 697E9C6621A4ED6C00E03846 /* saturation_protector.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A0221A4ED6900E03846 /* saturation_protector.cc */; }; + 697E9C6821A4ED6C00E03846 /* spectral_features_internal.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A0521A4ED6900E03846 /* spectral_features_internal.cc */; }; + 697E9C6B21A4ED6C00E03846 /* rnn.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A0821A4ED6900E03846 /* rnn.cc */; }; + 697E9C7021A4ED6C00E03846 /* pitch_search_internal.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A0D21A4ED6900E03846 /* pitch_search_internal.cc */; }; + 697E9C7721A4ED6C00E03846 /* spectral_features.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A1421A4ED6900E03846 /* spectral_features.cc */; }; + 697E9C7921A4ED6C00E03846 /* pitch_search.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A1621A4ED6900E03846 /* pitch_search.cc */; }; + 697E9C7B21A4ED6C00E03846 /* features_extraction.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A1821A4ED6900E03846 /* features_extraction.cc */; }; + 697E9C7C21A4ED6C00E03846 /* fft_util.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A1921A4ED6900E03846 /* fft_util.cc */; }; + 697E9C7D21A4ED6C00E03846 /* lp_residual.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A1A21A4ED6900E03846 /* lp_residual.cc */; }; + 697E9C7F21A4ED6C00E03846 /* adaptive_mode_level_estimator_agc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A1C21A4ED6900E03846 /* adaptive_mode_level_estimator_agc.cc */; }; + 697E9C8021A4ED6C00E03846 /* vector_float_frame.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A1D21A4ED6900E03846 /* vector_float_frame.cc */; }; + 697E9C8221A4ED6C00E03846 /* noise_level_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A1F21A4ED6900E03846 /* noise_level_estimator.cc */; }; + 697E9C8321A4ED6C00E03846 /* agc2_testing_common.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A2021A4ED6900E03846 /* agc2_testing_common.cc */; }; + 697E9C8421A4ED6C00E03846 /* fixed_digital_level_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A2121A4ED6900E03846 /* fixed_digital_level_estimator.cc */; }; + 697E9C8521A4ED6C00E03846 /* fixed_gain_controller.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A2221A4ED6900E03846 /* fixed_gain_controller.cc */; }; + 697E9C8721A4ED6C00E03846 /* vad_with_level.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A2421A4ED6900E03846 /* vad_with_level.cc */; }; + 697E9C8821A4ED6C00E03846 /* limiter_db_gain_curve.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A2521A4ED6900E03846 /* limiter_db_gain_curve.cc */; }; + 697E9C9121A4ED6D00E03846 /* down_sampler.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A2E21A4ED6900E03846 /* down_sampler.cc */; }; + 697E9C9321A4ED6D00E03846 /* signal_classifier.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A3021A4ED6900E03846 /* signal_classifier.cc */; }; + 697E9C9421A4ED6D00E03846 /* noise_spectrum_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A3121A4ED6900E03846 /* noise_spectrum_estimator.cc */; }; + 697E9C9521A4ED6D00E03846 /* compute_interpolated_gain_curve.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A3221A4ED6900E03846 /* compute_interpolated_gain_curve.cc */; }; + 697E9C9721A4ED6D00E03846 /* biquad_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A3421A4ED6900E03846 /* biquad_filter.cc */; }; + 697E9C9A21A4ED6D00E03846 /* adaptive_mode_level_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A3721A4ED6900E03846 /* adaptive_mode_level_estimator.cc */; }; + 697E9C9B21A4ED6D00E03846 /* moving_moments.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A3921A4ED6900E03846 /* moving_moments.cc */; }; + 697E9C9D21A4ED6D00E03846 /* wpd_tree.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A3B21A4ED6900E03846 /* wpd_tree.cc */; }; + 697E9CA421A4ED6D00E03846 /* wpd_node.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A4221A4ED6900E03846 /* wpd_node.cc */; }; + 697E9CA521A4ED6D00E03846 /* transient_suppressor.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A4321A4ED6900E03846 /* transient_suppressor.cc */; }; + 697E9CA621A4ED6D00E03846 /* transient_detector.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A4421A4ED6900E03846 /* transient_detector.cc */; }; + 697E9CA821A4ED6D00E03846 /* low_cut_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A4621A4ED6900E03846 /* low_cut_filter.cc */; }; + 697E9CAA21A4ED6D00E03846 /* level_estimator_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A4821A4ED6900E03846 /* level_estimator_impl.cc */; }; + 697E9CAB21A4ED6D00E03846 /* three_band_filter_bank.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A4921A4ED6900E03846 /* three_band_filter_bank.cc */; }; + 697E9CAC21A4ED6D00E03846 /* echo_cancellation.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A4B21A4ED6900E03846 /* echo_cancellation.cc */; }; + 697E9CAE21A4ED6D00E03846 /* aec_resampler.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A4D21A4ED6900E03846 /* aec_resampler.cc */; }; + 697E9CB021A4ED6D00E03846 /* aec_core.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A4F21A4ED6900E03846 /* aec_core.cc */; }; + 697E9CB321A4ED6D00E03846 /* aec_core_neon.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A5221A4ED6900E03846 /* aec_core_neon.cc */; }; + 697E9CB421A4ED6D00E03846 /* aec_core_sse2.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A5321A4ED6900E03846 /* aec_core_sse2.cc */; }; + 697E9CB721A4ED6D00E03846 /* voice_detection_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A5621A4ED6900E03846 /* voice_detection_impl.cc */; }; + 697E9CB821A4ED6D00E03846 /* echo_cancellation_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A5721A4ED6900E03846 /* echo_cancellation_impl.cc */; }; + 697E9CB921A4ED6D00E03846 /* gain_control_for_experimental_agc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A5821A4ED6900E03846 /* gain_control_for_experimental_agc.cc */; }; + 697E9CBA21A4ED6D00E03846 /* agc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A5A21A4ED6900E03846 /* agc.cc */; }; + 697E9CBB21A4ED6D00E03846 /* loudness_histogram.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A5B21A4ED6900E03846 /* loudness_histogram.cc */; }; + 697E9CBC21A4ED6D00E03846 /* agc_manager_direct.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A5C21A4ED6900E03846 /* agc_manager_direct.cc */; }; + 697E9CC021A4ED6D00E03846 /* analog_agc.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A6121A4ED6900E03846 /* analog_agc.c */; }; + 697E9CC121A4ED6D00E03846 /* digital_agc.c in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A6221A4ED6900E03846 /* digital_agc.c */; }; + 697E9CC221A4ED6D00E03846 /* utility.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A6321A4ED6900E03846 /* utility.cc */; }; + 697E9CCA21A4ED6D00E03846 /* audio_processing_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A6B21A4ED6900E03846 /* audio_processing_impl.cc */; }; + 697E9CD021A4ED6D00E03846 /* file_audio_generator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A7221A4ED6A00E03846 /* file_audio_generator.cc */; }; + 697E9CD121A4ED6D00E03846 /* gain_controller2.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A7321A4ED6A00E03846 /* gain_controller2.cc */; }; + 697E9CD321A4ED6D00E03846 /* residual_echo_detector.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A7521A4ED6A00E03846 /* residual_echo_detector.cc */; }; + 697E9CD521A4ED6D00E03846 /* noise_suppression_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A7721A4ED6A00E03846 /* noise_suppression_impl.cc */; }; + 697E9CDA21A4ED6D00E03846 /* aecm_core.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A7D21A4ED6A00E03846 /* aecm_core.cc */; }; + 697E9CDB21A4ED6D00E03846 /* aecm_core_c.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A7E21A4ED6A00E03846 /* aecm_core_c.cc */; }; + 697E9CDC21A4ED6D00E03846 /* aecm_core_neon.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A7F21A4ED6A00E03846 /* aecm_core_neon.cc */; }; + 697E9CDE21A4ED6D00E03846 /* echo_control_mobile.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A8121A4ED6A00E03846 /* echo_control_mobile.cc */; }; + 697E9CDF21A4ED6D00E03846 /* render_reverb_model.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A8321A4ED6A00E03846 /* render_reverb_model.cc */; }; + 697E9CE221A4ED6D00E03846 /* reverb_model_fallback.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A8621A4ED6A00E03846 /* reverb_model_fallback.cc */; }; + 697E9CE521A4ED6D00E03846 /* echo_remover_metrics.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A8921A4ED6A00E03846 /* echo_remover_metrics.cc */; }; + 697E9CE621A4ED6D00E03846 /* matched_filter_lag_aggregator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A8A21A4ED6A00E03846 /* matched_filter_lag_aggregator.cc */; }; + 697E9CE721A4ED6D00E03846 /* render_delay_buffer2.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A8B21A4ED6A00E03846 /* render_delay_buffer2.cc */; }; + 697E9CEA21A4ED6D00E03846 /* echo_path_variability.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A8E21A4ED6A00E03846 /* echo_path_variability.cc */; }; + 697E9CEB21A4ED6D00E03846 /* frame_blocker.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A8F21A4ED6A00E03846 /* frame_blocker.cc */; }; + 697E9CEC21A4ED6D00E03846 /* subtractor.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A9021A4ED6A00E03846 /* subtractor.cc */; }; + 697E9CF321A4ED6D00E03846 /* aec3_fft.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A9721A4ED6A00E03846 /* aec3_fft.cc */; }; + 697E9CF621A4ED6D00E03846 /* fullband_erle_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A9A21A4ED6A00E03846 /* fullband_erle_estimator.cc */; }; + 697E9CF721A4ED6D00E03846 /* suppression_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A9B21A4ED6A00E03846 /* suppression_filter.cc */; }; + 697E9CF821A4ED6D00E03846 /* block_processor.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9A9C21A4ED6A00E03846 /* block_processor.cc */; }; + 697E9CFC21A4ED6D00E03846 /* subband_erle_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AA021A4ED6A00E03846 /* subband_erle_estimator.cc */; }; + 697E9CFD21A4ED6D00E03846 /* render_delay_controller_metrics.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AA121A4ED6A00E03846 /* render_delay_controller_metrics.cc */; }; + 697E9CFE21A4ED6D00E03846 /* render_delay_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AA221A4ED6A00E03846 /* render_delay_buffer.cc */; }; + 697E9D0021A4ED6D00E03846 /* vector_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AA421A4ED6A00E03846 /* vector_buffer.cc */; }; + 697E9D0121A4ED6D00E03846 /* erl_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AA521A4ED6A00E03846 /* erl_estimator.cc */; }; + 697E9D0221A4ED6D00E03846 /* aec_state.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AA621A4ED6A00E03846 /* aec_state.cc */; }; + 697E9D0321A4ED6D00E03846 /* adaptive_fir_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AA721A4ED6A00E03846 /* adaptive_fir_filter.cc */; }; + 697E9D0521A4ED6D00E03846 /* render_delay_controller.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AA921A4ED6A00E03846 /* render_delay_controller.cc */; }; + 697E9D0621A4ED6D00E03846 /* skew_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AAA21A4ED6A00E03846 /* skew_estimator.cc */; }; + 697E9D0921A4ED6D00E03846 /* echo_path_delay_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AAD21A4ED6A00E03846 /* echo_path_delay_estimator.cc */; }; + 697E9D0C21A4ED6D00E03846 /* block_framer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AB021A4ED6A00E03846 /* block_framer.cc */; }; + 697E9D0D21A4ED6D00E03846 /* erle_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AB121A4ED6A00E03846 /* erle_estimator.cc */; }; + 697E9D0E21A4ED6D00E03846 /* reverb_model.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AB221A4ED6A00E03846 /* reverb_model.cc */; }; + 697E9D0F21A4ED6D00E03846 /* cascaded_biquad_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AB321A4ED6A00E03846 /* cascaded_biquad_filter.cc */; }; + 697E9D1121A4ED6D00E03846 /* render_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AB521A4ED6A00E03846 /* render_buffer.cc */; }; + 697E9D1321A4ED6D00E03846 /* subtractor_output.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AB721A4ED6A00E03846 /* subtractor_output.cc */; }; + 697E9D1421A4ED6D00E03846 /* stationarity_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AB821A4ED6A00E03846 /* stationarity_estimator.cc */; }; + 697E9D1521A4ED6D00E03846 /* render_signal_analyzer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AB921A4ED6A00E03846 /* render_signal_analyzer.cc */; }; + 697E9D1921A4ED6D00E03846 /* subtractor_output_analyzer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9ABD21A4ED6A00E03846 /* subtractor_output_analyzer.cc */; }; + 697E9D1A21A4ED6D00E03846 /* suppression_gain.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9ABE21A4ED6A00E03846 /* suppression_gain.cc */; }; + 697E9D1B21A4ED6D00E03846 /* echo_audibility.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9ABF21A4ED6A00E03846 /* echo_audibility.cc */; }; + 697E9D1C21A4ED6D00E03846 /* block_processor_metrics.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AC021A4ED6A00E03846 /* block_processor_metrics.cc */; }; + 697E9D1F21A4ED6D00E03846 /* moving_average.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AC321A4ED6A00E03846 /* moving_average.cc */; }; + 697E9D2221A4ED6D00E03846 /* reverb_model_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AC621A4ED6A00E03846 /* reverb_model_estimator.cc */; }; + 697E9D2321A4ED6D00E03846 /* aec3_common.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AC721A4ED6A00E03846 /* aec3_common.cc */; }; + 697E9D2421A4ED6D00E03846 /* residual_echo_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AC821A4ED6A00E03846 /* residual_echo_estimator.cc */; }; + 697E9D2721A4ED6D00E03846 /* matched_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9ACB21A4ED6A00E03846 /* matched_filter.cc */; }; + 697E9D2B21A4ED6D00E03846 /* reverb_decay_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9ACF21A4ED6A00E03846 /* reverb_decay_estimator.cc */; }; + 697E9D2C21A4ED6D00E03846 /* render_delay_controller2.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AD021A4ED6A00E03846 /* render_delay_controller2.cc */; }; + 697E9D2E21A4ED6D00E03846 /* suppression_gain_limiter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AD221A4ED6A00E03846 /* suppression_gain_limiter.cc */; }; + 697E9D2F21A4ED6D00E03846 /* main_filter_update_gain.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AD321A4ED6A00E03846 /* main_filter_update_gain.cc */; }; + 697E9D3021A4ED6D00E03846 /* echo_remover.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AD421A4ED6A00E03846 /* echo_remover.cc */; }; + 697E9D3221A4ED6D00E03846 /* downsampled_render_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AD621A4ED6A00E03846 /* downsampled_render_buffer.cc */; }; + 697E9D3421A4ED6D00E03846 /* matrix_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AD821A4ED6A00E03846 /* matrix_buffer.cc */; }; + 697E9D3821A4ED6D00E03846 /* block_processor2.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9ADC21A4ED6A00E03846 /* block_processor2.cc */; }; + 697E9D3921A4ED6D00E03846 /* echo_canceller3.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9ADD21A4ED6A00E03846 /* echo_canceller3.cc */; }; + 697E9D3A21A4ED6D00E03846 /* block_delay_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9ADE21A4ED6A00E03846 /* block_delay_buffer.cc */; }; + 697E9D3C21A4ED6D00E03846 /* fft_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AE021A4ED6A00E03846 /* fft_buffer.cc */; }; + 697E9D4321A4ED6D00E03846 /* comfort_noise_generator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AE721A4ED6A00E03846 /* comfort_noise_generator.cc */; }; + 697E9D4721A4ED6D00E03846 /* shadow_filter_update_gain.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AEB21A4ED6A00E03846 /* shadow_filter_update_gain.cc */; }; + 697E9D4821A4ED6D00E03846 /* filter_analyzer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AEC21A4ED6A00E03846 /* filter_analyzer.cc */; }; + 697E9D4A21A4ED6D00E03846 /* reverb_frequency_response.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AEE21A4ED6A00E03846 /* reverb_frequency_response.cc */; }; + 697E9D4B21A4ED6D00E03846 /* decimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AEF21A4ED6A00E03846 /* decimator.cc */; }; + 697E9D4D21A4ED6D00E03846 /* echo_control_mobile_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AF121A4ED6A00E03846 /* echo_control_mobile_impl.cc */; }; + 697E9D5021A4ED6D00E03846 /* apm_data_dumper.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AF521A4ED6A00E03846 /* apm_data_dumper.cc */; }; + 697E9D5221A4ED6D00E03846 /* voice_activity_detector.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AF821A4ED6A00E03846 /* voice_activity_detector.cc */; }; + 697E9D5321A4ED6D00E03846 /* standalone_vad.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AF921A4ED6A00E03846 /* standalone_vad.cc */; }; + 697E9D5521A4ED6D00E03846 /* pitch_internal.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AFB21A4ED6A00E03846 /* pitch_internal.cc */; }; + 697E9D5621A4ED6E00E03846 /* vad_circular_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AFC21A4ED6A00E03846 /* vad_circular_buffer.cc */; }; + 697E9D5921A4ED6E00E03846 /* vad_audio_proc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9AFF21A4ED6A00E03846 /* vad_audio_proc.cc */; }; + 697E9D5A21A4ED6E00E03846 /* pole_zero_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9B0021A4ED6A00E03846 /* pole_zero_filter.cc */; }; + 697E9D5C21A4ED6E00E03846 /* pitch_based_vad.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9B0221A4ED6A00E03846 /* pitch_based_vad.cc */; }; + 697E9D6321A4ED6E00E03846 /* gmm.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9B0921A4ED6A00E03846 /* gmm.cc */; }; + 697E9D6821A4ED6E00E03846 /* ooura_fft.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9B0F21A4ED6A00E03846 /* ooura_fft.cc */; }; + 697E9D6A21A4ED6E00E03846 /* delay_estimator_wrapper.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9B1121A4ED6A00E03846 /* delay_estimator_wrapper.cc */; }; + 697E9D6B21A4ED6E00E03846 /* ooura_fft_sse2.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9B1221A4ED6A00E03846 /* ooura_fft_sse2.cc */; }; + 697E9D6C21A4ED6E00E03846 /* delay_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9B1321A4ED6A00E03846 /* delay_estimator.cc */; }; + 697E9D6E21A4ED6E00E03846 /* ooura_fft_neon.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9B1521A4ED6A00E03846 /* ooura_fft_neon.cc */; }; + 697E9D6F21A4ED6E00E03846 /* block_mean_calculator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9B1621A4ED6A00E03846 /* block_mean_calculator.cc */; }; + 697E9D7321A4ED6E00E03846 /* rnn_vad_weights.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9B1D21A4ED6A00E03846 /* rnn_vad_weights.cc */; }; + 697E9D7621A4ED6E00E03846 /* kiss_fft.cc in Sources */ = {isa = PBXBuildFile; fileRef = 697E9B2021A4ED6A00E03846 /* kiss_fft.cc */; }; + 69960A051EF85C2900F9D091 /* DarwinSpecific.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69960A031EF85C2900F9D091 /* DarwinSpecific.mm */; }; + 69986177209526D400B68BEC /* Buffers.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69986175209526D400B68BEC /* Buffers.cpp */; }; + 6998617B2095292A00B68BEC /* PacketReassembler.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 699861792095292900B68BEC /* PacketReassembler.cpp */; }; + 69B607D422318BBE00ED7D94 /* ScreamCongestionController.h in Headers */ = {isa = PBXBuildFile; fileRef = 69B607D222318BBD00ED7D94 /* ScreamCongestionController.h */; }; + 69B607D522318BBE00ED7D94 /* ScreamCongestionController.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69B607D322318BBD00ED7D94 /* ScreamCongestionController.cpp */; }; + 69DD8D02218CD401001E8140 /* VideoRenderer.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69DD8CFE218CD400001E8140 /* VideoRenderer.cpp */; }; + 69DD8D03218CD401001E8140 /* VideoSource.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69DD8CFF218CD400001E8140 /* VideoSource.cpp */; }; + 69E357B020F88955002E163B /* AudioIO.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69E357A720F88954002E163B /* AudioIO.cpp */; }; + 69E629EE21AF62A900377D0F /* json11.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69E629ED21AF62A900377D0F /* json11.cpp */; }; + 69F7914C2220A41000FE53C4 /* TGVVideoSource.h in Headers */ = {isa = PBXBuildFile; fileRef = 69F7914A2220A41000FE53C4 /* TGVVideoSource.h */; }; + 69F7914D2220A41000FE53C4 /* TGVVideoSource.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69F7914B2220A41000FE53C4 /* TGVVideoSource.mm */; }; + 69F791502220A76500FE53C4 /* TGVVideoRenderer.h in Headers */ = {isa = PBXBuildFile; fileRef = 69F7914E2220A76500FE53C4 /* TGVVideoRenderer.h */; }; + 69F791512220A76500FE53C4 /* TGVVideoRenderer.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69F7914F2220A76500FE53C4 /* TGVVideoRenderer.mm */; }; + 69F791542221F16C00FE53C4 /* VideoToolboxEncoderSource.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69F791522221F16C00FE53C4 /* VideoToolboxEncoderSource.mm */; }; + 69F791552221F16C00FE53C4 /* VideoToolboxEncoderSource.h in Headers */ = {isa = PBXBuildFile; fileRef = 69F791532221F16C00FE53C4 /* VideoToolboxEncoderSource.h */; }; + 69F791582222AC2800FE53C4 /* SampleBufferDisplayLayerRenderer.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69F791562222AC2800FE53C4 /* SampleBufferDisplayLayerRenderer.mm */; }; + 69F791592222AC2800FE53C4 /* SampleBufferDisplayLayerRenderer.h in Headers */ = {isa = PBXBuildFile; fileRef = 69F791572222AC2800FE53C4 /* SampleBufferDisplayLayerRenderer.h */; }; + 69FB0B2D20F6860E00827817 /* MessageThread.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69FB0B2420F6860D00827817 /* MessageThread.cpp */; }; +/* End PBXBuildFile section */ + +/* Begin PBXContainerItemProxy section */ + 692AB9101E675E8800706ACC /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = D08805AC156E8F3600311537; + remoteInfo = Telegraph; + }; + 692AB9121E675E8800706ACC /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = D02601D71A55CA2300716290; + remoteInfo = Share; + }; + 692AB9141E675E8800706ACC /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = 68744C0D1BB1A9F700FE6542; + remoteInfo = watchkitapp; + }; + 692AB9161E675E8800706ACC /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = 68744C191BB1A9F700FE6542; + remoteInfo = "watchkitapp Extension"; + }; + 692AB9181E675E8800706ACC /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = D020FADD1D99466A00F279AA; + remoteInfo = SiriIntents; + }; + 692AB91A1E675E8800706ACC /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = D020FB0A1D99637100F279AA; + remoteInfo = LegacyDatabase; + }; + 69960A0D1EF85C2900F9D091 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = 099120C01EEAA63400F1366E; + remoteInfo = Widget; + }; +/* End PBXContainerItemProxy section */ + +/* Begin PBXFileReference section */ + 69015D921E9D848700AC9763 /* NetworkSocket.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = NetworkSocket.cpp; sourceTree = ""; }; + 69015D931E9D848700AC9763 /* NetworkSocket.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = NetworkSocket.h; sourceTree = ""; }; + 6915307A1E6B5BAB004F643F /* logging.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = logging.cpp; sourceTree = ""; }; + 6929CD0F2233ED81009B7378 /* PrivateDefines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = PrivateDefines.h; sourceTree = ""; }; + 692AB8881E6759DD00706ACC /* AudioInput.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = AudioInput.cpp; sourceTree = ""; }; + 692AB8891E6759DD00706ACC /* AudioInput.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = AudioInput.h; sourceTree = ""; }; + 692AB88A1E6759DD00706ACC /* AudioOutput.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = AudioOutput.cpp; sourceTree = ""; }; + 692AB88B1E6759DD00706ACC /* AudioOutput.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = AudioOutput.h; sourceTree = ""; }; + 692AB88C1E6759DD00706ACC /* BlockingQueue.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = BlockingQueue.cpp; sourceTree = ""; }; + 692AB88D1E6759DD00706ACC /* BlockingQueue.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = BlockingQueue.h; sourceTree = ""; }; + 692AB8971E6759DD00706ACC /* CongestionControl.cpp */ = {isa = PBXFileReference; explicitFileType = sourcecode.cpp.objcpp; fileEncoding = 4; path = CongestionControl.cpp; sourceTree = ""; }; + 692AB8981E6759DD00706ACC /* CongestionControl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CongestionControl.h; sourceTree = ""; }; + 692AB8991E6759DD00706ACC /* EchoCanceller.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = EchoCanceller.cpp; sourceTree = ""; }; + 692AB89A1E6759DD00706ACC /* EchoCanceller.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = EchoCanceller.h; sourceTree = ""; }; + 692AB8A71E6759DD00706ACC /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; + 692AB8A81E6759DD00706ACC /* JitterBuffer.cpp */ = {isa = PBXFileReference; explicitFileType = sourcecode.cpp.objcpp; fileEncoding = 4; path = JitterBuffer.cpp; sourceTree = ""; }; + 692AB8A91E6759DD00706ACC /* JitterBuffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = JitterBuffer.h; sourceTree = ""; }; + 692AB8AA1E6759DD00706ACC /* logging.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = logging.h; sourceTree = ""; }; + 692AB8AB1E6759DD00706ACC /* MediaStreamItf.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = MediaStreamItf.cpp; sourceTree = ""; }; + 692AB8AC1E6759DD00706ACC /* MediaStreamItf.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = MediaStreamItf.h; sourceTree = ""; }; + 692AB8AD1E6759DD00706ACC /* OpusDecoder.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = OpusDecoder.cpp; sourceTree = ""; }; + 692AB8AE1E6759DD00706ACC /* OpusDecoder.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = OpusDecoder.h; sourceTree = ""; }; + 692AB8AF1E6759DD00706ACC /* OpusEncoder.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = OpusEncoder.cpp; sourceTree = ""; }; + 692AB8B01E6759DD00706ACC /* OpusEncoder.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = OpusEncoder.h; sourceTree = ""; }; + 692AB8BE1E6759DD00706ACC /* AudioInputAudioUnit.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = AudioInputAudioUnit.cpp; sourceTree = ""; }; + 692AB8BF1E6759DD00706ACC /* AudioInputAudioUnit.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = AudioInputAudioUnit.h; sourceTree = ""; }; + 692AB8C01E6759DD00706ACC /* AudioOutputAudioUnit.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = AudioOutputAudioUnit.cpp; sourceTree = ""; }; + 692AB8C11E6759DD00706ACC /* AudioOutputAudioUnit.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = AudioOutputAudioUnit.h; sourceTree = ""; }; + 692AB8C21E6759DD00706ACC /* AudioUnitIO.cpp */ = {isa = PBXFileReference; explicitFileType = sourcecode.cpp.objcpp; fileEncoding = 4; path = AudioUnitIO.cpp; sourceTree = ""; }; + 692AB8C31E6759DD00706ACC /* AudioUnitIO.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = AudioUnitIO.h; sourceTree = ""; }; + 692AB8C41E6759DD00706ACC /* TGLogWrapper.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = TGLogWrapper.h; sourceTree = ""; }; + 692AB8C51E6759DD00706ACC /* TGLogWrapper.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = TGLogWrapper.m; sourceTree = ""; }; + 692AB8C61E6759DD00706ACC /* threading.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = threading.h; sourceTree = ""; }; + 692AB8C71E6759DD00706ACC /* VoIPController.cpp */ = {isa = PBXFileReference; explicitFileType = sourcecode.cpp.objcpp; fileEncoding = 4; path = VoIPController.cpp; sourceTree = ""; }; + 692AB8C81E6759DD00706ACC /* VoIPController.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VoIPController.h; sourceTree = ""; }; + 692AB8C91E6759DD00706ACC /* VoIPServerConfig.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VoIPServerConfig.cpp; sourceTree = ""; }; + 692AB8CA1E6759DD00706ACC /* VoIPServerConfig.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VoIPServerConfig.h; sourceTree = ""; }; + 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = Telegraph.xcodeproj; path = ../../Telegraph.xcodeproj; sourceTree = ""; }; + 692AB91C1E675F7000706ACC /* AudioToolbox.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = AudioToolbox.framework; path = System/Library/Frameworks/AudioToolbox.framework; sourceTree = SDKROOT; }; + 692AB91D1E675F7000706ACC /* AudioUnit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = AudioUnit.framework; path = System/Library/Frameworks/AudioUnit.framework; sourceTree = SDKROOT; }; + 692AB91E1E675F7000706ACC /* CoreAudio.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreAudio.framework; path = System/Library/Frameworks/CoreAudio.framework; sourceTree = SDKROOT; }; + 69719A77224A627E00FE9B2A /* VideoPacketSender.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VideoPacketSender.h; sourceTree = ""; }; + 69719A78224A627E00FE9B2A /* VideoFEC.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VideoFEC.h; sourceTree = ""; }; + 69719A79224A627F00FE9B2A /* VideoFEC.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VideoFEC.cpp; sourceTree = ""; }; + 69719A7A224A627F00FE9B2A /* VideoPacketSender.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VideoPacketSender.cpp; sourceTree = ""; }; + 69791A4B1EE8262400BB85FB /* NetworkSocketPosix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = NetworkSocketPosix.cpp; path = os/posix/NetworkSocketPosix.cpp; sourceTree = SOURCE_ROOT; }; + 69791A4C1EE8262400BB85FB /* NetworkSocketPosix.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = NetworkSocketPosix.h; path = os/posix/NetworkSocketPosix.h; sourceTree = SOURCE_ROOT; }; + 69791A551EE8272A00BB85FB /* Resampler.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = Resampler.cpp; sourceTree = ""; }; + 69791A561EE8272A00BB85FB /* Resampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = Resampler.h; sourceTree = ""; }; + 697E961921A4EA0700E03846 /* typedefs.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = typedefs.h; sourceTree = ""; }; + 697E988C21A4ED6800E03846 /* field_trial.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = field_trial.h; sourceTree = ""; }; + 697E988D21A4ED6800E03846 /* cpu_features_wrapper.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = cpu_features_wrapper.h; sourceTree = ""; }; + 697E988E21A4ED6800E03846 /* asm_defines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = asm_defines.h; sourceTree = ""; }; + 697E988F21A4ED6800E03846 /* metrics.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = metrics.h; sourceTree = ""; }; + 697E989021A4ED6800E03846 /* compile_assert_c.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = compile_assert_c.h; sourceTree = ""; }; + 697E989221A4ED6800E03846 /* field_trial.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = field_trial.cc; sourceTree = ""; }; + 697E989321A4ED6800E03846 /* metrics.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = metrics.cc; sourceTree = ""; }; + 697E989421A4ED6800E03846 /* cpu_features.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = cpu_features.cc; sourceTree = ""; }; + 697E989721A4ED6800E03846 /* mock_smoothing_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = mock_smoothing_filter.h; sourceTree = ""; }; + 697E989821A4ED6800E03846 /* wav_file.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = wav_file.h; sourceTree = ""; }; + 697E989921A4ED6800E03846 /* window_generator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = window_generator.cc; sourceTree = ""; }; + 697E989A21A4ED6800E03846 /* channel_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = channel_buffer.cc; sourceTree = ""; }; + 697E989B21A4ED6800E03846 /* fir_filter_factory.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fir_filter_factory.cc; sourceTree = ""; }; + 697E989C21A4ED6800E03846 /* sparse_fir_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = sparse_fir_filter.h; sourceTree = ""; }; + 697E989D21A4ED6800E03846 /* fir_filter_sse.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fir_filter_sse.h; sourceTree = ""; }; + 697E989E21A4ED6800E03846 /* window_generator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = window_generator.h; sourceTree = ""; }; + 697E989F21A4ED6800E03846 /* ring_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ring_buffer.h; sourceTree = ""; }; + 697E98A021A4ED6800E03846 /* fir_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fir_filter.h; sourceTree = ""; }; + 697E98A221A4ED6800E03846 /* audio_util.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_util.h; sourceTree = ""; }; + 697E98A321A4ED6800E03846 /* wav_header.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = wav_header.cc; sourceTree = ""; }; + 697E98A421A4ED6800E03846 /* real_fourier_ooura.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = real_fourier_ooura.cc; sourceTree = ""; }; + 697E98A521A4ED6800E03846 /* fir_filter_neon.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fir_filter_neon.cc; sourceTree = ""; }; + 697E98A621A4ED6800E03846 /* audio_util.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_util.cc; sourceTree = ""; }; + 697E98A721A4ED6800E03846 /* real_fourier_ooura.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = real_fourier_ooura.h; sourceTree = ""; }; + 697E98A821A4ED6800E03846 /* fir_filter_sse.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fir_filter_sse.cc; sourceTree = ""; }; + 697E98A921A4ED6800E03846 /* smoothing_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = smoothing_filter.h; sourceTree = ""; }; + 697E98AB21A4ED6800E03846 /* sinc_resampler_neon.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = sinc_resampler_neon.cc; sourceTree = ""; }; + 697E98AC21A4ED6800E03846 /* push_sinc_resampler.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = push_sinc_resampler.cc; sourceTree = ""; }; + 697E98AD21A4ED6800E03846 /* sinc_resampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = sinc_resampler.h; sourceTree = ""; }; + 697E98AE21A4ED6800E03846 /* resampler.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = resampler.cc; sourceTree = ""; }; + 697E98AF21A4ED6800E03846 /* sinc_resampler_sse.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = sinc_resampler_sse.cc; sourceTree = ""; }; + 697E98B121A4ED6800E03846 /* push_resampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = push_resampler.h; sourceTree = ""; }; + 697E98B221A4ED6800E03846 /* resampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = resampler.h; sourceTree = ""; }; + 697E98B321A4ED6800E03846 /* push_sinc_resampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = push_sinc_resampler.h; sourceTree = ""; }; + 697E98B421A4ED6800E03846 /* push_resampler.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = push_resampler.cc; sourceTree = ""; }; + 697E98B521A4ED6800E03846 /* sinusoidal_linear_chirp_source.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = sinusoidal_linear_chirp_source.h; sourceTree = ""; }; + 697E98B621A4ED6800E03846 /* sinc_resampler.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = sinc_resampler.cc; sourceTree = ""; }; + 697E98B721A4ED6800E03846 /* sinusoidal_linear_chirp_source.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = sinusoidal_linear_chirp_source.cc; sourceTree = ""; }; + 697E98B821A4ED6800E03846 /* fir_filter_factory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fir_filter_factory.h; sourceTree = ""; }; + 697E98B921A4ED6800E03846 /* audio_converter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_converter.h; sourceTree = ""; }; + 697E98BA21A4ED6800E03846 /* wav_file.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = wav_file.cc; sourceTree = ""; }; + 697E98BD21A4ED6800E03846 /* spl_sqrt_floor.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = spl_sqrt_floor.c; sourceTree = ""; }; + 697E98BE21A4ED6800E03846 /* spl_sqrt_floor_arm.S */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.asm; path = spl_sqrt_floor_arm.S; sourceTree = ""; }; + 697E98BF21A4ED6800E03846 /* spl_sqrt_floor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = spl_sqrt_floor.h; sourceTree = ""; }; + 697E98C121A4ED6800E03846 /* fft4g.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = fft4g.c; sourceTree = ""; }; + 697E98C221A4ED6800E03846 /* fft4g.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fft4g.h; sourceTree = ""; }; + 697E98C321A4ED6800E03846 /* audio_converter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_converter.cc; sourceTree = ""; }; + 697E98C421A4ED6800E03846 /* real_fourier.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = real_fourier.cc; sourceTree = ""; }; + 697E98C521A4ED6800E03846 /* channel_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = channel_buffer.h; sourceTree = ""; }; + 697E98C621A4ED6800E03846 /* real_fourier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = real_fourier.h; sourceTree = ""; }; + 697E98C721A4ED6800E03846 /* sparse_fir_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = sparse_fir_filter.cc; sourceTree = ""; }; + 697E98C821A4ED6800E03846 /* fir_filter_neon.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fir_filter_neon.h; sourceTree = ""; }; + 697E98C921A4ED6800E03846 /* smoothing_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = smoothing_filter.cc; sourceTree = ""; }; + 697E98CA21A4ED6800E03846 /* fir_filter_c.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fir_filter_c.cc; sourceTree = ""; }; + 697E98CB21A4ED6800E03846 /* ring_buffer.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = ring_buffer.c; sourceTree = ""; }; + 697E98CC21A4ED6800E03846 /* fir_filter_c.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fir_filter_c.h; sourceTree = ""; }; + 697E98CE21A4ED6800E03846 /* complex_fft_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = complex_fft_tables.h; sourceTree = ""; }; + 697E98CF21A4ED6800E03846 /* complex_fft.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = complex_fft.c; sourceTree = ""; }; + 697E98D021A4ED6800E03846 /* filter_ma_fast_q12.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = filter_ma_fast_q12.c; sourceTree = ""; }; + 697E98D121A4ED6800E03846 /* splitting_filter1.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = splitting_filter1.c; sourceTree = ""; }; + 697E98D221A4ED6800E03846 /* levinson_durbin.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = levinson_durbin.c; sourceTree = ""; }; + 697E98D321A4ED6800E03846 /* downsample_fast_neon.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = downsample_fast_neon.c; sourceTree = ""; }; + 697E98D421A4ED6800E03846 /* dot_product_with_scale.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = dot_product_with_scale.cc; sourceTree = ""; }; + 697E98D521A4ED6800E03846 /* auto_corr_to_refl_coef.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = auto_corr_to_refl_coef.c; sourceTree = ""; }; + 697E98D621A4ED6800E03846 /* resample_by_2_internal.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = resample_by_2_internal.c; sourceTree = ""; }; + 697E98D721A4ED6800E03846 /* complex_bit_reverse_arm.S */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.asm; path = complex_bit_reverse_arm.S; sourceTree = ""; }; + 697E98D821A4ED6800E03846 /* energy.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = energy.c; sourceTree = ""; }; + 697E98D921A4ED6800E03846 /* sqrt_of_one_minus_x_squared.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = sqrt_of_one_minus_x_squared.c; sourceTree = ""; }; + 697E98DA21A4ED6800E03846 /* downsample_fast.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = downsample_fast.c; sourceTree = ""; }; + 697E98DB21A4ED6800E03846 /* filter_ar_fast_q12.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = filter_ar_fast_q12.c; sourceTree = ""; }; + 697E98DC21A4ED6800E03846 /* spl_init.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = spl_init.c; sourceTree = ""; }; + 697E98DD21A4ED6800E03846 /* lpc_to_refl_coef.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lpc_to_refl_coef.c; sourceTree = ""; }; + 697E98DE21A4ED6800E03846 /* cross_correlation.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = cross_correlation.c; sourceTree = ""; }; + 697E98E021A4ED6800E03846 /* signal_processing_library.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = signal_processing_library.h; sourceTree = ""; }; + 697E98E121A4ED6800E03846 /* real_fft.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = real_fft.h; sourceTree = ""; }; + 697E98E221A4ED6800E03846 /* spl_inl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = spl_inl.h; sourceTree = ""; }; + 697E98E321A4ED6800E03846 /* spl_inl_armv7.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = spl_inl_armv7.h; sourceTree = ""; }; + 697E98E421A4ED6800E03846 /* division_operations.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = division_operations.c; sourceTree = ""; }; + 697E98E521A4ED6800E03846 /* auto_correlation.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = auto_correlation.c; sourceTree = ""; }; + 697E98E621A4ED6800E03846 /* get_scaling_square.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = get_scaling_square.c; sourceTree = ""; }; + 697E98E721A4ED6800E03846 /* min_max_operations_neon.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = min_max_operations_neon.c; sourceTree = ""; }; + 697E98E821A4ED6800E03846 /* dot_product_with_scale.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = dot_product_with_scale.h; sourceTree = ""; }; + 697E98E921A4ED6800E03846 /* resample_by_2_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = resample_by_2_internal.h; sourceTree = ""; }; + 697E98EA21A4ED6800E03846 /* resample.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = resample.c; sourceTree = ""; }; + 697E98EB21A4ED6800E03846 /* cross_correlation_neon.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = cross_correlation_neon.c; sourceTree = ""; }; + 697E98EC21A4ED6800E03846 /* min_max_operations.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = min_max_operations.c; sourceTree = ""; }; + 697E98ED21A4ED6800E03846 /* refl_coef_to_lpc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = refl_coef_to_lpc.c; sourceTree = ""; }; + 697E98EE21A4ED6800E03846 /* filter_ar.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = filter_ar.c; sourceTree = ""; }; + 697E98EF21A4ED6800E03846 /* vector_scaling_operations.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = vector_scaling_operations.c; sourceTree = ""; }; + 697E98F021A4ED6800E03846 /* resample_fractional.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = resample_fractional.c; sourceTree = ""; }; + 697E98F121A4ED6800E03846 /* real_fft.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = real_fft.c; sourceTree = ""; }; + 697E98F221A4ED6800E03846 /* ilbc_specific_functions.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = ilbc_specific_functions.c; sourceTree = ""; }; + 697E98F321A4ED6800E03846 /* complex_bit_reverse.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = complex_bit_reverse.c; sourceTree = ""; }; + 697E98F421A4ED6800E03846 /* randomization_functions.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = randomization_functions.c; sourceTree = ""; }; + 697E98F521A4ED6800E03846 /* filter_ar_fast_q12_armv7.S */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.asm; path = filter_ar_fast_q12_armv7.S; sourceTree = ""; }; + 697E98F621A4ED6800E03846 /* copy_set_operations.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = copy_set_operations.c; sourceTree = ""; }; + 697E98F721A4ED6800E03846 /* resample_by_2.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = resample_by_2.c; sourceTree = ""; }; + 697E98F821A4ED6800E03846 /* get_hanning_window.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = get_hanning_window.c; sourceTree = ""; }; + 697E98F921A4ED6800E03846 /* resample_48khz.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = resample_48khz.c; sourceTree = ""; }; + 697E98FA21A4ED6800E03846 /* spl_inl.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = spl_inl.c; sourceTree = ""; }; + 697E98FB21A4ED6800E03846 /* spl_sqrt.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = spl_sqrt.c; sourceTree = ""; }; + 697E98FC21A4ED6800E03846 /* wav_header.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = wav_header.h; sourceTree = ""; }; + 697E98FE21A4ED6800E03846 /* vad_sp.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = vad_sp.c; sourceTree = ""; }; + 697E98FF21A4ED6800E03846 /* vad.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = vad.cc; sourceTree = ""; }; + 697E990021A4ED6800E03846 /* webrtc_vad.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = webrtc_vad.c; sourceTree = ""; }; + 697E990121A4ED6800E03846 /* vad_core.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_core.h; sourceTree = ""; }; + 697E990321A4ED6800E03846 /* vad.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad.h; sourceTree = ""; }; + 697E990421A4ED6800E03846 /* webrtc_vad.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = webrtc_vad.h; sourceTree = ""; }; + 697E990521A4ED6800E03846 /* vad_gmm.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_gmm.h; sourceTree = ""; }; + 697E990621A4ED6800E03846 /* vad_filterbank.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = vad_filterbank.c; sourceTree = ""; }; + 697E990721A4ED6800E03846 /* vad_core.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = vad_core.c; sourceTree = ""; }; + 697E990821A4ED6800E03846 /* vad_sp.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_sp.h; sourceTree = ""; }; + 697E990921A4ED6800E03846 /* vad_filterbank.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_filterbank.h; sourceTree = ""; }; + 697E990A21A4ED6800E03846 /* vad_gmm.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = vad_gmm.c; sourceTree = ""; }; + 697E990E21A4ED6800E03846 /* memutil.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = memutil.h; sourceTree = ""; }; + 697E990F21A4ED6800E03846 /* memutil.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = memutil.cc; sourceTree = ""; }; + 697E991021A4ED6800E03846 /* string_view.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = string_view.cc; sourceTree = ""; }; + 697E991121A4ED6800E03846 /* ascii.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ascii.h; sourceTree = ""; }; + 697E991221A4ED6800E03846 /* ascii.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ascii.cc; sourceTree = ""; }; + 697E991321A4ED6800E03846 /* string_view.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = string_view.h; sourceTree = ""; }; + 697E991521A4ED6800E03846 /* optional.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = optional.h; sourceTree = ""; }; + 697E991621A4ED6800E03846 /* bad_optional_access.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = bad_optional_access.h; sourceTree = ""; }; + 697E991721A4ED6800E03846 /* bad_optional_access.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = bad_optional_access.cc; sourceTree = ""; }; + 697E991821A4ED6800E03846 /* optional.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = optional.cc; sourceTree = ""; }; + 697E991A21A4ED6800E03846 /* memory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = memory.h; sourceTree = ""; }; + 697E991C21A4ED6800E03846 /* type_traits.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = type_traits.h; sourceTree = ""; }; + 697E991E21A4ED6800E03846 /* algorithm.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = algorithm.h; sourceTree = ""; }; + 697E992021A4ED6800E03846 /* inlined_vector.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = inlined_vector.h; sourceTree = ""; }; + 697E992221A4ED6800E03846 /* policy_checks.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = policy_checks.h; sourceTree = ""; }; + 697E992321A4ED6800E03846 /* port.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = port.h; sourceTree = ""; }; + 697E992421A4ED6800E03846 /* config.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = config.h; sourceTree = ""; }; + 697E992621A4ED6800E03846 /* raw_logging.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = raw_logging.cc; sourceTree = ""; }; + 697E992721A4ED6800E03846 /* throw_delegate.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = throw_delegate.cc; sourceTree = ""; }; + 697E992821A4ED6800E03846 /* invoke.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = invoke.h; sourceTree = ""; }; + 697E992921A4ED6800E03846 /* inline_variable.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = inline_variable.h; sourceTree = ""; }; + 697E992A21A4ED6800E03846 /* atomic_hook.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = atomic_hook.h; sourceTree = ""; }; + 697E992B21A4ED6800E03846 /* identity.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = identity.h; sourceTree = ""; }; + 697E992C21A4ED6800E03846 /* raw_logging.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = raw_logging.h; sourceTree = ""; }; + 697E992D21A4ED6800E03846 /* throw_delegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = throw_delegate.h; sourceTree = ""; }; + 697E992E21A4ED6800E03846 /* attributes.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = attributes.h; sourceTree = ""; }; + 697E992F21A4ED6800E03846 /* macros.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = macros.h; sourceTree = ""; }; + 697E993021A4ED6800E03846 /* optimization.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = optimization.h; sourceTree = ""; }; + 697E993121A4ED6800E03846 /* log_severity.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = log_severity.h; sourceTree = ""; }; + 697E993321A4ED6800E03846 /* utility.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = utility.h; sourceTree = ""; }; + 697E993621A4ED6900E03846 /* audio_frame.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_frame.cc; sourceTree = ""; }; + 697E993721A4ED6900E03846 /* echo_canceller3_config.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_canceller3_config.h; sourceTree = ""; }; + 697E993821A4ED6900E03846 /* echo_control.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_control.h; sourceTree = ""; }; + 697E993921A4ED6900E03846 /* audio_frame.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_frame.h; sourceTree = ""; }; + 697E993A21A4ED6900E03846 /* echo_canceller3_config.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_canceller3_config.cc; sourceTree = ""; }; + 697E993B21A4ED6900E03846 /* echo_canceller3_factory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_canceller3_factory.h; sourceTree = ""; }; + 697E993C21A4ED6900E03846 /* echo_canceller3_factory.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_canceller3_factory.cc; sourceTree = ""; }; + 697E993D21A4ED6900E03846 /* array_view.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = array_view.h; sourceTree = ""; }; + 697E993F21A4ED6900E03846 /* string_to_number.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = string_to_number.h; sourceTree = ""; }; + 697E994021A4ED6900E03846 /* constructormagic.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = constructormagic.h; sourceTree = ""; }; + 697E994121A4ED6900E03846 /* race_checker.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = race_checker.cc; sourceTree = ""; }; + 697E994321A4ED6900E03846 /* string_builder.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = string_builder.h; sourceTree = ""; }; + 697E994421A4ED6900E03846 /* string_builder.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = string_builder.cc; sourceTree = ""; }; + 697E994521A4ED6900E03846 /* event_tracer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = event_tracer.h; sourceTree = ""; }; + 697E994621A4ED6900E03846 /* stringencode.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = stringencode.h; sourceTree = ""; }; + 697E994821A4ED6900E03846 /* aligned_malloc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aligned_malloc.cc; sourceTree = ""; }; + 697E994921A4ED6900E03846 /* aligned_malloc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aligned_malloc.h; sourceTree = ""; }; + 697E994A21A4ED6900E03846 /* timeutils.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = timeutils.cc; sourceTree = ""; }; + 697E994B21A4ED6900E03846 /* event.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = event.h; sourceTree = ""; }; + 697E994D21A4ED6900E03846 /* ignore_wundef.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ignore_wundef.h; sourceTree = ""; }; + 697E994E21A4ED6900E03846 /* stringutils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = stringutils.h; sourceTree = ""; }; + 697E994F21A4ED6900E03846 /* arraysize.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = arraysize.h; sourceTree = ""; }; + 697E995021A4ED6900E03846 /* platform_file.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = platform_file.cc; sourceTree = ""; }; + 697E995121A4ED6900E03846 /* swap_queue.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = swap_queue.h; sourceTree = ""; }; + 697E995221A4ED6900E03846 /* string_to_number.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = string_to_number.cc; sourceTree = ""; }; + 697E995321A4ED6900E03846 /* trace_event.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = trace_event.h; sourceTree = ""; }; + 697E995421A4ED6900E03846 /* checks.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = checks.h; sourceTree = ""; }; + 697E995521A4ED6900E03846 /* deprecation.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = deprecation.h; sourceTree = ""; }; + 697E995621A4ED6900E03846 /* thread_checker_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = thread_checker_impl.cc; sourceTree = ""; }; + 697E995721A4ED6900E03846 /* sanitizer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = sanitizer.h; sourceTree = ""; }; + 697E995821A4ED6900E03846 /* scoped_ref_ptr.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = scoped_ref_ptr.h; sourceTree = ""; }; + 697E995921A4ED6900E03846 /* logging.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = logging.h; sourceTree = ""; }; + 697E995A21A4ED6900E03846 /* timeutils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = timeutils.h; sourceTree = ""; }; + 697E995B21A4ED6900E03846 /* atomicops.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = atomicops.h; sourceTree = ""; }; + 697E995C21A4ED6900E03846 /* stringencode.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = stringencode.cc; sourceTree = ""; }; + 697E995D21A4ED6900E03846 /* stringutils.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = stringutils.cc; sourceTree = ""; }; + 697E995E21A4ED6900E03846 /* checks.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = checks.cc; sourceTree = ""; }; + 697E996021A4ED6900E03846 /* safe_minmax.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = safe_minmax.h; sourceTree = ""; }; + 697E996121A4ED6900E03846 /* safe_conversions.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = safe_conversions.h; sourceTree = ""; }; + 697E996221A4ED6900E03846 /* safe_conversions_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = safe_conversions_impl.h; sourceTree = ""; }; + 697E996321A4ED6900E03846 /* safe_compare.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = safe_compare.h; sourceTree = ""; }; + 697E996521A4ED6900E03846 /* unused.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = unused.h; sourceTree = ""; }; + 697E996621A4ED6900E03846 /* inline.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = inline.h; sourceTree = ""; }; + 697E996721A4ED6900E03846 /* ignore_warnings.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ignore_warnings.h; sourceTree = ""; }; + 697E996821A4ED6900E03846 /* asm_defines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = asm_defines.h; sourceTree = ""; }; + 697E996921A4ED6900E03846 /* rtc_export.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = rtc_export.h; sourceTree = ""; }; + 697E996A21A4ED6900E03846 /* arch.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = arch.h; sourceTree = ""; }; + 697E996B21A4ED6900E03846 /* platform_thread.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = platform_thread.cc; sourceTree = ""; }; + 697E996C21A4ED6900E03846 /* platform_thread.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = platform_thread.h; sourceTree = ""; }; + 697E996D21A4ED6900E03846 /* logging_webrtc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = logging_webrtc.cc; sourceTree = ""; }; + 697E996E21A4ED6900E03846 /* platform_thread_types.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = platform_thread_types.h; sourceTree = ""; }; + 697E996F21A4ED6900E03846 /* protobuf_utils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = protobuf_utils.h; sourceTree = ""; }; + 697E997021A4ED6900E03846 /* thread_annotations.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = thread_annotations.h; sourceTree = ""; }; + 697E997121A4ED6900E03846 /* gtest_prod_util.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gtest_prod_util.h; sourceTree = ""; }; + 697E997221A4ED6900E03846 /* function_view.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = function_view.h; sourceTree = ""; }; + 697E997321A4ED6900E03846 /* criticalsection.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = criticalsection.h; sourceTree = ""; }; + 697E997421A4ED6900E03846 /* criticalsection.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = criticalsection.cc; sourceTree = ""; }; + 697E997521A4ED6900E03846 /* platform_thread_types.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = platform_thread_types.cc; sourceTree = ""; }; + 697E997621A4ED6900E03846 /* refcount.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = refcount.h; sourceTree = ""; }; + 697E997721A4ED6900E03846 /* event.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = event.cc; sourceTree = ""; }; + 697E997821A4ED6900E03846 /* thread_checker_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = thread_checker_impl.h; sourceTree = ""; }; + 697E997921A4ED6900E03846 /* event_tracer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = event_tracer.cc; sourceTree = ""; }; + 697E997A21A4ED6900E03846 /* compile_assert_c.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = compile_assert_c.h; sourceTree = ""; }; + 697E997B21A4ED6900E03846 /* type_traits.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = type_traits.h; sourceTree = ""; }; + 697E997C21A4ED6900E03846 /* platform_file.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = platform_file.h; sourceTree = ""; }; + 697E997D21A4ED6900E03846 /* refcounter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = refcounter.h; sourceTree = ""; }; + 697E997F21A4ED6900E03846 /* thread_checker.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = thread_checker.h; sourceTree = ""; }; + 697E998021A4ED6900E03846 /* race_checker.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = race_checker.h; sourceTree = ""; }; + 697E998121A4ED6900E03846 /* refcountedobject.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = refcountedobject.h; sourceTree = ""; }; + 697E998521A4ED6900E03846 /* fft.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fft.h; sourceTree = ""; }; + 697E998621A4ED6900E03846 /* fft.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = fft.c; sourceTree = ""; }; + 697E998A21A4ED6900E03846 /* bandwidth_info.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = bandwidth_info.h; sourceTree = ""; }; + 697E998D21A4ED6900E03846 /* isac.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = isac.h; sourceTree = ""; }; + 697E998F21A4ED6900E03846 /* pitch_estimator.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = pitch_estimator.c; sourceTree = ""; }; + 697E999021A4ED6900E03846 /* lpc_shape_swb16_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lpc_shape_swb16_tables.c; sourceTree = ""; }; + 697E999121A4ED6900E03846 /* pitch_gain_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = pitch_gain_tables.c; sourceTree = ""; }; + 697E999221A4ED6900E03846 /* arith_routines_logist.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = arith_routines_logist.c; sourceTree = ""; }; + 697E999321A4ED6900E03846 /* os_specific_inline.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = os_specific_inline.h; sourceTree = ""; }; + 697E999421A4ED6900E03846 /* filterbanks.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = filterbanks.c; sourceTree = ""; }; + 697E999521A4ED6900E03846 /* entropy_coding.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = entropy_coding.h; sourceTree = ""; }; + 697E999621A4ED6900E03846 /* isac_vad.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = isac_vad.h; sourceTree = ""; }; + 697E999721A4ED6900E03846 /* settings.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = settings.h; sourceTree = ""; }; + 697E999821A4ED6900E03846 /* transform.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = transform.c; sourceTree = ""; }; + 697E999921A4ED6900E03846 /* lpc_shape_swb12_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = lpc_shape_swb12_tables.h; sourceTree = ""; }; + 697E999A21A4ED6900E03846 /* arith_routines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = arith_routines.h; sourceTree = ""; }; + 697E999B21A4ED6900E03846 /* crc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = crc.h; sourceTree = ""; }; + 697E999C21A4ED6900E03846 /* pitch_filter.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = pitch_filter.c; sourceTree = ""; }; + 697E999D21A4ED6900E03846 /* encode_lpc_swb.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = encode_lpc_swb.c; sourceTree = ""; }; + 697E999E21A4ED6900E03846 /* filter_functions.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = filter_functions.c; sourceTree = ""; }; + 697E999F21A4ED6900E03846 /* decode.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = decode.c; sourceTree = ""; }; + 697E99A021A4ED6900E03846 /* lattice.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lattice.c; sourceTree = ""; }; + 697E99A121A4ED6900E03846 /* intialize.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = intialize.c; sourceTree = ""; }; + 697E99A221A4ED6900E03846 /* lpc_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lpc_tables.c; sourceTree = ""; }; + 697E99A321A4ED6900E03846 /* lpc_gain_swb_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lpc_gain_swb_tables.c; sourceTree = ""; }; + 697E99A421A4ED6900E03846 /* bandwidth_estimator.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = bandwidth_estimator.c; sourceTree = ""; }; + 697E99A521A4ED6900E03846 /* isac_float_type.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = isac_float_type.h; sourceTree = ""; }; + 697E99A621A4ED6900E03846 /* pitch_lag_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_lag_tables.h; sourceTree = ""; }; + 697E99A721A4ED6900E03846 /* encode.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = encode.c; sourceTree = ""; }; + 697E99A821A4ED6900E03846 /* lpc_analysis.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lpc_analysis.c; sourceTree = ""; }; + 697E99A921A4ED6900E03846 /* spectrum_ar_model_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = spectrum_ar_model_tables.h; sourceTree = ""; }; + 697E99AA21A4ED6900E03846 /* arith_routines_hist.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = arith_routines_hist.c; sourceTree = ""; }; + 697E99AB21A4ED6900E03846 /* codec.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = codec.h; sourceTree = ""; }; + 697E99AC21A4ED6900E03846 /* pitch_gain_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_gain_tables.h; sourceTree = ""; }; + 697E99AD21A4ED6900E03846 /* lpc_shape_swb16_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = lpc_shape_swb16_tables.h; sourceTree = ""; }; + 697E99AE21A4ED6900E03846 /* pitch_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_estimator.h; sourceTree = ""; }; + 697E99AF21A4ED6900E03846 /* entropy_coding.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = entropy_coding.c; sourceTree = ""; }; + 697E99B021A4ED6900E03846 /* isac_vad.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = isac_vad.c; sourceTree = ""; }; + 697E99B121A4ED6900E03846 /* structs.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = structs.h; sourceTree = ""; }; + 697E99B221A4ED6900E03846 /* filter_functions.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = filter_functions.h; sourceTree = ""; }; + 697E99B321A4ED6900E03846 /* encode_lpc_swb.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = encode_lpc_swb.h; sourceTree = ""; }; + 697E99B421A4ED6900E03846 /* pitch_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_filter.h; sourceTree = ""; }; + 697E99B521A4ED6900E03846 /* arith_routines.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = arith_routines.c; sourceTree = ""; }; + 697E99B621A4ED6900E03846 /* crc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = crc.c; sourceTree = ""; }; + 697E99B721A4ED6900E03846 /* lpc_shape_swb12_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lpc_shape_swb12_tables.c; sourceTree = ""; }; + 697E99B821A4ED6900E03846 /* lpc_analysis.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = lpc_analysis.h; sourceTree = ""; }; + 697E99B921A4ED6900E03846 /* decode_bwe.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = decode_bwe.c; sourceTree = ""; }; + 697E99BA21A4ED6900E03846 /* spectrum_ar_model_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = spectrum_ar_model_tables.c; sourceTree = ""; }; + 697E99BB21A4ED6900E03846 /* bandwidth_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = bandwidth_estimator.h; sourceTree = ""; }; + 697E99BC21A4ED6900E03846 /* pitch_lag_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = pitch_lag_tables.c; sourceTree = ""; }; + 697E99BD21A4ED6900E03846 /* isac.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = isac.c; sourceTree = ""; }; + 697E99BE21A4ED6900E03846 /* lpc_gain_swb_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = lpc_gain_swb_tables.h; sourceTree = ""; }; + 697E99BF21A4ED6900E03846 /* lpc_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = lpc_tables.h; sourceTree = ""; }; + 697E99C121A4ED6900E03846 /* rms_level.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = rms_level.cc; sourceTree = ""; }; + 697E99C321A4ED6900E03846 /* moving_max.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = moving_max.h; sourceTree = ""; }; + 697E99C421A4ED6900E03846 /* circular_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = circular_buffer.h; sourceTree = ""; }; + 697E99C521A4ED6900E03846 /* normalized_covariance_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = normalized_covariance_estimator.h; sourceTree = ""; }; + 697E99C621A4ED6900E03846 /* normalized_covariance_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = normalized_covariance_estimator.cc; sourceTree = ""; }; + 697E99C721A4ED6900E03846 /* moving_max.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = moving_max.cc; sourceTree = ""; }; + 697E99C821A4ED6900E03846 /* circular_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = circular_buffer.cc; sourceTree = ""; }; + 697E99C921A4ED6900E03846 /* mean_variance_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = mean_variance_estimator.cc; sourceTree = ""; }; + 697E99CA21A4ED6900E03846 /* mean_variance_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = mean_variance_estimator.h; sourceTree = ""; }; + 697E99CB21A4ED6900E03846 /* gain_control_for_experimental_agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_control_for_experimental_agc.h; sourceTree = ""; }; + 697E99CC21A4ED6900E03846 /* splitting_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = splitting_filter.cc; sourceTree = ""; }; + 697E99CD21A4ED6900E03846 /* gain_control_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gain_control_impl.cc; sourceTree = ""; }; + 697E99CE21A4ED6900E03846 /* rms_level.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = rms_level.h; sourceTree = ""; }; + 697E99D421A4ED6900E03846 /* ns_core.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ns_core.h; sourceTree = ""; }; + 697E99D521A4ED6900E03846 /* nsx_core.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = nsx_core.c; sourceTree = ""; }; + 697E99D621A4ED6900E03846 /* noise_suppression_x.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = noise_suppression_x.c; sourceTree = ""; }; + 697E99D721A4ED6900E03846 /* nsx_core_c.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = nsx_core_c.c; sourceTree = ""; }; + 697E99D821A4ED6900E03846 /* defines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = defines.h; sourceTree = ""; }; + 697E99D921A4ED6900E03846 /* noise_suppression.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = noise_suppression.h; sourceTree = ""; }; + 697E99DA21A4ED6900E03846 /* ns_core.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = ns_core.c; sourceTree = ""; }; + 697E99DB21A4ED6900E03846 /* nsx_core.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = nsx_core.h; sourceTree = ""; }; + 697E99DC21A4ED6900E03846 /* windows_private.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = windows_private.h; sourceTree = ""; }; + 697E99DD21A4ED6900E03846 /* noise_suppression_x.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = noise_suppression_x.h; sourceTree = ""; }; + 697E99DE21A4ED6900E03846 /* nsx_core_neon.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = nsx_core_neon.c; sourceTree = ""; }; + 697E99DF21A4ED6900E03846 /* noise_suppression.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = noise_suppression.c; sourceTree = ""; }; + 697E99E021A4ED6900E03846 /* nsx_defines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = nsx_defines.h; sourceTree = ""; }; + 697E99E121A4ED6900E03846 /* residual_echo_detector.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = residual_echo_detector.h; sourceTree = ""; }; + 697E99E221A4ED6900E03846 /* audio_processing_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_processing_impl.h; sourceTree = ""; }; + 697E99E321A4ED6900E03846 /* audio_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_buffer.cc; sourceTree = ""; }; + 697E99E421A4ED6900E03846 /* typing_detection.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = typing_detection.cc; sourceTree = ""; }; + 697E99E521A4ED6900E03846 /* render_queue_item_verifier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_queue_item_verifier.h; sourceTree = ""; }; + 697E99E821A4ED6900E03846 /* audio_generator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_generator.h; sourceTree = ""; }; + 697E99E921A4ED6900E03846 /* config.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = config.h; sourceTree = ""; }; + 697E99EA21A4ED6900E03846 /* audio_frame_view.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_frame_view.h; sourceTree = ""; }; + 697E99EB21A4ED6900E03846 /* mock_audio_processing.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = mock_audio_processing.h; sourceTree = ""; }; + 697E99EC21A4ED6900E03846 /* gain_control.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_control.h; sourceTree = ""; }; + 697E99ED21A4ED6900E03846 /* audio_generator_factory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_generator_factory.h; sourceTree = ""; }; + 697E99EE21A4ED6900E03846 /* audio_processing_statistics.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_processing_statistics.cc; sourceTree = ""; }; + 697E99EF21A4ED6900E03846 /* audio_generator_factory.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_generator_factory.cc; sourceTree = ""; }; + 697E99F021A4ED6900E03846 /* aec_dump.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec_dump.cc; sourceTree = ""; }; + 697E99F121A4ED6900E03846 /* aec_dump.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec_dump.h; sourceTree = ""; }; + 697E99F221A4ED6900E03846 /* audio_processing_statistics.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_processing_statistics.h; sourceTree = ""; }; + 697E99F321A4ED6900E03846 /* audio_processing.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_processing.h; sourceTree = ""; }; + 697E99F421A4ED6900E03846 /* audio_processing.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_processing.cc; sourceTree = ""; }; + 697E99F521A4ED6900E03846 /* config.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = config.cc; sourceTree = ""; }; + 697E99F721A4ED6900E03846 /* interpolated_gain_curve.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = interpolated_gain_curve.h; sourceTree = ""; }; + 697E99F821A4ED6900E03846 /* biquad_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = biquad_filter.h; sourceTree = ""; }; + 697E99F921A4ED6900E03846 /* interpolated_gain_curve.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = interpolated_gain_curve.cc; sourceTree = ""; }; + 697E99FA21A4ED6900E03846 /* agc2_common.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = agc2_common.cc; sourceTree = ""; }; + 697E99FB21A4ED6900E03846 /* agc2_testing_common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = agc2_testing_common.h; sourceTree = ""; }; + 697E99FC21A4ED6900E03846 /* adaptive_mode_level_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = adaptive_mode_level_estimator.h; sourceTree = ""; }; + 697E99FD21A4ED6900E03846 /* gain_applier.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gain_applier.cc; sourceTree = ""; }; + 697E99FE21A4ED6900E03846 /* signal_classifier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = signal_classifier.h; sourceTree = ""; }; + 697E99FF21A4ED6900E03846 /* adaptive_agc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = adaptive_agc.cc; sourceTree = ""; }; + 697E9A0021A4ED6900E03846 /* adaptive_digital_gain_applier.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = adaptive_digital_gain_applier.cc; sourceTree = ""; }; + 697E9A0121A4ED6900E03846 /* limiter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = limiter.cc; sourceTree = ""; }; + 697E9A0221A4ED6900E03846 /* saturation_protector.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = saturation_protector.cc; sourceTree = ""; }; + 697E9A0321A4ED6900E03846 /* vector_float_frame.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vector_float_frame.h; sourceTree = ""; }; + 697E9A0521A4ED6900E03846 /* spectral_features_internal.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = spectral_features_internal.cc; sourceTree = ""; }; + 697E9A0621A4ED6900E03846 /* sequence_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = sequence_buffer.h; sourceTree = ""; }; + 697E9A0721A4ED6900E03846 /* rnn.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = rnn.h; sourceTree = ""; }; + 697E9A0821A4ED6900E03846 /* rnn.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = rnn.cc; sourceTree = ""; }; + 697E9A0921A4ED6900E03846 /* test_utils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = test_utils.h; sourceTree = ""; }; + 697E9A0A21A4ED6900E03846 /* pitch_info.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_info.h; sourceTree = ""; }; + 697E9A0B21A4ED6900E03846 /* lp_residual.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = lp_residual.h; sourceTree = ""; }; + 697E9A0C21A4ED6900E03846 /* ring_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ring_buffer.h; sourceTree = ""; }; + 697E9A0D21A4ED6900E03846 /* pitch_search_internal.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pitch_search_internal.cc; sourceTree = ""; }; + 697E9A0E21A4ED6900E03846 /* symmetric_matrix_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = symmetric_matrix_buffer.h; sourceTree = ""; }; + 697E9A0F21A4ED6900E03846 /* spectral_features.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = spectral_features.h; sourceTree = ""; }; + 697E9A1021A4ED6900E03846 /* features_extraction.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = features_extraction.h; sourceTree = ""; }; + 697E9A1121A4ED6900E03846 /* common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = common.h; sourceTree = ""; }; + 697E9A1221A4ED6900E03846 /* spectral_features_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = spectral_features_internal.h; sourceTree = ""; }; + 697E9A1321A4ED6900E03846 /* fft_util.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fft_util.h; sourceTree = ""; }; + 697E9A1421A4ED6900E03846 /* spectral_features.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = spectral_features.cc; sourceTree = ""; }; + 697E9A1521A4ED6900E03846 /* pitch_search_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_search_internal.h; sourceTree = ""; }; + 697E9A1621A4ED6900E03846 /* pitch_search.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pitch_search.cc; sourceTree = ""; }; + 697E9A1721A4ED6900E03846 /* pitch_search.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_search.h; sourceTree = ""; }; + 697E9A1821A4ED6900E03846 /* features_extraction.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = features_extraction.cc; sourceTree = ""; }; + 697E9A1921A4ED6900E03846 /* fft_util.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fft_util.cc; sourceTree = ""; }; + 697E9A1A21A4ED6900E03846 /* lp_residual.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = lp_residual.cc; sourceTree = ""; }; + 697E9A1B21A4ED6900E03846 /* fixed_gain_controller.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fixed_gain_controller.h; sourceTree = ""; }; + 697E9A1C21A4ED6900E03846 /* adaptive_mode_level_estimator_agc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = adaptive_mode_level_estimator_agc.cc; sourceTree = ""; }; + 697E9A1D21A4ED6900E03846 /* vector_float_frame.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = vector_float_frame.cc; sourceTree = ""; }; + 697E9A1E21A4ED6900E03846 /* down_sampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = down_sampler.h; sourceTree = ""; }; + 697E9A1F21A4ED6900E03846 /* noise_level_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = noise_level_estimator.cc; sourceTree = ""; }; + 697E9A2021A4ED6900E03846 /* agc2_testing_common.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = agc2_testing_common.cc; sourceTree = ""; }; + 697E9A2121A4ED6900E03846 /* fixed_digital_level_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fixed_digital_level_estimator.cc; sourceTree = ""; }; + 697E9A2221A4ED6900E03846 /* fixed_gain_controller.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fixed_gain_controller.cc; sourceTree = ""; }; + 697E9A2321A4ED6900E03846 /* saturation_protector.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = saturation_protector.h; sourceTree = ""; }; + 697E9A2421A4ED6900E03846 /* vad_with_level.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = vad_with_level.cc; sourceTree = ""; }; + 697E9A2521A4ED6900E03846 /* limiter_db_gain_curve.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = limiter_db_gain_curve.cc; sourceTree = ""; }; + 697E9A2621A4ED6900E03846 /* agc2_common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = agc2_common.h; sourceTree = ""; }; + 697E9A2721A4ED6900E03846 /* adaptive_mode_level_estimator_agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = adaptive_mode_level_estimator_agc.h; sourceTree = ""; }; + 697E9A2821A4ED6900E03846 /* adaptive_digital_gain_applier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = adaptive_digital_gain_applier.h; sourceTree = ""; }; + 697E9A2921A4ED6900E03846 /* vad_with_level.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_with_level.h; sourceTree = ""; }; + 697E9A2A21A4ED6900E03846 /* limiter_db_gain_curve.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = limiter_db_gain_curve.h; sourceTree = ""; }; + 697E9A2B21A4ED6900E03846 /* fixed_digital_level_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fixed_digital_level_estimator.h; sourceTree = ""; }; + 697E9A2C21A4ED6900E03846 /* adaptive_agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = adaptive_agc.h; sourceTree = ""; }; + 697E9A2D21A4ED6900E03846 /* gain_applier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_applier.h; sourceTree = ""; }; + 697E9A2E21A4ED6900E03846 /* down_sampler.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = down_sampler.cc; sourceTree = ""; }; + 697E9A2F21A4ED6900E03846 /* noise_level_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = noise_level_estimator.h; sourceTree = ""; }; + 697E9A3021A4ED6900E03846 /* signal_classifier.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = signal_classifier.cc; sourceTree = ""; }; + 697E9A3121A4ED6900E03846 /* noise_spectrum_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = noise_spectrum_estimator.cc; sourceTree = ""; }; + 697E9A3221A4ED6900E03846 /* compute_interpolated_gain_curve.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = compute_interpolated_gain_curve.cc; sourceTree = ""; }; + 697E9A3321A4ED6900E03846 /* compute_interpolated_gain_curve.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = compute_interpolated_gain_curve.h; sourceTree = ""; }; + 697E9A3421A4ED6900E03846 /* biquad_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = biquad_filter.cc; sourceTree = ""; }; + 697E9A3521A4ED6900E03846 /* noise_spectrum_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = noise_spectrum_estimator.h; sourceTree = ""; }; + 697E9A3621A4ED6900E03846 /* limiter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = limiter.h; sourceTree = ""; }; + 697E9A3721A4ED6900E03846 /* adaptive_mode_level_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = adaptive_mode_level_estimator.cc; sourceTree = ""; }; + 697E9A3921A4ED6900E03846 /* moving_moments.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = moving_moments.cc; sourceTree = ""; }; + 697E9A3A21A4ED6900E03846 /* transient_detector.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = transient_detector.h; sourceTree = ""; }; + 697E9A3B21A4ED6900E03846 /* wpd_tree.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = wpd_tree.cc; sourceTree = ""; }; + 697E9A3C21A4ED6900E03846 /* transient_suppressor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = transient_suppressor.h; sourceTree = ""; }; + 697E9A3D21A4ED6900E03846 /* daubechies_8_wavelet_coeffs.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = daubechies_8_wavelet_coeffs.h; sourceTree = ""; }; + 697E9A3E21A4ED6900E03846 /* common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = common.h; sourceTree = ""; }; + 697E9A3F21A4ED6900E03846 /* wpd_node.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = wpd_node.h; sourceTree = ""; }; + 697E9A4021A4ED6900E03846 /* moving_moments.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = moving_moments.h; sourceTree = ""; }; + 697E9A4121A4ED6900E03846 /* wpd_tree.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = wpd_tree.h; sourceTree = ""; }; + 697E9A4221A4ED6900E03846 /* wpd_node.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = wpd_node.cc; sourceTree = ""; }; + 697E9A4321A4ED6900E03846 /* transient_suppressor.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = transient_suppressor.cc; sourceTree = ""; }; + 697E9A4421A4ED6900E03846 /* transient_detector.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = transient_detector.cc; sourceTree = ""; }; + 697E9A4521A4ED6900E03846 /* dyadic_decimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = dyadic_decimator.h; sourceTree = ""; }; + 697E9A4621A4ED6900E03846 /* low_cut_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = low_cut_filter.cc; sourceTree = ""; }; + 697E9A4721A4ED6900E03846 /* noise_suppression_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = noise_suppression_impl.h; sourceTree = ""; }; + 697E9A4821A4ED6900E03846 /* level_estimator_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = level_estimator_impl.cc; sourceTree = ""; }; + 697E9A4921A4ED6900E03846 /* three_band_filter_bank.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = three_band_filter_bank.cc; sourceTree = ""; }; + 697E9A4B21A4ED6900E03846 /* echo_cancellation.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_cancellation.cc; sourceTree = ""; }; + 697E9A4C21A4ED6900E03846 /* aec_resampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec_resampler.h; sourceTree = ""; }; + 697E9A4D21A4ED6900E03846 /* aec_resampler.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec_resampler.cc; sourceTree = ""; }; + 697E9A4E21A4ED6900E03846 /* echo_cancellation.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_cancellation.h; sourceTree = ""; }; + 697E9A4F21A4ED6900E03846 /* aec_core.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec_core.cc; sourceTree = ""; }; + 697E9A5021A4ED6900E03846 /* aec_core.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec_core.h; sourceTree = ""; }; + 697E9A5121A4ED6900E03846 /* aec_core_optimized_methods.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec_core_optimized_methods.h; sourceTree = ""; }; + 697E9A5221A4ED6900E03846 /* aec_core_neon.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec_core_neon.cc; sourceTree = ""; }; + 697E9A5321A4ED6900E03846 /* aec_core_sse2.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec_core_sse2.cc; sourceTree = ""; }; + 697E9A5421A4ED6900E03846 /* aec_common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec_common.h; sourceTree = ""; }; + 697E9A5521A4ED6900E03846 /* voice_detection_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = voice_detection_impl.h; sourceTree = ""; }; + 697E9A5621A4ED6900E03846 /* voice_detection_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = voice_detection_impl.cc; sourceTree = ""; }; + 697E9A5721A4ED6900E03846 /* echo_cancellation_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_cancellation_impl.cc; sourceTree = ""; }; + 697E9A5821A4ED6900E03846 /* gain_control_for_experimental_agc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gain_control_for_experimental_agc.cc; sourceTree = ""; }; + 697E9A5A21A4ED6900E03846 /* agc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = agc.cc; sourceTree = ""; }; + 697E9A5B21A4ED6900E03846 /* loudness_histogram.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = loudness_histogram.cc; sourceTree = ""; }; + 697E9A5C21A4ED6900E03846 /* agc_manager_direct.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = agc_manager_direct.cc; sourceTree = ""; }; + 697E9A5E21A4ED6900E03846 /* analog_agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = analog_agc.h; sourceTree = ""; }; + 697E9A5F21A4ED6900E03846 /* gain_control.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_control.h; sourceTree = ""; }; + 697E9A6021A4ED6900E03846 /* digital_agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = digital_agc.h; sourceTree = ""; }; + 697E9A6121A4ED6900E03846 /* analog_agc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = analog_agc.c; sourceTree = ""; }; + 697E9A6221A4ED6900E03846 /* digital_agc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = digital_agc.c; sourceTree = ""; }; + 697E9A6321A4ED6900E03846 /* utility.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = utility.cc; sourceTree = ""; }; + 697E9A6421A4ED6900E03846 /* mock_agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = mock_agc.h; sourceTree = ""; }; + 697E9A6521A4ED6900E03846 /* loudness_histogram.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = loudness_histogram.h; sourceTree = ""; }; + 697E9A6621A4ED6900E03846 /* gain_map_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_map_internal.h; sourceTree = ""; }; + 697E9A6721A4ED6900E03846 /* utility.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = utility.h; sourceTree = ""; }; + 697E9A6821A4ED6900E03846 /* agc_manager_direct.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = agc_manager_direct.h; sourceTree = ""; }; + 697E9A6921A4ED6900E03846 /* agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = agc.h; sourceTree = ""; }; + 697E9A6A21A4ED6900E03846 /* common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = common.h; sourceTree = ""; }; + 697E9A6B21A4ED6900E03846 /* audio_processing_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_processing_impl.cc; sourceTree = ""; }; + 697E9A6C21A4ED6900E03846 /* audio_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_buffer.h; sourceTree = ""; }; + 697E9A6D21A4ED6900E03846 /* echo_control_mobile_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_control_mobile_impl.h; sourceTree = ""; }; + 697E9A6E21A4ED6900E03846 /* splitting_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = splitting_filter.h; sourceTree = ""; }; + 697E9A6F21A4ED6900E03846 /* low_cut_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = low_cut_filter.h; sourceTree = ""; }; + 697E9A7121A4ED6A00E03846 /* file_audio_generator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = file_audio_generator.h; sourceTree = ""; }; + 697E9A7221A4ED6A00E03846 /* file_audio_generator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = file_audio_generator.cc; sourceTree = ""; }; + 697E9A7321A4ED6A00E03846 /* gain_controller2.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gain_controller2.cc; sourceTree = ""; }; + 697E9A7421A4ED6A00E03846 /* three_band_filter_bank.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = three_band_filter_bank.h; sourceTree = ""; }; + 697E9A7521A4ED6A00E03846 /* residual_echo_detector.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = residual_echo_detector.cc; sourceTree = ""; }; + 697E9A7621A4ED6A00E03846 /* echo_cancellation_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_cancellation_impl.h; sourceTree = ""; }; + 697E9A7721A4ED6A00E03846 /* noise_suppression_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = noise_suppression_impl.cc; sourceTree = ""; }; + 697E9A7821A4ED6A00E03846 /* level_estimator_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = level_estimator_impl.h; sourceTree = ""; }; + 697E9A7921A4ED6A00E03846 /* gain_controller2.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_controller2.h; sourceTree = ""; }; + 697E9A7B21A4ED6A00E03846 /* aecm_core.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aecm_core.h; sourceTree = ""; }; + 697E9A7C21A4ED6A00E03846 /* aecm_defines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aecm_defines.h; sourceTree = ""; }; + 697E9A7D21A4ED6A00E03846 /* aecm_core.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aecm_core.cc; sourceTree = ""; }; + 697E9A7E21A4ED6A00E03846 /* aecm_core_c.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aecm_core_c.cc; sourceTree = ""; }; + 697E9A7F21A4ED6A00E03846 /* aecm_core_neon.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aecm_core_neon.cc; sourceTree = ""; }; + 697E9A8021A4ED6A00E03846 /* echo_control_mobile.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_control_mobile.h; sourceTree = ""; }; + 697E9A8121A4ED6A00E03846 /* echo_control_mobile.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_control_mobile.cc; sourceTree = ""; }; + 697E9A8321A4ED6A00E03846 /* render_reverb_model.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_reverb_model.cc; sourceTree = ""; }; + 697E9A8421A4ED6A00E03846 /* downsampled_render_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = downsampled_render_buffer.h; sourceTree = ""; }; + 697E9A8521A4ED6A00E03846 /* subtractor_output_analyzer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = subtractor_output_analyzer.h; sourceTree = ""; }; + 697E9A8621A4ED6A00E03846 /* reverb_model_fallback.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = reverb_model_fallback.cc; sourceTree = ""; }; + 697E9A8721A4ED6A00E03846 /* residual_echo_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = residual_echo_estimator.h; sourceTree = ""; }; + 697E9A8821A4ED6A00E03846 /* shadow_filter_update_gain.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = shadow_filter_update_gain.h; sourceTree = ""; }; + 697E9A8921A4ED6A00E03846 /* echo_remover_metrics.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_remover_metrics.cc; sourceTree = ""; }; + 697E9A8A21A4ED6A00E03846 /* matched_filter_lag_aggregator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = matched_filter_lag_aggregator.cc; sourceTree = ""; }; + 697E9A8B21A4ED6A00E03846 /* render_delay_buffer2.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_delay_buffer2.cc; sourceTree = ""; }; + 697E9A8C21A4ED6A00E03846 /* aec_state.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec_state.h; sourceTree = ""; }; + 697E9A8D21A4ED6A00E03846 /* suppression_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = suppression_filter.h; sourceTree = ""; }; + 697E9A8E21A4ED6A00E03846 /* echo_path_variability.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_path_variability.cc; sourceTree = ""; }; + 697E9A8F21A4ED6A00E03846 /* frame_blocker.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = frame_blocker.cc; sourceTree = ""; }; + 697E9A9021A4ED6A00E03846 /* subtractor.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = subtractor.cc; sourceTree = ""; }; + 697E9A9121A4ED6A00E03846 /* block_delay_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = block_delay_buffer.h; sourceTree = ""; }; + 697E9A9221A4ED6A00E03846 /* adaptive_fir_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = adaptive_fir_filter.h; sourceTree = ""; }; + 697E9A9321A4ED6A00E03846 /* cascaded_biquad_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = cascaded_biquad_filter.h; sourceTree = ""; }; + 697E9A9421A4ED6A00E03846 /* matched_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = matched_filter.h; sourceTree = ""; }; + 697E9A9521A4ED6A00E03846 /* subtractor_output.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = subtractor_output.h; sourceTree = ""; }; + 697E9A9621A4ED6A00E03846 /* render_signal_analyzer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_signal_analyzer.h; sourceTree = ""; }; + 697E9A9721A4ED6A00E03846 /* aec3_fft.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec3_fft.cc; sourceTree = ""; }; + 697E9A9821A4ED6A00E03846 /* aec3_fft.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec3_fft.h; sourceTree = ""; }; + 697E9A9921A4ED6A00E03846 /* echo_remover_metrics.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_remover_metrics.h; sourceTree = ""; }; + 697E9A9A21A4ED6A00E03846 /* fullband_erle_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fullband_erle_estimator.cc; sourceTree = ""; }; + 697E9A9B21A4ED6A00E03846 /* suppression_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = suppression_filter.cc; sourceTree = ""; }; + 697E9A9C21A4ED6A00E03846 /* block_processor.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = block_processor.cc; sourceTree = ""; }; + 697E9A9D21A4ED6A00E03846 /* filter_analyzer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = filter_analyzer.h; sourceTree = ""; }; + 697E9A9E21A4ED6A00E03846 /* subtractor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = subtractor.h; sourceTree = ""; }; + 697E9A9F21A4ED6A00E03846 /* echo_path_delay_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_path_delay_estimator.h; sourceTree = ""; }; + 697E9AA021A4ED6A00E03846 /* subband_erle_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = subband_erle_estimator.cc; sourceTree = ""; }; + 697E9AA121A4ED6A00E03846 /* render_delay_controller_metrics.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_delay_controller_metrics.cc; sourceTree = ""; }; + 697E9AA221A4ED6A00E03846 /* render_delay_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_delay_buffer.cc; sourceTree = ""; }; + 697E9AA321A4ED6A00E03846 /* block_processor_metrics.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = block_processor_metrics.h; sourceTree = ""; }; + 697E9AA421A4ED6A00E03846 /* vector_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = vector_buffer.cc; sourceTree = ""; }; + 697E9AA521A4ED6A00E03846 /* erl_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = erl_estimator.cc; sourceTree = ""; }; + 697E9AA621A4ED6A00E03846 /* aec_state.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec_state.cc; sourceTree = ""; }; + 697E9AA721A4ED6A00E03846 /* adaptive_fir_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = adaptive_fir_filter.cc; sourceTree = ""; }; + 697E9AA821A4ED6A00E03846 /* fft_data.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fft_data.h; sourceTree = ""; }; + 697E9AA921A4ED6A00E03846 /* render_delay_controller.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_delay_controller.cc; sourceTree = ""; }; + 697E9AAA21A4ED6A00E03846 /* skew_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = skew_estimator.cc; sourceTree = ""; }; + 697E9AAB21A4ED6A00E03846 /* render_delay_controller_metrics.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_delay_controller_metrics.h; sourceTree = ""; }; + 697E9AAC21A4ED6A00E03846 /* comfort_noise_generator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = comfort_noise_generator.h; sourceTree = ""; }; + 697E9AAD21A4ED6A00E03846 /* echo_path_delay_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_path_delay_estimator.cc; sourceTree = ""; }; + 697E9AAE21A4ED6A00E03846 /* erl_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = erl_estimator.h; sourceTree = ""; }; + 697E9AAF21A4ED6A00E03846 /* echo_remover.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_remover.h; sourceTree = ""; }; + 697E9AB021A4ED6A00E03846 /* block_framer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = block_framer.cc; sourceTree = ""; }; + 697E9AB121A4ED6A00E03846 /* erle_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = erle_estimator.cc; sourceTree = ""; }; + 697E9AB221A4ED6A00E03846 /* reverb_model.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = reverb_model.cc; sourceTree = ""; }; + 697E9AB321A4ED6A00E03846 /* cascaded_biquad_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = cascaded_biquad_filter.cc; sourceTree = ""; }; + 697E9AB421A4ED6A00E03846 /* matrix_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = matrix_buffer.h; sourceTree = ""; }; + 697E9AB521A4ED6A00E03846 /* render_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_buffer.cc; sourceTree = ""; }; + 697E9AB621A4ED6A00E03846 /* reverb_model_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = reverb_model_estimator.h; sourceTree = ""; }; + 697E9AB721A4ED6A00E03846 /* subtractor_output.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = subtractor_output.cc; sourceTree = ""; }; + 697E9AB821A4ED6A00E03846 /* stationarity_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = stationarity_estimator.cc; sourceTree = ""; }; + 697E9AB921A4ED6A00E03846 /* render_signal_analyzer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_signal_analyzer.cc; sourceTree = ""; }; + 697E9ABA21A4ED6A00E03846 /* echo_path_variability.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_path_variability.h; sourceTree = ""; }; + 697E9ABB21A4ED6A00E03846 /* moving_average.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = moving_average.h; sourceTree = ""; }; + 697E9ABC21A4ED6A00E03846 /* render_reverb_model.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_reverb_model.h; sourceTree = ""; }; + 697E9ABD21A4ED6A00E03846 /* subtractor_output_analyzer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = subtractor_output_analyzer.cc; sourceTree = ""; }; + 697E9ABE21A4ED6A00E03846 /* suppression_gain.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = suppression_gain.cc; sourceTree = ""; }; + 697E9ABF21A4ED6A00E03846 /* echo_audibility.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_audibility.cc; sourceTree = ""; }; + 697E9AC021A4ED6A00E03846 /* block_processor_metrics.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = block_processor_metrics.cc; sourceTree = ""; }; + 697E9AC121A4ED6A00E03846 /* render_delay_controller.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_delay_controller.h; sourceTree = ""; }; + 697E9AC221A4ED6A00E03846 /* suppression_gain.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = suppression_gain.h; sourceTree = ""; }; + 697E9AC321A4ED6A00E03846 /* moving_average.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = moving_average.cc; sourceTree = ""; }; + 697E9AC421A4ED6A00E03846 /* erle_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = erle_estimator.h; sourceTree = ""; }; + 697E9AC521A4ED6A00E03846 /* subband_erle_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = subband_erle_estimator.h; sourceTree = ""; }; + 697E9AC621A4ED6A00E03846 /* reverb_model_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = reverb_model_estimator.cc; sourceTree = ""; }; + 697E9AC721A4ED6A00E03846 /* aec3_common.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec3_common.cc; sourceTree = ""; }; + 697E9AC821A4ED6A00E03846 /* residual_echo_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = residual_echo_estimator.cc; sourceTree = ""; }; + 697E9AC921A4ED6A00E03846 /* block_processor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = block_processor.h; sourceTree = ""; }; + 697E9ACA21A4ED6A00E03846 /* fullband_erle_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fullband_erle_estimator.h; sourceTree = ""; }; + 697E9ACB21A4ED6A00E03846 /* matched_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = matched_filter.cc; sourceTree = ""; }; + 697E9ACC21A4ED6A00E03846 /* stationarity_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = stationarity_estimator.h; sourceTree = ""; }; + 697E9ACD21A4ED6A00E03846 /* echo_canceller3.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_canceller3.h; sourceTree = ""; }; + 697E9ACE21A4ED6A00E03846 /* skew_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = skew_estimator.h; sourceTree = ""; }; + 697E9ACF21A4ED6A00E03846 /* reverb_decay_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = reverb_decay_estimator.cc; sourceTree = ""; }; + 697E9AD021A4ED6A00E03846 /* render_delay_controller2.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_delay_controller2.cc; sourceTree = ""; }; + 697E9AD121A4ED6A00E03846 /* render_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_buffer.h; sourceTree = ""; }; + 697E9AD221A4ED6A00E03846 /* suppression_gain_limiter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = suppression_gain_limiter.cc; sourceTree = ""; }; + 697E9AD321A4ED6A00E03846 /* main_filter_update_gain.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = main_filter_update_gain.cc; sourceTree = ""; }; + 697E9AD421A4ED6A00E03846 /* echo_remover.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_remover.cc; sourceTree = ""; }; + 697E9AD521A4ED6A00E03846 /* reverb_model_fallback.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = reverb_model_fallback.h; sourceTree = ""; }; + 697E9AD621A4ED6A00E03846 /* downsampled_render_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = downsampled_render_buffer.cc; sourceTree = ""; }; + 697E9AD721A4ED6A00E03846 /* vector_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vector_buffer.h; sourceTree = ""; }; + 697E9AD821A4ED6A00E03846 /* matrix_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = matrix_buffer.cc; sourceTree = ""; }; + 697E9AD921A4ED6A00E03846 /* reverb_frequency_response.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = reverb_frequency_response.h; sourceTree = ""; }; + 697E9ADA21A4ED6A00E03846 /* echo_audibility.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_audibility.h; sourceTree = ""; }; + 697E9ADB21A4ED6A00E03846 /* fft_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fft_buffer.h; sourceTree = ""; }; + 697E9ADC21A4ED6A00E03846 /* block_processor2.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = block_processor2.cc; sourceTree = ""; }; + 697E9ADD21A4ED6A00E03846 /* echo_canceller3.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_canceller3.cc; sourceTree = ""; }; + 697E9ADE21A4ED6A00E03846 /* block_delay_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = block_delay_buffer.cc; sourceTree = ""; }; + 697E9ADF21A4ED6A00E03846 /* aec3_common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec3_common.h; sourceTree = ""; }; + 697E9AE021A4ED6A00E03846 /* fft_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fft_buffer.cc; sourceTree = ""; }; + 697E9AE121A4ED6A00E03846 /* vector_math.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vector_math.h; sourceTree = ""; }; + 697E9AE221A4ED6A00E03846 /* decimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = decimator.h; sourceTree = ""; }; + 697E9AE321A4ED6A00E03846 /* frame_blocker.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = frame_blocker.h; sourceTree = ""; }; + 697E9AE421A4ED6A00E03846 /* block_framer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = block_framer.h; sourceTree = ""; }; + 697E9AE521A4ED6A00E03846 /* suppression_gain_limiter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = suppression_gain_limiter.h; sourceTree = ""; }; + 697E9AE621A4ED6A00E03846 /* delay_estimate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = delay_estimate.h; sourceTree = ""; }; + 697E9AE721A4ED6A00E03846 /* comfort_noise_generator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = comfort_noise_generator.cc; sourceTree = ""; }; + 697E9AE821A4ED6A00E03846 /* reverb_model.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = reverb_model.h; sourceTree = ""; }; + 697E9AE921A4ED6A00E03846 /* main_filter_update_gain.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = main_filter_update_gain.h; sourceTree = ""; }; + 697E9AEA21A4ED6A00E03846 /* matched_filter_lag_aggregator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = matched_filter_lag_aggregator.h; sourceTree = ""; }; + 697E9AEB21A4ED6A00E03846 /* shadow_filter_update_gain.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = shadow_filter_update_gain.cc; sourceTree = ""; }; + 697E9AEC21A4ED6A00E03846 /* filter_analyzer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = filter_analyzer.cc; sourceTree = ""; }; + 697E9AED21A4ED6A00E03846 /* reverb_decay_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = reverb_decay_estimator.h; sourceTree = ""; }; + 697E9AEE21A4ED6A00E03846 /* reverb_frequency_response.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = reverb_frequency_response.cc; sourceTree = ""; }; + 697E9AEF21A4ED6A00E03846 /* decimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = decimator.cc; sourceTree = ""; }; + 697E9AF021A4ED6A00E03846 /* render_delay_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_delay_buffer.h; sourceTree = ""; }; + 697E9AF121A4ED6A00E03846 /* echo_control_mobile_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_control_mobile_impl.cc; sourceTree = ""; }; + 697E9AF221A4ED6A00E03846 /* gain_control_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_control_impl.h; sourceTree = ""; }; + 697E9AF321A4ED6A00E03846 /* typing_detection.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = typing_detection.h; sourceTree = ""; }; + 697E9AF521A4ED6A00E03846 /* apm_data_dumper.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = apm_data_dumper.cc; sourceTree = ""; }; + 697E9AF621A4ED6A00E03846 /* apm_data_dumper.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = apm_data_dumper.h; sourceTree = ""; }; + 697E9AF821A4ED6A00E03846 /* voice_activity_detector.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = voice_activity_detector.cc; sourceTree = ""; }; + 697E9AF921A4ED6A00E03846 /* standalone_vad.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = standalone_vad.cc; sourceTree = ""; }; + 697E9AFA21A4ED6A00E03846 /* vad_audio_proc_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_audio_proc_internal.h; sourceTree = ""; }; + 697E9AFB21A4ED6A00E03846 /* pitch_internal.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pitch_internal.cc; sourceTree = ""; }; + 697E9AFC21A4ED6A00E03846 /* vad_circular_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = vad_circular_buffer.cc; sourceTree = ""; }; + 697E9AFD21A4ED6A00E03846 /* vad_circular_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_circular_buffer.h; sourceTree = ""; }; + 697E9AFE21A4ED6A00E03846 /* pitch_based_vad.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_based_vad.h; sourceTree = ""; }; + 697E9AFF21A4ED6A00E03846 /* vad_audio_proc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = vad_audio_proc.cc; sourceTree = ""; }; + 697E9B0021A4ED6A00E03846 /* pole_zero_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pole_zero_filter.cc; sourceTree = ""; }; + 697E9B0121A4ED6A00E03846 /* pole_zero_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pole_zero_filter.h; sourceTree = ""; }; + 697E9B0221A4ED6A00E03846 /* pitch_based_vad.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pitch_based_vad.cc; sourceTree = ""; }; + 697E9B0321A4ED6A00E03846 /* gmm.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gmm.h; sourceTree = ""; }; + 697E9B0421A4ED6A00E03846 /* common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = common.h; sourceTree = ""; }; + 697E9B0521A4ED6A00E03846 /* vad_audio_proc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_audio_proc.h; sourceTree = ""; }; + 697E9B0621A4ED6A00E03846 /* voice_gmm_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = voice_gmm_tables.h; sourceTree = ""; }; + 697E9B0721A4ED6A00E03846 /* noise_gmm_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = noise_gmm_tables.h; sourceTree = ""; }; + 697E9B0821A4ED6A00E03846 /* pitch_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_internal.h; sourceTree = ""; }; + 697E9B0921A4ED6A00E03846 /* gmm.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gmm.cc; sourceTree = ""; }; + 697E9B0A21A4ED6A00E03846 /* standalone_vad.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = standalone_vad.h; sourceTree = ""; }; + 697E9B0B21A4ED6A00E03846 /* voice_activity_detector.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = voice_activity_detector.h; sourceTree = ""; }; + 697E9B0D21A4ED6A00E03846 /* ooura_fft_tables_neon_sse2.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ooura_fft_tables_neon_sse2.h; sourceTree = ""; }; + 697E9B0E21A4ED6A00E03846 /* delay_estimator_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = delay_estimator_internal.h; sourceTree = ""; }; + 697E9B0F21A4ED6A00E03846 /* ooura_fft.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ooura_fft.cc; sourceTree = ""; }; + 697E9B1021A4ED6A00E03846 /* ooura_fft.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ooura_fft.h; sourceTree = ""; }; + 697E9B1121A4ED6A00E03846 /* delay_estimator_wrapper.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = delay_estimator_wrapper.cc; sourceTree = ""; }; + 697E9B1221A4ED6A00E03846 /* ooura_fft_sse2.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ooura_fft_sse2.cc; sourceTree = ""; }; + 697E9B1321A4ED6A00E03846 /* delay_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = delay_estimator.cc; sourceTree = ""; }; + 697E9B1421A4ED6A00E03846 /* block_mean_calculator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = block_mean_calculator.h; sourceTree = ""; }; + 697E9B1521A4ED6A00E03846 /* ooura_fft_neon.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ooura_fft_neon.cc; sourceTree = ""; }; + 697E9B1621A4ED6A00E03846 /* block_mean_calculator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = block_mean_calculator.cc; sourceTree = ""; }; + 697E9B1721A4ED6A00E03846 /* delay_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = delay_estimator.h; sourceTree = ""; }; + 697E9B1821A4ED6A00E03846 /* ooura_fft_tables_common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ooura_fft_tables_common.h; sourceTree = ""; }; + 697E9B1921A4ED6A00E03846 /* delay_estimator_wrapper.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = delay_estimator_wrapper.h; sourceTree = ""; }; + 697E9B1D21A4ED6A00E03846 /* rnn_vad_weights.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = rnn_vad_weights.cc; sourceTree = ""; }; + 697E9B1E21A4ED6A00E03846 /* rnn_activations.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = rnn_activations.h; sourceTree = ""; }; + 697E9B1F21A4ED6A00E03846 /* kiss_fft.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = kiss_fft.h; sourceTree = ""; }; + 697E9B2021A4ED6A00E03846 /* kiss_fft.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = kiss_fft.cc; sourceTree = ""; }; + 697E9B2121A4ED6A00E03846 /* rnn_vad_weights.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = rnn_vad_weights.h; sourceTree = ""; }; + 69960A021EF85C2900F9D091 /* DarwinSpecific.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = DarwinSpecific.h; sourceTree = ""; }; + 69960A031EF85C2900F9D091 /* DarwinSpecific.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; path = DarwinSpecific.mm; sourceTree = ""; }; + 69986175209526D400B68BEC /* Buffers.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = Buffers.cpp; sourceTree = ""; }; + 69986176209526D400B68BEC /* Buffers.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = Buffers.h; sourceTree = ""; }; + 699861792095292900B68BEC /* PacketReassembler.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = PacketReassembler.cpp; sourceTree = ""; }; + 6998617A2095292A00B68BEC /* PacketReassembler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = PacketReassembler.h; sourceTree = ""; }; + 69B607D222318BBD00ED7D94 /* ScreamCongestionController.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ScreamCongestionController.h; sourceTree = ""; }; + 69B607D322318BBD00ED7D94 /* ScreamCongestionController.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ScreamCongestionController.cpp; sourceTree = ""; }; + 69DD8CFD218CD400001E8140 /* VideoRenderer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VideoRenderer.h; sourceTree = ""; }; + 69DD8CFE218CD400001E8140 /* VideoRenderer.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VideoRenderer.cpp; sourceTree = ""; }; + 69DD8CFF218CD400001E8140 /* VideoSource.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VideoSource.cpp; sourceTree = ""; }; + 69DD8D00218CD400001E8140 /* VideoSource.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VideoSource.h; sourceTree = ""; }; + 69E357A720F88954002E163B /* AudioIO.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = AudioIO.cpp; sourceTree = ""; }; + 69E357AF20F88954002E163B /* AudioIO.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = AudioIO.h; sourceTree = ""; }; + 69E629ED21AF62A900377D0F /* json11.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = json11.cpp; sourceTree = ""; }; + 69F7914A2220A41000FE53C4 /* TGVVideoSource.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = TGVVideoSource.h; sourceTree = ""; }; + 69F7914B2220A41000FE53C4 /* TGVVideoSource.mm */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.objcpp; path = TGVVideoSource.mm; sourceTree = ""; }; + 69F7914E2220A76500FE53C4 /* TGVVideoRenderer.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = TGVVideoRenderer.h; sourceTree = ""; }; + 69F7914F2220A76500FE53C4 /* TGVVideoRenderer.mm */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.objcpp; path = TGVVideoRenderer.mm; sourceTree = ""; }; + 69F791522221F16C00FE53C4 /* VideoToolboxEncoderSource.mm */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.objcpp; path = VideoToolboxEncoderSource.mm; sourceTree = ""; }; + 69F791532221F16C00FE53C4 /* VideoToolboxEncoderSource.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = VideoToolboxEncoderSource.h; sourceTree = ""; }; + 69F791562222AC2800FE53C4 /* SampleBufferDisplayLayerRenderer.mm */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.objcpp; path = SampleBufferDisplayLayerRenderer.mm; sourceTree = ""; }; + 69F791572222AC2800FE53C4 /* SampleBufferDisplayLayerRenderer.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = SampleBufferDisplayLayerRenderer.h; sourceTree = ""; }; + 69F842361E67540700C110F7 /* libtgvoip.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = libtgvoip.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + 69FB0B2420F6860D00827817 /* MessageThread.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = MessageThread.cpp; sourceTree = ""; }; + 69FB0B2C20F6860D00827817 /* MessageThread.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = MessageThread.h; sourceTree = ""; }; + D00ACA4D20222F5D0045D427 /* SetupLogging.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = SetupLogging.h; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 69F842321E67540700C110F7 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 692AB91F1E675F7000706ACC /* AudioToolbox.framework in Frameworks */, + 692AB9201E675F7000706ACC /* AudioUnit.framework in Frameworks */, + 692AB9211E675F7000706ACC /* CoreAudio.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 69015D871E9D846F00AC9763 /* posix */ = { + isa = PBXGroup; + children = ( + 69791A4B1EE8262400BB85FB /* NetworkSocketPosix.cpp */, + 69791A4C1EE8262400BB85FB /* NetworkSocketPosix.h */, + ); + name = posix; + path = ../../../../TDesktop/TBuild/tdesktop/third_party/libtgvoip/os/posix; + sourceTree = ""; + }; + 692AB8861E6759BF00706ACC /* libtgvoip */ = { + isa = PBXGroup; + children = ( + 692AB8871E6759DD00706ACC /* audio */, + 692AB88C1E6759DD00706ACC /* BlockingQueue.cpp */, + 692AB88D1E6759DD00706ACC /* BlockingQueue.h */, + 69986175209526D400B68BEC /* Buffers.cpp */, + 69986176209526D400B68BEC /* Buffers.h */, + 692AB8971E6759DD00706ACC /* CongestionControl.cpp */, + 692AB8981E6759DD00706ACC /* CongestionControl.h */, + 692AB8991E6759DD00706ACC /* EchoCanceller.cpp */, + 692AB89A1E6759DD00706ACC /* EchoCanceller.h */, + 692AB8A71E6759DD00706ACC /* Info.plist */, + 692AB8A81E6759DD00706ACC /* JitterBuffer.cpp */, + 692AB8A91E6759DD00706ACC /* JitterBuffer.h */, + 69E629ED21AF62A900377D0F /* json11.cpp */, + 6915307A1E6B5BAB004F643F /* logging.cpp */, + 692AB8AA1E6759DD00706ACC /* logging.h */, + 692AB8AB1E6759DD00706ACC /* MediaStreamItf.cpp */, + 692AB8AC1E6759DD00706ACC /* MediaStreamItf.h */, + 69FB0B2420F6860D00827817 /* MessageThread.cpp */, + 69FB0B2C20F6860D00827817 /* MessageThread.h */, + 69015D921E9D848700AC9763 /* NetworkSocket.cpp */, + 69015D931E9D848700AC9763 /* NetworkSocket.h */, + 692AB8AD1E6759DD00706ACC /* OpusDecoder.cpp */, + 692AB8AE1E6759DD00706ACC /* OpusDecoder.h */, + 692AB8AF1E6759DD00706ACC /* OpusEncoder.cpp */, + 692AB8B01E6759DD00706ACC /* OpusEncoder.h */, + 699861792095292900B68BEC /* PacketReassembler.cpp */, + 6998617A2095292A00B68BEC /* PacketReassembler.h */, + 6929CD0F2233ED81009B7378 /* PrivateDefines.h */, + 692AB8B11E6759DD00706ACC /* os */, + 692AB8C61E6759DD00706ACC /* threading.h */, + 692AB8C71E6759DD00706ACC /* VoIPController.cpp */, + 692AB8C81E6759DD00706ACC /* VoIPController.h */, + 692AB8C91E6759DD00706ACC /* VoIPServerConfig.cpp */, + 692AB8CA1E6759DD00706ACC /* VoIPServerConfig.h */, + 69DD8CFC218CD400001E8140 /* video */, + 69A6DCFE1E95EC7700000E69 /* webrtc_dsp */, + ); + name = libtgvoip; + sourceTree = ""; + }; + 692AB8871E6759DD00706ACC /* audio */ = { + isa = PBXGroup; + children = ( + 692AB8881E6759DD00706ACC /* AudioInput.cpp */, + 692AB8891E6759DD00706ACC /* AudioInput.h */, + 692AB88A1E6759DD00706ACC /* AudioOutput.cpp */, + 692AB88B1E6759DD00706ACC /* AudioOutput.h */, + 69E357A720F88954002E163B /* AudioIO.cpp */, + 69E357AF20F88954002E163B /* AudioIO.h */, + 69791A551EE8272A00BB85FB /* Resampler.cpp */, + 69791A561EE8272A00BB85FB /* Resampler.h */, + ); + path = audio; + sourceTree = ""; + }; + 692AB8B11E6759DD00706ACC /* os */ = { + isa = PBXGroup; + children = ( + 69015D871E9D846F00AC9763 /* posix */, + 692AB8BD1E6759DD00706ACC /* darwin */, + ); + path = os; + sourceTree = ""; + }; + 692AB8BD1E6759DD00706ACC /* darwin */ = { + isa = PBXGroup; + children = ( + 692AB8BE1E6759DD00706ACC /* AudioInputAudioUnit.cpp */, + 69F7914A2220A41000FE53C4 /* TGVVideoSource.h */, + 69F7914B2220A41000FE53C4 /* TGVVideoSource.mm */, + 69F7914E2220A76500FE53C4 /* TGVVideoRenderer.h */, + 69F7914F2220A76500FE53C4 /* TGVVideoRenderer.mm */, + 69F791562222AC2800FE53C4 /* SampleBufferDisplayLayerRenderer.mm */, + 69F791572222AC2800FE53C4 /* SampleBufferDisplayLayerRenderer.h */, + 69F791522221F16C00FE53C4 /* VideoToolboxEncoderSource.mm */, + 69F791532221F16C00FE53C4 /* VideoToolboxEncoderSource.h */, + 692AB8BF1E6759DD00706ACC /* AudioInputAudioUnit.h */, + 692AB8C01E6759DD00706ACC /* AudioOutputAudioUnit.cpp */, + 692AB8C11E6759DD00706ACC /* AudioOutputAudioUnit.h */, + 692AB8C21E6759DD00706ACC /* AudioUnitIO.cpp */, + 692AB8C31E6759DD00706ACC /* AudioUnitIO.h */, + 692AB8C41E6759DD00706ACC /* TGLogWrapper.h */, + 692AB8C51E6759DD00706ACC /* TGLogWrapper.m */, + 69960A021EF85C2900F9D091 /* DarwinSpecific.h */, + 69960A031EF85C2900F9D091 /* DarwinSpecific.mm */, + D00ACA4D20222F5D0045D427 /* SetupLogging.h */, + ); + path = darwin; + sourceTree = ""; + }; + 692AB9061E675E8700706ACC /* Frameworks */ = { + isa = PBXGroup; + children = ( + 692AB91C1E675F7000706ACC /* AudioToolbox.framework */, + 692AB91D1E675F7000706ACC /* AudioUnit.framework */, + 692AB91E1E675F7000706ACC /* CoreAudio.framework */, + 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */, + ); + name = Frameworks; + sourceTree = ""; + }; + 692AB9081E675E8800706ACC /* Products */ = { + isa = PBXGroup; + children = ( + 692AB9111E675E8800706ACC /* Telegram.app */, + 692AB9131E675E8800706ACC /* Share.appex */, + 692AB9151E675E8800706ACC /* watchkitapp.app */, + 692AB9171E675E8800706ACC /* watchkitapp Extension.appex */, + 692AB9191E675E8800706ACC /* SiriIntents.appex */, + 692AB91B1E675E8800706ACC /* LegacyDatabase.framework */, + 69960A0E1EF85C2900F9D091 /* Widget.appex */, + ); + name = Products; + sourceTree = ""; + }; + 697E988A21A4ED6800E03846 /* system_wrappers */ = { + isa = PBXGroup; + children = ( + 697E988B21A4ED6800E03846 /* include */, + 697E989121A4ED6800E03846 /* source */, + ); + path = system_wrappers; + sourceTree = ""; + }; + 697E988B21A4ED6800E03846 /* include */ = { + isa = PBXGroup; + children = ( + 697E988C21A4ED6800E03846 /* field_trial.h */, + 697E988D21A4ED6800E03846 /* cpu_features_wrapper.h */, + 697E988E21A4ED6800E03846 /* asm_defines.h */, + 697E988F21A4ED6800E03846 /* metrics.h */, + 697E989021A4ED6800E03846 /* compile_assert_c.h */, + ); + path = include; + sourceTree = ""; + }; + 697E989121A4ED6800E03846 /* source */ = { + isa = PBXGroup; + children = ( + 697E989221A4ED6800E03846 /* field_trial.cc */, + 697E989321A4ED6800E03846 /* metrics.cc */, + 697E989421A4ED6800E03846 /* cpu_features.cc */, + ); + path = source; + sourceTree = ""; + }; + 697E989521A4ED6800E03846 /* common_audio */ = { + isa = PBXGroup; + children = ( + 697E989621A4ED6800E03846 /* mocks */, + 697E989821A4ED6800E03846 /* wav_file.h */, + 697E989921A4ED6800E03846 /* window_generator.cc */, + 697E989A21A4ED6800E03846 /* channel_buffer.cc */, + 697E989B21A4ED6800E03846 /* fir_filter_factory.cc */, + 697E989C21A4ED6800E03846 /* sparse_fir_filter.h */, + 697E989D21A4ED6800E03846 /* fir_filter_sse.h */, + 697E989E21A4ED6800E03846 /* window_generator.h */, + 697E989F21A4ED6800E03846 /* ring_buffer.h */, + 697E98A021A4ED6800E03846 /* fir_filter.h */, + 697E98A121A4ED6800E03846 /* include */, + 697E98A321A4ED6800E03846 /* wav_header.cc */, + 697E98A421A4ED6800E03846 /* real_fourier_ooura.cc */, + 697E98A521A4ED6800E03846 /* fir_filter_neon.cc */, + 697E98A621A4ED6800E03846 /* audio_util.cc */, + 697E98A721A4ED6800E03846 /* real_fourier_ooura.h */, + 697E98A821A4ED6800E03846 /* fir_filter_sse.cc */, + 697E98A921A4ED6800E03846 /* smoothing_filter.h */, + 697E98AA21A4ED6800E03846 /* resampler */, + 697E98B821A4ED6800E03846 /* fir_filter_factory.h */, + 697E98B921A4ED6800E03846 /* audio_converter.h */, + 697E98BA21A4ED6800E03846 /* wav_file.cc */, + 697E98BB21A4ED6800E03846 /* third_party */, + 697E98C321A4ED6800E03846 /* audio_converter.cc */, + 697E98C421A4ED6800E03846 /* real_fourier.cc */, + 697E98C521A4ED6800E03846 /* channel_buffer.h */, + 697E98C621A4ED6800E03846 /* real_fourier.h */, + 697E98C721A4ED6800E03846 /* sparse_fir_filter.cc */, + 697E98C821A4ED6800E03846 /* fir_filter_neon.h */, + 697E98C921A4ED6800E03846 /* smoothing_filter.cc */, + 697E98CA21A4ED6800E03846 /* fir_filter_c.cc */, + 697E98CB21A4ED6800E03846 /* ring_buffer.c */, + 697E98CC21A4ED6800E03846 /* fir_filter_c.h */, + 697E98CD21A4ED6800E03846 /* signal_processing */, + 697E98FC21A4ED6800E03846 /* wav_header.h */, + 697E98FD21A4ED6800E03846 /* vad */, + ); + path = common_audio; + sourceTree = ""; + }; + 697E989621A4ED6800E03846 /* mocks */ = { + isa = PBXGroup; + children = ( + 697E989721A4ED6800E03846 /* mock_smoothing_filter.h */, + ); + path = mocks; + sourceTree = ""; + }; + 697E98A121A4ED6800E03846 /* include */ = { + isa = PBXGroup; + children = ( + 697E98A221A4ED6800E03846 /* audio_util.h */, + ); + path = include; + sourceTree = ""; + }; + 697E98AA21A4ED6800E03846 /* resampler */ = { + isa = PBXGroup; + children = ( + 697E98AB21A4ED6800E03846 /* sinc_resampler_neon.cc */, + 697E98AC21A4ED6800E03846 /* push_sinc_resampler.cc */, + 697E98AD21A4ED6800E03846 /* sinc_resampler.h */, + 697E98AE21A4ED6800E03846 /* resampler.cc */, + 697E98AF21A4ED6800E03846 /* sinc_resampler_sse.cc */, + 697E98B021A4ED6800E03846 /* include */, + 697E98B321A4ED6800E03846 /* push_sinc_resampler.h */, + 697E98B421A4ED6800E03846 /* push_resampler.cc */, + 697E98B521A4ED6800E03846 /* sinusoidal_linear_chirp_source.h */, + 697E98B621A4ED6800E03846 /* sinc_resampler.cc */, + 697E98B721A4ED6800E03846 /* sinusoidal_linear_chirp_source.cc */, + ); + path = resampler; + sourceTree = ""; + }; + 697E98B021A4ED6800E03846 /* include */ = { + isa = PBXGroup; + children = ( + 697E98B121A4ED6800E03846 /* push_resampler.h */, + 697E98B221A4ED6800E03846 /* resampler.h */, + ); + path = include; + sourceTree = ""; + }; + 697E98BB21A4ED6800E03846 /* third_party */ = { + isa = PBXGroup; + children = ( + 697E98BC21A4ED6800E03846 /* spl_sqrt_floor */, + 697E98C021A4ED6800E03846 /* fft4g */, + ); + path = third_party; + sourceTree = ""; + }; + 697E98BC21A4ED6800E03846 /* spl_sqrt_floor */ = { + isa = PBXGroup; + children = ( + 697E98BD21A4ED6800E03846 /* spl_sqrt_floor.c */, + 697E98BE21A4ED6800E03846 /* spl_sqrt_floor_arm.S */, + 697E98BF21A4ED6800E03846 /* spl_sqrt_floor.h */, + ); + path = spl_sqrt_floor; + sourceTree = ""; + }; + 697E98C021A4ED6800E03846 /* fft4g */ = { + isa = PBXGroup; + children = ( + 697E98C121A4ED6800E03846 /* fft4g.c */, + 697E98C221A4ED6800E03846 /* fft4g.h */, + ); + path = fft4g; + sourceTree = ""; + }; + 697E98CD21A4ED6800E03846 /* signal_processing */ = { + isa = PBXGroup; + children = ( + 697E98CE21A4ED6800E03846 /* complex_fft_tables.h */, + 697E98CF21A4ED6800E03846 /* complex_fft.c */, + 697E98D021A4ED6800E03846 /* filter_ma_fast_q12.c */, + 697E98D121A4ED6800E03846 /* splitting_filter1.c */, + 697E98D221A4ED6800E03846 /* levinson_durbin.c */, + 697E98D321A4ED6800E03846 /* downsample_fast_neon.c */, + 697E98D421A4ED6800E03846 /* dot_product_with_scale.cc */, + 697E98D521A4ED6800E03846 /* auto_corr_to_refl_coef.c */, + 697E98D621A4ED6800E03846 /* resample_by_2_internal.c */, + 697E98D721A4ED6800E03846 /* complex_bit_reverse_arm.S */, + 697E98D821A4ED6800E03846 /* energy.c */, + 697E98D921A4ED6800E03846 /* sqrt_of_one_minus_x_squared.c */, + 697E98DA21A4ED6800E03846 /* downsample_fast.c */, + 697E98DB21A4ED6800E03846 /* filter_ar_fast_q12.c */, + 697E98DC21A4ED6800E03846 /* spl_init.c */, + 697E98DD21A4ED6800E03846 /* lpc_to_refl_coef.c */, + 697E98DE21A4ED6800E03846 /* cross_correlation.c */, + 697E98DF21A4ED6800E03846 /* include */, + 697E98E421A4ED6800E03846 /* division_operations.c */, + 697E98E521A4ED6800E03846 /* auto_correlation.c */, + 697E98E621A4ED6800E03846 /* get_scaling_square.c */, + 697E98E721A4ED6800E03846 /* min_max_operations_neon.c */, + 697E98E821A4ED6800E03846 /* dot_product_with_scale.h */, + 697E98E921A4ED6800E03846 /* resample_by_2_internal.h */, + 697E98EA21A4ED6800E03846 /* resample.c */, + 697E98EB21A4ED6800E03846 /* cross_correlation_neon.c */, + 697E98EC21A4ED6800E03846 /* min_max_operations.c */, + 697E98ED21A4ED6800E03846 /* refl_coef_to_lpc.c */, + 697E98EE21A4ED6800E03846 /* filter_ar.c */, + 697E98EF21A4ED6800E03846 /* vector_scaling_operations.c */, + 697E98F021A4ED6800E03846 /* resample_fractional.c */, + 697E98F121A4ED6800E03846 /* real_fft.c */, + 697E98F221A4ED6800E03846 /* ilbc_specific_functions.c */, + 697E98F321A4ED6800E03846 /* complex_bit_reverse.c */, + 697E98F421A4ED6800E03846 /* randomization_functions.c */, + 697E98F521A4ED6800E03846 /* filter_ar_fast_q12_armv7.S */, + 697E98F621A4ED6800E03846 /* copy_set_operations.c */, + 697E98F721A4ED6800E03846 /* resample_by_2.c */, + 697E98F821A4ED6800E03846 /* get_hanning_window.c */, + 697E98F921A4ED6800E03846 /* resample_48khz.c */, + 697E98FA21A4ED6800E03846 /* spl_inl.c */, + 697E98FB21A4ED6800E03846 /* spl_sqrt.c */, + ); + path = signal_processing; + sourceTree = ""; + }; + 697E98DF21A4ED6800E03846 /* include */ = { + isa = PBXGroup; + children = ( + 697E98E021A4ED6800E03846 /* signal_processing_library.h */, + 697E98E121A4ED6800E03846 /* real_fft.h */, + 697E98E221A4ED6800E03846 /* spl_inl.h */, + 697E98E321A4ED6800E03846 /* spl_inl_armv7.h */, + ); + path = include; + sourceTree = ""; + }; + 697E98FD21A4ED6800E03846 /* vad */ = { + isa = PBXGroup; + children = ( + 697E98FE21A4ED6800E03846 /* vad_sp.c */, + 697E98FF21A4ED6800E03846 /* vad.cc */, + 697E990021A4ED6800E03846 /* webrtc_vad.c */, + 697E990121A4ED6800E03846 /* vad_core.h */, + 697E990221A4ED6800E03846 /* include */, + 697E990521A4ED6800E03846 /* vad_gmm.h */, + 697E990621A4ED6800E03846 /* vad_filterbank.c */, + 697E990721A4ED6800E03846 /* vad_core.c */, + 697E990821A4ED6800E03846 /* vad_sp.h */, + 697E990921A4ED6800E03846 /* vad_filterbank.h */, + 697E990A21A4ED6800E03846 /* vad_gmm.c */, + ); + path = vad; + sourceTree = ""; + }; + 697E990221A4ED6800E03846 /* include */ = { + isa = PBXGroup; + children = ( + 697E990321A4ED6800E03846 /* vad.h */, + 697E990421A4ED6800E03846 /* webrtc_vad.h */, + ); + path = include; + sourceTree = ""; + }; + 697E990B21A4ED6800E03846 /* absl */ = { + isa = PBXGroup; + children = ( + 697E990C21A4ED6800E03846 /* strings */, + 697E991421A4ED6800E03846 /* types */, + 697E991921A4ED6800E03846 /* memory */, + 697E991B21A4ED6800E03846 /* meta */, + 697E991D21A4ED6800E03846 /* algorithm */, + 697E991F21A4ED6800E03846 /* container */, + 697E992121A4ED6800E03846 /* base */, + 697E993221A4ED6800E03846 /* utility */, + ); + path = absl; + sourceTree = ""; + }; + 697E990C21A4ED6800E03846 /* strings */ = { + isa = PBXGroup; + children = ( + 697E990D21A4ED6800E03846 /* internal */, + 697E991021A4ED6800E03846 /* string_view.cc */, + 697E991121A4ED6800E03846 /* ascii.h */, + 697E991221A4ED6800E03846 /* ascii.cc */, + 697E991321A4ED6800E03846 /* string_view.h */, + ); + path = strings; + sourceTree = ""; + }; + 697E990D21A4ED6800E03846 /* internal */ = { + isa = PBXGroup; + children = ( + 697E990E21A4ED6800E03846 /* memutil.h */, + 697E990F21A4ED6800E03846 /* memutil.cc */, + ); + path = internal; + sourceTree = ""; + }; + 697E991421A4ED6800E03846 /* types */ = { + isa = PBXGroup; + children = ( + 697E991521A4ED6800E03846 /* optional.h */, + 697E991621A4ED6800E03846 /* bad_optional_access.h */, + 697E991721A4ED6800E03846 /* bad_optional_access.cc */, + 697E991821A4ED6800E03846 /* optional.cc */, + ); + path = types; + sourceTree = ""; + }; + 697E991921A4ED6800E03846 /* memory */ = { + isa = PBXGroup; + children = ( + 697E991A21A4ED6800E03846 /* memory.h */, + ); + path = memory; + sourceTree = ""; + }; + 697E991B21A4ED6800E03846 /* meta */ = { + isa = PBXGroup; + children = ( + 697E991C21A4ED6800E03846 /* type_traits.h */, + ); + path = meta; + sourceTree = ""; + }; + 697E991D21A4ED6800E03846 /* algorithm */ = { + isa = PBXGroup; + children = ( + 697E991E21A4ED6800E03846 /* algorithm.h */, + ); + path = algorithm; + sourceTree = ""; + }; + 697E991F21A4ED6800E03846 /* container */ = { + isa = PBXGroup; + children = ( + 697E992021A4ED6800E03846 /* inlined_vector.h */, + ); + path = container; + sourceTree = ""; + }; + 697E992121A4ED6800E03846 /* base */ = { + isa = PBXGroup; + children = ( + 697E992221A4ED6800E03846 /* policy_checks.h */, + 697E992321A4ED6800E03846 /* port.h */, + 697E992421A4ED6800E03846 /* config.h */, + 697E992521A4ED6800E03846 /* internal */, + 697E992E21A4ED6800E03846 /* attributes.h */, + 697E992F21A4ED6800E03846 /* macros.h */, + 697E993021A4ED6800E03846 /* optimization.h */, + 697E993121A4ED6800E03846 /* log_severity.h */, + ); + path = base; + sourceTree = ""; + }; + 697E992521A4ED6800E03846 /* internal */ = { + isa = PBXGroup; + children = ( + 697E992621A4ED6800E03846 /* raw_logging.cc */, + 697E992721A4ED6800E03846 /* throw_delegate.cc */, + 697E992821A4ED6800E03846 /* invoke.h */, + 697E992921A4ED6800E03846 /* inline_variable.h */, + 697E992A21A4ED6800E03846 /* atomic_hook.h */, + 697E992B21A4ED6800E03846 /* identity.h */, + 697E992C21A4ED6800E03846 /* raw_logging.h */, + 697E992D21A4ED6800E03846 /* throw_delegate.h */, + ); + path = internal; + sourceTree = ""; + }; + 697E993221A4ED6800E03846 /* utility */ = { + isa = PBXGroup; + children = ( + 697E993321A4ED6800E03846 /* utility.h */, + ); + path = utility; + sourceTree = ""; + }; + 697E993421A4ED6900E03846 /* api */ = { + isa = PBXGroup; + children = ( + 697E993521A4ED6900E03846 /* audio */, + 697E993D21A4ED6900E03846 /* array_view.h */, + ); + path = api; + sourceTree = ""; + }; + 697E993521A4ED6900E03846 /* audio */ = { + isa = PBXGroup; + children = ( + 697E993621A4ED6900E03846 /* audio_frame.cc */, + 697E993721A4ED6900E03846 /* echo_canceller3_config.h */, + 697E993821A4ED6900E03846 /* echo_control.h */, + 697E993921A4ED6900E03846 /* audio_frame.h */, + 697E993A21A4ED6900E03846 /* echo_canceller3_config.cc */, + 697E993B21A4ED6900E03846 /* echo_canceller3_factory.h */, + 697E993C21A4ED6900E03846 /* echo_canceller3_factory.cc */, + ); + path = audio; + sourceTree = ""; + }; + 697E993E21A4ED6900E03846 /* rtc_base */ = { + isa = PBXGroup; + children = ( + 697E993F21A4ED6900E03846 /* string_to_number.h */, + 697E994021A4ED6900E03846 /* constructormagic.h */, + 697E994121A4ED6900E03846 /* race_checker.cc */, + 697E994221A4ED6900E03846 /* strings */, + 697E994521A4ED6900E03846 /* event_tracer.h */, + 697E994621A4ED6900E03846 /* stringencode.h */, + 697E994721A4ED6900E03846 /* memory */, + 697E994A21A4ED6900E03846 /* timeutils.cc */, + 697E994B21A4ED6900E03846 /* event.h */, + 697E994D21A4ED6900E03846 /* ignore_wundef.h */, + 697E994E21A4ED6900E03846 /* stringutils.h */, + 697E994F21A4ED6900E03846 /* arraysize.h */, + 697E995021A4ED6900E03846 /* platform_file.cc */, + 697E995121A4ED6900E03846 /* swap_queue.h */, + 697E995221A4ED6900E03846 /* string_to_number.cc */, + 697E995321A4ED6900E03846 /* trace_event.h */, + 697E995421A4ED6900E03846 /* checks.h */, + 697E995521A4ED6900E03846 /* deprecation.h */, + 697E995621A4ED6900E03846 /* thread_checker_impl.cc */, + 697E995721A4ED6900E03846 /* sanitizer.h */, + 697E995821A4ED6900E03846 /* scoped_ref_ptr.h */, + 697E995921A4ED6900E03846 /* logging.h */, + 697E995A21A4ED6900E03846 /* timeutils.h */, + 697E995B21A4ED6900E03846 /* atomicops.h */, + 697E995C21A4ED6900E03846 /* stringencode.cc */, + 697E995D21A4ED6900E03846 /* stringutils.cc */, + 697E995E21A4ED6900E03846 /* checks.cc */, + 697E995F21A4ED6900E03846 /* numerics */, + 697E996421A4ED6900E03846 /* system */, + 697E996B21A4ED6900E03846 /* platform_thread.cc */, + 697E996C21A4ED6900E03846 /* platform_thread.h */, + 697E996D21A4ED6900E03846 /* logging_webrtc.cc */, + 697E996E21A4ED6900E03846 /* platform_thread_types.h */, + 697E996F21A4ED6900E03846 /* protobuf_utils.h */, + 697E997021A4ED6900E03846 /* thread_annotations.h */, + 697E997121A4ED6900E03846 /* gtest_prod_util.h */, + 697E997221A4ED6900E03846 /* function_view.h */, + 697E997321A4ED6900E03846 /* criticalsection.h */, + 697E997421A4ED6900E03846 /* criticalsection.cc */, + 697E997521A4ED6900E03846 /* platform_thread_types.cc */, + 697E997621A4ED6900E03846 /* refcount.h */, + 697E997721A4ED6900E03846 /* event.cc */, + 697E997821A4ED6900E03846 /* thread_checker_impl.h */, + 697E997921A4ED6900E03846 /* event_tracer.cc */, + 697E997A21A4ED6900E03846 /* compile_assert_c.h */, + 697E997B21A4ED6900E03846 /* type_traits.h */, + 697E997C21A4ED6900E03846 /* platform_file.h */, + 697E997D21A4ED6900E03846 /* refcounter.h */, + 697E997F21A4ED6900E03846 /* thread_checker.h */, + 697E998021A4ED6900E03846 /* race_checker.h */, + 697E998121A4ED6900E03846 /* refcountedobject.h */, + ); + path = rtc_base; + sourceTree = ""; + }; + 697E994221A4ED6900E03846 /* strings */ = { + isa = PBXGroup; + children = ( + 697E994321A4ED6900E03846 /* string_builder.h */, + 697E994421A4ED6900E03846 /* string_builder.cc */, + ); + path = strings; + sourceTree = ""; + }; + 697E994721A4ED6900E03846 /* memory */ = { + isa = PBXGroup; + children = ( + 697E994821A4ED6900E03846 /* aligned_malloc.cc */, + 697E994921A4ED6900E03846 /* aligned_malloc.h */, + ); + path = memory; + sourceTree = ""; + }; + 697E995F21A4ED6900E03846 /* numerics */ = { + isa = PBXGroup; + children = ( + 697E996021A4ED6900E03846 /* safe_minmax.h */, + 697E996121A4ED6900E03846 /* safe_conversions.h */, + 697E996221A4ED6900E03846 /* safe_conversions_impl.h */, + 697E996321A4ED6900E03846 /* safe_compare.h */, + ); + path = numerics; + sourceTree = ""; + }; + 697E996421A4ED6900E03846 /* system */ = { + isa = PBXGroup; + children = ( + 697E996521A4ED6900E03846 /* unused.h */, + 697E996621A4ED6900E03846 /* inline.h */, + 697E996721A4ED6900E03846 /* ignore_warnings.h */, + 697E996821A4ED6900E03846 /* asm_defines.h */, + 697E996921A4ED6900E03846 /* rtc_export.h */, + 697E996A21A4ED6900E03846 /* arch.h */, + ); + path = system; + sourceTree = ""; + }; + 697E998221A4ED6900E03846 /* modules */ = { + isa = PBXGroup; + children = ( + 697E998321A4ED6900E03846 /* third_party */, + 697E998721A4ED6900E03846 /* audio_coding */, + 697E99C021A4ED6900E03846 /* audio_processing */, + ); + path = modules; + sourceTree = ""; + }; + 697E998321A4ED6900E03846 /* third_party */ = { + isa = PBXGroup; + children = ( + 697E998421A4ED6900E03846 /* fft */, + ); + path = third_party; + sourceTree = ""; + }; + 697E998421A4ED6900E03846 /* fft */ = { + isa = PBXGroup; + children = ( + 697E998521A4ED6900E03846 /* fft.h */, + 697E998621A4ED6900E03846 /* fft.c */, + ); + path = fft; + sourceTree = ""; + }; + 697E998721A4ED6900E03846 /* audio_coding */ = { + isa = PBXGroup; + children = ( + 697E998821A4ED6900E03846 /* codecs */, + ); + path = audio_coding; + sourceTree = ""; + }; + 697E998821A4ED6900E03846 /* codecs */ = { + isa = PBXGroup; + children = ( + 697E998921A4ED6900E03846 /* isac */, + ); + path = codecs; + sourceTree = ""; + }; + 697E998921A4ED6900E03846 /* isac */ = { + isa = PBXGroup; + children = ( + 697E998A21A4ED6900E03846 /* bandwidth_info.h */, + 697E998B21A4ED6900E03846 /* main */, + ); + path = isac; + sourceTree = ""; + }; + 697E998B21A4ED6900E03846 /* main */ = { + isa = PBXGroup; + children = ( + 697E998C21A4ED6900E03846 /* include */, + 697E998E21A4ED6900E03846 /* source */, + ); + path = main; + sourceTree = ""; + }; + 697E998C21A4ED6900E03846 /* include */ = { + isa = PBXGroup; + children = ( + 697E998D21A4ED6900E03846 /* isac.h */, + ); + path = include; + sourceTree = ""; + }; + 697E998E21A4ED6900E03846 /* source */ = { + isa = PBXGroup; + children = ( + 697E998F21A4ED6900E03846 /* pitch_estimator.c */, + 697E999021A4ED6900E03846 /* lpc_shape_swb16_tables.c */, + 697E999121A4ED6900E03846 /* pitch_gain_tables.c */, + 697E999221A4ED6900E03846 /* arith_routines_logist.c */, + 697E999321A4ED6900E03846 /* os_specific_inline.h */, + 697E999421A4ED6900E03846 /* filterbanks.c */, + 697E999521A4ED6900E03846 /* entropy_coding.h */, + 697E999621A4ED6900E03846 /* isac_vad.h */, + 697E999721A4ED6900E03846 /* settings.h */, + 697E999821A4ED6900E03846 /* transform.c */, + 697E999921A4ED6900E03846 /* lpc_shape_swb12_tables.h */, + 697E999A21A4ED6900E03846 /* arith_routines.h */, + 697E999B21A4ED6900E03846 /* crc.h */, + 697E999C21A4ED6900E03846 /* pitch_filter.c */, + 697E999D21A4ED6900E03846 /* encode_lpc_swb.c */, + 697E999E21A4ED6900E03846 /* filter_functions.c */, + 697E999F21A4ED6900E03846 /* decode.c */, + 697E99A021A4ED6900E03846 /* lattice.c */, + 697E99A121A4ED6900E03846 /* intialize.c */, + 697E99A221A4ED6900E03846 /* lpc_tables.c */, + 697E99A321A4ED6900E03846 /* lpc_gain_swb_tables.c */, + 697E99A421A4ED6900E03846 /* bandwidth_estimator.c */, + 697E99A521A4ED6900E03846 /* isac_float_type.h */, + 697E99A621A4ED6900E03846 /* pitch_lag_tables.h */, + 697E99A721A4ED6900E03846 /* encode.c */, + 697E99A821A4ED6900E03846 /* lpc_analysis.c */, + 697E99A921A4ED6900E03846 /* spectrum_ar_model_tables.h */, + 697E99AA21A4ED6900E03846 /* arith_routines_hist.c */, + 697E99AB21A4ED6900E03846 /* codec.h */, + 697E99AC21A4ED6900E03846 /* pitch_gain_tables.h */, + 697E99AD21A4ED6900E03846 /* lpc_shape_swb16_tables.h */, + 697E99AE21A4ED6900E03846 /* pitch_estimator.h */, + 697E99AF21A4ED6900E03846 /* entropy_coding.c */, + 697E99B021A4ED6900E03846 /* isac_vad.c */, + 697E99B121A4ED6900E03846 /* structs.h */, + 697E99B221A4ED6900E03846 /* filter_functions.h */, + 697E99B321A4ED6900E03846 /* encode_lpc_swb.h */, + 697E99B421A4ED6900E03846 /* pitch_filter.h */, + 697E99B521A4ED6900E03846 /* arith_routines.c */, + 697E99B621A4ED6900E03846 /* crc.c */, + 697E99B721A4ED6900E03846 /* lpc_shape_swb12_tables.c */, + 697E99B821A4ED6900E03846 /* lpc_analysis.h */, + 697E99B921A4ED6900E03846 /* decode_bwe.c */, + 697E99BA21A4ED6900E03846 /* spectrum_ar_model_tables.c */, + 697E99BB21A4ED6900E03846 /* bandwidth_estimator.h */, + 697E99BC21A4ED6900E03846 /* pitch_lag_tables.c */, + 697E99BD21A4ED6900E03846 /* isac.c */, + 697E99BE21A4ED6900E03846 /* lpc_gain_swb_tables.h */, + 697E99BF21A4ED6900E03846 /* lpc_tables.h */, + ); + path = source; + sourceTree = ""; + }; + 697E99C021A4ED6900E03846 /* audio_processing */ = { + isa = PBXGroup; + children = ( + 697E99C121A4ED6900E03846 /* rms_level.cc */, + 697E99C221A4ED6900E03846 /* echo_detector */, + 697E99CB21A4ED6900E03846 /* gain_control_for_experimental_agc.h */, + 697E99CC21A4ED6900E03846 /* splitting_filter.cc */, + 697E99CD21A4ED6900E03846 /* gain_control_impl.cc */, + 697E99CE21A4ED6900E03846 /* rms_level.h */, + 697E99CF21A4ED6900E03846 /* test */, + 697E99D321A4ED6900E03846 /* ns */, + 697E99E121A4ED6900E03846 /* residual_echo_detector.h */, + 697E99E221A4ED6900E03846 /* audio_processing_impl.h */, + 697E99E321A4ED6900E03846 /* audio_buffer.cc */, + 697E99E421A4ED6900E03846 /* typing_detection.cc */, + 697E99E521A4ED6900E03846 /* render_queue_item_verifier.h */, + 697E99E621A4ED6900E03846 /* aec_dump */, + 697E99E721A4ED6900E03846 /* include */, + 697E99F621A4ED6900E03846 /* agc2 */, + 697E9A3821A4ED6900E03846 /* transient */, + 697E9A4621A4ED6900E03846 /* low_cut_filter.cc */, + 697E9A4721A4ED6900E03846 /* noise_suppression_impl.h */, + 697E9A4821A4ED6900E03846 /* level_estimator_impl.cc */, + 697E9A4921A4ED6900E03846 /* three_band_filter_bank.cc */, + 697E9A4A21A4ED6900E03846 /* aec */, + 697E9A5521A4ED6900E03846 /* voice_detection_impl.h */, + 697E9A5621A4ED6900E03846 /* voice_detection_impl.cc */, + 697E9A5721A4ED6900E03846 /* echo_cancellation_impl.cc */, + 697E9A5821A4ED6900E03846 /* gain_control_for_experimental_agc.cc */, + 697E9A5921A4ED6900E03846 /* agc */, + 697E9A6A21A4ED6900E03846 /* common.h */, + 697E9A6B21A4ED6900E03846 /* audio_processing_impl.cc */, + 697E9A6C21A4ED6900E03846 /* audio_buffer.h */, + 697E9A6D21A4ED6900E03846 /* echo_control_mobile_impl.h */, + 697E9A6E21A4ED6900E03846 /* splitting_filter.h */, + 697E9A6F21A4ED6900E03846 /* low_cut_filter.h */, + 697E9A7021A4ED6900E03846 /* audio_generator */, + 697E9A7321A4ED6A00E03846 /* gain_controller2.cc */, + 697E9A7421A4ED6A00E03846 /* three_band_filter_bank.h */, + 697E9A7521A4ED6A00E03846 /* residual_echo_detector.cc */, + 697E9A7621A4ED6A00E03846 /* echo_cancellation_impl.h */, + 697E9A7721A4ED6A00E03846 /* noise_suppression_impl.cc */, + 697E9A7821A4ED6A00E03846 /* level_estimator_impl.h */, + 697E9A7921A4ED6A00E03846 /* gain_controller2.h */, + 697E9A7A21A4ED6A00E03846 /* aecm */, + 697E9A8221A4ED6A00E03846 /* aec3 */, + 697E9AF121A4ED6A00E03846 /* echo_control_mobile_impl.cc */, + 697E9AF221A4ED6A00E03846 /* gain_control_impl.h */, + 697E9AF321A4ED6A00E03846 /* typing_detection.h */, + 697E9AF421A4ED6A00E03846 /* logging */, + 697E9AF721A4ED6A00E03846 /* vad */, + 697E9B0C21A4ED6A00E03846 /* utility */, + ); + path = audio_processing; + sourceTree = ""; + }; + 697E99C221A4ED6900E03846 /* echo_detector */ = { + isa = PBXGroup; + children = ( + 697E99C321A4ED6900E03846 /* moving_max.h */, + 697E99C421A4ED6900E03846 /* circular_buffer.h */, + 697E99C521A4ED6900E03846 /* normalized_covariance_estimator.h */, + 697E99C621A4ED6900E03846 /* normalized_covariance_estimator.cc */, + 697E99C721A4ED6900E03846 /* moving_max.cc */, + 697E99C821A4ED6900E03846 /* circular_buffer.cc */, + 697E99C921A4ED6900E03846 /* mean_variance_estimator.cc */, + 697E99CA21A4ED6900E03846 /* mean_variance_estimator.h */, + ); + path = echo_detector; + sourceTree = ""; + }; + 697E99CF21A4ED6900E03846 /* test */ = { + isa = PBXGroup; + children = ( + 697E99D021A4ED6900E03846 /* android */, + ); + path = test; + sourceTree = ""; + }; + 697E99D021A4ED6900E03846 /* android */ = { + isa = PBXGroup; + children = ( + 697E99D121A4ED6900E03846 /* apmtest */, + ); + path = android; + sourceTree = ""; + }; + 697E99D121A4ED6900E03846 /* apmtest */ = { + isa = PBXGroup; + children = ( + 697E99D221A4ED6900E03846 /* jni */, + ); + path = apmtest; + sourceTree = ""; + }; + 697E99D221A4ED6900E03846 /* jni */ = { + isa = PBXGroup; + children = ( + ); + path = jni; + sourceTree = ""; + }; + 697E99D321A4ED6900E03846 /* ns */ = { + isa = PBXGroup; + children = ( + 697E99D421A4ED6900E03846 /* ns_core.h */, + 697E99D521A4ED6900E03846 /* nsx_core.c */, + 697E99D621A4ED6900E03846 /* noise_suppression_x.c */, + 697E99D721A4ED6900E03846 /* nsx_core_c.c */, + 697E99D821A4ED6900E03846 /* defines.h */, + 697E99D921A4ED6900E03846 /* noise_suppression.h */, + 697E99DA21A4ED6900E03846 /* ns_core.c */, + 697E99DB21A4ED6900E03846 /* nsx_core.h */, + 697E99DC21A4ED6900E03846 /* windows_private.h */, + 697E99DD21A4ED6900E03846 /* noise_suppression_x.h */, + 697E99DE21A4ED6900E03846 /* nsx_core_neon.c */, + 697E99DF21A4ED6900E03846 /* noise_suppression.c */, + 697E99E021A4ED6900E03846 /* nsx_defines.h */, + ); + path = ns; + sourceTree = ""; + }; + 697E99E621A4ED6900E03846 /* aec_dump */ = { + isa = PBXGroup; + children = ( + ); + path = aec_dump; + sourceTree = ""; + }; + 697E99E721A4ED6900E03846 /* include */ = { + isa = PBXGroup; + children = ( + 697E99E821A4ED6900E03846 /* audio_generator.h */, + 697E99E921A4ED6900E03846 /* config.h */, + 697E99EA21A4ED6900E03846 /* audio_frame_view.h */, + 697E99EB21A4ED6900E03846 /* mock_audio_processing.h */, + 697E99EC21A4ED6900E03846 /* gain_control.h */, + 697E99ED21A4ED6900E03846 /* audio_generator_factory.h */, + 697E99EE21A4ED6900E03846 /* audio_processing_statistics.cc */, + 697E99EF21A4ED6900E03846 /* audio_generator_factory.cc */, + 697E99F021A4ED6900E03846 /* aec_dump.cc */, + 697E99F121A4ED6900E03846 /* aec_dump.h */, + 697E99F221A4ED6900E03846 /* audio_processing_statistics.h */, + 697E99F321A4ED6900E03846 /* audio_processing.h */, + 697E99F421A4ED6900E03846 /* audio_processing.cc */, + 697E99F521A4ED6900E03846 /* config.cc */, + ); + path = include; + sourceTree = ""; + }; + 697E99F621A4ED6900E03846 /* agc2 */ = { + isa = PBXGroup; + children = ( + 697E99F721A4ED6900E03846 /* interpolated_gain_curve.h */, + 697E99F821A4ED6900E03846 /* biquad_filter.h */, + 697E99F921A4ED6900E03846 /* interpolated_gain_curve.cc */, + 697E99FA21A4ED6900E03846 /* agc2_common.cc */, + 697E99FB21A4ED6900E03846 /* agc2_testing_common.h */, + 697E99FC21A4ED6900E03846 /* adaptive_mode_level_estimator.h */, + 697E99FD21A4ED6900E03846 /* gain_applier.cc */, + 697E99FE21A4ED6900E03846 /* signal_classifier.h */, + 697E99FF21A4ED6900E03846 /* adaptive_agc.cc */, + 697E9A0021A4ED6900E03846 /* adaptive_digital_gain_applier.cc */, + 697E9A0121A4ED6900E03846 /* limiter.cc */, + 697E9A0221A4ED6900E03846 /* saturation_protector.cc */, + 697E9A0321A4ED6900E03846 /* vector_float_frame.h */, + 697E9A0421A4ED6900E03846 /* rnn_vad */, + 697E9A1B21A4ED6900E03846 /* fixed_gain_controller.h */, + 697E9A1C21A4ED6900E03846 /* adaptive_mode_level_estimator_agc.cc */, + 697E9A1D21A4ED6900E03846 /* vector_float_frame.cc */, + 697E9A1E21A4ED6900E03846 /* down_sampler.h */, + 697E9A1F21A4ED6900E03846 /* noise_level_estimator.cc */, + 697E9A2021A4ED6900E03846 /* agc2_testing_common.cc */, + 697E9A2121A4ED6900E03846 /* fixed_digital_level_estimator.cc */, + 697E9A2221A4ED6900E03846 /* fixed_gain_controller.cc */, + 697E9A2321A4ED6900E03846 /* saturation_protector.h */, + 697E9A2421A4ED6900E03846 /* vad_with_level.cc */, + 697E9A2521A4ED6900E03846 /* limiter_db_gain_curve.cc */, + 697E9A2621A4ED6900E03846 /* agc2_common.h */, + 697E9A2721A4ED6900E03846 /* adaptive_mode_level_estimator_agc.h */, + 697E9A2821A4ED6900E03846 /* adaptive_digital_gain_applier.h */, + 697E9A2921A4ED6900E03846 /* vad_with_level.h */, + 697E9A2A21A4ED6900E03846 /* limiter_db_gain_curve.h */, + 697E9A2B21A4ED6900E03846 /* fixed_digital_level_estimator.h */, + 697E9A2C21A4ED6900E03846 /* adaptive_agc.h */, + 697E9A2D21A4ED6900E03846 /* gain_applier.h */, + 697E9A2E21A4ED6900E03846 /* down_sampler.cc */, + 697E9A2F21A4ED6900E03846 /* noise_level_estimator.h */, + 697E9A3021A4ED6900E03846 /* signal_classifier.cc */, + 697E9A3121A4ED6900E03846 /* noise_spectrum_estimator.cc */, + 697E9A3221A4ED6900E03846 /* compute_interpolated_gain_curve.cc */, + 697E9A3321A4ED6900E03846 /* compute_interpolated_gain_curve.h */, + 697E9A3421A4ED6900E03846 /* biquad_filter.cc */, + 697E9A3521A4ED6900E03846 /* noise_spectrum_estimator.h */, + 697E9A3621A4ED6900E03846 /* limiter.h */, + 697E9A3721A4ED6900E03846 /* adaptive_mode_level_estimator.cc */, + ); + path = agc2; + sourceTree = ""; + }; + 697E9A0421A4ED6900E03846 /* rnn_vad */ = { + isa = PBXGroup; + children = ( + 697E9A0521A4ED6900E03846 /* spectral_features_internal.cc */, + 697E9A0621A4ED6900E03846 /* sequence_buffer.h */, + 697E9A0721A4ED6900E03846 /* rnn.h */, + 697E9A0821A4ED6900E03846 /* rnn.cc */, + 697E9A0921A4ED6900E03846 /* test_utils.h */, + 697E9A0A21A4ED6900E03846 /* pitch_info.h */, + 697E9A0B21A4ED6900E03846 /* lp_residual.h */, + 697E9A0C21A4ED6900E03846 /* ring_buffer.h */, + 697E9A0D21A4ED6900E03846 /* pitch_search_internal.cc */, + 697E9A0E21A4ED6900E03846 /* symmetric_matrix_buffer.h */, + 697E9A0F21A4ED6900E03846 /* spectral_features.h */, + 697E9A1021A4ED6900E03846 /* features_extraction.h */, + 697E9A1121A4ED6900E03846 /* common.h */, + 697E9A1221A4ED6900E03846 /* spectral_features_internal.h */, + 697E9A1321A4ED6900E03846 /* fft_util.h */, + 697E9A1421A4ED6900E03846 /* spectral_features.cc */, + 697E9A1521A4ED6900E03846 /* pitch_search_internal.h */, + 697E9A1621A4ED6900E03846 /* pitch_search.cc */, + 697E9A1721A4ED6900E03846 /* pitch_search.h */, + 697E9A1821A4ED6900E03846 /* features_extraction.cc */, + 697E9A1921A4ED6900E03846 /* fft_util.cc */, + 697E9A1A21A4ED6900E03846 /* lp_residual.cc */, + ); + path = rnn_vad; + sourceTree = ""; + }; + 697E9A3821A4ED6900E03846 /* transient */ = { + isa = PBXGroup; + children = ( + 697E9A3921A4ED6900E03846 /* moving_moments.cc */, + 697E9A3A21A4ED6900E03846 /* transient_detector.h */, + 697E9A3B21A4ED6900E03846 /* wpd_tree.cc */, + 697E9A3C21A4ED6900E03846 /* transient_suppressor.h */, + 697E9A3D21A4ED6900E03846 /* daubechies_8_wavelet_coeffs.h */, + 697E9A3E21A4ED6900E03846 /* common.h */, + 697E9A3F21A4ED6900E03846 /* wpd_node.h */, + 697E9A4021A4ED6900E03846 /* moving_moments.h */, + 697E9A4121A4ED6900E03846 /* wpd_tree.h */, + 697E9A4221A4ED6900E03846 /* wpd_node.cc */, + 697E9A4321A4ED6900E03846 /* transient_suppressor.cc */, + 697E9A4421A4ED6900E03846 /* transient_detector.cc */, + 697E9A4521A4ED6900E03846 /* dyadic_decimator.h */, + ); + path = transient; + sourceTree = ""; + }; + 697E9A4A21A4ED6900E03846 /* aec */ = { + isa = PBXGroup; + children = ( + 697E9A4B21A4ED6900E03846 /* echo_cancellation.cc */, + 697E9A4C21A4ED6900E03846 /* aec_resampler.h */, + 697E9A4D21A4ED6900E03846 /* aec_resampler.cc */, + 697E9A4E21A4ED6900E03846 /* echo_cancellation.h */, + 697E9A4F21A4ED6900E03846 /* aec_core.cc */, + 697E9A5021A4ED6900E03846 /* aec_core.h */, + 697E9A5121A4ED6900E03846 /* aec_core_optimized_methods.h */, + 697E9A5221A4ED6900E03846 /* aec_core_neon.cc */, + 697E9A5321A4ED6900E03846 /* aec_core_sse2.cc */, + 697E9A5421A4ED6900E03846 /* aec_common.h */, + ); + path = aec; + sourceTree = ""; + }; + 697E9A5921A4ED6900E03846 /* agc */ = { + isa = PBXGroup; + children = ( + 697E9A5A21A4ED6900E03846 /* agc.cc */, + 697E9A5B21A4ED6900E03846 /* loudness_histogram.cc */, + 697E9A5C21A4ED6900E03846 /* agc_manager_direct.cc */, + 697E9A5D21A4ED6900E03846 /* legacy */, + 697E9A6321A4ED6900E03846 /* utility.cc */, + 697E9A6421A4ED6900E03846 /* mock_agc.h */, + 697E9A6521A4ED6900E03846 /* loudness_histogram.h */, + 697E9A6621A4ED6900E03846 /* gain_map_internal.h */, + 697E9A6721A4ED6900E03846 /* utility.h */, + 697E9A6821A4ED6900E03846 /* agc_manager_direct.h */, + 697E9A6921A4ED6900E03846 /* agc.h */, + ); + path = agc; + sourceTree = ""; + }; + 697E9A5D21A4ED6900E03846 /* legacy */ = { + isa = PBXGroup; + children = ( + 697E9A5E21A4ED6900E03846 /* analog_agc.h */, + 697E9A5F21A4ED6900E03846 /* gain_control.h */, + 697E9A6021A4ED6900E03846 /* digital_agc.h */, + 697E9A6121A4ED6900E03846 /* analog_agc.c */, + 697E9A6221A4ED6900E03846 /* digital_agc.c */, + ); + path = legacy; + sourceTree = ""; + }; + 697E9A7021A4ED6900E03846 /* audio_generator */ = { + isa = PBXGroup; + children = ( + 697E9A7121A4ED6A00E03846 /* file_audio_generator.h */, + 697E9A7221A4ED6A00E03846 /* file_audio_generator.cc */, + ); + path = audio_generator; + sourceTree = ""; + }; + 697E9A7A21A4ED6A00E03846 /* aecm */ = { + isa = PBXGroup; + children = ( + 697E9A7B21A4ED6A00E03846 /* aecm_core.h */, + 697E9A7C21A4ED6A00E03846 /* aecm_defines.h */, + 697E9A7D21A4ED6A00E03846 /* aecm_core.cc */, + 697E9A7E21A4ED6A00E03846 /* aecm_core_c.cc */, + 697E9A7F21A4ED6A00E03846 /* aecm_core_neon.cc */, + 697E9A8021A4ED6A00E03846 /* echo_control_mobile.h */, + 697E9A8121A4ED6A00E03846 /* echo_control_mobile.cc */, + ); + path = aecm; + sourceTree = ""; + }; + 697E9A8221A4ED6A00E03846 /* aec3 */ = { + isa = PBXGroup; + children = ( + 697E9A8321A4ED6A00E03846 /* render_reverb_model.cc */, + 697E9A8421A4ED6A00E03846 /* downsampled_render_buffer.h */, + 697E9A8521A4ED6A00E03846 /* subtractor_output_analyzer.h */, + 697E9A8621A4ED6A00E03846 /* reverb_model_fallback.cc */, + 697E9A8721A4ED6A00E03846 /* residual_echo_estimator.h */, + 697E9A8821A4ED6A00E03846 /* shadow_filter_update_gain.h */, + 697E9A8921A4ED6A00E03846 /* echo_remover_metrics.cc */, + 697E9A8A21A4ED6A00E03846 /* matched_filter_lag_aggregator.cc */, + 697E9A8B21A4ED6A00E03846 /* render_delay_buffer2.cc */, + 697E9A8C21A4ED6A00E03846 /* aec_state.h */, + 697E9A8D21A4ED6A00E03846 /* suppression_filter.h */, + 697E9A8E21A4ED6A00E03846 /* echo_path_variability.cc */, + 697E9A8F21A4ED6A00E03846 /* frame_blocker.cc */, + 697E9A9021A4ED6A00E03846 /* subtractor.cc */, + 697E9A9121A4ED6A00E03846 /* block_delay_buffer.h */, + 697E9A9221A4ED6A00E03846 /* adaptive_fir_filter.h */, + 697E9A9321A4ED6A00E03846 /* cascaded_biquad_filter.h */, + 697E9A9421A4ED6A00E03846 /* matched_filter.h */, + 697E9A9521A4ED6A00E03846 /* subtractor_output.h */, + 697E9A9621A4ED6A00E03846 /* render_signal_analyzer.h */, + 697E9A9721A4ED6A00E03846 /* aec3_fft.cc */, + 697E9A9821A4ED6A00E03846 /* aec3_fft.h */, + 697E9A9921A4ED6A00E03846 /* echo_remover_metrics.h */, + 697E9A9A21A4ED6A00E03846 /* fullband_erle_estimator.cc */, + 697E9A9B21A4ED6A00E03846 /* suppression_filter.cc */, + 697E9A9C21A4ED6A00E03846 /* block_processor.cc */, + 697E9A9D21A4ED6A00E03846 /* filter_analyzer.h */, + 697E9A9E21A4ED6A00E03846 /* subtractor.h */, + 697E9A9F21A4ED6A00E03846 /* echo_path_delay_estimator.h */, + 697E9AA021A4ED6A00E03846 /* subband_erle_estimator.cc */, + 697E9AA121A4ED6A00E03846 /* render_delay_controller_metrics.cc */, + 697E9AA221A4ED6A00E03846 /* render_delay_buffer.cc */, + 697E9AA321A4ED6A00E03846 /* block_processor_metrics.h */, + 697E9AA421A4ED6A00E03846 /* vector_buffer.cc */, + 697E9AA521A4ED6A00E03846 /* erl_estimator.cc */, + 697E9AA621A4ED6A00E03846 /* aec_state.cc */, + 697E9AA721A4ED6A00E03846 /* adaptive_fir_filter.cc */, + 697E9AA821A4ED6A00E03846 /* fft_data.h */, + 697E9AA921A4ED6A00E03846 /* render_delay_controller.cc */, + 697E9AAA21A4ED6A00E03846 /* skew_estimator.cc */, + 697E9AAB21A4ED6A00E03846 /* render_delay_controller_metrics.h */, + 697E9AAC21A4ED6A00E03846 /* comfort_noise_generator.h */, + 697E9AAD21A4ED6A00E03846 /* echo_path_delay_estimator.cc */, + 697E9AAE21A4ED6A00E03846 /* erl_estimator.h */, + 697E9AAF21A4ED6A00E03846 /* echo_remover.h */, + 697E9AB021A4ED6A00E03846 /* block_framer.cc */, + 697E9AB121A4ED6A00E03846 /* erle_estimator.cc */, + 697E9AB221A4ED6A00E03846 /* reverb_model.cc */, + 697E9AB321A4ED6A00E03846 /* cascaded_biquad_filter.cc */, + 697E9AB421A4ED6A00E03846 /* matrix_buffer.h */, + 697E9AB521A4ED6A00E03846 /* render_buffer.cc */, + 697E9AB621A4ED6A00E03846 /* reverb_model_estimator.h */, + 697E9AB721A4ED6A00E03846 /* subtractor_output.cc */, + 697E9AB821A4ED6A00E03846 /* stationarity_estimator.cc */, + 697E9AB921A4ED6A00E03846 /* render_signal_analyzer.cc */, + 697E9ABA21A4ED6A00E03846 /* echo_path_variability.h */, + 697E9ABB21A4ED6A00E03846 /* moving_average.h */, + 697E9ABC21A4ED6A00E03846 /* render_reverb_model.h */, + 697E9ABD21A4ED6A00E03846 /* subtractor_output_analyzer.cc */, + 697E9ABE21A4ED6A00E03846 /* suppression_gain.cc */, + 697E9ABF21A4ED6A00E03846 /* echo_audibility.cc */, + 697E9AC021A4ED6A00E03846 /* block_processor_metrics.cc */, + 697E9AC121A4ED6A00E03846 /* render_delay_controller.h */, + 697E9AC221A4ED6A00E03846 /* suppression_gain.h */, + 697E9AC321A4ED6A00E03846 /* moving_average.cc */, + 697E9AC421A4ED6A00E03846 /* erle_estimator.h */, + 697E9AC521A4ED6A00E03846 /* subband_erle_estimator.h */, + 697E9AC621A4ED6A00E03846 /* reverb_model_estimator.cc */, + 697E9AC721A4ED6A00E03846 /* aec3_common.cc */, + 697E9AC821A4ED6A00E03846 /* residual_echo_estimator.cc */, + 697E9AC921A4ED6A00E03846 /* block_processor.h */, + 697E9ACA21A4ED6A00E03846 /* fullband_erle_estimator.h */, + 697E9ACB21A4ED6A00E03846 /* matched_filter.cc */, + 697E9ACC21A4ED6A00E03846 /* stationarity_estimator.h */, + 697E9ACD21A4ED6A00E03846 /* echo_canceller3.h */, + 697E9ACE21A4ED6A00E03846 /* skew_estimator.h */, + 697E9ACF21A4ED6A00E03846 /* reverb_decay_estimator.cc */, + 697E9AD021A4ED6A00E03846 /* render_delay_controller2.cc */, + 697E9AD121A4ED6A00E03846 /* render_buffer.h */, + 697E9AD221A4ED6A00E03846 /* suppression_gain_limiter.cc */, + 697E9AD321A4ED6A00E03846 /* main_filter_update_gain.cc */, + 697E9AD421A4ED6A00E03846 /* echo_remover.cc */, + 697E9AD521A4ED6A00E03846 /* reverb_model_fallback.h */, + 697E9AD621A4ED6A00E03846 /* downsampled_render_buffer.cc */, + 697E9AD721A4ED6A00E03846 /* vector_buffer.h */, + 697E9AD821A4ED6A00E03846 /* matrix_buffer.cc */, + 697E9AD921A4ED6A00E03846 /* reverb_frequency_response.h */, + 697E9ADA21A4ED6A00E03846 /* echo_audibility.h */, + 697E9ADB21A4ED6A00E03846 /* fft_buffer.h */, + 697E9ADC21A4ED6A00E03846 /* block_processor2.cc */, + 697E9ADD21A4ED6A00E03846 /* echo_canceller3.cc */, + 697E9ADE21A4ED6A00E03846 /* block_delay_buffer.cc */, + 697E9ADF21A4ED6A00E03846 /* aec3_common.h */, + 697E9AE021A4ED6A00E03846 /* fft_buffer.cc */, + 697E9AE121A4ED6A00E03846 /* vector_math.h */, + 697E9AE221A4ED6A00E03846 /* decimator.h */, + 697E9AE321A4ED6A00E03846 /* frame_blocker.h */, + 697E9AE421A4ED6A00E03846 /* block_framer.h */, + 697E9AE521A4ED6A00E03846 /* suppression_gain_limiter.h */, + 697E9AE621A4ED6A00E03846 /* delay_estimate.h */, + 697E9AE721A4ED6A00E03846 /* comfort_noise_generator.cc */, + 697E9AE821A4ED6A00E03846 /* reverb_model.h */, + 697E9AE921A4ED6A00E03846 /* main_filter_update_gain.h */, + 697E9AEA21A4ED6A00E03846 /* matched_filter_lag_aggregator.h */, + 697E9AEB21A4ED6A00E03846 /* shadow_filter_update_gain.cc */, + 697E9AEC21A4ED6A00E03846 /* filter_analyzer.cc */, + 697E9AED21A4ED6A00E03846 /* reverb_decay_estimator.h */, + 697E9AEE21A4ED6A00E03846 /* reverb_frequency_response.cc */, + 697E9AEF21A4ED6A00E03846 /* decimator.cc */, + 697E9AF021A4ED6A00E03846 /* render_delay_buffer.h */, + ); + path = aec3; + sourceTree = ""; + }; + 697E9AF421A4ED6A00E03846 /* logging */ = { + isa = PBXGroup; + children = ( + 697E9AF521A4ED6A00E03846 /* apm_data_dumper.cc */, + 697E9AF621A4ED6A00E03846 /* apm_data_dumper.h */, + ); + path = logging; + sourceTree = ""; + }; + 697E9AF721A4ED6A00E03846 /* vad */ = { + isa = PBXGroup; + children = ( + 697E9AF821A4ED6A00E03846 /* voice_activity_detector.cc */, + 697E9AF921A4ED6A00E03846 /* standalone_vad.cc */, + 697E9AFA21A4ED6A00E03846 /* vad_audio_proc_internal.h */, + 697E9AFB21A4ED6A00E03846 /* pitch_internal.cc */, + 697E9AFC21A4ED6A00E03846 /* vad_circular_buffer.cc */, + 697E9AFD21A4ED6A00E03846 /* vad_circular_buffer.h */, + 697E9AFE21A4ED6A00E03846 /* pitch_based_vad.h */, + 697E9AFF21A4ED6A00E03846 /* vad_audio_proc.cc */, + 697E9B0021A4ED6A00E03846 /* pole_zero_filter.cc */, + 697E9B0121A4ED6A00E03846 /* pole_zero_filter.h */, + 697E9B0221A4ED6A00E03846 /* pitch_based_vad.cc */, + 697E9B0321A4ED6A00E03846 /* gmm.h */, + 697E9B0421A4ED6A00E03846 /* common.h */, + 697E9B0521A4ED6A00E03846 /* vad_audio_proc.h */, + 697E9B0621A4ED6A00E03846 /* voice_gmm_tables.h */, + 697E9B0721A4ED6A00E03846 /* noise_gmm_tables.h */, + 697E9B0821A4ED6A00E03846 /* pitch_internal.h */, + 697E9B0921A4ED6A00E03846 /* gmm.cc */, + 697E9B0A21A4ED6A00E03846 /* standalone_vad.h */, + 697E9B0B21A4ED6A00E03846 /* voice_activity_detector.h */, + ); + path = vad; + sourceTree = ""; + }; + 697E9B0C21A4ED6A00E03846 /* utility */ = { + isa = PBXGroup; + children = ( + 697E9B0D21A4ED6A00E03846 /* ooura_fft_tables_neon_sse2.h */, + 697E9B0E21A4ED6A00E03846 /* delay_estimator_internal.h */, + 697E9B0F21A4ED6A00E03846 /* ooura_fft.cc */, + 697E9B1021A4ED6A00E03846 /* ooura_fft.h */, + 697E9B1121A4ED6A00E03846 /* delay_estimator_wrapper.cc */, + 697E9B1221A4ED6A00E03846 /* ooura_fft_sse2.cc */, + 697E9B1321A4ED6A00E03846 /* delay_estimator.cc */, + 697E9B1421A4ED6A00E03846 /* block_mean_calculator.h */, + 697E9B1521A4ED6A00E03846 /* ooura_fft_neon.cc */, + 697E9B1621A4ED6A00E03846 /* block_mean_calculator.cc */, + 697E9B1721A4ED6A00E03846 /* delay_estimator.h */, + 697E9B1821A4ED6A00E03846 /* ooura_fft_tables_common.h */, + 697E9B1921A4ED6A00E03846 /* delay_estimator_wrapper.h */, + ); + path = utility; + sourceTree = ""; + }; + 697E9B1A21A4ED6A00E03846 /* third_party */ = { + isa = PBXGroup; + children = ( + 697E9B1B21A4ED6A00E03846 /* rnnoise */, + ); + path = third_party; + sourceTree = ""; + }; + 697E9B1B21A4ED6A00E03846 /* rnnoise */ = { + isa = PBXGroup; + children = ( + 697E9B1C21A4ED6A00E03846 /* src */, + ); + path = rnnoise; + sourceTree = ""; + }; + 697E9B1C21A4ED6A00E03846 /* src */ = { + isa = PBXGroup; + children = ( + 697E9B1D21A4ED6A00E03846 /* rnn_vad_weights.cc */, + 697E9B1E21A4ED6A00E03846 /* rnn_activations.h */, + 697E9B1F21A4ED6A00E03846 /* kiss_fft.h */, + 697E9B2021A4ED6A00E03846 /* kiss_fft.cc */, + 697E9B2121A4ED6A00E03846 /* rnn_vad_weights.h */, + ); + path = src; + sourceTree = ""; + }; + 69A6DCFE1E95EC7700000E69 /* webrtc_dsp */ = { + isa = PBXGroup; + children = ( + 697E990B21A4ED6800E03846 /* absl */, + 697E993421A4ED6900E03846 /* api */, + 697E989521A4ED6800E03846 /* common_audio */, + 697E998221A4ED6900E03846 /* modules */, + 697E993E21A4ED6900E03846 /* rtc_base */, + 697E988A21A4ED6800E03846 /* system_wrappers */, + 697E9B1A21A4ED6A00E03846 /* third_party */, + 697E961921A4EA0700E03846 /* typedefs.h */, + ); + path = webrtc_dsp; + sourceTree = ""; + }; + 69DD8CFC218CD400001E8140 /* video */ = { + isa = PBXGroup; + children = ( + 69719A79224A627F00FE9B2A /* VideoFEC.cpp */, + 69719A78224A627E00FE9B2A /* VideoFEC.h */, + 69719A7A224A627F00FE9B2A /* VideoPacketSender.cpp */, + 69719A77224A627E00FE9B2A /* VideoPacketSender.h */, + 69B607D322318BBD00ED7D94 /* ScreamCongestionController.cpp */, + 69B607D222318BBD00ED7D94 /* ScreamCongestionController.h */, + 69DD8CFD218CD400001E8140 /* VideoRenderer.h */, + 69DD8CFE218CD400001E8140 /* VideoRenderer.cpp */, + 69DD8CFF218CD400001E8140 /* VideoSource.cpp */, + 69DD8D00218CD400001E8140 /* VideoSource.h */, + ); + path = video; + sourceTree = ""; + }; + 69F8422C1E67540700C110F7 = { + isa = PBXGroup; + children = ( + 692AB8861E6759BF00706ACC /* libtgvoip */, + 69F842371E67540700C110F7 /* Products */, + 692AB9061E675E8700706ACC /* Frameworks */, + ); + sourceTree = ""; + }; + 69F842371E67540700C110F7 /* Products */ = { + isa = PBXGroup; + children = ( + 69F842361E67540700C110F7 /* libtgvoip.framework */, + ); + name = Products; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXHeadersBuildPhase section */ + 69F842331E67540700C110F7 /* Headers */ = { + isa = PBXHeadersBuildPhase; + buildActionMask = 2147483647; + files = ( + 69F791552221F16C00FE53C4 /* VideoToolboxEncoderSource.h in Headers */, + 69719A7B224A627F00FE9B2A /* VideoPacketSender.h in Headers */, + 69F7914C2220A41000FE53C4 /* TGVVideoSource.h in Headers */, + 692AB9051E6759DD00706ACC /* VoIPServerConfig.h in Headers */, + 692AB9031E6759DD00706ACC /* VoIPController.h in Headers */, + 69F791592222AC2800FE53C4 /* SampleBufferDisplayLayerRenderer.h in Headers */, + 69F791502220A76500FE53C4 /* TGVVideoRenderer.h in Headers */, + 69719A7C224A627F00FE9B2A /* VideoFEC.h in Headers */, + 69B607D422318BBE00ED7D94 /* ScreamCongestionController.h in Headers */, + 6929CD102233ED81009B7378 /* PrivateDefines.h in Headers */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXHeadersBuildPhase section */ + +/* Begin PBXNativeTarget section */ + 69F842351E67540700C110F7 /* libtgvoip */ = { + isa = PBXNativeTarget; + buildConfigurationList = 69F8423E1E67540700C110F7 /* Build configuration list for PBXNativeTarget "libtgvoip" */; + buildPhases = ( + 69F842311E67540700C110F7 /* Sources */, + 69F842321E67540700C110F7 /* Frameworks */, + 69F842331E67540700C110F7 /* Headers */, + 69F842341E67540700C110F7 /* Resources */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = libtgvoip; + productName = libtgvoip; + productReference = 69F842361E67540700C110F7 /* libtgvoip.framework */; + productType = "com.apple.product-type.framework"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 69F8422D1E67540700C110F7 /* Project object */ = { + isa = PBXProject; + attributes = { + LastUpgradeCheck = 0820; + ORGANIZATIONNAME = Grishka; + TargetAttributes = { + 69F842351E67540700C110F7 = { + CreatedOnToolsVersion = 8.2.1; + ProvisioningStyle = Automatic; + }; + }; + }; + buildConfigurationList = 69F842301E67540700C110F7 /* Build configuration list for PBXProject "libtgvoip" */; + compatibilityVersion = "Xcode 3.2"; + developmentRegion = English; + hasScannedForEncodings = 0; + knownRegions = ( + en, + ); + mainGroup = 69F8422C1E67540700C110F7; + productRefGroup = 69F842371E67540700C110F7 /* Products */; + projectDirPath = ""; + projectReferences = ( + { + ProductGroup = 692AB9081E675E8800706ACC /* Products */; + ProjectRef = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + }, + ); + projectRoot = ""; + targets = ( + 69F842351E67540700C110F7 /* libtgvoip */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXReferenceProxy section */ + 692AB9111E675E8800706ACC /* Telegram.app */ = { + isa = PBXReferenceProxy; + fileType = wrapper.application; + path = Telegram.app; + remoteRef = 692AB9101E675E8800706ACC /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; + 692AB9131E675E8800706ACC /* Share.appex */ = { + isa = PBXReferenceProxy; + fileType = "wrapper.app-extension"; + path = Share.appex; + remoteRef = 692AB9121E675E8800706ACC /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; + 692AB9151E675E8800706ACC /* watchkitapp.app */ = { + isa = PBXReferenceProxy; + fileType = wrapper.application; + path = watchkitapp.app; + remoteRef = 692AB9141E675E8800706ACC /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; + 692AB9171E675E8800706ACC /* watchkitapp Extension.appex */ = { + isa = PBXReferenceProxy; + fileType = "wrapper.app-extension"; + path = "watchkitapp Extension.appex"; + remoteRef = 692AB9161E675E8800706ACC /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; + 692AB9191E675E8800706ACC /* SiriIntents.appex */ = { + isa = PBXReferenceProxy; + fileType = "wrapper.app-extension"; + path = SiriIntents.appex; + remoteRef = 692AB9181E675E8800706ACC /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; + 692AB91B1E675E8800706ACC /* LegacyDatabase.framework */ = { + isa = PBXReferenceProxy; + fileType = wrapper.framework; + path = LegacyDatabase.framework; + remoteRef = 692AB91A1E675E8800706ACC /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; + 69960A0E1EF85C2900F9D091 /* Widget.appex */ = { + isa = PBXReferenceProxy; + fileType = "wrapper.app-extension"; + path = Widget.appex; + remoteRef = 69960A0D1EF85C2900F9D091 /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; +/* End PBXReferenceProxy section */ + +/* Begin PBXResourcesBuildPhase section */ + 69F842341E67540700C110F7 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXResourcesBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + 69F842311E67540700C110F7 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 697E9D1B21A4ED6D00E03846 /* echo_audibility.cc in Sources */, + 697E9B9821A4ED6B00E03846 /* ascii.cc in Sources */, + 697E9B3C21A4ED6B00E03846 /* sinc_resampler_neon.cc in Sources */, + 69B607D522318BBE00ED7D94 /* ScreamCongestionController.cpp in Sources */, + 69719A7D224A627F00FE9B2A /* VideoFEC.cpp in Sources */, + 697E9D0621A4ED6D00E03846 /* skew_estimator.cc in Sources */, + 697E9C5321A4ED6C00E03846 /* audio_processing_statistics.cc in Sources */, + 697E9BFD21A4ED6C00E03846 /* pitch_estimator.c in Sources */, + 697E9C7C21A4ED6C00E03846 /* fft_util.cc in Sources */, + 697E9D1F21A4ED6D00E03846 /* moving_average.cc in Sources */, + 697E9D1C21A4ED6D00E03846 /* block_processor_metrics.cc in Sources */, + 697E9C7721A4ED6C00E03846 /* spectral_features.cc in Sources */, + 697E9B4721A4ED6B00E03846 /* sinusoidal_linear_chirp_source.cc in Sources */, + 697E9D5A21A4ED6E00E03846 /* pole_zero_filter.cc in Sources */, + 697E9D1321A4ED6D00E03846 /* subtractor_output.cc in Sources */, + 697E9B3821A4ED6B00E03846 /* audio_util.cc in Sources */, + 697E9D5C21A4ED6E00E03846 /* pitch_based_vad.cc in Sources */, + 697E9B9021A4ED6B00E03846 /* vad_core.c in Sources */, + 697E9C9D21A4ED6D00E03846 /* wpd_tree.cc in Sources */, + 697E9C2721A4ED6C00E03846 /* decode_bwe.c in Sources */, + 697E9D6C21A4ED6E00E03846 /* delay_estimator.cc in Sources */, + 697E9C1021A4ED6C00E03846 /* lpc_tables.c in Sources */, + 697E9B5B21A4ED6B00E03846 /* complex_fft.c in Sources */, + 697E9B9321A4ED6B00E03846 /* vad_gmm.c in Sources */, + 697E9D4A21A4ED6D00E03846 /* reverb_frequency_response.cc in Sources */, + 697E9C9721A4ED6D00E03846 /* biquad_filter.cc in Sources */, + 697E9B5021A4ED6B00E03846 /* audio_converter.cc in Sources */, + 697E9CFC21A4ED6D00E03846 /* subband_erle_estimator.cc in Sources */, + 69F791512220A76500FE53C4 /* TGVVideoRenderer.mm in Sources */, + 697E9B4E21A4ED6B00E03846 /* fft4g.c in Sources */, + 697E9C6821A4ED6C00E03846 /* spectral_features_internal.cc in Sources */, + 697E9CAE21A4ED6D00E03846 /* aec_resampler.cc in Sources */, + 697E9D3C21A4ED6D00E03846 /* fft_buffer.cc in Sources */, + 697E9CD021A4ED6D00E03846 /* file_audio_generator.cc in Sources */, + 697E9CB921A4ED6D00E03846 /* gain_control_for_experimental_agc.cc in Sources */, + 697E9CDA21A4ED6D00E03846 /* aecm_core.cc in Sources */, + 697E9C6121A4ED6C00E03846 /* gain_applier.cc in Sources */, + 697E9C0C21A4ED6C00E03846 /* filter_functions.c in Sources */, + 697E9CBB21A4ED6D00E03846 /* loudness_histogram.cc in Sources */, + 6915307B1E6B5BAB004F643F /* logging.cpp in Sources */, + 697E9C0D21A4ED6C00E03846 /* decode.c in Sources */, + 697E9B2821A4ED6B00E03846 /* metrics.cc in Sources */, + 697E9CEA21A4ED6D00E03846 /* echo_path_variability.cc in Sources */, + 697E9B7921A4ED6B00E03846 /* filter_ar.c in Sources */, + 692AB9041E6759DD00706ACC /* VoIPServerConfig.cpp in Sources */, + 697E9B7D21A4ED6B00E03846 /* ilbc_specific_functions.c in Sources */, + 697E9C7021A4ED6C00E03846 /* pitch_search_internal.cc in Sources */, + 697E9C7D21A4ED6C00E03846 /* lp_residual.cc in Sources */, + 697E9B5621A4ED6B00E03846 /* smoothing_filter.cc in Sources */, + 692AB9021E6759DD00706ACC /* VoIPController.cpp in Sources */, + 697E9C2B21A4ED6C00E03846 /* isac.c in Sources */, + 697E9CDF21A4ED6D00E03846 /* render_reverb_model.cc in Sources */, + 697E9CCA21A4ED6D00E03846 /* audio_processing_impl.cc in Sources */, + 697E9CAC21A4ED6D00E03846 /* echo_cancellation.cc in Sources */, + 697E9CDE21A4ED6D00E03846 /* echo_control_mobile.cc in Sources */, + 697E9C6B21A4ED6C00E03846 /* rnn.cc in Sources */, + 697E9B4021A4ED6B00E03846 /* sinc_resampler_sse.cc in Sources */, + 697E9D0521A4ED6D00E03846 /* render_delay_controller.cc in Sources */, + 697E9D7621A4ED6E00E03846 /* kiss_fft.cc in Sources */, + 697E9B6521A4ED6B00E03846 /* sqrt_of_one_minus_x_squared.c in Sources */, + 69960A051EF85C2900F9D091 /* DarwinSpecific.mm in Sources */, + 69791A4D1EE8262400BB85FB /* NetworkSocketPosix.cpp in Sources */, + 697E9CBC21A4ED6D00E03846 /* agc_manager_direct.cc in Sources */, + 697E9B5821A4ED6B00E03846 /* ring_buffer.c in Sources */, + 697E9C1E21A4ED6C00E03846 /* isac_vad.c in Sources */, + 697E9B6921A4ED6B00E03846 /* lpc_to_refl_coef.c in Sources */, + 697E9CF321A4ED6D00E03846 /* aec3_fft.cc in Sources */, + 697E9B3A21A4ED6B00E03846 /* fir_filter_sse.cc in Sources */, + 697E9CEC21A4ED6D00E03846 /* subtractor.cc in Sources */, + 697E9C2821A4ED6C00E03846 /* spectrum_ar_model_tables.c in Sources */, + 697E9C1821A4ED6C00E03846 /* arith_routines_hist.c in Sources */, + 697E9B2E21A4ED6B00E03846 /* fir_filter_factory.cc in Sources */, + 69DD8D02218CD401001E8140 /* VideoRenderer.cpp in Sources */, + 697E9C8321A4ED6C00E03846 /* agc2_testing_common.cc in Sources */, + 697E9C6621A4ED6C00E03846 /* saturation_protector.cc in Sources */, + 697E9CA521A4ED6D00E03846 /* transient_suppressor.cc in Sources */, + 697E9B6F21A4ED6B00E03846 /* division_operations.c in Sources */, + 697E9CC021A4ED6D00E03846 /* analog_agc.c in Sources */, + 697E9C1D21A4ED6C00E03846 /* entropy_coding.c in Sources */, + 697E9CD521A4ED6D00E03846 /* noise_suppression_impl.cc in Sources */, + 697E9D1A21A4ED6D00E03846 /* suppression_gain.cc in Sources */, + 697E9B7221A4ED6B00E03846 /* min_max_operations_neon.c in Sources */, + 697E9B8921A4ED6B00E03846 /* vad.cc in Sources */, + 697E9BD721A4ED6C00E03846 /* checks.cc in Sources */, + 697E9C7F21A4ED6C00E03846 /* adaptive_mode_level_estimator_agc.cc in Sources */, + 692AB8D81E6759DD00706ACC /* CongestionControl.cpp in Sources */, + 697E9BE421A4ED6C00E03846 /* logging_webrtc.cc in Sources */, + 697E9D2F21A4ED6D00E03846 /* main_filter_update_gain.cc in Sources */, + 697E9C0A21A4ED6C00E03846 /* pitch_filter.c in Sources */, + 697E9CDB21A4ED6D00E03846 /* aecm_core_c.cc in Sources */, + 697E9C3421A4ED6C00E03846 /* circular_buffer.cc in Sources */, + 697E9B4B21A4ED6B00E03846 /* spl_sqrt_floor.c in Sources */, + 697E9D5521A4ED6D00E03846 /* pitch_internal.cc in Sources */, + 697E9CF621A4ED6D00E03846 /* fullband_erle_estimator.cc in Sources */, + 697E9C8821A4ED6C00E03846 /* limiter_db_gain_curve.cc in Sources */, + 697E9B4421A4ED6B00E03846 /* push_resampler.cc in Sources */, + 697E9B3D21A4ED6B00E03846 /* push_sinc_resampler.cc in Sources */, + 697E9C5921A4ED6C00E03846 /* audio_processing.cc in Sources */, + 697E9C4B21A4ED6C00E03846 /* typing_detection.cc in Sources */, + 697E9B6121A4ED6B00E03846 /* auto_corr_to_refl_coef.c in Sources */, + 697E9C2521A4ED6C00E03846 /* lpc_shape_swb12_tables.c in Sources */, + 697E9BA521A4ED6B00E03846 /* raw_logging.cc in Sources */, + 697E9D6E21A4ED6E00E03846 /* ooura_fft_neon.cc in Sources */, + 697E9C1521A4ED6C00E03846 /* encode.c in Sources */, + 697E9B5421A4ED6B00E03846 /* sparse_fir_filter.cc in Sources */, + 697E9B5721A4ED6B00E03846 /* fir_filter_c.cc in Sources */, + 697E9D0E21A4ED6D00E03846 /* reverb_model.cc in Sources */, + 697E9C7921A4ED6C00E03846 /* pitch_search.cc in Sources */, + 697E9B5C21A4ED6B00E03846 /* filter_ma_fast_q12.c in Sources */, + 69015D941E9D848700AC9763 /* NetworkSocket.cpp in Sources */, + 697E9C8021A4ED6C00E03846 /* vector_float_frame.cc in Sources */, + 697E9C3921A4ED6C00E03846 /* gain_control_impl.cc in Sources */, + 697E9B7C21A4ED6B00E03846 /* real_fft.c in Sources */, + 697E9D0F21A4ED6D00E03846 /* cascaded_biquad_filter.cc in Sources */, + 697E9D4821A4ED6D00E03846 /* filter_analyzer.cc in Sources */, + 697E9D5921A4ED6E00E03846 /* vad_audio_proc.cc in Sources */, + 697E9D4321A4ED6D00E03846 /* comfort_noise_generator.cc in Sources */, + 697E9B2721A4ED6B00E03846 /* field_trial.cc in Sources */, + 697E9CFE21A4ED6D00E03846 /* render_delay_buffer.cc in Sources */, + 697E9C5A21A4ED6C00E03846 /* config.cc in Sources */, + 697E9D4721A4ED6D00E03846 /* shadow_filter_update_gain.cc in Sources */, + 697E9CA421A4ED6D00E03846 /* wpd_node.cc in Sources */, + 697E9D1521A4ED6D00E03846 /* render_signal_analyzer.cc in Sources */, + 697E9B5E21A4ED6B00E03846 /* levinson_durbin.c in Sources */, + 697E9D0321A4ED6D00E03846 /* adaptive_fir_filter.cc in Sources */, + 69F791542221F16C00FE53C4 /* VideoToolboxEncoderSource.mm in Sources */, + 697E9B4A21A4ED6B00E03846 /* wav_file.cc in Sources */, + 697E9CE721A4ED6D00E03846 /* render_delay_buffer2.cc in Sources */, + 697E9C1121A4ED6C00E03846 /* lpc_gain_swb_tables.c in Sources */, + 697E9C3D21A4ED6C00E03846 /* noise_suppression_x.c in Sources */, + 697E9D6F21A4ED6E00E03846 /* block_mean_calculator.cc in Sources */, + 697E9CAB21A4ED6D00E03846 /* three_band_filter_bank.cc in Sources */, + 692AB8FB1E6759DD00706ACC /* AudioOutputAudioUnit.cpp in Sources */, + 697E9B7821A4ED6B00E03846 /* refl_coef_to_lpc.c in Sources */, + 697E9B2921A4ED6B00E03846 /* cpu_features.cc in Sources */, + 697E9C1221A4ED6C00E03846 /* bandwidth_estimator.c in Sources */, + 697E9BB821A4ED6B00E03846 /* echo_canceller3_factory.cc in Sources */, + 697E9BF021A4ED6C00E03846 /* event_tracer.cc in Sources */, + 697E9D5021A4ED6D00E03846 /* apm_data_dumper.cc in Sources */, + 697E9B8521A4ED6B00E03846 /* spl_inl.c in Sources */, + 697E9D3A21A4ED6D00E03846 /* block_delay_buffer.cc in Sources */, + 697E9C6321A4ED6C00E03846 /* adaptive_agc.cc in Sources */, + 697E9D4D21A4ED6D00E03846 /* echo_control_mobile_impl.cc in Sources */, + 697E9D0D21A4ED6D00E03846 /* erle_estimator.cc in Sources */, + 697E9B9C21A4ED6B00E03846 /* bad_optional_access.cc in Sources */, + 697E9C4521A4ED6C00E03846 /* nsx_core_neon.c in Sources */, + 697E9B5121A4ED6B00E03846 /* real_fourier.cc in Sources */, + 697E9CB021A4ED6D00E03846 /* aec_core.cc in Sources */, + 697E9B6221A4ED6B00E03846 /* resample_by_2_internal.c in Sources */, + 697E9B6421A4ED6B00E03846 /* energy.c in Sources */, + 692AB8EB1E6759DD00706ACC /* OpusDecoder.cpp in Sources */, + 697E9B8821A4ED6B00E03846 /* vad_sp.c in Sources */, + 697E9D2B21A4ED6D00E03846 /* reverb_decay_estimator.cc in Sources */, + 697E9C2321A4ED6C00E03846 /* arith_routines.c in Sources */, + 692AB8E61E6759DD00706ACC /* JitterBuffer.cpp in Sources */, + 697E9BFA21A4ED6C00E03846 /* fft.c in Sources */, + 697E9B3F21A4ED6B00E03846 /* resampler.cc in Sources */, + 697E9C3821A4ED6C00E03846 /* splitting_filter.cc in Sources */, + 697E9CF721A4ED6D00E03846 /* suppression_filter.cc in Sources */, + 697E9BB221A4ED6B00E03846 /* audio_frame.cc in Sources */, + 697E9C9321A4ED6D00E03846 /* signal_classifier.cc in Sources */, + 697E9C0621A4ED6C00E03846 /* transform.c in Sources */, + 697E9CB721A4ED6D00E03846 /* voice_detection_impl.cc in Sources */, + 692AB9001E6759DD00706ACC /* TGLogWrapper.m in Sources */, + 697E9BEE21A4ED6C00E03846 /* event.cc in Sources */, + 697E9D2421A4ED6D00E03846 /* residual_echo_estimator.cc in Sources */, + 697E9CE621A4ED6D00E03846 /* matched_filter_lag_aggregator.cc in Sources */, + 697E9B9D21A4ED6B00E03846 /* optional.cc in Sources */, + 697E9CFD21A4ED6D00E03846 /* render_delay_controller_metrics.cc in Sources */, + 697E9C3521A4ED6C00E03846 /* mean_variance_estimator.cc in Sources */, + 697E9B9521A4ED6B00E03846 /* memutil.cc in Sources */, + 697E9BFE21A4ED6C00E03846 /* lpc_shape_swb16_tables.c in Sources */, + 697E9C6521A4ED6C00E03846 /* limiter.cc in Sources */, + 697E9B7521A4ED6B00E03846 /* resample.c in Sources */, + 692AB8F91E6759DD00706ACC /* AudioInputAudioUnit.cpp in Sources */, + 697E9D1921A4ED6D00E03846 /* subtractor_output_analyzer.cc in Sources */, + 697E9BD521A4ED6C00E03846 /* stringencode.cc in Sources */, + 697E9D5321A4ED6D00E03846 /* standalone_vad.cc in Sources */, + 697E9C0B21A4ED6C00E03846 /* encode_lpc_swb.c in Sources */, + 697E9CD121A4ED6D00E03846 /* gain_controller2.cc in Sources */, + 697E9BBC21A4ED6B00E03846 /* race_checker.cc in Sources */, + 697E9D3821A4ED6D00E03846 /* block_processor2.cc in Sources */, + 697E9BEB21A4ED6C00E03846 /* criticalsection.cc in Sources */, + 69791A571EE8272A00BB85FB /* Resampler.cpp in Sources */, + 69F7914D2220A41000FE53C4 /* TGVVideoSource.mm in Sources */, + 697E9B8221A4ED6B00E03846 /* resample_by_2.c in Sources */, + 697E9B3521A4ED6B00E03846 /* wav_header.cc in Sources */, + 697E9D5621A4ED6E00E03846 /* vad_circular_buffer.cc in Sources */, + 697E9CEB21A4ED6D00E03846 /* frame_blocker.cc in Sources */, + 697E9B7A21A4ED6B00E03846 /* vector_scaling_operations.c in Sources */, + 697E9BBE21A4ED6B00E03846 /* string_builder.cc in Sources */, + 697E9BC921A4ED6C00E03846 /* platform_file.cc in Sources */, + 697E9C0E21A4ED6C00E03846 /* lattice.c in Sources */, + 69DD8D03218CD401001E8140 /* VideoSource.cpp in Sources */, + 697E9CB421A4ED6D00E03846 /* aec_core_sse2.cc in Sources */, + 697E9B6721A4ED6B00E03846 /* filter_ar_fast_q12.c in Sources */, + 697E9CDC21A4ED6D00E03846 /* aecm_core_neon.cc in Sources */, + 697E9C5521A4ED6C00E03846 /* aec_dump.cc in Sources */, + 697E9D4B21A4ED6D00E03846 /* decimator.cc in Sources */, + 697E9C8521A4ED6C00E03846 /* fixed_gain_controller.cc in Sources */, + 692AB8E91E6759DD00706ACC /* MediaStreamItf.cpp in Sources */, + 697E9CE221A4ED6D00E03846 /* reverb_model_fallback.cc in Sources */, + 697E9B8F21A4ED6B00E03846 /* vad_filterbank.c in Sources */, + 697E9C9121A4ED6D00E03846 /* down_sampler.cc in Sources */, + 697E9CA821A4ED6D00E03846 /* low_cut_filter.cc in Sources */, + 697E9C9A21A4ED6D00E03846 /* adaptive_mode_level_estimator.cc in Sources */, + 697E9C9521A4ED6D00E03846 /* compute_interpolated_gain_curve.cc in Sources */, + 697E9C1621A4ED6C00E03846 /* lpc_analysis.c in Sources */, + 697E9B8321A4ED6B00E03846 /* get_hanning_window.c in Sources */, + 697E9C0221A4ED6C00E03846 /* filterbanks.c in Sources */, + 697E9C5E21A4ED6C00E03846 /* agc2_common.cc in Sources */, + 697E9D0021A4ED6D00E03846 /* vector_buffer.cc in Sources */, + 697E9C0021A4ED6C00E03846 /* arith_routines_logist.c in Sources */, + 697E9B8A21A4ED6B00E03846 /* webrtc_vad.c in Sources */, + 697E9D0221A4ED6D00E03846 /* aec_state.cc in Sources */, + 697E9B3621A4ED6B00E03846 /* real_fourier_ooura.cc in Sources */, + 692AB8DA1E6759DD00706ACC /* EchoCanceller.cpp in Sources */, + 697E9C7B21A4ED6C00E03846 /* features_extraction.cc in Sources */, + 697E9D2C21A4ED6D00E03846 /* render_delay_controller2.cc in Sources */, + 697E9CB321A4ED6D00E03846 /* aec_core_neon.cc in Sources */, + 697E9D3921A4ED6D00E03846 /* echo_canceller3.cc in Sources */, + 697E9CF821A4ED6D00E03846 /* block_processor.cc in Sources */, + 697E9C5D21A4ED6C00E03846 /* interpolated_gain_curve.cc in Sources */, + 697E9C3E21A4ED6C00E03846 /* nsx_core_c.c in Sources */, + 697E9BE221A4ED6C00E03846 /* platform_thread.cc in Sources */, + 697E9B6621A4ED6B00E03846 /* downsample_fast.c in Sources */, + 697E9BEC21A4ED6C00E03846 /* platform_thread_types.cc in Sources */, + 697E9CB821A4ED6D00E03846 /* echo_cancellation_impl.cc in Sources */, + 697E9C2A21A4ED6C00E03846 /* pitch_lag_tables.c in Sources */, + 697E9C3321A4ED6C00E03846 /* moving_max.cc in Sources */, + 697E9BCB21A4ED6C00E03846 /* string_to_number.cc in Sources */, + 6998617B2095292A00B68BEC /* PacketReassembler.cpp in Sources */, + 697E9B8421A4ED6B00E03846 /* resample_48khz.c in Sources */, + 697E9D2721A4ED6D00E03846 /* matched_filter.cc in Sources */, + 697E9C4A21A4ED6C00E03846 /* audio_buffer.cc in Sources */, + 69FB0B2D20F6860E00827817 /* MessageThread.cpp in Sources */, + 697E9B8621A4ED6B00E03846 /* spl_sqrt.c in Sources */, + 697E9BC121A4ED6B00E03846 /* aligned_malloc.cc in Sources */, + 697E9CD321A4ED6D00E03846 /* residual_echo_detector.cc in Sources */, + 697E9D0121A4ED6D00E03846 /* erl_estimator.cc in Sources */, + 697E9BD621A4ED6C00E03846 /* stringutils.cc in Sources */, + 697E9D6A21A4ED6E00E03846 /* delay_estimator_wrapper.cc in Sources */, + 692AB8CF1E6759DD00706ACC /* BlockingQueue.cpp in Sources */, + 692AB8CB1E6759DD00706ACC /* AudioInput.cpp in Sources */, + 697E9B7621A4ED6B00E03846 /* cross_correlation_neon.c in Sources */, + 697E9C4121A4ED6C00E03846 /* ns_core.c in Sources */, + 69E357B020F88955002E163B /* AudioIO.cpp in Sources */, + 697E9D3221A4ED6D00E03846 /* downsampled_render_buffer.cc in Sources */, + 69E629EE21AF62A900377D0F /* json11.cpp in Sources */, + 697E9D6B21A4ED6E00E03846 /* ooura_fft_sse2.cc in Sources */, + 69719A7E224A627F00FE9B2A /* VideoPacketSender.cpp in Sources */, + 697E9C6421A4ED6C00E03846 /* adaptive_digital_gain_applier.cc in Sources */, + 697E9C9421A4ED6D00E03846 /* noise_spectrum_estimator.cc in Sources */, + 697E9BCF21A4ED6C00E03846 /* thread_checker_impl.cc in Sources */, + 697E9D6321A4ED6E00E03846 /* gmm.cc in Sources */, + 697E9CAA21A4ED6D00E03846 /* level_estimator_impl.cc in Sources */, + 697E9D3021A4ED6D00E03846 /* echo_remover.cc in Sources */, + 69F791582222AC2800FE53C4 /* SampleBufferDisplayLayerRenderer.mm in Sources */, + 697E9C8721A4ED6C00E03846 /* vad_with_level.cc in Sources */, + 697E9B3721A4ED6B00E03846 /* fir_filter_neon.cc in Sources */, + 697E9C4621A4ED6C00E03846 /* noise_suppression.c in Sources */, + 697E9C2E21A4ED6C00E03846 /* rms_level.cc in Sources */, + 697E9B6821A4ED6B00E03846 /* spl_init.c in Sources */, + 697E9B7721A4ED6B00E03846 /* min_max_operations.c in Sources */, + 697E9D2E21A4ED6D00E03846 /* suppression_gain_limiter.cc in Sources */, + 697E9C8221A4ED6C00E03846 /* noise_level_estimator.cc in Sources */, + 697E9B8121A4ED6B00E03846 /* copy_set_operations.c in Sources */, + 697E9B6021A4ED6B00E03846 /* dot_product_with_scale.cc in Sources */, + 697E9B5D21A4ED6B00E03846 /* splitting_filter1.c in Sources */, + 697E9C3C21A4ED6C00E03846 /* nsx_core.c in Sources */, + 697E9C3221A4ED6C00E03846 /* normalized_covariance_estimator.cc in Sources */, + 697E9B5F21A4ED6B00E03846 /* downsample_fast_neon.c in Sources */, + 697E9D2321A4ED6D00E03846 /* aec3_common.cc in Sources */, + 697E9D1121A4ED6D00E03846 /* render_buffer.cc in Sources */, + 697E9B7B21A4ED6B00E03846 /* resample_fractional.c in Sources */, + 697E9D3421A4ED6D00E03846 /* matrix_buffer.cc in Sources */, + 697E9C8421A4ED6C00E03846 /* fixed_digital_level_estimator.cc in Sources */, + 697E9BFF21A4ED6C00E03846 /* pitch_gain_tables.c in Sources */, + 697E9CA621A4ED6D00E03846 /* transient_detector.cc in Sources */, + 697E9D1421A4ED6D00E03846 /* stationarity_estimator.cc in Sources */, + 697E9C2421A4ED6C00E03846 /* crc.c in Sources */, + 697E9BC321A4ED6B00E03846 /* timeutils.cc in Sources */, + 697E9B9621A4ED6B00E03846 /* string_view.cc in Sources */, + 692AB8FD1E6759DD00706ACC /* AudioUnitIO.cpp in Sources */, + 697E9D0C21A4ED6D00E03846 /* block_framer.cc in Sources */, + 697E9B6A21A4ED6B00E03846 /* cross_correlation.c in Sources */, + 697E9D0921A4ED6D00E03846 /* echo_path_delay_estimator.cc in Sources */, + 69986177209526D400B68BEC /* Buffers.cpp in Sources */, + 697E9B2C21A4ED6B00E03846 /* window_generator.cc in Sources */, + 697E9C0F21A4ED6C00E03846 /* intialize.c in Sources */, + 692AB8CD1E6759DD00706ACC /* AudioOutput.cpp in Sources */, + 697E9CC221A4ED6D00E03846 /* utility.cc in Sources */, + 697E9B4621A4ED6B00E03846 /* sinc_resampler.cc in Sources */, + 697E9B7021A4ED6B00E03846 /* auto_correlation.c in Sources */, + 697E9B7121A4ED6B00E03846 /* get_scaling_square.c in Sources */, + 697E9D5221A4ED6D00E03846 /* voice_activity_detector.cc in Sources */, + 697E9D2221A4ED6D00E03846 /* reverb_model_estimator.cc in Sources */, + 697E9BA621A4ED6B00E03846 /* throw_delegate.cc in Sources */, + 697E9D6821A4ED6E00E03846 /* ooura_fft.cc in Sources */, + 697E9B7F21A4ED6B00E03846 /* randomization_functions.c in Sources */, + 697E9CE521A4ED6D00E03846 /* echo_remover_metrics.cc in Sources */, + 697E9CBA21A4ED6D00E03846 /* agc.cc in Sources */, + 697E9C9B21A4ED6D00E03846 /* moving_moments.cc in Sources */, + 697E9D7321A4ED6E00E03846 /* rnn_vad_weights.cc in Sources */, + 697E9C5421A4ED6C00E03846 /* audio_generator_factory.cc in Sources */, + 697E9CC121A4ED6D00E03846 /* digital_agc.c in Sources */, + 697E9B2D21A4ED6B00E03846 /* channel_buffer.cc in Sources */, + 697E9BB621A4ED6B00E03846 /* echo_canceller3_config.cc in Sources */, + 692AB8ED1E6759DD00706ACC /* OpusEncoder.cpp in Sources */, + 697E9B7E21A4ED6B00E03846 /* complex_bit_reverse.c in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin XCBuildConfiguration section */ + 69F8423C1E67540700C110F7 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = Debug; + }; + 69F8423D1E67540700C110F7 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VALIDATE_PRODUCT = YES; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = Release; + }; + 69F8423F1E67540700C110F7 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(PROJECT_DIR)/../../Telegraph/thirdparty/opus/include/opus", + "$(inherited)", + "$(PROJECT_DIR)/../../Telegraph", + webrtc_dsp, + "$(PROJECT_DIR)/../TelegramUI/third-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.6; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DWEBRTC_POSIX", + "-DTGVOIP_HAVE_TGLOG", + "-DWEBRTC_NS_FLOAT", + "-DWEBRTC_IOS", + "-DWEBRTC_HAS_NEON", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + }; + name = Debug; + }; + 69F842401E67540700C110F7 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(PROJECT_DIR)/../../Telegraph/thirdparty/opus/include/opus", + "$(inherited)", + "$(PROJECT_DIR)/../../Telegraph", + webrtc_dsp, + "$(PROJECT_DIR)/../TelegramUI/third-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.6; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DWEBRTC_POSIX", + "-DTGVOIP_HAVE_TGLOG", + "-DWEBRTC_NS_FLOAT", + "-DWEBRTC_IOS", + "-DWEBRTC_HAS_NEON", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + }; + name = Release; + }; + D00ACA51202234510045D427 /* DebugHockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = DebugHockeyapp; + }; + D00ACA52202234510045D427 /* DebugHockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(PROJECT_DIR)/../../Telegraph/thirdparty/opus/include/opus", + "$(inherited)", + "$(PROJECT_DIR)/../../Telegraph", + webrtc_dsp, + "$(PROJECT_DIR)/../TelegramUI/third-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.6; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DWEBRTC_POSIX", + "-DTGVOIP_HAVE_TGLOG", + "-DWEBRTC_NS_FLOAT", + "-DWEBRTC_IOS", + "-DWEBRTC_HAS_NEON", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + }; + name = DebugHockeyapp; + }; + D00ACA532022347C0045D427 /* ReleaseHockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VALIDATE_PRODUCT = YES; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = ReleaseHockeyapp; + }; + D00ACA542022347C0045D427 /* ReleaseHockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(PROJECT_DIR)/../../Telegraph/thirdparty/opus/include/opus", + "$(inherited)", + "$(PROJECT_DIR)/../../Telegraph", + webrtc_dsp, + "$(PROJECT_DIR)/../TelegramUI/third-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.6; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DWEBRTC_POSIX", + "-DTGVOIP_HAVE_TGLOG", + "-DWEBRTC_NS_FLOAT", + "-DWEBRTC_IOS", + "-DWEBRTC_HAS_NEON", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + }; + name = ReleaseHockeyapp; + }; + D00ACA55202234840045D427 /* ReleaseHockeyappInternal */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VALIDATE_PRODUCT = YES; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = ReleaseHockeyappInternal; + }; + D00ACA56202234840045D427 /* ReleaseHockeyappInternal */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(PROJECT_DIR)/../../Telegraph/thirdparty/opus/include/opus", + "$(inherited)", + "$(PROJECT_DIR)/../../Telegraph", + webrtc_dsp, + "$(PROJECT_DIR)/../TelegramUI/third-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.6; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DWEBRTC_POSIX", + "-DTGVOIP_HAVE_TGLOG", + "-DWEBRTC_NS_FLOAT", + "-DWEBRTC_IOS", + "-DWEBRTC_HAS_NEON", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + }; + name = ReleaseHockeyappInternal; + }; + D00ACA5B2022A70D0045D427 /* ReleaseAppStore */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VALIDATE_PRODUCT = YES; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = ReleaseAppStore; + }; + D00ACA5C2022A70D0045D427 /* ReleaseAppStore */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(PROJECT_DIR)/../../Telegraph/thirdparty/opus/include/opus", + "$(inherited)", + "$(PROJECT_DIR)/../../Telegraph", + webrtc_dsp, + "$(PROJECT_DIR)/../TelegramUI/third-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.6; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DWEBRTC_POSIX", + "-DTGVOIP_HAVE_TGLOG", + "-DWEBRTC_NS_FLOAT", + "-DWEBRTC_IOS", + "-DWEBRTC_HAS_NEON", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + }; + name = ReleaseAppStore; + }; + D021D50E219CB21A0064BEBA /* DebugFork */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = DebugFork; + }; + D021D50F219CB21A0064BEBA /* DebugFork */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(PROJECT_DIR)/../../Telegraph/thirdparty/opus/include/opus", + "$(inherited)", + "$(PROJECT_DIR)/../../Telegraph", + webrtc_dsp, + "$(PROJECT_DIR)/../TelegramUI/third-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.6; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DWEBRTC_POSIX", + "-DTGVOIP_HAVE_TGLOG", + "-DWEBRTC_NS_FLOAT", + "-DWEBRTC_IOS", + "-DWEBRTC_HAS_NEON", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + }; + name = DebugFork; + }; + D04D01C31E678C0D0086DDC0 /* DebugAppStore */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = DebugAppStore; + }; + D04D01C41E678C0D0086DDC0 /* DebugAppStore */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(PROJECT_DIR)/../../Telegraph/thirdparty/opus/include/opus", + "$(inherited)", + "$(PROJECT_DIR)/../../Telegraph", + webrtc_dsp, + "$(PROJECT_DIR)/../TelegramUI/third-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.6; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DWEBRTC_POSIX", + "-DTGVOIP_HAVE_TGLOG", + "-DWEBRTC_NS_FLOAT", + "-DWEBRTC_IOS", + "-DWEBRTC_HAS_NEON", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + }; + name = DebugAppStore; + }; + D04D01CB1E678C230086DDC0 /* Hockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VALIDATE_PRODUCT = YES; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = Hockeyapp; + }; + D04D01CC1E678C230086DDC0 /* Hockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(PROJECT_DIR)/../../Telegraph/thirdparty/opus/include/opus", + "$(inherited)", + "$(PROJECT_DIR)/../../Telegraph", + webrtc_dsp, + "$(PROJECT_DIR)/../TelegramUI/third-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.6; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DWEBRTC_POSIX", + "-DTGVOIP_HAVE_TGLOG", + "-DWEBRTC_NS_FLOAT", + "-DWEBRTC_IOS", + "-DWEBRTC_HAS_NEON", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + }; + name = Hockeyapp; + }; + D077B8DF1F45EA870046D27A /* Release Hockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VALIDATE_PRODUCT = YES; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = "Release Hockeyapp"; + }; + D077B8E01F45EA870046D27A /* Release Hockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(PROJECT_DIR)/../../Telegraph/thirdparty/opus/include/opus", + "$(inherited)", + "$(PROJECT_DIR)/../../Telegraph", + webrtc_dsp, + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.6; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DWEBRTC_POSIX", + "-DTGVOIP_HAVE_TGLOG", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + }; + name = "Release Hockeyapp"; + }; + D0ADF946212B3AF400310BBC /* DebugAppStoreLLC */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = DebugAppStoreLLC; + }; + D0ADF947212B3AF400310BBC /* DebugAppStoreLLC */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(PROJECT_DIR)/../../Telegraph/thirdparty/opus/include/opus", + "$(inherited)", + "$(PROJECT_DIR)/../../Telegraph", + webrtc_dsp, + "$(PROJECT_DIR)/../TelegramUI/third-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.6; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DWEBRTC_POSIX", + "-DTGVOIP_HAVE_TGLOG", + "-DWEBRTC_NS_FLOAT", + "-DWEBRTC_IOS", + "-DWEBRTC_HAS_NEON", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + }; + name = DebugAppStoreLLC; + }; + D0CE6F00213DC31900BCD44B /* ReleaseAppStoreLLC */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VALIDATE_PRODUCT = YES; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = ReleaseAppStoreLLC; + }; + D0CE6F01213DC31900BCD44B /* ReleaseAppStoreLLC */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(PROJECT_DIR)/../../Telegraph/thirdparty/opus/include/opus", + "$(inherited)", + "$(PROJECT_DIR)/../../Telegraph", + webrtc_dsp, + "$(PROJECT_DIR)/../TelegramUI/third-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.6; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DWEBRTC_POSIX", + "-DTGVOIP_HAVE_TGLOG", + "-DWEBRTC_NS_FLOAT", + "-DWEBRTC_IOS", + "-DWEBRTC_HAS_NEON", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SKIP_INSTALL = YES; + }; + name = ReleaseAppStoreLLC; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 69F842301E67540700C110F7 /* Build configuration list for PBXProject "libtgvoip" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 69F8423C1E67540700C110F7 /* Debug */, + D00ACA51202234510045D427 /* DebugHockeyapp */, + D021D50E219CB21A0064BEBA /* DebugFork */, + D04D01C31E678C0D0086DDC0 /* DebugAppStore */, + D0ADF946212B3AF400310BBC /* DebugAppStoreLLC */, + 69F8423D1E67540700C110F7 /* Release */, + D00ACA5B2022A70D0045D427 /* ReleaseAppStore */, + D0CE6F00213DC31900BCD44B /* ReleaseAppStoreLLC */, + D00ACA532022347C0045D427 /* ReleaseHockeyapp */, + D00ACA55202234840045D427 /* ReleaseHockeyappInternal */, + D04D01CB1E678C230086DDC0 /* Hockeyapp */, + D077B8DF1F45EA870046D27A /* Release Hockeyapp */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 69F8423E1E67540700C110F7 /* Build configuration list for PBXNativeTarget "libtgvoip" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 69F8423F1E67540700C110F7 /* Debug */, + D00ACA52202234510045D427 /* DebugHockeyapp */, + D021D50F219CB21A0064BEBA /* DebugFork */, + D04D01C41E678C0D0086DDC0 /* DebugAppStore */, + D0ADF947212B3AF400310BBC /* DebugAppStoreLLC */, + 69F842401E67540700C110F7 /* Release */, + D00ACA5C2022A70D0045D427 /* ReleaseAppStore */, + D0CE6F01213DC31900BCD44B /* ReleaseAppStoreLLC */, + D00ACA542022347C0045D427 /* ReleaseHockeyapp */, + D00ACA56202234840045D427 /* ReleaseHockeyappInternal */, + D04D01CC1E678C230086DDC0 /* Hockeyapp */, + D077B8E01F45EA870046D27A /* Release Hockeyapp */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = 69F8422D1E67540700C110F7 /* Project object */; +} diff --git a/TMessagesProj/jni/libtgvoip2/libtgvoip.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/TMessagesProj/jni/libtgvoip2/libtgvoip.xcodeproj/project.xcworkspace/contents.xcworkspacedata new file mode 100644 index 000000000..55fe87423 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/libtgvoip.xcodeproj/project.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,7 @@ + + + + + diff --git a/TMessagesProj/jni/libtgvoip2/libtgvoip.xcodeproj/xcshareddata/IDETemplateMacros.plist b/TMessagesProj/jni/libtgvoip2/libtgvoip.xcodeproj/xcshareddata/IDETemplateMacros.plist new file mode 100644 index 000000000..7e0b977c2 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/libtgvoip.xcodeproj/xcshareddata/IDETemplateMacros.plist @@ -0,0 +1,12 @@ + + + + + FILEHEADER + +libtgvoip is free and unencumbered public domain software. +For more information, see http://unlicense.org or the UNLICENSE file +you should have received with this source code distribution. + + + diff --git a/TMessagesProj/jni/libtgvoip2/libtgvoip_osx.xcodeproj/project.pbxproj b/TMessagesProj/jni/libtgvoip2/libtgvoip_osx.xcodeproj/project.pbxproj new file mode 100644 index 000000000..f4e1fa899 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/libtgvoip_osx.xcodeproj/project.pbxproj @@ -0,0 +1,4144 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 46; + objects = { + +/* Begin PBXBuildFile section */ + 690725BE1EBBD5DE005D860B /* NetworkSocketPosix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 690725BC1EBBD5DE005D860B /* NetworkSocketPosix.cpp */; }; + 690725C21EBBD5F2005D860B /* NetworkSocket.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 690725C01EBBD5F2005D860B /* NetworkSocket.cpp */; }; + 6915307B1E6B5BAB004F643F /* logging.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6915307A1E6B5BAB004F643F /* logging.cpp */; }; + 691E05C921A4FD7600F838EF /* memutil.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E033321A4FD7500F838EF /* memutil.cc */; }; + 691E05CA21A4FD7600F838EF /* string_view.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E033421A4FD7500F838EF /* string_view.cc */; }; + 691E05CC21A4FD7600F838EF /* ascii.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E033621A4FD7500F838EF /* ascii.cc */; }; + 691E05D021A4FD7600F838EF /* bad_optional_access.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E033B21A4FD7500F838EF /* bad_optional_access.cc */; }; + 691E05D121A4FD7600F838EF /* optional.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E033C21A4FD7500F838EF /* optional.cc */; }; + 691E05D921A4FD7600F838EF /* raw_logging.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E034A21A4FD7500F838EF /* raw_logging.cc */; }; + 691E05DA21A4FD7600F838EF /* throw_delegate.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E034B21A4FD7500F838EF /* throw_delegate.cc */; }; + 691E05E821A4FD7600F838EF /* window_generator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E035C21A4FD7500F838EF /* window_generator.cc */; }; + 691E05E921A4FD7600F838EF /* channel_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E035D21A4FD7500F838EF /* channel_buffer.cc */; }; + 691E05EA21A4FD7600F838EF /* fir_filter_factory.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E035E21A4FD7500F838EF /* fir_filter_factory.cc */; }; + 691E05F121A4FD7600F838EF /* wav_header.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E036621A4FD7500F838EF /* wav_header.cc */; }; + 691E05F221A4FD7600F838EF /* real_fourier_ooura.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E036721A4FD7500F838EF /* real_fourier_ooura.cc */; }; + 691E05F321A4FD7600F838EF /* fir_filter_neon.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E036821A4FD7500F838EF /* fir_filter_neon.cc */; }; + 691E05F421A4FD7600F838EF /* audio_util.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E036921A4FD7500F838EF /* audio_util.cc */; }; + 691E05F621A4FD7600F838EF /* fir_filter_sse.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E036B21A4FD7500F838EF /* fir_filter_sse.cc */; }; + 691E05F821A4FD7600F838EF /* sinc_resampler_neon.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E036E21A4FD7500F838EF /* sinc_resampler_neon.cc */; }; + 691E05F921A4FD7600F838EF /* push_sinc_resampler.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E036F21A4FD7500F838EF /* push_sinc_resampler.cc */; }; + 691E05FB21A4FD7600F838EF /* resampler.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E037121A4FD7500F838EF /* resampler.cc */; }; + 691E05FC21A4FD7600F838EF /* sinc_resampler_sse.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E037221A4FD7500F838EF /* sinc_resampler_sse.cc */; }; + 691E060021A4FD7600F838EF /* push_resampler.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E037721A4FD7500F838EF /* push_resampler.cc */; }; + 691E060221A4FD7600F838EF /* sinc_resampler.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E037921A4FD7500F838EF /* sinc_resampler.cc */; }; + 691E060321A4FD7600F838EF /* sinusoidal_linear_chirp_source.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E037A21A4FD7500F838EF /* sinusoidal_linear_chirp_source.cc */; }; + 691E060621A4FD7600F838EF /* wav_file.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E037D21A4FD7500F838EF /* wav_file.cc */; }; + 691E060721A4FD7600F838EF /* spl_sqrt_floor.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E038021A4FD7500F838EF /* spl_sqrt_floor.c */; }; + 691E060A21A4FD7600F838EF /* fft4g.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E038421A4FD7500F838EF /* fft4g.c */; }; + 691E060C21A4FD7600F838EF /* audio_converter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E038621A4FD7500F838EF /* audio_converter.cc */; }; + 691E060D21A4FD7600F838EF /* real_fourier.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E038721A4FD7500F838EF /* real_fourier.cc */; }; + 691E061021A4FD7600F838EF /* sparse_fir_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E038A21A4FD7500F838EF /* sparse_fir_filter.cc */; }; + 691E061221A4FD7600F838EF /* smoothing_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E038C21A4FD7500F838EF /* smoothing_filter.cc */; }; + 691E061321A4FD7600F838EF /* fir_filter_c.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E038D21A4FD7500F838EF /* fir_filter_c.cc */; }; + 691E061421A4FD7600F838EF /* ring_buffer.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E038E21A4FD7500F838EF /* ring_buffer.c */; }; + 691E061721A4FD7600F838EF /* complex_fft.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E039221A4FD7500F838EF /* complex_fft.c */; }; + 691E061821A4FD7600F838EF /* filter_ma_fast_q12.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E039321A4FD7500F838EF /* filter_ma_fast_q12.c */; }; + 691E061921A4FD7600F838EF /* splitting_filter1.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E039421A4FD7500F838EF /* splitting_filter1.c */; }; + 691E061A21A4FD7600F838EF /* levinson_durbin.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E039521A4FD7500F838EF /* levinson_durbin.c */; }; + 691E061B21A4FD7600F838EF /* downsample_fast_neon.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E039621A4FD7500F838EF /* downsample_fast_neon.c */; }; + 691E061C21A4FD7600F838EF /* dot_product_with_scale.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E039721A4FD7500F838EF /* dot_product_with_scale.cc */; }; + 691E061D21A4FD7600F838EF /* auto_corr_to_refl_coef.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E039821A4FD7500F838EF /* auto_corr_to_refl_coef.c */; }; + 691E061E21A4FD7600F838EF /* resample_by_2_internal.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E039921A4FD7500F838EF /* resample_by_2_internal.c */; }; + 691E062021A4FD7600F838EF /* energy.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E039B21A4FD7500F838EF /* energy.c */; }; + 691E062121A4FD7600F838EF /* sqrt_of_one_minus_x_squared.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E039C21A4FD7500F838EF /* sqrt_of_one_minus_x_squared.c */; }; + 691E062221A4FD7600F838EF /* downsample_fast.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E039D21A4FD7500F838EF /* downsample_fast.c */; }; + 691E062321A4FD7600F838EF /* filter_ar_fast_q12.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E039E21A4FD7500F838EF /* filter_ar_fast_q12.c */; }; + 691E062421A4FD7600F838EF /* spl_init.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E039F21A4FD7500F838EF /* spl_init.c */; }; + 691E062521A4FD7600F838EF /* lpc_to_refl_coef.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03A021A4FD7500F838EF /* lpc_to_refl_coef.c */; }; + 691E062621A4FD7600F838EF /* cross_correlation.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03A121A4FD7500F838EF /* cross_correlation.c */; }; + 691E062B21A4FD7600F838EF /* division_operations.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03A721A4FD7500F838EF /* division_operations.c */; }; + 691E062C21A4FD7600F838EF /* auto_correlation.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03A821A4FD7500F838EF /* auto_correlation.c */; }; + 691E062D21A4FD7600F838EF /* get_scaling_square.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03A921A4FD7500F838EF /* get_scaling_square.c */; }; + 691E062E21A4FD7600F838EF /* min_max_operations_neon.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03AA21A4FD7500F838EF /* min_max_operations_neon.c */; }; + 691E063121A4FD7600F838EF /* resample.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03AD21A4FD7500F838EF /* resample.c */; }; + 691E063221A4FD7600F838EF /* cross_correlation_neon.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03AE21A4FD7500F838EF /* cross_correlation_neon.c */; }; + 691E063321A4FD7600F838EF /* min_max_operations.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03AF21A4FD7500F838EF /* min_max_operations.c */; }; + 691E063421A4FD7600F838EF /* refl_coef_to_lpc.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03B021A4FD7500F838EF /* refl_coef_to_lpc.c */; }; + 691E063521A4FD7600F838EF /* filter_ar.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03B121A4FD7500F838EF /* filter_ar.c */; }; + 691E063621A4FD7600F838EF /* vector_scaling_operations.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03B221A4FD7500F838EF /* vector_scaling_operations.c */; }; + 691E063721A4FD7600F838EF /* resample_fractional.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03B321A4FD7500F838EF /* resample_fractional.c */; }; + 691E063821A4FD7600F838EF /* real_fft.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03B421A4FD7500F838EF /* real_fft.c */; }; + 691E063921A4FD7600F838EF /* ilbc_specific_functions.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03B521A4FD7500F838EF /* ilbc_specific_functions.c */; }; + 691E063A21A4FD7600F838EF /* complex_bit_reverse.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03B621A4FD7500F838EF /* complex_bit_reverse.c */; }; + 691E063B21A4FD7600F838EF /* randomization_functions.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03B721A4FD7500F838EF /* randomization_functions.c */; }; + 691E063D21A4FD7600F838EF /* copy_set_operations.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03B921A4FD7500F838EF /* copy_set_operations.c */; }; + 691E063E21A4FD7600F838EF /* resample_by_2.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03BA21A4FD7500F838EF /* resample_by_2.c */; }; + 691E063F21A4FD7600F838EF /* get_hanning_window.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03BB21A4FD7500F838EF /* get_hanning_window.c */; }; + 691E064021A4FD7600F838EF /* resample_48khz.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03BC21A4FD7500F838EF /* resample_48khz.c */; }; + 691E064121A4FD7600F838EF /* spl_inl.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03BD21A4FD7500F838EF /* spl_inl.c */; }; + 691E064221A4FD7600F838EF /* spl_sqrt.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03BE21A4FD7500F838EF /* spl_sqrt.c */; }; + 691E064421A4FD7600F838EF /* vad_sp.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03C121A4FD7500F838EF /* vad_sp.c */; }; + 691E064521A4FD7600F838EF /* vad.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E03C221A4FD7500F838EF /* vad.cc */; }; + 691E064621A4FD7600F838EF /* webrtc_vad.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03C321A4FD7500F838EF /* webrtc_vad.c */; }; + 691E064B21A4FD7600F838EF /* vad_filterbank.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03C921A4FD7500F838EF /* vad_filterbank.c */; }; + 691E064C21A4FD7600F838EF /* vad_core.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03CA21A4FD7500F838EF /* vad_core.c */; }; + 691E064F21A4FD7600F838EF /* vad_gmm.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03CD21A4FD7500F838EF /* vad_gmm.c */; }; + 691E065021A4FD7600F838EF /* audio_frame.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E03D021A4FD7500F838EF /* audio_frame.cc */; }; + 691E065421A4FD7600F838EF /* echo_canceller3_config.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E03D421A4FD7500F838EF /* echo_canceller3_config.cc */; }; + 691E065621A4FD7600F838EF /* echo_canceller3_factory.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E03D621A4FD7500F838EF /* echo_canceller3_factory.cc */; }; + 691E065821A4FD7600F838EF /* rnn_vad_weights.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E03DB21A4FD7500F838EF /* rnn_vad_weights.cc */; }; + 691E065B21A4FD7600F838EF /* kiss_fft.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E03DE21A4FD7500F838EF /* kiss_fft.cc */; }; + 691E066221A4FD7600F838EF /* field_trial.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E03E821A4FD7500F838EF /* field_trial.cc */; }; + 691E066321A4FD7600F838EF /* metrics.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E03E921A4FD7500F838EF /* metrics.cc */; }; + 691E066421A4FD7600F838EF /* cpu_features.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E03EA21A4FD7500F838EF /* cpu_features.cc */; }; + 691E066621A4FD7600F838EF /* fft.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03EF21A4FD7500F838EF /* fft.c */; }; + 691E066921A4FD7600F838EF /* pitch_estimator.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03F821A4FD7500F838EF /* pitch_estimator.c */; }; + 691E066A21A4FD7600F838EF /* lpc_shape_swb16_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03F921A4FD7500F838EF /* lpc_shape_swb16_tables.c */; }; + 691E066B21A4FD7600F838EF /* pitch_gain_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03FA21A4FD7500F838EF /* pitch_gain_tables.c */; }; + 691E066C21A4FD7600F838EF /* arith_routines_logist.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03FB21A4FD7500F838EF /* arith_routines_logist.c */; }; + 691E066E21A4FD7600F838EF /* filterbanks.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E03FD21A4FD7500F838EF /* filterbanks.c */; }; + 691E067221A4FD7600F838EF /* transform.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E040121A4FD7500F838EF /* transform.c */; }; + 691E067621A4FD7600F838EF /* pitch_filter.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E040521A4FD7500F838EF /* pitch_filter.c */; }; + 691E067721A4FD7600F838EF /* encode_lpc_swb.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E040621A4FD7500F838EF /* encode_lpc_swb.c */; }; + 691E067821A4FD7600F838EF /* filter_functions.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E040721A4FD7500F838EF /* filter_functions.c */; }; + 691E067921A4FD7600F838EF /* decode.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E040821A4FD7500F838EF /* decode.c */; }; + 691E067A21A4FD7600F838EF /* lattice.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E040921A4FD7500F838EF /* lattice.c */; }; + 691E067B21A4FD7600F838EF /* intialize.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E040A21A4FD7500F838EF /* intialize.c */; }; + 691E067C21A4FD7600F838EF /* lpc_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E040B21A4FD7500F838EF /* lpc_tables.c */; }; + 691E067D21A4FD7600F838EF /* lpc_gain_swb_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E040C21A4FD7500F838EF /* lpc_gain_swb_tables.c */; }; + 691E067E21A4FD7600F838EF /* bandwidth_estimator.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E040D21A4FD7500F838EF /* bandwidth_estimator.c */; }; + 691E068121A4FD7600F838EF /* encode.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E041021A4FD7500F838EF /* encode.c */; }; + 691E068221A4FD7600F838EF /* lpc_analysis.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E041121A4FD7500F838EF /* lpc_analysis.c */; }; + 691E068421A4FD7600F838EF /* arith_routines_hist.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E041321A4FD7500F838EF /* arith_routines_hist.c */; }; + 691E068921A4FD7600F838EF /* entropy_coding.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E041821A4FD7500F838EF /* entropy_coding.c */; }; + 691E068A21A4FD7600F838EF /* isac_vad.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E041921A4FD7500F838EF /* isac_vad.c */; }; + 691E068F21A4FD7600F838EF /* arith_routines.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E041E21A4FD7500F838EF /* arith_routines.c */; }; + 691E069021A4FD7600F838EF /* crc.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E041F21A4FD7500F838EF /* crc.c */; }; + 691E069121A4FD7600F838EF /* lpc_shape_swb12_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E042021A4FD7500F838EF /* lpc_shape_swb12_tables.c */; }; + 691E069321A4FD7600F838EF /* decode_bwe.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E042221A4FD7500F838EF /* decode_bwe.c */; }; + 691E069421A4FD7600F838EF /* spectrum_ar_model_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E042321A4FD7500F838EF /* spectrum_ar_model_tables.c */; }; + 691E069621A4FD7600F838EF /* pitch_lag_tables.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E042521A4FD7500F838EF /* pitch_lag_tables.c */; }; + 691E069721A4FD7600F838EF /* isac.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E042621A4FD7500F838EF /* isac.c */; }; + 691E069A21A4FD7600F838EF /* rms_level.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E042A21A4FD7500F838EF /* rms_level.cc */; }; + 691E069E21A4FD7600F838EF /* normalized_covariance_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E042F21A4FD7600F838EF /* normalized_covariance_estimator.cc */; }; + 691E069F21A4FD7600F838EF /* moving_max.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E043021A4FD7600F838EF /* moving_max.cc */; }; + 691E06A021A4FD7600F838EF /* circular_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E043121A4FD7600F838EF /* circular_buffer.cc */; }; + 691E06A121A4FD7600F838EF /* mean_variance_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E043221A4FD7600F838EF /* mean_variance_estimator.cc */; }; + 691E06A421A4FD7600F838EF /* splitting_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E043521A4FD7600F838EF /* splitting_filter.cc */; }; + 691E06A521A4FD7600F838EF /* gain_control_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E043621A4FD7600F838EF /* gain_control_impl.cc */; }; + 691E06A821A4FD7600F838EF /* nsx_core.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E043E21A4FD7600F838EF /* nsx_core.c */; }; + 691E06A921A4FD7600F838EF /* noise_suppression_x.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E043F21A4FD7600F838EF /* noise_suppression_x.c */; }; + 691E06AA21A4FD7600F838EF /* nsx_core_c.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E044021A4FD7600F838EF /* nsx_core_c.c */; }; + 691E06AD21A4FD7600F838EF /* ns_core.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E044321A4FD7600F838EF /* ns_core.c */; }; + 691E06B121A4FD7600F838EF /* nsx_core_neon.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E044721A4FD7600F838EF /* nsx_core_neon.c */; }; + 691E06B221A4FD7600F838EF /* noise_suppression.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E044821A4FD7600F838EF /* noise_suppression.c */; }; + 691E06B621A4FD7600F838EF /* audio_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E044C21A4FD7600F838EF /* audio_buffer.cc */; }; + 691E06B721A4FD7600F838EF /* typing_detection.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E044D21A4FD7600F838EF /* typing_detection.cc */; }; + 691E06BF21A4FD7600F838EF /* audio_processing_statistics.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E045721A4FD7600F838EF /* audio_processing_statistics.cc */; }; + 691E06C021A4FD7600F838EF /* audio_generator_factory.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E045821A4FD7600F838EF /* audio_generator_factory.cc */; }; + 691E06C121A4FD7600F838EF /* aec_dump.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E045921A4FD7600F838EF /* aec_dump.cc */; }; + 691E06C521A4FD7600F838EF /* audio_processing.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E045D21A4FD7600F838EF /* audio_processing.cc */; }; + 691E06C621A4FD7600F838EF /* config.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E045E21A4FD7600F838EF /* config.cc */; }; + 691E06C921A4FD7600F838EF /* interpolated_gain_curve.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E046221A4FD7600F838EF /* interpolated_gain_curve.cc */; }; + 691E06CA21A4FD7600F838EF /* agc2_common.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E046321A4FD7600F838EF /* agc2_common.cc */; }; + 691E06CD21A4FD7600F838EF /* gain_applier.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E046621A4FD7600F838EF /* gain_applier.cc */; }; + 691E06CF21A4FD7600F838EF /* adaptive_agc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E046821A4FD7600F838EF /* adaptive_agc.cc */; }; + 691E06D021A4FD7600F838EF /* adaptive_digital_gain_applier.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E046921A4FD7600F838EF /* adaptive_digital_gain_applier.cc */; }; + 691E06D121A4FD7600F838EF /* limiter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E046A21A4FD7600F838EF /* limiter.cc */; }; + 691E06D221A4FD7600F838EF /* saturation_protector.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E046B21A4FD7600F838EF /* saturation_protector.cc */; }; + 691E06D421A4FD7600F838EF /* spectral_features_internal.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E046E21A4FD7600F838EF /* spectral_features_internal.cc */; }; + 691E06D721A4FD7600F838EF /* rnn.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E047121A4FD7600F838EF /* rnn.cc */; }; + 691E06DC21A4FD7600F838EF /* pitch_search_internal.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E047621A4FD7600F838EF /* pitch_search_internal.cc */; }; + 691E06E321A4FD7600F838EF /* spectral_features.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E047D21A4FD7600F838EF /* spectral_features.cc */; }; + 691E06E521A4FD7600F838EF /* pitch_search.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E047F21A4FD7600F838EF /* pitch_search.cc */; }; + 691E06E721A4FD7600F838EF /* features_extraction.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E048121A4FD7600F838EF /* features_extraction.cc */; }; + 691E06E821A4FD7600F838EF /* fft_util.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E048221A4FD7600F838EF /* fft_util.cc */; }; + 691E06E921A4FD7600F838EF /* lp_residual.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E048321A4FD7600F838EF /* lp_residual.cc */; }; + 691E06EB21A4FD7600F838EF /* adaptive_mode_level_estimator_agc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E048521A4FD7600F838EF /* adaptive_mode_level_estimator_agc.cc */; }; + 691E06EC21A4FD7600F838EF /* vector_float_frame.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E048621A4FD7600F838EF /* vector_float_frame.cc */; }; + 691E06EE21A4FD7600F838EF /* noise_level_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E048821A4FD7600F838EF /* noise_level_estimator.cc */; }; + 691E06EF21A4FD7600F838EF /* agc2_testing_common.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E048921A4FD7600F838EF /* agc2_testing_common.cc */; }; + 691E06F021A4FD7600F838EF /* fixed_digital_level_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E048A21A4FD7600F838EF /* fixed_digital_level_estimator.cc */; }; + 691E06F121A4FD7600F838EF /* fixed_gain_controller.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E048B21A4FD7600F838EF /* fixed_gain_controller.cc */; }; + 691E06F321A4FD7600F838EF /* vad_with_level.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E048D21A4FD7600F838EF /* vad_with_level.cc */; }; + 691E06F421A4FD7600F838EF /* limiter_db_gain_curve.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E048E21A4FD7600F838EF /* limiter_db_gain_curve.cc */; }; + 691E06FD21A4FD7600F838EF /* down_sampler.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E049721A4FD7600F838EF /* down_sampler.cc */; }; + 691E06FF21A4FD7600F838EF /* signal_classifier.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E049921A4FD7600F838EF /* signal_classifier.cc */; }; + 691E070021A4FD7600F838EF /* noise_spectrum_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E049A21A4FD7600F838EF /* noise_spectrum_estimator.cc */; }; + 691E070121A4FD7600F838EF /* compute_interpolated_gain_curve.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E049B21A4FD7600F838EF /* compute_interpolated_gain_curve.cc */; }; + 691E070321A4FD7600F838EF /* biquad_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E049D21A4FD7600F838EF /* biquad_filter.cc */; }; + 691E070621A4FD7700F838EF /* adaptive_mode_level_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04A021A4FD7600F838EF /* adaptive_mode_level_estimator.cc */; }; + 691E070721A4FD7700F838EF /* moving_moments.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04A221A4FD7600F838EF /* moving_moments.cc */; }; + 691E070921A4FD7700F838EF /* wpd_tree.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04A421A4FD7600F838EF /* wpd_tree.cc */; }; + 691E071021A4FD7700F838EF /* wpd_node.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04AB21A4FD7600F838EF /* wpd_node.cc */; }; + 691E071121A4FD7700F838EF /* transient_suppressor.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04AC21A4FD7600F838EF /* transient_suppressor.cc */; }; + 691E071221A4FD7700F838EF /* transient_detector.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04AD21A4FD7600F838EF /* transient_detector.cc */; }; + 691E071421A4FD7700F838EF /* low_cut_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04AF21A4FD7600F838EF /* low_cut_filter.cc */; }; + 691E071621A4FD7700F838EF /* level_estimator_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04B121A4FD7600F838EF /* level_estimator_impl.cc */; }; + 691E071721A4FD7700F838EF /* three_band_filter_bank.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04B221A4FD7600F838EF /* three_band_filter_bank.cc */; }; + 691E071821A4FD7700F838EF /* echo_cancellation.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04B421A4FD7600F838EF /* echo_cancellation.cc */; }; + 691E071A21A4FD7700F838EF /* aec_resampler.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04B621A4FD7600F838EF /* aec_resampler.cc */; }; + 691E071C21A4FD7700F838EF /* aec_core.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04B821A4FD7600F838EF /* aec_core.cc */; }; + 691E071F21A4FD7700F838EF /* aec_core_neon.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04BB21A4FD7600F838EF /* aec_core_neon.cc */; }; + 691E072021A4FD7700F838EF /* aec_core_sse2.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04BC21A4FD7600F838EF /* aec_core_sse2.cc */; }; + 691E072321A4FD7700F838EF /* voice_detection_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04BF21A4FD7600F838EF /* voice_detection_impl.cc */; }; + 691E072421A4FD7700F838EF /* echo_cancellation_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04C021A4FD7600F838EF /* echo_cancellation_impl.cc */; }; + 691E072521A4FD7700F838EF /* gain_control_for_experimental_agc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04C121A4FD7600F838EF /* gain_control_for_experimental_agc.cc */; }; + 691E072621A4FD7700F838EF /* agc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04C321A4FD7600F838EF /* agc.cc */; }; + 691E072721A4FD7700F838EF /* loudness_histogram.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04C421A4FD7600F838EF /* loudness_histogram.cc */; }; + 691E072821A4FD7700F838EF /* agc_manager_direct.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04C521A4FD7600F838EF /* agc_manager_direct.cc */; }; + 691E072C21A4FD7700F838EF /* analog_agc.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E04CA21A4FD7600F838EF /* analog_agc.c */; }; + 691E072D21A4FD7700F838EF /* digital_agc.c in Sources */ = {isa = PBXBuildFile; fileRef = 691E04CB21A4FD7600F838EF /* digital_agc.c */; }; + 691E072E21A4FD7700F838EF /* utility.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04CC21A4FD7600F838EF /* utility.cc */; }; + 691E073621A4FD7700F838EF /* audio_processing_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04D421A4FD7600F838EF /* audio_processing_impl.cc */; }; + 691E073C21A4FD7700F838EF /* file_audio_generator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04DB21A4FD7600F838EF /* file_audio_generator.cc */; }; + 691E073D21A4FD7700F838EF /* gain_controller2.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04DC21A4FD7600F838EF /* gain_controller2.cc */; }; + 691E073F21A4FD7700F838EF /* residual_echo_detector.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04DE21A4FD7600F838EF /* residual_echo_detector.cc */; }; + 691E074121A4FD7700F838EF /* noise_suppression_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04E021A4FD7600F838EF /* noise_suppression_impl.cc */; }; + 691E074621A4FD7700F838EF /* aecm_core.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04E621A4FD7600F838EF /* aecm_core.cc */; }; + 691E074721A4FD7700F838EF /* aecm_core_c.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04E721A4FD7600F838EF /* aecm_core_c.cc */; }; + 691E074821A4FD7700F838EF /* aecm_core_neon.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04E821A4FD7600F838EF /* aecm_core_neon.cc */; }; + 691E074A21A4FD7700F838EF /* echo_control_mobile.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04EA21A4FD7600F838EF /* echo_control_mobile.cc */; }; + 691E074B21A4FD7700F838EF /* render_reverb_model.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04EC21A4FD7600F838EF /* render_reverb_model.cc */; }; + 691E074E21A4FD7700F838EF /* reverb_model_fallback.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04EF21A4FD7600F838EF /* reverb_model_fallback.cc */; }; + 691E075121A4FD7700F838EF /* echo_remover_metrics.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04F221A4FD7600F838EF /* echo_remover_metrics.cc */; }; + 691E075221A4FD7700F838EF /* matched_filter_lag_aggregator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04F321A4FD7600F838EF /* matched_filter_lag_aggregator.cc */; }; + 691E075321A4FD7700F838EF /* render_delay_buffer2.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04F421A4FD7600F838EF /* render_delay_buffer2.cc */; }; + 691E075621A4FD7700F838EF /* echo_path_variability.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04F721A4FD7600F838EF /* echo_path_variability.cc */; }; + 691E075721A4FD7700F838EF /* frame_blocker.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04F821A4FD7600F838EF /* frame_blocker.cc */; }; + 691E075821A4FD7700F838EF /* subtractor.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E04F921A4FD7600F838EF /* subtractor.cc */; }; + 691E075F21A4FD7700F838EF /* aec3_fft.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E050021A4FD7600F838EF /* aec3_fft.cc */; }; + 691E076221A4FD7700F838EF /* fullband_erle_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E050321A4FD7600F838EF /* fullband_erle_estimator.cc */; }; + 691E076321A4FD7700F838EF /* suppression_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E050421A4FD7600F838EF /* suppression_filter.cc */; }; + 691E076421A4FD7700F838EF /* block_processor.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E050521A4FD7600F838EF /* block_processor.cc */; }; + 691E076821A4FD7700F838EF /* subband_erle_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E050921A4FD7600F838EF /* subband_erle_estimator.cc */; }; + 691E076921A4FD7700F838EF /* render_delay_controller_metrics.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E050A21A4FD7600F838EF /* render_delay_controller_metrics.cc */; }; + 691E076A21A4FD7700F838EF /* render_delay_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E050B21A4FD7600F838EF /* render_delay_buffer.cc */; }; + 691E076C21A4FD7700F838EF /* vector_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E050D21A4FD7600F838EF /* vector_buffer.cc */; }; + 691E076D21A4FD7700F838EF /* erl_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E050E21A4FD7600F838EF /* erl_estimator.cc */; }; + 691E076E21A4FD7700F838EF /* aec_state.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E050F21A4FD7600F838EF /* aec_state.cc */; }; + 691E076F21A4FD7700F838EF /* adaptive_fir_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E051021A4FD7600F838EF /* adaptive_fir_filter.cc */; }; + 691E077121A4FD7700F838EF /* render_delay_controller.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E051221A4FD7600F838EF /* render_delay_controller.cc */; }; + 691E077221A4FD7700F838EF /* skew_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E051321A4FD7600F838EF /* skew_estimator.cc */; }; + 691E077521A4FD7700F838EF /* echo_path_delay_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E051621A4FD7600F838EF /* echo_path_delay_estimator.cc */; }; + 691E077821A4FD7700F838EF /* block_framer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E051921A4FD7600F838EF /* block_framer.cc */; }; + 691E077921A4FD7700F838EF /* erle_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E051A21A4FD7600F838EF /* erle_estimator.cc */; }; + 691E077A21A4FD7700F838EF /* reverb_model.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E051B21A4FD7600F838EF /* reverb_model.cc */; }; + 691E077B21A4FD7700F838EF /* cascaded_biquad_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E051C21A4FD7600F838EF /* cascaded_biquad_filter.cc */; }; + 691E077D21A4FD7700F838EF /* render_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E051E21A4FD7600F838EF /* render_buffer.cc */; }; + 691E077F21A4FD7700F838EF /* subtractor_output.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E052021A4FD7600F838EF /* subtractor_output.cc */; }; + 691E078021A4FD7700F838EF /* stationarity_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E052121A4FD7600F838EF /* stationarity_estimator.cc */; }; + 691E078121A4FD7700F838EF /* render_signal_analyzer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E052221A4FD7600F838EF /* render_signal_analyzer.cc */; }; + 691E078521A4FD7700F838EF /* subtractor_output_analyzer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E052621A4FD7600F838EF /* subtractor_output_analyzer.cc */; }; + 691E078621A4FD7700F838EF /* suppression_gain.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E052721A4FD7600F838EF /* suppression_gain.cc */; }; + 691E078721A4FD7700F838EF /* echo_audibility.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E052821A4FD7600F838EF /* echo_audibility.cc */; }; + 691E078821A4FD7700F838EF /* block_processor_metrics.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E052921A4FD7600F838EF /* block_processor_metrics.cc */; }; + 691E078B21A4FD7700F838EF /* moving_average.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E052C21A4FD7600F838EF /* moving_average.cc */; }; + 691E078E21A4FD7700F838EF /* reverb_model_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E052F21A4FD7600F838EF /* reverb_model_estimator.cc */; }; + 691E078F21A4FD7700F838EF /* aec3_common.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E053021A4FD7600F838EF /* aec3_common.cc */; }; + 691E079021A4FD7700F838EF /* residual_echo_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E053121A4FD7600F838EF /* residual_echo_estimator.cc */; }; + 691E079321A4FD7700F838EF /* matched_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E053421A4FD7600F838EF /* matched_filter.cc */; }; + 691E079721A4FD7700F838EF /* reverb_decay_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E053821A4FD7600F838EF /* reverb_decay_estimator.cc */; }; + 691E079821A4FD7700F838EF /* render_delay_controller2.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E053921A4FD7600F838EF /* render_delay_controller2.cc */; }; + 691E079A21A4FD7700F838EF /* suppression_gain_limiter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E053B21A4FD7600F838EF /* suppression_gain_limiter.cc */; }; + 691E079B21A4FD7700F838EF /* main_filter_update_gain.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E053C21A4FD7600F838EF /* main_filter_update_gain.cc */; }; + 691E079C21A4FD7700F838EF /* echo_remover.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E053D21A4FD7600F838EF /* echo_remover.cc */; }; + 691E079E21A4FD7700F838EF /* downsampled_render_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E053F21A4FD7600F838EF /* downsampled_render_buffer.cc */; }; + 691E07A021A4FD7700F838EF /* matrix_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E054121A4FD7600F838EF /* matrix_buffer.cc */; }; + 691E07A421A4FD7700F838EF /* block_processor2.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E054521A4FD7600F838EF /* block_processor2.cc */; }; + 691E07A521A4FD7700F838EF /* echo_canceller3.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E054621A4FD7600F838EF /* echo_canceller3.cc */; }; + 691E07A621A4FD7700F838EF /* block_delay_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E054721A4FD7600F838EF /* block_delay_buffer.cc */; }; + 691E07A821A4FD7700F838EF /* fft_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E054921A4FD7600F838EF /* fft_buffer.cc */; }; + 691E07AF21A4FD7700F838EF /* comfort_noise_generator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E055021A4FD7600F838EF /* comfort_noise_generator.cc */; }; + 691E07B321A4FD7700F838EF /* shadow_filter_update_gain.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E055421A4FD7600F838EF /* shadow_filter_update_gain.cc */; }; + 691E07B421A4FD7700F838EF /* filter_analyzer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E055521A4FD7600F838EF /* filter_analyzer.cc */; }; + 691E07B621A4FD7700F838EF /* reverb_frequency_response.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E055721A4FD7600F838EF /* reverb_frequency_response.cc */; }; + 691E07B721A4FD7700F838EF /* decimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E055821A4FD7600F838EF /* decimator.cc */; }; + 691E07B921A4FD7700F838EF /* echo_control_mobile_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E055A21A4FD7600F838EF /* echo_control_mobile_impl.cc */; }; + 691E07BC21A4FD7700F838EF /* apm_data_dumper.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E055E21A4FD7600F838EF /* apm_data_dumper.cc */; }; + 691E07BE21A4FD7700F838EF /* voice_activity_detector.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E056121A4FD7600F838EF /* voice_activity_detector.cc */; }; + 691E07BF21A4FD7700F838EF /* standalone_vad.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E056221A4FD7600F838EF /* standalone_vad.cc */; }; + 691E07C121A4FD7700F838EF /* pitch_internal.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E056421A4FD7600F838EF /* pitch_internal.cc */; }; + 691E07C221A4FD7700F838EF /* vad_circular_buffer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E056521A4FD7600F838EF /* vad_circular_buffer.cc */; }; + 691E07C521A4FD7700F838EF /* vad_audio_proc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E056821A4FD7600F838EF /* vad_audio_proc.cc */; }; + 691E07C621A4FD7700F838EF /* pole_zero_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E056921A4FD7600F838EF /* pole_zero_filter.cc */; }; + 691E07C821A4FD7700F838EF /* pitch_based_vad.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E056B21A4FD7600F838EF /* pitch_based_vad.cc */; }; + 691E07CF21A4FD7700F838EF /* gmm.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E057221A4FD7600F838EF /* gmm.cc */; }; + 691E07D421A4FD7700F838EF /* ooura_fft.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E057821A4FD7600F838EF /* ooura_fft.cc */; }; + 691E07D621A4FD7700F838EF /* delay_estimator_wrapper.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E057A21A4FD7600F838EF /* delay_estimator_wrapper.cc */; }; + 691E07D721A4FD7700F838EF /* ooura_fft_sse2.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E057B21A4FD7600F838EF /* ooura_fft_sse2.cc */; }; + 691E07D821A4FD7700F838EF /* delay_estimator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E057C21A4FD7600F838EF /* delay_estimator.cc */; }; + 691E07DA21A4FD7700F838EF /* ooura_fft_neon.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E057E21A4FD7600F838EF /* ooura_fft_neon.cc */; }; + 691E07DB21A4FD7700F838EF /* block_mean_calculator.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E057F21A4FD7600F838EF /* block_mean_calculator.cc */; }; + 691E07E121A4FD7700F838EF /* race_checker.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E058621A4FD7600F838EF /* race_checker.cc */; }; + 691E07E321A4FD7700F838EF /* string_builder.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E058921A4FD7600F838EF /* string_builder.cc */; }; + 691E07E621A4FD7700F838EF /* aligned_malloc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E058D21A4FD7600F838EF /* aligned_malloc.cc */; }; + 691E07E821A4FD7700F838EF /* timeutils.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E058F21A4FD7600F838EF /* timeutils.cc */; }; + 691E07EA21A4FD7700F838EF /* logging_mac.mm in Sources */ = {isa = PBXBuildFile; fileRef = 691E059121A4FD7600F838EF /* logging_mac.mm */; }; + 691E07EE21A4FD7700F838EF /* platform_file.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E059521A4FD7600F838EF /* platform_file.cc */; }; + 691E07F021A4FD7700F838EF /* string_to_number.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E059721A4FD7600F838EF /* string_to_number.cc */; }; + 691E07F421A4FD7700F838EF /* thread_checker_impl.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E059B21A4FD7600F838EF /* thread_checker_impl.cc */; }; + 691E07FA21A4FD7700F838EF /* stringencode.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E05A121A4FD7600F838EF /* stringencode.cc */; }; + 691E07FB21A4FD7700F838EF /* stringutils.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E05A221A4FD7600F838EF /* stringutils.cc */; }; + 691E07FC21A4FD7700F838EF /* checks.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E05A321A4FD7600F838EF /* checks.cc */; }; + 691E080721A4FD7700F838EF /* platform_thread.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E05B021A4FD7600F838EF /* platform_thread.cc */; }; + 691E080921A4FD7700F838EF /* logging_webrtc.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E05B221A4FD7600F838EF /* logging_webrtc.cc */; }; + 691E081021A4FD7700F838EF /* criticalsection.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E05B921A4FD7600F838EF /* criticalsection.cc */; }; + 691E081121A4FD7700F838EF /* platform_thread_types.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E05BA21A4FD7600F838EF /* platform_thread_types.cc */; }; + 691E081321A4FD7700F838EF /* event.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E05BC21A4FD7600F838EF /* event.cc */; }; + 691E081521A4FD7700F838EF /* event_tracer.cc in Sources */ = {isa = PBXBuildFile; fileRef = 691E05BE21A4FD7600F838EF /* event_tracer.cc */; }; + 692AB8CB1E6759DD00706ACC /* AudioInput.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8881E6759DD00706ACC /* AudioInput.cpp */; }; + 692AB8CD1E6759DD00706ACC /* AudioOutput.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB88A1E6759DD00706ACC /* AudioOutput.cpp */; }; + 692AB8CF1E6759DD00706ACC /* BlockingQueue.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB88C1E6759DD00706ACC /* BlockingQueue.cpp */; }; + 692AB8D11E6759DD00706ACC /* Buffers.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB88E1E6759DD00706ACC /* Buffers.cpp */; }; + 692AB8D31E6759DD00706ACC /* VoIPGroupController.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8901E6759DD00706ACC /* VoIPGroupController.cpp */; }; + 692AB8D81E6759DD00706ACC /* CongestionControl.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8971E6759DD00706ACC /* CongestionControl.cpp */; }; + 692AB8DA1E6759DD00706ACC /* EchoCanceller.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8991E6759DD00706ACC /* EchoCanceller.cpp */; }; + 692AB8E61E6759DD00706ACC /* JitterBuffer.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8A81E6759DD00706ACC /* JitterBuffer.cpp */; }; + 692AB8E91E6759DD00706ACC /* MediaStreamItf.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8AB1E6759DD00706ACC /* MediaStreamItf.cpp */; }; + 692AB8EB1E6759DD00706ACC /* OpusDecoder.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8AD1E6759DD00706ACC /* OpusDecoder.cpp */; }; + 692AB8ED1E6759DD00706ACC /* OpusEncoder.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8AF1E6759DD00706ACC /* OpusEncoder.cpp */; }; + 692AB9021E6759DD00706ACC /* VoIPController.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8C71E6759DD00706ACC /* VoIPController.cpp */; }; + 692AB9031E6759DD00706ACC /* VoIPController.h in Headers */ = {isa = PBXBuildFile; fileRef = 692AB8C81E6759DD00706ACC /* VoIPController.h */; }; + 692AB9041E6759DD00706ACC /* VoIPServerConfig.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 692AB8C91E6759DD00706ACC /* VoIPServerConfig.cpp */; }; + 692AB9051E6759DD00706ACC /* VoIPServerConfig.h in Headers */ = {isa = PBXBuildFile; fileRef = 692AB8CA1E6759DD00706ACC /* VoIPServerConfig.h */; }; + 692AB91F1E675F7000706ACC /* AudioToolbox.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 692AB91C1E675F7000706ACC /* AudioToolbox.framework */; }; + 692AB9201E675F7000706ACC /* AudioUnit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 692AB91D1E675F7000706ACC /* AudioUnit.framework */; }; + 692AB9211E675F7000706ACC /* CoreAudio.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 692AB91E1E675F7000706ACC /* CoreAudio.framework */; }; + 694DE8A1219F2265009C09A7 /* VideoRenderer.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 694DE89D219F2265009C09A7 /* VideoRenderer.cpp */; }; + 694DE8A2219F2265009C09A7 /* VideoSource.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 694DE89E219F2265009C09A7 /* VideoSource.cpp */; }; + 6970AF4E225FFEBE00F02034 /* VideoFEC.h in Headers */ = {isa = PBXBuildFile; fileRef = 6970AF4A225FFEBE00F02034 /* VideoFEC.h */; }; + 6970AF4F225FFEBE00F02034 /* VideoPacketSender.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6970AF4B225FFEBE00F02034 /* VideoPacketSender.cpp */; }; + 6970AF50225FFEBE00F02034 /* VideoFEC.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6970AF4C225FFEBE00F02034 /* VideoFEC.cpp */; }; + 6970AF51225FFEBE00F02034 /* VideoPacketSender.h in Headers */ = {isa = PBXBuildFile; fileRef = 6970AF4D225FFEBE00F02034 /* VideoPacketSender.h */; }; + 6971220F20C8107F00971C2C /* PacketReassembler.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6971220D20C8107E00971C2C /* PacketReassembler.cpp */; }; + 6976FD0320F6A7060019939E /* MessageThread.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6976FD0120F6A7050019939E /* MessageThread.cpp */; }; + 697B6FC72136DBA4004C8E54 /* libtgvoipTests.mm in Sources */ = {isa = PBXBuildFile; fileRef = 697B6FC62136DBA4004C8E54 /* libtgvoipTests.mm */; }; + 697B6FC92136DBA4004C8E54 /* libtgvoip.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 69F842361E67540700C110F7 /* libtgvoip.framework */; }; + 697B6FD62136E1F3004C8E54 /* AudioIO.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 697B6FD42136E1F3004C8E54 /* AudioIO.cpp */; }; + 697B6FDA2136E2D9004C8E54 /* AudioIOCallback.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 697B6FD82136E2D9004C8E54 /* AudioIOCallback.cpp */; }; + 697B6FDF2136F01E004C8E54 /* MockReflector.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 697B6FDE2136F01E004C8E54 /* MockReflector.cpp */; }; + 69A2076521AF628A003AC4F9 /* json11.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69A2076421AF6289003AC4F9 /* json11.cpp */; }; + 69A6DF431E9614B700000E69 /* AudioInputAudioUnitOSX.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69A6DF3F1E9614B700000E69 /* AudioInputAudioUnitOSX.cpp */; }; + 69A6DF451E9614B700000E69 /* AudioOutputAudioUnitOSX.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69A6DF411E9614B700000E69 /* AudioOutputAudioUnitOSX.cpp */; }; + 69DF15622237DEBB00C1F8ED /* ScreamCongestionController.h in Headers */ = {isa = PBXBuildFile; fileRef = 69DF15602237DEBB00C1F8ED /* ScreamCongestionController.h */; }; + 69DF15632237DEBB00C1F8ED /* ScreamCongestionController.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69DF15612237DEBB00C1F8ED /* ScreamCongestionController.cpp */; }; + 69DF15642237DEBB00C1F8ED /* ScreamCongestionController.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 69DF15612237DEBB00C1F8ED /* ScreamCongestionController.cpp */; }; + 69DF156D2237DEDC00C1F8ED /* TGVVideoRenderer.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69DF15652237DEDA00C1F8ED /* TGVVideoRenderer.mm */; }; + 69DF156E2237DEDC00C1F8ED /* TGVVideoRenderer.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69DF15652237DEDA00C1F8ED /* TGVVideoRenderer.mm */; }; + 69DF15712237DEDC00C1F8ED /* TGVVideoRenderer.h in Headers */ = {isa = PBXBuildFile; fileRef = 69DF15672237DEDB00C1F8ED /* TGVVideoRenderer.h */; }; + 69DF15722237DEDC00C1F8ED /* TGVVideoSource.h in Headers */ = {isa = PBXBuildFile; fileRef = 69DF15682237DEDB00C1F8ED /* TGVVideoSource.h */; }; + 69DF15732237DEDC00C1F8ED /* TGVVideoSource.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69DF15692237DEDB00C1F8ED /* TGVVideoSource.mm */; }; + 69DF15742237DEDC00C1F8ED /* TGVVideoSource.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69DF15692237DEDB00C1F8ED /* TGVVideoSource.mm */; }; + 69DF15772237DEDC00C1F8ED /* VideoToolboxEncoderSource.h in Headers */ = {isa = PBXBuildFile; fileRef = 69DF156B2237DEDC00C1F8ED /* VideoToolboxEncoderSource.h */; }; + 69DF15782237DEDC00C1F8ED /* VideoToolboxEncoderSource.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69DF156C2237DEDC00C1F8ED /* VideoToolboxEncoderSource.mm */; }; + 69DF15792237DEDC00C1F8ED /* VideoToolboxEncoderSource.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69DF156C2237DEDC00C1F8ED /* VideoToolboxEncoderSource.mm */; }; + 69DF157B2237DFE100C1F8ED /* SampleBufferDisplayLayerRenderer.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69DF157A2237DFE100C1F8ED /* SampleBufferDisplayLayerRenderer.mm */; }; + 69DF157C2237DFE100C1F8ED /* SampleBufferDisplayLayerRenderer.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69DF157A2237DFE100C1F8ED /* SampleBufferDisplayLayerRenderer.mm */; }; + 69DF157E2237DFE700C1F8ED /* SampleBufferDisplayLayerRenderer.h in Headers */ = {isa = PBXBuildFile; fileRef = 69DF157D2237DFE700C1F8ED /* SampleBufferDisplayLayerRenderer.h */; }; + 69DF15802237E96E00C1F8ED /* VideoToolbox.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 69DF157F2237E96E00C1F8ED /* VideoToolbox.framework */; }; + 69EBC7942136D277003CFE90 /* DarwinSpecific.mm in Sources */ = {isa = PBXBuildFile; fileRef = 69EBC7932136D277003CFE90 /* DarwinSpecific.mm */; }; + C2A87DD81F4B6A33002D3F73 /* Resampler.cpp in Sources */ = {isa = PBXBuildFile; fileRef = C2A87DD71F4B6A33002D3F73 /* Resampler.cpp */; }; + C2A87DDF1F4B6A61002D3F73 /* AudioInputAudioUnit.cpp in Sources */ = {isa = PBXBuildFile; fileRef = C2A87DDB1F4B6A61002D3F73 /* AudioInputAudioUnit.cpp */; }; + C2A87DE01F4B6A61002D3F73 /* AudioOutputAudioUnit.cpp in Sources */ = {isa = PBXBuildFile; fileRef = C2A87DDD1F4B6A61002D3F73 /* AudioOutputAudioUnit.cpp */; }; + C2A87DE41F4B6AD3002D3F73 /* AudioUnitIO.cpp in Sources */ = {isa = PBXBuildFile; fileRef = C2A87DE31F4B6AD3002D3F73 /* AudioUnitIO.cpp */; }; +/* End PBXBuildFile section */ + +/* Begin PBXContainerItemProxy section */ + 692AB9101E675E8800706ACC /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = D08805AC156E8F3600311537; + remoteInfo = Telegraph; + }; + 692AB9121E675E8800706ACC /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = D02601D71A55CA2300716290; + remoteInfo = Share; + }; + 692AB9141E675E8800706ACC /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = 68744C0D1BB1A9F700FE6542; + remoteInfo = watchkitapp; + }; + 692AB9161E675E8800706ACC /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = 68744C191BB1A9F700FE6542; + remoteInfo = "watchkitapp Extension"; + }; + 692AB9181E675E8800706ACC /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = D020FADD1D99466A00F279AA; + remoteInfo = SiriIntents; + }; + 692AB91A1E675E8800706ACC /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = D020FB0A1D99637100F279AA; + remoteInfo = LegacyDatabase; + }; + 6976FCFF20F6A6EF0019939E /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + proxyType = 2; + remoteGlobalIDString = 099120C01EEAA63400F1366E; + remoteInfo = Widget; + }; + 697B6FCA2136DBA4004C8E54 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 69F8422D1E67540700C110F7 /* Project object */; + proxyType = 1; + remoteGlobalIDString = 69F842351E67540700C110F7; + remoteInfo = libtgvoip; + }; +/* End PBXContainerItemProxy section */ + +/* Begin PBXFileReference section */ + 690725BC1EBBD5DE005D860B /* NetworkSocketPosix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = NetworkSocketPosix.cpp; path = os/posix/NetworkSocketPosix.cpp; sourceTree = SOURCE_ROOT; }; + 690725BD1EBBD5DE005D860B /* NetworkSocketPosix.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = NetworkSocketPosix.h; path = os/posix/NetworkSocketPosix.h; sourceTree = SOURCE_ROOT; }; + 690725C01EBBD5F2005D860B /* NetworkSocket.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = NetworkSocket.cpp; sourceTree = SOURCE_ROOT; }; + 690725C11EBBD5F2005D860B /* NetworkSocket.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = NetworkSocket.h; sourceTree = SOURCE_ROOT; }; + 6915307A1E6B5BAB004F643F /* logging.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = logging.cpp; sourceTree = SOURCE_ROOT; }; + 691E032E21A4FD7500F838EF /* typedefs.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = typedefs.h; sourceTree = ""; }; + 691E033221A4FD7500F838EF /* memutil.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = memutil.h; sourceTree = ""; }; + 691E033321A4FD7500F838EF /* memutil.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = memutil.cc; sourceTree = ""; }; + 691E033421A4FD7500F838EF /* string_view.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = string_view.cc; sourceTree = ""; }; + 691E033521A4FD7500F838EF /* ascii.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ascii.h; sourceTree = ""; }; + 691E033621A4FD7500F838EF /* ascii.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ascii.cc; sourceTree = ""; }; + 691E033721A4FD7500F838EF /* string_view.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = string_view.h; sourceTree = ""; }; + 691E033921A4FD7500F838EF /* optional.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = optional.h; sourceTree = ""; }; + 691E033A21A4FD7500F838EF /* bad_optional_access.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = bad_optional_access.h; sourceTree = ""; }; + 691E033B21A4FD7500F838EF /* bad_optional_access.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = bad_optional_access.cc; sourceTree = ""; }; + 691E033C21A4FD7500F838EF /* optional.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = optional.cc; sourceTree = ""; }; + 691E033E21A4FD7500F838EF /* memory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = memory.h; sourceTree = ""; }; + 691E034021A4FD7500F838EF /* type_traits.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = type_traits.h; sourceTree = ""; }; + 691E034221A4FD7500F838EF /* algorithm.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = algorithm.h; sourceTree = ""; }; + 691E034421A4FD7500F838EF /* inlined_vector.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = inlined_vector.h; sourceTree = ""; }; + 691E034621A4FD7500F838EF /* policy_checks.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = policy_checks.h; sourceTree = ""; }; + 691E034721A4FD7500F838EF /* port.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = port.h; sourceTree = ""; }; + 691E034821A4FD7500F838EF /* config.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = config.h; sourceTree = ""; }; + 691E034A21A4FD7500F838EF /* raw_logging.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = raw_logging.cc; sourceTree = ""; }; + 691E034B21A4FD7500F838EF /* throw_delegate.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = throw_delegate.cc; sourceTree = ""; }; + 691E034C21A4FD7500F838EF /* invoke.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = invoke.h; sourceTree = ""; }; + 691E034D21A4FD7500F838EF /* inline_variable.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = inline_variable.h; sourceTree = ""; }; + 691E034E21A4FD7500F838EF /* atomic_hook.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = atomic_hook.h; sourceTree = ""; }; + 691E034F21A4FD7500F838EF /* identity.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = identity.h; sourceTree = ""; }; + 691E035021A4FD7500F838EF /* raw_logging.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = raw_logging.h; sourceTree = ""; }; + 691E035121A4FD7500F838EF /* throw_delegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = throw_delegate.h; sourceTree = ""; }; + 691E035221A4FD7500F838EF /* attributes.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = attributes.h; sourceTree = ""; }; + 691E035321A4FD7500F838EF /* macros.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = macros.h; sourceTree = ""; }; + 691E035421A4FD7500F838EF /* optimization.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = optimization.h; sourceTree = ""; }; + 691E035521A4FD7500F838EF /* log_severity.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = log_severity.h; sourceTree = ""; }; + 691E035721A4FD7500F838EF /* utility.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = utility.h; sourceTree = ""; }; + 691E035A21A4FD7500F838EF /* mock_smoothing_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = mock_smoothing_filter.h; sourceTree = ""; }; + 691E035B21A4FD7500F838EF /* wav_file.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = wav_file.h; sourceTree = ""; }; + 691E035C21A4FD7500F838EF /* window_generator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = window_generator.cc; sourceTree = ""; }; + 691E035D21A4FD7500F838EF /* channel_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = channel_buffer.cc; sourceTree = ""; }; + 691E035E21A4FD7500F838EF /* fir_filter_factory.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fir_filter_factory.cc; sourceTree = ""; }; + 691E035F21A4FD7500F838EF /* sparse_fir_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = sparse_fir_filter.h; sourceTree = ""; }; + 691E036021A4FD7500F838EF /* fir_filter_sse.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fir_filter_sse.h; sourceTree = ""; }; + 691E036121A4FD7500F838EF /* window_generator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = window_generator.h; sourceTree = ""; }; + 691E036221A4FD7500F838EF /* ring_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ring_buffer.h; sourceTree = ""; }; + 691E036321A4FD7500F838EF /* fir_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fir_filter.h; sourceTree = ""; }; + 691E036521A4FD7500F838EF /* audio_util.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_util.h; sourceTree = ""; }; + 691E036621A4FD7500F838EF /* wav_header.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = wav_header.cc; sourceTree = ""; }; + 691E036721A4FD7500F838EF /* real_fourier_ooura.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = real_fourier_ooura.cc; sourceTree = ""; }; + 691E036821A4FD7500F838EF /* fir_filter_neon.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fir_filter_neon.cc; sourceTree = ""; }; + 691E036921A4FD7500F838EF /* audio_util.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_util.cc; sourceTree = ""; }; + 691E036A21A4FD7500F838EF /* real_fourier_ooura.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = real_fourier_ooura.h; sourceTree = ""; }; + 691E036B21A4FD7500F838EF /* fir_filter_sse.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fir_filter_sse.cc; sourceTree = ""; }; + 691E036C21A4FD7500F838EF /* smoothing_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = smoothing_filter.h; sourceTree = ""; }; + 691E036E21A4FD7500F838EF /* sinc_resampler_neon.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = sinc_resampler_neon.cc; sourceTree = ""; }; + 691E036F21A4FD7500F838EF /* push_sinc_resampler.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = push_sinc_resampler.cc; sourceTree = ""; }; + 691E037021A4FD7500F838EF /* sinc_resampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = sinc_resampler.h; sourceTree = ""; }; + 691E037121A4FD7500F838EF /* resampler.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = resampler.cc; sourceTree = ""; }; + 691E037221A4FD7500F838EF /* sinc_resampler_sse.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = sinc_resampler_sse.cc; sourceTree = ""; }; + 691E037421A4FD7500F838EF /* push_resampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = push_resampler.h; sourceTree = ""; }; + 691E037521A4FD7500F838EF /* resampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = resampler.h; sourceTree = ""; }; + 691E037621A4FD7500F838EF /* push_sinc_resampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = push_sinc_resampler.h; sourceTree = ""; }; + 691E037721A4FD7500F838EF /* push_resampler.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = push_resampler.cc; sourceTree = ""; }; + 691E037821A4FD7500F838EF /* sinusoidal_linear_chirp_source.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = sinusoidal_linear_chirp_source.h; sourceTree = ""; }; + 691E037921A4FD7500F838EF /* sinc_resampler.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = sinc_resampler.cc; sourceTree = ""; }; + 691E037A21A4FD7500F838EF /* sinusoidal_linear_chirp_source.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = sinusoidal_linear_chirp_source.cc; sourceTree = ""; }; + 691E037B21A4FD7500F838EF /* fir_filter_factory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fir_filter_factory.h; sourceTree = ""; }; + 691E037C21A4FD7500F838EF /* audio_converter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_converter.h; sourceTree = ""; }; + 691E037D21A4FD7500F838EF /* wav_file.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = wav_file.cc; sourceTree = ""; }; + 691E038021A4FD7500F838EF /* spl_sqrt_floor.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = spl_sqrt_floor.c; sourceTree = ""; }; + 691E038221A4FD7500F838EF /* spl_sqrt_floor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = spl_sqrt_floor.h; sourceTree = ""; }; + 691E038421A4FD7500F838EF /* fft4g.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = fft4g.c; sourceTree = ""; }; + 691E038521A4FD7500F838EF /* fft4g.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fft4g.h; sourceTree = ""; }; + 691E038621A4FD7500F838EF /* audio_converter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_converter.cc; sourceTree = ""; }; + 691E038721A4FD7500F838EF /* real_fourier.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = real_fourier.cc; sourceTree = ""; }; + 691E038821A4FD7500F838EF /* channel_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = channel_buffer.h; sourceTree = ""; }; + 691E038921A4FD7500F838EF /* real_fourier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = real_fourier.h; sourceTree = ""; }; + 691E038A21A4FD7500F838EF /* sparse_fir_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = sparse_fir_filter.cc; sourceTree = ""; }; + 691E038B21A4FD7500F838EF /* fir_filter_neon.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fir_filter_neon.h; sourceTree = ""; }; + 691E038C21A4FD7500F838EF /* smoothing_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = smoothing_filter.cc; sourceTree = ""; }; + 691E038D21A4FD7500F838EF /* fir_filter_c.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fir_filter_c.cc; sourceTree = ""; }; + 691E038E21A4FD7500F838EF /* ring_buffer.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = ring_buffer.c; sourceTree = ""; }; + 691E038F21A4FD7500F838EF /* fir_filter_c.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fir_filter_c.h; sourceTree = ""; }; + 691E039121A4FD7500F838EF /* complex_fft_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = complex_fft_tables.h; sourceTree = ""; }; + 691E039221A4FD7500F838EF /* complex_fft.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = complex_fft.c; sourceTree = ""; }; + 691E039321A4FD7500F838EF /* filter_ma_fast_q12.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = filter_ma_fast_q12.c; sourceTree = ""; }; + 691E039421A4FD7500F838EF /* splitting_filter1.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = splitting_filter1.c; sourceTree = ""; }; + 691E039521A4FD7500F838EF /* levinson_durbin.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = levinson_durbin.c; sourceTree = ""; }; + 691E039621A4FD7500F838EF /* downsample_fast_neon.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = downsample_fast_neon.c; sourceTree = ""; }; + 691E039721A4FD7500F838EF /* dot_product_with_scale.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = dot_product_with_scale.cc; sourceTree = ""; }; + 691E039821A4FD7500F838EF /* auto_corr_to_refl_coef.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = auto_corr_to_refl_coef.c; sourceTree = ""; }; + 691E039921A4FD7500F838EF /* resample_by_2_internal.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = resample_by_2_internal.c; sourceTree = ""; }; + 691E039B21A4FD7500F838EF /* energy.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = energy.c; sourceTree = ""; }; + 691E039C21A4FD7500F838EF /* sqrt_of_one_minus_x_squared.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = sqrt_of_one_minus_x_squared.c; sourceTree = ""; }; + 691E039D21A4FD7500F838EF /* downsample_fast.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = downsample_fast.c; sourceTree = ""; }; + 691E039E21A4FD7500F838EF /* filter_ar_fast_q12.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = filter_ar_fast_q12.c; sourceTree = ""; }; + 691E039F21A4FD7500F838EF /* spl_init.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = spl_init.c; sourceTree = ""; }; + 691E03A021A4FD7500F838EF /* lpc_to_refl_coef.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lpc_to_refl_coef.c; sourceTree = ""; }; + 691E03A121A4FD7500F838EF /* cross_correlation.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = cross_correlation.c; sourceTree = ""; }; + 691E03A321A4FD7500F838EF /* signal_processing_library.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = signal_processing_library.h; sourceTree = ""; }; + 691E03A421A4FD7500F838EF /* real_fft.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = real_fft.h; sourceTree = ""; }; + 691E03A521A4FD7500F838EF /* spl_inl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = spl_inl.h; sourceTree = ""; }; + 691E03A621A4FD7500F838EF /* spl_inl_armv7.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = spl_inl_armv7.h; sourceTree = ""; }; + 691E03A721A4FD7500F838EF /* division_operations.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = division_operations.c; sourceTree = ""; }; + 691E03A821A4FD7500F838EF /* auto_correlation.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = auto_correlation.c; sourceTree = ""; }; + 691E03A921A4FD7500F838EF /* get_scaling_square.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = get_scaling_square.c; sourceTree = ""; }; + 691E03AA21A4FD7500F838EF /* min_max_operations_neon.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = min_max_operations_neon.c; sourceTree = ""; }; + 691E03AB21A4FD7500F838EF /* dot_product_with_scale.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = dot_product_with_scale.h; sourceTree = ""; }; + 691E03AC21A4FD7500F838EF /* resample_by_2_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = resample_by_2_internal.h; sourceTree = ""; }; + 691E03AD21A4FD7500F838EF /* resample.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = resample.c; sourceTree = ""; }; + 691E03AE21A4FD7500F838EF /* cross_correlation_neon.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = cross_correlation_neon.c; sourceTree = ""; }; + 691E03AF21A4FD7500F838EF /* min_max_operations.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = min_max_operations.c; sourceTree = ""; }; + 691E03B021A4FD7500F838EF /* refl_coef_to_lpc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = refl_coef_to_lpc.c; sourceTree = ""; }; + 691E03B121A4FD7500F838EF /* filter_ar.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = filter_ar.c; sourceTree = ""; }; + 691E03B221A4FD7500F838EF /* vector_scaling_operations.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = vector_scaling_operations.c; sourceTree = ""; }; + 691E03B321A4FD7500F838EF /* resample_fractional.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = resample_fractional.c; sourceTree = ""; }; + 691E03B421A4FD7500F838EF /* real_fft.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = real_fft.c; sourceTree = ""; }; + 691E03B521A4FD7500F838EF /* ilbc_specific_functions.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = ilbc_specific_functions.c; sourceTree = ""; }; + 691E03B621A4FD7500F838EF /* complex_bit_reverse.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = complex_bit_reverse.c; sourceTree = ""; }; + 691E03B721A4FD7500F838EF /* randomization_functions.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = randomization_functions.c; sourceTree = ""; }; + 691E03B921A4FD7500F838EF /* copy_set_operations.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = copy_set_operations.c; sourceTree = ""; }; + 691E03BA21A4FD7500F838EF /* resample_by_2.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = resample_by_2.c; sourceTree = ""; }; + 691E03BB21A4FD7500F838EF /* get_hanning_window.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = get_hanning_window.c; sourceTree = ""; }; + 691E03BC21A4FD7500F838EF /* resample_48khz.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = resample_48khz.c; sourceTree = ""; }; + 691E03BD21A4FD7500F838EF /* spl_inl.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = spl_inl.c; sourceTree = ""; }; + 691E03BE21A4FD7500F838EF /* spl_sqrt.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = spl_sqrt.c; sourceTree = ""; }; + 691E03BF21A4FD7500F838EF /* wav_header.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = wav_header.h; sourceTree = ""; }; + 691E03C121A4FD7500F838EF /* vad_sp.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = vad_sp.c; sourceTree = ""; }; + 691E03C221A4FD7500F838EF /* vad.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = vad.cc; sourceTree = ""; }; + 691E03C321A4FD7500F838EF /* webrtc_vad.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = webrtc_vad.c; sourceTree = ""; }; + 691E03C421A4FD7500F838EF /* vad_core.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_core.h; sourceTree = ""; }; + 691E03C621A4FD7500F838EF /* vad.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad.h; sourceTree = ""; }; + 691E03C721A4FD7500F838EF /* webrtc_vad.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = webrtc_vad.h; sourceTree = ""; }; + 691E03C821A4FD7500F838EF /* vad_gmm.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_gmm.h; sourceTree = ""; }; + 691E03C921A4FD7500F838EF /* vad_filterbank.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = vad_filterbank.c; sourceTree = ""; }; + 691E03CA21A4FD7500F838EF /* vad_core.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = vad_core.c; sourceTree = ""; }; + 691E03CB21A4FD7500F838EF /* vad_sp.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_sp.h; sourceTree = ""; }; + 691E03CC21A4FD7500F838EF /* vad_filterbank.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_filterbank.h; sourceTree = ""; }; + 691E03CD21A4FD7500F838EF /* vad_gmm.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = vad_gmm.c; sourceTree = ""; }; + 691E03D021A4FD7500F838EF /* audio_frame.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_frame.cc; sourceTree = ""; }; + 691E03D121A4FD7500F838EF /* echo_canceller3_config.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_canceller3_config.h; sourceTree = ""; }; + 691E03D221A4FD7500F838EF /* echo_control.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_control.h; sourceTree = ""; }; + 691E03D321A4FD7500F838EF /* audio_frame.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_frame.h; sourceTree = ""; }; + 691E03D421A4FD7500F838EF /* echo_canceller3_config.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_canceller3_config.cc; sourceTree = ""; }; + 691E03D521A4FD7500F838EF /* echo_canceller3_factory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_canceller3_factory.h; sourceTree = ""; }; + 691E03D621A4FD7500F838EF /* echo_canceller3_factory.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_canceller3_factory.cc; sourceTree = ""; }; + 691E03D721A4FD7500F838EF /* array_view.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = array_view.h; sourceTree = ""; }; + 691E03DB21A4FD7500F838EF /* rnn_vad_weights.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = rnn_vad_weights.cc; sourceTree = ""; }; + 691E03DC21A4FD7500F838EF /* rnn_activations.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = rnn_activations.h; sourceTree = ""; }; + 691E03DD21A4FD7500F838EF /* kiss_fft.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = kiss_fft.h; sourceTree = ""; }; + 691E03DE21A4FD7500F838EF /* kiss_fft.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = kiss_fft.cc; sourceTree = ""; }; + 691E03DF21A4FD7500F838EF /* rnn_vad_weights.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = rnn_vad_weights.h; sourceTree = ""; }; + 691E03E221A4FD7500F838EF /* field_trial.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = field_trial.h; sourceTree = ""; }; + 691E03E321A4FD7500F838EF /* cpu_features_wrapper.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = cpu_features_wrapper.h; sourceTree = ""; }; + 691E03E421A4FD7500F838EF /* asm_defines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = asm_defines.h; sourceTree = ""; }; + 691E03E521A4FD7500F838EF /* metrics.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = metrics.h; sourceTree = ""; }; + 691E03E621A4FD7500F838EF /* compile_assert_c.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = compile_assert_c.h; sourceTree = ""; }; + 691E03E821A4FD7500F838EF /* field_trial.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = field_trial.cc; sourceTree = ""; }; + 691E03E921A4FD7500F838EF /* metrics.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = metrics.cc; sourceTree = ""; }; + 691E03EA21A4FD7500F838EF /* cpu_features.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = cpu_features.cc; sourceTree = ""; }; + 691E03EE21A4FD7500F838EF /* fft.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fft.h; sourceTree = ""; }; + 691E03EF21A4FD7500F838EF /* fft.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = fft.c; sourceTree = ""; }; + 691E03F321A4FD7500F838EF /* bandwidth_info.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = bandwidth_info.h; sourceTree = ""; }; + 691E03F621A4FD7500F838EF /* isac.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = isac.h; sourceTree = ""; }; + 691E03F821A4FD7500F838EF /* pitch_estimator.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = pitch_estimator.c; sourceTree = ""; }; + 691E03F921A4FD7500F838EF /* lpc_shape_swb16_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lpc_shape_swb16_tables.c; sourceTree = ""; }; + 691E03FA21A4FD7500F838EF /* pitch_gain_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = pitch_gain_tables.c; sourceTree = ""; }; + 691E03FB21A4FD7500F838EF /* arith_routines_logist.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = arith_routines_logist.c; sourceTree = ""; }; + 691E03FC21A4FD7500F838EF /* os_specific_inline.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = os_specific_inline.h; sourceTree = ""; }; + 691E03FD21A4FD7500F838EF /* filterbanks.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = filterbanks.c; sourceTree = ""; }; + 691E03FE21A4FD7500F838EF /* entropy_coding.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = entropy_coding.h; sourceTree = ""; }; + 691E03FF21A4FD7500F838EF /* isac_vad.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = isac_vad.h; sourceTree = ""; }; + 691E040021A4FD7500F838EF /* settings.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = settings.h; sourceTree = ""; }; + 691E040121A4FD7500F838EF /* transform.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = transform.c; sourceTree = ""; }; + 691E040221A4FD7500F838EF /* lpc_shape_swb12_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = lpc_shape_swb12_tables.h; sourceTree = ""; }; + 691E040321A4FD7500F838EF /* arith_routines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = arith_routines.h; sourceTree = ""; }; + 691E040421A4FD7500F838EF /* crc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = crc.h; sourceTree = ""; }; + 691E040521A4FD7500F838EF /* pitch_filter.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = pitch_filter.c; sourceTree = ""; }; + 691E040621A4FD7500F838EF /* encode_lpc_swb.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = encode_lpc_swb.c; sourceTree = ""; }; + 691E040721A4FD7500F838EF /* filter_functions.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = filter_functions.c; sourceTree = ""; }; + 691E040821A4FD7500F838EF /* decode.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = decode.c; sourceTree = ""; }; + 691E040921A4FD7500F838EF /* lattice.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lattice.c; sourceTree = ""; }; + 691E040A21A4FD7500F838EF /* intialize.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = intialize.c; sourceTree = ""; }; + 691E040B21A4FD7500F838EF /* lpc_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lpc_tables.c; sourceTree = ""; }; + 691E040C21A4FD7500F838EF /* lpc_gain_swb_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lpc_gain_swb_tables.c; sourceTree = ""; }; + 691E040D21A4FD7500F838EF /* bandwidth_estimator.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = bandwidth_estimator.c; sourceTree = ""; }; + 691E040E21A4FD7500F838EF /* isac_float_type.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = isac_float_type.h; sourceTree = ""; }; + 691E040F21A4FD7500F838EF /* pitch_lag_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_lag_tables.h; sourceTree = ""; }; + 691E041021A4FD7500F838EF /* encode.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = encode.c; sourceTree = ""; }; + 691E041121A4FD7500F838EF /* lpc_analysis.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lpc_analysis.c; sourceTree = ""; }; + 691E041221A4FD7500F838EF /* spectrum_ar_model_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = spectrum_ar_model_tables.h; sourceTree = ""; }; + 691E041321A4FD7500F838EF /* arith_routines_hist.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = arith_routines_hist.c; sourceTree = ""; }; + 691E041421A4FD7500F838EF /* codec.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = codec.h; sourceTree = ""; }; + 691E041521A4FD7500F838EF /* pitch_gain_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_gain_tables.h; sourceTree = ""; }; + 691E041621A4FD7500F838EF /* lpc_shape_swb16_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = lpc_shape_swb16_tables.h; sourceTree = ""; }; + 691E041721A4FD7500F838EF /* pitch_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_estimator.h; sourceTree = ""; }; + 691E041821A4FD7500F838EF /* entropy_coding.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = entropy_coding.c; sourceTree = ""; }; + 691E041921A4FD7500F838EF /* isac_vad.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = isac_vad.c; sourceTree = ""; }; + 691E041A21A4FD7500F838EF /* structs.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = structs.h; sourceTree = ""; }; + 691E041B21A4FD7500F838EF /* filter_functions.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = filter_functions.h; sourceTree = ""; }; + 691E041C21A4FD7500F838EF /* encode_lpc_swb.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = encode_lpc_swb.h; sourceTree = ""; }; + 691E041D21A4FD7500F838EF /* pitch_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_filter.h; sourceTree = ""; }; + 691E041E21A4FD7500F838EF /* arith_routines.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = arith_routines.c; sourceTree = ""; }; + 691E041F21A4FD7500F838EF /* crc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = crc.c; sourceTree = ""; }; + 691E042021A4FD7500F838EF /* lpc_shape_swb12_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = lpc_shape_swb12_tables.c; sourceTree = ""; }; + 691E042121A4FD7500F838EF /* lpc_analysis.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = lpc_analysis.h; sourceTree = ""; }; + 691E042221A4FD7500F838EF /* decode_bwe.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = decode_bwe.c; sourceTree = ""; }; + 691E042321A4FD7500F838EF /* spectrum_ar_model_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = spectrum_ar_model_tables.c; sourceTree = ""; }; + 691E042421A4FD7500F838EF /* bandwidth_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = bandwidth_estimator.h; sourceTree = ""; }; + 691E042521A4FD7500F838EF /* pitch_lag_tables.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = pitch_lag_tables.c; sourceTree = ""; }; + 691E042621A4FD7500F838EF /* isac.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = isac.c; sourceTree = ""; }; + 691E042721A4FD7500F838EF /* lpc_gain_swb_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = lpc_gain_swb_tables.h; sourceTree = ""; }; + 691E042821A4FD7500F838EF /* lpc_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = lpc_tables.h; sourceTree = ""; }; + 691E042A21A4FD7500F838EF /* rms_level.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = rms_level.cc; sourceTree = ""; }; + 691E042C21A4FD7500F838EF /* moving_max.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = moving_max.h; sourceTree = ""; }; + 691E042D21A4FD7600F838EF /* circular_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = circular_buffer.h; sourceTree = ""; }; + 691E042E21A4FD7600F838EF /* normalized_covariance_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = normalized_covariance_estimator.h; sourceTree = ""; }; + 691E042F21A4FD7600F838EF /* normalized_covariance_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = normalized_covariance_estimator.cc; sourceTree = ""; }; + 691E043021A4FD7600F838EF /* moving_max.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = moving_max.cc; sourceTree = ""; }; + 691E043121A4FD7600F838EF /* circular_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = circular_buffer.cc; sourceTree = ""; }; + 691E043221A4FD7600F838EF /* mean_variance_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = mean_variance_estimator.cc; sourceTree = ""; }; + 691E043321A4FD7600F838EF /* mean_variance_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = mean_variance_estimator.h; sourceTree = ""; }; + 691E043421A4FD7600F838EF /* gain_control_for_experimental_agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_control_for_experimental_agc.h; sourceTree = ""; }; + 691E043521A4FD7600F838EF /* splitting_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = splitting_filter.cc; sourceTree = ""; }; + 691E043621A4FD7600F838EF /* gain_control_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gain_control_impl.cc; sourceTree = ""; }; + 691E043721A4FD7600F838EF /* rms_level.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = rms_level.h; sourceTree = ""; }; + 691E043D21A4FD7600F838EF /* ns_core.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ns_core.h; sourceTree = ""; }; + 691E043E21A4FD7600F838EF /* nsx_core.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = nsx_core.c; sourceTree = ""; }; + 691E043F21A4FD7600F838EF /* noise_suppression_x.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = noise_suppression_x.c; sourceTree = ""; }; + 691E044021A4FD7600F838EF /* nsx_core_c.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = nsx_core_c.c; sourceTree = ""; }; + 691E044121A4FD7600F838EF /* defines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = defines.h; sourceTree = ""; }; + 691E044221A4FD7600F838EF /* noise_suppression.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = noise_suppression.h; sourceTree = ""; }; + 691E044321A4FD7600F838EF /* ns_core.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = ns_core.c; sourceTree = ""; }; + 691E044421A4FD7600F838EF /* nsx_core.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = nsx_core.h; sourceTree = ""; }; + 691E044521A4FD7600F838EF /* windows_private.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = windows_private.h; sourceTree = ""; }; + 691E044621A4FD7600F838EF /* noise_suppression_x.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = noise_suppression_x.h; sourceTree = ""; }; + 691E044721A4FD7600F838EF /* nsx_core_neon.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = nsx_core_neon.c; sourceTree = ""; }; + 691E044821A4FD7600F838EF /* noise_suppression.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = noise_suppression.c; sourceTree = ""; }; + 691E044921A4FD7600F838EF /* nsx_defines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = nsx_defines.h; sourceTree = ""; }; + 691E044A21A4FD7600F838EF /* residual_echo_detector.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = residual_echo_detector.h; sourceTree = ""; }; + 691E044B21A4FD7600F838EF /* audio_processing_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_processing_impl.h; sourceTree = ""; }; + 691E044C21A4FD7600F838EF /* audio_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_buffer.cc; sourceTree = ""; }; + 691E044D21A4FD7600F838EF /* typing_detection.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = typing_detection.cc; sourceTree = ""; }; + 691E044E21A4FD7600F838EF /* render_queue_item_verifier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_queue_item_verifier.h; sourceTree = ""; }; + 691E045121A4FD7600F838EF /* audio_generator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_generator.h; sourceTree = ""; }; + 691E045221A4FD7600F838EF /* config.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = config.h; sourceTree = ""; }; + 691E045321A4FD7600F838EF /* audio_frame_view.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_frame_view.h; sourceTree = ""; }; + 691E045421A4FD7600F838EF /* mock_audio_processing.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = mock_audio_processing.h; sourceTree = ""; }; + 691E045521A4FD7600F838EF /* gain_control.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_control.h; sourceTree = ""; }; + 691E045621A4FD7600F838EF /* audio_generator_factory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_generator_factory.h; sourceTree = ""; }; + 691E045721A4FD7600F838EF /* audio_processing_statistics.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_processing_statistics.cc; sourceTree = ""; }; + 691E045821A4FD7600F838EF /* audio_generator_factory.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_generator_factory.cc; sourceTree = ""; }; + 691E045921A4FD7600F838EF /* aec_dump.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec_dump.cc; sourceTree = ""; }; + 691E045A21A4FD7600F838EF /* aec_dump.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec_dump.h; sourceTree = ""; }; + 691E045B21A4FD7600F838EF /* audio_processing_statistics.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_processing_statistics.h; sourceTree = ""; }; + 691E045C21A4FD7600F838EF /* audio_processing.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_processing.h; sourceTree = ""; }; + 691E045D21A4FD7600F838EF /* audio_processing.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_processing.cc; sourceTree = ""; }; + 691E045E21A4FD7600F838EF /* config.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = config.cc; sourceTree = ""; }; + 691E046021A4FD7600F838EF /* interpolated_gain_curve.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = interpolated_gain_curve.h; sourceTree = ""; }; + 691E046121A4FD7600F838EF /* biquad_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = biquad_filter.h; sourceTree = ""; }; + 691E046221A4FD7600F838EF /* interpolated_gain_curve.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = interpolated_gain_curve.cc; sourceTree = ""; }; + 691E046321A4FD7600F838EF /* agc2_common.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = agc2_common.cc; sourceTree = ""; }; + 691E046421A4FD7600F838EF /* agc2_testing_common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = agc2_testing_common.h; sourceTree = ""; }; + 691E046521A4FD7600F838EF /* adaptive_mode_level_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = adaptive_mode_level_estimator.h; sourceTree = ""; }; + 691E046621A4FD7600F838EF /* gain_applier.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gain_applier.cc; sourceTree = ""; }; + 691E046721A4FD7600F838EF /* signal_classifier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = signal_classifier.h; sourceTree = ""; }; + 691E046821A4FD7600F838EF /* adaptive_agc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = adaptive_agc.cc; sourceTree = ""; }; + 691E046921A4FD7600F838EF /* adaptive_digital_gain_applier.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = adaptive_digital_gain_applier.cc; sourceTree = ""; }; + 691E046A21A4FD7600F838EF /* limiter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = limiter.cc; sourceTree = ""; }; + 691E046B21A4FD7600F838EF /* saturation_protector.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = saturation_protector.cc; sourceTree = ""; }; + 691E046C21A4FD7600F838EF /* vector_float_frame.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vector_float_frame.h; sourceTree = ""; }; + 691E046E21A4FD7600F838EF /* spectral_features_internal.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = spectral_features_internal.cc; sourceTree = ""; }; + 691E046F21A4FD7600F838EF /* sequence_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = sequence_buffer.h; sourceTree = ""; }; + 691E047021A4FD7600F838EF /* rnn.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = rnn.h; sourceTree = ""; }; + 691E047121A4FD7600F838EF /* rnn.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = rnn.cc; sourceTree = ""; }; + 691E047221A4FD7600F838EF /* test_utils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = test_utils.h; sourceTree = ""; }; + 691E047321A4FD7600F838EF /* pitch_info.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_info.h; sourceTree = ""; }; + 691E047421A4FD7600F838EF /* lp_residual.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = lp_residual.h; sourceTree = ""; }; + 691E047521A4FD7600F838EF /* ring_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ring_buffer.h; sourceTree = ""; }; + 691E047621A4FD7600F838EF /* pitch_search_internal.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pitch_search_internal.cc; sourceTree = ""; }; + 691E047721A4FD7600F838EF /* symmetric_matrix_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = symmetric_matrix_buffer.h; sourceTree = ""; }; + 691E047821A4FD7600F838EF /* spectral_features.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = spectral_features.h; sourceTree = ""; }; + 691E047921A4FD7600F838EF /* features_extraction.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = features_extraction.h; sourceTree = ""; }; + 691E047A21A4FD7600F838EF /* common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = common.h; sourceTree = ""; }; + 691E047B21A4FD7600F838EF /* spectral_features_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = spectral_features_internal.h; sourceTree = ""; }; + 691E047C21A4FD7600F838EF /* fft_util.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fft_util.h; sourceTree = ""; }; + 691E047D21A4FD7600F838EF /* spectral_features.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = spectral_features.cc; sourceTree = ""; }; + 691E047E21A4FD7600F838EF /* pitch_search_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_search_internal.h; sourceTree = ""; }; + 691E047F21A4FD7600F838EF /* pitch_search.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pitch_search.cc; sourceTree = ""; }; + 691E048021A4FD7600F838EF /* pitch_search.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_search.h; sourceTree = ""; }; + 691E048121A4FD7600F838EF /* features_extraction.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = features_extraction.cc; sourceTree = ""; }; + 691E048221A4FD7600F838EF /* fft_util.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fft_util.cc; sourceTree = ""; }; + 691E048321A4FD7600F838EF /* lp_residual.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = lp_residual.cc; sourceTree = ""; }; + 691E048421A4FD7600F838EF /* fixed_gain_controller.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fixed_gain_controller.h; sourceTree = ""; }; + 691E048521A4FD7600F838EF /* adaptive_mode_level_estimator_agc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = adaptive_mode_level_estimator_agc.cc; sourceTree = ""; }; + 691E048621A4FD7600F838EF /* vector_float_frame.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = vector_float_frame.cc; sourceTree = ""; }; + 691E048721A4FD7600F838EF /* down_sampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = down_sampler.h; sourceTree = ""; }; + 691E048821A4FD7600F838EF /* noise_level_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = noise_level_estimator.cc; sourceTree = ""; }; + 691E048921A4FD7600F838EF /* agc2_testing_common.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = agc2_testing_common.cc; sourceTree = ""; }; + 691E048A21A4FD7600F838EF /* fixed_digital_level_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fixed_digital_level_estimator.cc; sourceTree = ""; }; + 691E048B21A4FD7600F838EF /* fixed_gain_controller.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fixed_gain_controller.cc; sourceTree = ""; }; + 691E048C21A4FD7600F838EF /* saturation_protector.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = saturation_protector.h; sourceTree = ""; }; + 691E048D21A4FD7600F838EF /* vad_with_level.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = vad_with_level.cc; sourceTree = ""; }; + 691E048E21A4FD7600F838EF /* limiter_db_gain_curve.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = limiter_db_gain_curve.cc; sourceTree = ""; }; + 691E048F21A4FD7600F838EF /* agc2_common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = agc2_common.h; sourceTree = ""; }; + 691E049021A4FD7600F838EF /* adaptive_mode_level_estimator_agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = adaptive_mode_level_estimator_agc.h; sourceTree = ""; }; + 691E049121A4FD7600F838EF /* adaptive_digital_gain_applier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = adaptive_digital_gain_applier.h; sourceTree = ""; }; + 691E049221A4FD7600F838EF /* vad_with_level.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_with_level.h; sourceTree = ""; }; + 691E049321A4FD7600F838EF /* limiter_db_gain_curve.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = limiter_db_gain_curve.h; sourceTree = ""; }; + 691E049421A4FD7600F838EF /* fixed_digital_level_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fixed_digital_level_estimator.h; sourceTree = ""; }; + 691E049521A4FD7600F838EF /* adaptive_agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = adaptive_agc.h; sourceTree = ""; }; + 691E049621A4FD7600F838EF /* gain_applier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_applier.h; sourceTree = ""; }; + 691E049721A4FD7600F838EF /* down_sampler.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = down_sampler.cc; sourceTree = ""; }; + 691E049821A4FD7600F838EF /* noise_level_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = noise_level_estimator.h; sourceTree = ""; }; + 691E049921A4FD7600F838EF /* signal_classifier.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = signal_classifier.cc; sourceTree = ""; }; + 691E049A21A4FD7600F838EF /* noise_spectrum_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = noise_spectrum_estimator.cc; sourceTree = ""; }; + 691E049B21A4FD7600F838EF /* compute_interpolated_gain_curve.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = compute_interpolated_gain_curve.cc; sourceTree = ""; }; + 691E049C21A4FD7600F838EF /* compute_interpolated_gain_curve.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = compute_interpolated_gain_curve.h; sourceTree = ""; }; + 691E049D21A4FD7600F838EF /* biquad_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = biquad_filter.cc; sourceTree = ""; }; + 691E049E21A4FD7600F838EF /* noise_spectrum_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = noise_spectrum_estimator.h; sourceTree = ""; }; + 691E049F21A4FD7600F838EF /* limiter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = limiter.h; sourceTree = ""; }; + 691E04A021A4FD7600F838EF /* adaptive_mode_level_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = adaptive_mode_level_estimator.cc; sourceTree = ""; }; + 691E04A221A4FD7600F838EF /* moving_moments.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = moving_moments.cc; sourceTree = ""; }; + 691E04A321A4FD7600F838EF /* transient_detector.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = transient_detector.h; sourceTree = ""; }; + 691E04A421A4FD7600F838EF /* wpd_tree.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = wpd_tree.cc; sourceTree = ""; }; + 691E04A521A4FD7600F838EF /* transient_suppressor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = transient_suppressor.h; sourceTree = ""; }; + 691E04A621A4FD7600F838EF /* daubechies_8_wavelet_coeffs.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = daubechies_8_wavelet_coeffs.h; sourceTree = ""; }; + 691E04A721A4FD7600F838EF /* common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = common.h; sourceTree = ""; }; + 691E04A821A4FD7600F838EF /* wpd_node.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = wpd_node.h; sourceTree = ""; }; + 691E04A921A4FD7600F838EF /* moving_moments.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = moving_moments.h; sourceTree = ""; }; + 691E04AA21A4FD7600F838EF /* wpd_tree.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = wpd_tree.h; sourceTree = ""; }; + 691E04AB21A4FD7600F838EF /* wpd_node.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = wpd_node.cc; sourceTree = ""; }; + 691E04AC21A4FD7600F838EF /* transient_suppressor.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = transient_suppressor.cc; sourceTree = ""; }; + 691E04AD21A4FD7600F838EF /* transient_detector.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = transient_detector.cc; sourceTree = ""; }; + 691E04AE21A4FD7600F838EF /* dyadic_decimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = dyadic_decimator.h; sourceTree = ""; }; + 691E04AF21A4FD7600F838EF /* low_cut_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = low_cut_filter.cc; sourceTree = ""; }; + 691E04B021A4FD7600F838EF /* noise_suppression_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = noise_suppression_impl.h; sourceTree = ""; }; + 691E04B121A4FD7600F838EF /* level_estimator_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = level_estimator_impl.cc; sourceTree = ""; }; + 691E04B221A4FD7600F838EF /* three_band_filter_bank.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = three_band_filter_bank.cc; sourceTree = ""; }; + 691E04B421A4FD7600F838EF /* echo_cancellation.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_cancellation.cc; sourceTree = ""; }; + 691E04B521A4FD7600F838EF /* aec_resampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec_resampler.h; sourceTree = ""; }; + 691E04B621A4FD7600F838EF /* aec_resampler.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec_resampler.cc; sourceTree = ""; }; + 691E04B721A4FD7600F838EF /* echo_cancellation.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_cancellation.h; sourceTree = ""; }; + 691E04B821A4FD7600F838EF /* aec_core.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec_core.cc; sourceTree = ""; }; + 691E04B921A4FD7600F838EF /* aec_core.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec_core.h; sourceTree = ""; }; + 691E04BA21A4FD7600F838EF /* aec_core_optimized_methods.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec_core_optimized_methods.h; sourceTree = ""; }; + 691E04BB21A4FD7600F838EF /* aec_core_neon.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec_core_neon.cc; sourceTree = ""; }; + 691E04BC21A4FD7600F838EF /* aec_core_sse2.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec_core_sse2.cc; sourceTree = ""; }; + 691E04BD21A4FD7600F838EF /* aec_common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec_common.h; sourceTree = ""; }; + 691E04BE21A4FD7600F838EF /* voice_detection_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = voice_detection_impl.h; sourceTree = ""; }; + 691E04BF21A4FD7600F838EF /* voice_detection_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = voice_detection_impl.cc; sourceTree = ""; }; + 691E04C021A4FD7600F838EF /* echo_cancellation_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_cancellation_impl.cc; sourceTree = ""; }; + 691E04C121A4FD7600F838EF /* gain_control_for_experimental_agc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gain_control_for_experimental_agc.cc; sourceTree = ""; }; + 691E04C321A4FD7600F838EF /* agc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = agc.cc; sourceTree = ""; }; + 691E04C421A4FD7600F838EF /* loudness_histogram.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = loudness_histogram.cc; sourceTree = ""; }; + 691E04C521A4FD7600F838EF /* agc_manager_direct.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = agc_manager_direct.cc; sourceTree = ""; }; + 691E04C721A4FD7600F838EF /* analog_agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = analog_agc.h; sourceTree = ""; }; + 691E04C821A4FD7600F838EF /* gain_control.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_control.h; sourceTree = ""; }; + 691E04C921A4FD7600F838EF /* digital_agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = digital_agc.h; sourceTree = ""; }; + 691E04CA21A4FD7600F838EF /* analog_agc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = analog_agc.c; sourceTree = ""; }; + 691E04CB21A4FD7600F838EF /* digital_agc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = digital_agc.c; sourceTree = ""; }; + 691E04CC21A4FD7600F838EF /* utility.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = utility.cc; sourceTree = ""; }; + 691E04CD21A4FD7600F838EF /* mock_agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = mock_agc.h; sourceTree = ""; }; + 691E04CE21A4FD7600F838EF /* loudness_histogram.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = loudness_histogram.h; sourceTree = ""; }; + 691E04CF21A4FD7600F838EF /* gain_map_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_map_internal.h; sourceTree = ""; }; + 691E04D021A4FD7600F838EF /* utility.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = utility.h; sourceTree = ""; }; + 691E04D121A4FD7600F838EF /* agc_manager_direct.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = agc_manager_direct.h; sourceTree = ""; }; + 691E04D221A4FD7600F838EF /* agc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = agc.h; sourceTree = ""; }; + 691E04D321A4FD7600F838EF /* common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = common.h; sourceTree = ""; }; + 691E04D421A4FD7600F838EF /* audio_processing_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = audio_processing_impl.cc; sourceTree = ""; }; + 691E04D521A4FD7600F838EF /* audio_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = audio_buffer.h; sourceTree = ""; }; + 691E04D621A4FD7600F838EF /* echo_control_mobile_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_control_mobile_impl.h; sourceTree = ""; }; + 691E04D721A4FD7600F838EF /* splitting_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = splitting_filter.h; sourceTree = ""; }; + 691E04D821A4FD7600F838EF /* low_cut_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = low_cut_filter.h; sourceTree = ""; }; + 691E04DA21A4FD7600F838EF /* file_audio_generator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = file_audio_generator.h; sourceTree = ""; }; + 691E04DB21A4FD7600F838EF /* file_audio_generator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = file_audio_generator.cc; sourceTree = ""; }; + 691E04DC21A4FD7600F838EF /* gain_controller2.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gain_controller2.cc; sourceTree = ""; }; + 691E04DD21A4FD7600F838EF /* three_band_filter_bank.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = three_band_filter_bank.h; sourceTree = ""; }; + 691E04DE21A4FD7600F838EF /* residual_echo_detector.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = residual_echo_detector.cc; sourceTree = ""; }; + 691E04DF21A4FD7600F838EF /* echo_cancellation_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_cancellation_impl.h; sourceTree = ""; }; + 691E04E021A4FD7600F838EF /* noise_suppression_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = noise_suppression_impl.cc; sourceTree = ""; }; + 691E04E121A4FD7600F838EF /* level_estimator_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = level_estimator_impl.h; sourceTree = ""; }; + 691E04E221A4FD7600F838EF /* gain_controller2.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_controller2.h; sourceTree = ""; }; + 691E04E421A4FD7600F838EF /* aecm_core.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aecm_core.h; sourceTree = ""; }; + 691E04E521A4FD7600F838EF /* aecm_defines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aecm_defines.h; sourceTree = ""; }; + 691E04E621A4FD7600F838EF /* aecm_core.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aecm_core.cc; sourceTree = ""; }; + 691E04E721A4FD7600F838EF /* aecm_core_c.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aecm_core_c.cc; sourceTree = ""; }; + 691E04E821A4FD7600F838EF /* aecm_core_neon.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aecm_core_neon.cc; sourceTree = ""; }; + 691E04E921A4FD7600F838EF /* echo_control_mobile.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_control_mobile.h; sourceTree = ""; }; + 691E04EA21A4FD7600F838EF /* echo_control_mobile.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_control_mobile.cc; sourceTree = ""; }; + 691E04EC21A4FD7600F838EF /* render_reverb_model.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_reverb_model.cc; sourceTree = ""; }; + 691E04ED21A4FD7600F838EF /* downsampled_render_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = downsampled_render_buffer.h; sourceTree = ""; }; + 691E04EE21A4FD7600F838EF /* subtractor_output_analyzer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = subtractor_output_analyzer.h; sourceTree = ""; }; + 691E04EF21A4FD7600F838EF /* reverb_model_fallback.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = reverb_model_fallback.cc; sourceTree = ""; }; + 691E04F021A4FD7600F838EF /* residual_echo_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = residual_echo_estimator.h; sourceTree = ""; }; + 691E04F121A4FD7600F838EF /* shadow_filter_update_gain.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = shadow_filter_update_gain.h; sourceTree = ""; }; + 691E04F221A4FD7600F838EF /* echo_remover_metrics.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_remover_metrics.cc; sourceTree = ""; }; + 691E04F321A4FD7600F838EF /* matched_filter_lag_aggregator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = matched_filter_lag_aggregator.cc; sourceTree = ""; }; + 691E04F421A4FD7600F838EF /* render_delay_buffer2.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_delay_buffer2.cc; sourceTree = ""; }; + 691E04F521A4FD7600F838EF /* aec_state.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec_state.h; sourceTree = ""; }; + 691E04F621A4FD7600F838EF /* suppression_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = suppression_filter.h; sourceTree = ""; }; + 691E04F721A4FD7600F838EF /* echo_path_variability.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_path_variability.cc; sourceTree = ""; }; + 691E04F821A4FD7600F838EF /* frame_blocker.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = frame_blocker.cc; sourceTree = ""; }; + 691E04F921A4FD7600F838EF /* subtractor.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = subtractor.cc; sourceTree = ""; }; + 691E04FA21A4FD7600F838EF /* block_delay_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = block_delay_buffer.h; sourceTree = ""; }; + 691E04FB21A4FD7600F838EF /* adaptive_fir_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = adaptive_fir_filter.h; sourceTree = ""; }; + 691E04FC21A4FD7600F838EF /* cascaded_biquad_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = cascaded_biquad_filter.h; sourceTree = ""; }; + 691E04FD21A4FD7600F838EF /* matched_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = matched_filter.h; sourceTree = ""; }; + 691E04FE21A4FD7600F838EF /* subtractor_output.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = subtractor_output.h; sourceTree = ""; }; + 691E04FF21A4FD7600F838EF /* render_signal_analyzer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_signal_analyzer.h; sourceTree = ""; }; + 691E050021A4FD7600F838EF /* aec3_fft.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec3_fft.cc; sourceTree = ""; }; + 691E050121A4FD7600F838EF /* aec3_fft.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec3_fft.h; sourceTree = ""; }; + 691E050221A4FD7600F838EF /* echo_remover_metrics.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_remover_metrics.h; sourceTree = ""; }; + 691E050321A4FD7600F838EF /* fullband_erle_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fullband_erle_estimator.cc; sourceTree = ""; }; + 691E050421A4FD7600F838EF /* suppression_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = suppression_filter.cc; sourceTree = ""; }; + 691E050521A4FD7600F838EF /* block_processor.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = block_processor.cc; sourceTree = ""; }; + 691E050621A4FD7600F838EF /* filter_analyzer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = filter_analyzer.h; sourceTree = ""; }; + 691E050721A4FD7600F838EF /* subtractor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = subtractor.h; sourceTree = ""; }; + 691E050821A4FD7600F838EF /* echo_path_delay_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_path_delay_estimator.h; sourceTree = ""; }; + 691E050921A4FD7600F838EF /* subband_erle_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = subband_erle_estimator.cc; sourceTree = ""; }; + 691E050A21A4FD7600F838EF /* render_delay_controller_metrics.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_delay_controller_metrics.cc; sourceTree = ""; }; + 691E050B21A4FD7600F838EF /* render_delay_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_delay_buffer.cc; sourceTree = ""; }; + 691E050C21A4FD7600F838EF /* block_processor_metrics.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = block_processor_metrics.h; sourceTree = ""; }; + 691E050D21A4FD7600F838EF /* vector_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = vector_buffer.cc; sourceTree = ""; }; + 691E050E21A4FD7600F838EF /* erl_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = erl_estimator.cc; sourceTree = ""; }; + 691E050F21A4FD7600F838EF /* aec_state.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec_state.cc; sourceTree = ""; }; + 691E051021A4FD7600F838EF /* adaptive_fir_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = adaptive_fir_filter.cc; sourceTree = ""; }; + 691E051121A4FD7600F838EF /* fft_data.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fft_data.h; sourceTree = ""; }; + 691E051221A4FD7600F838EF /* render_delay_controller.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_delay_controller.cc; sourceTree = ""; }; + 691E051321A4FD7600F838EF /* skew_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = skew_estimator.cc; sourceTree = ""; }; + 691E051421A4FD7600F838EF /* render_delay_controller_metrics.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_delay_controller_metrics.h; sourceTree = ""; }; + 691E051521A4FD7600F838EF /* comfort_noise_generator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = comfort_noise_generator.h; sourceTree = ""; }; + 691E051621A4FD7600F838EF /* echo_path_delay_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_path_delay_estimator.cc; sourceTree = ""; }; + 691E051721A4FD7600F838EF /* erl_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = erl_estimator.h; sourceTree = ""; }; + 691E051821A4FD7600F838EF /* echo_remover.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_remover.h; sourceTree = ""; }; + 691E051921A4FD7600F838EF /* block_framer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = block_framer.cc; sourceTree = ""; }; + 691E051A21A4FD7600F838EF /* erle_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = erle_estimator.cc; sourceTree = ""; }; + 691E051B21A4FD7600F838EF /* reverb_model.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = reverb_model.cc; sourceTree = ""; }; + 691E051C21A4FD7600F838EF /* cascaded_biquad_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = cascaded_biquad_filter.cc; sourceTree = ""; }; + 691E051D21A4FD7600F838EF /* matrix_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = matrix_buffer.h; sourceTree = ""; }; + 691E051E21A4FD7600F838EF /* render_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_buffer.cc; sourceTree = ""; }; + 691E051F21A4FD7600F838EF /* reverb_model_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = reverb_model_estimator.h; sourceTree = ""; }; + 691E052021A4FD7600F838EF /* subtractor_output.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = subtractor_output.cc; sourceTree = ""; }; + 691E052121A4FD7600F838EF /* stationarity_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = stationarity_estimator.cc; sourceTree = ""; }; + 691E052221A4FD7600F838EF /* render_signal_analyzer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_signal_analyzer.cc; sourceTree = ""; }; + 691E052321A4FD7600F838EF /* echo_path_variability.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_path_variability.h; sourceTree = ""; }; + 691E052421A4FD7600F838EF /* moving_average.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = moving_average.h; sourceTree = ""; }; + 691E052521A4FD7600F838EF /* render_reverb_model.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_reverb_model.h; sourceTree = ""; }; + 691E052621A4FD7600F838EF /* subtractor_output_analyzer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = subtractor_output_analyzer.cc; sourceTree = ""; }; + 691E052721A4FD7600F838EF /* suppression_gain.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = suppression_gain.cc; sourceTree = ""; }; + 691E052821A4FD7600F838EF /* echo_audibility.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_audibility.cc; sourceTree = ""; }; + 691E052921A4FD7600F838EF /* block_processor_metrics.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = block_processor_metrics.cc; sourceTree = ""; }; + 691E052A21A4FD7600F838EF /* render_delay_controller.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_delay_controller.h; sourceTree = ""; }; + 691E052B21A4FD7600F838EF /* suppression_gain.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = suppression_gain.h; sourceTree = ""; }; + 691E052C21A4FD7600F838EF /* moving_average.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = moving_average.cc; sourceTree = ""; }; + 691E052D21A4FD7600F838EF /* erle_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = erle_estimator.h; sourceTree = ""; }; + 691E052E21A4FD7600F838EF /* subband_erle_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = subband_erle_estimator.h; sourceTree = ""; }; + 691E052F21A4FD7600F838EF /* reverb_model_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = reverb_model_estimator.cc; sourceTree = ""; }; + 691E053021A4FD7600F838EF /* aec3_common.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aec3_common.cc; sourceTree = ""; }; + 691E053121A4FD7600F838EF /* residual_echo_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = residual_echo_estimator.cc; sourceTree = ""; }; + 691E053221A4FD7600F838EF /* block_processor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = block_processor.h; sourceTree = ""; }; + 691E053321A4FD7600F838EF /* fullband_erle_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fullband_erle_estimator.h; sourceTree = ""; }; + 691E053421A4FD7600F838EF /* matched_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = matched_filter.cc; sourceTree = ""; }; + 691E053521A4FD7600F838EF /* stationarity_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = stationarity_estimator.h; sourceTree = ""; }; + 691E053621A4FD7600F838EF /* echo_canceller3.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_canceller3.h; sourceTree = ""; }; + 691E053721A4FD7600F838EF /* skew_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = skew_estimator.h; sourceTree = ""; }; + 691E053821A4FD7600F838EF /* reverb_decay_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = reverb_decay_estimator.cc; sourceTree = ""; }; + 691E053921A4FD7600F838EF /* render_delay_controller2.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = render_delay_controller2.cc; sourceTree = ""; }; + 691E053A21A4FD7600F838EF /* render_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_buffer.h; sourceTree = ""; }; + 691E053B21A4FD7600F838EF /* suppression_gain_limiter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = suppression_gain_limiter.cc; sourceTree = ""; }; + 691E053C21A4FD7600F838EF /* main_filter_update_gain.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = main_filter_update_gain.cc; sourceTree = ""; }; + 691E053D21A4FD7600F838EF /* echo_remover.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_remover.cc; sourceTree = ""; }; + 691E053E21A4FD7600F838EF /* reverb_model_fallback.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = reverb_model_fallback.h; sourceTree = ""; }; + 691E053F21A4FD7600F838EF /* downsampled_render_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = downsampled_render_buffer.cc; sourceTree = ""; }; + 691E054021A4FD7600F838EF /* vector_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vector_buffer.h; sourceTree = ""; }; + 691E054121A4FD7600F838EF /* matrix_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = matrix_buffer.cc; sourceTree = ""; }; + 691E054221A4FD7600F838EF /* reverb_frequency_response.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = reverb_frequency_response.h; sourceTree = ""; }; + 691E054321A4FD7600F838EF /* echo_audibility.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = echo_audibility.h; sourceTree = ""; }; + 691E054421A4FD7600F838EF /* fft_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = fft_buffer.h; sourceTree = ""; }; + 691E054521A4FD7600F838EF /* block_processor2.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = block_processor2.cc; sourceTree = ""; }; + 691E054621A4FD7600F838EF /* echo_canceller3.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_canceller3.cc; sourceTree = ""; }; + 691E054721A4FD7600F838EF /* block_delay_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = block_delay_buffer.cc; sourceTree = ""; }; + 691E054821A4FD7600F838EF /* aec3_common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aec3_common.h; sourceTree = ""; }; + 691E054921A4FD7600F838EF /* fft_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = fft_buffer.cc; sourceTree = ""; }; + 691E054A21A4FD7600F838EF /* vector_math.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vector_math.h; sourceTree = ""; }; + 691E054B21A4FD7600F838EF /* decimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = decimator.h; sourceTree = ""; }; + 691E054C21A4FD7600F838EF /* frame_blocker.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = frame_blocker.h; sourceTree = ""; }; + 691E054D21A4FD7600F838EF /* block_framer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = block_framer.h; sourceTree = ""; }; + 691E054E21A4FD7600F838EF /* suppression_gain_limiter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = suppression_gain_limiter.h; sourceTree = ""; }; + 691E054F21A4FD7600F838EF /* delay_estimate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = delay_estimate.h; sourceTree = ""; }; + 691E055021A4FD7600F838EF /* comfort_noise_generator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = comfort_noise_generator.cc; sourceTree = ""; }; + 691E055121A4FD7600F838EF /* reverb_model.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = reverb_model.h; sourceTree = ""; }; + 691E055221A4FD7600F838EF /* main_filter_update_gain.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = main_filter_update_gain.h; sourceTree = ""; }; + 691E055321A4FD7600F838EF /* matched_filter_lag_aggregator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = matched_filter_lag_aggregator.h; sourceTree = ""; }; + 691E055421A4FD7600F838EF /* shadow_filter_update_gain.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = shadow_filter_update_gain.cc; sourceTree = ""; }; + 691E055521A4FD7600F838EF /* filter_analyzer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = filter_analyzer.cc; sourceTree = ""; }; + 691E055621A4FD7600F838EF /* reverb_decay_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = reverb_decay_estimator.h; sourceTree = ""; }; + 691E055721A4FD7600F838EF /* reverb_frequency_response.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = reverb_frequency_response.cc; sourceTree = ""; }; + 691E055821A4FD7600F838EF /* decimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = decimator.cc; sourceTree = ""; }; + 691E055921A4FD7600F838EF /* render_delay_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = render_delay_buffer.h; sourceTree = ""; }; + 691E055A21A4FD7600F838EF /* echo_control_mobile_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = echo_control_mobile_impl.cc; sourceTree = ""; }; + 691E055B21A4FD7600F838EF /* gain_control_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gain_control_impl.h; sourceTree = ""; }; + 691E055C21A4FD7600F838EF /* typing_detection.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = typing_detection.h; sourceTree = ""; }; + 691E055E21A4FD7600F838EF /* apm_data_dumper.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = apm_data_dumper.cc; sourceTree = ""; }; + 691E055F21A4FD7600F838EF /* apm_data_dumper.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = apm_data_dumper.h; sourceTree = ""; }; + 691E056121A4FD7600F838EF /* voice_activity_detector.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = voice_activity_detector.cc; sourceTree = ""; }; + 691E056221A4FD7600F838EF /* standalone_vad.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = standalone_vad.cc; sourceTree = ""; }; + 691E056321A4FD7600F838EF /* vad_audio_proc_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_audio_proc_internal.h; sourceTree = ""; }; + 691E056421A4FD7600F838EF /* pitch_internal.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pitch_internal.cc; sourceTree = ""; }; + 691E056521A4FD7600F838EF /* vad_circular_buffer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = vad_circular_buffer.cc; sourceTree = ""; }; + 691E056621A4FD7600F838EF /* vad_circular_buffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_circular_buffer.h; sourceTree = ""; }; + 691E056721A4FD7600F838EF /* pitch_based_vad.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_based_vad.h; sourceTree = ""; }; + 691E056821A4FD7600F838EF /* vad_audio_proc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = vad_audio_proc.cc; sourceTree = ""; }; + 691E056921A4FD7600F838EF /* pole_zero_filter.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pole_zero_filter.cc; sourceTree = ""; }; + 691E056A21A4FD7600F838EF /* pole_zero_filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pole_zero_filter.h; sourceTree = ""; }; + 691E056B21A4FD7600F838EF /* pitch_based_vad.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pitch_based_vad.cc; sourceTree = ""; }; + 691E056C21A4FD7600F838EF /* gmm.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gmm.h; sourceTree = ""; }; + 691E056D21A4FD7600F838EF /* common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = common.h; sourceTree = ""; }; + 691E056E21A4FD7600F838EF /* vad_audio_proc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = vad_audio_proc.h; sourceTree = ""; }; + 691E056F21A4FD7600F838EF /* voice_gmm_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = voice_gmm_tables.h; sourceTree = ""; }; + 691E057021A4FD7600F838EF /* noise_gmm_tables.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = noise_gmm_tables.h; sourceTree = ""; }; + 691E057121A4FD7600F838EF /* pitch_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pitch_internal.h; sourceTree = ""; }; + 691E057221A4FD7600F838EF /* gmm.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gmm.cc; sourceTree = ""; }; + 691E057321A4FD7600F838EF /* standalone_vad.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = standalone_vad.h; sourceTree = ""; }; + 691E057421A4FD7600F838EF /* voice_activity_detector.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = voice_activity_detector.h; sourceTree = ""; }; + 691E057621A4FD7600F838EF /* ooura_fft_tables_neon_sse2.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ooura_fft_tables_neon_sse2.h; sourceTree = ""; }; + 691E057721A4FD7600F838EF /* delay_estimator_internal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = delay_estimator_internal.h; sourceTree = ""; }; + 691E057821A4FD7600F838EF /* ooura_fft.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ooura_fft.cc; sourceTree = ""; }; + 691E057921A4FD7600F838EF /* ooura_fft.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ooura_fft.h; sourceTree = ""; }; + 691E057A21A4FD7600F838EF /* delay_estimator_wrapper.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = delay_estimator_wrapper.cc; sourceTree = ""; }; + 691E057B21A4FD7600F838EF /* ooura_fft_sse2.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ooura_fft_sse2.cc; sourceTree = ""; }; + 691E057C21A4FD7600F838EF /* delay_estimator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = delay_estimator.cc; sourceTree = ""; }; + 691E057D21A4FD7600F838EF /* block_mean_calculator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = block_mean_calculator.h; sourceTree = ""; }; + 691E057E21A4FD7600F838EF /* ooura_fft_neon.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ooura_fft_neon.cc; sourceTree = ""; }; + 691E057F21A4FD7600F838EF /* block_mean_calculator.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = block_mean_calculator.cc; sourceTree = ""; }; + 691E058021A4FD7600F838EF /* delay_estimator.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = delay_estimator.h; sourceTree = ""; }; + 691E058121A4FD7600F838EF /* ooura_fft_tables_common.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ooura_fft_tables_common.h; sourceTree = ""; }; + 691E058221A4FD7600F838EF /* delay_estimator_wrapper.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = delay_estimator_wrapper.h; sourceTree = ""; }; + 691E058421A4FD7600F838EF /* string_to_number.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = string_to_number.h; sourceTree = ""; }; + 691E058521A4FD7600F838EF /* constructormagic.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = constructormagic.h; sourceTree = ""; }; + 691E058621A4FD7600F838EF /* race_checker.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = race_checker.cc; sourceTree = ""; }; + 691E058821A4FD7600F838EF /* string_builder.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = string_builder.h; sourceTree = ""; }; + 691E058921A4FD7600F838EF /* string_builder.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = string_builder.cc; sourceTree = ""; }; + 691E058A21A4FD7600F838EF /* event_tracer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = event_tracer.h; sourceTree = ""; }; + 691E058B21A4FD7600F838EF /* stringencode.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = stringencode.h; sourceTree = ""; }; + 691E058D21A4FD7600F838EF /* aligned_malloc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = aligned_malloc.cc; sourceTree = ""; }; + 691E058E21A4FD7600F838EF /* aligned_malloc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = aligned_malloc.h; sourceTree = ""; }; + 691E058F21A4FD7600F838EF /* timeutils.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = timeutils.cc; sourceTree = ""; }; + 691E059021A4FD7600F838EF /* event.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = event.h; sourceTree = ""; }; + 691E059121A4FD7600F838EF /* logging_mac.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; path = logging_mac.mm; sourceTree = ""; }; + 691E059221A4FD7600F838EF /* ignore_wundef.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ignore_wundef.h; sourceTree = ""; }; + 691E059321A4FD7600F838EF /* stringutils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = stringutils.h; sourceTree = ""; }; + 691E059421A4FD7600F838EF /* arraysize.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = arraysize.h; sourceTree = ""; }; + 691E059521A4FD7600F838EF /* platform_file.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = platform_file.cc; sourceTree = ""; }; + 691E059621A4FD7600F838EF /* swap_queue.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = swap_queue.h; sourceTree = ""; }; + 691E059721A4FD7600F838EF /* string_to_number.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = string_to_number.cc; sourceTree = ""; }; + 691E059821A4FD7600F838EF /* trace_event.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = trace_event.h; sourceTree = ""; }; + 691E059921A4FD7600F838EF /* checks.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = checks.h; sourceTree = ""; }; + 691E059A21A4FD7600F838EF /* deprecation.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = deprecation.h; sourceTree = ""; }; + 691E059B21A4FD7600F838EF /* thread_checker_impl.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = thread_checker_impl.cc; sourceTree = ""; }; + 691E059C21A4FD7600F838EF /* sanitizer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = sanitizer.h; sourceTree = ""; }; + 691E059D21A4FD7600F838EF /* scoped_ref_ptr.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = scoped_ref_ptr.h; sourceTree = ""; }; + 691E059E21A4FD7600F838EF /* logging.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = logging.h; sourceTree = ""; }; + 691E059F21A4FD7600F838EF /* timeutils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = timeutils.h; sourceTree = ""; }; + 691E05A021A4FD7600F838EF /* atomicops.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = atomicops.h; sourceTree = ""; }; + 691E05A121A4FD7600F838EF /* stringencode.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = stringencode.cc; sourceTree = ""; }; + 691E05A221A4FD7600F838EF /* stringutils.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = stringutils.cc; sourceTree = ""; }; + 691E05A321A4FD7600F838EF /* checks.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = checks.cc; sourceTree = ""; }; + 691E05A521A4FD7600F838EF /* safe_minmax.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = safe_minmax.h; sourceTree = ""; }; + 691E05A621A4FD7600F838EF /* safe_conversions.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = safe_conversions.h; sourceTree = ""; }; + 691E05A721A4FD7600F838EF /* safe_conversions_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = safe_conversions_impl.h; sourceTree = ""; }; + 691E05A821A4FD7600F838EF /* safe_compare.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = safe_compare.h; sourceTree = ""; }; + 691E05AA21A4FD7600F838EF /* unused.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = unused.h; sourceTree = ""; }; + 691E05AB21A4FD7600F838EF /* inline.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = inline.h; sourceTree = ""; }; + 691E05AC21A4FD7600F838EF /* ignore_warnings.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ignore_warnings.h; sourceTree = ""; }; + 691E05AD21A4FD7600F838EF /* asm_defines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = asm_defines.h; sourceTree = ""; }; + 691E05AE21A4FD7600F838EF /* rtc_export.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = rtc_export.h; sourceTree = ""; }; + 691E05AF21A4FD7600F838EF /* arch.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = arch.h; sourceTree = ""; }; + 691E05B021A4FD7600F838EF /* platform_thread.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = platform_thread.cc; sourceTree = ""; }; + 691E05B121A4FD7600F838EF /* platform_thread.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = platform_thread.h; sourceTree = ""; }; + 691E05B221A4FD7600F838EF /* logging_webrtc.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = logging_webrtc.cc; sourceTree = ""; }; + 691E05B321A4FD7600F838EF /* platform_thread_types.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = platform_thread_types.h; sourceTree = ""; }; + 691E05B421A4FD7600F838EF /* protobuf_utils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = protobuf_utils.h; sourceTree = ""; }; + 691E05B521A4FD7600F838EF /* thread_annotations.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = thread_annotations.h; sourceTree = ""; }; + 691E05B621A4FD7600F838EF /* gtest_prod_util.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gtest_prod_util.h; sourceTree = ""; }; + 691E05B721A4FD7600F838EF /* function_view.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = function_view.h; sourceTree = ""; }; + 691E05B821A4FD7600F838EF /* criticalsection.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = criticalsection.h; sourceTree = ""; }; + 691E05B921A4FD7600F838EF /* criticalsection.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = criticalsection.cc; sourceTree = ""; }; + 691E05BA21A4FD7600F838EF /* platform_thread_types.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = platform_thread_types.cc; sourceTree = ""; }; + 691E05BB21A4FD7600F838EF /* refcount.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = refcount.h; sourceTree = ""; }; + 691E05BC21A4FD7600F838EF /* event.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = event.cc; sourceTree = ""; }; + 691E05BD21A4FD7600F838EF /* thread_checker_impl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = thread_checker_impl.h; sourceTree = ""; }; + 691E05BE21A4FD7600F838EF /* event_tracer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = event_tracer.cc; sourceTree = ""; }; + 691E05BF21A4FD7600F838EF /* compile_assert_c.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = compile_assert_c.h; sourceTree = ""; }; + 691E05C021A4FD7600F838EF /* type_traits.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = type_traits.h; sourceTree = ""; }; + 691E05C121A4FD7600F838EF /* platform_file.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = platform_file.h; sourceTree = ""; }; + 691E05C221A4FD7600F838EF /* refcounter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = refcounter.h; sourceTree = ""; }; + 691E05C321A4FD7600F838EF /* logging_mac.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = logging_mac.h; sourceTree = ""; }; + 691E05C421A4FD7600F838EF /* thread_checker.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = thread_checker.h; sourceTree = ""; }; + 691E05C521A4FD7600F838EF /* race_checker.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = race_checker.h; sourceTree = ""; }; + 691E05C621A4FD7600F838EF /* refcountedobject.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = refcountedobject.h; sourceTree = ""; }; + 692AB8881E6759DD00706ACC /* AudioInput.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = AudioInput.cpp; path = audio/AudioInput.cpp; sourceTree = SOURCE_ROOT; }; + 692AB8891E6759DD00706ACC /* AudioInput.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AudioInput.h; path = audio/AudioInput.h; sourceTree = SOURCE_ROOT; }; + 692AB88A1E6759DD00706ACC /* AudioOutput.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = AudioOutput.cpp; path = audio/AudioOutput.cpp; sourceTree = SOURCE_ROOT; }; + 692AB88B1E6759DD00706ACC /* AudioOutput.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AudioOutput.h; path = audio/AudioOutput.h; sourceTree = SOURCE_ROOT; }; + 692AB88C1E6759DD00706ACC /* BlockingQueue.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = BlockingQueue.cpp; sourceTree = SOURCE_ROOT; }; + 692AB88D1E6759DD00706ACC /* BlockingQueue.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = BlockingQueue.h; sourceTree = SOURCE_ROOT; }; + 692AB88E1E6759DD00706ACC /* Buffers.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = Buffers.cpp; sourceTree = SOURCE_ROOT; }; + 692AB88F1E6759DD00706ACC /* Buffers.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = Buffers.h; sourceTree = SOURCE_ROOT; }; + 692AB8901E6759DD00706ACC /* VoIPGroupController.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VoIPGroupController.cpp; sourceTree = SOURCE_ROOT; }; + 692AB8911E6759DD00706ACC /* PrivateDefines.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = PrivateDefines.h; sourceTree = SOURCE_ROOT; }; + 692AB8971E6759DD00706ACC /* CongestionControl.cpp */ = {isa = PBXFileReference; explicitFileType = sourcecode.cpp.objcpp; fileEncoding = 4; path = CongestionControl.cpp; sourceTree = SOURCE_ROOT; }; + 692AB8981E6759DD00706ACC /* CongestionControl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CongestionControl.h; sourceTree = SOURCE_ROOT; }; + 692AB8991E6759DD00706ACC /* EchoCanceller.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = EchoCanceller.cpp; sourceTree = SOURCE_ROOT; }; + 692AB89A1E6759DD00706ACC /* EchoCanceller.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = EchoCanceller.h; sourceTree = SOURCE_ROOT; }; + 692AB8A71E6759DD00706ACC /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = SOURCE_ROOT; }; + 692AB8A81E6759DD00706ACC /* JitterBuffer.cpp */ = {isa = PBXFileReference; explicitFileType = sourcecode.cpp.objcpp; fileEncoding = 4; path = JitterBuffer.cpp; sourceTree = SOURCE_ROOT; }; + 692AB8A91E6759DD00706ACC /* JitterBuffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = JitterBuffer.h; sourceTree = SOURCE_ROOT; }; + 692AB8AA1E6759DD00706ACC /* logging.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = logging.h; sourceTree = SOURCE_ROOT; }; + 692AB8AB1E6759DD00706ACC /* MediaStreamItf.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = MediaStreamItf.cpp; sourceTree = SOURCE_ROOT; }; + 692AB8AC1E6759DD00706ACC /* MediaStreamItf.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = MediaStreamItf.h; sourceTree = SOURCE_ROOT; }; + 692AB8AD1E6759DD00706ACC /* OpusDecoder.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = OpusDecoder.cpp; sourceTree = SOURCE_ROOT; }; + 692AB8AE1E6759DD00706ACC /* OpusDecoder.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = OpusDecoder.h; sourceTree = SOURCE_ROOT; }; + 692AB8AF1E6759DD00706ACC /* OpusEncoder.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = OpusEncoder.cpp; sourceTree = SOURCE_ROOT; }; + 692AB8B01E6759DD00706ACC /* OpusEncoder.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = OpusEncoder.h; sourceTree = SOURCE_ROOT; }; + 692AB8C61E6759DD00706ACC /* threading.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = threading.h; sourceTree = SOURCE_ROOT; }; + 692AB8C71E6759DD00706ACC /* VoIPController.cpp */ = {isa = PBXFileReference; explicitFileType = sourcecode.cpp.objcpp; fileEncoding = 4; path = VoIPController.cpp; sourceTree = SOURCE_ROOT; }; + 692AB8C81E6759DD00706ACC /* VoIPController.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VoIPController.h; sourceTree = SOURCE_ROOT; }; + 692AB8C91E6759DD00706ACC /* VoIPServerConfig.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VoIPServerConfig.cpp; sourceTree = SOURCE_ROOT; }; + 692AB8CA1E6759DD00706ACC /* VoIPServerConfig.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VoIPServerConfig.h; sourceTree = SOURCE_ROOT; }; + 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = Telegraph.xcodeproj; path = ../../Telegraph.xcodeproj; sourceTree = ""; }; + 692AB91C1E675F7000706ACC /* AudioToolbox.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = AudioToolbox.framework; path = System/Library/Frameworks/AudioToolbox.framework; sourceTree = SDKROOT; }; + 692AB91D1E675F7000706ACC /* AudioUnit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = AudioUnit.framework; path = System/Library/Frameworks/AudioUnit.framework; sourceTree = SDKROOT; }; + 692AB91E1E675F7000706ACC /* CoreAudio.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreAudio.framework; path = System/Library/Frameworks/CoreAudio.framework; sourceTree = SDKROOT; }; + 694DE89C219F2265009C09A7 /* VideoRenderer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VideoRenderer.h; sourceTree = ""; }; + 694DE89D219F2265009C09A7 /* VideoRenderer.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VideoRenderer.cpp; sourceTree = ""; }; + 694DE89E219F2265009C09A7 /* VideoSource.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VideoSource.cpp; sourceTree = ""; }; + 694DE89F219F2265009C09A7 /* VideoSource.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VideoSource.h; sourceTree = ""; }; + 695B20601EBD39FF00E31757 /* DarwinSpecific.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = DarwinSpecific.h; path = os/darwin/DarwinSpecific.h; sourceTree = SOURCE_ROOT; }; + 6970AF4A225FFEBE00F02034 /* VideoFEC.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VideoFEC.h; sourceTree = ""; }; + 6970AF4B225FFEBE00F02034 /* VideoPacketSender.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VideoPacketSender.cpp; sourceTree = ""; }; + 6970AF4C225FFEBE00F02034 /* VideoFEC.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = VideoFEC.cpp; sourceTree = ""; }; + 6970AF4D225FFEBE00F02034 /* VideoPacketSender.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VideoPacketSender.h; sourceTree = ""; }; + 6971220D20C8107E00971C2C /* PacketReassembler.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = PacketReassembler.cpp; sourceTree = SOURCE_ROOT; }; + 6971220E20C8107F00971C2C /* PacketReassembler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = PacketReassembler.h; sourceTree = SOURCE_ROOT; }; + 6976FD0120F6A7050019939E /* MessageThread.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = MessageThread.cpp; sourceTree = SOURCE_ROOT; }; + 6976FD0220F6A7060019939E /* MessageThread.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = MessageThread.h; sourceTree = SOURCE_ROOT; }; + 697B6FC42136DBA4004C8E54 /* libtgvoipTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = libtgvoipTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; }; + 697B6FC62136DBA4004C8E54 /* libtgvoipTests.mm */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.objcpp; path = libtgvoipTests.mm; sourceTree = ""; }; + 697B6FC82136DBA4004C8E54 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; + 697B6FD22136E18A004C8E54 /* AudioUnitIO.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AudioUnitIO.h; path = os/darwin/AudioUnitIO.h; sourceTree = SOURCE_ROOT; }; + 697B6FD42136E1F3004C8E54 /* AudioIO.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = AudioIO.cpp; sourceTree = ""; }; + 697B6FD52136E1F3004C8E54 /* AudioIO.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = AudioIO.h; sourceTree = ""; }; + 697B6FD82136E2D9004C8E54 /* AudioIOCallback.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = AudioIOCallback.cpp; sourceTree = ""; }; + 697B6FD92136E2D9004C8E54 /* AudioIOCallback.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = AudioIOCallback.h; sourceTree = ""; }; + 697B6FDC2136E673004C8E54 /* utils.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = utils.h; sourceTree = ""; }; + 697B6FDD2136F01E004C8E54 /* MockReflector.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = MockReflector.h; sourceTree = ""; }; + 697B6FDE2136F01E004C8E54 /* MockReflector.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; path = MockReflector.cpp; sourceTree = ""; }; + 69A2076421AF6289003AC4F9 /* json11.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = json11.cpp; sourceTree = ""; }; + 69A6DF3F1E9614B700000E69 /* AudioInputAudioUnitOSX.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = AudioInputAudioUnitOSX.cpp; path = os/darwin/AudioInputAudioUnitOSX.cpp; sourceTree = SOURCE_ROOT; }; + 69A6DF401E9614B700000E69 /* AudioInputAudioUnitOSX.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AudioInputAudioUnitOSX.h; path = os/darwin/AudioInputAudioUnitOSX.h; sourceTree = SOURCE_ROOT; }; + 69A6DF411E9614B700000E69 /* AudioOutputAudioUnitOSX.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = AudioOutputAudioUnitOSX.cpp; path = os/darwin/AudioOutputAudioUnitOSX.cpp; sourceTree = SOURCE_ROOT; }; + 69A6DF421E9614B700000E69 /* AudioOutputAudioUnitOSX.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AudioOutputAudioUnitOSX.h; path = os/darwin/AudioOutputAudioUnitOSX.h; sourceTree = SOURCE_ROOT; }; + 69DF15602237DEBB00C1F8ED /* ScreamCongestionController.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ScreamCongestionController.h; sourceTree = ""; }; + 69DF15612237DEBB00C1F8ED /* ScreamCongestionController.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ScreamCongestionController.cpp; sourceTree = ""; }; + 69DF15652237DEDA00C1F8ED /* TGVVideoRenderer.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; path = TGVVideoRenderer.mm; sourceTree = ""; }; + 69DF15672237DEDB00C1F8ED /* TGVVideoRenderer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = TGVVideoRenderer.h; sourceTree = ""; }; + 69DF15682237DEDB00C1F8ED /* TGVVideoSource.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = TGVVideoSource.h; sourceTree = ""; }; + 69DF15692237DEDB00C1F8ED /* TGVVideoSource.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; path = TGVVideoSource.mm; sourceTree = ""; }; + 69DF156B2237DEDC00C1F8ED /* VideoToolboxEncoderSource.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = VideoToolboxEncoderSource.h; sourceTree = ""; }; + 69DF156C2237DEDC00C1F8ED /* VideoToolboxEncoderSource.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; path = VideoToolboxEncoderSource.mm; sourceTree = ""; }; + 69DF157A2237DFE100C1F8ED /* SampleBufferDisplayLayerRenderer.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; path = SampleBufferDisplayLayerRenderer.mm; sourceTree = ""; }; + 69DF157D2237DFE700C1F8ED /* SampleBufferDisplayLayerRenderer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = SampleBufferDisplayLayerRenderer.h; sourceTree = ""; }; + 69DF157F2237E96E00C1F8ED /* VideoToolbox.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = VideoToolbox.framework; path = Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.14.sdk/System/Library/Frameworks/VideoToolbox.framework; sourceTree = DEVELOPER_DIR; }; + 69EBC7932136D277003CFE90 /* DarwinSpecific.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; name = DarwinSpecific.mm; path = os/darwin/DarwinSpecific.mm; sourceTree = SOURCE_ROOT; }; + 69EBC7952136D2A9003CFE90 /* Resampler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = Resampler.h; path = audio/Resampler.h; sourceTree = SOURCE_ROOT; }; + 69F842361E67540700C110F7 /* libtgvoip.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = libtgvoip.framework; sourceTree = BUILT_PRODUCTS_DIR; }; + C2A87DD71F4B6A33002D3F73 /* Resampler.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = Resampler.cpp; path = audio/Resampler.cpp; sourceTree = SOURCE_ROOT; }; + C2A87DDB1F4B6A61002D3F73 /* AudioInputAudioUnit.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = AudioInputAudioUnit.cpp; path = os/darwin/AudioInputAudioUnit.cpp; sourceTree = SOURCE_ROOT; }; + C2A87DDC1F4B6A61002D3F73 /* AudioInputAudioUnitOSX.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = AudioInputAudioUnitOSX.cpp; path = os/darwin/AudioInputAudioUnitOSX.cpp; sourceTree = SOURCE_ROOT; }; + C2A87DDD1F4B6A61002D3F73 /* AudioOutputAudioUnit.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = AudioOutputAudioUnit.cpp; path = os/darwin/AudioOutputAudioUnit.cpp; sourceTree = SOURCE_ROOT; }; + C2A87DDE1F4B6A61002D3F73 /* AudioOutputAudioUnitOSX.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = AudioOutputAudioUnitOSX.cpp; path = os/darwin/AudioOutputAudioUnitOSX.cpp; sourceTree = SOURCE_ROOT; }; + C2A87DE31F4B6AD3002D3F73 /* AudioUnitIO.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = AudioUnitIO.cpp; path = os/darwin/AudioUnitIO.cpp; sourceTree = SOURCE_ROOT; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 697B6FC12136DBA4004C8E54 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 697B6FC92136DBA4004C8E54 /* libtgvoip.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 69F842321E67540700C110F7 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + 69DF15802237E96E00C1F8ED /* VideoToolbox.framework in Frameworks */, + 692AB91F1E675F7000706ACC /* AudioToolbox.framework in Frameworks */, + 692AB9201E675F7000706ACC /* AudioUnit.framework in Frameworks */, + 692AB9211E675F7000706ACC /* CoreAudio.framework in Frameworks */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 690725BB1EBBD5DE005D860B /* posix */ = { + isa = PBXGroup; + children = ( + 690725BC1EBBD5DE005D860B /* NetworkSocketPosix.cpp */, + 690725BD1EBBD5DE005D860B /* NetworkSocketPosix.h */, + ); + path = posix; + sourceTree = ""; + }; + 691E032F21A4FD7500F838EF /* absl */ = { + isa = PBXGroup; + children = ( + 691E033021A4FD7500F838EF /* strings */, + 691E033821A4FD7500F838EF /* types */, + 691E033D21A4FD7500F838EF /* memory */, + 691E033F21A4FD7500F838EF /* meta */, + 691E034121A4FD7500F838EF /* algorithm */, + 691E034321A4FD7500F838EF /* container */, + 691E034521A4FD7500F838EF /* base */, + 691E035621A4FD7500F838EF /* utility */, + ); + path = absl; + sourceTree = ""; + }; + 691E033021A4FD7500F838EF /* strings */ = { + isa = PBXGroup; + children = ( + 691E033121A4FD7500F838EF /* internal */, + 691E033421A4FD7500F838EF /* string_view.cc */, + 691E033521A4FD7500F838EF /* ascii.h */, + 691E033621A4FD7500F838EF /* ascii.cc */, + 691E033721A4FD7500F838EF /* string_view.h */, + ); + path = strings; + sourceTree = ""; + }; + 691E033121A4FD7500F838EF /* internal */ = { + isa = PBXGroup; + children = ( + 691E033221A4FD7500F838EF /* memutil.h */, + 691E033321A4FD7500F838EF /* memutil.cc */, + ); + path = internal; + sourceTree = ""; + }; + 691E033821A4FD7500F838EF /* types */ = { + isa = PBXGroup; + children = ( + 691E033921A4FD7500F838EF /* optional.h */, + 691E033A21A4FD7500F838EF /* bad_optional_access.h */, + 691E033B21A4FD7500F838EF /* bad_optional_access.cc */, + 691E033C21A4FD7500F838EF /* optional.cc */, + ); + path = types; + sourceTree = ""; + }; + 691E033D21A4FD7500F838EF /* memory */ = { + isa = PBXGroup; + children = ( + 691E033E21A4FD7500F838EF /* memory.h */, + ); + path = memory; + sourceTree = ""; + }; + 691E033F21A4FD7500F838EF /* meta */ = { + isa = PBXGroup; + children = ( + 691E034021A4FD7500F838EF /* type_traits.h */, + ); + path = meta; + sourceTree = ""; + }; + 691E034121A4FD7500F838EF /* algorithm */ = { + isa = PBXGroup; + children = ( + 691E034221A4FD7500F838EF /* algorithm.h */, + ); + path = algorithm; + sourceTree = ""; + }; + 691E034321A4FD7500F838EF /* container */ = { + isa = PBXGroup; + children = ( + 691E034421A4FD7500F838EF /* inlined_vector.h */, + ); + path = container; + sourceTree = ""; + }; + 691E034521A4FD7500F838EF /* base */ = { + isa = PBXGroup; + children = ( + 691E034621A4FD7500F838EF /* policy_checks.h */, + 691E034721A4FD7500F838EF /* port.h */, + 691E034821A4FD7500F838EF /* config.h */, + 691E034921A4FD7500F838EF /* internal */, + 691E035221A4FD7500F838EF /* attributes.h */, + 691E035321A4FD7500F838EF /* macros.h */, + 691E035421A4FD7500F838EF /* optimization.h */, + 691E035521A4FD7500F838EF /* log_severity.h */, + ); + path = base; + sourceTree = ""; + }; + 691E034921A4FD7500F838EF /* internal */ = { + isa = PBXGroup; + children = ( + 691E034A21A4FD7500F838EF /* raw_logging.cc */, + 691E034B21A4FD7500F838EF /* throw_delegate.cc */, + 691E034C21A4FD7500F838EF /* invoke.h */, + 691E034D21A4FD7500F838EF /* inline_variable.h */, + 691E034E21A4FD7500F838EF /* atomic_hook.h */, + 691E034F21A4FD7500F838EF /* identity.h */, + 691E035021A4FD7500F838EF /* raw_logging.h */, + 691E035121A4FD7500F838EF /* throw_delegate.h */, + ); + path = internal; + sourceTree = ""; + }; + 691E035621A4FD7500F838EF /* utility */ = { + isa = PBXGroup; + children = ( + 691E035721A4FD7500F838EF /* utility.h */, + ); + path = utility; + sourceTree = ""; + }; + 691E035821A4FD7500F838EF /* common_audio */ = { + isa = PBXGroup; + children = ( + 691E035921A4FD7500F838EF /* mocks */, + 691E035B21A4FD7500F838EF /* wav_file.h */, + 691E035C21A4FD7500F838EF /* window_generator.cc */, + 691E035D21A4FD7500F838EF /* channel_buffer.cc */, + 691E035E21A4FD7500F838EF /* fir_filter_factory.cc */, + 691E035F21A4FD7500F838EF /* sparse_fir_filter.h */, + 691E036021A4FD7500F838EF /* fir_filter_sse.h */, + 691E036121A4FD7500F838EF /* window_generator.h */, + 691E036221A4FD7500F838EF /* ring_buffer.h */, + 691E036321A4FD7500F838EF /* fir_filter.h */, + 691E036421A4FD7500F838EF /* include */, + 691E036621A4FD7500F838EF /* wav_header.cc */, + 691E036721A4FD7500F838EF /* real_fourier_ooura.cc */, + 691E036821A4FD7500F838EF /* fir_filter_neon.cc */, + 691E036921A4FD7500F838EF /* audio_util.cc */, + 691E036A21A4FD7500F838EF /* real_fourier_ooura.h */, + 691E036B21A4FD7500F838EF /* fir_filter_sse.cc */, + 691E036C21A4FD7500F838EF /* smoothing_filter.h */, + 691E036D21A4FD7500F838EF /* resampler */, + 691E037B21A4FD7500F838EF /* fir_filter_factory.h */, + 691E037C21A4FD7500F838EF /* audio_converter.h */, + 691E037D21A4FD7500F838EF /* wav_file.cc */, + 691E037E21A4FD7500F838EF /* third_party */, + 691E038621A4FD7500F838EF /* audio_converter.cc */, + 691E038721A4FD7500F838EF /* real_fourier.cc */, + 691E038821A4FD7500F838EF /* channel_buffer.h */, + 691E038921A4FD7500F838EF /* real_fourier.h */, + 691E038A21A4FD7500F838EF /* sparse_fir_filter.cc */, + 691E038B21A4FD7500F838EF /* fir_filter_neon.h */, + 691E038C21A4FD7500F838EF /* smoothing_filter.cc */, + 691E038D21A4FD7500F838EF /* fir_filter_c.cc */, + 691E038E21A4FD7500F838EF /* ring_buffer.c */, + 691E038F21A4FD7500F838EF /* fir_filter_c.h */, + 691E039021A4FD7500F838EF /* signal_processing */, + 691E03BF21A4FD7500F838EF /* wav_header.h */, + 691E03C021A4FD7500F838EF /* vad */, + ); + path = common_audio; + sourceTree = ""; + }; + 691E035921A4FD7500F838EF /* mocks */ = { + isa = PBXGroup; + children = ( + 691E035A21A4FD7500F838EF /* mock_smoothing_filter.h */, + ); + path = mocks; + sourceTree = ""; + }; + 691E036421A4FD7500F838EF /* include */ = { + isa = PBXGroup; + children = ( + 691E036521A4FD7500F838EF /* audio_util.h */, + ); + path = include; + sourceTree = ""; + }; + 691E036D21A4FD7500F838EF /* resampler */ = { + isa = PBXGroup; + children = ( + 691E036E21A4FD7500F838EF /* sinc_resampler_neon.cc */, + 691E036F21A4FD7500F838EF /* push_sinc_resampler.cc */, + 691E037021A4FD7500F838EF /* sinc_resampler.h */, + 691E037121A4FD7500F838EF /* resampler.cc */, + 691E037221A4FD7500F838EF /* sinc_resampler_sse.cc */, + 691E037321A4FD7500F838EF /* include */, + 691E037621A4FD7500F838EF /* push_sinc_resampler.h */, + 691E037721A4FD7500F838EF /* push_resampler.cc */, + 691E037821A4FD7500F838EF /* sinusoidal_linear_chirp_source.h */, + 691E037921A4FD7500F838EF /* sinc_resampler.cc */, + 691E037A21A4FD7500F838EF /* sinusoidal_linear_chirp_source.cc */, + ); + path = resampler; + sourceTree = ""; + }; + 691E037321A4FD7500F838EF /* include */ = { + isa = PBXGroup; + children = ( + 691E037421A4FD7500F838EF /* push_resampler.h */, + 691E037521A4FD7500F838EF /* resampler.h */, + ); + path = include; + sourceTree = ""; + }; + 691E037E21A4FD7500F838EF /* third_party */ = { + isa = PBXGroup; + children = ( + 691E037F21A4FD7500F838EF /* spl_sqrt_floor */, + 691E038321A4FD7500F838EF /* fft4g */, + ); + path = third_party; + sourceTree = ""; + }; + 691E037F21A4FD7500F838EF /* spl_sqrt_floor */ = { + isa = PBXGroup; + children = ( + 691E038021A4FD7500F838EF /* spl_sqrt_floor.c */, + 691E038221A4FD7500F838EF /* spl_sqrt_floor.h */, + ); + path = spl_sqrt_floor; + sourceTree = ""; + }; + 691E038321A4FD7500F838EF /* fft4g */ = { + isa = PBXGroup; + children = ( + 691E038421A4FD7500F838EF /* fft4g.c */, + 691E038521A4FD7500F838EF /* fft4g.h */, + ); + path = fft4g; + sourceTree = ""; + }; + 691E039021A4FD7500F838EF /* signal_processing */ = { + isa = PBXGroup; + children = ( + 691E039121A4FD7500F838EF /* complex_fft_tables.h */, + 691E039221A4FD7500F838EF /* complex_fft.c */, + 691E039321A4FD7500F838EF /* filter_ma_fast_q12.c */, + 691E039421A4FD7500F838EF /* splitting_filter1.c */, + 691E039521A4FD7500F838EF /* levinson_durbin.c */, + 691E039621A4FD7500F838EF /* downsample_fast_neon.c */, + 691E039721A4FD7500F838EF /* dot_product_with_scale.cc */, + 691E039821A4FD7500F838EF /* auto_corr_to_refl_coef.c */, + 691E039921A4FD7500F838EF /* resample_by_2_internal.c */, + 691E039B21A4FD7500F838EF /* energy.c */, + 691E039C21A4FD7500F838EF /* sqrt_of_one_minus_x_squared.c */, + 691E039D21A4FD7500F838EF /* downsample_fast.c */, + 691E039E21A4FD7500F838EF /* filter_ar_fast_q12.c */, + 691E039F21A4FD7500F838EF /* spl_init.c */, + 691E03A021A4FD7500F838EF /* lpc_to_refl_coef.c */, + 691E03A121A4FD7500F838EF /* cross_correlation.c */, + 691E03A221A4FD7500F838EF /* include */, + 691E03A721A4FD7500F838EF /* division_operations.c */, + 691E03A821A4FD7500F838EF /* auto_correlation.c */, + 691E03A921A4FD7500F838EF /* get_scaling_square.c */, + 691E03AA21A4FD7500F838EF /* min_max_operations_neon.c */, + 691E03AB21A4FD7500F838EF /* dot_product_with_scale.h */, + 691E03AC21A4FD7500F838EF /* resample_by_2_internal.h */, + 691E03AD21A4FD7500F838EF /* resample.c */, + 691E03AE21A4FD7500F838EF /* cross_correlation_neon.c */, + 691E03AF21A4FD7500F838EF /* min_max_operations.c */, + 691E03B021A4FD7500F838EF /* refl_coef_to_lpc.c */, + 691E03B121A4FD7500F838EF /* filter_ar.c */, + 691E03B221A4FD7500F838EF /* vector_scaling_operations.c */, + 691E03B321A4FD7500F838EF /* resample_fractional.c */, + 691E03B421A4FD7500F838EF /* real_fft.c */, + 691E03B521A4FD7500F838EF /* ilbc_specific_functions.c */, + 691E03B621A4FD7500F838EF /* complex_bit_reverse.c */, + 691E03B721A4FD7500F838EF /* randomization_functions.c */, + 691E03B921A4FD7500F838EF /* copy_set_operations.c */, + 691E03BA21A4FD7500F838EF /* resample_by_2.c */, + 691E03BB21A4FD7500F838EF /* get_hanning_window.c */, + 691E03BC21A4FD7500F838EF /* resample_48khz.c */, + 691E03BD21A4FD7500F838EF /* spl_inl.c */, + 691E03BE21A4FD7500F838EF /* spl_sqrt.c */, + ); + path = signal_processing; + sourceTree = ""; + }; + 691E03A221A4FD7500F838EF /* include */ = { + isa = PBXGroup; + children = ( + 691E03A321A4FD7500F838EF /* signal_processing_library.h */, + 691E03A421A4FD7500F838EF /* real_fft.h */, + 691E03A521A4FD7500F838EF /* spl_inl.h */, + 691E03A621A4FD7500F838EF /* spl_inl_armv7.h */, + ); + path = include; + sourceTree = ""; + }; + 691E03C021A4FD7500F838EF /* vad */ = { + isa = PBXGroup; + children = ( + 691E03C121A4FD7500F838EF /* vad_sp.c */, + 691E03C221A4FD7500F838EF /* vad.cc */, + 691E03C321A4FD7500F838EF /* webrtc_vad.c */, + 691E03C421A4FD7500F838EF /* vad_core.h */, + 691E03C521A4FD7500F838EF /* include */, + 691E03C821A4FD7500F838EF /* vad_gmm.h */, + 691E03C921A4FD7500F838EF /* vad_filterbank.c */, + 691E03CA21A4FD7500F838EF /* vad_core.c */, + 691E03CB21A4FD7500F838EF /* vad_sp.h */, + 691E03CC21A4FD7500F838EF /* vad_filterbank.h */, + 691E03CD21A4FD7500F838EF /* vad_gmm.c */, + ); + path = vad; + sourceTree = ""; + }; + 691E03C521A4FD7500F838EF /* include */ = { + isa = PBXGroup; + children = ( + 691E03C621A4FD7500F838EF /* vad.h */, + 691E03C721A4FD7500F838EF /* webrtc_vad.h */, + ); + path = include; + sourceTree = ""; + }; + 691E03CE21A4FD7500F838EF /* api */ = { + isa = PBXGroup; + children = ( + 691E03CF21A4FD7500F838EF /* audio */, + 691E03D721A4FD7500F838EF /* array_view.h */, + ); + path = api; + sourceTree = ""; + }; + 691E03CF21A4FD7500F838EF /* audio */ = { + isa = PBXGroup; + children = ( + 691E03D021A4FD7500F838EF /* audio_frame.cc */, + 691E03D121A4FD7500F838EF /* echo_canceller3_config.h */, + 691E03D221A4FD7500F838EF /* echo_control.h */, + 691E03D321A4FD7500F838EF /* audio_frame.h */, + 691E03D421A4FD7500F838EF /* echo_canceller3_config.cc */, + 691E03D521A4FD7500F838EF /* echo_canceller3_factory.h */, + 691E03D621A4FD7500F838EF /* echo_canceller3_factory.cc */, + ); + path = audio; + sourceTree = ""; + }; + 691E03D821A4FD7500F838EF /* third_party */ = { + isa = PBXGroup; + children = ( + 691E03D921A4FD7500F838EF /* rnnoise */, + ); + path = third_party; + sourceTree = ""; + }; + 691E03D921A4FD7500F838EF /* rnnoise */ = { + isa = PBXGroup; + children = ( + 691E03DA21A4FD7500F838EF /* src */, + ); + path = rnnoise; + sourceTree = ""; + }; + 691E03DA21A4FD7500F838EF /* src */ = { + isa = PBXGroup; + children = ( + 691E03DB21A4FD7500F838EF /* rnn_vad_weights.cc */, + 691E03DC21A4FD7500F838EF /* rnn_activations.h */, + 691E03DD21A4FD7500F838EF /* kiss_fft.h */, + 691E03DE21A4FD7500F838EF /* kiss_fft.cc */, + 691E03DF21A4FD7500F838EF /* rnn_vad_weights.h */, + ); + path = src; + sourceTree = ""; + }; + 691E03E021A4FD7500F838EF /* system_wrappers */ = { + isa = PBXGroup; + children = ( + 691E03E121A4FD7500F838EF /* include */, + 691E03E721A4FD7500F838EF /* source */, + ); + path = system_wrappers; + sourceTree = ""; + }; + 691E03E121A4FD7500F838EF /* include */ = { + isa = PBXGroup; + children = ( + 691E03E221A4FD7500F838EF /* field_trial.h */, + 691E03E321A4FD7500F838EF /* cpu_features_wrapper.h */, + 691E03E421A4FD7500F838EF /* asm_defines.h */, + 691E03E521A4FD7500F838EF /* metrics.h */, + 691E03E621A4FD7500F838EF /* compile_assert_c.h */, + ); + path = include; + sourceTree = ""; + }; + 691E03E721A4FD7500F838EF /* source */ = { + isa = PBXGroup; + children = ( + 691E03E821A4FD7500F838EF /* field_trial.cc */, + 691E03E921A4FD7500F838EF /* metrics.cc */, + 691E03EA21A4FD7500F838EF /* cpu_features.cc */, + ); + path = source; + sourceTree = ""; + }; + 691E03EB21A4FD7500F838EF /* modules */ = { + isa = PBXGroup; + children = ( + 691E03EC21A4FD7500F838EF /* third_party */, + 691E03F021A4FD7500F838EF /* audio_coding */, + 691E042921A4FD7500F838EF /* audio_processing */, + ); + path = modules; + sourceTree = ""; + }; + 691E03EC21A4FD7500F838EF /* third_party */ = { + isa = PBXGroup; + children = ( + 691E03ED21A4FD7500F838EF /* fft */, + ); + path = third_party; + sourceTree = ""; + }; + 691E03ED21A4FD7500F838EF /* fft */ = { + isa = PBXGroup; + children = ( + 691E03EE21A4FD7500F838EF /* fft.h */, + 691E03EF21A4FD7500F838EF /* fft.c */, + ); + path = fft; + sourceTree = ""; + }; + 691E03F021A4FD7500F838EF /* audio_coding */ = { + isa = PBXGroup; + children = ( + 691E03F121A4FD7500F838EF /* codecs */, + ); + path = audio_coding; + sourceTree = ""; + }; + 691E03F121A4FD7500F838EF /* codecs */ = { + isa = PBXGroup; + children = ( + 691E03F221A4FD7500F838EF /* isac */, + ); + path = codecs; + sourceTree = ""; + }; + 691E03F221A4FD7500F838EF /* isac */ = { + isa = PBXGroup; + children = ( + 691E03F321A4FD7500F838EF /* bandwidth_info.h */, + 691E03F421A4FD7500F838EF /* main */, + ); + path = isac; + sourceTree = ""; + }; + 691E03F421A4FD7500F838EF /* main */ = { + isa = PBXGroup; + children = ( + 691E03F521A4FD7500F838EF /* include */, + 691E03F721A4FD7500F838EF /* source */, + ); + path = main; + sourceTree = ""; + }; + 691E03F521A4FD7500F838EF /* include */ = { + isa = PBXGroup; + children = ( + 691E03F621A4FD7500F838EF /* isac.h */, + ); + path = include; + sourceTree = ""; + }; + 691E03F721A4FD7500F838EF /* source */ = { + isa = PBXGroup; + children = ( + 691E03F821A4FD7500F838EF /* pitch_estimator.c */, + 691E03F921A4FD7500F838EF /* lpc_shape_swb16_tables.c */, + 691E03FA21A4FD7500F838EF /* pitch_gain_tables.c */, + 691E03FB21A4FD7500F838EF /* arith_routines_logist.c */, + 691E03FC21A4FD7500F838EF /* os_specific_inline.h */, + 691E03FD21A4FD7500F838EF /* filterbanks.c */, + 691E03FE21A4FD7500F838EF /* entropy_coding.h */, + 691E03FF21A4FD7500F838EF /* isac_vad.h */, + 691E040021A4FD7500F838EF /* settings.h */, + 691E040121A4FD7500F838EF /* transform.c */, + 691E040221A4FD7500F838EF /* lpc_shape_swb12_tables.h */, + 691E040321A4FD7500F838EF /* arith_routines.h */, + 691E040421A4FD7500F838EF /* crc.h */, + 691E040521A4FD7500F838EF /* pitch_filter.c */, + 691E040621A4FD7500F838EF /* encode_lpc_swb.c */, + 691E040721A4FD7500F838EF /* filter_functions.c */, + 691E040821A4FD7500F838EF /* decode.c */, + 691E040921A4FD7500F838EF /* lattice.c */, + 691E040A21A4FD7500F838EF /* intialize.c */, + 691E040B21A4FD7500F838EF /* lpc_tables.c */, + 691E040C21A4FD7500F838EF /* lpc_gain_swb_tables.c */, + 691E040D21A4FD7500F838EF /* bandwidth_estimator.c */, + 691E040E21A4FD7500F838EF /* isac_float_type.h */, + 691E040F21A4FD7500F838EF /* pitch_lag_tables.h */, + 691E041021A4FD7500F838EF /* encode.c */, + 691E041121A4FD7500F838EF /* lpc_analysis.c */, + 691E041221A4FD7500F838EF /* spectrum_ar_model_tables.h */, + 691E041321A4FD7500F838EF /* arith_routines_hist.c */, + 691E041421A4FD7500F838EF /* codec.h */, + 691E041521A4FD7500F838EF /* pitch_gain_tables.h */, + 691E041621A4FD7500F838EF /* lpc_shape_swb16_tables.h */, + 691E041721A4FD7500F838EF /* pitch_estimator.h */, + 691E041821A4FD7500F838EF /* entropy_coding.c */, + 691E041921A4FD7500F838EF /* isac_vad.c */, + 691E041A21A4FD7500F838EF /* structs.h */, + 691E041B21A4FD7500F838EF /* filter_functions.h */, + 691E041C21A4FD7500F838EF /* encode_lpc_swb.h */, + 691E041D21A4FD7500F838EF /* pitch_filter.h */, + 691E041E21A4FD7500F838EF /* arith_routines.c */, + 691E041F21A4FD7500F838EF /* crc.c */, + 691E042021A4FD7500F838EF /* lpc_shape_swb12_tables.c */, + 691E042121A4FD7500F838EF /* lpc_analysis.h */, + 691E042221A4FD7500F838EF /* decode_bwe.c */, + 691E042321A4FD7500F838EF /* spectrum_ar_model_tables.c */, + 691E042421A4FD7500F838EF /* bandwidth_estimator.h */, + 691E042521A4FD7500F838EF /* pitch_lag_tables.c */, + 691E042621A4FD7500F838EF /* isac.c */, + 691E042721A4FD7500F838EF /* lpc_gain_swb_tables.h */, + 691E042821A4FD7500F838EF /* lpc_tables.h */, + ); + path = source; + sourceTree = ""; + }; + 691E042921A4FD7500F838EF /* audio_processing */ = { + isa = PBXGroup; + children = ( + 691E042A21A4FD7500F838EF /* rms_level.cc */, + 691E042B21A4FD7500F838EF /* echo_detector */, + 691E043421A4FD7600F838EF /* gain_control_for_experimental_agc.h */, + 691E043521A4FD7600F838EF /* splitting_filter.cc */, + 691E043621A4FD7600F838EF /* gain_control_impl.cc */, + 691E043721A4FD7600F838EF /* rms_level.h */, + 691E043821A4FD7600F838EF /* test */, + 691E043C21A4FD7600F838EF /* ns */, + 691E044A21A4FD7600F838EF /* residual_echo_detector.h */, + 691E044B21A4FD7600F838EF /* audio_processing_impl.h */, + 691E044C21A4FD7600F838EF /* audio_buffer.cc */, + 691E044D21A4FD7600F838EF /* typing_detection.cc */, + 691E044E21A4FD7600F838EF /* render_queue_item_verifier.h */, + 691E044F21A4FD7600F838EF /* aec_dump */, + 691E045021A4FD7600F838EF /* include */, + 691E045F21A4FD7600F838EF /* agc2 */, + 691E04A121A4FD7600F838EF /* transient */, + 691E04AF21A4FD7600F838EF /* low_cut_filter.cc */, + 691E04B021A4FD7600F838EF /* noise_suppression_impl.h */, + 691E04B121A4FD7600F838EF /* level_estimator_impl.cc */, + 691E04B221A4FD7600F838EF /* three_band_filter_bank.cc */, + 691E04B321A4FD7600F838EF /* aec */, + 691E04BE21A4FD7600F838EF /* voice_detection_impl.h */, + 691E04BF21A4FD7600F838EF /* voice_detection_impl.cc */, + 691E04C021A4FD7600F838EF /* echo_cancellation_impl.cc */, + 691E04C121A4FD7600F838EF /* gain_control_for_experimental_agc.cc */, + 691E04C221A4FD7600F838EF /* agc */, + 691E04D321A4FD7600F838EF /* common.h */, + 691E04D421A4FD7600F838EF /* audio_processing_impl.cc */, + 691E04D521A4FD7600F838EF /* audio_buffer.h */, + 691E04D621A4FD7600F838EF /* echo_control_mobile_impl.h */, + 691E04D721A4FD7600F838EF /* splitting_filter.h */, + 691E04D821A4FD7600F838EF /* low_cut_filter.h */, + 691E04D921A4FD7600F838EF /* audio_generator */, + 691E04DC21A4FD7600F838EF /* gain_controller2.cc */, + 691E04DD21A4FD7600F838EF /* three_band_filter_bank.h */, + 691E04DE21A4FD7600F838EF /* residual_echo_detector.cc */, + 691E04DF21A4FD7600F838EF /* echo_cancellation_impl.h */, + 691E04E021A4FD7600F838EF /* noise_suppression_impl.cc */, + 691E04E121A4FD7600F838EF /* level_estimator_impl.h */, + 691E04E221A4FD7600F838EF /* gain_controller2.h */, + 691E04E321A4FD7600F838EF /* aecm */, + 691E04EB21A4FD7600F838EF /* aec3 */, + 691E055A21A4FD7600F838EF /* echo_control_mobile_impl.cc */, + 691E055B21A4FD7600F838EF /* gain_control_impl.h */, + 691E055C21A4FD7600F838EF /* typing_detection.h */, + 691E055D21A4FD7600F838EF /* logging */, + 691E056021A4FD7600F838EF /* vad */, + 691E057521A4FD7600F838EF /* utility */, + ); + path = audio_processing; + sourceTree = ""; + }; + 691E042B21A4FD7500F838EF /* echo_detector */ = { + isa = PBXGroup; + children = ( + 691E042C21A4FD7500F838EF /* moving_max.h */, + 691E042D21A4FD7600F838EF /* circular_buffer.h */, + 691E042E21A4FD7600F838EF /* normalized_covariance_estimator.h */, + 691E042F21A4FD7600F838EF /* normalized_covariance_estimator.cc */, + 691E043021A4FD7600F838EF /* moving_max.cc */, + 691E043121A4FD7600F838EF /* circular_buffer.cc */, + 691E043221A4FD7600F838EF /* mean_variance_estimator.cc */, + 691E043321A4FD7600F838EF /* mean_variance_estimator.h */, + ); + path = echo_detector; + sourceTree = ""; + }; + 691E043821A4FD7600F838EF /* test */ = { + isa = PBXGroup; + children = ( + 691E043921A4FD7600F838EF /* android */, + ); + path = test; + sourceTree = ""; + }; + 691E043921A4FD7600F838EF /* android */ = { + isa = PBXGroup; + children = ( + 691E043A21A4FD7600F838EF /* apmtest */, + ); + path = android; + sourceTree = ""; + }; + 691E043A21A4FD7600F838EF /* apmtest */ = { + isa = PBXGroup; + children = ( + 691E043B21A4FD7600F838EF /* jni */, + ); + path = apmtest; + sourceTree = ""; + }; + 691E043B21A4FD7600F838EF /* jni */ = { + isa = PBXGroup; + children = ( + ); + path = jni; + sourceTree = ""; + }; + 691E043C21A4FD7600F838EF /* ns */ = { + isa = PBXGroup; + children = ( + 691E043D21A4FD7600F838EF /* ns_core.h */, + 691E043E21A4FD7600F838EF /* nsx_core.c */, + 691E043F21A4FD7600F838EF /* noise_suppression_x.c */, + 691E044021A4FD7600F838EF /* nsx_core_c.c */, + 691E044121A4FD7600F838EF /* defines.h */, + 691E044221A4FD7600F838EF /* noise_suppression.h */, + 691E044321A4FD7600F838EF /* ns_core.c */, + 691E044421A4FD7600F838EF /* nsx_core.h */, + 691E044521A4FD7600F838EF /* windows_private.h */, + 691E044621A4FD7600F838EF /* noise_suppression_x.h */, + 691E044721A4FD7600F838EF /* nsx_core_neon.c */, + 691E044821A4FD7600F838EF /* noise_suppression.c */, + 691E044921A4FD7600F838EF /* nsx_defines.h */, + ); + path = ns; + sourceTree = ""; + }; + 691E044F21A4FD7600F838EF /* aec_dump */ = { + isa = PBXGroup; + children = ( + ); + path = aec_dump; + sourceTree = ""; + }; + 691E045021A4FD7600F838EF /* include */ = { + isa = PBXGroup; + children = ( + 691E045121A4FD7600F838EF /* audio_generator.h */, + 691E045221A4FD7600F838EF /* config.h */, + 691E045321A4FD7600F838EF /* audio_frame_view.h */, + 691E045421A4FD7600F838EF /* mock_audio_processing.h */, + 691E045521A4FD7600F838EF /* gain_control.h */, + 691E045621A4FD7600F838EF /* audio_generator_factory.h */, + 691E045721A4FD7600F838EF /* audio_processing_statistics.cc */, + 691E045821A4FD7600F838EF /* audio_generator_factory.cc */, + 691E045921A4FD7600F838EF /* aec_dump.cc */, + 691E045A21A4FD7600F838EF /* aec_dump.h */, + 691E045B21A4FD7600F838EF /* audio_processing_statistics.h */, + 691E045C21A4FD7600F838EF /* audio_processing.h */, + 691E045D21A4FD7600F838EF /* audio_processing.cc */, + 691E045E21A4FD7600F838EF /* config.cc */, + ); + path = include; + sourceTree = ""; + }; + 691E045F21A4FD7600F838EF /* agc2 */ = { + isa = PBXGroup; + children = ( + 691E046021A4FD7600F838EF /* interpolated_gain_curve.h */, + 691E046121A4FD7600F838EF /* biquad_filter.h */, + 691E046221A4FD7600F838EF /* interpolated_gain_curve.cc */, + 691E046321A4FD7600F838EF /* agc2_common.cc */, + 691E046421A4FD7600F838EF /* agc2_testing_common.h */, + 691E046521A4FD7600F838EF /* adaptive_mode_level_estimator.h */, + 691E046621A4FD7600F838EF /* gain_applier.cc */, + 691E046721A4FD7600F838EF /* signal_classifier.h */, + 691E046821A4FD7600F838EF /* adaptive_agc.cc */, + 691E046921A4FD7600F838EF /* adaptive_digital_gain_applier.cc */, + 691E046A21A4FD7600F838EF /* limiter.cc */, + 691E046B21A4FD7600F838EF /* saturation_protector.cc */, + 691E046C21A4FD7600F838EF /* vector_float_frame.h */, + 691E046D21A4FD7600F838EF /* rnn_vad */, + 691E048421A4FD7600F838EF /* fixed_gain_controller.h */, + 691E048521A4FD7600F838EF /* adaptive_mode_level_estimator_agc.cc */, + 691E048621A4FD7600F838EF /* vector_float_frame.cc */, + 691E048721A4FD7600F838EF /* down_sampler.h */, + 691E048821A4FD7600F838EF /* noise_level_estimator.cc */, + 691E048921A4FD7600F838EF /* agc2_testing_common.cc */, + 691E048A21A4FD7600F838EF /* fixed_digital_level_estimator.cc */, + 691E048B21A4FD7600F838EF /* fixed_gain_controller.cc */, + 691E048C21A4FD7600F838EF /* saturation_protector.h */, + 691E048D21A4FD7600F838EF /* vad_with_level.cc */, + 691E048E21A4FD7600F838EF /* limiter_db_gain_curve.cc */, + 691E048F21A4FD7600F838EF /* agc2_common.h */, + 691E049021A4FD7600F838EF /* adaptive_mode_level_estimator_agc.h */, + 691E049121A4FD7600F838EF /* adaptive_digital_gain_applier.h */, + 691E049221A4FD7600F838EF /* vad_with_level.h */, + 691E049321A4FD7600F838EF /* limiter_db_gain_curve.h */, + 691E049421A4FD7600F838EF /* fixed_digital_level_estimator.h */, + 691E049521A4FD7600F838EF /* adaptive_agc.h */, + 691E049621A4FD7600F838EF /* gain_applier.h */, + 691E049721A4FD7600F838EF /* down_sampler.cc */, + 691E049821A4FD7600F838EF /* noise_level_estimator.h */, + 691E049921A4FD7600F838EF /* signal_classifier.cc */, + 691E049A21A4FD7600F838EF /* noise_spectrum_estimator.cc */, + 691E049B21A4FD7600F838EF /* compute_interpolated_gain_curve.cc */, + 691E049C21A4FD7600F838EF /* compute_interpolated_gain_curve.h */, + 691E049D21A4FD7600F838EF /* biquad_filter.cc */, + 691E049E21A4FD7600F838EF /* noise_spectrum_estimator.h */, + 691E049F21A4FD7600F838EF /* limiter.h */, + 691E04A021A4FD7600F838EF /* adaptive_mode_level_estimator.cc */, + ); + path = agc2; + sourceTree = ""; + }; + 691E046D21A4FD7600F838EF /* rnn_vad */ = { + isa = PBXGroup; + children = ( + 691E046E21A4FD7600F838EF /* spectral_features_internal.cc */, + 691E046F21A4FD7600F838EF /* sequence_buffer.h */, + 691E047021A4FD7600F838EF /* rnn.h */, + 691E047121A4FD7600F838EF /* rnn.cc */, + 691E047221A4FD7600F838EF /* test_utils.h */, + 691E047321A4FD7600F838EF /* pitch_info.h */, + 691E047421A4FD7600F838EF /* lp_residual.h */, + 691E047521A4FD7600F838EF /* ring_buffer.h */, + 691E047621A4FD7600F838EF /* pitch_search_internal.cc */, + 691E047721A4FD7600F838EF /* symmetric_matrix_buffer.h */, + 691E047821A4FD7600F838EF /* spectral_features.h */, + 691E047921A4FD7600F838EF /* features_extraction.h */, + 691E047A21A4FD7600F838EF /* common.h */, + 691E047B21A4FD7600F838EF /* spectral_features_internal.h */, + 691E047C21A4FD7600F838EF /* fft_util.h */, + 691E047D21A4FD7600F838EF /* spectral_features.cc */, + 691E047E21A4FD7600F838EF /* pitch_search_internal.h */, + 691E047F21A4FD7600F838EF /* pitch_search.cc */, + 691E048021A4FD7600F838EF /* pitch_search.h */, + 691E048121A4FD7600F838EF /* features_extraction.cc */, + 691E048221A4FD7600F838EF /* fft_util.cc */, + 691E048321A4FD7600F838EF /* lp_residual.cc */, + ); + path = rnn_vad; + sourceTree = ""; + }; + 691E04A121A4FD7600F838EF /* transient */ = { + isa = PBXGroup; + children = ( + 691E04A221A4FD7600F838EF /* moving_moments.cc */, + 691E04A321A4FD7600F838EF /* transient_detector.h */, + 691E04A421A4FD7600F838EF /* wpd_tree.cc */, + 691E04A521A4FD7600F838EF /* transient_suppressor.h */, + 691E04A621A4FD7600F838EF /* daubechies_8_wavelet_coeffs.h */, + 691E04A721A4FD7600F838EF /* common.h */, + 691E04A821A4FD7600F838EF /* wpd_node.h */, + 691E04A921A4FD7600F838EF /* moving_moments.h */, + 691E04AA21A4FD7600F838EF /* wpd_tree.h */, + 691E04AB21A4FD7600F838EF /* wpd_node.cc */, + 691E04AC21A4FD7600F838EF /* transient_suppressor.cc */, + 691E04AD21A4FD7600F838EF /* transient_detector.cc */, + 691E04AE21A4FD7600F838EF /* dyadic_decimator.h */, + ); + path = transient; + sourceTree = ""; + }; + 691E04B321A4FD7600F838EF /* aec */ = { + isa = PBXGroup; + children = ( + 691E04B421A4FD7600F838EF /* echo_cancellation.cc */, + 691E04B521A4FD7600F838EF /* aec_resampler.h */, + 691E04B621A4FD7600F838EF /* aec_resampler.cc */, + 691E04B721A4FD7600F838EF /* echo_cancellation.h */, + 691E04B821A4FD7600F838EF /* aec_core.cc */, + 691E04B921A4FD7600F838EF /* aec_core.h */, + 691E04BA21A4FD7600F838EF /* aec_core_optimized_methods.h */, + 691E04BB21A4FD7600F838EF /* aec_core_neon.cc */, + 691E04BC21A4FD7600F838EF /* aec_core_sse2.cc */, + 691E04BD21A4FD7600F838EF /* aec_common.h */, + ); + path = aec; + sourceTree = ""; + }; + 691E04C221A4FD7600F838EF /* agc */ = { + isa = PBXGroup; + children = ( + 691E04C321A4FD7600F838EF /* agc.cc */, + 691E04C421A4FD7600F838EF /* loudness_histogram.cc */, + 691E04C521A4FD7600F838EF /* agc_manager_direct.cc */, + 691E04C621A4FD7600F838EF /* legacy */, + 691E04CC21A4FD7600F838EF /* utility.cc */, + 691E04CD21A4FD7600F838EF /* mock_agc.h */, + 691E04CE21A4FD7600F838EF /* loudness_histogram.h */, + 691E04CF21A4FD7600F838EF /* gain_map_internal.h */, + 691E04D021A4FD7600F838EF /* utility.h */, + 691E04D121A4FD7600F838EF /* agc_manager_direct.h */, + 691E04D221A4FD7600F838EF /* agc.h */, + ); + path = agc; + sourceTree = ""; + }; + 691E04C621A4FD7600F838EF /* legacy */ = { + isa = PBXGroup; + children = ( + 691E04C721A4FD7600F838EF /* analog_agc.h */, + 691E04C821A4FD7600F838EF /* gain_control.h */, + 691E04C921A4FD7600F838EF /* digital_agc.h */, + 691E04CA21A4FD7600F838EF /* analog_agc.c */, + 691E04CB21A4FD7600F838EF /* digital_agc.c */, + ); + path = legacy; + sourceTree = ""; + }; + 691E04D921A4FD7600F838EF /* audio_generator */ = { + isa = PBXGroup; + children = ( + 691E04DA21A4FD7600F838EF /* file_audio_generator.h */, + 691E04DB21A4FD7600F838EF /* file_audio_generator.cc */, + ); + path = audio_generator; + sourceTree = ""; + }; + 691E04E321A4FD7600F838EF /* aecm */ = { + isa = PBXGroup; + children = ( + 691E04E421A4FD7600F838EF /* aecm_core.h */, + 691E04E521A4FD7600F838EF /* aecm_defines.h */, + 691E04E621A4FD7600F838EF /* aecm_core.cc */, + 691E04E721A4FD7600F838EF /* aecm_core_c.cc */, + 691E04E821A4FD7600F838EF /* aecm_core_neon.cc */, + 691E04E921A4FD7600F838EF /* echo_control_mobile.h */, + 691E04EA21A4FD7600F838EF /* echo_control_mobile.cc */, + ); + path = aecm; + sourceTree = ""; + }; + 691E04EB21A4FD7600F838EF /* aec3 */ = { + isa = PBXGroup; + children = ( + 691E04EC21A4FD7600F838EF /* render_reverb_model.cc */, + 691E04ED21A4FD7600F838EF /* downsampled_render_buffer.h */, + 691E04EE21A4FD7600F838EF /* subtractor_output_analyzer.h */, + 691E04EF21A4FD7600F838EF /* reverb_model_fallback.cc */, + 691E04F021A4FD7600F838EF /* residual_echo_estimator.h */, + 691E04F121A4FD7600F838EF /* shadow_filter_update_gain.h */, + 691E04F221A4FD7600F838EF /* echo_remover_metrics.cc */, + 691E04F321A4FD7600F838EF /* matched_filter_lag_aggregator.cc */, + 691E04F421A4FD7600F838EF /* render_delay_buffer2.cc */, + 691E04F521A4FD7600F838EF /* aec_state.h */, + 691E04F621A4FD7600F838EF /* suppression_filter.h */, + 691E04F721A4FD7600F838EF /* echo_path_variability.cc */, + 691E04F821A4FD7600F838EF /* frame_blocker.cc */, + 691E04F921A4FD7600F838EF /* subtractor.cc */, + 691E04FA21A4FD7600F838EF /* block_delay_buffer.h */, + 691E04FB21A4FD7600F838EF /* adaptive_fir_filter.h */, + 691E04FC21A4FD7600F838EF /* cascaded_biquad_filter.h */, + 691E04FD21A4FD7600F838EF /* matched_filter.h */, + 691E04FE21A4FD7600F838EF /* subtractor_output.h */, + 691E04FF21A4FD7600F838EF /* render_signal_analyzer.h */, + 691E050021A4FD7600F838EF /* aec3_fft.cc */, + 691E050121A4FD7600F838EF /* aec3_fft.h */, + 691E050221A4FD7600F838EF /* echo_remover_metrics.h */, + 691E050321A4FD7600F838EF /* fullband_erle_estimator.cc */, + 691E050421A4FD7600F838EF /* suppression_filter.cc */, + 691E050521A4FD7600F838EF /* block_processor.cc */, + 691E050621A4FD7600F838EF /* filter_analyzer.h */, + 691E050721A4FD7600F838EF /* subtractor.h */, + 691E050821A4FD7600F838EF /* echo_path_delay_estimator.h */, + 691E050921A4FD7600F838EF /* subband_erle_estimator.cc */, + 691E050A21A4FD7600F838EF /* render_delay_controller_metrics.cc */, + 691E050B21A4FD7600F838EF /* render_delay_buffer.cc */, + 691E050C21A4FD7600F838EF /* block_processor_metrics.h */, + 691E050D21A4FD7600F838EF /* vector_buffer.cc */, + 691E050E21A4FD7600F838EF /* erl_estimator.cc */, + 691E050F21A4FD7600F838EF /* aec_state.cc */, + 691E051021A4FD7600F838EF /* adaptive_fir_filter.cc */, + 691E051121A4FD7600F838EF /* fft_data.h */, + 691E051221A4FD7600F838EF /* render_delay_controller.cc */, + 691E051321A4FD7600F838EF /* skew_estimator.cc */, + 691E051421A4FD7600F838EF /* render_delay_controller_metrics.h */, + 691E051521A4FD7600F838EF /* comfort_noise_generator.h */, + 691E051621A4FD7600F838EF /* echo_path_delay_estimator.cc */, + 691E051721A4FD7600F838EF /* erl_estimator.h */, + 691E051821A4FD7600F838EF /* echo_remover.h */, + 691E051921A4FD7600F838EF /* block_framer.cc */, + 691E051A21A4FD7600F838EF /* erle_estimator.cc */, + 691E051B21A4FD7600F838EF /* reverb_model.cc */, + 691E051C21A4FD7600F838EF /* cascaded_biquad_filter.cc */, + 691E051D21A4FD7600F838EF /* matrix_buffer.h */, + 691E051E21A4FD7600F838EF /* render_buffer.cc */, + 691E051F21A4FD7600F838EF /* reverb_model_estimator.h */, + 691E052021A4FD7600F838EF /* subtractor_output.cc */, + 691E052121A4FD7600F838EF /* stationarity_estimator.cc */, + 691E052221A4FD7600F838EF /* render_signal_analyzer.cc */, + 691E052321A4FD7600F838EF /* echo_path_variability.h */, + 691E052421A4FD7600F838EF /* moving_average.h */, + 691E052521A4FD7600F838EF /* render_reverb_model.h */, + 691E052621A4FD7600F838EF /* subtractor_output_analyzer.cc */, + 691E052721A4FD7600F838EF /* suppression_gain.cc */, + 691E052821A4FD7600F838EF /* echo_audibility.cc */, + 691E052921A4FD7600F838EF /* block_processor_metrics.cc */, + 691E052A21A4FD7600F838EF /* render_delay_controller.h */, + 691E052B21A4FD7600F838EF /* suppression_gain.h */, + 691E052C21A4FD7600F838EF /* moving_average.cc */, + 691E052D21A4FD7600F838EF /* erle_estimator.h */, + 691E052E21A4FD7600F838EF /* subband_erle_estimator.h */, + 691E052F21A4FD7600F838EF /* reverb_model_estimator.cc */, + 691E053021A4FD7600F838EF /* aec3_common.cc */, + 691E053121A4FD7600F838EF /* residual_echo_estimator.cc */, + 691E053221A4FD7600F838EF /* block_processor.h */, + 691E053321A4FD7600F838EF /* fullband_erle_estimator.h */, + 691E053421A4FD7600F838EF /* matched_filter.cc */, + 691E053521A4FD7600F838EF /* stationarity_estimator.h */, + 691E053621A4FD7600F838EF /* echo_canceller3.h */, + 691E053721A4FD7600F838EF /* skew_estimator.h */, + 691E053821A4FD7600F838EF /* reverb_decay_estimator.cc */, + 691E053921A4FD7600F838EF /* render_delay_controller2.cc */, + 691E053A21A4FD7600F838EF /* render_buffer.h */, + 691E053B21A4FD7600F838EF /* suppression_gain_limiter.cc */, + 691E053C21A4FD7600F838EF /* main_filter_update_gain.cc */, + 691E053D21A4FD7600F838EF /* echo_remover.cc */, + 691E053E21A4FD7600F838EF /* reverb_model_fallback.h */, + 691E053F21A4FD7600F838EF /* downsampled_render_buffer.cc */, + 691E054021A4FD7600F838EF /* vector_buffer.h */, + 691E054121A4FD7600F838EF /* matrix_buffer.cc */, + 691E054221A4FD7600F838EF /* reverb_frequency_response.h */, + 691E054321A4FD7600F838EF /* echo_audibility.h */, + 691E054421A4FD7600F838EF /* fft_buffer.h */, + 691E054521A4FD7600F838EF /* block_processor2.cc */, + 691E054621A4FD7600F838EF /* echo_canceller3.cc */, + 691E054721A4FD7600F838EF /* block_delay_buffer.cc */, + 691E054821A4FD7600F838EF /* aec3_common.h */, + 691E054921A4FD7600F838EF /* fft_buffer.cc */, + 691E054A21A4FD7600F838EF /* vector_math.h */, + 691E054B21A4FD7600F838EF /* decimator.h */, + 691E054C21A4FD7600F838EF /* frame_blocker.h */, + 691E054D21A4FD7600F838EF /* block_framer.h */, + 691E054E21A4FD7600F838EF /* suppression_gain_limiter.h */, + 691E054F21A4FD7600F838EF /* delay_estimate.h */, + 691E055021A4FD7600F838EF /* comfort_noise_generator.cc */, + 691E055121A4FD7600F838EF /* reverb_model.h */, + 691E055221A4FD7600F838EF /* main_filter_update_gain.h */, + 691E055321A4FD7600F838EF /* matched_filter_lag_aggregator.h */, + 691E055421A4FD7600F838EF /* shadow_filter_update_gain.cc */, + 691E055521A4FD7600F838EF /* filter_analyzer.cc */, + 691E055621A4FD7600F838EF /* reverb_decay_estimator.h */, + 691E055721A4FD7600F838EF /* reverb_frequency_response.cc */, + 691E055821A4FD7600F838EF /* decimator.cc */, + 691E055921A4FD7600F838EF /* render_delay_buffer.h */, + ); + path = aec3; + sourceTree = ""; + }; + 691E055D21A4FD7600F838EF /* logging */ = { + isa = PBXGroup; + children = ( + 691E055E21A4FD7600F838EF /* apm_data_dumper.cc */, + 691E055F21A4FD7600F838EF /* apm_data_dumper.h */, + ); + path = logging; + sourceTree = ""; + }; + 691E056021A4FD7600F838EF /* vad */ = { + isa = PBXGroup; + children = ( + 691E056121A4FD7600F838EF /* voice_activity_detector.cc */, + 691E056221A4FD7600F838EF /* standalone_vad.cc */, + 691E056321A4FD7600F838EF /* vad_audio_proc_internal.h */, + 691E056421A4FD7600F838EF /* pitch_internal.cc */, + 691E056521A4FD7600F838EF /* vad_circular_buffer.cc */, + 691E056621A4FD7600F838EF /* vad_circular_buffer.h */, + 691E056721A4FD7600F838EF /* pitch_based_vad.h */, + 691E056821A4FD7600F838EF /* vad_audio_proc.cc */, + 691E056921A4FD7600F838EF /* pole_zero_filter.cc */, + 691E056A21A4FD7600F838EF /* pole_zero_filter.h */, + 691E056B21A4FD7600F838EF /* pitch_based_vad.cc */, + 691E056C21A4FD7600F838EF /* gmm.h */, + 691E056D21A4FD7600F838EF /* common.h */, + 691E056E21A4FD7600F838EF /* vad_audio_proc.h */, + 691E056F21A4FD7600F838EF /* voice_gmm_tables.h */, + 691E057021A4FD7600F838EF /* noise_gmm_tables.h */, + 691E057121A4FD7600F838EF /* pitch_internal.h */, + 691E057221A4FD7600F838EF /* gmm.cc */, + 691E057321A4FD7600F838EF /* standalone_vad.h */, + 691E057421A4FD7600F838EF /* voice_activity_detector.h */, + ); + path = vad; + sourceTree = ""; + }; + 691E057521A4FD7600F838EF /* utility */ = { + isa = PBXGroup; + children = ( + 691E057621A4FD7600F838EF /* ooura_fft_tables_neon_sse2.h */, + 691E057721A4FD7600F838EF /* delay_estimator_internal.h */, + 691E057821A4FD7600F838EF /* ooura_fft.cc */, + 691E057921A4FD7600F838EF /* ooura_fft.h */, + 691E057A21A4FD7600F838EF /* delay_estimator_wrapper.cc */, + 691E057B21A4FD7600F838EF /* ooura_fft_sse2.cc */, + 691E057C21A4FD7600F838EF /* delay_estimator.cc */, + 691E057D21A4FD7600F838EF /* block_mean_calculator.h */, + 691E057E21A4FD7600F838EF /* ooura_fft_neon.cc */, + 691E057F21A4FD7600F838EF /* block_mean_calculator.cc */, + 691E058021A4FD7600F838EF /* delay_estimator.h */, + 691E058121A4FD7600F838EF /* ooura_fft_tables_common.h */, + 691E058221A4FD7600F838EF /* delay_estimator_wrapper.h */, + ); + path = utility; + sourceTree = ""; + }; + 691E058321A4FD7600F838EF /* rtc_base */ = { + isa = PBXGroup; + children = ( + 691E058421A4FD7600F838EF /* string_to_number.h */, + 691E058521A4FD7600F838EF /* constructormagic.h */, + 691E058621A4FD7600F838EF /* race_checker.cc */, + 691E058721A4FD7600F838EF /* strings */, + 691E058A21A4FD7600F838EF /* event_tracer.h */, + 691E058B21A4FD7600F838EF /* stringencode.h */, + 691E058C21A4FD7600F838EF /* memory */, + 691E058F21A4FD7600F838EF /* timeutils.cc */, + 691E059021A4FD7600F838EF /* event.h */, + 691E059121A4FD7600F838EF /* logging_mac.mm */, + 691E059221A4FD7600F838EF /* ignore_wundef.h */, + 691E059321A4FD7600F838EF /* stringutils.h */, + 691E059421A4FD7600F838EF /* arraysize.h */, + 691E059521A4FD7600F838EF /* platform_file.cc */, + 691E059621A4FD7600F838EF /* swap_queue.h */, + 691E059721A4FD7600F838EF /* string_to_number.cc */, + 691E059821A4FD7600F838EF /* trace_event.h */, + 691E059921A4FD7600F838EF /* checks.h */, + 691E059A21A4FD7600F838EF /* deprecation.h */, + 691E059B21A4FD7600F838EF /* thread_checker_impl.cc */, + 691E059C21A4FD7600F838EF /* sanitizer.h */, + 691E059D21A4FD7600F838EF /* scoped_ref_ptr.h */, + 691E059E21A4FD7600F838EF /* logging.h */, + 691E059F21A4FD7600F838EF /* timeutils.h */, + 691E05A021A4FD7600F838EF /* atomicops.h */, + 691E05A121A4FD7600F838EF /* stringencode.cc */, + 691E05A221A4FD7600F838EF /* stringutils.cc */, + 691E05A321A4FD7600F838EF /* checks.cc */, + 691E05A421A4FD7600F838EF /* numerics */, + 691E05A921A4FD7600F838EF /* system */, + 691E05B021A4FD7600F838EF /* platform_thread.cc */, + 691E05B121A4FD7600F838EF /* platform_thread.h */, + 691E05B221A4FD7600F838EF /* logging_webrtc.cc */, + 691E05B321A4FD7600F838EF /* platform_thread_types.h */, + 691E05B421A4FD7600F838EF /* protobuf_utils.h */, + 691E05B521A4FD7600F838EF /* thread_annotations.h */, + 691E05B621A4FD7600F838EF /* gtest_prod_util.h */, + 691E05B721A4FD7600F838EF /* function_view.h */, + 691E05B821A4FD7600F838EF /* criticalsection.h */, + 691E05B921A4FD7600F838EF /* criticalsection.cc */, + 691E05BA21A4FD7600F838EF /* platform_thread_types.cc */, + 691E05BB21A4FD7600F838EF /* refcount.h */, + 691E05BC21A4FD7600F838EF /* event.cc */, + 691E05BD21A4FD7600F838EF /* thread_checker_impl.h */, + 691E05BE21A4FD7600F838EF /* event_tracer.cc */, + 691E05BF21A4FD7600F838EF /* compile_assert_c.h */, + 691E05C021A4FD7600F838EF /* type_traits.h */, + 691E05C121A4FD7600F838EF /* platform_file.h */, + 691E05C221A4FD7600F838EF /* refcounter.h */, + 691E05C321A4FD7600F838EF /* logging_mac.h */, + 691E05C421A4FD7600F838EF /* thread_checker.h */, + 691E05C521A4FD7600F838EF /* race_checker.h */, + 691E05C621A4FD7600F838EF /* refcountedobject.h */, + ); + path = rtc_base; + sourceTree = ""; + }; + 691E058721A4FD7600F838EF /* strings */ = { + isa = PBXGroup; + children = ( + 691E058821A4FD7600F838EF /* string_builder.h */, + 691E058921A4FD7600F838EF /* string_builder.cc */, + ); + path = strings; + sourceTree = ""; + }; + 691E058C21A4FD7600F838EF /* memory */ = { + isa = PBXGroup; + children = ( + 691E058D21A4FD7600F838EF /* aligned_malloc.cc */, + 691E058E21A4FD7600F838EF /* aligned_malloc.h */, + ); + path = memory; + sourceTree = ""; + }; + 691E05A421A4FD7600F838EF /* numerics */ = { + isa = PBXGroup; + children = ( + 691E05A521A4FD7600F838EF /* safe_minmax.h */, + 691E05A621A4FD7600F838EF /* safe_conversions.h */, + 691E05A721A4FD7600F838EF /* safe_conversions_impl.h */, + 691E05A821A4FD7600F838EF /* safe_compare.h */, + ); + path = numerics; + sourceTree = ""; + }; + 691E05A921A4FD7600F838EF /* system */ = { + isa = PBXGroup; + children = ( + 691E05AA21A4FD7600F838EF /* unused.h */, + 691E05AB21A4FD7600F838EF /* inline.h */, + 691E05AC21A4FD7600F838EF /* ignore_warnings.h */, + 691E05AD21A4FD7600F838EF /* asm_defines.h */, + 691E05AE21A4FD7600F838EF /* rtc_export.h */, + 691E05AF21A4FD7600F838EF /* arch.h */, + ); + path = system; + sourceTree = ""; + }; + 692AB8861E6759BF00706ACC /* libtgvoip */ = { + isa = PBXGroup; + children = ( + 692AB8871E6759DD00706ACC /* audio */, + 692AB88C1E6759DD00706ACC /* BlockingQueue.cpp */, + 692AB88D1E6759DD00706ACC /* BlockingQueue.h */, + 692AB88E1E6759DD00706ACC /* Buffers.cpp */, + 692AB88F1E6759DD00706ACC /* Buffers.h */, + 692AB8901E6759DD00706ACC /* VoIPGroupController.cpp */, + 692AB8911E6759DD00706ACC /* PrivateDefines.h */, + 692AB8971E6759DD00706ACC /* CongestionControl.cpp */, + 692AB8981E6759DD00706ACC /* CongestionControl.h */, + 692AB8991E6759DD00706ACC /* EchoCanceller.cpp */, + 692AB89A1E6759DD00706ACC /* EchoCanceller.h */, + 692AB8A71E6759DD00706ACC /* Info.plist */, + 692AB8A81E6759DD00706ACC /* JitterBuffer.cpp */, + 692AB8A91E6759DD00706ACC /* JitterBuffer.h */, + 69A2076421AF6289003AC4F9 /* json11.cpp */, + 6915307A1E6B5BAB004F643F /* logging.cpp */, + 692AB8AA1E6759DD00706ACC /* logging.h */, + 692AB8AB1E6759DD00706ACC /* MediaStreamItf.cpp */, + 692AB8AC1E6759DD00706ACC /* MediaStreamItf.h */, + 6976FD0120F6A7050019939E /* MessageThread.cpp */, + 6976FD0220F6A7060019939E /* MessageThread.h */, + 690725C01EBBD5F2005D860B /* NetworkSocket.cpp */, + 690725C11EBBD5F2005D860B /* NetworkSocket.h */, + 692AB8AD1E6759DD00706ACC /* OpusDecoder.cpp */, + 692AB8AE1E6759DD00706ACC /* OpusDecoder.h */, + 692AB8AF1E6759DD00706ACC /* OpusEncoder.cpp */, + 692AB8B01E6759DD00706ACC /* OpusEncoder.h */, + 6971220D20C8107E00971C2C /* PacketReassembler.cpp */, + 6971220E20C8107F00971C2C /* PacketReassembler.h */, + 692AB8B11E6759DD00706ACC /* os */, + 692AB8C61E6759DD00706ACC /* threading.h */, + 692AB8C71E6759DD00706ACC /* VoIPController.cpp */, + 692AB8C81E6759DD00706ACC /* VoIPController.h */, + 692AB8C91E6759DD00706ACC /* VoIPServerConfig.cpp */, + 692AB8CA1E6759DD00706ACC /* VoIPServerConfig.h */, + 697B6FDC2136E673004C8E54 /* utils.h */, + 694DE89B219F2265009C09A7 /* video */, + 69A6DE201E96149300000E69 /* webrtc_dsp */, + ); + name = libtgvoip; + sourceTree = ""; + }; + 692AB8871E6759DD00706ACC /* audio */ = { + isa = PBXGroup; + children = ( + 692AB8881E6759DD00706ACC /* AudioInput.cpp */, + 692AB8891E6759DD00706ACC /* AudioInput.h */, + 692AB88A1E6759DD00706ACC /* AudioOutput.cpp */, + 692AB88B1E6759DD00706ACC /* AudioOutput.h */, + 697B6FD42136E1F3004C8E54 /* AudioIO.cpp */, + 697B6FD52136E1F3004C8E54 /* AudioIO.h */, + C2A87DD71F4B6A33002D3F73 /* Resampler.cpp */, + 69EBC7952136D2A9003CFE90 /* Resampler.h */, + 697B6FD82136E2D9004C8E54 /* AudioIOCallback.cpp */, + 697B6FD92136E2D9004C8E54 /* AudioIOCallback.h */, + ); + path = audio; + sourceTree = ""; + }; + 692AB8B11E6759DD00706ACC /* os */ = { + isa = PBXGroup; + children = ( + 690725BB1EBBD5DE005D860B /* posix */, + 692AB8BD1E6759DD00706ACC /* darwin */, + ); + path = os; + sourceTree = ""; + }; + 692AB8BD1E6759DD00706ACC /* darwin */ = { + isa = PBXGroup; + children = ( + C2A87DE31F4B6AD3002D3F73 /* AudioUnitIO.cpp */, + 697B6FD22136E18A004C8E54 /* AudioUnitIO.h */, + C2A87DDB1F4B6A61002D3F73 /* AudioInputAudioUnit.cpp */, + C2A87DDC1F4B6A61002D3F73 /* AudioInputAudioUnitOSX.cpp */, + C2A87DDD1F4B6A61002D3F73 /* AudioOutputAudioUnit.cpp */, + C2A87DDE1F4B6A61002D3F73 /* AudioOutputAudioUnitOSX.cpp */, + 69A6DF3F1E9614B700000E69 /* AudioInputAudioUnitOSX.cpp */, + 69A6DF401E9614B700000E69 /* AudioInputAudioUnitOSX.h */, + 69A6DF411E9614B700000E69 /* AudioOutputAudioUnitOSX.cpp */, + 69A6DF421E9614B700000E69 /* AudioOutputAudioUnitOSX.h */, + 695B20601EBD39FF00E31757 /* DarwinSpecific.h */, + 69EBC7932136D277003CFE90 /* DarwinSpecific.mm */, + 69DF15672237DEDB00C1F8ED /* TGVVideoRenderer.h */, + 69DF15652237DEDA00C1F8ED /* TGVVideoRenderer.mm */, + 69DF157A2237DFE100C1F8ED /* SampleBufferDisplayLayerRenderer.mm */, + 69DF157D2237DFE700C1F8ED /* SampleBufferDisplayLayerRenderer.h */, + 69DF15682237DEDB00C1F8ED /* TGVVideoSource.h */, + 69DF15692237DEDB00C1F8ED /* TGVVideoSource.mm */, + 69DF156B2237DEDC00C1F8ED /* VideoToolboxEncoderSource.h */, + 69DF156C2237DEDC00C1F8ED /* VideoToolboxEncoderSource.mm */, + ); + name = darwin; + path = os/darwin; + sourceTree = SOURCE_ROOT; + }; + 692AB9061E675E8700706ACC /* Frameworks */ = { + isa = PBXGroup; + children = ( + 69DF157F2237E96E00C1F8ED /* VideoToolbox.framework */, + 692AB91C1E675F7000706ACC /* AudioToolbox.framework */, + 692AB91D1E675F7000706ACC /* AudioUnit.framework */, + 692AB91E1E675F7000706ACC /* CoreAudio.framework */, + 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */, + ); + name = Frameworks; + sourceTree = ""; + }; + 692AB9081E675E8800706ACC /* Products */ = { + isa = PBXGroup; + children = ( + 692AB9111E675E8800706ACC /* Telegram.app */, + 692AB9131E675E8800706ACC /* Share.appex */, + 692AB9151E675E8800706ACC /* watchkitapp.app */, + 692AB9171E675E8800706ACC /* watchkitapp Extension.appex */, + 692AB9191E675E8800706ACC /* SiriIntents.appex */, + 692AB91B1E675E8800706ACC /* LegacyDatabase.framework */, + 6976FD0020F6A6EF0019939E /* Widget.appex */, + ); + name = Products; + sourceTree = ""; + }; + 694DE89B219F2265009C09A7 /* video */ = { + isa = PBXGroup; + children = ( + 694DE89C219F2265009C09A7 /* VideoRenderer.h */, + 694DE89D219F2265009C09A7 /* VideoRenderer.cpp */, + 694DE89E219F2265009C09A7 /* VideoSource.cpp */, + 694DE89F219F2265009C09A7 /* VideoSource.h */, + 6970AF4C225FFEBE00F02034 /* VideoFEC.cpp */, + 6970AF4A225FFEBE00F02034 /* VideoFEC.h */, + 6970AF4B225FFEBE00F02034 /* VideoPacketSender.cpp */, + 6970AF4D225FFEBE00F02034 /* VideoPacketSender.h */, + 69DF15612237DEBB00C1F8ED /* ScreamCongestionController.cpp */, + 69DF15602237DEBB00C1F8ED /* ScreamCongestionController.h */, + ); + path = video; + sourceTree = ""; + }; + 697B6FC52136DBA4004C8E54 /* tests */ = { + isa = PBXGroup; + children = ( + 697B6FC62136DBA4004C8E54 /* libtgvoipTests.mm */, + 697B6FDD2136F01E004C8E54 /* MockReflector.h */, + 697B6FDE2136F01E004C8E54 /* MockReflector.cpp */, + 697B6FC82136DBA4004C8E54 /* Info.plist */, + ); + path = tests; + sourceTree = ""; + }; + 69A6DE201E96149300000E69 /* webrtc_dsp */ = { + isa = PBXGroup; + children = ( + 691E032F21A4FD7500F838EF /* absl */, + 691E03CE21A4FD7500F838EF /* api */, + 691E035821A4FD7500F838EF /* common_audio */, + 691E03EB21A4FD7500F838EF /* modules */, + 691E058321A4FD7600F838EF /* rtc_base */, + 691E03E021A4FD7500F838EF /* system_wrappers */, + 691E03D821A4FD7500F838EF /* third_party */, + 691E032E21A4FD7500F838EF /* typedefs.h */, + ); + path = webrtc_dsp; + sourceTree = SOURCE_ROOT; + }; + 69F8422C1E67540700C110F7 = { + isa = PBXGroup; + children = ( + 692AB8861E6759BF00706ACC /* libtgvoip */, + 697B6FC52136DBA4004C8E54 /* tests */, + 69F842371E67540700C110F7 /* Products */, + 692AB9061E675E8700706ACC /* Frameworks */, + ); + sourceTree = ""; + }; + 69F842371E67540700C110F7 /* Products */ = { + isa = PBXGroup; + children = ( + 69F842361E67540700C110F7 /* libtgvoip.framework */, + 697B6FC42136DBA4004C8E54 /* libtgvoipTests.xctest */, + ); + name = Products; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXHeadersBuildPhase section */ + 69F842331E67540700C110F7 /* Headers */ = { + isa = PBXHeadersBuildPhase; + buildActionMask = 2147483647; + files = ( + 69DF15622237DEBB00C1F8ED /* ScreamCongestionController.h in Headers */, + 6970AF51225FFEBE00F02034 /* VideoPacketSender.h in Headers */, + 692AB9051E6759DD00706ACC /* VoIPServerConfig.h in Headers */, + 69DF15722237DEDC00C1F8ED /* TGVVideoSource.h in Headers */, + 69DF157E2237DFE700C1F8ED /* SampleBufferDisplayLayerRenderer.h in Headers */, + 692AB9031E6759DD00706ACC /* VoIPController.h in Headers */, + 6970AF4E225FFEBE00F02034 /* VideoFEC.h in Headers */, + 69DF15772237DEDC00C1F8ED /* VideoToolboxEncoderSource.h in Headers */, + 69DF15712237DEDC00C1F8ED /* TGVVideoRenderer.h in Headers */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXHeadersBuildPhase section */ + +/* Begin PBXNativeTarget section */ + 697B6FC32136DBA4004C8E54 /* libtgvoipTests */ = { + isa = PBXNativeTarget; + buildConfigurationList = 697B6FD12136DBA4004C8E54 /* Build configuration list for PBXNativeTarget "libtgvoipTests" */; + buildPhases = ( + 697B6FC02136DBA4004C8E54 /* Sources */, + 697B6FC12136DBA4004C8E54 /* Frameworks */, + 697B6FC22136DBA4004C8E54 /* Resources */, + ); + buildRules = ( + ); + dependencies = ( + 697B6FCB2136DBA4004C8E54 /* PBXTargetDependency */, + ); + name = libtgvoipTests; + productName = libtgvoipTests; + productReference = 697B6FC42136DBA4004C8E54 /* libtgvoipTests.xctest */; + productType = "com.apple.product-type.bundle.unit-test"; + }; + 69F842351E67540700C110F7 /* libtgvoip */ = { + isa = PBXNativeTarget; + buildConfigurationList = 69F8423E1E67540700C110F7 /* Build configuration list for PBXNativeTarget "libtgvoip" */; + buildPhases = ( + 69F842311E67540700C110F7 /* Sources */, + 69F842321E67540700C110F7 /* Frameworks */, + 69F842331E67540700C110F7 /* Headers */, + 69F842341E67540700C110F7 /* Resources */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = libtgvoip; + productName = libtgvoip; + productReference = 69F842361E67540700C110F7 /* libtgvoip.framework */; + productType = "com.apple.product-type.framework"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 69F8422D1E67540700C110F7 /* Project object */ = { + isa = PBXProject; + attributes = { + LastUpgradeCheck = 0820; + ORGANIZATIONNAME = Grishka; + TargetAttributes = { + 697B6FC32136DBA4004C8E54 = { + CreatedOnToolsVersion = 9.4.1; + ProvisioningStyle = Automatic; + }; + 69F842351E67540700C110F7 = { + CreatedOnToolsVersion = 8.2.1; + ProvisioningStyle = Automatic; + }; + }; + }; + buildConfigurationList = 69F842301E67540700C110F7 /* Build configuration list for PBXProject "libtgvoip_osx" */; + compatibilityVersion = "Xcode 3.2"; + developmentRegion = English; + hasScannedForEncodings = 0; + knownRegions = ( + English, + en, + ); + mainGroup = 69F8422C1E67540700C110F7; + productRefGroup = 69F842371E67540700C110F7 /* Products */; + projectDirPath = ""; + projectReferences = ( + { + ProductGroup = 692AB9081E675E8800706ACC /* Products */; + ProjectRef = 692AB9071E675E8800706ACC /* Telegraph.xcodeproj */; + }, + ); + projectRoot = ""; + targets = ( + 69F842351E67540700C110F7 /* libtgvoip */, + 697B6FC32136DBA4004C8E54 /* libtgvoipTests */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXReferenceProxy section */ + 692AB9111E675E8800706ACC /* Telegram.app */ = { + isa = PBXReferenceProxy; + fileType = wrapper.application; + path = Telegram.app; + remoteRef = 692AB9101E675E8800706ACC /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; + 692AB9131E675E8800706ACC /* Share.appex */ = { + isa = PBXReferenceProxy; + fileType = "wrapper.app-extension"; + path = Share.appex; + remoteRef = 692AB9121E675E8800706ACC /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; + 692AB9151E675E8800706ACC /* watchkitapp.app */ = { + isa = PBXReferenceProxy; + fileType = wrapper.application; + path = watchkitapp.app; + remoteRef = 692AB9141E675E8800706ACC /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; + 692AB9171E675E8800706ACC /* watchkitapp Extension.appex */ = { + isa = PBXReferenceProxy; + fileType = "wrapper.app-extension"; + path = "watchkitapp Extension.appex"; + remoteRef = 692AB9161E675E8800706ACC /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; + 692AB9191E675E8800706ACC /* SiriIntents.appex */ = { + isa = PBXReferenceProxy; + fileType = "wrapper.app-extension"; + path = SiriIntents.appex; + remoteRef = 692AB9181E675E8800706ACC /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; + 692AB91B1E675E8800706ACC /* LegacyDatabase.framework */ = { + isa = PBXReferenceProxy; + fileType = wrapper.framework; + path = LegacyDatabase.framework; + remoteRef = 692AB91A1E675E8800706ACC /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; + 6976FD0020F6A6EF0019939E /* Widget.appex */ = { + isa = PBXReferenceProxy; + fileType = "wrapper.app-extension"; + path = Widget.appex; + remoteRef = 6976FCFF20F6A6EF0019939E /* PBXContainerItemProxy */; + sourceTree = BUILT_PRODUCTS_DIR; + }; +/* End PBXReferenceProxy section */ + +/* Begin PBXResourcesBuildPhase section */ + 697B6FC22136DBA4004C8E54 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 69F842341E67540700C110F7 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXResourcesBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + 697B6FC02136DBA4004C8E54 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 69DF15742237DEDC00C1F8ED /* TGVVideoSource.mm in Sources */, + 69DF157C2237DFE100C1F8ED /* SampleBufferDisplayLayerRenderer.mm in Sources */, + 697B6FDF2136F01E004C8E54 /* MockReflector.cpp in Sources */, + 69DF15792237DEDC00C1F8ED /* VideoToolboxEncoderSource.mm in Sources */, + 69DF15642237DEBB00C1F8ED /* ScreamCongestionController.cpp in Sources */, + 69DF156E2237DEDC00C1F8ED /* TGVVideoRenderer.mm in Sources */, + 697B6FC72136DBA4004C8E54 /* libtgvoipTests.mm in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 69F842311E67540700C110F7 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 691E075321A4FD7700F838EF /* render_delay_buffer2.cc in Sources */, + 691E067721A4FD7600F838EF /* encode_lpc_swb.c in Sources */, + 691E05F921A4FD7600F838EF /* push_sinc_resampler.cc in Sources */, + 691E079021A4FD7700F838EF /* residual_echo_estimator.cc in Sources */, + 691E072421A4FD7700F838EF /* echo_cancellation_impl.cc in Sources */, + 691E071621A4FD7700F838EF /* level_estimator_impl.cc in Sources */, + 691E079E21A4FD7700F838EF /* downsampled_render_buffer.cc in Sources */, + 691E06D021A4FD7600F838EF /* adaptive_digital_gain_applier.cc in Sources */, + 691E07E121A4FD7700F838EF /* race_checker.cc in Sources */, + 691E062D21A4FD7600F838EF /* get_scaling_square.c in Sources */, + 691E080721A4FD7700F838EF /* platform_thread.cc in Sources */, + 691E078021A4FD7700F838EF /* stationarity_estimator.cc in Sources */, + 691E062121A4FD7600F838EF /* sqrt_of_one_minus_x_squared.c in Sources */, + 691E06F321A4FD7600F838EF /* vad_with_level.cc in Sources */, + 691E061D21A4FD7600F838EF /* auto_corr_to_refl_coef.c in Sources */, + 694DE8A2219F2265009C09A7 /* VideoSource.cpp in Sources */, + 6915307B1E6B5BAB004F643F /* logging.cpp in Sources */, + 691E067C21A4FD7600F838EF /* lpc_tables.c in Sources */, + 691E066221A4FD7600F838EF /* field_trial.cc in Sources */, + 691E067621A4FD7600F838EF /* pitch_filter.c in Sources */, + 691E070321A4FD7600F838EF /* biquad_filter.cc in Sources */, + 691E064621A4FD7600F838EF /* webrtc_vad.c in Sources */, + 691E064221A4FD7600F838EF /* spl_sqrt.c in Sources */, + 691E062321A4FD7600F838EF /* filter_ar_fast_q12.c in Sources */, + 691E07A821A4FD7700F838EF /* fft_buffer.cc in Sources */, + 69DF15732237DEDC00C1F8ED /* TGVVideoSource.mm in Sources */, + 691E05CA21A4FD7600F838EF /* string_view.cc in Sources */, + 691E079C21A4FD7700F838EF /* echo_remover.cc in Sources */, + 691E061921A4FD7600F838EF /* splitting_filter1.c in Sources */, + 691E07BF21A4FD7700F838EF /* standalone_vad.cc in Sources */, + 691E07CF21A4FD7700F838EF /* gmm.cc in Sources */, + 691E080921A4FD7700F838EF /* logging_webrtc.cc in Sources */, + 691E05F121A4FD7600F838EF /* wav_header.cc in Sources */, + 691E062021A4FD7600F838EF /* energy.c in Sources */, + 691E074621A4FD7700F838EF /* aecm_core.cc in Sources */, + 691E06FD21A4FD7600F838EF /* down_sampler.cc in Sources */, + 691E07C821A4FD7700F838EF /* pitch_based_vad.cc in Sources */, + 691E077A21A4FD7700F838EF /* reverb_model.cc in Sources */, + 691E064B21A4FD7600F838EF /* vad_filterbank.c in Sources */, + 691E069621A4FD7600F838EF /* pitch_lag_tables.c in Sources */, + 691E076421A4FD7700F838EF /* block_processor.cc in Sources */, + 691E069021A4FD7600F838EF /* crc.c in Sources */, + 691E064121A4FD7600F838EF /* spl_inl.c in Sources */, + 691E06AA21A4FD7600F838EF /* nsx_core_c.c in Sources */, + 69DF157B2237DFE100C1F8ED /* SampleBufferDisplayLayerRenderer.mm in Sources */, + 691E06A421A4FD7600F838EF /* splitting_filter.cc in Sources */, + 691E07E321A4FD7700F838EF /* string_builder.cc in Sources */, + 691E071421A4FD7700F838EF /* low_cut_filter.cc in Sources */, + 691E074B21A4FD7700F838EF /* render_reverb_model.cc in Sources */, + 691E081521A4FD7700F838EF /* event_tracer.cc in Sources */, + 6970AF50225FFEBE00F02034 /* VideoFEC.cpp in Sources */, + C2A87DE41F4B6AD3002D3F73 /* AudioUnitIO.cpp in Sources */, + 691E060D21A4FD7600F838EF /* real_fourier.cc in Sources */, + 691E076321A4FD7700F838EF /* suppression_filter.cc in Sources */, + 691E065621A4FD7600F838EF /* echo_canceller3_factory.cc in Sources */, + 691E05D021A4FD7600F838EF /* bad_optional_access.cc in Sources */, + 691E06D221A4FD7600F838EF /* saturation_protector.cc in Sources */, + 691E076C21A4FD7700F838EF /* vector_buffer.cc in Sources */, + 691E071121A4FD7700F838EF /* transient_suppressor.cc in Sources */, + 691E074A21A4FD7700F838EF /* echo_control_mobile.cc in Sources */, + 691E078621A4FD7700F838EF /* suppression_gain.cc in Sources */, + 691E072521A4FD7700F838EF /* gain_control_for_experimental_agc.cc in Sources */, + 691E081021A4FD7700F838EF /* criticalsection.cc in Sources */, + 691E05D121A4FD7600F838EF /* optional.cc in Sources */, + 691E061E21A4FD7600F838EF /* resample_by_2_internal.c in Sources */, + 691E066B21A4FD7600F838EF /* pitch_gain_tables.c in Sources */, + 690725C21EBBD5F2005D860B /* NetworkSocket.cpp in Sources */, + 691E05E921A4FD7600F838EF /* channel_buffer.cc in Sources */, + 691E078721A4FD7700F838EF /* echo_audibility.cc in Sources */, + 691E068921A4FD7600F838EF /* entropy_coding.c in Sources */, + 691E061821A4FD7600F838EF /* filter_ma_fast_q12.c in Sources */, + 691E05D921A4FD7600F838EF /* raw_logging.cc in Sources */, + 691E079A21A4FD7700F838EF /* suppression_gain_limiter.cc in Sources */, + 691E079821A4FD7700F838EF /* render_delay_controller2.cc in Sources */, + 691E063E21A4FD7600F838EF /* resample_by_2.c in Sources */, + 691E067921A4FD7600F838EF /* decode.c in Sources */, + 691E06D121A4FD7600F838EF /* limiter.cc in Sources */, + 691E073F21A4FD7700F838EF /* residual_echo_detector.cc in Sources */, + 691E078521A4FD7700F838EF /* subtractor_output_analyzer.cc in Sources */, + 691E075721A4FD7700F838EF /* frame_blocker.cc in Sources */, + 691E07FB21A4FD7700F838EF /* stringutils.cc in Sources */, + 691E07C521A4FD7700F838EF /* vad_audio_proc.cc in Sources */, + 691E062E21A4FD7600F838EF /* min_max_operations_neon.c in Sources */, + 691E05F321A4FD7600F838EF /* fir_filter_neon.cc in Sources */, + 691E06E521A4FD7600F838EF /* pitch_search.cc in Sources */, + 691E062421A4FD7600F838EF /* spl_init.c in Sources */, + 691E06EF21A4FD7600F838EF /* agc2_testing_common.cc in Sources */, + 69DF15632237DEBB00C1F8ED /* ScreamCongestionController.cpp in Sources */, + 691E066421A4FD7600F838EF /* cpu_features.cc in Sources */, + 691E07DB21A4FD7700F838EF /* block_mean_calculator.cc in Sources */, + 692AB9041E6759DD00706ACC /* VoIPServerConfig.cpp in Sources */, + 691E066A21A4FD7600F838EF /* lpc_shape_swb16_tables.c in Sources */, + 691E071021A4FD7700F838EF /* wpd_node.cc in Sources */, + 691E062621A4FD7600F838EF /* cross_correlation.c in Sources */, + 691E07EE21A4FD7700F838EF /* platform_file.cc in Sources */, + 691E072C21A4FD7700F838EF /* analog_agc.c in Sources */, + 691E067D21A4FD7600F838EF /* lpc_gain_swb_tables.c in Sources */, + 691E06EB21A4FD7600F838EF /* adaptive_mode_level_estimator_agc.cc in Sources */, + 691E068421A4FD7600F838EF /* arith_routines_hist.c in Sources */, + 691E068121A4FD7600F838EF /* encode.c in Sources */, + 691E06E821A4FD7600F838EF /* fft_util.cc in Sources */, + 691E06C121A4FD7600F838EF /* aec_dump.cc in Sources */, + 691E075821A4FD7700F838EF /* subtractor.cc in Sources */, + 691E07BC21A4FD7700F838EF /* apm_data_dumper.cc in Sources */, + 691E076D21A4FD7700F838EF /* erl_estimator.cc in Sources */, + 691E074121A4FD7700F838EF /* noise_suppression_impl.cc in Sources */, + 6976FD0320F6A7060019939E /* MessageThread.cpp in Sources */, + 692AB9021E6759DD00706ACC /* VoIPController.cpp in Sources */, + 691E06F421A4FD7600F838EF /* limiter_db_gain_curve.cc in Sources */, + 691E05F821A4FD7600F838EF /* sinc_resampler_neon.cc in Sources */, + 691E07F021A4FD7700F838EF /* string_to_number.cc in Sources */, + 691E060621A4FD7600F838EF /* wav_file.cc in Sources */, + 691E07C621A4FD7700F838EF /* pole_zero_filter.cc in Sources */, + 691E06A921A4FD7600F838EF /* noise_suppression_x.c in Sources */, + 691E078121A4FD7700F838EF /* render_signal_analyzer.cc in Sources */, + 691E06CA21A4FD7600F838EF /* agc2_common.cc in Sources */, + 691E071221A4FD7700F838EF /* transient_detector.cc in Sources */, + 691E069721A4FD7600F838EF /* isac.c in Sources */, + 691E071C21A4FD7700F838EF /* aec_core.cc in Sources */, + 691E069E21A4FD7600F838EF /* normalized_covariance_estimator.cc in Sources */, + 692AB8D81E6759DD00706ACC /* CongestionControl.cpp in Sources */, + 692AB8EB1E6759DD00706ACC /* OpusDecoder.cpp in Sources */, + 69DF156D2237DEDC00C1F8ED /* TGVVideoRenderer.mm in Sources */, + 691E071821A4FD7700F838EF /* echo_cancellation.cc in Sources */, + 691E077821A4FD7700F838EF /* block_framer.cc in Sources */, + 691E081121A4FD7700F838EF /* platform_thread_types.cc in Sources */, + 691E07E821A4FD7700F838EF /* timeutils.cc in Sources */, + 691E075121A4FD7700F838EF /* echo_remover_metrics.cc in Sources */, + 691E066621A4FD7600F838EF /* fft.c in Sources */, + 691E06F121A4FD7600F838EF /* fixed_gain_controller.cc in Sources */, + 69DF15782237DEDC00C1F8ED /* VideoToolboxEncoderSource.mm in Sources */, + 691E077F21A4FD7700F838EF /* subtractor_output.cc in Sources */, + 697B6FD62136E1F3004C8E54 /* AudioIO.cpp in Sources */, + 691E072D21A4FD7700F838EF /* digital_agc.c in Sources */, + 691E064421A4FD7600F838EF /* vad_sp.c in Sources */, + 691E070021A4FD7600F838EF /* noise_spectrum_estimator.cc in Sources */, + 691E06B621A4FD7600F838EF /* audio_buffer.cc in Sources */, + 691E064F21A4FD7600F838EF /* vad_gmm.c in Sources */, + 691E05FB21A4FD7600F838EF /* resampler.cc in Sources */, + 691E069421A4FD7600F838EF /* spectrum_ar_model_tables.c in Sources */, + 691E067821A4FD7600F838EF /* filter_functions.c in Sources */, + 691E06E321A4FD7600F838EF /* spectral_features.cc in Sources */, + 691E063521A4FD7600F838EF /* filter_ar.c in Sources */, + 691E07D421A4FD7700F838EF /* ooura_fft.cc in Sources */, + 691E05FC21A4FD7600F838EF /* sinc_resampler_sse.cc in Sources */, + 691E06C621A4FD7600F838EF /* config.cc in Sources */, + C2A87DDF1F4B6A61002D3F73 /* AudioInputAudioUnit.cpp in Sources */, + 691E067E21A4FD7600F838EF /* bandwidth_estimator.c in Sources */, + 691E05DA21A4FD7600F838EF /* throw_delegate.cc in Sources */, + 691E05E821A4FD7600F838EF /* window_generator.cc in Sources */, + 69A6DF431E9614B700000E69 /* AudioInputAudioUnitOSX.cpp in Sources */, + 691E06F021A4FD7600F838EF /* fixed_digital_level_estimator.cc in Sources */, + 691E061321A4FD7600F838EF /* fir_filter_c.cc in Sources */, + 691E07F421A4FD7700F838EF /* thread_checker_impl.cc in Sources */, + 691E07D721A4FD7700F838EF /* ooura_fft_sse2.cc in Sources */, + 691E078F21A4FD7700F838EF /* aec3_common.cc in Sources */, + 691E063721A4FD7600F838EF /* resample_fractional.c in Sources */, + 691E073C21A4FD7700F838EF /* file_audio_generator.cc in Sources */, + 691E063621A4FD7600F838EF /* vector_scaling_operations.c in Sources */, + 691E06A121A4FD7600F838EF /* mean_variance_estimator.cc in Sources */, + 691E077B21A4FD7700F838EF /* cascaded_biquad_filter.cc in Sources */, + 691E06A521A4FD7600F838EF /* gain_control_impl.cc in Sources */, + 691E07D621A4FD7700F838EF /* delay_estimator_wrapper.cc in Sources */, + 691E076221A4FD7700F838EF /* fullband_erle_estimator.cc in Sources */, + 691E075621A4FD7700F838EF /* echo_path_variability.cc in Sources */, + 691E063B21A4FD7600F838EF /* randomization_functions.c in Sources */, + 691E07C121A4FD7700F838EF /* pitch_internal.cc in Sources */, + 691E077D21A4FD7700F838EF /* render_buffer.cc in Sources */, + 691E06C921A4FD7600F838EF /* interpolated_gain_curve.cc in Sources */, + 691E071721A4FD7700F838EF /* three_band_filter_bank.cc in Sources */, + 691E061C21A4FD7600F838EF /* dot_product_with_scale.cc in Sources */, + 691E06B721A4FD7600F838EF /* typing_detection.cc in Sources */, + 691E060721A4FD7600F838EF /* spl_sqrt_floor.c in Sources */, + 691E072721A4FD7700F838EF /* loudness_histogram.cc in Sources */, + 691E07DA21A4FD7700F838EF /* ooura_fft_neon.cc in Sources */, + 691E063121A4FD7600F838EF /* resample.c in Sources */, + 691E061B21A4FD7600F838EF /* downsample_fast_neon.c in Sources */, + 691E066E21A4FD7600F838EF /* filterbanks.c in Sources */, + C2A87DE01F4B6A61002D3F73 /* AudioOutputAudioUnit.cpp in Sources */, + 691E07E621A4FD7700F838EF /* aligned_malloc.cc in Sources */, + 691E07EA21A4FD7700F838EF /* logging_mac.mm in Sources */, + 691E06EC21A4FD7600F838EF /* vector_float_frame.cc in Sources */, + 691E07A421A4FD7700F838EF /* block_processor2.cc in Sources */, + 691E065821A4FD7600F838EF /* rnn_vad_weights.cc in Sources */, + 691E07A621A4FD7700F838EF /* block_delay_buffer.cc in Sources */, + 691E06EE21A4FD7600F838EF /* noise_level_estimator.cc in Sources */, + 691E072621A4FD7700F838EF /* agc.cc in Sources */, + 691E072321A4FD7700F838EF /* voice_detection_impl.cc in Sources */, + 691E073621A4FD7700F838EF /* audio_processing_impl.cc in Sources */, + 691E081321A4FD7700F838EF /* event.cc in Sources */, + 691E072821A4FD7700F838EF /* agc_manager_direct.cc in Sources */, + 691E06A821A4FD7600F838EF /* nsx_core.c in Sources */, + 691E06CF21A4FD7600F838EF /* adaptive_agc.cc in Sources */, + 691E061021A4FD7600F838EF /* sparse_fir_filter.cc in Sources */, + 691E070921A4FD7700F838EF /* wpd_tree.cc in Sources */, + 691E060021A4FD7600F838EF /* push_resampler.cc in Sources */, + 691E064021A4FD7600F838EF /* resample_48khz.c in Sources */, + 691E062B21A4FD7600F838EF /* division_operations.c in Sources */, + 691E077221A4FD7700F838EF /* skew_estimator.cc in Sources */, + 691E07D821A4FD7700F838EF /* delay_estimator.cc in Sources */, + 691E063921A4FD7600F838EF /* ilbc_specific_functions.c in Sources */, + 69A6DF451E9614B700000E69 /* AudioOutputAudioUnitOSX.cpp in Sources */, + 691E063421A4FD7600F838EF /* refl_coef_to_lpc.c in Sources */, + 691E075221A4FD7700F838EF /* matched_filter_lag_aggregator.cc in Sources */, + 691E071F21A4FD7700F838EF /* aec_core_neon.cc in Sources */, + 691E063A21A4FD7600F838EF /* complex_bit_reverse.c in Sources */, + 691E07B921A4FD7700F838EF /* echo_control_mobile_impl.cc in Sources */, + 691E069321A4FD7600F838EF /* decode_bwe.c in Sources */, + 691E062521A4FD7600F838EF /* lpc_to_refl_coef.c in Sources */, + 692AB8E61E6759DD00706ACC /* JitterBuffer.cpp in Sources */, + 691E075F21A4FD7700F838EF /* aec3_fft.cc in Sources */, + 691E07B621A4FD7700F838EF /* reverb_frequency_response.cc in Sources */, + 691E060C21A4FD7600F838EF /* audio_converter.cc in Sources */, + 691E065021A4FD7600F838EF /* audio_frame.cc in Sources */, + 691E07FA21A4FD7700F838EF /* stringencode.cc in Sources */, + 691E076E21A4FD7700F838EF /* aec_state.cc in Sources */, + 691E062C21A4FD7600F838EF /* auto_correlation.c in Sources */, + 692AB8CB1E6759DD00706ACC /* AudioInput.cpp in Sources */, + 691E068F21A4FD7600F838EF /* arith_routines.c in Sources */, + 691E072021A4FD7700F838EF /* aec_core_sse2.cc in Sources */, + 691E06B221A4FD7600F838EF /* noise_suppression.c in Sources */, + 691E076A21A4FD7700F838EF /* render_delay_buffer.cc in Sources */, + 691E072E21A4FD7700F838EF /* utility.cc in Sources */, + 691E05F421A4FD7600F838EF /* audio_util.cc in Sources */, + 692AB8CD1E6759DD00706ACC /* AudioOutput.cpp in Sources */, + 691E074821A4FD7700F838EF /* aecm_core_neon.cc in Sources */, + 691E065421A4FD7600F838EF /* echo_canceller3_config.cc in Sources */, + 691E06D421A4FD7600F838EF /* spectral_features_internal.cc in Sources */, + 691E06DC21A4FD7600F838EF /* pitch_search_internal.cc in Sources */, + 6970AF4F225FFEBE00F02034 /* VideoPacketSender.cpp in Sources */, + 691E061421A4FD7600F838EF /* ring_buffer.c in Sources */, + 691E07C221A4FD7700F838EF /* vad_circular_buffer.cc in Sources */, + C2A87DD81F4B6A33002D3F73 /* Resampler.cpp in Sources */, + 697B6FDA2136E2D9004C8E54 /* AudioIOCallback.cpp in Sources */, + 691E079721A4FD7700F838EF /* reverb_decay_estimator.cc in Sources */, + 691E060321A4FD7600F838EF /* sinusoidal_linear_chirp_source.cc in Sources */, + 691E07B421A4FD7700F838EF /* filter_analyzer.cc in Sources */, + 69EBC7942136D277003CFE90 /* DarwinSpecific.mm in Sources */, + 692AB8D11E6759DD00706ACC /* Buffers.cpp in Sources */, + 691E067A21A4FD7600F838EF /* lattice.c in Sources */, + 691E064521A4FD7600F838EF /* vad.cc in Sources */, + 691E05EA21A4FD7600F838EF /* fir_filter_factory.cc in Sources */, + 691E063F21A4FD7600F838EF /* get_hanning_window.c in Sources */, + 691E07AF21A4FD7700F838EF /* comfort_noise_generator.cc in Sources */, + 692AB8E91E6759DD00706ACC /* MediaStreamItf.cpp in Sources */, + 692AB8DA1E6759DD00706ACC /* EchoCanceller.cpp in Sources */, + 691E07BE21A4FD7700F838EF /* voice_activity_detector.cc in Sources */, + 691E05F221A4FD7600F838EF /* real_fourier_ooura.cc in Sources */, + 691E077521A4FD7700F838EF /* echo_path_delay_estimator.cc in Sources */, + 691E068221A4FD7600F838EF /* lpc_analysis.c in Sources */, + 691E077921A4FD7700F838EF /* erle_estimator.cc in Sources */, + 691E074721A4FD7700F838EF /* aecm_core_c.cc in Sources */, + 691E074E21A4FD7700F838EF /* reverb_model_fallback.cc in Sources */, + 691E07B321A4FD7700F838EF /* shadow_filter_update_gain.cc in Sources */, + 691E06FF21A4FD7600F838EF /* signal_classifier.cc in Sources */, + 691E070721A4FD7700F838EF /* moving_moments.cc in Sources */, + 691E073D21A4FD7700F838EF /* gain_controller2.cc in Sources */, + 691E067B21A4FD7600F838EF /* intialize.c in Sources */, + 691E06C021A4FD7600F838EF /* audio_generator_factory.cc in Sources */, + 691E07B721A4FD7700F838EF /* decimator.cc in Sources */, + 691E06B121A4FD7600F838EF /* nsx_core_neon.c in Sources */, + 691E06D721A4FD7600F838EF /* rnn.cc in Sources */, + 691E068A21A4FD7600F838EF /* isac_vad.c in Sources */, + 691E06C521A4FD7600F838EF /* audio_processing.cc in Sources */, + 691E060A21A4FD7600F838EF /* fft4g.c in Sources */, + 691E061221A4FD7600F838EF /* smoothing_filter.cc in Sources */, + 694DE8A1219F2265009C09A7 /* VideoRenderer.cpp in Sources */, + 691E063D21A4FD7600F838EF /* copy_set_operations.c in Sources */, + 691E069121A4FD7600F838EF /* lpc_shape_swb12_tables.c in Sources */, + 691E078821A4FD7700F838EF /* block_processor_metrics.cc in Sources */, + 691E07A021A4FD7700F838EF /* matrix_buffer.cc in Sources */, + 691E07FC21A4FD7700F838EF /* checks.cc in Sources */, + 691E066321A4FD7600F838EF /* metrics.cc in Sources */, + 691E061721A4FD7600F838EF /* complex_fft.c in Sources */, + 691E076921A4FD7700F838EF /* render_delay_controller_metrics.cc in Sources */, + 692AB8D31E6759DD00706ACC /* VoIPGroupController.cpp in Sources */, + 691E062221A4FD7600F838EF /* downsample_fast.c in Sources */, + 691E064C21A4FD7600F838EF /* vad_core.c in Sources */, + 691E063821A4FD7600F838EF /* real_fft.c in Sources */, + 691E066C21A4FD7600F838EF /* arith_routines_logist.c in Sources */, + 691E060221A4FD7600F838EF /* sinc_resampler.cc in Sources */, + 69A2076521AF628A003AC4F9 /* json11.cpp in Sources */, + 691E076821A4FD7700F838EF /* subband_erle_estimator.cc in Sources */, + 691E07A521A4FD7700F838EF /* echo_canceller3.cc in Sources */, + 691E070621A4FD7700F838EF /* adaptive_mode_level_estimator.cc in Sources */, + 691E076F21A4FD7700F838EF /* adaptive_fir_filter.cc in Sources */, + 691E05C921A4FD7600F838EF /* memutil.cc in Sources */, + 691E079B21A4FD7700F838EF /* main_filter_update_gain.cc in Sources */, + 692AB8CF1E6759DD00706ACC /* BlockingQueue.cpp in Sources */, + 691E077121A4FD7700F838EF /* render_delay_controller.cc in Sources */, + 691E06E921A4FD7600F838EF /* lp_residual.cc in Sources */, + 690725BE1EBBD5DE005D860B /* NetworkSocketPosix.cpp in Sources */, + 691E06BF21A4FD7600F838EF /* audio_processing_statistics.cc in Sources */, + 6971220F20C8107F00971C2C /* PacketReassembler.cpp in Sources */, + 691E065B21A4FD7600F838EF /* kiss_fft.cc in Sources */, + 691E06CD21A4FD7600F838EF /* gain_applier.cc in Sources */, + 691E05F621A4FD7600F838EF /* fir_filter_sse.cc in Sources */, + 691E063321A4FD7600F838EF /* min_max_operations.c in Sources */, + 691E071A21A4FD7700F838EF /* aec_resampler.cc in Sources */, + 691E06A021A4FD7600F838EF /* circular_buffer.cc in Sources */, + 691E06AD21A4FD7600F838EF /* ns_core.c in Sources */, + 691E078B21A4FD7700F838EF /* moving_average.cc in Sources */, + 691E069A21A4FD7600F838EF /* rms_level.cc in Sources */, + 691E078E21A4FD7700F838EF /* reverb_model_estimator.cc in Sources */, + 691E070121A4FD7600F838EF /* compute_interpolated_gain_curve.cc in Sources */, + 692AB8ED1E6759DD00706ACC /* OpusEncoder.cpp in Sources */, + 691E06E721A4FD7600F838EF /* features_extraction.cc in Sources */, + 691E061A21A4FD7600F838EF /* levinson_durbin.c in Sources */, + 691E066921A4FD7600F838EF /* pitch_estimator.c in Sources */, + 691E05CC21A4FD7600F838EF /* ascii.cc in Sources */, + 691E079321A4FD7700F838EF /* matched_filter.cc in Sources */, + 691E067221A4FD7600F838EF /* transform.c in Sources */, + 691E069F21A4FD7600F838EF /* moving_max.cc in Sources */, + 691E063221A4FD7600F838EF /* cross_correlation_neon.c in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXTargetDependency section */ + 697B6FCB2136DBA4004C8E54 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = 69F842351E67540700C110F7 /* libtgvoip */; + targetProxy = 697B6FCA2136DBA4004C8E54 /* PBXContainerItemProxy */; + }; +/* End PBXTargetDependency section */ + +/* Begin XCBuildConfiguration section */ + 697B6FCC2136DBA4004C8E54 /* DebugHockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + CODE_SIGN_IDENTITY = "-"; + CODE_SIGN_STYLE = Automatic; + COMBINE_HIDPI_IMAGES = YES; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu11; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + HEADER_SEARCH_PATHS = ( + /usr/local/opt/openssl/include, + webrtc_dsp, + ); + INFOPLIST_FILE = tests/Info.plist; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks @loader_path/../Frameworks"; + LIBRARY_SEARCH_PATHS = ( + /usr/local/opt/openssl/lib, + /usr/local/lib, + ); + MACOSX_DEPLOYMENT_TARGET = 10.13; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + OTHER_CFLAGS = "-DTGVOIP_USE_CALLBACK_AUDIO_IO"; + OTHER_LDFLAGS = ( + "-lopus", + "-lcrypto", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoipTests; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + }; + name = DebugHockeyapp; + }; + 697B6FCD2136DBA4004C8E54 /* Debug Auto Test */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + CODE_SIGN_IDENTITY = "-"; + CODE_SIGN_STYLE = Automatic; + COMBINE_HIDPI_IMAGES = YES; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu11; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + HEADER_SEARCH_PATHS = ( + /usr/local/opt/openssl/include, + webrtc_dsp, + ); + INFOPLIST_FILE = tests/Info.plist; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks @loader_path/../Frameworks"; + LIBRARY_SEARCH_PATHS = ( + /usr/local/opt/openssl/lib, + /usr/local/lib, + ); + MACOSX_DEPLOYMENT_TARGET = 10.13; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + OTHER_CFLAGS = "-DTGVOIP_USE_CALLBACK_AUDIO_IO"; + OTHER_LDFLAGS = ( + "-lopus", + "-lcrypto", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoipTests; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + }; + name = "Debug Auto Test"; + }; + 697B6FCE2136DBA4004C8E54 /* DebugAppStore */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + CODE_SIGN_IDENTITY = "-"; + CODE_SIGN_STYLE = Automatic; + COMBINE_HIDPI_IMAGES = YES; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu11; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + HEADER_SEARCH_PATHS = ( + /usr/local/opt/openssl/include, + webrtc_dsp, + ); + INFOPLIST_FILE = tests/Info.plist; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks @loader_path/../Frameworks"; + LIBRARY_SEARCH_PATHS = ( + /usr/local/opt/openssl/lib, + /usr/local/lib, + ); + MACOSX_DEPLOYMENT_TARGET = 10.13; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + OTHER_CFLAGS = "-DTGVOIP_USE_CALLBACK_AUDIO_IO"; + OTHER_LDFLAGS = ( + "-lopus", + "-lcrypto", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoipTests; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + }; + name = DebugAppStore; + }; + 697B6FCF2136DBA4004C8E54 /* ReleaseHockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + CODE_SIGN_IDENTITY = "-"; + CODE_SIGN_STYLE = Automatic; + COMBINE_HIDPI_IMAGES = YES; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu11; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + HEADER_SEARCH_PATHS = ( + /usr/local/opt/openssl/include, + webrtc_dsp, + ); + INFOPLIST_FILE = tests/Info.plist; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks @loader_path/../Frameworks"; + LIBRARY_SEARCH_PATHS = ( + /usr/local/opt/openssl/lib, + /usr/local/lib, + ); + MACOSX_DEPLOYMENT_TARGET = 10.13; + MTL_ENABLE_DEBUG_INFO = NO; + OTHER_CFLAGS = "-DTGVOIP_USE_CALLBACK_AUDIO_IO"; + OTHER_LDFLAGS = ( + "-lopus", + "-lcrypto", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoipTests; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + }; + name = ReleaseHockeyapp; + }; + 697B6FD02136DBA4004C8E54 /* ReleaseAppStore */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + CODE_SIGN_IDENTITY = "-"; + CODE_SIGN_STYLE = Automatic; + COMBINE_HIDPI_IMAGES = YES; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu11; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + HEADER_SEARCH_PATHS = ( + /usr/local/opt/openssl/include, + webrtc_dsp, + ); + INFOPLIST_FILE = tests/Info.plist; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks @loader_path/../Frameworks"; + LIBRARY_SEARCH_PATHS = ( + /usr/local/opt/openssl/lib, + /usr/local/lib, + ); + MACOSX_DEPLOYMENT_TARGET = 10.13; + MTL_ENABLE_DEBUG_INFO = NO; + OTHER_CFLAGS = "-DTGVOIP_USE_CALLBACK_AUDIO_IO"; + OTHER_LDFLAGS = ( + "-lopus", + "-lcrypto", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoipTests; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + }; + name = ReleaseAppStore; + }; + 69EBC7982136D55A003CFE90 /* Debug Auto Test */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = "Debug Auto Test"; + }; + 69EBC7992136D55A003CFE90 /* Debug Auto Test */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(inherited)", + webrtc_dsp, + /usr/local/include/opus, + /usr/local/opt/openssl/include, + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.7; + OTHER_CFLAGS = ( + "-DWEBRTC_POSIX", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DTGVOIP_USE_DESKTOP_DSP", + "-DWEBRTC_MAC", + "-DTGVOIP_USE_CALLBACK_AUDIO_IO", + "-DWEBRTC_NS_FLOAT", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + SKIP_INSTALL = YES; + }; + name = "Debug Auto Test"; + }; + 69F8423C1E67540700C110F7 /* DebugHockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = DebugHockeyapp; + }; + 69F8423D1E67540700C110F7 /* ReleaseHockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VALIDATE_PRODUCT = YES; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = ReleaseHockeyapp; + }; + 69F8423F1E67540700C110F7 /* DebugHockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(inherited)", + "../../thrid-party/opus/include/opus", + "../../third-party/opus/include/opus", + webrtc_dsp, + "../Telegram-Mac/third-party/opus/include/opus", + "../Telegram-Mac/thrid-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.7; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_POSIX", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DTGVOIP_USE_DESKTOP_DSP", + "-DWEBRTC_MAC", + "-DWEBRTC_NS_FLOAT", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + SKIP_INSTALL = YES; + }; + name = DebugHockeyapp; + }; + 69F842401E67540700C110F7 /* ReleaseHockeyapp */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(inherited)", + "../../thrid-party/opus/include/opus", + "../../third-party/opus/include/opus", + webrtc_dsp, + "../Telegram-Mac/third-party/opus/include/opus", + "../Telegram-Mac/thrid-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.7; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_POSIX", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DTGVOIP_USE_DESKTOP_DSP", + "-DWEBRTC_MAC", + "-DWEBRTC_NS_FLOAT", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + SKIP_INSTALL = YES; + }; + name = ReleaseHockeyapp; + }; + A7F282BB238EA9FB00742C20 /* Github */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + TGVOIP_NO_OSX_PRIVATE_API, + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = Github; + }; + A7F282BC238EA9FB00742C20 /* Github */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(inherited)", + "../../thrid-party/opus/include/opus", + "../../third-party/opus/include/opus", + webrtc_dsp, + "../Telegram-Mac/third-party/opus/include/opus", + "../Telegram-Mac/thrid-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.7; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_POSIX", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DTGVOIP_USE_DESKTOP_DSP", + "-DWEBRTC_MAC", + "-DWEBRTC_NS_FLOAT", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + SKIP_INSTALL = YES; + }; + name = Github; + }; + A7F282BD238EA9FB00742C20 /* Github */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + CODE_SIGN_IDENTITY = "-"; + CODE_SIGN_STYLE = Automatic; + COMBINE_HIDPI_IMAGES = YES; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu11; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + HEADER_SEARCH_PATHS = ( + /usr/local/opt/openssl/include, + webrtc_dsp, + ); + INFOPLIST_FILE = tests/Info.plist; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks @loader_path/../Frameworks"; + LIBRARY_SEARCH_PATHS = ( + /usr/local/opt/openssl/lib, + /usr/local/lib, + ); + MACOSX_DEPLOYMENT_TARGET = 10.13; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + OTHER_CFLAGS = "-DTGVOIP_USE_CALLBACK_AUDIO_IO"; + OTHER_LDFLAGS = ( + "-lopus", + "-lcrypto", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoipTests; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + }; + name = Github; + }; + D045B56522E0C29A005B6623 /* HockeyappMacAlpha */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = HockeyappMacAlpha; + }; + D045B56622E0C29A005B6623 /* HockeyappMacAlpha */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(inherited)", + "../../thrid-party/opus/include/opus", + "../../third-party/opus/include/opus", + webrtc_dsp, + "../Telegram-Mac/third-party/opus/include/opus", + "../Telegram-Mac/thrid-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.7; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_POSIX", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DTGVOIP_USE_DESKTOP_DSP", + "-DWEBRTC_MAC", + "-DWEBRTC_NS_FLOAT", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + SKIP_INSTALL = YES; + }; + name = HockeyappMacAlpha; + }; + D045B56722E0C29A005B6623 /* HockeyappMacAlpha */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_ENABLE_OBJC_WEAK = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + CODE_SIGN_IDENTITY = "-"; + CODE_SIGN_STYLE = Automatic; + COMBINE_HIDPI_IMAGES = YES; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu11; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + HEADER_SEARCH_PATHS = ( + /usr/local/opt/openssl/include, + webrtc_dsp, + ); + INFOPLIST_FILE = tests/Info.plist; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks @loader_path/../Frameworks"; + LIBRARY_SEARCH_PATHS = ( + /usr/local/opt/openssl/lib, + /usr/local/lib, + ); + MACOSX_DEPLOYMENT_TARGET = 10.13; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + OTHER_CFLAGS = "-DTGVOIP_USE_CALLBACK_AUDIO_IO"; + OTHER_LDFLAGS = ( + "-lopus", + "-lcrypto", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoipTests; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + }; + name = HockeyappMacAlpha; + }; + D04D01C31E678C0D0086DDC0 /* DebugAppStore */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + TGVOIP_NO_OSX_PRIVATE_API, + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = DebugAppStore; + }; + D04D01C41E678C0D0086DDC0 /* DebugAppStore */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(inherited)", + "../../thrid-party/opus/include/opus", + "../../third-party/opus/include/opus", + webrtc_dsp, + "../Telegram-Mac/third-party/opus/include/opus", + "../Telegram-Mac/thrid-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.7; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_POSIX", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DTGVOIP_USE_DESKTOP_DSP", + "-DWEBRTC_MAC", + "-DWEBRTC_NS_FLOAT", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + SKIP_INSTALL = YES; + }; + name = DebugAppStore; + }; + D04D01CB1E678C230086DDC0 /* ReleaseAppStore */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_DOCUMENTATION_COMMENTS = YES; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + CURRENT_PROJECT_VERSION = 1; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_PREPROCESSOR_DEFINITIONS = TGVOIP_NO_OSX_PRIVATE_API; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 10.2; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VALIDATE_PRODUCT = YES; + VERSIONING_SYSTEM = "apple-generic"; + VERSION_INFO_PREFIX = ""; + }; + name = ReleaseAppStore; + }; + D04D01CC1E678C230086DDC0 /* ReleaseAppStore */ = { + isa = XCBuildConfiguration; + buildSettings = { + CLANG_CXX_LANGUAGE_STANDARD = "c++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CODE_SIGN_IDENTITY = ""; + DEFINES_MODULE = YES; + DYLIB_COMPATIBILITY_VERSION = 1; + DYLIB_CURRENT_VERSION = 1; + DYLIB_INSTALL_NAME_BASE = "@rpath"; + HEADER_SEARCH_PATHS = ( + "$(inherited)", + "../../thrid-party/opus/include/opus", + "../../third-party/opus/include/opus", + webrtc_dsp, + "../Telegram-Mac/third-party/opus/include/opus", + "../Telegram-Mac/thrid-party/opus/include/opus", + ); + INFOPLIST_FILE = "$(SRCROOT)/Info.plist"; + INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks"; + IPHONEOS_DEPLOYMENT_TARGET = 6.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + LIBRARY_SEARCH_PATHS = "$(inherited)"; + MACH_O_TYPE = staticlib; + MACOSX_DEPLOYMENT_TARGET = 10.7; + OTHER_CFLAGS = ( + "-DTGVOIP_USE_CUSTOM_CRYPTO", + "-DWEBRTC_POSIX", + "-DWEBRTC_APM_DEBUG_DUMP=0", + "-DTGVOIP_USE_DESKTOP_DSP", + "-DWEBRTC_MAC", + "-DWEBRTC_NS_FLOAT", + ); + PRODUCT_BUNDLE_IDENTIFIER = me.grishka.libtgvoip; + PRODUCT_NAME = "$(TARGET_NAME)"; + SDKROOT = macosx; + SKIP_INSTALL = YES; + }; + name = ReleaseAppStore; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 697B6FD12136DBA4004C8E54 /* Build configuration list for PBXNativeTarget "libtgvoipTests" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 697B6FCC2136DBA4004C8E54 /* DebugHockeyapp */, + D045B56722E0C29A005B6623 /* HockeyappMacAlpha */, + 697B6FCD2136DBA4004C8E54 /* Debug Auto Test */, + 697B6FCE2136DBA4004C8E54 /* DebugAppStore */, + A7F282BD238EA9FB00742C20 /* Github */, + 697B6FCF2136DBA4004C8E54 /* ReleaseHockeyapp */, + 697B6FD02136DBA4004C8E54 /* ReleaseAppStore */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = ReleaseHockeyapp; + }; + 69F842301E67540700C110F7 /* Build configuration list for PBXProject "libtgvoip_osx" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 69F8423C1E67540700C110F7 /* DebugHockeyapp */, + D045B56522E0C29A005B6623 /* HockeyappMacAlpha */, + 69EBC7982136D55A003CFE90 /* Debug Auto Test */, + D04D01C31E678C0D0086DDC0 /* DebugAppStore */, + A7F282BB238EA9FB00742C20 /* Github */, + 69F8423D1E67540700C110F7 /* ReleaseHockeyapp */, + D04D01CB1E678C230086DDC0 /* ReleaseAppStore */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = ReleaseHockeyapp; + }; + 69F8423E1E67540700C110F7 /* Build configuration list for PBXNativeTarget "libtgvoip" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 69F8423F1E67540700C110F7 /* DebugHockeyapp */, + D045B56622E0C29A005B6623 /* HockeyappMacAlpha */, + 69EBC7992136D55A003CFE90 /* Debug Auto Test */, + D04D01C41E678C0D0086DDC0 /* DebugAppStore */, + A7F282BC238EA9FB00742C20 /* Github */, + 69F842401E67540700C110F7 /* ReleaseHockeyapp */, + D04D01CC1E678C230086DDC0 /* ReleaseAppStore */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = ReleaseHockeyapp; + }; +/* End XCConfigurationList section */ + }; + rootObject = 69F8422D1E67540700C110F7 /* Project object */; +} diff --git a/TMessagesProj/jni/libtgvoip2/libtgvoip_osx.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/TMessagesProj/jni/libtgvoip2/libtgvoip_osx.xcodeproj/project.xcworkspace/contents.xcworkspacedata new file mode 100644 index 000000000..55fe87423 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/libtgvoip_osx.xcodeproj/project.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,7 @@ + + + + + diff --git a/TMessagesProj/jni/libtgvoip2/libtgvoip_osx.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/TMessagesProj/jni/libtgvoip2/libtgvoip_osx.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist new file mode 100644 index 000000000..18d981003 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/libtgvoip_osx.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist @@ -0,0 +1,8 @@ + + + + + IDEDidComputeMac32BitWarning + + + diff --git a/TMessagesProj/jni/libtgvoip2/libtgvoip_osx.xcodeproj/xcshareddata/IDETemplateMacros.plist b/TMessagesProj/jni/libtgvoip2/libtgvoip_osx.xcodeproj/xcshareddata/IDETemplateMacros.plist new file mode 100644 index 000000000..7e0b977c2 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/libtgvoip_osx.xcodeproj/xcshareddata/IDETemplateMacros.plist @@ -0,0 +1,12 @@ + + + + + FILEHEADER + +libtgvoip is free and unencumbered public domain software. +For more information, see http://unlicense.org or the UNLICENSE file +you should have received with this source code distribution. + + + diff --git a/TMessagesProj/jni/libtgvoip2/logging.cpp b/TMessagesProj/jni/libtgvoip2/logging.cpp new file mode 100644 index 000000000..78724eef8 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/logging.cpp @@ -0,0 +1,104 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + + +#include +#include +#include + +#include "VoIPController.h" + +#ifdef __ANDROID__ +#include +#elif defined(__linux__) +#include +#endif + +#ifdef __APPLE__ +#include +#include "os/darwin/DarwinSpecific.h" +#endif + +FILE* tgvoipLogFile=NULL; + +void tgvoip_log_file_printf(char level, const char* msg, ...){ + if(tgvoipLogFile){ + va_list argptr; + va_start(argptr, msg); + time_t t = time(0); + struct tm *now = localtime(&t); + fprintf(tgvoipLogFile, "%02d-%02d %02d:%02d:%02d %c: ", now->tm_mon + 1, now->tm_mday, now->tm_hour, now->tm_min, now->tm_sec, level); + vfprintf(tgvoipLogFile, msg, argptr); + fprintf(tgvoipLogFile, "\n"); + fflush(tgvoipLogFile); + } +} + +void tgvoip_log_file_write_header(FILE* file){ + if(file){ + time_t t = time(0); + struct tm *now = localtime(&t); +#if defined(_WIN32) + #if WINAPI_PARTITION_DESKTOP + char systemVersion[64]; + OSVERSIONINFOA vInfo; + vInfo.dwOSVersionInfoSize=sizeof(vInfo); + GetVersionExA(&vInfo); + snprintf(systemVersion, sizeof(systemVersion), "Windows %d.%d.%d %s", vInfo.dwMajorVersion, vInfo.dwMinorVersion, vInfo.dwBuildNumber, vInfo.szCSDVersion); +#else + char* systemVersion="Windows RT"; +#endif +#elif defined(__linux__) +#ifdef __ANDROID__ + char systemVersion[128]; + char sysRel[PROP_VALUE_MAX]; + char deviceVendor[PROP_VALUE_MAX]; + char deviceModel[PROP_VALUE_MAX]; + __system_property_get("ro.build.version.release", sysRel); + __system_property_get("ro.product.manufacturer", deviceVendor); + __system_property_get("ro.product.model", deviceModel); + snprintf(systemVersion, sizeof(systemVersion), "Android %s (%s %s)", sysRel, deviceVendor, deviceModel); +#else + struct utsname sysname; + uname(&sysname); + std::string sysver(sysname.sysname); + sysver+=" "; + sysver+=sysname.release; + sysver+=" ("; + sysver+=sysname.version; + sysver+=")"; + const char* systemVersion=sysver.c_str(); +#endif +#elif defined(__APPLE__) + char osxVer[128]; + tgvoip::DarwinSpecific::GetSystemName(osxVer, sizeof(osxVer)); + char systemVersion[128]; +#if TARGET_OS_OSX + snprintf(systemVersion, sizeof(systemVersion), "OS X %s", osxVer); +#elif TARGET_OS_IPHONE + snprintf(systemVersion, sizeof(systemVersion), "iOS %s", osxVer); +#else + snprintf(systemVersion, sizeof(systemVersion), "Unknown Darwin %s", osxVer); +#endif +#else + const char* systemVersion="Unknown OS"; +#endif + +#if defined(__aarch64__) + const char* cpuArch="ARM64"; +#elif defined(__arm__) || defined(_M_ARM) + const char* cpuArch="ARM"; +#elif defined(_M_X64) || defined(__x86_64__) + const char* cpuArch="x86_64"; +#elif defined(_M_IX86) || defined(__i386__) + const char* cpuArch="x86"; +#else + const char* cpuArch="Unknown CPU"; +#endif + + fprintf(file, "---------------\nlibtgvoip v" LIBTGVOIP_VERSION " on %s %s\nLog started on %d/%02d/%d at %d:%02d:%02d\n---------------\n", systemVersion, cpuArch, now->tm_mday, now->tm_mon+1, now->tm_year+1900, now->tm_hour, now->tm_min, now->tm_sec); + } +} diff --git a/TMessagesProj/jni/libtgvoip2/logging.h b/TMessagesProj/jni/libtgvoip2/logging.h new file mode 100644 index 000000000..8f0e61ada --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/logging.h @@ -0,0 +1,106 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef __LOGGING_H +#define __LOGGING_H +#define LSTR_INT(x) LSTR_DO_INT(x) +#define LSTR_DO_INT(x) #x + +#ifdef __APPLE__ +#include +#endif + +#include + +void tgvoip_log_file_printf(char level, const char* msg, ...); +void tgvoip_log_file_write_header(FILE* file); + +#if defined(__ANDROID__) + +#include + +//#define _LOG_WRAP(...) __BASE_FILE__":"LSTR_INT(__LINE__)": "__VA_ARGS__ +#define _LOG_WRAP(...) __VA_ARGS__ +#define TAG "tgvoip" +#define LOGV(...) {__android_log_print(ANDROID_LOG_VERBOSE, TAG, _LOG_WRAP(__VA_ARGS__)); tgvoip_log_file_printf('V', __VA_ARGS__);} +#define LOGD(...) {__android_log_print(ANDROID_LOG_DEBUG, TAG, _LOG_WRAP(__VA_ARGS__)); tgvoip_log_file_printf('D', __VA_ARGS__);} +#define LOGI(...) {__android_log_print(ANDROID_LOG_INFO, TAG, _LOG_WRAP(__VA_ARGS__)); tgvoip_log_file_printf('I', __VA_ARGS__);} +#define LOGW(...) {__android_log_print(ANDROID_LOG_WARN, TAG, _LOG_WRAP(__VA_ARGS__)); tgvoip_log_file_printf('W', __VA_ARGS__);} +#define LOGE(...) {__android_log_print(ANDROID_LOG_ERROR, TAG, _LOG_WRAP(__VA_ARGS__)); tgvoip_log_file_printf('E', __VA_ARGS__);} + +#elif defined(__APPLE__) && TARGET_OS_IPHONE && defined(TGVOIP_HAVE_TGLOG) + +#include "os/darwin/TGLogWrapper.h" + +#define LOGV(msg, ...) {__tgvoip_call_tglog("V/tgvoip: " msg, ##__VA_ARGS__); tgvoip_log_file_printf('V', msg, ##__VA_ARGS__);} +#define LOGD(msg, ...) {__tgvoip_call_tglog("D/tgvoip: " msg, ##__VA_ARGS__); tgvoip_log_file_printf('D', msg, ##__VA_ARGS__);} +#define LOGI(msg, ...) {__tgvoip_call_tglog("I/tgvoip: " msg, ##__VA_ARGS__); tgvoip_log_file_printf('I', msg, ##__VA_ARGS__);} +#define LOGW(msg, ...) {__tgvoip_call_tglog("W/tgvoip: " msg, ##__VA_ARGS__); tgvoip_log_file_printf('W', msg, ##__VA_ARGS__);} +#define LOGE(msg, ...) {__tgvoip_call_tglog("E/tgvoip: " msg, ##__VA_ARGS__); tgvoip_log_file_printf('E', msg, ##__VA_ARGS__);} + +#elif defined(_WIN32) && defined(_DEBUG) + +#include +#include + +#define _TGVOIP_W32_LOG_PRINT(verb, msg, ...){ char __log_buf[1024]; snprintf(__log_buf, 1024, "%c/tgvoip: " msg "\n", verb, ##__VA_ARGS__); OutputDebugStringA(__log_buf); tgvoip_log_file_printf((char)verb, msg, __VA_ARGS__);} + +#define LOGV(msg, ...) _TGVOIP_W32_LOG_PRINT('V', msg, ##__VA_ARGS__) +#define LOGD(msg, ...) _TGVOIP_W32_LOG_PRINT('D', msg, ##__VA_ARGS__) +#define LOGI(msg, ...) _TGVOIP_W32_LOG_PRINT('I', msg, ##__VA_ARGS__) +#define LOGW(msg, ...) _TGVOIP_W32_LOG_PRINT('W', msg, ##__VA_ARGS__) +#define LOGE(msg, ...) _TGVOIP_W32_LOG_PRINT('E', msg, ##__VA_ARGS__) + +#else + +#include + +#ifndef TGVOIP_NO_STDOUT_LOGS +#ifndef TGVOIP_NO_STDOUT_COLOR +#define _TGVOIP_LOG_PRINT(verb, color, msg, ...) {printf("\033[%dm%c/tgvoip: " msg "\033[0m\n", color, verb, ##__VA_ARGS__); tgvoip_log_file_printf(verb, msg, ##__VA_ARGS__);} +#else +#define _TGVOIP_LOG_PRINT(verb, color, msg, ...) {printf("%c/tgvoip: " msg "\n", verb, ##__VA_ARGS__); tgvoip_log_file_printf(verb, msg, ##__VA_ARGS__);} +#endif +#else +#define _TGVOIP_LOG_PRINT(verb, color, msg, ...) {tgvoip_log_file_printf(verb, msg, ##__VA_ARGS__);} +#endif + +#define LOGV(msg, ...) _TGVOIP_LOG_PRINT('V', 90, msg, ##__VA_ARGS__) +#define LOGD(msg, ...) _TGVOIP_LOG_PRINT('D', 37, msg, ##__VA_ARGS__) +#define LOGI(msg, ...) _TGVOIP_LOG_PRINT('I', 94, msg, ##__VA_ARGS__) +#define LOGW(msg, ...) _TGVOIP_LOG_PRINT('W', 93, msg, ##__VA_ARGS__) +#define LOGE(msg, ...) _TGVOIP_LOG_PRINT('E', 91, msg, ##__VA_ARGS__) + +#endif + +#if !defined(snprintf) && defined(_WIN32) && defined(__cplusplus_winrt) +#define snprintf _snprintf +#endif + +#ifdef TGVOIP_LOG_VERBOSITY +#if TGVOIP_LOG_VERBOSITY<5 +#undef LOGV +#define LOGV(msg, ...) +#endif +#if TGVOIP_LOG_VERBOSITY<4 +#undef LOGD +#define LOGD(msg, ...) +#endif +#if TGVOIP_LOG_VERBOSITY<3 +#undef LOGI +#define LOGI(msg, ...) +#endif +#if TGVOIP_LOG_VERBOSITY<2 +#undef LOGW +#define LOGW(msg, ...) +#endif +#if TGVOIP_LOG_VERBOSITY<1 +#undef LOGE +#define LOGE(msg, ...) +#endif +#endif + +#endif //__LOGGING_H diff --git a/TMessagesProj/jni/libtgvoip2/ltmain.sh b/TMessagesProj/jni/libtgvoip2/ltmain.sh new file mode 100644 index 000000000..d3ab94d6f --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/ltmain.sh @@ -0,0 +1,11369 @@ +#! /bin/sh +## DO NOT EDIT - This file generated from ./build-aux/ltmain.in +## by inline-source v2018-07-24.06 + +# libtool (GNU libtool) 2.4.6.42-b88ce +# Provide generalized library-building support services. +# Written by Gordon Matzigkeit , 1996 + +# Copyright (C) 1996-2018 Free Software Foundation, Inc. +# This is free software; see the source for copying conditions. There is NO +# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + +# GNU Libtool 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 2 of the License, or +# (at your option) any later version. +# +# As a special exception to the GNU General Public License, +# if you distribute this file as part of a program or library that +# is built using GNU Libtool, you may include this file under the +# same distribution terms that you use for the rest of that program. +# +# GNU Libtool 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 this program. If not, see . + + +PROGRAM=libtool +PACKAGE=libtool +VERSION=2.4.6.42-b88ce +package_revision=2.4.6.42 + + +## ------ ## +## Usage. ## +## ------ ## + +# Run './libtool --help' for help with using this script from the +# command line. + + +## ------------------------------- ## +## User overridable command paths. ## +## ------------------------------- ## + +# After configure completes, it has a better idea of some of the +# shell tools we need than the defaults used by the functions shared +# with bootstrap, so set those here where they can still be over- +# ridden by the user, but otherwise take precedence. + +: ${AUTOCONF="autoconf"} +: ${AUTOMAKE="automake"} + + +## -------------------------- ## +## Source external libraries. ## +## -------------------------- ## + +# Much of our low-level functionality needs to be sourced from external +# libraries, which are installed to $pkgauxdir. + +# Set a version string for this script. +scriptversion=2018-07-24.06; # UTC + +# General shell script boiler plate, and helper functions. +# Written by Gary V. Vaughan, 2004 + +# This is free software. There is NO warranty; not even for +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +# +# Copyright (C) 2004-2018 Bootstrap Authors +# +# This file is dual licensed under the terms of the MIT license +# , and GPL version 3 or later +# . You must apply one of +# these licenses when using or redistributing this software or any of +# the files within it. See the URLs above, or the file `LICENSE` +# included in the Bootstrap distribution for the full license texts. + +# Please report bugs or propose patches to: +# + + +## ------ ## +## Usage. ## +## ------ ## + +# Evaluate this file near the top of your script to gain access to +# the functions and variables defined here: +# +# . `echo "$0" | ${SED-sed} 's|[^/]*$||'`/build-aux/funclib.sh +# +# If you need to override any of the default environment variable +# settings, do that before evaluating this file. + + +## -------------------- ## +## Shell normalisation. ## +## -------------------- ## + +# Some shells need a little help to be as Bourne compatible as possible. +# Before doing anything else, make sure all that help has been provided! + +DUALCASE=1; export DUALCASE # for MKS sh +if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : + emulate sh + NULLCMD=: + # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which + # is contrary to our usage. Disable this feature. + alias -g '${1+"$@"}'='"$@"' + setopt NO_GLOB_SUBST +else + case `(set -o) 2>/dev/null` in *posix*) set -o posix ;; esac +fi + +# NLS nuisances: We save the old values in case they are required later. +_G_user_locale= +_G_safe_locale= +for _G_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES +do + eval "if test set = \"\${$_G_var+set}\"; then + save_$_G_var=\$$_G_var + $_G_var=C + export $_G_var + _G_user_locale=\"$_G_var=\\\$save_\$_G_var; \$_G_user_locale\" + _G_safe_locale=\"$_G_var=C; \$_G_safe_locale\" + fi" +done + +# Make sure IFS has a sensible default +sp=' ' +nl=' +' +IFS="$sp $nl" + +# There are apparently some retarded systems that use ';' as a PATH separator! +if test "${PATH_SEPARATOR+set}" != set; then + PATH_SEPARATOR=: + (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { + (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || + PATH_SEPARATOR=';' + } +fi + + +# func_unset VAR +# -------------- +# Portably unset VAR. +# In some shells, an 'unset VAR' statement leaves a non-zero return +# status if VAR is already unset, which might be problematic if the +# statement is used at the end of a function (thus poisoning its return +# value) or when 'set -e' is active (causing even a spurious abort of +# the script in this case). +func_unset () +{ + { eval $1=; (eval unset $1) >/dev/null 2>&1 && eval unset $1 || : ; } +} + + +# Make sure CDPATH doesn't cause `cd` commands to output the target dir. +func_unset CDPATH + +# Make sure ${,E,F}GREP behave sanely. +func_unset GREP_OPTIONS + + +## ------------------------- ## +## Locate command utilities. ## +## ------------------------- ## + + +# func_executable_p FILE +# ---------------------- +# Check that FILE is an executable regular file. +func_executable_p () +{ + test -f "$1" && test -x "$1" +} + + +# func_path_progs PROGS_LIST CHECK_FUNC [PATH] +# -------------------------------------------- +# Search for either a program that responds to --version with output +# containing "GNU", or else returned by CHECK_FUNC otherwise, by +# trying all the directories in PATH with each of the elements of +# PROGS_LIST. +# +# CHECK_FUNC should accept the path to a candidate program, and +# set $func_check_prog_result if it truncates its output less than +# $_G_path_prog_max characters. +func_path_progs () +{ + _G_progs_list=$1 + _G_check_func=$2 + _G_PATH=${3-"$PATH"} + + _G_path_prog_max=0 + _G_path_prog_found=false + _G_save_IFS=$IFS; IFS=${PATH_SEPARATOR-:} + for _G_dir in $_G_PATH; do + IFS=$_G_save_IFS + test -z "$_G_dir" && _G_dir=. + for _G_prog_name in $_G_progs_list; do + for _exeext in '' .EXE; do + _G_path_prog=$_G_dir/$_G_prog_name$_exeext + func_executable_p "$_G_path_prog" || continue + case `"$_G_path_prog" --version 2>&1` in + *GNU*) func_path_progs_result=$_G_path_prog _G_path_prog_found=: ;; + *) $_G_check_func $_G_path_prog + func_path_progs_result=$func_check_prog_result + ;; + esac + $_G_path_prog_found && break 3 + done + done + done + IFS=$_G_save_IFS + test -z "$func_path_progs_result" && { + echo "no acceptable sed could be found in \$PATH" >&2 + exit 1 + } +} + + +# We want to be able to use the functions in this file before configure +# has figured out where the best binaries are kept, which means we have +# to search for them ourselves - except when the results are already set +# where we skip the searches. + +# Unless the user overrides by setting SED, search the path for either GNU +# sed, or the sed that truncates its output the least. +test -z "$SED" && { + _G_sed_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ + for _G_i in 1 2 3 4 5 6 7; do + _G_sed_script=$_G_sed_script$nl$_G_sed_script + done + echo "$_G_sed_script" 2>/dev/null | sed 99q >conftest.sed + _G_sed_script= + + func_check_prog_sed () + { + _G_path_prog=$1 + + _G_count=0 + printf 0123456789 >conftest.in + while : + do + cat conftest.in conftest.in >conftest.tmp + mv conftest.tmp conftest.in + cp conftest.in conftest.nl + echo '' >> conftest.nl + "$_G_path_prog" -f conftest.sed conftest.out 2>/dev/null || break + diff conftest.out conftest.nl >/dev/null 2>&1 || break + _G_count=`expr $_G_count + 1` + if test "$_G_count" -gt "$_G_path_prog_max"; then + # Best one so far, save it but keep looking for a better one + func_check_prog_result=$_G_path_prog + _G_path_prog_max=$_G_count + fi + # 10*(2^10) chars as input seems more than enough + test 10 -lt "$_G_count" && break + done + rm -f conftest.in conftest.tmp conftest.nl conftest.out + } + + func_path_progs "sed gsed" func_check_prog_sed "$PATH:/usr/xpg4/bin" + rm -f conftest.sed + SED=$func_path_progs_result +} + + +# Unless the user overrides by setting GREP, search the path for either GNU +# grep, or the grep that truncates its output the least. +test -z "$GREP" && { + func_check_prog_grep () + { + _G_path_prog=$1 + + _G_count=0 + _G_path_prog_max=0 + printf 0123456789 >conftest.in + while : + do + cat conftest.in conftest.in >conftest.tmp + mv conftest.tmp conftest.in + cp conftest.in conftest.nl + echo 'GREP' >> conftest.nl + "$_G_path_prog" -e 'GREP$' -e '-(cannot match)-' conftest.out 2>/dev/null || break + diff conftest.out conftest.nl >/dev/null 2>&1 || break + _G_count=`expr $_G_count + 1` + if test "$_G_count" -gt "$_G_path_prog_max"; then + # Best one so far, save it but keep looking for a better one + func_check_prog_result=$_G_path_prog + _G_path_prog_max=$_G_count + fi + # 10*(2^10) chars as input seems more than enough + test 10 -lt "$_G_count" && break + done + rm -f conftest.in conftest.tmp conftest.nl conftest.out + } + + func_path_progs "grep ggrep" func_check_prog_grep "$PATH:/usr/xpg4/bin" + GREP=$func_path_progs_result +} + + +## ------------------------------- ## +## User overridable command paths. ## +## ------------------------------- ## + +# All uppercase variable names are used for environment variables. These +# variables can be overridden by the user before calling a script that +# uses them if a suitable command of that name is not already available +# in the command search PATH. + +: ${CP="cp -f"} +: ${ECHO="printf %s\n"} +: ${EGREP="$GREP -E"} +: ${FGREP="$GREP -F"} +: ${LN_S="ln -s"} +: ${MAKE="make"} +: ${MKDIR="mkdir"} +: ${MV="mv -f"} +: ${RM="rm -f"} +: ${SHELL="${CONFIG_SHELL-/bin/sh}"} + + +## -------------------- ## +## Useful sed snippets. ## +## -------------------- ## + +sed_dirname='s|/[^/]*$||' +sed_basename='s|^.*/||' + +# Sed substitution that helps us do robust quoting. It backslashifies +# metacharacters that are still active within double-quoted strings. +sed_quote_subst='s|\([`"$\\]\)|\\\1|g' + +# Same as above, but do not quote variable references. +sed_double_quote_subst='s/\(["`\\]\)/\\\1/g' + +# Sed substitution that turns a string into a regex matching for the +# string literally. +sed_make_literal_regex='s|[].[^$\\*\/]|\\&|g' + +# Sed substitution that converts a w32 file name or path +# that contains forward slashes, into one that contains +# (escaped) backslashes. A very naive implementation. +sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g' + +# Re-'\' parameter expansions in output of sed_double_quote_subst that +# were '\'-ed in input to the same. If an odd number of '\' preceded a +# '$' in input to sed_double_quote_subst, that '$' was protected from +# expansion. Since each input '\' is now two '\'s, look for any number +# of runs of four '\'s followed by two '\'s and then a '$'. '\' that '$'. +_G_bs='\\' +_G_bs2='\\\\' +_G_bs4='\\\\\\\\' +_G_dollar='\$' +sed_double_backslash="\ + s/$_G_bs4/&\\ +/g + s/^$_G_bs2$_G_dollar/$_G_bs&/ + s/\\([^$_G_bs]\\)$_G_bs2$_G_dollar/\\1$_G_bs2$_G_bs$_G_dollar/g + s/\n//g" + + +## ----------------- ## +## Global variables. ## +## ----------------- ## + +# Except for the global variables explicitly listed below, the following +# functions in the '^func_' namespace, and the '^require_' namespace +# variables initialised in the 'Resource management' section, sourcing +# this file will not pollute your global namespace with anything +# else. There's no portable way to scope variables in Bourne shell +# though, so actually running these functions will sometimes place +# results into a variable named after the function, and often use +# temporary variables in the '^_G_' namespace. If you are careful to +# avoid using those namespaces casually in your sourcing script, things +# should continue to work as you expect. And, of course, you can freely +# overwrite any of the functions or variables defined here before +# calling anything to customize them. + +EXIT_SUCCESS=0 +EXIT_FAILURE=1 +EXIT_MISMATCH=63 # $? = 63 is used to indicate version mismatch to missing. +EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake. + +# Allow overriding, eg assuming that you follow the convention of +# putting '$debug_cmd' at the start of all your functions, you can get +# bash to show function call trace with: +# +# debug_cmd='eval echo "${FUNCNAME[0]} $*" >&2' bash your-script-name +debug_cmd=${debug_cmd-":"} +exit_cmd=: + +# By convention, finish your script with: +# +# exit $exit_status +# +# so that you can set exit_status to non-zero if you want to indicate +# something went wrong during execution without actually bailing out at +# the point of failure. +exit_status=$EXIT_SUCCESS + +# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh +# is ksh but when the shell is invoked as "sh" and the current value of +# the _XPG environment variable is not equal to 1 (one), the special +# positional parameter $0, within a function call, is the name of the +# function. +progpath=$0 + +# The name of this program. +progname=`$ECHO "$progpath" |$SED "$sed_basename"` + +# Make sure we have an absolute progpath for reexecution: +case $progpath in + [\\/]*|[A-Za-z]:\\*) ;; + *[\\/]*) + progdir=`$ECHO "$progpath" |$SED "$sed_dirname"` + progdir=`cd "$progdir" && pwd` + progpath=$progdir/$progname + ;; + *) + _G_IFS=$IFS + IFS=${PATH_SEPARATOR-:} + for progdir in $PATH; do + IFS=$_G_IFS + test -x "$progdir/$progname" && break + done + IFS=$_G_IFS + test -n "$progdir" || progdir=`pwd` + progpath=$progdir/$progname + ;; +esac + + +## ----------------- ## +## Standard options. ## +## ----------------- ## + +# The following options affect the operation of the functions defined +# below, and should be set appropriately depending on run-time para- +# meters passed on the command line. + +opt_dry_run=false +opt_quiet=false +opt_verbose=false + +# Categories 'all' and 'none' are always available. Append any others +# you will pass as the first argument to func_warning from your own +# code. +warning_categories= + +# By default, display warnings according to 'opt_warning_types'. Set +# 'warning_func' to ':' to elide all warnings, or func_fatal_error to +# treat the next displayed warning as a fatal error. +warning_func=func_warn_and_continue + +# Set to 'all' to display all warnings, 'none' to suppress all +# warnings, or a space delimited list of some subset of +# 'warning_categories' to display only the listed warnings. +opt_warning_types=all + + +## -------------------- ## +## Resource management. ## +## -------------------- ## + +# This section contains definitions for functions that each ensure a +# particular resource (a file, or a non-empty configuration variable for +# example) is available, and if appropriate to extract default values +# from pertinent package files. Call them using their associated +# 'require_*' variable to ensure that they are executed, at most, once. +# +# It's entirely deliberate that calling these functions can set +# variables that don't obey the namespace limitations obeyed by the rest +# of this file, in order that that they be as useful as possible to +# callers. + + +# require_term_colors +# ------------------- +# Allow display of bold text on terminals that support it. +require_term_colors=func_require_term_colors +func_require_term_colors () +{ + $debug_cmd + + test -t 1 && { + # COLORTERM and USE_ANSI_COLORS environment variables take + # precedence, because most terminfo databases neglect to describe + # whether color sequences are supported. + test -n "${COLORTERM+set}" && : ${USE_ANSI_COLORS="1"} + + if test 1 = "$USE_ANSI_COLORS"; then + # Standard ANSI escape sequences + tc_reset='' + tc_bold=''; tc_standout='' + tc_red=''; tc_green='' + tc_blue=''; tc_cyan='' + else + # Otherwise trust the terminfo database after all. + test -n "`tput sgr0 2>/dev/null`" && { + tc_reset=`tput sgr0` + test -n "`tput bold 2>/dev/null`" && tc_bold=`tput bold` + tc_standout=$tc_bold + test -n "`tput smso 2>/dev/null`" && tc_standout=`tput smso` + test -n "`tput setaf 1 2>/dev/null`" && tc_red=`tput setaf 1` + test -n "`tput setaf 2 2>/dev/null`" && tc_green=`tput setaf 2` + test -n "`tput setaf 4 2>/dev/null`" && tc_blue=`tput setaf 4` + test -n "`tput setaf 5 2>/dev/null`" && tc_cyan=`tput setaf 5` + } + fi + } + + require_term_colors=: +} + + +## ----------------- ## +## Function library. ## +## ----------------- ## + +# This section contains a variety of useful functions to call in your +# scripts. Take note of the portable wrappers for features provided by +# some modern shells, which will fall back to slower equivalents on +# less featureful shells. + + +# func_append VAR VALUE +# --------------------- +# Append VALUE onto the existing contents of VAR. + + # We should try to minimise forks, especially on Windows where they are + # unreasonably slow, so skip the feature probes when bash or zsh are + # being used: + if test set = "${BASH_VERSION+set}${ZSH_VERSION+set}"; then + : ${_G_HAVE_ARITH_OP="yes"} + : ${_G_HAVE_XSI_OPS="yes"} + # The += operator was introduced in bash 3.1 + case $BASH_VERSION in + [12].* | 3.0 | 3.0*) ;; + *) + : ${_G_HAVE_PLUSEQ_OP="yes"} + ;; + esac + fi + + # _G_HAVE_PLUSEQ_OP + # Can be empty, in which case the shell is probed, "yes" if += is + # useable or anything else if it does not work. + test -z "$_G_HAVE_PLUSEQ_OP" \ + && (eval 'x=a; x+=" b"; test "a b" = "$x"') 2>/dev/null \ + && _G_HAVE_PLUSEQ_OP=yes + +if test yes = "$_G_HAVE_PLUSEQ_OP" +then + # This is an XSI compatible shell, allowing a faster implementation... + eval 'func_append () + { + $debug_cmd + + eval "$1+=\$2" + }' +else + # ...otherwise fall back to using expr, which is often a shell builtin. + func_append () + { + $debug_cmd + + eval "$1=\$$1\$2" + } +fi + + +# func_append_quoted VAR VALUE +# ---------------------------- +# Quote VALUE and append to the end of shell variable VAR, separated +# by a space. +if test yes = "$_G_HAVE_PLUSEQ_OP"; then + eval 'func_append_quoted () + { + $debug_cmd + + func_quote_arg pretty "$2" + eval "$1+=\\ \$func_quote_arg_result" + }' +else + func_append_quoted () + { + $debug_cmd + + func_quote_arg pretty "$2" + eval "$1=\$$1\\ \$func_quote_arg_result" + } +fi + + +# func_append_uniq VAR VALUE +# -------------------------- +# Append unique VALUE onto the existing contents of VAR, assuming +# entries are delimited by the first character of VALUE. For example: +# +# func_append_uniq options " --another-option option-argument" +# +# will only append to $options if " --another-option option-argument " +# is not already present somewhere in $options already (note spaces at +# each end implied by leading space in second argument). +func_append_uniq () +{ + $debug_cmd + + eval _G_current_value='`$ECHO $'$1'`' + _G_delim=`expr "$2" : '\(.\)'` + + case $_G_delim$_G_current_value$_G_delim in + *"$2$_G_delim"*) ;; + *) func_append "$@" ;; + esac +} + + +# func_arith TERM... +# ------------------ +# Set func_arith_result to the result of evaluating TERMs. + test -z "$_G_HAVE_ARITH_OP" \ + && (eval 'test 2 = $(( 1 + 1 ))') 2>/dev/null \ + && _G_HAVE_ARITH_OP=yes + +if test yes = "$_G_HAVE_ARITH_OP"; then + eval 'func_arith () + { + $debug_cmd + + func_arith_result=$(( $* )) + }' +else + func_arith () + { + $debug_cmd + + func_arith_result=`expr "$@"` + } +fi + + +# func_basename FILE +# ------------------ +# Set func_basename_result to FILE with everything up to and including +# the last / stripped. +if test yes = "$_G_HAVE_XSI_OPS"; then + # If this shell supports suffix pattern removal, then use it to avoid + # forking. Hide the definitions single quotes in case the shell chokes + # on unsupported syntax... + _b='func_basename_result=${1##*/}' + _d='case $1 in + */*) func_dirname_result=${1%/*}$2 ;; + * ) func_dirname_result=$3 ;; + esac' + +else + # ...otherwise fall back to using sed. + _b='func_basename_result=`$ECHO "$1" |$SED "$sed_basename"`' + _d='func_dirname_result=`$ECHO "$1" |$SED "$sed_dirname"` + if test "X$func_dirname_result" = "X$1"; then + func_dirname_result=$3 + else + func_append func_dirname_result "$2" + fi' +fi + +eval 'func_basename () +{ + $debug_cmd + + '"$_b"' +}' + + +# func_dirname FILE APPEND NONDIR_REPLACEMENT +# ------------------------------------------- +# Compute the dirname of FILE. If nonempty, add APPEND to the result, +# otherwise set result to NONDIR_REPLACEMENT. +eval 'func_dirname () +{ + $debug_cmd + + '"$_d"' +}' + + +# func_dirname_and_basename FILE APPEND NONDIR_REPLACEMENT +# -------------------------------------------------------- +# Perform func_basename and func_dirname in a single function +# call: +# dirname: Compute the dirname of FILE. If nonempty, +# add APPEND to the result, otherwise set result +# to NONDIR_REPLACEMENT. +# value returned in "$func_dirname_result" +# basename: Compute filename of FILE. +# value retuned in "$func_basename_result" +# For efficiency, we do not delegate to the functions above but instead +# duplicate the functionality here. +eval 'func_dirname_and_basename () +{ + $debug_cmd + + '"$_b"' + '"$_d"' +}' + + +# func_echo ARG... +# ---------------- +# Echo program name prefixed message. +func_echo () +{ + $debug_cmd + + _G_message=$* + + func_echo_IFS=$IFS + IFS=$nl + for _G_line in $_G_message; do + IFS=$func_echo_IFS + $ECHO "$progname: $_G_line" + done + IFS=$func_echo_IFS +} + + +# func_echo_all ARG... +# -------------------- +# Invoke $ECHO with all args, space-separated. +func_echo_all () +{ + $ECHO "$*" +} + + +# func_echo_infix_1 INFIX ARG... +# ------------------------------ +# Echo program name, followed by INFIX on the first line, with any +# additional lines not showing INFIX. +func_echo_infix_1 () +{ + $debug_cmd + + $require_term_colors + + _G_infix=$1; shift + _G_indent=$_G_infix + _G_prefix="$progname: $_G_infix: " + _G_message=$* + + # Strip color escape sequences before counting printable length + for _G_tc in "$tc_reset" "$tc_bold" "$tc_standout" "$tc_red" "$tc_green" "$tc_blue" "$tc_cyan" + do + test -n "$_G_tc" && { + _G_esc_tc=`$ECHO "$_G_tc" | $SED "$sed_make_literal_regex"` + _G_indent=`$ECHO "$_G_indent" | $SED "s|$_G_esc_tc||g"` + } + done + _G_indent="$progname: "`echo "$_G_indent" | $SED 's|.| |g'`" " ## exclude from sc_prohibit_nested_quotes + + func_echo_infix_1_IFS=$IFS + IFS=$nl + for _G_line in $_G_message; do + IFS=$func_echo_infix_1_IFS + $ECHO "$_G_prefix$tc_bold$_G_line$tc_reset" >&2 + _G_prefix=$_G_indent + done + IFS=$func_echo_infix_1_IFS +} + + +# func_error ARG... +# ----------------- +# Echo program name prefixed message to standard error. +func_error () +{ + $debug_cmd + + $require_term_colors + + func_echo_infix_1 " $tc_standout${tc_red}error$tc_reset" "$*" >&2 +} + + +# func_fatal_error ARG... +# ----------------------- +# Echo program name prefixed message to standard error, and exit. +func_fatal_error () +{ + $debug_cmd + + func_error "$*" + exit $EXIT_FAILURE +} + + +# func_grep EXPRESSION FILENAME +# ----------------------------- +# Check whether EXPRESSION matches any line of FILENAME, without output. +func_grep () +{ + $debug_cmd + + $GREP "$1" "$2" >/dev/null 2>&1 +} + + +# func_len STRING +# --------------- +# Set func_len_result to the length of STRING. STRING may not +# start with a hyphen. + test -z "$_G_HAVE_XSI_OPS" \ + && (eval 'x=a/b/c; + test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \ + && _G_HAVE_XSI_OPS=yes + +if test yes = "$_G_HAVE_XSI_OPS"; then + eval 'func_len () + { + $debug_cmd + + func_len_result=${#1} + }' +else + func_len () + { + $debug_cmd + + func_len_result=`expr "$1" : ".*" 2>/dev/null || echo $max_cmd_len` + } +fi + + +# func_mkdir_p DIRECTORY-PATH +# --------------------------- +# Make sure the entire path to DIRECTORY-PATH is available. +func_mkdir_p () +{ + $debug_cmd + + _G_directory_path=$1 + _G_dir_list= + + if test -n "$_G_directory_path" && test : != "$opt_dry_run"; then + + # Protect directory names starting with '-' + case $_G_directory_path in + -*) _G_directory_path=./$_G_directory_path ;; + esac + + # While some portion of DIR does not yet exist... + while test ! -d "$_G_directory_path"; do + # ...make a list in topmost first order. Use a colon delimited + # list incase some portion of path contains whitespace. + _G_dir_list=$_G_directory_path:$_G_dir_list + + # If the last portion added has no slash in it, the list is done + case $_G_directory_path in */*) ;; *) break ;; esac + + # ...otherwise throw away the child directory and loop + _G_directory_path=`$ECHO "$_G_directory_path" | $SED -e "$sed_dirname"` + done + _G_dir_list=`$ECHO "$_G_dir_list" | $SED 's|:*$||'` + + func_mkdir_p_IFS=$IFS; IFS=: + for _G_dir in $_G_dir_list; do + IFS=$func_mkdir_p_IFS + # mkdir can fail with a 'File exist' error if two processes + # try to create one of the directories concurrently. Don't + # stop in that case! + $MKDIR "$_G_dir" 2>/dev/null || : + done + IFS=$func_mkdir_p_IFS + + # Bail out if we (or some other process) failed to create a directory. + test -d "$_G_directory_path" || \ + func_fatal_error "Failed to create '$1'" + fi +} + + +# func_mktempdir [BASENAME] +# ------------------------- +# Make a temporary directory that won't clash with other running +# libtool processes, and avoids race conditions if possible. If +# given, BASENAME is the basename for that directory. +func_mktempdir () +{ + $debug_cmd + + _G_template=${TMPDIR-/tmp}/${1-$progname} + + if test : = "$opt_dry_run"; then + # Return a directory name, but don't create it in dry-run mode + _G_tmpdir=$_G_template-$$ + else + + # If mktemp works, use that first and foremost + _G_tmpdir=`mktemp -d "$_G_template-XXXXXXXX" 2>/dev/null` + + if test ! -d "$_G_tmpdir"; then + # Failing that, at least try and use $RANDOM to avoid a race + _G_tmpdir=$_G_template-${RANDOM-0}$$ + + func_mktempdir_umask=`umask` + umask 0077 + $MKDIR "$_G_tmpdir" + umask $func_mktempdir_umask + fi + + # If we're not in dry-run mode, bomb out on failure + test -d "$_G_tmpdir" || \ + func_fatal_error "cannot create temporary directory '$_G_tmpdir'" + fi + + $ECHO "$_G_tmpdir" +} + + +# func_normal_abspath PATH +# ------------------------ +# Remove doubled-up and trailing slashes, "." path components, +# and cancel out any ".." path components in PATH after making +# it an absolute path. +func_normal_abspath () +{ + $debug_cmd + + # These SED scripts presuppose an absolute path with a trailing slash. + _G_pathcar='s|^/\([^/]*\).*$|\1|' + _G_pathcdr='s|^/[^/]*||' + _G_removedotparts=':dotsl + s|/\./|/|g + t dotsl + s|/\.$|/|' + _G_collapseslashes='s|/\{1,\}|/|g' + _G_finalslash='s|/*$|/|' + + # Start from root dir and reassemble the path. + func_normal_abspath_result= + func_normal_abspath_tpath=$1 + func_normal_abspath_altnamespace= + case $func_normal_abspath_tpath in + "") + # Empty path, that just means $cwd. + func_stripname '' '/' "`pwd`" + func_normal_abspath_result=$func_stripname_result + return + ;; + # The next three entries are used to spot a run of precisely + # two leading slashes without using negated character classes; + # we take advantage of case's first-match behaviour. + ///*) + # Unusual form of absolute path, do nothing. + ;; + //*) + # Not necessarily an ordinary path; POSIX reserves leading '//' + # and for example Cygwin uses it to access remote file shares + # over CIFS/SMB, so we conserve a leading double slash if found. + func_normal_abspath_altnamespace=/ + ;; + /*) + # Absolute path, do nothing. + ;; + *) + # Relative path, prepend $cwd. + func_normal_abspath_tpath=`pwd`/$func_normal_abspath_tpath + ;; + esac + + # Cancel out all the simple stuff to save iterations. We also want + # the path to end with a slash for ease of parsing, so make sure + # there is one (and only one) here. + func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \ + -e "$_G_removedotparts" -e "$_G_collapseslashes" -e "$_G_finalslash"` + while :; do + # Processed it all yet? + if test / = "$func_normal_abspath_tpath"; then + # If we ascended to the root using ".." the result may be empty now. + if test -z "$func_normal_abspath_result"; then + func_normal_abspath_result=/ + fi + break + fi + func_normal_abspath_tcomponent=`$ECHO "$func_normal_abspath_tpath" | $SED \ + -e "$_G_pathcar"` + func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \ + -e "$_G_pathcdr"` + # Figure out what to do with it + case $func_normal_abspath_tcomponent in + "") + # Trailing empty path component, ignore it. + ;; + ..) + # Parent dir; strip last assembled component from result. + func_dirname "$func_normal_abspath_result" + func_normal_abspath_result=$func_dirname_result + ;; + *) + # Actual path component, append it. + func_append func_normal_abspath_result "/$func_normal_abspath_tcomponent" + ;; + esac + done + # Restore leading double-slash if one was found on entry. + func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspath_result +} + + +# func_notquiet ARG... +# -------------------- +# Echo program name prefixed message only when not in quiet mode. +func_notquiet () +{ + $debug_cmd + + $opt_quiet || func_echo ${1+"$@"} + + # A bug in bash halts the script if the last line of a function + # fails when set -e is in force, so we need another command to + # work around that: + : +} + + +# func_relative_path SRCDIR DSTDIR +# -------------------------------- +# Set func_relative_path_result to the relative path from SRCDIR to DSTDIR. +func_relative_path () +{ + $debug_cmd + + func_relative_path_result= + func_normal_abspath "$1" + func_relative_path_tlibdir=$func_normal_abspath_result + func_normal_abspath "$2" + func_relative_path_tbindir=$func_normal_abspath_result + + # Ascend the tree starting from libdir + while :; do + # check if we have found a prefix of bindir + case $func_relative_path_tbindir in + $func_relative_path_tlibdir) + # found an exact match + func_relative_path_tcancelled= + break + ;; + $func_relative_path_tlibdir*) + # found a matching prefix + func_stripname "$func_relative_path_tlibdir" '' "$func_relative_path_tbindir" + func_relative_path_tcancelled=$func_stripname_result + if test -z "$func_relative_path_result"; then + func_relative_path_result=. + fi + break + ;; + *) + func_dirname $func_relative_path_tlibdir + func_relative_path_tlibdir=$func_dirname_result + if test -z "$func_relative_path_tlibdir"; then + # Have to descend all the way to the root! + func_relative_path_result=../$func_relative_path_result + func_relative_path_tcancelled=$func_relative_path_tbindir + break + fi + func_relative_path_result=../$func_relative_path_result + ;; + esac + done + + # Now calculate path; take care to avoid doubling-up slashes. + func_stripname '' '/' "$func_relative_path_result" + func_relative_path_result=$func_stripname_result + func_stripname '/' '/' "$func_relative_path_tcancelled" + if test -n "$func_stripname_result"; then + func_append func_relative_path_result "/$func_stripname_result" + fi + + # Normalisation. If bindir is libdir, return '.' else relative path. + if test -n "$func_relative_path_result"; then + func_stripname './' '' "$func_relative_path_result" + func_relative_path_result=$func_stripname_result + fi + + test -n "$func_relative_path_result" || func_relative_path_result=. + + : +} + + +# func_quote_portable EVAL ARG +# ---------------------------- +# Internal function to portably implement func_quote_arg. Note that we still +# keep attention to performance here so we as much as possible try to avoid +# calling sed binary (so far O(N) complexity as long as func_append is O(1)). +func_quote_portable () +{ + $debug_cmd + + func_quote_portable_result=$2 + + # one-time-loop (easy break) + while true + do + if $1; then + func_quote_portable_result=`$ECHO "$2" | $SED \ + -e "$sed_double_quote_subst" -e "$sed_double_backslash"` + break + fi + + # Quote for eval. + case $func_quote_portable_result in + *[\\\`\"\$]*) + case $func_quote_portable_result in + *[\[\*\?]*) + func_quote_portable_result=`$ECHO "$func_quote_portable_result" \ + | $SED "$sed_quote_subst"` + break + ;; + esac + + func_quote_portable_old_IFS=$IFS + for _G_char in '\' '`' '"' '$' + do + # STATE($1) PREV($2) SEPARATOR($3) + set start "" "" + func_quote_portable_result=dummy"$_G_char$func_quote_portable_result$_G_char"dummy + IFS=$_G_char + for _G_part in $func_quote_portable_result + do + case $1 in + quote) + func_append func_quote_portable_result "$3$2" + set quote "$_G_part" "\\$_G_char" + ;; + start) + set first "" "" + func_quote_portable_result= + ;; + first) + set quote "$_G_part" "" + ;; + esac + done + done + IFS=$func_quote_portable_old_IFS + ;; + *) ;; + esac + break + done + + func_quote_portable_unquoted_result=$func_quote_portable_result + case $func_quote_portable_result in + # double-quote args containing shell metacharacters to delay + # word splitting, command substitution and variable expansion + # for a subsequent eval. + # many bourne shells cannot handle close brackets correctly + # in scan sets, so we specify it separately. + *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") + func_quote_portable_result=\"$func_quote_portable_result\" + ;; + esac +} + + +# func_quotefast_eval ARG +# ----------------------- +# Quote one ARG (internal). This is equivalent to 'func_quote_arg eval ARG', +# but optimized for speed. Result is stored in $func_quotefast_eval. +if test xyes = `(x=; printf -v x %q yes; echo x"$x") 2>/dev/null`; then + printf -v _GL_test_printf_tilde %q '~' + if test '\~' = "$_GL_test_printf_tilde"; then + func_quotefast_eval () + { + printf -v func_quotefast_eval_result %q "$1" + } + else + # Broken older Bash implementations. Make those faster too if possible. + func_quotefast_eval () + { + case $1 in + '~'*) + func_quote_portable false "$1" + func_quotefast_eval_result=$func_quote_portable_result + ;; + *) + printf -v func_quotefast_eval_result %q "$1" + ;; + esac + } + fi +else + func_quotefast_eval () + { + func_quote_portable false "$1" + func_quotefast_eval_result=$func_quote_portable_result + } +fi + + +# func_quote_arg MODEs ARG +# ------------------------ +# Quote one ARG to be evaled later. MODEs argument may contain zero or more +# specifiers listed below separated by ',' character. This function returns two +# values: +# i) func_quote_arg_result +# double-quoted (when needed), suitable for a subsequent eval +# ii) func_quote_arg_unquoted_result +# has all characters that are still active within double +# quotes backslashified. Available only if 'unquoted' is specified. +# +# Available modes: +# ---------------- +# 'eval' (default) +# - escape shell special characters +# 'expand' +# - the same as 'eval'; but do not quote variable references +# 'pretty' +# - request aesthetic output, i.e. '"a b"' instead of 'a\ b'. This might +# be used later in func_quote to get output like: 'echo "a b"' instead +# of 'echo a\ b'. This is slower than default on some shells. +# 'unquoted' +# - produce also $func_quote_arg_unquoted_result which does not contain +# wrapping double-quotes. +# +# Examples for 'func_quote_arg pretty,unquoted string': +# +# string | *_result | *_unquoted_result +# ------------+-----------------------+------------------- +# " | \" | \" +# a b | "a b" | a b +# "a b" | "\"a b\"" | \"a b\" +# * | "*" | * +# z="${x-$y}" | "z=\"\${x-\$y}\"" | z=\"\${x-\$y}\" +# +# Examples for 'func_quote_arg pretty,unquoted,expand string': +# +# string | *_result | *_unquoted_result +# --------------+---------------------+-------------------- +# z="${x-$y}" | "z=\"${x-$y}\"" | z=\"${x-$y}\" +func_quote_arg () +{ + _G_quote_expand=false + case ,$1, in + *,expand,*) + _G_quote_expand=: + ;; + esac + + case ,$1, in + *,pretty,*|*,expand,*|*,unquoted,*) + func_quote_portable $_G_quote_expand "$2" + func_quote_arg_result=$func_quote_portable_result + func_quote_arg_unquoted_result=$func_quote_portable_unquoted_result + ;; + *) + # Faster quote-for-eval for some shells. + func_quotefast_eval "$2" + func_quote_arg_result=$func_quotefast_eval_result + ;; + esac +} + + +# func_quote MODEs ARGs... +# ------------------------ +# Quote all ARGs to be evaled later and join them into single command. See +# func_quote_arg's description for more info. +func_quote () +{ + $debug_cmd + _G_func_quote_mode=$1 ; shift + func_quote_result= + while test 0 -lt $#; do + func_quote_arg "$_G_func_quote_mode" "$1" + if test -n "$func_quote_result"; then + func_append func_quote_result " $func_quote_arg_result" + else + func_append func_quote_result "$func_quote_arg_result" + fi + shift + done +} + + +# func_stripname PREFIX SUFFIX NAME +# --------------------------------- +# strip PREFIX and SUFFIX from NAME, and store in func_stripname_result. +# PREFIX and SUFFIX must not contain globbing or regex special +# characters, hashes, percent signs, but SUFFIX may contain a leading +# dot (in which case that matches only a dot). +if test yes = "$_G_HAVE_XSI_OPS"; then + eval 'func_stripname () + { + $debug_cmd + + # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are + # positional parameters, so assign one to ordinary variable first. + func_stripname_result=$3 + func_stripname_result=${func_stripname_result#"$1"} + func_stripname_result=${func_stripname_result%"$2"} + }' +else + func_stripname () + { + $debug_cmd + + case $2 in + .*) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%\\\\$2\$%%"`;; + *) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%$2\$%%"`;; + esac + } +fi + + +# func_show_eval CMD [FAIL_EXP] +# ----------------------------- +# Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is +# not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP +# is given, then evaluate it. +func_show_eval () +{ + $debug_cmd + + _G_cmd=$1 + _G_fail_exp=${2-':'} + + func_quote_arg pretty,expand "$_G_cmd" + eval "func_notquiet $func_quote_arg_result" + + $opt_dry_run || { + eval "$_G_cmd" + _G_status=$? + if test 0 -ne "$_G_status"; then + eval "(exit $_G_status); $_G_fail_exp" + fi + } +} + + +# func_show_eval_locale CMD [FAIL_EXP] +# ------------------------------------ +# Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is +# not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP +# is given, then evaluate it. Use the saved locale for evaluation. +func_show_eval_locale () +{ + $debug_cmd + + _G_cmd=$1 + _G_fail_exp=${2-':'} + + $opt_quiet || { + func_quote_arg expand,pretty "$_G_cmd" + eval "func_echo $func_quote_arg_result" + } + + $opt_dry_run || { + eval "$_G_user_locale + $_G_cmd" + _G_status=$? + eval "$_G_safe_locale" + if test 0 -ne "$_G_status"; then + eval "(exit $_G_status); $_G_fail_exp" + fi + } +} + + +# func_tr_sh +# ---------- +# Turn $1 into a string suitable for a shell variable name. +# Result is stored in $func_tr_sh_result. All characters +# not in the set a-zA-Z0-9_ are replaced with '_'. Further, +# if $1 begins with a digit, a '_' is prepended as well. +func_tr_sh () +{ + $debug_cmd + + case $1 in + [0-9]* | *[!a-zA-Z0-9_]*) + func_tr_sh_result=`$ECHO "$1" | $SED -e 's/^\([0-9]\)/_\1/' -e 's/[^a-zA-Z0-9_]/_/g'` + ;; + * ) + func_tr_sh_result=$1 + ;; + esac +} + + +# func_verbose ARG... +# ------------------- +# Echo program name prefixed message in verbose mode only. +func_verbose () +{ + $debug_cmd + + $opt_verbose && func_echo "$*" + + : +} + + +# func_warn_and_continue ARG... +# ----------------------------- +# Echo program name prefixed warning message to standard error. +func_warn_and_continue () +{ + $debug_cmd + + $require_term_colors + + func_echo_infix_1 "${tc_red}warning$tc_reset" "$*" >&2 +} + + +# func_warning CATEGORY ARG... +# ---------------------------- +# Echo program name prefixed warning message to standard error. Warning +# messages can be filtered according to CATEGORY, where this function +# elides messages where CATEGORY is not listed in the global variable +# 'opt_warning_types'. +func_warning () +{ + $debug_cmd + + # CATEGORY must be in the warning_categories list! + case " $warning_categories " in + *" $1 "*) ;; + *) func_internal_error "invalid warning category '$1'" ;; + esac + + _G_category=$1 + shift + + case " $opt_warning_types " in + *" $_G_category "*) $warning_func ${1+"$@"} ;; + esac +} + + +# func_sort_ver VER1 VER2 +# ----------------------- +# 'sort -V' is not generally available. +# Note this deviates from the version comparison in automake +# in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a +# but this should suffice as we won't be specifying old +# version formats or redundant trailing .0 in bootstrap.conf. +# If we did want full compatibility then we should probably +# use m4_version_compare from autoconf. +func_sort_ver () +{ + $debug_cmd + + printf '%s\n%s\n' "$1" "$2" \ + | sort -t. -k 1,1n -k 2,2n -k 3,3n -k 4,4n -k 5,5n -k 6,6n -k 7,7n -k 8,8n -k 9,9n +} + +# func_lt_ver PREV CURR +# --------------------- +# Return true if PREV and CURR are in the correct order according to +# func_sort_ver, otherwise false. Use it like this: +# +# func_lt_ver "$prev_ver" "$proposed_ver" || func_fatal_error "..." +func_lt_ver () +{ + $debug_cmd + + test "x$1" = x`func_sort_ver "$1" "$2" | $SED 1q` +} + + +# Local variables: +# mode: shell-script +# sh-indentation: 2 +# eval: (add-hook 'before-save-hook 'time-stamp) +# time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC" +# time-stamp-time-zone: "UTC" +# End: +#! /bin/sh + +# A portable, pluggable option parser for Bourne shell. +# Written by Gary V. Vaughan, 2010 + +# This is free software. There is NO warranty; not even for +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +# +# Copyright (C) 2010-2018 Bootstrap Authors +# +# This file is dual licensed under the terms of the MIT license +# , and GPL version 3 or later +# . You must apply one of +# these licenses when using or redistributing this software or any of +# the files within it. See the URLs above, or the file `LICENSE` +# included in the Bootstrap distribution for the full license texts. + +# Please report bugs or propose patches to: +# + +# Set a version string for this script. +scriptversion=2018-07-24.06; # UTC + + +## ------ ## +## Usage. ## +## ------ ## + +# This file is a library for parsing options in your shell scripts along +# with assorted other useful supporting features that you can make use +# of too. +# +# For the simplest scripts you might need only: +# +# #!/bin/sh +# . relative/path/to/funclib.sh +# . relative/path/to/options-parser +# scriptversion=1.0 +# func_options ${1+"$@"} +# eval set dummy "$func_options_result"; shift +# ...rest of your script... +# +# In order for the '--version' option to work, you will need to have a +# suitably formatted comment like the one at the top of this file +# starting with '# Written by ' and ending with '# Copyright'. +# +# For '-h' and '--help' to work, you will also need a one line +# description of your script's purpose in a comment directly above the +# '# Written by ' line, like the one at the top of this file. +# +# The default options also support '--debug', which will turn on shell +# execution tracing (see the comment above debug_cmd below for another +# use), and '--verbose' and the func_verbose function to allow your script +# to display verbose messages only when your user has specified +# '--verbose'. +# +# After sourcing this file, you can plug in processing for additional +# options by amending the variables from the 'Configuration' section +# below, and following the instructions in the 'Option parsing' +# section further down. + +## -------------- ## +## Configuration. ## +## -------------- ## + +# You should override these variables in your script after sourcing this +# file so that they reflect the customisations you have added to the +# option parser. + +# The usage line for option parsing errors and the start of '-h' and +# '--help' output messages. You can embed shell variables for delayed +# expansion at the time the message is displayed, but you will need to +# quote other shell meta-characters carefully to prevent them being +# expanded when the contents are evaled. +usage='$progpath [OPTION]...' + +# Short help message in response to '-h' and '--help'. Add to this or +# override it after sourcing this library to reflect the full set of +# options your script accepts. +usage_message="\ + --debug enable verbose shell tracing + -W, --warnings=CATEGORY + report the warnings falling in CATEGORY [all] + -v, --verbose verbosely report processing + --version print version information and exit + -h, --help print short or long help message and exit +" + +# Additional text appended to 'usage_message' in response to '--help'. +long_help_message=" +Warning categories include: + 'all' show all warnings + 'none' turn off all the warnings + 'error' warnings are treated as fatal errors" + +# Help message printed before fatal option parsing errors. +fatal_help="Try '\$progname --help' for more information." + + + +## ------------------------- ## +## Hook function management. ## +## ------------------------- ## + +# This section contains functions for adding, removing, and running hooks +# in the main code. A hook is just a list of function names that can be +# run in order later on. + +# func_hookable FUNC_NAME +# ----------------------- +# Declare that FUNC_NAME will run hooks added with +# 'func_add_hook FUNC_NAME ...'. +func_hookable () +{ + $debug_cmd + + func_append hookable_fns " $1" +} + + +# func_add_hook FUNC_NAME HOOK_FUNC +# --------------------------------- +# Request that FUNC_NAME call HOOK_FUNC before it returns. FUNC_NAME must +# first have been declared "hookable" by a call to 'func_hookable'. +func_add_hook () +{ + $debug_cmd + + case " $hookable_fns " in + *" $1 "*) ;; + *) func_fatal_error "'$1' does not accept hook functions." ;; + esac + + eval func_append ${1}_hooks '" $2"' +} + + +# func_remove_hook FUNC_NAME HOOK_FUNC +# ------------------------------------ +# Remove HOOK_FUNC from the list of hook functions to be called by +# FUNC_NAME. +func_remove_hook () +{ + $debug_cmd + + eval ${1}_hooks='`$ECHO "\$'$1'_hooks" |$SED "s| '$2'||"`' +} + + +# func_propagate_result FUNC_NAME_A FUNC_NAME_B +# --------------------------------------------- +# If the *_result variable of FUNC_NAME_A _is set_, assign its value to +# *_result variable of FUNC_NAME_B. +func_propagate_result () +{ + $debug_cmd + + func_propagate_result_result=: + if eval "test \"\${${1}_result+set}\" = set" + then + eval "${2}_result=\$${1}_result" + else + func_propagate_result_result=false + fi +} + + +# func_run_hooks FUNC_NAME [ARG]... +# --------------------------------- +# Run all hook functions registered to FUNC_NAME. +# It's assumed that the list of hook functions contains nothing more +# than a whitespace-delimited list of legal shell function names, and +# no effort is wasted trying to catch shell meta-characters or preserve +# whitespace. +func_run_hooks () +{ + $debug_cmd + + case " $hookable_fns " in + *" $1 "*) ;; + *) func_fatal_error "'$1' does not support hook functions." ;; + esac + + eval _G_hook_fns=\$$1_hooks; shift + + for _G_hook in $_G_hook_fns; do + func_unset "${_G_hook}_result" + eval $_G_hook '${1+"$@"}' + func_propagate_result $_G_hook func_run_hooks + if $func_propagate_result_result; then + eval set dummy "$func_run_hooks_result"; shift + fi + done +} + + + +## --------------- ## +## Option parsing. ## +## --------------- ## + +# In order to add your own option parsing hooks, you must accept the +# full positional parameter list from your hook function. You may remove +# or edit any options that you action, and then pass back the remaining +# unprocessed options in '_result', escaped +# suitably for 'eval'. +# +# The '_result' variable is automatically unset +# before your hook gets called; for best performance, only set the +# *_result variable when necessary (i.e. don't call the 'func_quote' +# function unnecessarily because it can be an expensive operation on some +# machines). +# +# Like this: +# +# my_options_prep () +# { +# $debug_cmd +# +# # Extend the existing usage message. +# usage_message=$usage_message' +# -s, --silent don'\''t print informational messages +# ' +# # No change in '$@' (ignored completely by this hook). Leave +# # my_options_prep_result variable intact. +# } +# func_add_hook func_options_prep my_options_prep +# +# +# my_silent_option () +# { +# $debug_cmd +# +# args_changed=false +# +# # Note that, for efficiency, we parse as many options as we can +# # recognise in a loop before passing the remainder back to the +# # caller on the first unrecognised argument we encounter. +# while test $# -gt 0; do +# opt=$1; shift +# case $opt in +# --silent|-s) opt_silent=: +# args_changed=: +# ;; +# # Separate non-argument short options: +# -s*) func_split_short_opt "$_G_opt" +# set dummy "$func_split_short_opt_name" \ +# "-$func_split_short_opt_arg" ${1+"$@"} +# shift +# args_changed=: +# ;; +# *) # Make sure the first unrecognised option "$_G_opt" +# # is added back to "$@" in case we need it later, +# # if $args_changed was set to 'true'. +# set dummy "$_G_opt" ${1+"$@"}; shift; break ;; +# esac +# done +# +# # Only call 'func_quote' here if we processed at least one argument. +# if $args_changed; then +# func_quote eval ${1+"$@"} +# my_silent_option_result=$func_quote_result +# fi +# } +# func_add_hook func_parse_options my_silent_option +# +# +# my_option_validation () +# { +# $debug_cmd +# +# $opt_silent && $opt_verbose && func_fatal_help "\ +# '--silent' and '--verbose' options are mutually exclusive." +# } +# func_add_hook func_validate_options my_option_validation +# +# You'll also need to manually amend $usage_message to reflect the extra +# options you parse. It's preferable to append if you can, so that +# multiple option parsing hooks can be added safely. + + +# func_options_finish [ARG]... +# ---------------------------- +# Finishing the option parse loop (call 'func_options' hooks ATM). +func_options_finish () +{ + $debug_cmd + + func_run_hooks func_options ${1+"$@"} + func_propagate_result func_run_hooks func_options_finish +} + + +# func_options [ARG]... +# --------------------- +# All the functions called inside func_options are hookable. See the +# individual implementations for details. +func_hookable func_options +func_options () +{ + $debug_cmd + + _G_options_quoted=false + + for my_func in options_prep parse_options validate_options options_finish + do + func_unset func_${my_func}_result + func_unset func_run_hooks_result + eval func_$my_func '${1+"$@"}' + func_propagate_result func_$my_func func_options + if $func_propagate_result_result; then + eval set dummy "$func_options_result"; shift + _G_options_quoted=: + fi + done + + $_G_options_quoted || { + # As we (func_options) are top-level options-parser function and + # nobody quoted "$@" for us yet, we need to do it explicitly for + # caller. + func_quote eval ${1+"$@"} + func_options_result=$func_quote_result + } +} + + +# func_options_prep [ARG]... +# -------------------------- +# All initialisations required before starting the option parse loop. +# Note that when calling hook functions, we pass through the list of +# positional parameters. If a hook function modifies that list, and +# needs to propagate that back to rest of this script, then the complete +# modified list must be put in 'func_run_hooks_result' before returning. +func_hookable func_options_prep +func_options_prep () +{ + $debug_cmd + + # Option defaults: + opt_verbose=false + opt_warning_types= + + func_run_hooks func_options_prep ${1+"$@"} + func_propagate_result func_run_hooks func_options_prep +} + + +# func_parse_options [ARG]... +# --------------------------- +# The main option parsing loop. +func_hookable func_parse_options +func_parse_options () +{ + $debug_cmd + + _G_parse_options_requote=false + # this just eases exit handling + while test $# -gt 0; do + # Defer to hook functions for initial option parsing, so they + # get priority in the event of reusing an option name. + func_run_hooks func_parse_options ${1+"$@"} + func_propagate_result func_run_hooks func_parse_options + if $func_propagate_result_result; then + eval set dummy "$func_parse_options_result"; shift + # Even though we may have changed "$@", we passed the "$@" array + # down into the hook and it quoted it for us (because we are in + # this if-branch). No need to quote it again. + _G_parse_options_requote=false + fi + + # Break out of the loop if we already parsed every option. + test $# -gt 0 || break + + # We expect that one of the options parsed in this function matches + # and thus we remove _G_opt from "$@" and need to re-quote. + _G_match_parse_options=: + _G_opt=$1 + shift + case $_G_opt in + --debug|-x) debug_cmd='set -x' + func_echo "enabling shell trace mode" >&2 + $debug_cmd + ;; + + --no-warnings|--no-warning|--no-warn) + set dummy --warnings none ${1+"$@"} + shift + ;; + + --warnings|--warning|-W) + if test $# = 0 && func_missing_arg $_G_opt; then + _G_parse_options_requote=: + break + fi + case " $warning_categories $1" in + *" $1 "*) + # trailing space prevents matching last $1 above + func_append_uniq opt_warning_types " $1" + ;; + *all) + opt_warning_types=$warning_categories + ;; + *none) + opt_warning_types=none + warning_func=: + ;; + *error) + opt_warning_types=$warning_categories + warning_func=func_fatal_error + ;; + *) + func_fatal_error \ + "unsupported warning category: '$1'" + ;; + esac + shift + ;; + + --verbose|-v) opt_verbose=: ;; + --version) func_version ;; + -\?|-h) func_usage ;; + --help) func_help ;; + + # Separate optargs to long options (plugins may need this): + --*=*) func_split_equals "$_G_opt" + set dummy "$func_split_equals_lhs" \ + "$func_split_equals_rhs" ${1+"$@"} + shift + ;; + + # Separate optargs to short options: + -W*) + func_split_short_opt "$_G_opt" + set dummy "$func_split_short_opt_name" \ + "$func_split_short_opt_arg" ${1+"$@"} + shift + ;; + + # Separate non-argument short options: + -\?*|-h*|-v*|-x*) + func_split_short_opt "$_G_opt" + set dummy "$func_split_short_opt_name" \ + "-$func_split_short_opt_arg" ${1+"$@"} + shift + ;; + + --) _G_parse_options_requote=: ; break ;; + -*) func_fatal_help "unrecognised option: '$_G_opt'" ;; + *) set dummy "$_G_opt" ${1+"$@"}; shift + _G_match_parse_options=false + break + ;; + esac + + if $_G_match_parse_options; then + _G_parse_options_requote=: + fi + done + + if $_G_parse_options_requote; then + # save modified positional parameters for caller + func_quote eval ${1+"$@"} + func_parse_options_result=$func_quote_result + fi +} + + +# func_validate_options [ARG]... +# ------------------------------ +# Perform any sanity checks on option settings and/or unconsumed +# arguments. +func_hookable func_validate_options +func_validate_options () +{ + $debug_cmd + + # Display all warnings if -W was not given. + test -n "$opt_warning_types" || opt_warning_types=" $warning_categories" + + func_run_hooks func_validate_options ${1+"$@"} + func_propagate_result func_run_hooks func_validate_options + + # Bail if the options were screwed! + $exit_cmd $EXIT_FAILURE +} + + + +## ----------------- ## +## Helper functions. ## +## ----------------- ## + +# This section contains the helper functions used by the rest of the +# hookable option parser framework in ascii-betical order. + + +# func_fatal_help ARG... +# ---------------------- +# Echo program name prefixed message to standard error, followed by +# a help hint, and exit. +func_fatal_help () +{ + $debug_cmd + + eval \$ECHO \""Usage: $usage"\" + eval \$ECHO \""$fatal_help"\" + func_error ${1+"$@"} + exit $EXIT_FAILURE +} + + +# func_help +# --------- +# Echo long help message to standard output and exit. +func_help () +{ + $debug_cmd + + func_usage_message + $ECHO "$long_help_message" + exit 0 +} + + +# func_missing_arg ARGNAME +# ------------------------ +# Echo program name prefixed message to standard error and set global +# exit_cmd. +func_missing_arg () +{ + $debug_cmd + + func_error "Missing argument for '$1'." + exit_cmd=exit +} + + +# func_split_equals STRING +# ------------------------ +# Set func_split_equals_lhs and func_split_equals_rhs shell variables +# after splitting STRING at the '=' sign. +test -z "$_G_HAVE_XSI_OPS" \ + && (eval 'x=a/b/c; + test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \ + && _G_HAVE_XSI_OPS=yes + +if test yes = "$_G_HAVE_XSI_OPS" +then + # This is an XSI compatible shell, allowing a faster implementation... + eval 'func_split_equals () + { + $debug_cmd + + func_split_equals_lhs=${1%%=*} + func_split_equals_rhs=${1#*=} + if test "x$func_split_equals_lhs" = "x$1"; then + func_split_equals_rhs= + fi + }' +else + # ...otherwise fall back to using expr, which is often a shell builtin. + func_split_equals () + { + $debug_cmd + + func_split_equals_lhs=`expr "x$1" : 'x\([^=]*\)'` + func_split_equals_rhs= + test "x$func_split_equals_lhs" = "x$1" \ + || func_split_equals_rhs=`expr "x$1" : 'x[^=]*=\(.*\)$'` + } +fi #func_split_equals + + +# func_split_short_opt SHORTOPT +# ----------------------------- +# Set func_split_short_opt_name and func_split_short_opt_arg shell +# variables after splitting SHORTOPT after the 2nd character. +if test yes = "$_G_HAVE_XSI_OPS" +then + # This is an XSI compatible shell, allowing a faster implementation... + eval 'func_split_short_opt () + { + $debug_cmd + + func_split_short_opt_arg=${1#??} + func_split_short_opt_name=${1%"$func_split_short_opt_arg"} + }' +else + # ...otherwise fall back to using expr, which is often a shell builtin. + func_split_short_opt () + { + $debug_cmd + + func_split_short_opt_name=`expr "x$1" : 'x-\(.\)'` + func_split_short_opt_arg=`expr "x$1" : 'x-.\(.*\)$'` + } +fi #func_split_short_opt + + +# func_usage +# ---------- +# Echo short help message to standard output and exit. +func_usage () +{ + $debug_cmd + + func_usage_message + $ECHO "Run '$progname --help |${PAGER-more}' for full usage" + exit 0 +} + + +# func_usage_message +# ------------------ +# Echo short help message to standard output. +func_usage_message () +{ + $debug_cmd + + eval \$ECHO \""Usage: $usage"\" + echo + $SED -n 's|^# || + /^Written by/{ + x;p;x + } + h + /^Written by/q' < "$progpath" + echo + eval \$ECHO \""$usage_message"\" +} + + +# func_version +# ------------ +# Echo version message to standard output and exit. +# The version message is extracted from the calling file's header +# comments, with leading '# ' stripped: +# 1. First display the progname and version +# 2. Followed by the header comment line matching /^# Written by / +# 3. Then a blank line followed by the first following line matching +# /^# Copyright / +# 4. Immediately followed by any lines between the previous matches, +# except lines preceding the intervening completely blank line. +# For example, see the header comments of this file. +func_version () +{ + $debug_cmd + + printf '%s\n' "$progname $scriptversion" + $SED -n ' + /^# Written by /!b + s|^# ||; p; n + + :fwd2blnk + /./ { + n + b fwd2blnk + } + p; n + + :holdwrnt + s|^# || + s|^# *$|| + /^Copyright /!{ + /./H + n + b holdwrnt + } + + s|\((C)\)[ 0-9,-]*[ ,-]\([1-9][0-9]* \)|\1 \2| + G + s|\(\n\)\n*|\1|g + p; q' < "$progpath" + + exit $? +} + + +# Local variables: +# mode: shell-script +# sh-indentation: 2 +# eval: (add-hook 'before-save-hook 'time-stamp) +# time-stamp-pattern: "30/scriptversion=%:y-%02m-%02d.%02H; # UTC" +# time-stamp-time-zone: "UTC" +# End: + +# Set a version string. +scriptversion='(GNU libtool) 2.4.6.42-b88ce' + + +# func_echo ARG... +# ---------------- +# Libtool also displays the current mode in messages, so override +# funclib.sh func_echo with this custom definition. +func_echo () +{ + $debug_cmd + + _G_message=$* + + func_echo_IFS=$IFS + IFS=$nl + for _G_line in $_G_message; do + IFS=$func_echo_IFS + $ECHO "$progname${opt_mode+: $opt_mode}: $_G_line" + done + IFS=$func_echo_IFS +} + + +# func_warning ARG... +# ------------------- +# Libtool warnings are not categorized, so override funclib.sh +# func_warning with this simpler definition. +func_warning () +{ + $debug_cmd + + $warning_func ${1+"$@"} +} + + +## ---------------- ## +## Options parsing. ## +## ---------------- ## + +# Hook in the functions to make sure our own options are parsed during +# the option parsing loop. + +usage='$progpath [OPTION]... [MODE-ARG]...' + +# Short help message in response to '-h'. +usage_message="Options: + --config show all configuration variables + --debug enable verbose shell tracing + -n, --dry-run display commands without modifying any files + --features display basic configuration information and exit + --mode=MODE use operation mode MODE + --no-warnings equivalent to '-Wnone' + --preserve-dup-deps don't remove duplicate dependency libraries + --quiet, --silent don't print informational messages + --tag=TAG use configuration variables from tag TAG + -v, --verbose print more informational messages than default + --version print version information + -W, --warnings=CATEGORY report the warnings falling in CATEGORY [all] + -h, --help, --help-all print short, long, or detailed help message +" + +# Additional text appended to 'usage_message' in response to '--help'. +func_help () +{ + $debug_cmd + + func_usage_message + $ECHO "$long_help_message + +MODE must be one of the following: + + clean remove files from the build directory + compile compile a source file into a libtool object + execute automatically set library path, then run a program + finish complete the installation of libtool libraries + install install libraries or executables + link create a library or an executable + uninstall remove libraries from an installed directory + +MODE-ARGS vary depending on the MODE. When passed as first option, +'--mode=MODE' may be abbreviated as 'MODE' or a unique abbreviation of that. +Try '$progname --help --mode=MODE' for a more detailed description of MODE. + +When reporting a bug, please describe a test case to reproduce it and +include the following information: + + host-triplet: $host + shell: $SHELL + compiler: $LTCC + compiler flags: $LTCFLAGS + linker: $LD (gnu? $with_gnu_ld) + version: $progname (GNU libtool) 2.4.6.42-b88ce + automake: `($AUTOMAKE --version) 2>/dev/null |$SED 1q` + autoconf: `($AUTOCONF --version) 2>/dev/null |$SED 1q` + +Report bugs to . +GNU libtool home page: . +General help using GNU software: ." + exit 0 +} + + +# func_lo2o OBJECT-NAME +# --------------------- +# Transform OBJECT-NAME from a '.lo' suffix to the platform specific +# object suffix. + +lo2o=s/\\.lo\$/.$objext/ +o2lo=s/\\.$objext\$/.lo/ + +if test yes = "$_G_HAVE_XSI_OPS"; then + eval 'func_lo2o () + { + case $1 in + *.lo) func_lo2o_result=${1%.lo}.$objext ;; + * ) func_lo2o_result=$1 ;; + esac + }' + + # func_xform LIBOBJ-OR-SOURCE + # --------------------------- + # Transform LIBOBJ-OR-SOURCE from a '.o' or '.c' (or otherwise) + # suffix to a '.lo' libtool-object suffix. + eval 'func_xform () + { + func_xform_result=${1%.*}.lo + }' +else + # ...otherwise fall back to using sed. + func_lo2o () + { + func_lo2o_result=`$ECHO "$1" | $SED "$lo2o"` + } + + func_xform () + { + func_xform_result=`$ECHO "$1" | $SED 's|\.[^.]*$|.lo|'` + } +fi + + +# func_fatal_configuration ARG... +# ------------------------------- +# Echo program name prefixed message to standard error, followed by +# a configuration failure hint, and exit. +func_fatal_configuration () +{ + func_fatal_error ${1+"$@"} \ + "See the $PACKAGE documentation for more information." \ + "Fatal configuration error." +} + + +# func_config +# ----------- +# Display the configuration for all the tags in this script. +func_config () +{ + re_begincf='^# ### BEGIN LIBTOOL' + re_endcf='^# ### END LIBTOOL' + + # Default configuration. + $SED "1,/$re_begincf CONFIG/d;/$re_endcf CONFIG/,\$d" < "$progpath" + + # Now print the configurations for the tags. + for tagname in $taglist; do + $SED -n "/$re_begincf TAG CONFIG: $tagname\$/,/$re_endcf TAG CONFIG: $tagname\$/p" < "$progpath" + done + + exit $? +} + + +# func_features +# ------------- +# Display the features supported by this script. +func_features () +{ + echo "host: $host" + if test yes = "$build_libtool_libs"; then + echo "enable shared libraries" + else + echo "disable shared libraries" + fi + if test yes = "$build_old_libs"; then + echo "enable static libraries" + else + echo "disable static libraries" + fi + + exit $? +} + + +# func_enable_tag TAGNAME +# ----------------------- +# Verify that TAGNAME is valid, and either flag an error and exit, or +# enable the TAGNAME tag. We also add TAGNAME to the global $taglist +# variable here. +func_enable_tag () +{ + # Global variable: + tagname=$1 + + re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$" + re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$" + sed_extractcf=/$re_begincf/,/$re_endcf/p + + # Validate tagname. + case $tagname in + *[!-_A-Za-z0-9,/]*) + func_fatal_error "invalid tag name: $tagname" + ;; + esac + + # Don't test for the "default" C tag, as we know it's + # there but not specially marked. + case $tagname in + CC) ;; + *) + if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then + taglist="$taglist $tagname" + + # Evaluate the configuration. Be careful to quote the path + # and the sed script, to avoid splitting on whitespace, but + # also don't use non-portable quotes within backquotes within + # quotes we have to do it in 2 steps: + extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"` + eval "$extractedcf" + else + func_error "ignoring unknown tag $tagname" + fi + ;; + esac +} + + +# func_check_version_match +# ------------------------ +# Ensure that we are using m4 macros, and libtool script from the same +# release of libtool. +func_check_version_match () +{ + if test "$package_revision" != "$macro_revision"; then + if test "$VERSION" != "$macro_version"; then + if test -z "$macro_version"; then + cat >&2 <<_LT_EOF +$progname: Version mismatch error. This is $PACKAGE $VERSION, but the +$progname: definition of this LT_INIT comes from an older release. +$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION +$progname: and run autoconf again. +_LT_EOF + else + cat >&2 <<_LT_EOF +$progname: Version mismatch error. This is $PACKAGE $VERSION, but the +$progname: definition of this LT_INIT comes from $PACKAGE $macro_version. +$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION +$progname: and run autoconf again. +_LT_EOF + fi + else + cat >&2 <<_LT_EOF +$progname: Version mismatch error. This is $PACKAGE $VERSION, revision $package_revision, +$progname: but the definition of this LT_INIT comes from revision $macro_revision. +$progname: You should recreate aclocal.m4 with macros from revision $package_revision +$progname: of $PACKAGE $VERSION and run autoconf again. +_LT_EOF + fi + + exit $EXIT_MISMATCH + fi +} + + +# libtool_options_prep [ARG]... +# ----------------------------- +# Preparation for options parsed by libtool. +libtool_options_prep () +{ + $debug_mode + + # Option defaults: + opt_config=false + opt_dlopen= + opt_dry_run=false + opt_help=false + opt_mode= + opt_preserve_dup_deps=false + opt_quiet=false + + nonopt= + preserve_args= + + _G_rc_lt_options_prep=: + + # Shorthand for --mode=foo, only valid as the first argument + case $1 in + clean|clea|cle|cl) + shift; set dummy --mode clean ${1+"$@"}; shift + ;; + compile|compil|compi|comp|com|co|c) + shift; set dummy --mode compile ${1+"$@"}; shift + ;; + execute|execut|execu|exec|exe|ex|e) + shift; set dummy --mode execute ${1+"$@"}; shift + ;; + finish|finis|fini|fin|fi|f) + shift; set dummy --mode finish ${1+"$@"}; shift + ;; + install|instal|insta|inst|ins|in|i) + shift; set dummy --mode install ${1+"$@"}; shift + ;; + link|lin|li|l) + shift; set dummy --mode link ${1+"$@"}; shift + ;; + uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u) + shift; set dummy --mode uninstall ${1+"$@"}; shift + ;; + *) + _G_rc_lt_options_prep=false + ;; + esac + + if $_G_rc_lt_options_prep; then + # Pass back the list of options. + func_quote eval ${1+"$@"} + libtool_options_prep_result=$func_quote_result + fi +} +func_add_hook func_options_prep libtool_options_prep + + +# libtool_parse_options [ARG]... +# --------------------------------- +# Provide handling for libtool specific options. +libtool_parse_options () +{ + $debug_cmd + + _G_rc_lt_parse_options=false + + # Perform our own loop to consume as many options as possible in + # each iteration. + while test $# -gt 0; do + _G_match_lt_parse_options=: + _G_opt=$1 + shift + case $_G_opt in + --dry-run|--dryrun|-n) + opt_dry_run=: + ;; + + --config) func_config ;; + + --dlopen|-dlopen) + opt_dlopen="${opt_dlopen+$opt_dlopen +}$1" + shift + ;; + + --preserve-dup-deps) + opt_preserve_dup_deps=: ;; + + --features) func_features ;; + + --finish) set dummy --mode finish ${1+"$@"}; shift ;; + + --help) opt_help=: ;; + + --help-all) opt_help=': help-all' ;; + + --mode) test $# = 0 && func_missing_arg $_G_opt && break + opt_mode=$1 + case $1 in + # Valid mode arguments: + clean|compile|execute|finish|install|link|relink|uninstall) ;; + + # Catch anything else as an error + *) func_error "invalid argument for $_G_opt" + exit_cmd=exit + break + ;; + esac + shift + ;; + + --no-silent|--no-quiet) + opt_quiet=false + func_append preserve_args " $_G_opt" + ;; + + --no-warnings|--no-warning|--no-warn) + opt_warning=false + func_append preserve_args " $_G_opt" + ;; + + --no-verbose) + opt_verbose=false + func_append preserve_args " $_G_opt" + ;; + + --silent|--quiet) + opt_quiet=: + opt_verbose=false + func_append preserve_args " $_G_opt" + ;; + + --tag) test $# = 0 && func_missing_arg $_G_opt && break + opt_tag=$1 + func_append preserve_args " $_G_opt $1" + func_enable_tag "$1" + shift + ;; + + --verbose|-v) opt_quiet=false + opt_verbose=: + func_append preserve_args " $_G_opt" + ;; + + # An option not handled by this hook function: + *) set dummy "$_G_opt" ${1+"$@"} ; shift + _G_match_lt_parse_options=false + break + ;; + esac + $_G_match_lt_parse_options && _G_rc_lt_parse_options=: + done + + if $_G_rc_lt_parse_options; then + # save modified positional parameters for caller + func_quote eval ${1+"$@"} + libtool_parse_options_result=$func_quote_result + fi +} +func_add_hook func_parse_options libtool_parse_options + + + +# libtool_validate_options [ARG]... +# --------------------------------- +# Perform any sanity checks on option settings and/or unconsumed +# arguments. +libtool_validate_options () +{ + # save first non-option argument + if test 0 -lt $#; then + nonopt=$1 + shift + fi + + # preserve --debug + test : = "$debug_cmd" || func_append preserve_args " --debug" + + case $host in + # Solaris2 added to fix http://debbugs.gnu.org/cgi/bugreport.cgi?bug=16452 + # see also: http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59788 + *cygwin* | *mingw* | *pw32* | *cegcc* | *solaris2* | *os2*) + # don't eliminate duplications in $postdeps and $predeps + opt_duplicate_compiler_generated_deps=: + ;; + *) + opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps + ;; + esac + + $opt_help || { + # Sanity checks first: + func_check_version_match + + test yes != "$build_libtool_libs" \ + && test yes != "$build_old_libs" \ + && func_fatal_configuration "not configured to build any kind of library" + + # Darwin sucks + eval std_shrext=\"$shrext_cmds\" + + # Only execute mode is allowed to have -dlopen flags. + if test -n "$opt_dlopen" && test execute != "$opt_mode"; then + func_error "unrecognized option '-dlopen'" + $ECHO "$help" 1>&2 + exit $EXIT_FAILURE + fi + + # Change the help message to a mode-specific one. + generic_help=$help + help="Try '$progname --help --mode=$opt_mode' for more information." + } + + # Pass back the unparsed argument list + func_quote eval ${1+"$@"} + libtool_validate_options_result=$func_quote_result +} +func_add_hook func_validate_options libtool_validate_options + + +# Process options as early as possible so that --help and --version +# can return quickly. +func_options ${1+"$@"} +eval set dummy "$func_options_result"; shift + + + +## ----------- ## +## Main. ## +## ----------- ## + +magic='%%%MAGIC variable%%%' +magic_exe='%%%MAGIC EXE variable%%%' + +# Global variables. +extracted_archives= +extracted_serial=0 + +# If this variable is set in any of the actions, the command in it +# will be execed at the end. This prevents here-documents from being +# left over by shells. +exec_cmd= + + +# A function that is used when there is no print builtin or printf. +func_fallback_echo () +{ + eval 'cat <<_LTECHO_EOF +$1 +_LTECHO_EOF' +} + +# func_generated_by_libtool +# True iff stdin has been generated by Libtool. This function is only +# a basic sanity check; it will hardly flush out determined imposters. +func_generated_by_libtool_p () +{ + $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1 +} + +# func_lalib_p file +# True iff FILE is a libtool '.la' library or '.lo' object file. +# This function is only a basic sanity check; it will hardly flush out +# determined imposters. +func_lalib_p () +{ + test -f "$1" && + $SED -e 4q "$1" 2>/dev/null | func_generated_by_libtool_p +} + +# func_lalib_unsafe_p file +# True iff FILE is a libtool '.la' library or '.lo' object file. +# This function implements the same check as func_lalib_p without +# resorting to external programs. To this end, it redirects stdin and +# closes it afterwards, without saving the original file descriptor. +# As a safety measure, use it only where a negative result would be +# fatal anyway. Works if 'file' does not exist. +func_lalib_unsafe_p () +{ + lalib_p=no + if test -f "$1" && test -r "$1" && exec 5<&0 <"$1"; then + for lalib_p_l in 1 2 3 4 + do + read lalib_p_line + case $lalib_p_line in + \#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;; + esac + done + exec 0<&5 5<&- + fi + test yes = "$lalib_p" +} + +# func_ltwrapper_script_p file +# True iff FILE is a libtool wrapper script +# This function is only a basic sanity check; it will hardly flush out +# determined imposters. +func_ltwrapper_script_p () +{ + test -f "$1" && + $lt_truncate_bin < "$1" 2>/dev/null | func_generated_by_libtool_p +} + +# func_ltwrapper_executable_p file +# True iff FILE is a libtool wrapper executable +# This function is only a basic sanity check; it will hardly flush out +# determined imposters. +func_ltwrapper_executable_p () +{ + func_ltwrapper_exec_suffix= + case $1 in + *.exe) ;; + *) func_ltwrapper_exec_suffix=.exe ;; + esac + $GREP "$magic_exe" "$1$func_ltwrapper_exec_suffix" >/dev/null 2>&1 +} + +# func_ltwrapper_scriptname file +# Assumes file is an ltwrapper_executable +# uses $file to determine the appropriate filename for a +# temporary ltwrapper_script. +func_ltwrapper_scriptname () +{ + func_dirname_and_basename "$1" "" "." + func_stripname '' '.exe' "$func_basename_result" + func_ltwrapper_scriptname_result=$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper +} + +# func_ltwrapper_p file +# True iff FILE is a libtool wrapper script or wrapper executable +# This function is only a basic sanity check; it will hardly flush out +# determined imposters. +func_ltwrapper_p () +{ + func_ltwrapper_script_p "$1" || func_ltwrapper_executable_p "$1" +} + + +# func_execute_cmds commands fail_cmd +# Execute tilde-delimited COMMANDS. +# If FAIL_CMD is given, eval that upon failure. +# FAIL_CMD may read-access the current command in variable CMD! +func_execute_cmds () +{ + $debug_cmd + + save_ifs=$IFS; IFS='~' + for cmd in $1; do + IFS=$sp$nl + eval cmd=\"$cmd\" + IFS=$save_ifs + func_show_eval "$cmd" "${2-:}" + done + IFS=$save_ifs +} + + +# func_source file +# Source FILE, adding directory component if necessary. +# Note that it is not necessary on cygwin/mingw to append a dot to +# FILE even if both FILE and FILE.exe exist: automatic-append-.exe +# behavior happens only for exec(3), not for open(2)! Also, sourcing +# 'FILE.' does not work on cygwin managed mounts. +func_source () +{ + $debug_cmd + + case $1 in + */* | *\\*) . "$1" ;; + *) . "./$1" ;; + esac +} + + +# func_resolve_sysroot PATH +# Replace a leading = in PATH with a sysroot. Store the result into +# func_resolve_sysroot_result +func_resolve_sysroot () +{ + func_resolve_sysroot_result=$1 + case $func_resolve_sysroot_result in + =*) + func_stripname '=' '' "$func_resolve_sysroot_result" + func_resolve_sysroot_result=$lt_sysroot$func_stripname_result + ;; + esac +} + +# func_replace_sysroot PATH +# If PATH begins with the sysroot, replace it with = and +# store the result into func_replace_sysroot_result. +func_replace_sysroot () +{ + case $lt_sysroot:$1 in + ?*:"$lt_sysroot"*) + func_stripname "$lt_sysroot" '' "$1" + func_replace_sysroot_result='='$func_stripname_result + ;; + *) + # Including no sysroot. + func_replace_sysroot_result=$1 + ;; + esac +} + +# func_infer_tag arg +# Infer tagged configuration to use if any are available and +# if one wasn't chosen via the "--tag" command line option. +# Only attempt this if the compiler in the base compile +# command doesn't match the default compiler. +# arg is usually of the form 'gcc ...' +func_infer_tag () +{ + $debug_cmd + + if test -n "$available_tags" && test -z "$tagname"; then + CC_quoted= + for arg in $CC; do + func_append_quoted CC_quoted "$arg" + done + CC_expanded=`func_echo_all $CC` + CC_quoted_expanded=`func_echo_all $CC_quoted` + case $@ in + # Blanks in the command may have been stripped by the calling shell, + # but not from the CC environment variable when configure was run. + " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ + " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) ;; + # Blanks at the start of $base_compile will cause this to fail + # if we don't check for them as well. + *) + for z in $available_tags; do + if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then + # Evaluate the configuration. + eval "`$SED -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`" + CC_quoted= + for arg in $CC; do + # Double-quote args containing other shell metacharacters. + func_append_quoted CC_quoted "$arg" + done + CC_expanded=`func_echo_all $CC` + CC_quoted_expanded=`func_echo_all $CC_quoted` + case "$@ " in + " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ + " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) + # The compiler in the base compile command matches + # the one in the tagged configuration. + # Assume this is the tagged configuration we want. + tagname=$z + break + ;; + esac + fi + done + # If $tagname still isn't set, then no tagged configuration + # was found and let the user know that the "--tag" command + # line option must be used. + if test -z "$tagname"; then + func_echo "unable to infer tagged configuration" + func_fatal_error "specify a tag with '--tag'" +# else +# func_verbose "using $tagname tagged configuration" + fi + ;; + esac + fi +} + + + +# func_write_libtool_object output_name pic_name nonpic_name +# Create a libtool object file (analogous to a ".la" file), +# but don't create it if we're doing a dry run. +func_write_libtool_object () +{ + write_libobj=$1 + if test yes = "$build_libtool_libs"; then + write_lobj=\'$2\' + else + write_lobj=none + fi + + if test yes = "$build_old_libs"; then + write_oldobj=\'$3\' + else + write_oldobj=none + fi + + $opt_dry_run || { + cat >${write_libobj}T </dev/null` + if test "$?" -eq 0 && test -n "$func_convert_core_file_wine_to_w32_tmp"; then + func_convert_core_file_wine_to_w32_result=`$ECHO "$func_convert_core_file_wine_to_w32_tmp" | + $SED -e "$sed_naive_backslashify"` + else + func_convert_core_file_wine_to_w32_result= + fi + fi +} +# end: func_convert_core_file_wine_to_w32 + + +# func_convert_core_path_wine_to_w32 ARG +# Helper function used by path conversion functions when $build is *nix, and +# $host is mingw, cygwin, or some other w32 environment. Relies on a correctly +# configured wine environment available, with the winepath program in $build's +# $PATH. Assumes ARG has no leading or trailing path separator characters. +# +# ARG is path to be converted from $build format to win32. +# Result is available in $func_convert_core_path_wine_to_w32_result. +# Unconvertible file (directory) names in ARG are skipped; if no directory names +# are convertible, then the result may be empty. +func_convert_core_path_wine_to_w32 () +{ + $debug_cmd + + # unfortunately, winepath doesn't convert paths, only file names + func_convert_core_path_wine_to_w32_result= + if test -n "$1"; then + oldIFS=$IFS + IFS=: + for func_convert_core_path_wine_to_w32_f in $1; do + IFS=$oldIFS + func_convert_core_file_wine_to_w32 "$func_convert_core_path_wine_to_w32_f" + if test -n "$func_convert_core_file_wine_to_w32_result"; then + if test -z "$func_convert_core_path_wine_to_w32_result"; then + func_convert_core_path_wine_to_w32_result=$func_convert_core_file_wine_to_w32_result + else + func_append func_convert_core_path_wine_to_w32_result ";$func_convert_core_file_wine_to_w32_result" + fi + fi + done + IFS=$oldIFS + fi +} +# end: func_convert_core_path_wine_to_w32 + + +# func_cygpath ARGS... +# Wrapper around calling the cygpath program via LT_CYGPATH. This is used when +# when (1) $build is *nix and Cygwin is hosted via a wine environment; or (2) +# $build is MSYS and $host is Cygwin, or (3) $build is Cygwin. In case (1) or +# (2), returns the Cygwin file name or path in func_cygpath_result (input +# file name or path is assumed to be in w32 format, as previously converted +# from $build's *nix or MSYS format). In case (3), returns the w32 file name +# or path in func_cygpath_result (input file name or path is assumed to be in +# Cygwin format). Returns an empty string on error. +# +# ARGS are passed to cygpath, with the last one being the file name or path to +# be converted. +# +# Specify the absolute *nix (or w32) name to cygpath in the LT_CYGPATH +# environment variable; do not put it in $PATH. +func_cygpath () +{ + $debug_cmd + + if test -n "$LT_CYGPATH" && test -f "$LT_CYGPATH"; then + func_cygpath_result=`$LT_CYGPATH "$@" 2>/dev/null` + if test "$?" -ne 0; then + # on failure, ensure result is empty + func_cygpath_result= + fi + else + func_cygpath_result= + func_error "LT_CYGPATH is empty or specifies non-existent file: '$LT_CYGPATH'" + fi +} +#end: func_cygpath + + +# func_convert_core_msys_to_w32 ARG +# Convert file name or path ARG from MSYS format to w32 format. Return +# result in func_convert_core_msys_to_w32_result. +func_convert_core_msys_to_w32 () +{ + $debug_cmd + + # awkward: cmd appends spaces to result + func_convert_core_msys_to_w32_result=`( cmd //c echo "$1" ) 2>/dev/null | + $SED -e 's/[ ]*$//' -e "$sed_naive_backslashify"` +} +#end: func_convert_core_msys_to_w32 + + +# func_convert_file_check ARG1 ARG2 +# Verify that ARG1 (a file name in $build format) was converted to $host +# format in ARG2. Otherwise, emit an error message, but continue (resetting +# func_to_host_file_result to ARG1). +func_convert_file_check () +{ + $debug_cmd + + if test -z "$2" && test -n "$1"; then + func_error "Could not determine host file name corresponding to" + func_error " '$1'" + func_error "Continuing, but uninstalled executables may not work." + # Fallback: + func_to_host_file_result=$1 + fi +} +# end func_convert_file_check + + +# func_convert_path_check FROM_PATHSEP TO_PATHSEP FROM_PATH TO_PATH +# Verify that FROM_PATH (a path in $build format) was converted to $host +# format in TO_PATH. Otherwise, emit an error message, but continue, resetting +# func_to_host_file_result to a simplistic fallback value (see below). +func_convert_path_check () +{ + $debug_cmd + + if test -z "$4" && test -n "$3"; then + func_error "Could not determine the host path corresponding to" + func_error " '$3'" + func_error "Continuing, but uninstalled executables may not work." + # Fallback. This is a deliberately simplistic "conversion" and + # should not be "improved". See libtool.info. + if test "x$1" != "x$2"; then + lt_replace_pathsep_chars="s|$1|$2|g" + func_to_host_path_result=`echo "$3" | + $SED -e "$lt_replace_pathsep_chars"` + else + func_to_host_path_result=$3 + fi + fi +} +# end func_convert_path_check + + +# func_convert_path_front_back_pathsep FRONTPAT BACKPAT REPL ORIG +# Modifies func_to_host_path_result by prepending REPL if ORIG matches FRONTPAT +# and appending REPL if ORIG matches BACKPAT. +func_convert_path_front_back_pathsep () +{ + $debug_cmd + + case $4 in + $1 ) func_to_host_path_result=$3$func_to_host_path_result + ;; + esac + case $4 in + $2 ) func_append func_to_host_path_result "$3" + ;; + esac +} +# end func_convert_path_front_back_pathsep + + +################################################## +# $build to $host FILE NAME CONVERSION FUNCTIONS # +################################################## +# invoked via '$to_host_file_cmd ARG' +# +# In each case, ARG is the path to be converted from $build to $host format. +# Result will be available in $func_to_host_file_result. + + +# func_to_host_file ARG +# Converts the file name ARG from $build format to $host format. Return result +# in func_to_host_file_result. +func_to_host_file () +{ + $debug_cmd + + $to_host_file_cmd "$1" +} +# end func_to_host_file + + +# func_to_tool_file ARG LAZY +# converts the file name ARG from $build format to toolchain format. Return +# result in func_to_tool_file_result. If the conversion in use is listed +# in (the comma separated) LAZY, no conversion takes place. +func_to_tool_file () +{ + $debug_cmd + + case ,$2, in + *,"$to_tool_file_cmd",*) + func_to_tool_file_result=$1 + ;; + *) + $to_tool_file_cmd "$1" + func_to_tool_file_result=$func_to_host_file_result + ;; + esac +} +# end func_to_tool_file + + +# func_convert_file_noop ARG +# Copy ARG to func_to_host_file_result. +func_convert_file_noop () +{ + func_to_host_file_result=$1 +} +# end func_convert_file_noop + + +# func_convert_file_msys_to_w32 ARG +# Convert file name ARG from (mingw) MSYS to (mingw) w32 format; automatic +# conversion to w32 is not available inside the cwrapper. Returns result in +# func_to_host_file_result. +func_convert_file_msys_to_w32 () +{ + $debug_cmd + + func_to_host_file_result=$1 + if test -n "$1"; then + func_convert_core_msys_to_w32 "$1" + func_to_host_file_result=$func_convert_core_msys_to_w32_result + fi + func_convert_file_check "$1" "$func_to_host_file_result" +} +# end func_convert_file_msys_to_w32 + + +# func_convert_file_cygwin_to_w32 ARG +# Convert file name ARG from Cygwin to w32 format. Returns result in +# func_to_host_file_result. +func_convert_file_cygwin_to_w32 () +{ + $debug_cmd + + func_to_host_file_result=$1 + if test -n "$1"; then + # because $build is cygwin, we call "the" cygpath in $PATH; no need to use + # LT_CYGPATH in this case. + func_to_host_file_result=`cygpath -m "$1"` + fi + func_convert_file_check "$1" "$func_to_host_file_result" +} +# end func_convert_file_cygwin_to_w32 + + +# func_convert_file_nix_to_w32 ARG +# Convert file name ARG from *nix to w32 format. Requires a wine environment +# and a working winepath. Returns result in func_to_host_file_result. +func_convert_file_nix_to_w32 () +{ + $debug_cmd + + func_to_host_file_result=$1 + if test -n "$1"; then + func_convert_core_file_wine_to_w32 "$1" + func_to_host_file_result=$func_convert_core_file_wine_to_w32_result + fi + func_convert_file_check "$1" "$func_to_host_file_result" +} +# end func_convert_file_nix_to_w32 + + +# func_convert_file_msys_to_cygwin ARG +# Convert file name ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. +# Returns result in func_to_host_file_result. +func_convert_file_msys_to_cygwin () +{ + $debug_cmd + + func_to_host_file_result=$1 + if test -n "$1"; then + func_convert_core_msys_to_w32 "$1" + func_cygpath -u "$func_convert_core_msys_to_w32_result" + func_to_host_file_result=$func_cygpath_result + fi + func_convert_file_check "$1" "$func_to_host_file_result" +} +# end func_convert_file_msys_to_cygwin + + +# func_convert_file_nix_to_cygwin ARG +# Convert file name ARG from *nix to Cygwin format. Requires Cygwin installed +# in a wine environment, working winepath, and LT_CYGPATH set. Returns result +# in func_to_host_file_result. +func_convert_file_nix_to_cygwin () +{ + $debug_cmd + + func_to_host_file_result=$1 + if test -n "$1"; then + # convert from *nix to w32, then use cygpath to convert from w32 to cygwin. + func_convert_core_file_wine_to_w32 "$1" + func_cygpath -u "$func_convert_core_file_wine_to_w32_result" + func_to_host_file_result=$func_cygpath_result + fi + func_convert_file_check "$1" "$func_to_host_file_result" +} +# end func_convert_file_nix_to_cygwin + + +############################################# +# $build to $host PATH CONVERSION FUNCTIONS # +############################################# +# invoked via '$to_host_path_cmd ARG' +# +# In each case, ARG is the path to be converted from $build to $host format. +# The result will be available in $func_to_host_path_result. +# +# Path separators are also converted from $build format to $host format. If +# ARG begins or ends with a path separator character, it is preserved (but +# converted to $host format) on output. +# +# All path conversion functions are named using the following convention: +# file name conversion function : func_convert_file_X_to_Y () +# path conversion function : func_convert_path_X_to_Y () +# where, for any given $build/$host combination the 'X_to_Y' value is the +# same. If conversion functions are added for new $build/$host combinations, +# the two new functions must follow this pattern, or func_init_to_host_path_cmd +# will break. + + +# func_init_to_host_path_cmd +# Ensures that function "pointer" variable $to_host_path_cmd is set to the +# appropriate value, based on the value of $to_host_file_cmd. +to_host_path_cmd= +func_init_to_host_path_cmd () +{ + $debug_cmd + + if test -z "$to_host_path_cmd"; then + func_stripname 'func_convert_file_' '' "$to_host_file_cmd" + to_host_path_cmd=func_convert_path_$func_stripname_result + fi +} + + +# func_to_host_path ARG +# Converts the path ARG from $build format to $host format. Return result +# in func_to_host_path_result. +func_to_host_path () +{ + $debug_cmd + + func_init_to_host_path_cmd + $to_host_path_cmd "$1" +} +# end func_to_host_path + + +# func_convert_path_noop ARG +# Copy ARG to func_to_host_path_result. +func_convert_path_noop () +{ + func_to_host_path_result=$1 +} +# end func_convert_path_noop + + +# func_convert_path_msys_to_w32 ARG +# Convert path ARG from (mingw) MSYS to (mingw) w32 format; automatic +# conversion to w32 is not available inside the cwrapper. Returns result in +# func_to_host_path_result. +func_convert_path_msys_to_w32 () +{ + $debug_cmd + + func_to_host_path_result=$1 + if test -n "$1"; then + # Remove leading and trailing path separator characters from ARG. MSYS + # behavior is inconsistent here; cygpath turns them into '.;' and ';.'; + # and winepath ignores them completely. + func_stripname : : "$1" + func_to_host_path_tmp1=$func_stripname_result + func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" + func_to_host_path_result=$func_convert_core_msys_to_w32_result + func_convert_path_check : ";" \ + "$func_to_host_path_tmp1" "$func_to_host_path_result" + func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" + fi +} +# end func_convert_path_msys_to_w32 + + +# func_convert_path_cygwin_to_w32 ARG +# Convert path ARG from Cygwin to w32 format. Returns result in +# func_to_host_file_result. +func_convert_path_cygwin_to_w32 () +{ + $debug_cmd + + func_to_host_path_result=$1 + if test -n "$1"; then + # See func_convert_path_msys_to_w32: + func_stripname : : "$1" + func_to_host_path_tmp1=$func_stripname_result + func_to_host_path_result=`cygpath -m -p "$func_to_host_path_tmp1"` + func_convert_path_check : ";" \ + "$func_to_host_path_tmp1" "$func_to_host_path_result" + func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" + fi +} +# end func_convert_path_cygwin_to_w32 + + +# func_convert_path_nix_to_w32 ARG +# Convert path ARG from *nix to w32 format. Requires a wine environment and +# a working winepath. Returns result in func_to_host_file_result. +func_convert_path_nix_to_w32 () +{ + $debug_cmd + + func_to_host_path_result=$1 + if test -n "$1"; then + # See func_convert_path_msys_to_w32: + func_stripname : : "$1" + func_to_host_path_tmp1=$func_stripname_result + func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" + func_to_host_path_result=$func_convert_core_path_wine_to_w32_result + func_convert_path_check : ";" \ + "$func_to_host_path_tmp1" "$func_to_host_path_result" + func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" + fi +} +# end func_convert_path_nix_to_w32 + + +# func_convert_path_msys_to_cygwin ARG +# Convert path ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. +# Returns result in func_to_host_file_result. +func_convert_path_msys_to_cygwin () +{ + $debug_cmd + + func_to_host_path_result=$1 + if test -n "$1"; then + # See func_convert_path_msys_to_w32: + func_stripname : : "$1" + func_to_host_path_tmp1=$func_stripname_result + func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" + func_cygpath -u -p "$func_convert_core_msys_to_w32_result" + func_to_host_path_result=$func_cygpath_result + func_convert_path_check : : \ + "$func_to_host_path_tmp1" "$func_to_host_path_result" + func_convert_path_front_back_pathsep ":*" "*:" : "$1" + fi +} +# end func_convert_path_msys_to_cygwin + + +# func_convert_path_nix_to_cygwin ARG +# Convert path ARG from *nix to Cygwin format. Requires Cygwin installed in a +# a wine environment, working winepath, and LT_CYGPATH set. Returns result in +# func_to_host_file_result. +func_convert_path_nix_to_cygwin () +{ + $debug_cmd + + func_to_host_path_result=$1 + if test -n "$1"; then + # Remove leading and trailing path separator characters from + # ARG. msys behavior is inconsistent here, cygpath turns them + # into '.;' and ';.', and winepath ignores them completely. + func_stripname : : "$1" + func_to_host_path_tmp1=$func_stripname_result + func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" + func_cygpath -u -p "$func_convert_core_path_wine_to_w32_result" + func_to_host_path_result=$func_cygpath_result + func_convert_path_check : : \ + "$func_to_host_path_tmp1" "$func_to_host_path_result" + func_convert_path_front_back_pathsep ":*" "*:" : "$1" + fi +} +# end func_convert_path_nix_to_cygwin + + +# func_dll_def_p FILE +# True iff FILE is a Windows DLL '.def' file. +# Keep in sync with _LT_DLL_DEF_P in libtool.m4 +func_dll_def_p () +{ + $debug_cmd + + func_dll_def_p_tmp=`$SED -n \ + -e 's/^[ ]*//' \ + -e '/^\(;.*\)*$/d' \ + -e 's/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p' \ + -e q \ + "$1"` + test DEF = "$func_dll_def_p_tmp" +} + + +# func_mode_compile arg... +func_mode_compile () +{ + $debug_cmd + + # Get the compilation command and the source file. + base_compile= + srcfile=$nonopt # always keep a non-empty value in "srcfile" + suppress_opt=yes + suppress_output= + arg_mode=normal + libobj= + later= + pie_flag= + + for arg + do + case $arg_mode in + arg ) + # do not "continue". Instead, add this to base_compile + lastarg=$arg + arg_mode=normal + ;; + + target ) + libobj=$arg + arg_mode=normal + continue + ;; + + normal ) + # Accept any command-line options. + case $arg in + -o) + test -n "$libobj" && \ + func_fatal_error "you cannot specify '-o' more than once" + arg_mode=target + continue + ;; + + -pie | -fpie | -fPIE) + func_append pie_flag " $arg" + continue + ;; + + -shared | -static | -prefer-pic | -prefer-non-pic) + func_append later " $arg" + continue + ;; + + -no-suppress) + suppress_opt=no + continue + ;; + + -Xcompiler) + arg_mode=arg # the next one goes into the "base_compile" arg list + continue # The current "srcfile" will either be retained or + ;; # replaced later. I would guess that would be a bug. + + -Wc,*) + func_stripname '-Wc,' '' "$arg" + args=$func_stripname_result + lastarg= + save_ifs=$IFS; IFS=, + for arg in $args; do + IFS=$save_ifs + func_append_quoted lastarg "$arg" + done + IFS=$save_ifs + func_stripname ' ' '' "$lastarg" + lastarg=$func_stripname_result + + # Add the arguments to base_compile. + func_append base_compile " $lastarg" + continue + ;; + + *) + # Accept the current argument as the source file. + # The previous "srcfile" becomes the current argument. + # + lastarg=$srcfile + srcfile=$arg + ;; + esac # case $arg + ;; + esac # case $arg_mode + + # Aesthetically quote the previous argument. + func_append_quoted base_compile "$lastarg" + done # for arg + + case $arg_mode in + arg) + func_fatal_error "you must specify an argument for -Xcompile" + ;; + target) + func_fatal_error "you must specify a target with '-o'" + ;; + *) + # Get the name of the library object. + test -z "$libobj" && { + func_basename "$srcfile" + libobj=$func_basename_result + } + ;; + esac + + # Recognize several different file suffixes. + # If the user specifies -o file.o, it is replaced with file.lo + case $libobj in + *.[cCFSifmso] | \ + *.ada | *.adb | *.ads | *.asm | \ + *.c++ | *.cc | *.ii | *.class | *.cpp | *.cxx | \ + *.[fF][09]? | *.for | *.java | *.go | *.obj | *.sx | *.cu | *.cup) + func_xform "$libobj" + libobj=$func_xform_result + ;; + esac + + case $libobj in + *.lo) func_lo2o "$libobj"; obj=$func_lo2o_result ;; + *) + func_fatal_error "cannot determine name of library object from '$libobj'" + ;; + esac + + func_infer_tag $base_compile + + for arg in $later; do + case $arg in + -shared) + test yes = "$build_libtool_libs" \ + || func_fatal_configuration "cannot build a shared library" + build_old_libs=no + continue + ;; + + -static) + build_libtool_libs=no + build_old_libs=yes + continue + ;; + + -prefer-pic) + pic_mode=yes + continue + ;; + + -prefer-non-pic) + pic_mode=no + continue + ;; + esac + done + + func_quote_arg pretty "$libobj" + test "X$libobj" != "X$func_quote_arg_result" \ + && $ECHO "X$libobj" | $GREP '[]~#^*{};<>?"'"'"' &()|`$[]' \ + && func_warning "libobj name '$libobj' may not contain shell special characters." + func_dirname_and_basename "$obj" "/" "" + objname=$func_basename_result + xdir=$func_dirname_result + lobj=$xdir$objdir/$objname + + test -z "$base_compile" && \ + func_fatal_help "you must specify a compilation command" + + # Delete any leftover library objects. + if test yes = "$build_old_libs"; then + removelist="$obj $lobj $libobj ${libobj}T" + else + removelist="$lobj $libobj ${libobj}T" + fi + + # On Cygwin there's no "real" PIC flag so we must build both object types + case $host_os in + cygwin* | mingw* | pw32* | os2* | cegcc*) + pic_mode=default + ;; + esac + if test no = "$pic_mode" && test pass_all != "$deplibs_check_method"; then + # non-PIC code in shared libraries is not supported + pic_mode=default + fi + + # Calculate the filename of the output object if compiler does + # not support -o with -c + if test no = "$compiler_c_o"; then + output_obj=`$ECHO "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.$objext + lockfile=$output_obj.lock + else + output_obj= + need_locks=no + lockfile= + fi + + # Lock this critical section if it is needed + # We use this script file to make the link, it avoids creating a new file + if test yes = "$need_locks"; then + until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do + func_echo "Waiting for $lockfile to be removed" + sleep 2 + done + elif test warn = "$need_locks"; then + if test -f "$lockfile"; then + $ECHO "\ +*** ERROR, $lockfile exists and contains: +`cat $lockfile 2>/dev/null` + +This indicates that another process is trying to use the same +temporary object file, and libtool could not work around it because +your compiler does not support '-c' and '-o' together. If you +repeat this compilation, it may succeed, by chance, but you had better +avoid parallel builds (make -j) in this platform, or get a better +compiler." + + $opt_dry_run || $RM $removelist + exit $EXIT_FAILURE + fi + func_append removelist " $output_obj" + $ECHO "$srcfile" > "$lockfile" + fi + + $opt_dry_run || $RM $removelist + func_append removelist " $lockfile" + trap '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' 1 2 15 + + func_to_tool_file "$srcfile" func_convert_file_msys_to_w32 + srcfile=$func_to_tool_file_result + func_quote_arg pretty "$srcfile" + qsrcfile=$func_quote_arg_result + + # Only build a PIC object if we are building libtool libraries. + if test yes = "$build_libtool_libs"; then + # Without this assignment, base_compile gets emptied. + fbsd_hideous_sh_bug=$base_compile + + if test no != "$pic_mode"; then + command="$base_compile $qsrcfile $pic_flag" + else + # Don't build PIC code + command="$base_compile $qsrcfile" + fi + + func_mkdir_p "$xdir$objdir" + + if test -z "$output_obj"; then + # Place PIC objects in $objdir + func_append command " -o $lobj" + fi + + func_show_eval_locale "$command" \ + 'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE' + + if test warn = "$need_locks" && + test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then + $ECHO "\ +*** ERROR, $lockfile contains: +`cat $lockfile 2>/dev/null` + +but it should contain: +$srcfile + +This indicates that another process is trying to use the same +temporary object file, and libtool could not work around it because +your compiler does not support '-c' and '-o' together. If you +repeat this compilation, it may succeed, by chance, but you had better +avoid parallel builds (make -j) in this platform, or get a better +compiler." + + $opt_dry_run || $RM $removelist + exit $EXIT_FAILURE + fi + + # Just move the object if needed, then go on to compile the next one + if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then + func_show_eval '$MV "$output_obj" "$lobj"' \ + 'error=$?; $opt_dry_run || $RM $removelist; exit $error' + fi + + # Allow error messages only from the first compilation. + if test yes = "$suppress_opt"; then + suppress_output=' >/dev/null 2>&1' + fi + fi + + # Only build a position-dependent object if we build old libraries. + if test yes = "$build_old_libs"; then + if test yes != "$pic_mode"; then + # Don't build PIC code + command="$base_compile $qsrcfile$pie_flag" + else + command="$base_compile $qsrcfile $pic_flag" + fi + if test yes = "$compiler_c_o"; then + func_append command " -o $obj" + fi + + # Suppress compiler output if we already did a PIC compilation. + func_append command "$suppress_output" + func_show_eval_locale "$command" \ + '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' + + if test warn = "$need_locks" && + test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then + $ECHO "\ +*** ERROR, $lockfile contains: +`cat $lockfile 2>/dev/null` + +but it should contain: +$srcfile + +This indicates that another process is trying to use the same +temporary object file, and libtool could not work around it because +your compiler does not support '-c' and '-o' together. If you +repeat this compilation, it may succeed, by chance, but you had better +avoid parallel builds (make -j) in this platform, or get a better +compiler." + + $opt_dry_run || $RM $removelist + exit $EXIT_FAILURE + fi + + # Just move the object if needed + if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then + func_show_eval '$MV "$output_obj" "$obj"' \ + 'error=$?; $opt_dry_run || $RM $removelist; exit $error' + fi + fi + + $opt_dry_run || { + func_write_libtool_object "$libobj" "$objdir/$objname" "$objname" + + # Unlock the critical section if it was locked + if test no != "$need_locks"; then + removelist=$lockfile + $RM "$lockfile" + fi + } + + exit $EXIT_SUCCESS +} + +$opt_help || { + test compile = "$opt_mode" && func_mode_compile ${1+"$@"} +} + +func_mode_help () +{ + # We need to display help for each of the modes. + case $opt_mode in + "") + # Generic help is extracted from the usage comments + # at the start of this file. + func_help + ;; + + clean) + $ECHO \ +"Usage: $progname [OPTION]... --mode=clean RM [RM-OPTION]... FILE... + +Remove files from the build directory. + +RM is the name of the program to use to delete files associated with each FILE +(typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed +to RM. + +If FILE is a libtool library, object or program, all the files associated +with it are deleted. Otherwise, only FILE itself is deleted using RM." + ;; + + compile) + $ECHO \ +"Usage: $progname [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE + +Compile a source file into a libtool library object. + +This mode accepts the following additional options: + + -o OUTPUT-FILE set the output file name to OUTPUT-FILE + -no-suppress do not suppress compiler output for multiple passes + -prefer-pic try to build PIC objects only + -prefer-non-pic try to build non-PIC objects only + -shared do not build a '.o' file suitable for static linking + -static only build a '.o' file suitable for static linking + -Wc,FLAG pass FLAG directly to the compiler + +COMPILE-COMMAND is a command to be used in creating a 'standard' object file +from the given SOURCEFILE. + +The output file name is determined by removing the directory component from +SOURCEFILE, then substituting the C source code suffix '.c' with the +library object suffix, '.lo'." + ;; + + execute) + $ECHO \ +"Usage: $progname [OPTION]... --mode=execute COMMAND [ARGS]... + +Automatically set library path, then run a program. + +This mode accepts the following additional options: + + -dlopen FILE add the directory containing FILE to the library path + +This mode sets the library path environment variable according to '-dlopen' +flags. + +If any of the ARGS are libtool executable wrappers, then they are translated +into their corresponding uninstalled binary, and any of their required library +directories are added to the library path. + +Then, COMMAND is executed, with ARGS as arguments." + ;; + + finish) + $ECHO \ +"Usage: $progname [OPTION]... --mode=finish [LIBDIR]... + +Complete the installation of libtool libraries. + +Each LIBDIR is a directory that contains libtool libraries. + +The commands that this mode executes may require superuser privileges. Use +the '--dry-run' option if you just want to see what would be executed." + ;; + + install) + $ECHO \ +"Usage: $progname [OPTION]... --mode=install INSTALL-COMMAND... + +Install executables or libraries. + +INSTALL-COMMAND is the installation command. The first component should be +either the 'install' or 'cp' program. + +The following components of INSTALL-COMMAND are treated specially: + + -inst-prefix-dir PREFIX-DIR Use PREFIX-DIR as a staging area for installation + +The rest of the components are interpreted as arguments to that command (only +BSD-compatible install options are recognized)." + ;; + + link) + $ECHO \ +"Usage: $progname [OPTION]... --mode=link LINK-COMMAND... + +Link object files or libraries together to form another library, or to +create an executable program. + +LINK-COMMAND is a command using the C compiler that you would use to create +a program from several object files. + +The following components of LINK-COMMAND are treated specially: + + -all-static do not do any dynamic linking at all + -avoid-version do not add a version suffix if possible + -bindir BINDIR specify path to binaries directory (for systems where + libraries must be found in the PATH setting at runtime) + -dlopen FILE '-dlpreopen' FILE if it cannot be dlopened at runtime + -dlpreopen FILE link in FILE and add its symbols to lt_preloaded_symbols + -export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3) + -export-symbols SYMFILE + try to export only the symbols listed in SYMFILE + -export-symbols-regex REGEX + try to export only the symbols matching REGEX + -LLIBDIR search LIBDIR for required installed libraries + -lNAME OUTPUT-FILE requires the installed library libNAME + -module build a library that can dlopened + -no-fast-install disable the fast-install mode + -no-install link a not-installable executable + -no-undefined declare that a library does not refer to external symbols + -o OUTPUT-FILE create OUTPUT-FILE from the specified objects + -objectlist FILE use a list of object files found in FILE to specify objects + -os2dllname NAME force a short DLL name on OS/2 (no effect on other OSes) + -precious-files-regex REGEX + don't remove output files matching REGEX + -release RELEASE specify package release information + -rpath LIBDIR the created library will eventually be installed in LIBDIR + -R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries + -shared only do dynamic linking of libtool libraries + -shrext SUFFIX override the standard shared library file extension + -static do not do any dynamic linking of uninstalled libtool libraries + -static-libtool-libs + do not do any dynamic linking of libtool libraries + -version-info CURRENT[:REVISION[:AGE]] + specify library version info [each variable defaults to 0] + -weak LIBNAME declare that the target provides the LIBNAME interface + -Wc,FLAG + -Xcompiler FLAG pass linker-specific FLAG directly to the compiler + -Wl,FLAG + -Xlinker FLAG pass linker-specific FLAG directly to the linker + -XCClinker FLAG pass link-specific FLAG to the compiler driver (CC) + +All other options (arguments beginning with '-') are ignored. + +Every other argument is treated as a filename. Files ending in '.la' are +treated as uninstalled libtool libraries, other files are standard or library +object files. + +If the OUTPUT-FILE ends in '.la', then a libtool library is created, +only library objects ('.lo' files) may be specified, and '-rpath' is +required, except when creating a convenience library. + +If OUTPUT-FILE ends in '.a' or '.lib', then a standard library is created +using 'ar' and 'ranlib', or on Windows using 'lib'. + +If OUTPUT-FILE ends in '.lo' or '.$objext', then a reloadable object file +is created, otherwise an executable program is created." + ;; + + uninstall) + $ECHO \ +"Usage: $progname [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE... + +Remove libraries from an installation directory. + +RM is the name of the program to use to delete files associated with each FILE +(typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed +to RM. + +If FILE is a libtool library, all the files associated with it are deleted. +Otherwise, only FILE itself is deleted using RM." + ;; + + *) + func_fatal_help "invalid operation mode '$opt_mode'" + ;; + esac + + echo + $ECHO "Try '$progname --help' for more information about other modes." +} + +# Now that we've collected a possible --mode arg, show help if necessary +if $opt_help; then + if test : = "$opt_help"; then + func_mode_help + else + { + func_help noexit + for opt_mode in compile link execute install finish uninstall clean; do + func_mode_help + done + } | $SED -n '1p; 2,$s/^Usage:/ or: /p' + { + func_help noexit + for opt_mode in compile link execute install finish uninstall clean; do + echo + func_mode_help + done + } | + $SED '1d + /^When reporting/,/^Report/{ + H + d + } + $x + /information about other modes/d + /more detailed .*MODE/d + s/^Usage:.*--mode=\([^ ]*\) .*/Description of \1 mode:/' + fi + exit $? +fi + + +# func_mode_execute arg... +func_mode_execute () +{ + $debug_cmd + + # The first argument is the command name. + cmd=$nonopt + test -z "$cmd" && \ + func_fatal_help "you must specify a COMMAND" + + # Handle -dlopen flags immediately. + for file in $opt_dlopen; do + test -f "$file" \ + || func_fatal_help "'$file' is not a file" + + dir= + case $file in + *.la) + func_resolve_sysroot "$file" + file=$func_resolve_sysroot_result + + # Check to see that this really is a libtool archive. + func_lalib_unsafe_p "$file" \ + || func_fatal_help "'$lib' is not a valid libtool archive" + + # Read the libtool library. + dlname= + library_names= + func_source "$file" + + # Skip this library if it cannot be dlopened. + if test -z "$dlname"; then + # Warn if it was a shared library. + test -n "$library_names" && \ + func_warning "'$file' was not linked with '-export-dynamic'" + continue + fi + + func_dirname "$file" "" "." + dir=$func_dirname_result + + if test -f "$dir/$objdir/$dlname"; then + func_append dir "/$objdir" + else + if test ! -f "$dir/$dlname"; then + func_fatal_error "cannot find '$dlname' in '$dir' or '$dir/$objdir'" + fi + fi + ;; + + *.lo) + # Just add the directory containing the .lo file. + func_dirname "$file" "" "." + dir=$func_dirname_result + ;; + + *) + func_warning "'-dlopen' is ignored for non-libtool libraries and objects" + continue + ;; + esac + + # Get the absolute pathname. + absdir=`cd "$dir" && pwd` + test -n "$absdir" && dir=$absdir + + # Now add the directory to shlibpath_var. + if eval "test -z \"\$$shlibpath_var\""; then + eval "$shlibpath_var=\"\$dir\"" + else + eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\"" + fi + done + + # This variable tells wrapper scripts just to set shlibpath_var + # rather than running their programs. + libtool_execute_magic=$magic + + # Check if any of the arguments is a wrapper script. + args= + for file + do + case $file in + -* | *.la | *.lo ) ;; + *) + # Do a test to see if this is really a libtool program. + if func_ltwrapper_script_p "$file"; then + func_source "$file" + # Transform arg to wrapped name. + file=$progdir/$program + elif func_ltwrapper_executable_p "$file"; then + func_ltwrapper_scriptname "$file" + func_source "$func_ltwrapper_scriptname_result" + # Transform arg to wrapped name. + file=$progdir/$program + fi + ;; + esac + # Quote arguments (to preserve shell metacharacters). + func_append_quoted args "$file" + done + + if $opt_dry_run; then + # Display what would be done. + if test -n "$shlibpath_var"; then + eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\"" + echo "export $shlibpath_var" + fi + $ECHO "$cmd$args" + exit $EXIT_SUCCESS + else + if test -n "$shlibpath_var"; then + # Export the shlibpath_var. + eval "export $shlibpath_var" + fi + + # Restore saved environment variables + for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES + do + eval "if test \"\${save_$lt_var+set}\" = set; then + $lt_var=\$save_$lt_var; export $lt_var + else + $lt_unset $lt_var + fi" + done + + # Now prepare to actually exec the command. + exec_cmd=\$cmd$args + fi +} + +test execute = "$opt_mode" && func_mode_execute ${1+"$@"} + + +# func_mode_finish arg... +func_mode_finish () +{ + $debug_cmd + + libs= + libdirs= + admincmds= + + for opt in "$nonopt" ${1+"$@"} + do + if test -d "$opt"; then + func_append libdirs " $opt" + + elif test -f "$opt"; then + if func_lalib_unsafe_p "$opt"; then + func_append libs " $opt" + else + func_warning "'$opt' is not a valid libtool archive" + fi + + else + func_fatal_error "invalid argument '$opt'" + fi + done + + if test -n "$libs"; then + if test -n "$lt_sysroot"; then + sysroot_regex=`$ECHO "$lt_sysroot" | $SED "$sed_make_literal_regex"` + sysroot_cmd="s/\([ ']\)$sysroot_regex/\1/g;" + else + sysroot_cmd= + fi + + # Remove sysroot references + if $opt_dry_run; then + for lib in $libs; do + echo "removing references to $lt_sysroot and '=' prefixes from $lib" + done + else + tmpdir=`func_mktempdir` + for lib in $libs; do + $SED -e "$sysroot_cmd s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \ + > $tmpdir/tmp-la + mv -f $tmpdir/tmp-la $lib + done + ${RM}r "$tmpdir" + fi + fi + + if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then + for libdir in $libdirs; do + if test -n "$finish_cmds"; then + # Do each command in the finish commands. + func_execute_cmds "$finish_cmds" 'admincmds="$admincmds +'"$cmd"'"' + fi + if test -n "$finish_eval"; then + # Do the single finish_eval. + eval cmds=\"$finish_eval\" + $opt_dry_run || eval "$cmds" || func_append admincmds " + $cmds" + fi + done + fi + + # Exit here if they wanted silent mode. + $opt_quiet && exit $EXIT_SUCCESS + + if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then + echo "----------------------------------------------------------------------" + echo "Libraries have been installed in:" + for libdir in $libdirs; do + $ECHO " $libdir" + done + echo + echo "If you ever happen to want to link against installed libraries" + echo "in a given directory, LIBDIR, you must either use libtool, and" + echo "specify the full pathname of the library, or use the '-LLIBDIR'" + echo "flag during linking and do at least one of the following:" + if test -n "$shlibpath_var"; then + echo " - add LIBDIR to the '$shlibpath_var' environment variable" + echo " during execution" + fi + if test -n "$runpath_var"; then + echo " - add LIBDIR to the '$runpath_var' environment variable" + echo " during linking" + fi + if test -n "$hardcode_libdir_flag_spec"; then + libdir=LIBDIR + eval flag=\"$hardcode_libdir_flag_spec\" + + $ECHO " - use the '$flag' linker flag" + fi + if test -n "$admincmds"; then + $ECHO " - have your system administrator run these commands:$admincmds" + fi + if test -f /etc/ld.so.conf; then + echo " - have your system administrator add LIBDIR to '/etc/ld.so.conf'" + fi + echo + + echo "See any operating system documentation about shared libraries for" + case $host in + solaris2.[6789]|solaris2.1[0-9]) + echo "more information, such as the ld(1), crle(1) and ld.so(8) manual" + echo "pages." + ;; + *) + echo "more information, such as the ld(1) and ld.so(8) manual pages." + ;; + esac + echo "----------------------------------------------------------------------" + fi + exit $EXIT_SUCCESS +} + +test finish = "$opt_mode" && func_mode_finish ${1+"$@"} + + +# func_mode_install arg... +func_mode_install () +{ + $debug_cmd + + # There may be an optional sh(1) argument at the beginning of + # install_prog (especially on Windows NT). + if test "$SHELL" = "$nonopt" || test /bin/sh = "$nonopt" || + # Allow the use of GNU shtool's install command. + case $nonopt in *shtool*) :;; *) false;; esac + then + # Aesthetically quote it. + func_quote_arg pretty "$nonopt" + install_prog="$func_quote_arg_result " + arg=$1 + shift + else + install_prog= + arg=$nonopt + fi + + # The real first argument should be the name of the installation program. + # Aesthetically quote it. + func_quote_arg pretty "$arg" + func_append install_prog "$func_quote_arg_result" + install_shared_prog=$install_prog + case " $install_prog " in + *[\\\ /]cp\ *) install_cp=: ;; + *) install_cp=false ;; + esac + + # We need to accept at least all the BSD install flags. + dest= + files= + opts= + prev= + install_type= + isdir=false + stripme= + no_mode=: + for arg + do + arg2= + if test -n "$dest"; then + func_append files " $dest" + dest=$arg + continue + fi + + case $arg in + -d) isdir=: ;; + -f) + if $install_cp; then :; else + prev=$arg + fi + ;; + -g | -m | -o) + prev=$arg + ;; + -s) + stripme=" -s" + continue + ;; + -*) + ;; + *) + # If the previous option needed an argument, then skip it. + if test -n "$prev"; then + if test X-m = "X$prev" && test -n "$install_override_mode"; then + arg2=$install_override_mode + no_mode=false + fi + prev= + else + dest=$arg + continue + fi + ;; + esac + + # Aesthetically quote the argument. + func_quote_arg pretty "$arg" + func_append install_prog " $func_quote_arg_result" + if test -n "$arg2"; then + func_quote_arg pretty "$arg2" + fi + func_append install_shared_prog " $func_quote_arg_result" + done + + test -z "$install_prog" && \ + func_fatal_help "you must specify an install program" + + test -n "$prev" && \ + func_fatal_help "the '$prev' option requires an argument" + + if test -n "$install_override_mode" && $no_mode; then + if $install_cp; then :; else + func_quote_arg pretty "$install_override_mode" + func_append install_shared_prog " -m $func_quote_arg_result" + fi + fi + + if test -z "$files"; then + if test -z "$dest"; then + func_fatal_help "no file or destination specified" + else + func_fatal_help "you must specify a destination" + fi + fi + + # Strip any trailing slash from the destination. + func_stripname '' '/' "$dest" + dest=$func_stripname_result + + # Check to see that the destination is a directory. + test -d "$dest" && isdir=: + if $isdir; then + destdir=$dest + destname= + else + func_dirname_and_basename "$dest" "" "." + destdir=$func_dirname_result + destname=$func_basename_result + + # Not a directory, so check to see that there is only one file specified. + set dummy $files; shift + test "$#" -gt 1 && \ + func_fatal_help "'$dest' is not a directory" + fi + case $destdir in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + for file in $files; do + case $file in + *.lo) ;; + *) + func_fatal_help "'$destdir' must be an absolute directory name" + ;; + esac + done + ;; + esac + + # This variable tells wrapper scripts just to set variables rather + # than running their programs. + libtool_install_magic=$magic + + staticlibs= + future_libdirs= + current_libdirs= + for file in $files; do + + # Do each installation. + case $file in + *.$libext) + # Do the static libraries later. + func_append staticlibs " $file" + ;; + + *.la) + func_resolve_sysroot "$file" + file=$func_resolve_sysroot_result + + # Check to see that this really is a libtool archive. + func_lalib_unsafe_p "$file" \ + || func_fatal_help "'$file' is not a valid libtool archive" + + library_names= + old_library= + relink_command= + func_source "$file" + + # Add the libdir to current_libdirs if it is the destination. + if test "X$destdir" = "X$libdir"; then + case "$current_libdirs " in + *" $libdir "*) ;; + *) func_append current_libdirs " $libdir" ;; + esac + else + # Note the libdir as a future libdir. + case "$future_libdirs " in + *" $libdir "*) ;; + *) func_append future_libdirs " $libdir" ;; + esac + fi + + func_dirname "$file" "/" "" + dir=$func_dirname_result + func_append dir "$objdir" + + if test -n "$relink_command"; then + # Determine the prefix the user has applied to our future dir. + inst_prefix_dir=`$ECHO "$destdir" | $SED -e "s%$libdir\$%%"` + + # Don't allow the user to place us outside of our expected + # location b/c this prevents finding dependent libraries that + # are installed to the same prefix. + # At present, this check doesn't affect windows .dll's that + # are installed into $libdir/../bin (currently, that works fine) + # but it's something to keep an eye on. + test "$inst_prefix_dir" = "$destdir" && \ + func_fatal_error "error: cannot install '$file' to a directory not ending in $libdir" + + if test -n "$inst_prefix_dir"; then + # Stick the inst_prefix_dir data into the link command. + relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"` + else + relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%%"` + fi + + func_warning "relinking '$file'" + func_show_eval "$relink_command" \ + 'func_fatal_error "error: relink '\''$file'\'' with the above command before installing it"' + fi + + # See the names of the shared library. + set dummy $library_names; shift + if test -n "$1"; then + realname=$1 + shift + + srcname=$realname + test -n "$relink_command" && srcname=${realname}T + + # Install the shared library and build the symlinks. + func_show_eval "$install_shared_prog $dir/$srcname $destdir/$realname" \ + 'exit $?' + tstripme=$stripme + case $host_os in + cygwin* | mingw* | pw32* | cegcc*) + case $realname in + *.dll.a) + tstripme= + ;; + esac + ;; + os2*) + case $realname in + *_dll.a) + tstripme= + ;; + esac + ;; + esac + if test -n "$tstripme" && test -n "$striplib"; then + func_show_eval "$striplib $destdir/$realname" 'exit $?' + fi + + if test "$#" -gt 0; then + # Delete the old symlinks, and create new ones. + # Try 'ln -sf' first, because the 'ln' binary might depend on + # the symlink we replace! Solaris /bin/ln does not understand -f, + # so we also need to try rm && ln -s. + for linkname + do + test "$linkname" != "$realname" \ + && func_show_eval "(cd $destdir && { $LN_S -f $realname $linkname || { $RM $linkname && $LN_S $realname $linkname; }; })" + done + fi + + # Do each command in the postinstall commands. + lib=$destdir/$realname + func_execute_cmds "$postinstall_cmds" 'exit $?' + fi + + # Install the pseudo-library for information purposes. + func_basename "$file" + name=$func_basename_result + instname=$dir/${name}i + func_show_eval "$install_prog $instname $destdir/$name" 'exit $?' + + # Maybe install the static library, too. + test -n "$old_library" && func_append staticlibs " $dir/$old_library" + ;; + + *.lo) + # Install (i.e. copy) a libtool object. + + # Figure out destination file name, if it wasn't already specified. + if test -n "$destname"; then + destfile=$destdir/$destname + else + func_basename "$file" + destfile=$func_basename_result + destfile=$destdir/$destfile + fi + + # Deduce the name of the destination old-style object file. + case $destfile in + *.lo) + func_lo2o "$destfile" + staticdest=$func_lo2o_result + ;; + *.$objext) + staticdest=$destfile + destfile= + ;; + *) + func_fatal_help "cannot copy a libtool object to '$destfile'" + ;; + esac + + # Install the libtool object if requested. + test -n "$destfile" && \ + func_show_eval "$install_prog $file $destfile" 'exit $?' + + # Install the old object if enabled. + if test yes = "$build_old_libs"; then + # Deduce the name of the old-style object file. + func_lo2o "$file" + staticobj=$func_lo2o_result + func_show_eval "$install_prog \$staticobj \$staticdest" 'exit $?' + fi + exit $EXIT_SUCCESS + ;; + + *) + # Figure out destination file name, if it wasn't already specified. + if test -n "$destname"; then + destfile=$destdir/$destname + else + func_basename "$file" + destfile=$func_basename_result + destfile=$destdir/$destfile + fi + + # If the file is missing, and there is a .exe on the end, strip it + # because it is most likely a libtool script we actually want to + # install + stripped_ext= + case $file in + *.exe) + if test ! -f "$file"; then + func_stripname '' '.exe' "$file" + file=$func_stripname_result + stripped_ext=.exe + fi + ;; + esac + + # Do a test to see if this is really a libtool program. + case $host in + *cygwin* | *mingw*) + if func_ltwrapper_executable_p "$file"; then + func_ltwrapper_scriptname "$file" + wrapper=$func_ltwrapper_scriptname_result + else + func_stripname '' '.exe' "$file" + wrapper=$func_stripname_result + fi + ;; + *) + wrapper=$file + ;; + esac + if func_ltwrapper_script_p "$wrapper"; then + notinst_deplibs= + relink_command= + + func_source "$wrapper" + + # Check the variables that should have been set. + test -z "$generated_by_libtool_version" && \ + func_fatal_error "invalid libtool wrapper script '$wrapper'" + + finalize=: + for lib in $notinst_deplibs; do + # Check to see that each library is installed. + libdir= + if test -f "$lib"; then + func_source "$lib" + fi + libfile=$libdir/`$ECHO "$lib" | $SED 's%^.*/%%g'` + if test -n "$libdir" && test ! -f "$libfile"; then + func_warning "'$lib' has not been installed in '$libdir'" + finalize=false + fi + done + + relink_command= + func_source "$wrapper" + + outputname= + if test no = "$fast_install" && test -n "$relink_command"; then + $opt_dry_run || { + if $finalize; then + tmpdir=`func_mktempdir` + func_basename "$file$stripped_ext" + file=$func_basename_result + outputname=$tmpdir/$file + # Replace the output file specification. + relink_command=`$ECHO "$relink_command" | $SED 's%@OUTPUT@%'"$outputname"'%g'` + + $opt_quiet || { + func_quote_arg expand,pretty "$relink_command" + eval "func_echo $func_quote_arg_result" + } + if eval "$relink_command"; then : + else + func_error "error: relink '$file' with the above command before installing it" + $opt_dry_run || ${RM}r "$tmpdir" + continue + fi + file=$outputname + else + func_warning "cannot relink '$file'" + fi + } + else + # Install the binary that we compiled earlier. + file=`$ECHO "$file$stripped_ext" | $SED "s%\([^/]*\)$%$objdir/\1%"` + fi + fi + + # remove .exe since cygwin /usr/bin/install will append another + # one anyway + case $install_prog,$host in + */usr/bin/install*,*cygwin*) + case $file:$destfile in + *.exe:*.exe) + # this is ok + ;; + *.exe:*) + destfile=$destfile.exe + ;; + *:*.exe) + func_stripname '' '.exe' "$destfile" + destfile=$func_stripname_result + ;; + esac + ;; + esac + func_show_eval "$install_prog\$stripme \$file \$destfile" 'exit $?' + $opt_dry_run || if test -n "$outputname"; then + ${RM}r "$tmpdir" + fi + ;; + esac + done + + for file in $staticlibs; do + func_basename "$file" + name=$func_basename_result + + # Set up the ranlib parameters. + oldlib=$destdir/$name + func_to_tool_file "$oldlib" func_convert_file_msys_to_w32 + tool_oldlib=$func_to_tool_file_result + + func_show_eval "$install_prog \$file \$oldlib" 'exit $?' + + if test -n "$stripme" && test -n "$old_striplib"; then + func_show_eval "$old_striplib $tool_oldlib" 'exit $?' + fi + + # Do each command in the postinstall commands. + func_execute_cmds "$old_postinstall_cmds" 'exit $?' + done + + test -n "$future_libdirs" && \ + func_warning "remember to run '$progname --finish$future_libdirs'" + + if test -n "$current_libdirs"; then + # Maybe just do a dry run. + $opt_dry_run && current_libdirs=" -n$current_libdirs" + exec_cmd='$SHELL "$progpath" $preserve_args --finish$current_libdirs' + else + exit $EXIT_SUCCESS + fi +} + +test install = "$opt_mode" && func_mode_install ${1+"$@"} + + +# func_generate_dlsyms outputname originator pic_p +# Extract symbols from dlprefiles and create ${outputname}S.o with +# a dlpreopen symbol table. +func_generate_dlsyms () +{ + $debug_cmd + + my_outputname=$1 + my_originator=$2 + my_pic_p=${3-false} + my_prefix=`$ECHO "$my_originator" | $SED 's%[^a-zA-Z0-9]%_%g'` + my_dlsyms= + + if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then + if test -n "$NM" && test -n "$global_symbol_pipe"; then + my_dlsyms=${my_outputname}S.c + else + func_error "not configured to extract global symbols from dlpreopened files" + fi + fi + + if test -n "$my_dlsyms"; then + case $my_dlsyms in + "") ;; + *.c) + # Discover the nlist of each of the dlfiles. + nlist=$output_objdir/$my_outputname.nm + + func_show_eval "$RM $nlist ${nlist}S ${nlist}T" + + # Parse the name list into a source file. + func_verbose "creating $output_objdir/$my_dlsyms" + + $opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\ +/* $my_dlsyms - symbol resolution table for '$my_outputname' dlsym emulation. */ +/* Generated by $PROGRAM (GNU $PACKAGE) $VERSION */ + +#ifdef __cplusplus +extern \"C\" { +#endif + +#if defined __GNUC__ && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC__ > 4)) +#pragma GCC diagnostic ignored \"-Wstrict-prototypes\" +#endif + +/* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ +#if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE +/* DATA imports from DLLs on WIN32 can't be const, because runtime + relocations are performed -- see ld's documentation on pseudo-relocs. */ +# define LT_DLSYM_CONST +#elif defined __osf__ +/* This system does not cope well with relocations in const data. */ +# define LT_DLSYM_CONST +#else +# define LT_DLSYM_CONST const +#endif + +#define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0) + +/* External symbol declarations for the compiler. */\ +" + + if test yes = "$dlself"; then + func_verbose "generating symbol list for '$output'" + + $opt_dry_run || echo ': @PROGRAM@ ' > "$nlist" + + # Add our own program objects to the symbol list. + progfiles=`$ECHO "$objs$old_deplibs" | $SP2NL | $SED "$lo2o" | $NL2SP` + for progfile in $progfiles; do + func_to_tool_file "$progfile" func_convert_file_msys_to_w32 + func_verbose "extracting global C symbols from '$func_to_tool_file_result'" + $opt_dry_run || eval "$NM $func_to_tool_file_result | $global_symbol_pipe >> '$nlist'" + done + + if test -n "$exclude_expsyms"; then + $opt_dry_run || { + eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T' + eval '$MV "$nlist"T "$nlist"' + } + fi + + if test -n "$export_symbols_regex"; then + $opt_dry_run || { + eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T' + eval '$MV "$nlist"T "$nlist"' + } + fi + + # Prepare the list of exported symbols + if test -z "$export_symbols"; then + export_symbols=$output_objdir/$outputname.exp + $opt_dry_run || { + $RM $export_symbols + eval "$SED -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"' + case $host in + *cygwin* | *mingw* | *cegcc* ) + eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' + eval 'cat "$export_symbols" >> "$output_objdir/$outputname.def"' + ;; + esac + } + else + $opt_dry_run || { + eval "$SED -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"' + eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T' + eval '$MV "$nlist"T "$nlist"' + case $host in + *cygwin* | *mingw* | *cegcc* ) + eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' + eval 'cat "$nlist" >> "$output_objdir/$outputname.def"' + ;; + esac + } + fi + fi + + for dlprefile in $dlprefiles; do + func_verbose "extracting global C symbols from '$dlprefile'" + func_basename "$dlprefile" + name=$func_basename_result + case $host in + *cygwin* | *mingw* | *cegcc* ) + # if an import library, we need to obtain dlname + if func_win32_import_lib_p "$dlprefile"; then + func_tr_sh "$dlprefile" + eval "curr_lafile=\$libfile_$func_tr_sh_result" + dlprefile_dlbasename= + if test -n "$curr_lafile" && func_lalib_p "$curr_lafile"; then + # Use subshell, to avoid clobbering current variable values + dlprefile_dlname=`source "$curr_lafile" && echo "$dlname"` + if test -n "$dlprefile_dlname"; then + func_basename "$dlprefile_dlname" + dlprefile_dlbasename=$func_basename_result + else + # no lafile. user explicitly requested -dlpreopen . + $sharedlib_from_linklib_cmd "$dlprefile" + dlprefile_dlbasename=$sharedlib_from_linklib_result + fi + fi + $opt_dry_run || { + if test -n "$dlprefile_dlbasename"; then + eval '$ECHO ": $dlprefile_dlbasename" >> "$nlist"' + else + func_warning "Could not compute DLL name from $name" + eval '$ECHO ": $name " >> "$nlist"' + fi + func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 + eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe | + $SED -e '/I __imp/d' -e 's/I __nm_/D /;s/_nm__//' >> '$nlist'" + } + else # not an import lib + $opt_dry_run || { + eval '$ECHO ": $name " >> "$nlist"' + func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 + eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'" + } + fi + ;; + *) + $opt_dry_run || { + eval '$ECHO ": $name " >> "$nlist"' + func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 + eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'" + } + ;; + esac + done + + $opt_dry_run || { + # Make sure we have at least an empty file. + test -f "$nlist" || : > "$nlist" + + if test -n "$exclude_expsyms"; then + $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T + $MV "$nlist"T "$nlist" + fi + + # Try sorting and uniquifying the output. + if $GREP -v "^: " < "$nlist" | + if sort -k 3 /dev/null 2>&1; then + sort -k 3 + else + sort +2 + fi | + uniq > "$nlist"S; then + : + else + $GREP -v "^: " < "$nlist" > "$nlist"S + fi + + if test -f "$nlist"S; then + eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$my_dlsyms"' + else + echo '/* NONE */' >> "$output_objdir/$my_dlsyms" + fi + + func_show_eval '$RM "${nlist}I"' + if test -n "$global_symbol_to_import"; then + eval "$global_symbol_to_import"' < "$nlist"S > "$nlist"I' + fi + + echo >> "$output_objdir/$my_dlsyms" "\ + +/* The mapping between symbol names and symbols. */ +typedef struct { + const char *name; + void *address; +} lt_dlsymlist; +extern LT_DLSYM_CONST lt_dlsymlist +lt_${my_prefix}_LTX_preloaded_symbols[];\ +" + + if test -s "$nlist"I; then + echo >> "$output_objdir/$my_dlsyms" "\ +static void lt_syminit(void) +{ + LT_DLSYM_CONST lt_dlsymlist *symbol = lt_${my_prefix}_LTX_preloaded_symbols; + for (; symbol->name; ++symbol) + {" + $SED 's/.*/ if (STREQ (symbol->name, \"&\")) symbol->address = (void *) \&&;/' < "$nlist"I >> "$output_objdir/$my_dlsyms" + echo >> "$output_objdir/$my_dlsyms" "\ + } +}" + fi + echo >> "$output_objdir/$my_dlsyms" "\ +LT_DLSYM_CONST lt_dlsymlist +lt_${my_prefix}_LTX_preloaded_symbols[] = +{ {\"$my_originator\", (void *) 0}," + + if test -s "$nlist"I; then + echo >> "$output_objdir/$my_dlsyms" "\ + {\"@INIT@\", (void *) <_syminit}," + fi + + case $need_lib_prefix in + no) + eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$my_dlsyms" + ;; + *) + eval "$global_symbol_to_c_name_address_lib_prefix" < "$nlist" >> "$output_objdir/$my_dlsyms" + ;; + esac + echo >> "$output_objdir/$my_dlsyms" "\ + {0, (void *) 0} +}; + +/* This works around a problem in FreeBSD linker */ +#ifdef FREEBSD_WORKAROUND +static const void *lt_preloaded_setup() { + return lt_${my_prefix}_LTX_preloaded_symbols; +} +#endif + +#ifdef __cplusplus +} +#endif\ +" + } # !$opt_dry_run + + pic_flag_for_symtable= + case "$compile_command " in + *" -static "*) ;; + *) + case $host in + # compiling the symbol table file with pic_flag works around + # a FreeBSD bug that causes programs to crash when -lm is + # linked before any other PIC object. But we must not use + # pic_flag when linking with -static. The problem exists in + # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1. + *-*-freebsd2.*|*-*-freebsd3.0*|*-*-freebsdelf3.0*) + pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND" ;; + *-*-hpux*) + pic_flag_for_symtable=" $pic_flag" ;; + *) + $my_pic_p && pic_flag_for_symtable=" $pic_flag" + ;; + esac + ;; + esac + symtab_cflags= + for arg in $LTCFLAGS; do + case $arg in + -pie | -fpie | -fPIE) ;; + *) func_append symtab_cflags " $arg" ;; + esac + done + + # Now compile the dynamic symbol file. + func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_flag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?' + + # Clean up the generated files. + func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T" "${nlist}I"' + + # Transform the symbol file into the correct name. + symfileobj=$output_objdir/${my_outputname}S.$objext + case $host in + *cygwin* | *mingw* | *cegcc* ) + if test -f "$output_objdir/$my_outputname.def"; then + compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` + finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` + else + compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"` + finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"` + fi + ;; + *) + compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"` + finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"` + ;; + esac + ;; + *) + func_fatal_error "unknown suffix for '$my_dlsyms'" + ;; + esac + else + # We keep going just in case the user didn't refer to + # lt_preloaded_symbols. The linker will fail if global_symbol_pipe + # really was required. + + # Nullify the symbol file. + compile_command=`$ECHO "$compile_command" | $SED "s% @SYMFILE@%%"` + finalize_command=`$ECHO "$finalize_command" | $SED "s% @SYMFILE@%%"` + fi +} + +# func_cygming_gnu_implib_p ARG +# This predicate returns with zero status (TRUE) if +# ARG is a GNU/binutils-style import library. Returns +# with nonzero status (FALSE) otherwise. +func_cygming_gnu_implib_p () +{ + $debug_cmd + + func_to_tool_file "$1" func_convert_file_msys_to_w32 + func_cygming_gnu_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $EGREP ' (_head_[A-Za-z0-9_]+_[ad]l*|[A-Za-z0-9_]+_[ad]l*_iname)$'` + test -n "$func_cygming_gnu_implib_tmp" +} + +# func_cygming_ms_implib_p ARG +# This predicate returns with zero status (TRUE) if +# ARG is an MS-style import library. Returns +# with nonzero status (FALSE) otherwise. +func_cygming_ms_implib_p () +{ + $debug_cmd + + func_to_tool_file "$1" func_convert_file_msys_to_w32 + func_cygming_ms_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'` + test -n "$func_cygming_ms_implib_tmp" +} + +# func_win32_libid arg +# return the library type of file 'arg' +# +# Need a lot of goo to handle *both* DLLs and import libs +# Has to be a shell function in order to 'eat' the argument +# that is supplied when $file_magic_command is called. +# Despite the name, also deal with 64 bit binaries. +func_win32_libid () +{ + $debug_cmd + + win32_libid_type=unknown + win32_fileres=`file -L $1 2>/dev/null` + case $win32_fileres in + *ar\ archive\ import\ library*) # definitely import + win32_libid_type="x86 archive import" + ;; + *ar\ archive*) # could be an import, or static + # Keep the egrep pattern in sync with the one in _LT_CHECK_MAGIC_METHOD. + if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null | + $EGREP 'file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' >/dev/null; then + case $nm_interface in + "MS dumpbin") + if func_cygming_ms_implib_p "$1" || + func_cygming_gnu_implib_p "$1" + then + win32_nmres=import + else + win32_nmres= + fi + ;; + *) + func_to_tool_file "$1" func_convert_file_msys_to_w32 + win32_nmres=`eval $NM -f posix -A \"$func_to_tool_file_result\" | + $SED -n -e ' + 1,100{ + / I /{ + s|.*|import| + p + q + } + }'` + ;; + esac + case $win32_nmres in + import*) win32_libid_type="x86 archive import";; + *) win32_libid_type="x86 archive static";; + esac + fi + ;; + *DLL*) + win32_libid_type="x86 DLL" + ;; + *executable*) # but shell scripts are "executable" too... + case $win32_fileres in + *MS\ Windows\ PE\ Intel*) + win32_libid_type="x86 DLL" + ;; + esac + ;; + esac + $ECHO "$win32_libid_type" +} + +# func_cygming_dll_for_implib ARG +# +# Platform-specific function to extract the +# name of the DLL associated with the specified +# import library ARG. +# Invoked by eval'ing the libtool variable +# $sharedlib_from_linklib_cmd +# Result is available in the variable +# $sharedlib_from_linklib_result +func_cygming_dll_for_implib () +{ + $debug_cmd + + sharedlib_from_linklib_result=`$DLLTOOL --identify-strict --identify "$1"` +} + +# func_cygming_dll_for_implib_fallback_core SECTION_NAME LIBNAMEs +# +# The is the core of a fallback implementation of a +# platform-specific function to extract the name of the +# DLL associated with the specified import library LIBNAME. +# +# SECTION_NAME is either .idata$6 or .idata$7, depending +# on the platform and compiler that created the implib. +# +# Echos the name of the DLL associated with the +# specified import library. +func_cygming_dll_for_implib_fallback_core () +{ + $debug_cmd + + match_literal=`$ECHO "$1" | $SED "$sed_make_literal_regex"` + $OBJDUMP -s --section "$1" "$2" 2>/dev/null | + $SED '/^Contents of section '"$match_literal"':/{ + # Place marker at beginning of archive member dllname section + s/.*/====MARK====/ + p + d + } + # These lines can sometimes be longer than 43 characters, but + # are always uninteresting + /:[ ]*file format pe[i]\{,1\}-/d + /^In archive [^:]*:/d + # Ensure marker is printed + /^====MARK====/p + # Remove all lines with less than 43 characters + /^.\{43\}/!d + # From remaining lines, remove first 43 characters + s/^.\{43\}//' | + $SED -n ' + # Join marker and all lines until next marker into a single line + /^====MARK====/ b para + H + $ b para + b + :para + x + s/\n//g + # Remove the marker + s/^====MARK====// + # Remove trailing dots and whitespace + s/[\. \t]*$// + # Print + /./p' | + # we now have a list, one entry per line, of the stringified + # contents of the appropriate section of all members of the + # archive that possess that section. Heuristic: eliminate + # all those that have a first or second character that is + # a '.' (that is, objdump's representation of an unprintable + # character.) This should work for all archives with less than + # 0x302f exports -- but will fail for DLLs whose name actually + # begins with a literal '.' or a single character followed by + # a '.'. + # + # Of those that remain, print the first one. + $SED -e '/^\./d;/^.\./d;q' +} + +# func_cygming_dll_for_implib_fallback ARG +# Platform-specific function to extract the +# name of the DLL associated with the specified +# import library ARG. +# +# This fallback implementation is for use when $DLLTOOL +# does not support the --identify-strict option. +# Invoked by eval'ing the libtool variable +# $sharedlib_from_linklib_cmd +# Result is available in the variable +# $sharedlib_from_linklib_result +func_cygming_dll_for_implib_fallback () +{ + $debug_cmd + + if func_cygming_gnu_implib_p "$1"; then + # binutils import library + sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$7' "$1"` + elif func_cygming_ms_implib_p "$1"; then + # ms-generated import library + sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$6' "$1"` + else + # unknown + sharedlib_from_linklib_result= + fi +} + + +# func_extract_an_archive dir oldlib +func_extract_an_archive () +{ + $debug_cmd + + f_ex_an_ar_dir=$1; shift + f_ex_an_ar_oldlib=$1 + if test yes = "$lock_old_archive_extraction"; then + lockfile=$f_ex_an_ar_oldlib.lock + until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do + func_echo "Waiting for $lockfile to be removed" + sleep 2 + done + fi + func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" \ + 'stat=$?; rm -f "$lockfile"; exit $stat' + if test yes = "$lock_old_archive_extraction"; then + $opt_dry_run || rm -f "$lockfile" + fi + if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then + : + else + func_fatal_error "object name conflicts in archive: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib" + fi +} + + +# func_extract_archives gentop oldlib ... +func_extract_archives () +{ + $debug_cmd + + my_gentop=$1; shift + my_oldlibs=${1+"$@"} + my_oldobjs= + my_xlib= + my_xabs= + my_xdir= + + for my_xlib in $my_oldlibs; do + # Extract the objects. + case $my_xlib in + [\\/]* | [A-Za-z]:[\\/]*) my_xabs=$my_xlib ;; + *) my_xabs=`pwd`"/$my_xlib" ;; + esac + func_basename "$my_xlib" + my_xlib=$func_basename_result + my_xlib_u=$my_xlib + while :; do + case " $extracted_archives " in + *" $my_xlib_u "*) + func_arith $extracted_serial + 1 + extracted_serial=$func_arith_result + my_xlib_u=lt$extracted_serial-$my_xlib ;; + *) break ;; + esac + done + extracted_archives="$extracted_archives $my_xlib_u" + my_xdir=$my_gentop/$my_xlib_u + + func_mkdir_p "$my_xdir" + + case $host in + *-darwin*) + func_verbose "Extracting $my_xabs" + # Do not bother doing anything if just a dry run + $opt_dry_run || { + darwin_orig_dir=`pwd` + cd $my_xdir || exit $? + darwin_archive=$my_xabs + darwin_curdir=`pwd` + func_basename "$darwin_archive" + darwin_base_archive=$func_basename_result + darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Architectures 2>/dev/null || true` + if test -n "$darwin_arches"; then + darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'` + darwin_arch= + func_verbose "$darwin_base_archive has multiple architectures $darwin_arches" + for darwin_arch in $darwin_arches; do + func_mkdir_p "unfat-$$/$darwin_base_archive-$darwin_arch" + $LIPO -thin $darwin_arch -output "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive" "$darwin_archive" + cd "unfat-$$/$darwin_base_archive-$darwin_arch" + func_extract_an_archive "`pwd`" "$darwin_base_archive" + cd "$darwin_curdir" + $RM "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive" + done # $darwin_arches + ## Okay now we've a bunch of thin objects, gotta fatten them up :) + darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print | $SED -e "$sed_basename" | sort -u` + darwin_file= + darwin_files= + for darwin_file in $darwin_filelist; do + darwin_files=`find unfat-$$ -name $darwin_file -print | sort | $NL2SP` + $LIPO -create -output "$darwin_file" $darwin_files + done # $darwin_filelist + $RM -rf unfat-$$ + cd "$darwin_orig_dir" + else + cd $darwin_orig_dir + func_extract_an_archive "$my_xdir" "$my_xabs" + fi # $darwin_arches + } # !$opt_dry_run + ;; + *) + func_extract_an_archive "$my_xdir" "$my_xabs" + ;; + esac + my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | sort | $NL2SP` + done + + func_extract_archives_result=$my_oldobjs +} + + +# func_emit_wrapper [arg=no] +# +# Emit a libtool wrapper script on stdout. +# Don't directly open a file because we may want to +# incorporate the script contents within a cygwin/mingw +# wrapper executable. Must ONLY be called from within +# func_mode_link because it depends on a number of variables +# set therein. +# +# ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR +# variable will take. If 'yes', then the emitted script +# will assume that the directory where it is stored is +# the $objdir directory. This is a cygwin/mingw-specific +# behavior. +func_emit_wrapper () +{ + func_emit_wrapper_arg1=${1-no} + + $ECHO "\ +#! $SHELL + +# $output - temporary wrapper script for $objdir/$outputname +# Generated by $PROGRAM (GNU $PACKAGE) $VERSION +# +# The $output program cannot be directly executed until all the libtool +# libraries that it depends on are installed. +# +# This wrapper script should never be moved out of the build directory. +# If it is, it will not operate correctly. + +# Sed substitution that helps us do robust quoting. It backslashifies +# metacharacters that are still active within double-quoted strings. +sed_quote_subst='$sed_quote_subst' + +# Be Bourne compatible +if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then + emulate sh + NULLCMD=: + # Zsh 3.x and 4.x performs word splitting on \${1+\"\$@\"}, which + # is contrary to our usage. Disable this feature. + alias -g '\${1+\"\$@\"}'='\"\$@\"' + setopt NO_GLOB_SUBST +else + case \`(set -o) 2>/dev/null\` in *posix*) set -o posix;; esac +fi +BIN_SH=xpg4; export BIN_SH # for Tru64 +DUALCASE=1; export DUALCASE # for MKS sh + +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +(unset CDPATH) >/dev/null 2>&1 && unset CDPATH + +relink_command=\"$relink_command\" + +# This environment variable determines our operation mode. +if test \"\$libtool_install_magic\" = \"$magic\"; then + # install mode needs the following variables: + generated_by_libtool_version='$macro_version' + notinst_deplibs='$notinst_deplibs' +else + # When we are sourced in execute mode, \$file and \$ECHO are already set. + if test \"\$libtool_execute_magic\" != \"$magic\"; then + file=\"\$0\"" + + func_quote_arg pretty "$ECHO" + qECHO=$func_quote_arg_result + $ECHO "\ + +# A function that is used when there is no print builtin or printf. +func_fallback_echo () +{ + eval 'cat <<_LTECHO_EOF +\$1 +_LTECHO_EOF' +} + ECHO=$qECHO + fi + +# Very basic option parsing. These options are (a) specific to +# the libtool wrapper, (b) are identical between the wrapper +# /script/ and the wrapper /executable/ that is used only on +# windows platforms, and (c) all begin with the string "--lt-" +# (application programs are unlikely to have options that match +# this pattern). +# +# There are only two supported options: --lt-debug and +# --lt-dump-script. There is, deliberately, no --lt-help. +# +# The first argument to this parsing function should be the +# script's $0 value, followed by "$@". +lt_option_debug= +func_parse_lt_options () +{ + lt_script_arg0=\$0 + shift + for lt_opt + do + case \"\$lt_opt\" in + --lt-debug) lt_option_debug=1 ;; + --lt-dump-script) + lt_dump_D=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%/[^/]*$%%'\` + test \"X\$lt_dump_D\" = \"X\$lt_script_arg0\" && lt_dump_D=. + lt_dump_F=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%^.*/%%'\` + cat \"\$lt_dump_D/\$lt_dump_F\" + exit 0 + ;; + --lt-*) + \$ECHO \"Unrecognized --lt- option: '\$lt_opt'\" 1>&2 + exit 1 + ;; + esac + done + + # Print the debug banner immediately: + if test -n \"\$lt_option_debug\"; then + echo \"$outputname:$output:\$LINENO: libtool wrapper (GNU $PACKAGE) $VERSION\" 1>&2 + fi +} + +# Used when --lt-debug. Prints its arguments to stdout +# (redirection is the responsibility of the caller) +func_lt_dump_args () +{ + lt_dump_args_N=1; + for lt_arg + do + \$ECHO \"$outputname:$output:\$LINENO: newargv[\$lt_dump_args_N]: \$lt_arg\" + lt_dump_args_N=\`expr \$lt_dump_args_N + 1\` + done +} + +# Core function for launching the target application +func_exec_program_core () +{ +" + case $host in + # Backslashes separate directories on plain windows + *-*-mingw | *-*-os2* | *-cegcc*) + $ECHO "\ + if test -n \"\$lt_option_debug\"; then + \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir\\\\\$program\" 1>&2 + func_lt_dump_args \${1+\"\$@\"} 1>&2 + fi + exec \"\$progdir\\\\\$program\" \${1+\"\$@\"} +" + ;; + + *) + $ECHO "\ + if test -n \"\$lt_option_debug\"; then + \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir/\$program\" 1>&2 + func_lt_dump_args \${1+\"\$@\"} 1>&2 + fi + exec \"\$progdir/\$program\" \${1+\"\$@\"} +" + ;; + esac + $ECHO "\ + \$ECHO \"\$0: cannot exec \$program \$*\" 1>&2 + exit 1 +} + +# A function to encapsulate launching the target application +# Strips options in the --lt-* namespace from \$@ and +# launches target application with the remaining arguments. +func_exec_program () +{ + case \" \$* \" in + *\\ --lt-*) + for lt_wr_arg + do + case \$lt_wr_arg in + --lt-*) ;; + *) set x \"\$@\" \"\$lt_wr_arg\"; shift;; + esac + shift + done ;; + esac + func_exec_program_core \${1+\"\$@\"} +} + + # Parse options + func_parse_lt_options \"\$0\" \${1+\"\$@\"} + + # Find the directory that this script lives in. + thisdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*$%%'\` + test \"x\$thisdir\" = \"x\$file\" && thisdir=. + + # Follow symbolic links until we get to the real thisdir. + file=\`ls -ld \"\$file\" | $SED -n 's/.*-> //p'\` + while test -n \"\$file\"; do + destdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*\$%%'\` + + # If there was a directory component, then change thisdir. + if test \"x\$destdir\" != \"x\$file\"; then + case \"\$destdir\" in + [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;; + *) thisdir=\"\$thisdir/\$destdir\" ;; + esac + fi + + file=\`\$ECHO \"\$file\" | $SED 's%^.*/%%'\` + file=\`ls -ld \"\$thisdir/\$file\" | $SED -n 's/.*-> //p'\` + done + + # Usually 'no', except on cygwin/mingw when embedded into + # the cwrapper. + WRAPPER_SCRIPT_BELONGS_IN_OBJDIR=$func_emit_wrapper_arg1 + if test \"\$WRAPPER_SCRIPT_BELONGS_IN_OBJDIR\" = \"yes\"; then + # special case for '.' + if test \"\$thisdir\" = \".\"; then + thisdir=\`pwd\` + fi + # remove .libs from thisdir + case \"\$thisdir\" in + *[\\\\/]$objdir ) thisdir=\`\$ECHO \"\$thisdir\" | $SED 's%[\\\\/][^\\\\/]*$%%'\` ;; + $objdir ) thisdir=. ;; + esac + fi + + # Try to get the absolute directory name. + absdir=\`cd \"\$thisdir\" && pwd\` + test -n \"\$absdir\" && thisdir=\"\$absdir\" +" + + if test yes = "$fast_install"; then + $ECHO "\ + program=lt-'$outputname'$exeext + progdir=\"\$thisdir/$objdir\" + + if test ! -f \"\$progdir/\$program\" || + { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | $SED 1q\`; \\ + test \"X\$file\" != \"X\$progdir/\$program\"; }; then + + file=\"\$\$-\$program\" + + if test ! -d \"\$progdir\"; then + $MKDIR \"\$progdir\" + else + $RM \"\$progdir/\$file\" + fi" + + $ECHO "\ + + # relink executable if necessary + if test -n \"\$relink_command\"; then + if relink_command_output=\`eval \$relink_command 2>&1\`; then : + else + \$ECHO \"\$relink_command_output\" >&2 + $RM \"\$progdir/\$file\" + exit 1 + fi + fi + + $MV \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null || + { $RM \"\$progdir/\$program\"; + $MV \"\$progdir/\$file\" \"\$progdir/\$program\"; } + $RM \"\$progdir/\$file\" + fi" + else + $ECHO "\ + program='$outputname' + progdir=\"\$thisdir/$objdir\" +" + fi + + $ECHO "\ + + if test -f \"\$progdir/\$program\"; then" + + # fixup the dll searchpath if we need to. + # + # Fix the DLL searchpath if we need to. Do this before prepending + # to shlibpath, because on Windows, both are PATH and uninstalled + # libraries must come first. + if test -n "$dllsearchpath"; then + $ECHO "\ + # Add the dll search path components to the executable PATH + PATH=$dllsearchpath:\$PATH +" + fi + + # Export our shlibpath_var if we have one. + if test yes = "$shlibpath_overrides_runpath" && test -n "$shlibpath_var" && test -n "$temp_rpath"; then + $ECHO "\ + # Add our own library path to $shlibpath_var + $shlibpath_var=\"$temp_rpath\$$shlibpath_var\" + + # Some systems cannot cope with colon-terminated $shlibpath_var + # The second colon is a workaround for a bug in BeOS R4 sed + $shlibpath_var=\`\$ECHO \"\$$shlibpath_var\" | $SED 's/::*\$//'\` + + export $shlibpath_var +" + fi + + $ECHO "\ + if test \"\$libtool_execute_magic\" != \"$magic\"; then + # Run the actual program with our arguments. + func_exec_program \${1+\"\$@\"} + fi + else + # The program doesn't exist. + \$ECHO \"\$0: error: '\$progdir/\$program' does not exist\" 1>&2 + \$ECHO \"This script is just a wrapper for \$program.\" 1>&2 + \$ECHO \"See the $PACKAGE documentation for more information.\" 1>&2 + exit 1 + fi +fi\ +" +} + + +# func_emit_cwrapperexe_src +# emit the source code for a wrapper executable on stdout +# Must ONLY be called from within func_mode_link because +# it depends on a number of variable set therein. +func_emit_cwrapperexe_src () +{ + cat < +#include +#ifdef _MSC_VER +# include +# include +# include +#else +# include +# include +# ifdef __CYGWIN__ +# include +# endif +#endif +#include +#include +#include +#include +#include +#include +#include +#include + +#define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0) + +/* declarations of non-ANSI functions */ +#if defined __MINGW32__ +# ifdef __STRICT_ANSI__ +int _putenv (const char *); +# endif +#elif defined __CYGWIN__ +# ifdef __STRICT_ANSI__ +char *realpath (const char *, char *); +int putenv (char *); +int setenv (const char *, const char *, int); +# endif +/* #elif defined other_platform || defined ... */ +#endif + +/* portability defines, excluding path handling macros */ +#if defined _MSC_VER +# define setmode _setmode +# define stat _stat +# define chmod _chmod +# define getcwd _getcwd +# define putenv _putenv +# define S_IXUSR _S_IEXEC +#elif defined __MINGW32__ +# define setmode _setmode +# define stat _stat +# define chmod _chmod +# define getcwd _getcwd +# define putenv _putenv +#elif defined __CYGWIN__ +# define HAVE_SETENV +# define FOPEN_WB "wb" +/* #elif defined other platforms ... */ +#endif + +#if defined PATH_MAX +# define LT_PATHMAX PATH_MAX +#elif defined MAXPATHLEN +# define LT_PATHMAX MAXPATHLEN +#else +# define LT_PATHMAX 1024 +#endif + +#ifndef S_IXOTH +# define S_IXOTH 0 +#endif +#ifndef S_IXGRP +# define S_IXGRP 0 +#endif + +/* path handling portability macros */ +#ifndef DIR_SEPARATOR +# define DIR_SEPARATOR '/' +# define PATH_SEPARATOR ':' +#endif + +#if defined _WIN32 || defined __MSDOS__ || defined __DJGPP__ || \ + defined __OS2__ +# define HAVE_DOS_BASED_FILE_SYSTEM +# define FOPEN_WB "wb" +# ifndef DIR_SEPARATOR_2 +# define DIR_SEPARATOR_2 '\\' +# endif +# ifndef PATH_SEPARATOR_2 +# define PATH_SEPARATOR_2 ';' +# endif +#endif + +#ifndef DIR_SEPARATOR_2 +# define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR) +#else /* DIR_SEPARATOR_2 */ +# define IS_DIR_SEPARATOR(ch) \ + (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2)) +#endif /* DIR_SEPARATOR_2 */ + +#ifndef PATH_SEPARATOR_2 +# define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR) +#else /* PATH_SEPARATOR_2 */ +# define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR_2) +#endif /* PATH_SEPARATOR_2 */ + +#ifndef FOPEN_WB +# define FOPEN_WB "w" +#endif +#ifndef _O_BINARY +# define _O_BINARY 0 +#endif + +#define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type))) +#define XFREE(stale) do { \ + if (stale) { free (stale); stale = 0; } \ +} while (0) + +#if defined LT_DEBUGWRAPPER +static int lt_debug = 1; +#else +static int lt_debug = 0; +#endif + +const char *program_name = "libtool-wrapper"; /* in case xstrdup fails */ + +void *xmalloc (size_t num); +char *xstrdup (const char *string); +const char *base_name (const char *name); +char *find_executable (const char *wrapper); +char *chase_symlinks (const char *pathspec); +int make_executable (const char *path); +int check_executable (const char *path); +char *strendzap (char *str, const char *pat); +void lt_debugprintf (const char *file, int line, const char *fmt, ...); +void lt_fatal (const char *file, int line, const char *message, ...); +static const char *nonnull (const char *s); +static const char *nonempty (const char *s); +void lt_setenv (const char *name, const char *value); +char *lt_extend_str (const char *orig_value, const char *add, int to_end); +void lt_update_exe_path (const char *name, const char *value); +void lt_update_lib_path (const char *name, const char *value); +char **prepare_spawn (char **argv); +void lt_dump_script (FILE *f); +EOF + + cat <= 0) + && (st.st_mode & (S_IXUSR | S_IXGRP | S_IXOTH))) + return 1; + else + return 0; +} + +int +make_executable (const char *path) +{ + int rval = 0; + struct stat st; + + lt_debugprintf (__FILE__, __LINE__, "(make_executable): %s\n", + nonempty (path)); + if ((!path) || (!*path)) + return 0; + + if (stat (path, &st) >= 0) + { + rval = chmod (path, st.st_mode | S_IXOTH | S_IXGRP | S_IXUSR); + } + return rval; +} + +/* Searches for the full path of the wrapper. Returns + newly allocated full path name if found, NULL otherwise + Does not chase symlinks, even on platforms that support them. +*/ +char * +find_executable (const char *wrapper) +{ + int has_slash = 0; + const char *p; + const char *p_next; + /* static buffer for getcwd */ + char tmp[LT_PATHMAX + 1]; + size_t tmp_len; + char *concat_name; + + lt_debugprintf (__FILE__, __LINE__, "(find_executable): %s\n", + nonempty (wrapper)); + + if ((wrapper == NULL) || (*wrapper == '\0')) + return NULL; + + /* Absolute path? */ +#if defined HAVE_DOS_BASED_FILE_SYSTEM + if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':') + { + concat_name = xstrdup (wrapper); + if (check_executable (concat_name)) + return concat_name; + XFREE (concat_name); + } + else + { +#endif + if (IS_DIR_SEPARATOR (wrapper[0])) + { + concat_name = xstrdup (wrapper); + if (check_executable (concat_name)) + return concat_name; + XFREE (concat_name); + } +#if defined HAVE_DOS_BASED_FILE_SYSTEM + } +#endif + + for (p = wrapper; *p; p++) + if (*p == '/') + { + has_slash = 1; + break; + } + if (!has_slash) + { + /* no slashes; search PATH */ + const char *path = getenv ("PATH"); + if (path != NULL) + { + for (p = path; *p; p = p_next) + { + const char *q; + size_t p_len; + for (q = p; *q; q++) + if (IS_PATH_SEPARATOR (*q)) + break; + p_len = (size_t) (q - p); + p_next = (*q == '\0' ? q : q + 1); + if (p_len == 0) + { + /* empty path: current directory */ + if (getcwd (tmp, LT_PATHMAX) == NULL) + lt_fatal (__FILE__, __LINE__, "getcwd failed: %s", + nonnull (strerror (errno))); + tmp_len = strlen (tmp); + concat_name = + XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); + memcpy (concat_name, tmp, tmp_len); + concat_name[tmp_len] = '/'; + strcpy (concat_name + tmp_len + 1, wrapper); + } + else + { + concat_name = + XMALLOC (char, p_len + 1 + strlen (wrapper) + 1); + memcpy (concat_name, p, p_len); + concat_name[p_len] = '/'; + strcpy (concat_name + p_len + 1, wrapper); + } + if (check_executable (concat_name)) + return concat_name; + XFREE (concat_name); + } + } + /* not found in PATH; assume curdir */ + } + /* Relative path | not found in path: prepend cwd */ + if (getcwd (tmp, LT_PATHMAX) == NULL) + lt_fatal (__FILE__, __LINE__, "getcwd failed: %s", + nonnull (strerror (errno))); + tmp_len = strlen (tmp); + concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); + memcpy (concat_name, tmp, tmp_len); + concat_name[tmp_len] = '/'; + strcpy (concat_name + tmp_len + 1, wrapper); + + if (check_executable (concat_name)) + return concat_name; + XFREE (concat_name); + return NULL; +} + +char * +chase_symlinks (const char *pathspec) +{ +#ifndef S_ISLNK + return xstrdup (pathspec); +#else + char buf[LT_PATHMAX]; + struct stat s; + char *tmp_pathspec = xstrdup (pathspec); + char *p; + int has_symlinks = 0; + while (strlen (tmp_pathspec) && !has_symlinks) + { + lt_debugprintf (__FILE__, __LINE__, + "checking path component for symlinks: %s\n", + tmp_pathspec); + if (lstat (tmp_pathspec, &s) == 0) + { + if (S_ISLNK (s.st_mode) != 0) + { + has_symlinks = 1; + break; + } + + /* search backwards for last DIR_SEPARATOR */ + p = tmp_pathspec + strlen (tmp_pathspec) - 1; + while ((p > tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) + p--; + if ((p == tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) + { + /* no more DIR_SEPARATORS left */ + break; + } + *p = '\0'; + } + else + { + lt_fatal (__FILE__, __LINE__, + "error accessing file \"%s\": %s", + tmp_pathspec, nonnull (strerror (errno))); + } + } + XFREE (tmp_pathspec); + + if (!has_symlinks) + { + return xstrdup (pathspec); + } + + tmp_pathspec = realpath (pathspec, buf); + if (tmp_pathspec == 0) + { + lt_fatal (__FILE__, __LINE__, + "could not follow symlinks for %s", pathspec); + } + return xstrdup (tmp_pathspec); +#endif +} + +char * +strendzap (char *str, const char *pat) +{ + size_t len, patlen; + + assert (str != NULL); + assert (pat != NULL); + + len = strlen (str); + patlen = strlen (pat); + + if (patlen <= len) + { + str += len - patlen; + if (STREQ (str, pat)) + *str = '\0'; + } + return str; +} + +void +lt_debugprintf (const char *file, int line, const char *fmt, ...) +{ + va_list args; + if (lt_debug) + { + (void) fprintf (stderr, "%s:%s:%d: ", program_name, file, line); + va_start (args, fmt); + (void) vfprintf (stderr, fmt, args); + va_end (args); + } +} + +static void +lt_error_core (int exit_status, const char *file, + int line, const char *mode, + const char *message, va_list ap) +{ + fprintf (stderr, "%s:%s:%d: %s: ", program_name, file, line, mode); + vfprintf (stderr, message, ap); + fprintf (stderr, ".\n"); + + if (exit_status >= 0) + exit (exit_status); +} + +void +lt_fatal (const char *file, int line, const char *message, ...) +{ + va_list ap; + va_start (ap, message); + lt_error_core (EXIT_FAILURE, file, line, "FATAL", message, ap); + va_end (ap); +} + +static const char * +nonnull (const char *s) +{ + return s ? s : "(null)"; +} + +static const char * +nonempty (const char *s) +{ + return (s && !*s) ? "(empty)" : nonnull (s); +} + +void +lt_setenv (const char *name, const char *value) +{ + lt_debugprintf (__FILE__, __LINE__, + "(lt_setenv) setting '%s' to '%s'\n", + nonnull (name), nonnull (value)); + { +#ifdef HAVE_SETENV + /* always make a copy, for consistency with !HAVE_SETENV */ + char *str = xstrdup (value); + setenv (name, str, 1); +#else + size_t len = strlen (name) + 1 + strlen (value) + 1; + char *str = XMALLOC (char, len); + sprintf (str, "%s=%s", name, value); + if (putenv (str) != EXIT_SUCCESS) + { + XFREE (str); + } +#endif + } +} + +char * +lt_extend_str (const char *orig_value, const char *add, int to_end) +{ + char *new_value; + if (orig_value && *orig_value) + { + size_t orig_value_len = strlen (orig_value); + size_t add_len = strlen (add); + new_value = XMALLOC (char, add_len + orig_value_len + 1); + if (to_end) + { + strcpy (new_value, orig_value); + strcpy (new_value + orig_value_len, add); + } + else + { + strcpy (new_value, add); + strcpy (new_value + add_len, orig_value); + } + } + else + { + new_value = xstrdup (add); + } + return new_value; +} + +void +lt_update_exe_path (const char *name, const char *value) +{ + lt_debugprintf (__FILE__, __LINE__, + "(lt_update_exe_path) modifying '%s' by prepending '%s'\n", + nonnull (name), nonnull (value)); + + if (name && *name && value && *value) + { + char *new_value = lt_extend_str (getenv (name), value, 0); + /* some systems can't cope with a ':'-terminated path #' */ + size_t len = strlen (new_value); + while ((len > 0) && IS_PATH_SEPARATOR (new_value[len-1])) + { + new_value[--len] = '\0'; + } + lt_setenv (name, new_value); + XFREE (new_value); + } +} + +void +lt_update_lib_path (const char *name, const char *value) +{ + lt_debugprintf (__FILE__, __LINE__, + "(lt_update_lib_path) modifying '%s' by prepending '%s'\n", + nonnull (name), nonnull (value)); + + if (name && *name && value && *value) + { + char *new_value = lt_extend_str (getenv (name), value, 0); + lt_setenv (name, new_value); + XFREE (new_value); + } +} + +EOF + case $host_os in + mingw*) + cat <<"EOF" + +/* Prepares an argument vector before calling spawn(). + Note that spawn() does not by itself call the command interpreter + (getenv ("COMSPEC") != NULL ? getenv ("COMSPEC") : + ({ OSVERSIONINFO v; v.dwOSVersionInfoSize = sizeof(OSVERSIONINFO); + GetVersionEx(&v); + v.dwPlatformId == VER_PLATFORM_WIN32_NT; + }) ? "cmd.exe" : "command.com"). + Instead it simply concatenates the arguments, separated by ' ', and calls + CreateProcess(). We must quote the arguments since Win32 CreateProcess() + interprets characters like ' ', '\t', '\\', '"' (but not '<' and '>') in a + special way: + - Space and tab are interpreted as delimiters. They are not treated as + delimiters if they are surrounded by double quotes: "...". + - Unescaped double quotes are removed from the input. Their only effect is + that within double quotes, space and tab are treated like normal + characters. + - Backslashes not followed by double quotes are not special. + - But 2*n+1 backslashes followed by a double quote become + n backslashes followed by a double quote (n >= 0): + \" -> " + \\\" -> \" + \\\\\" -> \\" + */ +#define SHELL_SPECIAL_CHARS "\"\\ \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037" +#define SHELL_SPACE_CHARS " \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037" +char ** +prepare_spawn (char **argv) +{ + size_t argc; + char **new_argv; + size_t i; + + /* Count number of arguments. */ + for (argc = 0; argv[argc] != NULL; argc++) + ; + + /* Allocate new argument vector. */ + new_argv = XMALLOC (char *, argc + 1); + + /* Put quoted arguments into the new argument vector. */ + for (i = 0; i < argc; i++) + { + const char *string = argv[i]; + + if (string[0] == '\0') + new_argv[i] = xstrdup ("\"\""); + else if (strpbrk (string, SHELL_SPECIAL_CHARS) != NULL) + { + int quote_around = (strpbrk (string, SHELL_SPACE_CHARS) != NULL); + size_t length; + unsigned int backslashes; + const char *s; + char *quoted_string; + char *p; + + length = 0; + backslashes = 0; + if (quote_around) + length++; + for (s = string; *s != '\0'; s++) + { + char c = *s; + if (c == '"') + length += backslashes + 1; + length++; + if (c == '\\') + backslashes++; + else + backslashes = 0; + } + if (quote_around) + length += backslashes + 1; + + quoted_string = XMALLOC (char, length + 1); + + p = quoted_string; + backslashes = 0; + if (quote_around) + *p++ = '"'; + for (s = string; *s != '\0'; s++) + { + char c = *s; + if (c == '"') + { + unsigned int j; + for (j = backslashes + 1; j > 0; j--) + *p++ = '\\'; + } + *p++ = c; + if (c == '\\') + backslashes++; + else + backslashes = 0; + } + if (quote_around) + { + unsigned int j; + for (j = backslashes; j > 0; j--) + *p++ = '\\'; + *p++ = '"'; + } + *p = '\0'; + + new_argv[i] = quoted_string; + } + else + new_argv[i] = (char *) string; + } + new_argv[argc] = NULL; + + return new_argv; +} +EOF + ;; + esac + + cat <<"EOF" +void lt_dump_script (FILE* f) +{ +EOF + func_emit_wrapper yes | + $SED -n -e ' +s/^\(.\{79\}\)\(..*\)/\1\ +\2/ +h +s/\([\\"]\)/\\\1/g +s/$/\\n/ +s/\([^\n]*\).*/ fputs ("\1", f);/p +g +D' + cat <<"EOF" +} +EOF +} +# end: func_emit_cwrapperexe_src + +# func_win32_import_lib_p ARG +# True if ARG is an import lib, as indicated by $file_magic_cmd +func_win32_import_lib_p () +{ + $debug_cmd + + case `eval $file_magic_cmd \"\$1\" 2>/dev/null | $SED -e 10q` in + *import*) : ;; + *) false ;; + esac +} + +# func_suncc_cstd_abi +# !!ONLY CALL THIS FOR SUN CC AFTER $compile_command IS FULLY EXPANDED!! +# Several compiler flags select an ABI that is incompatible with the +# Cstd library. Avoid specifying it if any are in CXXFLAGS. +func_suncc_cstd_abi () +{ + $debug_cmd + + case " $compile_command " in + *" -compat=g "*|*\ -std=c++[0-9][0-9]\ *|*" -library=stdcxx4 "*|*" -library=stlport4 "*) + suncc_use_cstd_abi=no + ;; + *) + suncc_use_cstd_abi=yes + ;; + esac +} + +# func_mode_link arg... +func_mode_link () +{ + $debug_cmd + + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) + # It is impossible to link a dll without this setting, and + # we shouldn't force the makefile maintainer to figure out + # what system we are compiling for in order to pass an extra + # flag for every libtool invocation. + # allow_undefined=no + + # FIXME: Unfortunately, there are problems with the above when trying + # to make a dll that has undefined symbols, in which case not + # even a static library is built. For now, we need to specify + # -no-undefined on the libtool link line when we can be certain + # that all symbols are satisfied, otherwise we get a static library. + allow_undefined=yes + ;; + *) + allow_undefined=yes + ;; + esac + libtool_args=$nonopt + base_compile="$nonopt $@" + compile_command=$nonopt + finalize_command=$nonopt + + compile_rpath= + finalize_rpath= + compile_shlibpath= + finalize_shlibpath= + convenience= + old_convenience= + deplibs= + old_deplibs= + compiler_flags= + linker_flags= + dllsearchpath= + lib_search_path=`pwd` + inst_prefix_dir= + new_inherited_linker_flags= + + avoid_version=no + bindir= + dlfiles= + dlprefiles= + dlself=no + export_dynamic=no + export_symbols= + export_symbols_regex= + generated= + libobjs= + ltlibs= + module=no + no_install=no + objs= + os2dllname= + non_pic_objects= + precious_files_regex= + prefer_static_libs=no + preload=false + prev= + prevarg= + release= + rpath= + xrpath= + perm_rpath= + temp_rpath= + thread_safe=no + vinfo= + vinfo_number=no + weak_libs= + single_module=$wl-single_module + func_infer_tag $base_compile + + # We need to know -static, to get the right output filenames. + for arg + do + case $arg in + -shared) + test yes != "$build_libtool_libs" \ + && func_fatal_configuration "cannot build a shared library" + build_old_libs=no + break + ;; + -all-static | -static | -static-libtool-libs) + case $arg in + -all-static) + if test yes = "$build_libtool_libs" && test -z "$link_static_flag"; then + func_warning "complete static linking is impossible in this configuration" + fi + if test -n "$link_static_flag"; then + dlopen_self=$dlopen_self_static + fi + prefer_static_libs=yes + ;; + -static) + if test -z "$pic_flag" && test -n "$link_static_flag"; then + dlopen_self=$dlopen_self_static + fi + prefer_static_libs=built + ;; + -static-libtool-libs) + if test -z "$pic_flag" && test -n "$link_static_flag"; then + dlopen_self=$dlopen_self_static + fi + prefer_static_libs=yes + ;; + esac + build_libtool_libs=no + build_old_libs=yes + break + ;; + esac + done + + # See if our shared archives depend on static archives. + test -n "$old_archive_from_new_cmds" && build_old_libs=yes + + # Go through the arguments, transforming them on the way. + while test "$#" -gt 0; do + arg=$1 + shift + func_quote_arg pretty,unquoted "$arg" + qarg=$func_quote_arg_unquoted_result + func_append libtool_args " $func_quote_arg_result" + + # If the previous option needs an argument, assign it. + if test -n "$prev"; then + case $prev in + output) + func_append compile_command " @OUTPUT@" + func_append finalize_command " @OUTPUT@" + ;; + esac + + case $prev in + bindir) + bindir=$arg + prev= + continue + ;; + dlfiles|dlprefiles) + $preload || { + # Add the symbol object into the linking commands. + func_append compile_command " @SYMFILE@" + func_append finalize_command " @SYMFILE@" + preload=: + } + case $arg in + *.la | *.lo) ;; # We handle these cases below. + force) + if test no = "$dlself"; then + dlself=needless + export_dynamic=yes + fi + prev= + continue + ;; + self) + if test dlprefiles = "$prev"; then + dlself=yes + elif test dlfiles = "$prev" && test yes != "$dlopen_self"; then + dlself=yes + else + dlself=needless + export_dynamic=yes + fi + prev= + continue + ;; + *) + if test dlfiles = "$prev"; then + func_append dlfiles " $arg" + else + func_append dlprefiles " $arg" + fi + prev= + continue + ;; + esac + ;; + expsyms) + export_symbols=$arg + test -f "$arg" \ + || func_fatal_error "symbol file '$arg' does not exist" + prev= + continue + ;; + expsyms_regex) + export_symbols_regex=$arg + prev= + continue + ;; + framework) + case $host in + *-*-darwin*) + case "$deplibs " in + *" $qarg.ltframework "*) ;; + *) func_append deplibs " $qarg.ltframework" # this is fixed later + ;; + esac + ;; + esac + prev= + continue + ;; + inst_prefix) + inst_prefix_dir=$arg + prev= + continue + ;; + mllvm) + # Clang does not use LLVM to link, so we can simply discard any + # '-mllvm $arg' options when doing the link step. + prev= + continue + ;; + objectlist) + if test -f "$arg"; then + save_arg=$arg + moreargs= + for fil in `cat "$save_arg"` + do +# func_append moreargs " $fil" + arg=$fil + # A libtool-controlled object. + + # Check to see that this really is a libtool object. + if func_lalib_unsafe_p "$arg"; then + pic_object= + non_pic_object= + + # Read the .lo file + func_source "$arg" + + if test -z "$pic_object" || + test -z "$non_pic_object" || + test none = "$pic_object" && + test none = "$non_pic_object"; then + func_fatal_error "cannot find name of object for '$arg'" + fi + + # Extract subdirectory from the argument. + func_dirname "$arg" "/" "" + xdir=$func_dirname_result + + if test none != "$pic_object"; then + # Prepend the subdirectory the object is found in. + pic_object=$xdir$pic_object + + if test dlfiles = "$prev"; then + if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then + func_append dlfiles " $pic_object" + prev= + continue + else + # If libtool objects are unsupported, then we need to preload. + prev=dlprefiles + fi + fi + + # CHECK ME: I think I busted this. -Ossama + if test dlprefiles = "$prev"; then + # Preload the old-style object. + func_append dlprefiles " $pic_object" + prev= + fi + + # A PIC object. + func_append libobjs " $pic_object" + arg=$pic_object + fi + + # Non-PIC object. + if test none != "$non_pic_object"; then + # Prepend the subdirectory the object is found in. + non_pic_object=$xdir$non_pic_object + + # A standard non-PIC object + func_append non_pic_objects " $non_pic_object" + if test -z "$pic_object" || test none = "$pic_object"; then + arg=$non_pic_object + fi + else + # If the PIC object exists, use it instead. + # $xdir was prepended to $pic_object above. + non_pic_object=$pic_object + func_append non_pic_objects " $non_pic_object" + fi + else + # Only an error if not doing a dry-run. + if $opt_dry_run; then + # Extract subdirectory from the argument. + func_dirname "$arg" "/" "" + xdir=$func_dirname_result + + func_lo2o "$arg" + pic_object=$xdir$objdir/$func_lo2o_result + non_pic_object=$xdir$func_lo2o_result + func_append libobjs " $pic_object" + func_append non_pic_objects " $non_pic_object" + else + func_fatal_error "'$arg' is not a valid libtool object" + fi + fi + done + else + func_fatal_error "link input file '$arg' does not exist" + fi + arg=$save_arg + prev= + continue + ;; + os2dllname) + os2dllname=$arg + prev= + continue + ;; + precious_regex) + precious_files_regex=$arg + prev= + continue + ;; + release) + release=-$arg + prev= + continue + ;; + rpath | xrpath) + # We need an absolute path. + case $arg in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + func_fatal_error "only absolute run-paths are allowed" + ;; + esac + if test rpath = "$prev"; then + case "$rpath " in + *" $arg "*) ;; + *) func_append rpath " $arg" ;; + esac + else + case "$xrpath " in + *" $arg "*) ;; + *) func_append xrpath " $arg" ;; + esac + fi + prev= + continue + ;; + shrext) + shrext_cmds=$arg + prev= + continue + ;; + weak) + func_append weak_libs " $arg" + prev= + continue + ;; + xcclinker) + func_append linker_flags " $qarg" + func_append compiler_flags " $qarg" + prev= + func_append compile_command " $qarg" + func_append finalize_command " $qarg" + continue + ;; + xcompiler) + func_append compiler_flags " $qarg" + prev= + func_append compile_command " $qarg" + func_append finalize_command " $qarg" + continue + ;; + xlinker) + func_append linker_flags " $qarg" + func_append compiler_flags " $wl$qarg" + prev= + func_append compile_command " $wl$qarg" + func_append finalize_command " $wl$qarg" + continue + ;; + *) + eval "$prev=\"\$arg\"" + prev= + continue + ;; + esac + fi # test -n "$prev" + + prevarg=$arg + + case $arg in + -all-static) + if test -n "$link_static_flag"; then + # See comment for -static flag below, for more details. + func_append compile_command " $link_static_flag" + func_append finalize_command " $link_static_flag" + fi + continue + ;; + + -allow-undefined) + # FIXME: remove this flag sometime in the future. + func_fatal_error "'-allow-undefined' must not be used because it is the default" + ;; + + -avoid-version) + avoid_version=yes + continue + ;; + + -bindir) + prev=bindir + continue + ;; + + -dlopen) + prev=dlfiles + continue + ;; + + -dlpreopen) + prev=dlprefiles + continue + ;; + + -export-dynamic) + export_dynamic=yes + continue + ;; + + -export-symbols | -export-symbols-regex) + if test -n "$export_symbols" || test -n "$export_symbols_regex"; then + func_fatal_error "more than one -exported-symbols argument is not allowed" + fi + if test X-export-symbols = "X$arg"; then + prev=expsyms + else + prev=expsyms_regex + fi + continue + ;; + + -framework) + prev=framework + continue + ;; + + -inst-prefix-dir) + prev=inst_prefix + continue + ;; + + # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:* + # so, if we see these flags be careful not to treat them like -L + -L[A-Z][A-Z]*:*) + case $with_gcc/$host in + no/*-*-irix* | /*-*-irix*) + func_append compile_command " $arg" + func_append finalize_command " $arg" + ;; + esac + continue + ;; + + -L*) + func_stripname "-L" '' "$arg" + if test -z "$func_stripname_result"; then + if test "$#" -gt 0; then + func_fatal_error "require no space between '-L' and '$1'" + else + func_fatal_error "need path for '-L' option" + fi + fi + func_resolve_sysroot "$func_stripname_result" + dir=$func_resolve_sysroot_result + # We need an absolute path. + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) ;; + *) + absdir=`cd "$dir" && pwd` + test -z "$absdir" && \ + func_fatal_error "cannot determine absolute directory name of '$dir'" + dir=$absdir + ;; + esac + case "$deplibs " in + *" -L$dir "* | *" $arg "*) + # Will only happen for absolute or sysroot arguments + ;; + *) + # Preserve sysroot, but never include relative directories + case $dir in + [\\/]* | [A-Za-z]:[\\/]* | =*) func_append deplibs " $arg" ;; + *) func_append deplibs " -L$dir" ;; + esac + func_append lib_search_path " $dir" + ;; + esac + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) + testbindir=`$ECHO "$dir" | $SED 's*/lib$*/bin*'` + case :$dllsearchpath: in + *":$dir:"*) ;; + ::) dllsearchpath=$dir;; + *) func_append dllsearchpath ":$dir";; + esac + case :$dllsearchpath: in + *":$testbindir:"*) ;; + ::) dllsearchpath=$testbindir;; + *) func_append dllsearchpath ":$testbindir";; + esac + ;; + esac + continue + ;; + + -l*) + if test X-lc = "X$arg" || test X-lm = "X$arg"; then + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc* | *-*-haiku*) + # These systems don't actually have a C or math library (as such) + continue + ;; + *-*-os2*) + # These systems don't actually have a C library (as such) + test X-lc = "X$arg" && continue + ;; + *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*) + # Do not include libc due to us having libc/libc_r. + test X-lc = "X$arg" && continue + ;; + *-*-rhapsody* | *-*-darwin1.[012]) + # Rhapsody C and math libraries are in the System framework + func_append deplibs " System.ltframework" + continue + ;; + *-*-sco3.2v5* | *-*-sco5v6*) + # Causes problems with __ctype + test X-lc = "X$arg" && continue + ;; + *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) + # Compiler inserts libc in the correct place for threads to work + test X-lc = "X$arg" && continue + ;; + esac + elif test X-lc_r = "X$arg"; then + case $host in + *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*) + # Do not include libc_r directly, use -pthread flag. + continue + ;; + esac + fi + func_append deplibs " $arg" + continue + ;; + + -mllvm) + prev=mllvm + continue + ;; + + -module) + module=yes + continue + ;; + + # Tru64 UNIX uses -model [arg] to determine the layout of C++ + # classes, name mangling, and exception handling. + # Darwin uses the -arch flag to determine output architecture. + -model|-arch|-isysroot|--sysroot) + func_append compiler_flags " $arg" + func_append compile_command " $arg" + func_append finalize_command " $arg" + prev=xcompiler + continue + ;; + + -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \ + |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*) + func_append compiler_flags " $arg" + func_append compile_command " $arg" + func_append finalize_command " $arg" + case "$new_inherited_linker_flags " in + *" $arg "*) ;; + * ) func_append new_inherited_linker_flags " $arg" ;; + esac + continue + ;; + + -multi_module) + single_module=$wl-multi_module + continue + ;; + + -no-fast-install) + fast_install=no + continue + ;; + + -no-install) + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*) + # The PATH hackery in wrapper scripts is required on Windows + # and Darwin in order for the loader to find any dlls it needs. + func_warning "'-no-install' is ignored for $host" + func_warning "assuming '-no-fast-install' instead" + fast_install=no + ;; + *) no_install=yes ;; + esac + continue + ;; + + -no-undefined) + allow_undefined=no + continue + ;; + + -objectlist) + prev=objectlist + continue + ;; + + -os2dllname) + prev=os2dllname + continue + ;; + + -o) prev=output ;; + + -precious-files-regex) + prev=precious_regex + continue + ;; + + -release) + prev=release + continue + ;; + + -rpath) + prev=rpath + continue + ;; + + -R) + prev=xrpath + continue + ;; + + -R*) + func_stripname '-R' '' "$arg" + dir=$func_stripname_result + # We need an absolute path. + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) ;; + =*) + func_stripname '=' '' "$dir" + dir=$lt_sysroot$func_stripname_result + ;; + *) + func_fatal_error "only absolute run-paths are allowed" + ;; + esac + case "$xrpath " in + *" $dir "*) ;; + *) func_append xrpath " $dir" ;; + esac + continue + ;; + + -shared) + # The effects of -shared are defined in a previous loop. + continue + ;; + + -shrext) + prev=shrext + continue + ;; + + -static | -static-libtool-libs) + # The effects of -static are defined in a previous loop. + # We used to do the same as -all-static on platforms that + # didn't have a PIC flag, but the assumption that the effects + # would be equivalent was wrong. It would break on at least + # Digital Unix and AIX. + continue + ;; + + -thread-safe) + thread_safe=yes + continue + ;; + + -version-info) + prev=vinfo + continue + ;; + + -version-number) + prev=vinfo + vinfo_number=yes + continue + ;; + + -weak) + prev=weak + continue + ;; + + -Wc,*) + func_stripname '-Wc,' '' "$arg" + args=$func_stripname_result + arg= + save_ifs=$IFS; IFS=, + for flag in $args; do + IFS=$save_ifs + func_quote_arg pretty "$flag" + func_append arg " $func_quote_arg_result" + func_append compiler_flags " $func_quote_arg_result" + done + IFS=$save_ifs + func_stripname ' ' '' "$arg" + arg=$func_stripname_result + ;; + + -Wl,*) + func_stripname '-Wl,' '' "$arg" + args=$func_stripname_result + arg= + save_ifs=$IFS; IFS=, + for flag in $args; do + IFS=$save_ifs + func_quote_arg pretty "$flag" + func_append arg " $wl$func_quote_arg_result" + func_append compiler_flags " $wl$func_quote_arg_result" + func_append linker_flags " $func_quote_arg_result" + done + IFS=$save_ifs + func_stripname ' ' '' "$arg" + arg=$func_stripname_result + ;; + + -Xcompiler) + prev=xcompiler + continue + ;; + + -Xlinker) + prev=xlinker + continue + ;; + + -XCClinker) + prev=xcclinker + continue + ;; + + # -msg_* for osf cc + -msg_*) + func_quote_arg pretty "$arg" + arg=$func_quote_arg_result + ;; + + # Flags to be passed through unchanged, with rationale: + # -64, -mips[0-9] enable 64-bit mode for the SGI compiler + # -r[0-9][0-9]* specify processor for the SGI compiler + # -xarch=*, -xtarget=* enable 64-bit mode for the Sun compiler + # +DA*, +DD* enable 64-bit mode for the HP compiler + # -q* compiler args for the IBM compiler + # -m*, -t[45]*, -txscale* architecture-specific flags for GCC + # -F/path path to uninstalled frameworks, gcc on darwin + # -p, -pg, --coverage, -fprofile-* profiling flags for GCC + # -fstack-protector* stack protector flags for GCC + # @file GCC response files + # -tp=* Portland pgcc target processor selection + # --sysroot=* for sysroot support + # -O*, -g*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization + # -specs=* GCC specs files + # -stdlib=* select c++ std lib with clang + # -fsanitize=* Clang/GCC memory and address sanitizer + # -fuse-ld=* Linker select flags for GCC + -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \ + -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \ + -O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*| \ + -specs=*|-fsanitize=*|-fuse-ld=*) + func_quote_arg pretty "$arg" + arg=$func_quote_arg_result + func_append compile_command " $arg" + func_append finalize_command " $arg" + func_append compiler_flags " $arg" + continue + ;; + + -Z*) + if test os2 = "`expr $host : '.*\(os2\)'`"; then + # OS/2 uses -Zxxx to specify OS/2-specific options + compiler_flags="$compiler_flags $arg" + func_append compile_command " $arg" + func_append finalize_command " $arg" + case $arg in + -Zlinker | -Zstack) + prev=xcompiler + ;; + esac + continue + else + # Otherwise treat like 'Some other compiler flag' below + func_quote_arg pretty "$arg" + arg=$func_quote_arg_result + fi + ;; + + # Some other compiler flag. + -* | +*) + func_quote_arg pretty "$arg" + arg=$func_quote_arg_result + ;; + + *.$objext) + # A standard object. + func_append objs " $arg" + ;; + + *.lo) + # A libtool-controlled object. + + # Check to see that this really is a libtool object. + if func_lalib_unsafe_p "$arg"; then + pic_object= + non_pic_object= + + # Read the .lo file + func_source "$arg" + + if test -z "$pic_object" || + test -z "$non_pic_object" || + test none = "$pic_object" && + test none = "$non_pic_object"; then + func_fatal_error "cannot find name of object for '$arg'" + fi + + # Extract subdirectory from the argument. + func_dirname "$arg" "/" "" + xdir=$func_dirname_result + + test none = "$pic_object" || { + # Prepend the subdirectory the object is found in. + pic_object=$xdir$pic_object + + if test dlfiles = "$prev"; then + if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then + func_append dlfiles " $pic_object" + prev= + continue + else + # If libtool objects are unsupported, then we need to preload. + prev=dlprefiles + fi + fi + + # CHECK ME: I think I busted this. -Ossama + if test dlprefiles = "$prev"; then + # Preload the old-style object. + func_append dlprefiles " $pic_object" + prev= + fi + + # A PIC object. + func_append libobjs " $pic_object" + arg=$pic_object + } + + # Non-PIC object. + if test none != "$non_pic_object"; then + # Prepend the subdirectory the object is found in. + non_pic_object=$xdir$non_pic_object + + # A standard non-PIC object + func_append non_pic_objects " $non_pic_object" + if test -z "$pic_object" || test none = "$pic_object"; then + arg=$non_pic_object + fi + else + # If the PIC object exists, use it instead. + # $xdir was prepended to $pic_object above. + non_pic_object=$pic_object + func_append non_pic_objects " $non_pic_object" + fi + else + # Only an error if not doing a dry-run. + if $opt_dry_run; then + # Extract subdirectory from the argument. + func_dirname "$arg" "/" "" + xdir=$func_dirname_result + + func_lo2o "$arg" + pic_object=$xdir$objdir/$func_lo2o_result + non_pic_object=$xdir$func_lo2o_result + func_append libobjs " $pic_object" + func_append non_pic_objects " $non_pic_object" + else + func_fatal_error "'$arg' is not a valid libtool object" + fi + fi + ;; + + *.$libext) + # An archive. + func_append deplibs " $arg" + func_append old_deplibs " $arg" + continue + ;; + + *.la) + # A libtool-controlled library. + + func_resolve_sysroot "$arg" + if test dlfiles = "$prev"; then + # This library was specified with -dlopen. + func_append dlfiles " $func_resolve_sysroot_result" + prev= + elif test dlprefiles = "$prev"; then + # The library was specified with -dlpreopen. + func_append dlprefiles " $func_resolve_sysroot_result" + prev= + else + func_append deplibs " $func_resolve_sysroot_result" + fi + continue + ;; + + # Some other compiler argument. + *) + # Unknown arguments in both finalize_command and compile_command need + # to be aesthetically quoted because they are evaled later. + func_quote_arg pretty "$arg" + arg=$func_quote_arg_result + ;; + esac # arg + + # Now actually substitute the argument into the commands. + if test -n "$arg"; then + func_append compile_command " $arg" + func_append finalize_command " $arg" + fi + done # argument parsing loop + + test -n "$prev" && \ + func_fatal_help "the '$prevarg' option requires an argument" + + if test yes = "$export_dynamic" && test -n "$export_dynamic_flag_spec"; then + eval arg=\"$export_dynamic_flag_spec\" + func_append compile_command " $arg" + func_append finalize_command " $arg" + fi + + oldlibs= + # calculate the name of the file, without its directory + func_basename "$output" + outputname=$func_basename_result + libobjs_save=$libobjs + + if test -n "$shlibpath_var"; then + # get the directories listed in $shlibpath_var + eval shlib_search_path=\`\$ECHO \"\$$shlibpath_var\" \| \$SED \'s/:/ /g\'\` + else + shlib_search_path= + fi + eval sys_lib_search_path=\"$sys_lib_search_path_spec\" + eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\" + + # Definition is injected by LT_CONFIG during libtool generation. + func_munge_path_list sys_lib_dlsearch_path "$LT_SYS_LIBRARY_PATH" + + func_dirname "$output" "/" "" + output_objdir=$func_dirname_result$objdir + func_to_tool_file "$output_objdir/" + tool_output_objdir=$func_to_tool_file_result + # Create the object directory. + func_mkdir_p "$output_objdir" + + # Determine the type of output + case $output in + "") + func_fatal_help "you must specify an output file" + ;; + *.$libext) linkmode=oldlib ;; + *.lo | *.$objext) linkmode=obj ;; + *.la) linkmode=lib ;; + *) linkmode=prog ;; # Anything else should be a program. + esac + + specialdeplibs= + + libs= + # Find all interdependent deplibs by searching for libraries + # that are linked more than once (e.g. -la -lb -la) + for deplib in $deplibs; do + if $opt_preserve_dup_deps; then + case "$libs " in + *" $deplib "*) func_append specialdeplibs " $deplib" ;; + esac + fi + func_append libs " $deplib" + done + + if test lib = "$linkmode"; then + libs="$predeps $libs $compiler_lib_search_path $postdeps" + + # Compute libraries that are listed more than once in $predeps + # $postdeps and mark them as special (i.e., whose duplicates are + # not to be eliminated). + pre_post_deps= + if $opt_duplicate_compiler_generated_deps; then + for pre_post_dep in $predeps $postdeps; do + case "$pre_post_deps " in + *" $pre_post_dep "*) func_append specialdeplibs " $pre_post_deps" ;; + esac + func_append pre_post_deps " $pre_post_dep" + done + fi + pre_post_deps= + fi + + deplibs= + newdependency_libs= + newlib_search_path= + need_relink=no # whether we're linking any uninstalled libtool libraries + notinst_deplibs= # not-installed libtool libraries + notinst_path= # paths that contain not-installed libtool libraries + + case $linkmode in + lib) + passes="conv dlpreopen link" + for file in $dlfiles $dlprefiles; do + case $file in + *.la) ;; + *) + func_fatal_help "libraries can '-dlopen' only libtool libraries: $file" + ;; + esac + done + ;; + prog) + compile_deplibs= + finalize_deplibs= + alldeplibs=false + newdlfiles= + newdlprefiles= + passes="conv scan dlopen dlpreopen link" + ;; + *) passes="conv" + ;; + esac + + for pass in $passes; do + # The preopen pass in lib mode reverses $deplibs; put it back here + # so that -L comes before libs that need it for instance... + if test lib,link = "$linkmode,$pass"; then + ## FIXME: Find the place where the list is rebuilt in the wrong + ## order, and fix it there properly + tmp_deplibs= + for deplib in $deplibs; do + tmp_deplibs="$deplib $tmp_deplibs" + done + deplibs=$tmp_deplibs + fi + + if test lib,link = "$linkmode,$pass" || + test prog,scan = "$linkmode,$pass"; then + libs=$deplibs + deplibs= + fi + if test prog = "$linkmode"; then + case $pass in + dlopen) libs=$dlfiles ;; + dlpreopen) libs=$dlprefiles ;; + link) libs="$deplibs %DEPLIBS% $dependency_libs" ;; + esac + fi + if test lib,dlpreopen = "$linkmode,$pass"; then + # Collect and forward deplibs of preopened libtool libs + for lib in $dlprefiles; do + # Ignore non-libtool-libs + dependency_libs= + func_resolve_sysroot "$lib" + case $lib in + *.la) func_source "$func_resolve_sysroot_result" ;; + esac + + # Collect preopened libtool deplibs, except any this library + # has declared as weak libs + for deplib in $dependency_libs; do + func_basename "$deplib" + deplib_base=$func_basename_result + case " $weak_libs " in + *" $deplib_base "*) ;; + *) func_append deplibs " $deplib" ;; + esac + done + done + libs=$dlprefiles + fi + if test dlopen = "$pass"; then + # Collect dlpreopened libraries + save_deplibs=$deplibs + deplibs= + fi + + for deplib in $libs; do + lib= + found=false + case $deplib in + -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \ + |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*) + if test prog,link = "$linkmode,$pass"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + func_append compiler_flags " $deplib" + if test lib = "$linkmode"; then + case "$new_inherited_linker_flags " in + *" $deplib "*) ;; + * ) func_append new_inherited_linker_flags " $deplib" ;; + esac + fi + fi + continue + ;; + -l*) + if test lib != "$linkmode" && test prog != "$linkmode"; then + func_warning "'-l' is ignored for archives/objects" + continue + fi + func_stripname '-l' '' "$deplib" + name=$func_stripname_result + if test lib = "$linkmode"; then + searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search_dirs $sys_lib_search_path $shlib_search_path" + else + searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path" + fi + for searchdir in $searchdirs; do + for search_ext in .la $std_shrext .so .a; do + # Search the libtool library + lib=$searchdir/lib$name$search_ext + if test -f "$lib"; then + if test .la = "$search_ext"; then + found=: + else + found=false + fi + break 2 + fi + done + done + if $found; then + # deplib is a libtool library + # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib, + # We need to do some special things here, and not later. + if test yes = "$allow_libtool_libs_with_static_runtimes"; then + case " $predeps $postdeps " in + *" $deplib "*) + if func_lalib_p "$lib"; then + library_names= + old_library= + func_source "$lib" + for l in $old_library $library_names; do + ll=$l + done + if test "X$ll" = "X$old_library"; then # only static version available + found=false + func_dirname "$lib" "" "." + ladir=$func_dirname_result + lib=$ladir/$old_library + if test prog,link = "$linkmode,$pass"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + deplibs="$deplib $deplibs" + test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs" + fi + continue + fi + fi + ;; + *) ;; + esac + fi + else + # deplib doesn't seem to be a libtool library + if test prog,link = "$linkmode,$pass"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + deplibs="$deplib $deplibs" + test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs" + fi + continue + fi + ;; # -l + *.ltframework) + if test prog,link = "$linkmode,$pass"; then + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + deplibs="$deplib $deplibs" + if test lib = "$linkmode"; then + case "$new_inherited_linker_flags " in + *" $deplib "*) ;; + * ) func_append new_inherited_linker_flags " $deplib" ;; + esac + fi + fi + continue + ;; + -L*) + case $linkmode in + lib) + deplibs="$deplib $deplibs" + test conv = "$pass" && continue + newdependency_libs="$deplib $newdependency_libs" + func_stripname '-L' '' "$deplib" + func_resolve_sysroot "$func_stripname_result" + func_append newlib_search_path " $func_resolve_sysroot_result" + ;; + prog) + if test conv = "$pass"; then + deplibs="$deplib $deplibs" + continue + fi + if test scan = "$pass"; then + deplibs="$deplib $deplibs" + else + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + fi + func_stripname '-L' '' "$deplib" + func_resolve_sysroot "$func_stripname_result" + func_append newlib_search_path " $func_resolve_sysroot_result" + ;; + *) + func_warning "'-L' is ignored for archives/objects" + ;; + esac # linkmode + continue + ;; # -L + -R*) + if test link = "$pass"; then + func_stripname '-R' '' "$deplib" + func_resolve_sysroot "$func_stripname_result" + dir=$func_resolve_sysroot_result + # Make sure the xrpath contains only unique directories. + case "$xrpath " in + *" $dir "*) ;; + *) func_append xrpath " $dir" ;; + esac + fi + deplibs="$deplib $deplibs" + continue + ;; + *.la) + func_resolve_sysroot "$deplib" + lib=$func_resolve_sysroot_result + ;; + *.$libext) + if test conv = "$pass"; then + deplibs="$deplib $deplibs" + continue + fi + case $linkmode in + lib) + # Linking convenience modules into shared libraries is allowed, + # but linking other static libraries is non-portable. + case " $dlpreconveniencelibs " in + *" $deplib "*) ;; + *) + valid_a_lib=false + case $deplibs_check_method in + match_pattern*) + set dummy $deplibs_check_method; shift + match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` + if eval "\$ECHO \"$deplib\"" 2>/dev/null | $SED 10q \ + | $EGREP "$match_pattern_regex" > /dev/null; then + valid_a_lib=: + fi + ;; + pass_all) + valid_a_lib=: + ;; + esac + if $valid_a_lib; then + echo + $ECHO "*** Warning: Linking the shared library $output against the" + $ECHO "*** static library $deplib is not portable!" + deplibs="$deplib $deplibs" + else + echo + $ECHO "*** Warning: Trying to link with static lib archive $deplib." + echo "*** I have the capability to make that library automatically link in when" + echo "*** you link to this library. But I can only do this if you have a" + echo "*** shared version of the library, which you do not appear to have" + echo "*** because the file extensions .$libext of this argument makes me believe" + echo "*** that it is just a static archive that I should not use here." + fi + ;; + esac + continue + ;; + prog) + if test link != "$pass"; then + deplibs="$deplib $deplibs" + else + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + fi + continue + ;; + esac # linkmode + ;; # *.$libext + *.lo | *.$objext) + if test conv = "$pass"; then + deplibs="$deplib $deplibs" + elif test prog = "$linkmode"; then + if test dlpreopen = "$pass" || test yes != "$dlopen_support" || test no = "$build_libtool_libs"; then + # If there is no dlopen support or we're linking statically, + # we need to preload. + func_append newdlprefiles " $deplib" + compile_deplibs="$deplib $compile_deplibs" + finalize_deplibs="$deplib $finalize_deplibs" + else + func_append newdlfiles " $deplib" + fi + fi + continue + ;; + %DEPLIBS%) + alldeplibs=: + continue + ;; + esac # case $deplib + + $found || test -f "$lib" \ + || func_fatal_error "cannot find the library '$lib' or unhandled argument '$deplib'" + + # Check to see that this really is a libtool archive. + func_lalib_unsafe_p "$lib" \ + || func_fatal_error "'$lib' is not a valid libtool archive" + + func_dirname "$lib" "" "." + ladir=$func_dirname_result + + dlname= + dlopen= + dlpreopen= + libdir= + library_names= + old_library= + inherited_linker_flags= + # If the library was installed with an old release of libtool, + # it will not redefine variables installed, or shouldnotlink + installed=yes + shouldnotlink=no + avoidtemprpath= + + + # Read the .la file + func_source "$lib" + + # Convert "-framework foo" to "foo.ltframework" + if test -n "$inherited_linker_flags"; then + tmp_inherited_linker_flags=`$ECHO "$inherited_linker_flags" | $SED 's/-framework \([^ $]*\)/\1.ltframework/g'` + for tmp_inherited_linker_flag in $tmp_inherited_linker_flags; do + case " $new_inherited_linker_flags " in + *" $tmp_inherited_linker_flag "*) ;; + *) func_append new_inherited_linker_flags " $tmp_inherited_linker_flag";; + esac + done + fi + dependency_libs=`$ECHO " $dependency_libs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` + if test lib,link = "$linkmode,$pass" || + test prog,scan = "$linkmode,$pass" || + { test prog != "$linkmode" && test lib != "$linkmode"; }; then + test -n "$dlopen" && func_append dlfiles " $dlopen" + test -n "$dlpreopen" && func_append dlprefiles " $dlpreopen" + fi + + if test conv = "$pass"; then + # Only check for convenience libraries + deplibs="$lib $deplibs" + if test -z "$libdir"; then + if test -z "$old_library"; then + func_fatal_error "cannot find name of link library for '$lib'" + fi + # It is a libtool convenience library, so add in its objects. + func_append convenience " $ladir/$objdir/$old_library" + func_append old_convenience " $ladir/$objdir/$old_library" + elif test prog != "$linkmode" && test lib != "$linkmode"; then + func_fatal_error "'$lib' is not a convenience library" + fi + tmp_libs= + for deplib in $dependency_libs; do + deplibs="$deplib $deplibs" + if $opt_preserve_dup_deps; then + case "$tmp_libs " in + *" $deplib "*) func_append specialdeplibs " $deplib" ;; + esac + fi + func_append tmp_libs " $deplib" + done + continue + fi # $pass = conv + + + # Get the name of the library we link against. + linklib= + if test -n "$old_library" && + { test yes = "$prefer_static_libs" || + test built,no = "$prefer_static_libs,$installed"; }; then + linklib=$old_library + else + for l in $old_library $library_names; do + linklib=$l + done + fi + if test -z "$linklib"; then + func_fatal_error "cannot find name of link library for '$lib'" + fi + + # This library was specified with -dlopen. + if test dlopen = "$pass"; then + test -z "$libdir" \ + && func_fatal_error "cannot -dlopen a convenience library: '$lib'" + if test -z "$dlname" || + test yes != "$dlopen_support" || + test no = "$build_libtool_libs" + then + # If there is no dlname, no dlopen support or we're linking + # statically, we need to preload. We also need to preload any + # dependent libraries so libltdl's deplib preloader doesn't + # bomb out in the load deplibs phase. + func_append dlprefiles " $lib $dependency_libs" + else + func_append newdlfiles " $lib" + fi + continue + fi # $pass = dlopen + + # We need an absolute path. + case $ladir in + [\\/]* | [A-Za-z]:[\\/]*) abs_ladir=$ladir ;; + *) + abs_ladir=`cd "$ladir" && pwd` + if test -z "$abs_ladir"; then + func_warning "cannot determine absolute directory name of '$ladir'" + func_warning "passing it literally to the linker, although it might fail" + abs_ladir=$ladir + fi + ;; + esac + func_basename "$lib" + laname=$func_basename_result + + # Find the relevant object directory and library name. + if test yes = "$installed"; then + if test ! -f "$lt_sysroot$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then + func_warning "library '$lib' was moved." + dir=$ladir + absdir=$abs_ladir + libdir=$abs_ladir + else + dir=$lt_sysroot$libdir + absdir=$lt_sysroot$libdir + fi + test yes = "$hardcode_automatic" && avoidtemprpath=yes + else + if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then + dir=$ladir + absdir=$abs_ladir + # Remove this search path later + func_append notinst_path " $abs_ladir" + else + dir=$ladir/$objdir + absdir=$abs_ladir/$objdir + # Remove this search path later + func_append notinst_path " $abs_ladir" + fi + fi # $installed = yes + func_stripname 'lib' '.la' "$laname" + name=$func_stripname_result + + # This library was specified with -dlpreopen. + if test dlpreopen = "$pass"; then + if test -z "$libdir" && test prog = "$linkmode"; then + func_fatal_error "only libraries may -dlpreopen a convenience library: '$lib'" + fi + case $host in + # special handling for platforms with PE-DLLs. + *cygwin* | *mingw* | *cegcc* ) + # Linker will automatically link against shared library if both + # static and shared are present. Therefore, ensure we extract + # symbols from the import library if a shared library is present + # (otherwise, the dlopen module name will be incorrect). We do + # this by putting the import library name into $newdlprefiles. + # We recover the dlopen module name by 'saving' the la file + # name in a special purpose variable, and (later) extracting the + # dlname from the la file. + if test -n "$dlname"; then + func_tr_sh "$dir/$linklib" + eval "libfile_$func_tr_sh_result=\$abs_ladir/\$laname" + func_append newdlprefiles " $dir/$linklib" + else + func_append newdlprefiles " $dir/$old_library" + # Keep a list of preopened convenience libraries to check + # that they are being used correctly in the link pass. + test -z "$libdir" && \ + func_append dlpreconveniencelibs " $dir/$old_library" + fi + ;; + * ) + # Prefer using a static library (so that no silly _DYNAMIC symbols + # are required to link). + if test -n "$old_library"; then + func_append newdlprefiles " $dir/$old_library" + # Keep a list of preopened convenience libraries to check + # that they are being used correctly in the link pass. + test -z "$libdir" && \ + func_append dlpreconveniencelibs " $dir/$old_library" + # Otherwise, use the dlname, so that lt_dlopen finds it. + elif test -n "$dlname"; then + func_append newdlprefiles " $dir/$dlname" + else + func_append newdlprefiles " $dir/$linklib" + fi + ;; + esac + fi # $pass = dlpreopen + + if test -z "$libdir"; then + # Link the convenience library + if test lib = "$linkmode"; then + deplibs="$dir/$old_library $deplibs" + elif test prog,link = "$linkmode,$pass"; then + compile_deplibs="$dir/$old_library $compile_deplibs" + finalize_deplibs="$dir/$old_library $finalize_deplibs" + else + deplibs="$lib $deplibs" # used for prog,scan pass + fi + continue + fi + + + if test prog = "$linkmode" && test link != "$pass"; then + func_append newlib_search_path " $ladir" + deplibs="$lib $deplibs" + + linkalldeplibs=false + if test no != "$link_all_deplibs" || test -z "$library_names" || + test no = "$build_libtool_libs"; then + linkalldeplibs=: + fi + + tmp_libs= + for deplib in $dependency_libs; do + case $deplib in + -L*) func_stripname '-L' '' "$deplib" + func_resolve_sysroot "$func_stripname_result" + func_append newlib_search_path " $func_resolve_sysroot_result" + ;; + esac + # Need to link against all dependency_libs? + if $linkalldeplibs; then + deplibs="$deplib $deplibs" + else + # Need to hardcode shared library paths + # or/and link against static libraries + newdependency_libs="$deplib $newdependency_libs" + fi + if $opt_preserve_dup_deps; then + case "$tmp_libs " in + *" $deplib "*) func_append specialdeplibs " $deplib" ;; + esac + fi + func_append tmp_libs " $deplib" + done # for deplib + continue + fi # $linkmode = prog... + + if test prog,link = "$linkmode,$pass"; then + if test -n "$library_names" && + { { test no = "$prefer_static_libs" || + test built,yes = "$prefer_static_libs,$installed"; } || + test -z "$old_library"; }; then + # We need to hardcode the library path + if test -n "$shlibpath_var" && test -z "$avoidtemprpath"; then + # Make sure the rpath contains only unique directories. + case $temp_rpath: in + *"$absdir:"*) ;; + *) func_append temp_rpath "$absdir:" ;; + esac + fi + + # Hardcode the library path. + # Skip directories that are in the system default run-time + # search path. + case " $sys_lib_dlsearch_path " in + *" $absdir "*) ;; + *) + case "$compile_rpath " in + *" $absdir "*) ;; + *) func_append compile_rpath " $absdir" ;; + esac + ;; + esac + case " $sys_lib_dlsearch_path " in + *" $libdir "*) ;; + *) + case "$finalize_rpath " in + *" $libdir "*) ;; + *) func_append finalize_rpath " $libdir" ;; + esac + ;; + esac + fi # $linkmode,$pass = prog,link... + + if $alldeplibs && + { test pass_all = "$deplibs_check_method" || + { test yes = "$build_libtool_libs" && + test -n "$library_names"; }; }; then + # We only need to search for static libraries + continue + fi + fi + + link_static=no # Whether the deplib will be linked statically + use_static_libs=$prefer_static_libs + if test built = "$use_static_libs" && test yes = "$installed"; then + use_static_libs=no + fi + if test -n "$library_names" && + { test no = "$use_static_libs" || test -z "$old_library"; }; then + case $host in + *cygwin* | *mingw* | *cegcc* | *os2*) + # No point in relinking DLLs because paths are not encoded + func_append notinst_deplibs " $lib" + need_relink=no + ;; + *) + if test no = "$installed"; then + func_append notinst_deplibs " $lib" + need_relink=yes + fi + ;; + esac + # This is a shared library + + # Warn about portability, can't link against -module's on some + # systems (darwin). Don't bleat about dlopened modules though! + dlopenmodule= + for dlpremoduletest in $dlprefiles; do + if test "X$dlpremoduletest" = "X$lib"; then + dlopenmodule=$dlpremoduletest + break + fi + done + if test -z "$dlopenmodule" && test yes = "$shouldnotlink" && test link = "$pass"; then + echo + if test prog = "$linkmode"; then + $ECHO "*** Warning: Linking the executable $output against the loadable module" + else + $ECHO "*** Warning: Linking the shared library $output against the loadable module" + fi + $ECHO "*** $linklib is not portable!" + fi + if test lib = "$linkmode" && + test yes = "$hardcode_into_libs"; then + # Hardcode the library path. + # Skip directories that are in the system default run-time + # search path. + case " $sys_lib_dlsearch_path " in + *" $absdir "*) ;; + *) + case "$compile_rpath " in + *" $absdir "*) ;; + *) func_append compile_rpath " $absdir" ;; + esac + ;; + esac + case " $sys_lib_dlsearch_path " in + *" $libdir "*) ;; + *) + case "$finalize_rpath " in + *" $libdir "*) ;; + *) func_append finalize_rpath " $libdir" ;; + esac + ;; + esac + fi + + if test -n "$old_archive_from_expsyms_cmds"; then + # figure out the soname + set dummy $library_names + shift + realname=$1 + shift + libname=`eval "\\$ECHO \"$libname_spec\""` + # use dlname if we got it. it's perfectly good, no? + if test -n "$dlname"; then + soname=$dlname + elif test -n "$soname_spec"; then + # bleh windows + case $host in + *cygwin* | mingw* | *cegcc* | *os2*) + func_arith $current - $age + major=$func_arith_result + versuffix=-$major + ;; + esac + eval soname=\"$soname_spec\" + else + soname=$realname + fi + + # Make a new name for the extract_expsyms_cmds to use + soroot=$soname + func_basename "$soroot" + soname=$func_basename_result + func_stripname 'lib' '.dll' "$soname" + newlib=libimp-$func_stripname_result.a + + # If the library has no export list, then create one now + if test -f "$output_objdir/$soname-def"; then : + else + func_verbose "extracting exported symbol list from '$soname'" + func_execute_cmds "$extract_expsyms_cmds" 'exit $?' + fi + + # Create $newlib + if test -f "$output_objdir/$newlib"; then :; else + func_verbose "generating import library for '$soname'" + func_execute_cmds "$old_archive_from_expsyms_cmds" 'exit $?' + fi + # make sure the library variables are pointing to the new library + dir=$output_objdir + linklib=$newlib + fi # test -n "$old_archive_from_expsyms_cmds" + + if test prog = "$linkmode" || test relink != "$opt_mode"; then + add_shlibpath= + add_dir= + add= + lib_linked=yes + case $hardcode_action in + immediate | unsupported) + if test no = "$hardcode_direct"; then + add=$dir/$linklib + case $host in + *-*-sco3.2v5.0.[024]*) add_dir=-L$dir ;; + *-*-sysv4*uw2*) add_dir=-L$dir ;; + *-*-sysv5OpenUNIX* | *-*-sysv5UnixWare7.[01].[10]* | \ + *-*-unixware7*) add_dir=-L$dir ;; + *-*-darwin* ) + # if the lib is a (non-dlopened) module then we cannot + # link against it, someone is ignoring the earlier warnings + if /usr/bin/file -L $add 2> /dev/null | + $GREP ": [^:]* bundle" >/dev/null; then + if test "X$dlopenmodule" != "X$lib"; then + $ECHO "*** Warning: lib $linklib is a module, not a shared library" + if test -z "$old_library"; then + echo + echo "*** And there doesn't seem to be a static archive available" + echo "*** The link will probably fail, sorry" + else + add=$dir/$old_library + fi + elif test -n "$old_library"; then + add=$dir/$old_library + fi + fi + esac + elif test no = "$hardcode_minus_L"; then + case $host in + *-*-sunos*) add_shlibpath=$dir ;; + esac + add_dir=-L$dir + add=-l$name + elif test no = "$hardcode_shlibpath_var"; then + add_shlibpath=$dir + add=-l$name + else + lib_linked=no + fi + ;; + relink) + if test yes = "$hardcode_direct" && + test no = "$hardcode_direct_absolute"; then + add=$dir/$linklib + elif test yes = "$hardcode_minus_L"; then + add_dir=-L$absdir + # Try looking first in the location we're being installed to. + if test -n "$inst_prefix_dir"; then + case $libdir in + [\\/]*) + func_append add_dir " -L$inst_prefix_dir$libdir" + ;; + esac + fi + add=-l$name + elif test yes = "$hardcode_shlibpath_var"; then + add_shlibpath=$dir + add=-l$name + else + lib_linked=no + fi + ;; + *) lib_linked=no ;; + esac + + if test yes != "$lib_linked"; then + func_fatal_configuration "unsupported hardcode properties" + fi + + if test -n "$add_shlibpath"; then + case :$compile_shlibpath: in + *":$add_shlibpath:"*) ;; + *) func_append compile_shlibpath "$add_shlibpath:" ;; + esac + fi + if test prog = "$linkmode"; then + test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs" + test -n "$add" && compile_deplibs="$add $compile_deplibs" + else + test -n "$add_dir" && deplibs="$add_dir $deplibs" + test -n "$add" && deplibs="$add $deplibs" + if test yes != "$hardcode_direct" && + test yes != "$hardcode_minus_L" && + test yes = "$hardcode_shlibpath_var"; then + case :$finalize_shlibpath: in + *":$libdir:"*) ;; + *) func_append finalize_shlibpath "$libdir:" ;; + esac + fi + fi + fi + + if test prog = "$linkmode" || test relink = "$opt_mode"; then + add_shlibpath= + add_dir= + add= + # Finalize command for both is simple: just hardcode it. + if test yes = "$hardcode_direct" && + test no = "$hardcode_direct_absolute"; then + add=$libdir/$linklib + elif test yes = "$hardcode_minus_L"; then + add_dir=-L$libdir + add=-l$name + elif test yes = "$hardcode_shlibpath_var"; then + case :$finalize_shlibpath: in + *":$libdir:"*) ;; + *) func_append finalize_shlibpath "$libdir:" ;; + esac + add=-l$name + elif test yes = "$hardcode_automatic"; then + if test -n "$inst_prefix_dir" && + test -f "$inst_prefix_dir$libdir/$linklib"; then + add=$inst_prefix_dir$libdir/$linklib + else + add=$libdir/$linklib + fi + else + # We cannot seem to hardcode it, guess we'll fake it. + add_dir=-L$libdir + # Try looking first in the location we're being installed to. + if test -n "$inst_prefix_dir"; then + case $libdir in + [\\/]*) + func_append add_dir " -L$inst_prefix_dir$libdir" + ;; + esac + fi + add=-l$name + fi + + if test prog = "$linkmode"; then + test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs" + test -n "$add" && finalize_deplibs="$add $finalize_deplibs" + else + test -n "$add_dir" && deplibs="$add_dir $deplibs" + test -n "$add" && deplibs="$add $deplibs" + fi + fi + elif test prog = "$linkmode"; then + # Here we assume that one of hardcode_direct or hardcode_minus_L + # is not unsupported. This is valid on all known static and + # shared platforms. + if test unsupported != "$hardcode_direct"; then + test -n "$old_library" && linklib=$old_library + compile_deplibs="$dir/$linklib $compile_deplibs" + finalize_deplibs="$dir/$linklib $finalize_deplibs" + else + compile_deplibs="-l$name -L$dir $compile_deplibs" + finalize_deplibs="-l$name -L$dir $finalize_deplibs" + fi + elif test yes = "$build_libtool_libs"; then + # Not a shared library + if test pass_all != "$deplibs_check_method"; then + # We're trying link a shared library against a static one + # but the system doesn't support it. + + # Just print a warning and add the library to dependency_libs so + # that the program can be linked against the static library. + echo + $ECHO "*** Warning: This system cannot link to static lib archive $lib." + echo "*** I have the capability to make that library automatically link in when" + echo "*** you link to this library. But I can only do this if you have a" + echo "*** shared version of the library, which you do not appear to have." + if test yes = "$module"; then + echo "*** But as you try to build a module library, libtool will still create " + echo "*** a static module, that should work as long as the dlopening application" + echo "*** is linked with the -dlopen flag to resolve symbols at runtime." + if test -z "$global_symbol_pipe"; then + echo + echo "*** However, this would only work if libtool was able to extract symbol" + echo "*** lists from a program, using 'nm' or equivalent, but libtool could" + echo "*** not find such a program. So, this module is probably useless." + echo "*** 'nm' from GNU binutils and a full rebuild may help." + fi + if test no = "$build_old_libs"; then + build_libtool_libs=module + build_old_libs=yes + else + build_libtool_libs=no + fi + fi + else + deplibs="$dir/$old_library $deplibs" + link_static=yes + fi + fi # link shared/static library? + + if test lib = "$linkmode"; then + if test -n "$dependency_libs" && + { test yes != "$hardcode_into_libs" || + test yes = "$build_old_libs" || + test yes = "$link_static"; }; then + # Extract -R from dependency_libs + temp_deplibs= + for libdir in $dependency_libs; do + case $libdir in + -R*) func_stripname '-R' '' "$libdir" + temp_xrpath=$func_stripname_result + case " $xrpath " in + *" $temp_xrpath "*) ;; + *) func_append xrpath " $temp_xrpath";; + esac;; + *) func_append temp_deplibs " $libdir";; + esac + done + dependency_libs=$temp_deplibs + fi + + func_append newlib_search_path " $absdir" + # Link against this library + test no = "$link_static" && newdependency_libs="$abs_ladir/$laname $newdependency_libs" + # ... and its dependency_libs + tmp_libs= + for deplib in $dependency_libs; do + newdependency_libs="$deplib $newdependency_libs" + case $deplib in + -L*) func_stripname '-L' '' "$deplib" + func_resolve_sysroot "$func_stripname_result";; + *) func_resolve_sysroot "$deplib" ;; + esac + if $opt_preserve_dup_deps; then + case "$tmp_libs " in + *" $func_resolve_sysroot_result "*) + func_append specialdeplibs " $func_resolve_sysroot_result" ;; + esac + fi + func_append tmp_libs " $func_resolve_sysroot_result" + done + + if test no != "$link_all_deplibs"; then + # Add the search paths of all dependency libraries + for deplib in $dependency_libs; do + path= + case $deplib in + -L*) path=$deplib ;; + *.la) + func_resolve_sysroot "$deplib" + deplib=$func_resolve_sysroot_result + func_dirname "$deplib" "" "." + dir=$func_dirname_result + # We need an absolute path. + case $dir in + [\\/]* | [A-Za-z]:[\\/]*) absdir=$dir ;; + *) + absdir=`cd "$dir" && pwd` + if test -z "$absdir"; then + func_warning "cannot determine absolute directory name of '$dir'" + absdir=$dir + fi + ;; + esac + if $GREP "^installed=no" $deplib > /dev/null; then + case $host in + *-*-darwin*) + depdepl= + eval deplibrary_names=`$SED -n -e 's/^library_names=\(.*\)$/\1/p' $deplib` + if test -n "$deplibrary_names"; then + for tmp in $deplibrary_names; do + depdepl=$tmp + done + if test -f "$absdir/$objdir/$depdepl"; then + depdepl=$absdir/$objdir/$depdepl + darwin_install_name=`$OTOOL -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` + if test -z "$darwin_install_name"; then + darwin_install_name=`$OTOOL64 -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` + fi + func_append compiler_flags " $wl-dylib_file $wl$darwin_install_name:$depdepl" + func_append linker_flags " -dylib_file $darwin_install_name:$depdepl" + path= + fi + fi + ;; + *) + path=-L$absdir/$objdir + ;; + esac + else + eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` + test -z "$libdir" && \ + func_fatal_error "'$deplib' is not a valid libtool archive" + test "$absdir" != "$libdir" && \ + func_warning "'$deplib' seems to be moved" + + path=-L$absdir + fi + ;; + esac + case " $deplibs " in + *" $path "*) ;; + *) deplibs="$path $deplibs" ;; + esac + done + fi # link_all_deplibs != no + fi # linkmode = lib + done # for deplib in $libs + if test link = "$pass"; then + if test prog = "$linkmode"; then + compile_deplibs="$new_inherited_linker_flags $compile_deplibs" + finalize_deplibs="$new_inherited_linker_flags $finalize_deplibs" + else + compiler_flags="$compiler_flags "`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` + fi + fi + dependency_libs=$newdependency_libs + if test dlpreopen = "$pass"; then + # Link the dlpreopened libraries before other libraries + for deplib in $save_deplibs; do + deplibs="$deplib $deplibs" + done + fi + if test dlopen != "$pass"; then + test conv = "$pass" || { + # Make sure lib_search_path contains only unique directories. + lib_search_path= + for dir in $newlib_search_path; do + case "$lib_search_path " in + *" $dir "*) ;; + *) func_append lib_search_path " $dir" ;; + esac + done + newlib_search_path= + } + + if test prog,link = "$linkmode,$pass"; then + vars="compile_deplibs finalize_deplibs" + else + vars=deplibs + fi + for var in $vars dependency_libs; do + # Add libraries to $var in reverse order + eval tmp_libs=\"\$$var\" + new_libs= + for deplib in $tmp_libs; do + # FIXME: Pedantically, this is the right thing to do, so + # that some nasty dependency loop isn't accidentally + # broken: + #new_libs="$deplib $new_libs" + # Pragmatically, this seems to cause very few problems in + # practice: + case $deplib in + -L*) new_libs="$deplib $new_libs" ;; + -R*) ;; + *) + # And here is the reason: when a library appears more + # than once as an explicit dependence of a library, or + # is implicitly linked in more than once by the + # compiler, it is considered special, and multiple + # occurrences thereof are not removed. Compare this + # with having the same library being listed as a + # dependency of multiple other libraries: in this case, + # we know (pedantically, we assume) the library does not + # need to be listed more than once, so we keep only the + # last copy. This is not always right, but it is rare + # enough that we require users that really mean to play + # such unportable linking tricks to link the library + # using -Wl,-lname, so that libtool does not consider it + # for duplicate removal. + case " $specialdeplibs " in + *" $deplib "*) new_libs="$deplib $new_libs" ;; + *) + case " $new_libs " in + *" $deplib "*) ;; + *) new_libs="$deplib $new_libs" ;; + esac + ;; + esac + ;; + esac + done + tmp_libs= + for deplib in $new_libs; do + case $deplib in + -L*) + case " $tmp_libs " in + *" $deplib "*) ;; + *) func_append tmp_libs " $deplib" ;; + esac + ;; + *) func_append tmp_libs " $deplib" ;; + esac + done + eval $var=\"$tmp_libs\" + done # for var + fi + + # Add Sun CC postdeps if required: + test CXX = "$tagname" && { + case $host_os in + linux*) + case `$CC -V 2>&1 | sed 5q` in + *Sun\ C*) # Sun C++ 5.9 + func_suncc_cstd_abi + + if test no != "$suncc_use_cstd_abi"; then + func_append postdeps ' -library=Cstd -library=Crun' + fi + ;; + esac + ;; + + solaris*) + func_cc_basename "$CC" + case $func_cc_basename_result in + CC* | sunCC*) + func_suncc_cstd_abi + + if test no != "$suncc_use_cstd_abi"; then + func_append postdeps ' -library=Cstd -library=Crun' + fi + ;; + esac + ;; + esac + } + + # Last step: remove runtime libs from dependency_libs + # (they stay in deplibs) + tmp_libs= + for i in $dependency_libs; do + case " $predeps $postdeps $compiler_lib_search_path " in + *" $i "*) + i= + ;; + esac + if test -n "$i"; then + func_append tmp_libs " $i" + fi + done + dependency_libs=$tmp_libs + done # for pass + if test prog = "$linkmode"; then + dlfiles=$newdlfiles + fi + if test prog = "$linkmode" || test lib = "$linkmode"; then + dlprefiles=$newdlprefiles + fi + + case $linkmode in + oldlib) + if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then + func_warning "'-dlopen' is ignored for archives" + fi + + case " $deplibs" in + *\ -l* | *\ -L*) + func_warning "'-l' and '-L' are ignored for archives" ;; + esac + + test -n "$rpath" && \ + func_warning "'-rpath' is ignored for archives" + + test -n "$xrpath" && \ + func_warning "'-R' is ignored for archives" + + test -n "$vinfo" && \ + func_warning "'-version-info/-version-number' is ignored for archives" + + test -n "$release" && \ + func_warning "'-release' is ignored for archives" + + test -n "$export_symbols$export_symbols_regex" && \ + func_warning "'-export-symbols' is ignored for archives" + + # Now set the variables for building old libraries. + build_libtool_libs=no + oldlibs=$output + func_append objs "$old_deplibs" + ;; + + lib) + # Make sure we only generate libraries of the form 'libNAME.la'. + case $outputname in + lib*) + func_stripname 'lib' '.la' "$outputname" + name=$func_stripname_result + eval shared_ext=\"$shrext_cmds\" + eval libname=\"$libname_spec\" + ;; + *) + test no = "$module" \ + && func_fatal_help "libtool library '$output' must begin with 'lib'" + + if test no != "$need_lib_prefix"; then + # Add the "lib" prefix for modules if required + func_stripname '' '.la' "$outputname" + name=$func_stripname_result + eval shared_ext=\"$shrext_cmds\" + eval libname=\"$libname_spec\" + else + func_stripname '' '.la' "$outputname" + libname=$func_stripname_result + fi + ;; + esac + + if test -n "$objs"; then + if test pass_all != "$deplibs_check_method"; then + func_fatal_error "cannot build libtool library '$output' from non-libtool objects on this host:$objs" + else + echo + $ECHO "*** Warning: Linking the shared library $output against the non-libtool" + $ECHO "*** objects $objs is not portable!" + func_append libobjs " $objs" + fi + fi + + test no = "$dlself" \ + || func_warning "'-dlopen self' is ignored for libtool libraries" + + set dummy $rpath + shift + test 1 -lt "$#" \ + && func_warning "ignoring multiple '-rpath's for a libtool library" + + install_libdir=$1 + + oldlibs= + if test -z "$rpath"; then + if test yes = "$build_libtool_libs"; then + # Building a libtool convenience library. + # Some compilers have problems with a '.al' extension so + # convenience libraries should have the same extension an + # archive normally would. + oldlibs="$output_objdir/$libname.$libext $oldlibs" + build_libtool_libs=convenience + build_old_libs=yes + fi + + test -n "$vinfo" && \ + func_warning "'-version-info/-version-number' is ignored for convenience libraries" + + test -n "$release" && \ + func_warning "'-release' is ignored for convenience libraries" + else + + # Parse the version information argument. + save_ifs=$IFS; IFS=: + set dummy $vinfo 0 0 0 + shift + IFS=$save_ifs + + test -n "$7" && \ + func_fatal_help "too many parameters to '-version-info'" + + # convert absolute version numbers to libtool ages + # this retains compatibility with .la files and attempts + # to make the code below a bit more comprehensible + + case $vinfo_number in + yes) + number_major=$1 + number_minor=$2 + number_revision=$3 + # + # There are really only two kinds -- those that + # use the current revision as the major version + # and those that subtract age and use age as + # a minor version. But, then there is irix + # that has an extra 1 added just for fun + # + case $version_type in + # correct linux to gnu/linux during the next big refactor + darwin|freebsd-elf|linux|osf|windows|none) + func_arith $number_major + $number_minor + current=$func_arith_result + age=$number_minor + revision=$number_revision + ;; + freebsd-aout|qnx|sunos) + current=$number_major + revision=$number_minor + age=0 + ;; + irix|nonstopux) + func_arith $number_major + $number_minor + current=$func_arith_result + age=$number_minor + revision=$number_minor + lt_irix_increment=no + ;; + esac + ;; + no) + current=$1 + revision=$2 + age=$3 + ;; + esac + + # Check that each of the things are valid numbers. + case $current in + 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; + *) + func_error "CURRENT '$current' must be a nonnegative integer" + func_fatal_error "'$vinfo' is not valid version information" + ;; + esac + + case $revision in + 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; + *) + func_error "REVISION '$revision' must be a nonnegative integer" + func_fatal_error "'$vinfo' is not valid version information" + ;; + esac + + case $age in + 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; + *) + func_error "AGE '$age' must be a nonnegative integer" + func_fatal_error "'$vinfo' is not valid version information" + ;; + esac + + if test "$age" -gt "$current"; then + func_error "AGE '$age' is greater than the current interface number '$current'" + func_fatal_error "'$vinfo' is not valid version information" + fi + + # Calculate the version variables. + major= + versuffix= + verstring= + case $version_type in + none) ;; + + darwin) + # Like Linux, but with the current version available in + # verstring for coding it into the library header + func_arith $current - $age + major=.$func_arith_result + versuffix=$major.$age.$revision + # Darwin ld doesn't like 0 for these options... + func_arith $current + 1 + minor_current=$func_arith_result + xlcverstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision" + verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" + # On Darwin other compilers + case $CC in + nagfor*) + verstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision" + ;; + *) + verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" + ;; + esac + ;; + + freebsd-aout) + major=.$current + versuffix=.$current.$revision + ;; + + freebsd-elf) + func_arith $current - $age + major=.$func_arith_result + versuffix=$major.$age.$revision + ;; + + irix | nonstopux) + if test no = "$lt_irix_increment"; then + func_arith $current - $age + else + func_arith $current - $age + 1 + fi + major=$func_arith_result + + case $version_type in + nonstopux) verstring_prefix=nonstopux ;; + *) verstring_prefix=sgi ;; + esac + verstring=$verstring_prefix$major.$revision + + # Add in all the interfaces that we are compatible with. + loop=$revision + while test 0 -ne "$loop"; do + func_arith $revision - $loop + iface=$func_arith_result + func_arith $loop - 1 + loop=$func_arith_result + verstring=$verstring_prefix$major.$iface:$verstring + done + + # Before this point, $major must not contain '.'. + major=.$major + versuffix=$major.$revision + ;; + + linux) # correct to gnu/linux during the next big refactor + func_arith $current - $age + major=.$func_arith_result + versuffix=$major.$age.$revision + ;; + + osf) + func_arith $current - $age + major=.$func_arith_result + versuffix=.$current.$age.$revision + verstring=$current.$age.$revision + + # Add in all the interfaces that we are compatible with. + loop=$age + while test 0 -ne "$loop"; do + func_arith $current - $loop + iface=$func_arith_result + func_arith $loop - 1 + loop=$func_arith_result + verstring=$verstring:$iface.0 + done + + # Make executables depend on our current version. + func_append verstring ":$current.0" + ;; + + qnx) + major=.$current + versuffix=.$current + ;; + + sco) + major=.$current + versuffix=.$current + ;; + + sunos) + major=.$current + versuffix=.$current.$revision + ;; + + windows) + # Use '-' rather than '.', since we only want one + # extension on DOS 8.3 file systems. + func_arith $current - $age + major=$func_arith_result + versuffix=-$major + ;; + + *) + func_fatal_configuration "unknown library version type '$version_type'" + ;; + esac + + # Clear the version info if we defaulted, and they specified a release. + if test -z "$vinfo" && test -n "$release"; then + major= + case $version_type in + darwin) + # we can't check for "0.0" in archive_cmds due to quoting + # problems, so we reset it completely + verstring= + ;; + *) + verstring=0.0 + ;; + esac + if test no = "$need_version"; then + versuffix= + else + versuffix=.0.0 + fi + fi + + # Remove version info from name if versioning should be avoided + if test yes,no = "$avoid_version,$need_version"; then + major= + versuffix= + verstring= + fi + + # Check to see if the archive will have undefined symbols. + if test yes = "$allow_undefined"; then + if test unsupported = "$allow_undefined_flag"; then + if test yes = "$build_old_libs"; then + func_warning "undefined symbols not allowed in $host shared libraries; building static only" + build_libtool_libs=no + else + func_fatal_error "can't build $host shared library unless -no-undefined is specified" + fi + fi + else + # Don't allow undefined symbols. + allow_undefined_flag=$no_undefined_flag + fi + + fi + + func_generate_dlsyms "$libname" "$libname" : + func_append libobjs " $symfileobj" + test " " = "$libobjs" && libobjs= + + if test relink != "$opt_mode"; then + # Remove our outputs, but don't remove object files since they + # may have been created when compiling PIC objects. + removelist= + tempremovelist=`$ECHO "$output_objdir/*"` + for p in $tempremovelist; do + case $p in + *.$objext | *.gcno) + ;; + $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/$libname$release.*) + if test -n "$precious_files_regex"; then + if $ECHO "$p" | $EGREP -e "$precious_files_regex" >/dev/null 2>&1 + then + continue + fi + fi + func_append removelist " $p" + ;; + *) ;; + esac + done + test -n "$removelist" && \ + func_show_eval "${RM}r \$removelist" + fi + + # Now set the variables for building old libraries. + if test yes = "$build_old_libs" && test convenience != "$build_libtool_libs"; then + func_append oldlibs " $output_objdir/$libname.$libext" + + # Transform .lo files to .o files. + oldobjs="$objs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; $lo2o" | $NL2SP` + fi + + # Eliminate all temporary directories. + #for path in $notinst_path; do + # lib_search_path=`$ECHO "$lib_search_path " | $SED "s% $path % %g"` + # deplibs=`$ECHO "$deplibs " | $SED "s% -L$path % %g"` + # dependency_libs=`$ECHO "$dependency_libs " | $SED "s% -L$path % %g"` + #done + + if test -n "$xrpath"; then + # If the user specified any rpath flags, then add them. + temp_xrpath= + for libdir in $xrpath; do + func_replace_sysroot "$libdir" + func_append temp_xrpath " -R$func_replace_sysroot_result" + case "$finalize_rpath " in + *" $libdir "*) ;; + *) func_append finalize_rpath " $libdir" ;; + esac + done + if test yes != "$hardcode_into_libs" || test yes = "$build_old_libs"; then + dependency_libs="$temp_xrpath $dependency_libs" + fi + fi + + # Make sure dlfiles contains only unique files that won't be dlpreopened + old_dlfiles=$dlfiles + dlfiles= + for lib in $old_dlfiles; do + case " $dlprefiles $dlfiles " in + *" $lib "*) ;; + *) func_append dlfiles " $lib" ;; + esac + done + + # Make sure dlprefiles contains only unique files + old_dlprefiles=$dlprefiles + dlprefiles= + for lib in $old_dlprefiles; do + case "$dlprefiles " in + *" $lib "*) ;; + *) func_append dlprefiles " $lib" ;; + esac + done + + if test yes = "$build_libtool_libs"; then + if test -n "$rpath"; then + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc* | *-*-haiku*) + # these systems don't actually have a c library (as such)! + ;; + *-*-rhapsody* | *-*-darwin1.[012]) + # Rhapsody C library is in the System framework + func_append deplibs " System.ltframework" + ;; + *-*-netbsd*) + # Don't link with libc until the a.out ld.so is fixed. + ;; + *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*) + # Do not include libc due to us having libc/libc_r. + ;; + *-*-sco3.2v5* | *-*-sco5v6*) + # Causes problems with __ctype + ;; + *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) + # Compiler inserts libc in the correct place for threads to work + ;; + *) + # Add libc to deplibs on all other systems if necessary. + if test yes = "$build_libtool_need_lc"; then + func_append deplibs " -lc" + fi + ;; + esac + fi + + # Transform deplibs into only deplibs that can be linked in shared. + name_save=$name + libname_save=$libname + release_save=$release + versuffix_save=$versuffix + major_save=$major + # I'm not sure if I'm treating the release correctly. I think + # release should show up in the -l (ie -lgmp5) so we don't want to + # add it in twice. Is that correct? + release= + versuffix= + major= + newdeplibs= + droppeddeps=no + case $deplibs_check_method in + pass_all) + # Don't check for shared/static. Everything works. + # This might be a little naive. We might want to check + # whether the library exists or not. But this is on + # osf3 & osf4 and I'm not really sure... Just + # implementing what was already the behavior. + newdeplibs=$deplibs + ;; + test_compile) + # This code stresses the "libraries are programs" paradigm to its + # limits. Maybe even breaks it. We compile a program, linking it + # against the deplibs as a proxy for the library. Then we can check + # whether they linked in statically or dynamically with ldd. + $opt_dry_run || $RM conftest.c + cat > conftest.c </dev/null` + $nocaseglob + else + potential_libs=`ls $i/$libnameglob[.-]* 2>/dev/null` + fi + for potent_lib in $potential_libs; do + # Follow soft links. + if ls -lLd "$potent_lib" 2>/dev/null | + $GREP " -> " >/dev/null; then + continue + fi + # The statement above tries to avoid entering an + # endless loop below, in case of cyclic links. + # We might still enter an endless loop, since a link + # loop can be closed while we follow links, + # but so what? + potlib=$potent_lib + while test -h "$potlib" 2>/dev/null; do + potliblink=`ls -ld $potlib | $SED 's/.* -> //'` + case $potliblink in + [\\/]* | [A-Za-z]:[\\/]*) potlib=$potliblink;; + *) potlib=`$ECHO "$potlib" | $SED 's|[^/]*$||'`"$potliblink";; + esac + done + if eval $file_magic_cmd \"\$potlib\" 2>/dev/null | + $SED -e 10q | + $EGREP "$file_magic_regex" > /dev/null; then + func_append newdeplibs " $a_deplib" + a_deplib= + break 2 + fi + done + done + fi + if test -n "$a_deplib"; then + droppeddeps=yes + echo + $ECHO "*** Warning: linker path does not have real file for library $a_deplib." + echo "*** I have the capability to make that library automatically link in when" + echo "*** you link to this library. But I can only do this if you have a" + echo "*** shared version of the library, which you do not appear to have" + echo "*** because I did check the linker path looking for a file starting" + if test -z "$potlib"; then + $ECHO "*** with $libname but no candidates were found. (...for file magic test)" + else + $ECHO "*** with $libname and none of the candidates passed a file format test" + $ECHO "*** using a file magic. Last file checked: $potlib" + fi + fi + ;; + *) + # Add a -L argument. + func_append newdeplibs " $a_deplib" + ;; + esac + done # Gone through all deplibs. + ;; + match_pattern*) + set dummy $deplibs_check_method; shift + match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` + for a_deplib in $deplibs; do + case $a_deplib in + -l*) + func_stripname -l '' "$a_deplib" + name=$func_stripname_result + if test yes = "$allow_libtool_libs_with_static_runtimes"; then + case " $predeps $postdeps " in + *" $a_deplib "*) + func_append newdeplibs " $a_deplib" + a_deplib= + ;; + esac + fi + if test -n "$a_deplib"; then + libname=`eval "\\$ECHO \"$libname_spec\""` + for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do + potential_libs=`ls $i/$libname[.-]* 2>/dev/null` + for potent_lib in $potential_libs; do + potlib=$potent_lib # see symlink-check above in file_magic test + if eval "\$ECHO \"$potent_lib\"" 2>/dev/null | $SED 10q | \ + $EGREP "$match_pattern_regex" > /dev/null; then + func_append newdeplibs " $a_deplib" + a_deplib= + break 2 + fi + done + done + fi + if test -n "$a_deplib"; then + droppeddeps=yes + echo + $ECHO "*** Warning: linker path does not have real file for library $a_deplib." + echo "*** I have the capability to make that library automatically link in when" + echo "*** you link to this library. But I can only do this if you have a" + echo "*** shared version of the library, which you do not appear to have" + echo "*** because I did check the linker path looking for a file starting" + if test -z "$potlib"; then + $ECHO "*** with $libname but no candidates were found. (...for regex pattern test)" + else + $ECHO "*** with $libname and none of the candidates passed a file format test" + $ECHO "*** using a regex pattern. Last file checked: $potlib" + fi + fi + ;; + *) + # Add a -L argument. + func_append newdeplibs " $a_deplib" + ;; + esac + done # Gone through all deplibs. + ;; + none | unknown | *) + newdeplibs= + tmp_deplibs=`$ECHO " $deplibs" | $SED 's/ -lc$//; s/ -[LR][^ ]*//g'` + if test yes = "$allow_libtool_libs_with_static_runtimes"; then + for i in $predeps $postdeps; do + # can't use Xsed below, because $i might contain '/' + tmp_deplibs=`$ECHO " $tmp_deplibs" | $SED "s|$i||"` + done + fi + case $tmp_deplibs in + *[!\ \ ]*) + echo + if test none = "$deplibs_check_method"; then + echo "*** Warning: inter-library dependencies are not supported in this platform." + else + echo "*** Warning: inter-library dependencies are not known to be supported." + fi + echo "*** All declared inter-library dependencies are being dropped." + droppeddeps=yes + ;; + esac + ;; + esac + versuffix=$versuffix_save + major=$major_save + release=$release_save + libname=$libname_save + name=$name_save + + case $host in + *-*-rhapsody* | *-*-darwin1.[012]) + # On Rhapsody replace the C library with the System framework + newdeplibs=`$ECHO " $newdeplibs" | $SED 's/ -lc / System.ltframework /'` + ;; + esac + + if test yes = "$droppeddeps"; then + if test yes = "$module"; then + echo + echo "*** Warning: libtool could not satisfy all declared inter-library" + $ECHO "*** dependencies of module $libname. Therefore, libtool will create" + echo "*** a static module, that should work as long as the dlopening" + echo "*** application is linked with the -dlopen flag." + if test -z "$global_symbol_pipe"; then + echo + echo "*** However, this would only work if libtool was able to extract symbol" + echo "*** lists from a program, using 'nm' or equivalent, but libtool could" + echo "*** not find such a program. So, this module is probably useless." + echo "*** 'nm' from GNU binutils and a full rebuild may help." + fi + if test no = "$build_old_libs"; then + oldlibs=$output_objdir/$libname.$libext + build_libtool_libs=module + build_old_libs=yes + else + build_libtool_libs=no + fi + else + echo "*** The inter-library dependencies that have been dropped here will be" + echo "*** automatically added whenever a program is linked with this library" + echo "*** or is declared to -dlopen it." + + if test no = "$allow_undefined"; then + echo + echo "*** Since this library must not contain undefined symbols," + echo "*** because either the platform does not support them or" + echo "*** it was explicitly requested with -no-undefined," + echo "*** libtool will only create a static version of it." + if test no = "$build_old_libs"; then + oldlibs=$output_objdir/$libname.$libext + build_libtool_libs=module + build_old_libs=yes + else + build_libtool_libs=no + fi + fi + fi + fi + # Done checking deplibs! + deplibs=$newdeplibs + fi + # Time to change all our "foo.ltframework" stuff back to "-framework foo" + case $host in + *-*-darwin*) + newdeplibs=`$ECHO " $newdeplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` + new_inherited_linker_flags=`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` + deplibs=`$ECHO " $deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` + ;; + esac + + # move library search paths that coincide with paths to not yet + # installed libraries to the beginning of the library search list + new_libs= + for path in $notinst_path; do + case " $new_libs " in + *" -L$path/$objdir "*) ;; + *) + case " $deplibs " in + *" -L$path/$objdir "*) + func_append new_libs " -L$path/$objdir" ;; + esac + ;; + esac + done + for deplib in $deplibs; do + case $deplib in + -L*) + case " $new_libs " in + *" $deplib "*) ;; + *) func_append new_libs " $deplib" ;; + esac + ;; + *) func_append new_libs " $deplib" ;; + esac + done + deplibs=$new_libs + + # All the library-specific variables (install_libdir is set above). + library_names= + old_library= + dlname= + + # Test again, we may have decided not to build it any more + if test yes = "$build_libtool_libs"; then + # Remove $wl instances when linking with ld. + # FIXME: should test the right _cmds variable. + case $archive_cmds in + *\$LD\ *) wl= ;; + esac + if test yes = "$hardcode_into_libs"; then + # Hardcode the library paths + hardcode_libdirs= + dep_rpath= + rpath=$finalize_rpath + test relink = "$opt_mode" || rpath=$compile_rpath$rpath + for libdir in $rpath; do + if test -n "$hardcode_libdir_flag_spec"; then + if test -n "$hardcode_libdir_separator"; then + func_replace_sysroot "$libdir" + libdir=$func_replace_sysroot_result + if test -z "$hardcode_libdirs"; then + hardcode_libdirs=$libdir + else + # Just accumulate the unique libdirs. + case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in + *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) + ;; + *) + func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" + ;; + esac + fi + else + eval flag=\"$hardcode_libdir_flag_spec\" + func_append dep_rpath " $flag" + fi + elif test -n "$runpath_var"; then + case "$perm_rpath " in + *" $libdir "*) ;; + *) func_append perm_rpath " $libdir" ;; + esac + fi + done + # Substitute the hardcoded libdirs into the rpath. + if test -n "$hardcode_libdir_separator" && + test -n "$hardcode_libdirs"; then + libdir=$hardcode_libdirs + eval "dep_rpath=\"$hardcode_libdir_flag_spec\"" + fi + if test -n "$runpath_var" && test -n "$perm_rpath"; then + # We should set the runpath_var. + rpath= + for dir in $perm_rpath; do + func_append rpath "$dir:" + done + eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var" + fi + test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs" + fi + + shlibpath=$finalize_shlibpath + test relink = "$opt_mode" || shlibpath=$compile_shlibpath$shlibpath + if test -n "$shlibpath"; then + eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var" + fi + + # Get the real and link names of the library. + eval shared_ext=\"$shrext_cmds\" + eval library_names=\"$library_names_spec\" + set dummy $library_names + shift + realname=$1 + shift + + if test -n "$soname_spec"; then + eval soname=\"$soname_spec\" + else + soname=$realname + fi + if test -z "$dlname"; then + dlname=$soname + fi + + lib=$output_objdir/$realname + linknames= + for link + do + func_append linknames " $link" + done + + # Use standard objects if they are pic + test -z "$pic_flag" && libobjs=`$ECHO "$libobjs" | $SP2NL | $SED "$lo2o" | $NL2SP` + test "X$libobjs" = "X " && libobjs= + + delfiles= + if test -n "$export_symbols" && test -n "$include_expsyms"; then + $opt_dry_run || cp "$export_symbols" "$output_objdir/$libname.uexp" + export_symbols=$output_objdir/$libname.uexp + func_append delfiles " $export_symbols" + fi + + orig_export_symbols= + case $host_os in + cygwin* | mingw* | cegcc*) + if test -n "$export_symbols" && test -z "$export_symbols_regex"; then + # exporting using user supplied symfile + func_dll_def_p "$export_symbols" || { + # and it's NOT already a .def file. Must figure out + # which of the given symbols are data symbols and tag + # them as such. So, trigger use of export_symbols_cmds. + # export_symbols gets reassigned inside the "prepare + # the list of exported symbols" if statement, so the + # include_expsyms logic still works. + orig_export_symbols=$export_symbols + export_symbols= + always_export_symbols=yes + } + fi + ;; + esac + + # Prepare the list of exported symbols + if test -z "$export_symbols"; then + if test yes = "$always_export_symbols" || test -n "$export_symbols_regex"; then + func_verbose "generating symbol list for '$libname.la'" + export_symbols=$output_objdir/$libname.exp + $opt_dry_run || $RM $export_symbols + cmds=$export_symbols_cmds + save_ifs=$IFS; IFS='~' + for cmd1 in $cmds; do + IFS=$save_ifs + # Take the normal branch if the nm_file_list_spec branch + # doesn't work or if tool conversion is not needed. + case $nm_file_list_spec~$to_tool_file_cmd in + *~func_convert_file_noop | *~func_convert_file_msys_to_w32 | ~*) + try_normal_branch=yes + eval cmd=\"$cmd1\" + func_len " $cmd" + len=$func_len_result + ;; + *) + try_normal_branch=no + ;; + esac + if test yes = "$try_normal_branch" \ + && { test "$len" -lt "$max_cmd_len" \ + || test "$max_cmd_len" -le -1; } + then + func_show_eval "$cmd" 'exit $?' + skipped_export=false + elif test -n "$nm_file_list_spec"; then + func_basename "$output" + output_la=$func_basename_result + save_libobjs=$libobjs + save_output=$output + output=$output_objdir/$output_la.nm + func_to_tool_file "$output" + libobjs=$nm_file_list_spec$func_to_tool_file_result + func_append delfiles " $output" + func_verbose "creating $NM input file list: $output" + for obj in $save_libobjs; do + func_to_tool_file "$obj" + $ECHO "$func_to_tool_file_result" + done > "$output" + eval cmd=\"$cmd1\" + func_show_eval "$cmd" 'exit $?' + output=$save_output + libobjs=$save_libobjs + skipped_export=false + else + # The command line is too long to execute in one step. + func_verbose "using reloadable object file for export list..." + skipped_export=: + # Break out early, otherwise skipped_export may be + # set to false by a later but shorter cmd. + break + fi + done + IFS=$save_ifs + if test -n "$export_symbols_regex" && test : != "$skipped_export"; then + func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' + func_show_eval '$MV "${export_symbols}T" "$export_symbols"' + fi + fi + fi + + if test -n "$export_symbols" && test -n "$include_expsyms"; then + tmp_export_symbols=$export_symbols + test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols + $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"' + fi + + if test : != "$skipped_export" && test -n "$orig_export_symbols"; then + # The given exports_symbols file has to be filtered, so filter it. + func_verbose "filter symbol list for '$libname.la' to tag DATA exports" + # FIXME: $output_objdir/$libname.filter potentially contains lots of + # 's' commands, which not all seds can handle. GNU sed should be fine + # though. Also, the filter scales superlinearly with the number of + # global variables. join(1) would be nice here, but unfortunately + # isn't a blessed tool. + $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter + func_append delfiles " $export_symbols $output_objdir/$libname.filter" + export_symbols=$output_objdir/$libname.def + $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols + fi + + tmp_deplibs= + for test_deplib in $deplibs; do + case " $convenience " in + *" $test_deplib "*) ;; + *) + func_append tmp_deplibs " $test_deplib" + ;; + esac + done + deplibs=$tmp_deplibs + + if test -n "$convenience"; then + if test -n "$whole_archive_flag_spec" && + test yes = "$compiler_needs_object" && + test -z "$libobjs"; then + # extract the archives, so we have objects to list. + # TODO: could optimize this to just extract one archive. + whole_archive_flag_spec= + fi + if test -n "$whole_archive_flag_spec"; then + save_libobjs=$libobjs + eval libobjs=\"\$libobjs $whole_archive_flag_spec\" + test "X$libobjs" = "X " && libobjs= + else + gentop=$output_objdir/${outputname}x + func_append generated " $gentop" + + func_extract_archives $gentop $convenience + func_append libobjs " $func_extract_archives_result" + test "X$libobjs" = "X " && libobjs= + fi + fi + + if test yes = "$thread_safe" && test -n "$thread_safe_flag_spec"; then + eval flag=\"$thread_safe_flag_spec\" + func_append linker_flags " $flag" + fi + + # Make a backup of the uninstalled library when relinking + if test relink = "$opt_mode"; then + $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}U && $MV $realname ${realname}U)' || exit $? + fi + + # Do each of the archive commands. + if test yes = "$module" && test -n "$module_cmds"; then + if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then + eval test_cmds=\"$module_expsym_cmds\" + cmds=$module_expsym_cmds + else + eval test_cmds=\"$module_cmds\" + cmds=$module_cmds + fi + else + if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then + eval test_cmds=\"$archive_expsym_cmds\" + cmds=$archive_expsym_cmds + else + eval test_cmds=\"$archive_cmds\" + cmds=$archive_cmds + fi + fi + + if test : != "$skipped_export" && + func_len " $test_cmds" && + len=$func_len_result && + test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then + : + else + # The command line is too long to link in one step, link piecewise + # or, if using GNU ld and skipped_export is not :, use a linker + # script. + + # Save the value of $output and $libobjs because we want to + # use them later. If we have whole_archive_flag_spec, we + # want to use save_libobjs as it was before + # whole_archive_flag_spec was expanded, because we can't + # assume the linker understands whole_archive_flag_spec. + # This may have to be revisited, in case too many + # convenience libraries get linked in and end up exceeding + # the spec. + if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then + save_libobjs=$libobjs + fi + save_output=$output + func_basename "$output" + output_la=$func_basename_result + + # Clear the reloadable object creation command queue and + # initialize k to one. + test_cmds= + concat_cmds= + objlist= + last_robj= + k=1 + + if test -n "$save_libobjs" && test : != "$skipped_export" && test yes = "$with_gnu_ld"; then + output=$output_objdir/$output_la.lnkscript + func_verbose "creating GNU ld script: $output" + echo 'INPUT (' > $output + for obj in $save_libobjs + do + func_to_tool_file "$obj" + $ECHO "$func_to_tool_file_result" >> $output + done + echo ')' >> $output + func_append delfiles " $output" + func_to_tool_file "$output" + output=$func_to_tool_file_result + elif test -n "$save_libobjs" && test : != "$skipped_export" && test -n "$file_list_spec"; then + output=$output_objdir/$output_la.lnk + func_verbose "creating linker input file list: $output" + : > $output + set x $save_libobjs + shift + firstobj= + if test yes = "$compiler_needs_object"; then + firstobj="$1 " + shift + fi + for obj + do + func_to_tool_file "$obj" + $ECHO "$func_to_tool_file_result" >> $output + done + func_append delfiles " $output" + func_to_tool_file "$output" + output=$firstobj\"$file_list_spec$func_to_tool_file_result\" + else + if test -n "$save_libobjs"; then + func_verbose "creating reloadable object files..." + output=$output_objdir/$output_la-$k.$objext + eval test_cmds=\"$reload_cmds\" + func_len " $test_cmds" + len0=$func_len_result + len=$len0 + + # Loop over the list of objects to be linked. + for obj in $save_libobjs + do + func_len " $obj" + func_arith $len + $func_len_result + len=$func_arith_result + if test -z "$objlist" || + test "$len" -lt "$max_cmd_len"; then + func_append objlist " $obj" + else + # The command $test_cmds is almost too long, add a + # command to the queue. + if test 1 -eq "$k"; then + # The first file doesn't have a previous command to add. + reload_objs=$objlist + eval concat_cmds=\"$reload_cmds\" + else + # All subsequent reloadable object files will link in + # the last one created. + reload_objs="$objlist $last_robj" + eval concat_cmds=\"\$concat_cmds~$reload_cmds~\$RM $last_robj\" + fi + last_robj=$output_objdir/$output_la-$k.$objext + func_arith $k + 1 + k=$func_arith_result + output=$output_objdir/$output_la-$k.$objext + objlist=" $obj" + func_len " $last_robj" + func_arith $len0 + $func_len_result + len=$func_arith_result + fi + done + # Handle the remaining objects by creating one last + # reloadable object file. All subsequent reloadable object + # files will link in the last one created. + test -z "$concat_cmds" || concat_cmds=$concat_cmds~ + reload_objs="$objlist $last_robj" + eval concat_cmds=\"\$concat_cmds$reload_cmds\" + if test -n "$last_robj"; then + eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\" + fi + func_append delfiles " $output" + + else + output= + fi + + ${skipped_export-false} && { + func_verbose "generating symbol list for '$libname.la'" + export_symbols=$output_objdir/$libname.exp + $opt_dry_run || $RM $export_symbols + libobjs=$output + # Append the command to create the export file. + test -z "$concat_cmds" || concat_cmds=$concat_cmds~ + eval concat_cmds=\"\$concat_cmds$export_symbols_cmds\" + if test -n "$last_robj"; then + eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\" + fi + } + + test -n "$save_libobjs" && + func_verbose "creating a temporary reloadable object file: $output" + + # Loop through the commands generated above and execute them. + save_ifs=$IFS; IFS='~' + for cmd in $concat_cmds; do + IFS=$save_ifs + $opt_quiet || { + func_quote_arg expand,pretty "$cmd" + eval "func_echo $func_quote_arg_result" + } + $opt_dry_run || eval "$cmd" || { + lt_exit=$? + + # Restore the uninstalled library and exit + if test relink = "$opt_mode"; then + ( cd "$output_objdir" && \ + $RM "${realname}T" && \ + $MV "${realname}U" "$realname" ) + fi + + exit $lt_exit + } + done + IFS=$save_ifs + + if test -n "$export_symbols_regex" && ${skipped_export-false}; then + func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' + func_show_eval '$MV "${export_symbols}T" "$export_symbols"' + fi + fi + + ${skipped_export-false} && { + if test -n "$export_symbols" && test -n "$include_expsyms"; then + tmp_export_symbols=$export_symbols + test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols + $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"' + fi + + if test -n "$orig_export_symbols"; then + # The given exports_symbols file has to be filtered, so filter it. + func_verbose "filter symbol list for '$libname.la' to tag DATA exports" + # FIXME: $output_objdir/$libname.filter potentially contains lots of + # 's' commands, which not all seds can handle. GNU sed should be fine + # though. Also, the filter scales superlinearly with the number of + # global variables. join(1) would be nice here, but unfortunately + # isn't a blessed tool. + $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter + func_append delfiles " $export_symbols $output_objdir/$libname.filter" + export_symbols=$output_objdir/$libname.def + $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols + fi + } + + libobjs=$output + # Restore the value of output. + output=$save_output + + if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then + eval libobjs=\"\$libobjs $whole_archive_flag_spec\" + test "X$libobjs" = "X " && libobjs= + fi + # Expand the library linking commands again to reset the + # value of $libobjs for piecewise linking. + + # Do each of the archive commands. + if test yes = "$module" && test -n "$module_cmds"; then + if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then + cmds=$module_expsym_cmds + else + cmds=$module_cmds + fi + else + if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then + cmds=$archive_expsym_cmds + else + cmds=$archive_cmds + fi + fi + fi + + if test -n "$delfiles"; then + # Append the command to remove temporary files to $cmds. + eval cmds=\"\$cmds~\$RM $delfiles\" + fi + + # Add any objects from preloaded convenience libraries + if test -n "$dlprefiles"; then + gentop=$output_objdir/${outputname}x + func_append generated " $gentop" + + func_extract_archives $gentop $dlprefiles + func_append libobjs " $func_extract_archives_result" + test "X$libobjs" = "X " && libobjs= + fi + + save_ifs=$IFS; IFS='~' + for cmd in $cmds; do + IFS=$sp$nl + eval cmd=\"$cmd\" + IFS=$save_ifs + $opt_quiet || { + func_quote_arg expand,pretty "$cmd" + eval "func_echo $func_quote_arg_result" + } + $opt_dry_run || eval "$cmd" || { + lt_exit=$? + + # Restore the uninstalled library and exit + if test relink = "$opt_mode"; then + ( cd "$output_objdir" && \ + $RM "${realname}T" && \ + $MV "${realname}U" "$realname" ) + fi + + exit $lt_exit + } + done + IFS=$save_ifs + + # Restore the uninstalled library and exit + if test relink = "$opt_mode"; then + $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}T && $MV $realname ${realname}T && $MV ${realname}U $realname)' || exit $? + + if test -n "$convenience"; then + if test -z "$whole_archive_flag_spec"; then + func_show_eval '${RM}r "$gentop"' + fi + fi + + exit $EXIT_SUCCESS + fi + + # Create links to the real library. + for linkname in $linknames; do + if test "$realname" != "$linkname"; then + func_show_eval '(cd "$output_objdir" && $RM "$linkname" && $LN_S "$realname" "$linkname")' 'exit $?' + fi + done + + # If -module or -export-dynamic was specified, set the dlname. + if test yes = "$module" || test yes = "$export_dynamic"; then + # On all known operating systems, these are identical. + dlname=$soname + fi + fi + ;; + + obj) + if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then + func_warning "'-dlopen' is ignored for objects" + fi + + case " $deplibs" in + *\ -l* | *\ -L*) + func_warning "'-l' and '-L' are ignored for objects" ;; + esac + + test -n "$rpath" && \ + func_warning "'-rpath' is ignored for objects" + + test -n "$xrpath" && \ + func_warning "'-R' is ignored for objects" + + test -n "$vinfo" && \ + func_warning "'-version-info' is ignored for objects" + + test -n "$release" && \ + func_warning "'-release' is ignored for objects" + + case $output in + *.lo) + test -n "$objs$old_deplibs" && \ + func_fatal_error "cannot build library object '$output' from non-libtool objects" + + libobj=$output + func_lo2o "$libobj" + obj=$func_lo2o_result + ;; + *) + libobj= + obj=$output + ;; + esac + + # Delete the old objects. + $opt_dry_run || $RM $obj $libobj + + # Objects from convenience libraries. This assumes + # single-version convenience libraries. Whenever we create + # different ones for PIC/non-PIC, this we'll have to duplicate + # the extraction. + reload_conv_objs= + gentop= + # if reload_cmds runs $LD directly, get rid of -Wl from + # whole_archive_flag_spec and hope we can get by with turning comma + # into space. + case $reload_cmds in + *\$LD[\ \$]*) wl= ;; + esac + if test -n "$convenience"; then + if test -n "$whole_archive_flag_spec"; then + eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\" + test -n "$wl" || tmp_whole_archive_flags=`$ECHO "$tmp_whole_archive_flags" | $SED 's|,| |g'` + reload_conv_objs=$reload_objs\ $tmp_whole_archive_flags + else + gentop=$output_objdir/${obj}x + func_append generated " $gentop" + + func_extract_archives $gentop $convenience + reload_conv_objs="$reload_objs $func_extract_archives_result" + fi + fi + + # If we're not building shared, we need to use non_pic_objs + test yes = "$build_libtool_libs" || libobjs=$non_pic_objects + + # Create the old-style object. + reload_objs=$objs$old_deplibs' '`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; /\.lib$/d; $lo2o" | $NL2SP`' '$reload_conv_objs + + output=$obj + func_execute_cmds "$reload_cmds" 'exit $?' + + # Exit if we aren't doing a library object file. + if test -z "$libobj"; then + if test -n "$gentop"; then + func_show_eval '${RM}r "$gentop"' + fi + + exit $EXIT_SUCCESS + fi + + test yes = "$build_libtool_libs" || { + if test -n "$gentop"; then + func_show_eval '${RM}r "$gentop"' + fi + + # Create an invalid libtool object if no PIC, so that we don't + # accidentally link it into a program. + # $show "echo timestamp > $libobj" + # $opt_dry_run || eval "echo timestamp > $libobj" || exit $? + exit $EXIT_SUCCESS + } + + if test -n "$pic_flag" || test default != "$pic_mode"; then + # Only do commands if we really have different PIC objects. + reload_objs="$libobjs $reload_conv_objs" + output=$libobj + func_execute_cmds "$reload_cmds" 'exit $?' + fi + + if test -n "$gentop"; then + func_show_eval '${RM}r "$gentop"' + fi + + exit $EXIT_SUCCESS + ;; + + prog) + case $host in + *cygwin*) func_stripname '' '.exe' "$output" + output=$func_stripname_result.exe;; + esac + test -n "$vinfo" && \ + func_warning "'-version-info' is ignored for programs" + + test -n "$release" && \ + func_warning "'-release' is ignored for programs" + + $preload \ + && test unknown,unknown,unknown = "$dlopen_support,$dlopen_self,$dlopen_self_static" \ + && func_warning "'LT_INIT([dlopen])' not used. Assuming no dlopen support." + + case $host in + *-*-rhapsody* | *-*-darwin1.[012]) + # On Rhapsody replace the C library is the System framework + compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's/ -lc / System.ltframework /'` + finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's/ -lc / System.ltframework /'` + ;; + esac + + case $host in + *-*-darwin*) + # Don't allow lazy linking, it breaks C++ global constructors + # But is supposedly fixed on 10.4 or later (yay!). + if test CXX = "$tagname"; then + case ${MACOSX_DEPLOYMENT_TARGET-10.0} in + 10.[0123]) + func_append compile_command " $wl-bind_at_load" + func_append finalize_command " $wl-bind_at_load" + ;; + esac + fi + # Time to change all our "foo.ltframework" stuff back to "-framework foo" + compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` + finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` + ;; + esac + + + # move library search paths that coincide with paths to not yet + # installed libraries to the beginning of the library search list + new_libs= + for path in $notinst_path; do + case " $new_libs " in + *" -L$path/$objdir "*) ;; + *) + case " $compile_deplibs " in + *" -L$path/$objdir "*) + func_append new_libs " -L$path/$objdir" ;; + esac + ;; + esac + done + for deplib in $compile_deplibs; do + case $deplib in + -L*) + case " $new_libs " in + *" $deplib "*) ;; + *) func_append new_libs " $deplib" ;; + esac + ;; + *) func_append new_libs " $deplib" ;; + esac + done + compile_deplibs=$new_libs + + + func_append compile_command " $compile_deplibs" + func_append finalize_command " $finalize_deplibs" + + if test -n "$rpath$xrpath"; then + # If the user specified any rpath flags, then add them. + for libdir in $rpath $xrpath; do + # This is the magic to use -rpath. + case "$finalize_rpath " in + *" $libdir "*) ;; + *) func_append finalize_rpath " $libdir" ;; + esac + done + fi + + # Now hardcode the library paths + rpath= + hardcode_libdirs= + for libdir in $compile_rpath $finalize_rpath; do + if test -n "$hardcode_libdir_flag_spec"; then + if test -n "$hardcode_libdir_separator"; then + if test -z "$hardcode_libdirs"; then + hardcode_libdirs=$libdir + else + # Just accumulate the unique libdirs. + case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in + *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) + ;; + *) + func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" + ;; + esac + fi + else + eval flag=\"$hardcode_libdir_flag_spec\" + func_append rpath " $flag" + fi + elif test -n "$runpath_var"; then + case "$perm_rpath " in + *" $libdir "*) ;; + *) func_append perm_rpath " $libdir" ;; + esac + fi + case $host in + *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) + testbindir=`$ECHO "$libdir" | $SED -e 's*/lib$*/bin*'` + case :$dllsearchpath: in + *":$libdir:"*) ;; + ::) dllsearchpath=$libdir;; + *) func_append dllsearchpath ":$libdir";; + esac + case :$dllsearchpath: in + *":$testbindir:"*) ;; + ::) dllsearchpath=$testbindir;; + *) func_append dllsearchpath ":$testbindir";; + esac + ;; + esac + done + # Substitute the hardcoded libdirs into the rpath. + if test -n "$hardcode_libdir_separator" && + test -n "$hardcode_libdirs"; then + libdir=$hardcode_libdirs + eval rpath=\" $hardcode_libdir_flag_spec\" + fi + compile_rpath=$rpath + + rpath= + hardcode_libdirs= + for libdir in $finalize_rpath; do + if test -n "$hardcode_libdir_flag_spec"; then + if test -n "$hardcode_libdir_separator"; then + if test -z "$hardcode_libdirs"; then + hardcode_libdirs=$libdir + else + # Just accumulate the unique libdirs. + case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in + *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) + ;; + *) + func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" + ;; + esac + fi + else + eval flag=\"$hardcode_libdir_flag_spec\" + func_append rpath " $flag" + fi + elif test -n "$runpath_var"; then + case "$finalize_perm_rpath " in + *" $libdir "*) ;; + *) func_append finalize_perm_rpath " $libdir" ;; + esac + fi + done + # Substitute the hardcoded libdirs into the rpath. + if test -n "$hardcode_libdir_separator" && + test -n "$hardcode_libdirs"; then + libdir=$hardcode_libdirs + eval rpath=\" $hardcode_libdir_flag_spec\" + fi + finalize_rpath=$rpath + + if test -n "$libobjs" && test yes = "$build_old_libs"; then + # Transform all the library objects into standard objects. + compile_command=`$ECHO "$compile_command" | $SP2NL | $SED "$lo2o" | $NL2SP` + finalize_command=`$ECHO "$finalize_command" | $SP2NL | $SED "$lo2o" | $NL2SP` + fi + + func_generate_dlsyms "$outputname" "@PROGRAM@" false + + # template prelinking step + if test -n "$prelink_cmds"; then + func_execute_cmds "$prelink_cmds" 'exit $?' + fi + + wrappers_required=: + case $host in + *cegcc* | *mingw32ce*) + # Disable wrappers for cegcc and mingw32ce hosts, we are cross compiling anyway. + wrappers_required=false + ;; + *cygwin* | *mingw* ) + test yes = "$build_libtool_libs" || wrappers_required=false + ;; + *) + if test no = "$need_relink" || test yes != "$build_libtool_libs"; then + wrappers_required=false + fi + ;; + esac + $wrappers_required || { + # Replace the output file specification. + compile_command=`$ECHO "$compile_command" | $SED 's%@OUTPUT@%'"$output"'%g'` + link_command=$compile_command$compile_rpath + + # We have no uninstalled library dependencies, so finalize right now. + exit_status=0 + func_show_eval "$link_command" 'exit_status=$?' + + if test -n "$postlink_cmds"; then + func_to_tool_file "$output" + postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` + func_execute_cmds "$postlink_cmds" 'exit $?' + fi + + # Delete the generated files. + if test -f "$output_objdir/${outputname}S.$objext"; then + func_show_eval '$RM "$output_objdir/${outputname}S.$objext"' + fi + + exit $exit_status + } + + if test -n "$compile_shlibpath$finalize_shlibpath"; then + compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command" + fi + if test -n "$finalize_shlibpath"; then + finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command" + fi + + compile_var= + finalize_var= + if test -n "$runpath_var"; then + if test -n "$perm_rpath"; then + # We should set the runpath_var. + rpath= + for dir in $perm_rpath; do + func_append rpath "$dir:" + done + compile_var="$runpath_var=\"$rpath\$$runpath_var\" " + fi + if test -n "$finalize_perm_rpath"; then + # We should set the runpath_var. + rpath= + for dir in $finalize_perm_rpath; do + func_append rpath "$dir:" + done + finalize_var="$runpath_var=\"$rpath\$$runpath_var\" " + fi + fi + + if test yes = "$no_install"; then + # We don't need to create a wrapper script. + link_command=$compile_var$compile_command$compile_rpath + # Replace the output file specification. + link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output"'%g'` + # Delete the old output file. + $opt_dry_run || $RM $output + # Link the executable and exit + func_show_eval "$link_command" 'exit $?' + + if test -n "$postlink_cmds"; then + func_to_tool_file "$output" + postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` + func_execute_cmds "$postlink_cmds" 'exit $?' + fi + + exit $EXIT_SUCCESS + fi + + case $hardcode_action,$fast_install in + relink,*) + # Fast installation is not supported + link_command=$compile_var$compile_command$compile_rpath + relink_command=$finalize_var$finalize_command$finalize_rpath + + func_warning "this platform does not like uninstalled shared libraries" + func_warning "'$output' will be relinked during installation" + ;; + *,yes) + link_command=$finalize_var$compile_command$finalize_rpath + relink_command=`$ECHO "$compile_var$compile_command$compile_rpath" | $SED 's%@OUTPUT@%\$progdir/\$file%g'` + ;; + *,no) + link_command=$compile_var$compile_command$compile_rpath + relink_command=$finalize_var$finalize_command$finalize_rpath + ;; + *,needless) + link_command=$finalize_var$compile_command$finalize_rpath + relink_command= + ;; + esac + + # Replace the output file specification. + link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'` + + # Delete the old output files. + $opt_dry_run || $RM $output $output_objdir/$outputname $output_objdir/lt-$outputname + + func_show_eval "$link_command" 'exit $?' + + if test -n "$postlink_cmds"; then + func_to_tool_file "$output_objdir/$outputname" + postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` + func_execute_cmds "$postlink_cmds" 'exit $?' + fi + + # Now create the wrapper script. + func_verbose "creating $output" + + # Quote the relink command for shipping. + if test -n "$relink_command"; then + # Preserve any variables that may affect compiler behavior + for var in $variables_saved_for_relink; do + if eval test -z \"\${$var+set}\"; then + relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" + elif eval var_value=\$$var; test -z "$var_value"; then + relink_command="$var=; export $var; $relink_command" + else + func_quote_arg pretty "$var_value" + relink_command="$var=$func_quote_arg_result; export $var; $relink_command" + fi + done + func_quote eval cd "`pwd`" + func_quote_arg pretty,unquoted "($func_quote_result; $relink_command)" + relink_command=$func_quote_arg_unquoted_result + fi + + # Only actually do things if not in dry run mode. + $opt_dry_run || { + # win32 will think the script is a binary if it has + # a .exe suffix, so we strip it off here. + case $output in + *.exe) func_stripname '' '.exe' "$output" + output=$func_stripname_result ;; + esac + # test for cygwin because mv fails w/o .exe extensions + case $host in + *cygwin*) + exeext=.exe + func_stripname '' '.exe' "$outputname" + outputname=$func_stripname_result ;; + *) exeext= ;; + esac + case $host in + *cygwin* | *mingw* ) + func_dirname_and_basename "$output" "" "." + output_name=$func_basename_result + output_path=$func_dirname_result + cwrappersource=$output_path/$objdir/lt-$output_name.c + cwrapper=$output_path/$output_name.exe + $RM $cwrappersource $cwrapper + trap "$RM $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15 + + func_emit_cwrapperexe_src > $cwrappersource + + # The wrapper executable is built using the $host compiler, + # because it contains $host paths and files. If cross- + # compiling, it, like the target executable, must be + # executed on the $host or under an emulation environment. + $opt_dry_run || { + $LTCC $LTCFLAGS -o $cwrapper $cwrappersource + $STRIP $cwrapper + } + + # Now, create the wrapper script for func_source use: + func_ltwrapper_scriptname $cwrapper + $RM $func_ltwrapper_scriptname_result + trap "$RM $func_ltwrapper_scriptname_result; exit $EXIT_FAILURE" 1 2 15 + $opt_dry_run || { + # note: this script will not be executed, so do not chmod. + if test "x$build" = "x$host"; then + $cwrapper --lt-dump-script > $func_ltwrapper_scriptname_result + else + func_emit_wrapper no > $func_ltwrapper_scriptname_result + fi + } + ;; + * ) + $RM $output + trap "$RM $output; exit $EXIT_FAILURE" 1 2 15 + + func_emit_wrapper no > $output + chmod +x $output + ;; + esac + } + exit $EXIT_SUCCESS + ;; + esac + + # See if we need to build an old-fashioned archive. + for oldlib in $oldlibs; do + + case $build_libtool_libs in + convenience) + oldobjs="$libobjs_save $symfileobj" + addlibs=$convenience + build_libtool_libs=no + ;; + module) + oldobjs=$libobjs_save + addlibs=$old_convenience + build_libtool_libs=no + ;; + *) + oldobjs="$old_deplibs $non_pic_objects" + $preload && test -f "$symfileobj" \ + && func_append oldobjs " $symfileobj" + addlibs=$old_convenience + ;; + esac + + if test -n "$addlibs"; then + gentop=$output_objdir/${outputname}x + func_append generated " $gentop" + + func_extract_archives $gentop $addlibs + func_append oldobjs " $func_extract_archives_result" + fi + + # Do each command in the archive commands. + if test -n "$old_archive_from_new_cmds" && test yes = "$build_libtool_libs"; then + cmds=$old_archive_from_new_cmds + else + + # Add any objects from preloaded convenience libraries + if test -n "$dlprefiles"; then + gentop=$output_objdir/${outputname}x + func_append generated " $gentop" + + func_extract_archives $gentop $dlprefiles + func_append oldobjs " $func_extract_archives_result" + fi + + # POSIX demands no paths to be encoded in archives. We have + # to avoid creating archives with duplicate basenames if we + # might have to extract them afterwards, e.g., when creating a + # static archive out of a convenience library, or when linking + # the entirety of a libtool archive into another (currently + # not supported by libtool). + if (for obj in $oldobjs + do + func_basename "$obj" + $ECHO "$func_basename_result" + done | sort | sort -uc >/dev/null 2>&1); then + : + else + echo "copying selected object files to avoid basename conflicts..." + gentop=$output_objdir/${outputname}x + func_append generated " $gentop" + func_mkdir_p "$gentop" + save_oldobjs=$oldobjs + oldobjs= + counter=1 + for obj in $save_oldobjs + do + func_basename "$obj" + objbase=$func_basename_result + case " $oldobjs " in + " ") oldobjs=$obj ;; + *[\ /]"$objbase "*) + while :; do + # Make sure we don't pick an alternate name that also + # overlaps. + newobj=lt$counter-$objbase + func_arith $counter + 1 + counter=$func_arith_result + case " $oldobjs " in + *[\ /]"$newobj "*) ;; + *) if test ! -f "$gentop/$newobj"; then break; fi ;; + esac + done + func_show_eval "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj" + func_append oldobjs " $gentop/$newobj" + ;; + *) func_append oldobjs " $obj" ;; + esac + done + fi + func_to_tool_file "$oldlib" func_convert_file_msys_to_w32 + tool_oldlib=$func_to_tool_file_result + eval cmds=\"$old_archive_cmds\" + + func_len " $cmds" + len=$func_len_result + if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then + cmds=$old_archive_cmds + elif test -n "$archiver_list_spec"; then + func_verbose "using command file archive linking..." + for obj in $oldobjs + do + func_to_tool_file "$obj" + $ECHO "$func_to_tool_file_result" + done > $output_objdir/$libname.libcmd + func_to_tool_file "$output_objdir/$libname.libcmd" + oldobjs=" $archiver_list_spec$func_to_tool_file_result" + cmds=$old_archive_cmds + else + # the command line is too long to link in one step, link in parts + func_verbose "using piecewise archive linking..." + save_RANLIB=$RANLIB + RANLIB=: + objlist= + concat_cmds= + save_oldobjs=$oldobjs + oldobjs= + # Is there a better way of finding the last object in the list? + for obj in $save_oldobjs + do + last_oldobj=$obj + done + eval test_cmds=\"$old_archive_cmds\" + func_len " $test_cmds" + len0=$func_len_result + len=$len0 + for obj in $save_oldobjs + do + func_len " $obj" + func_arith $len + $func_len_result + len=$func_arith_result + func_append objlist " $obj" + if test "$len" -lt "$max_cmd_len"; then + : + else + # the above command should be used before it gets too long + oldobjs=$objlist + if test "$obj" = "$last_oldobj"; then + RANLIB=$save_RANLIB + fi + test -z "$concat_cmds" || concat_cmds=$concat_cmds~ + eval concat_cmds=\"\$concat_cmds$old_archive_cmds\" + objlist= + len=$len0 + fi + done + RANLIB=$save_RANLIB + oldobjs=$objlist + if test -z "$oldobjs"; then + eval cmds=\"\$concat_cmds\" + else + eval cmds=\"\$concat_cmds~\$old_archive_cmds\" + fi + fi + fi + func_execute_cmds "$cmds" 'exit $?' + done + + test -n "$generated" && \ + func_show_eval "${RM}r$generated" + + # Now create the libtool archive. + case $output in + *.la) + old_library= + test yes = "$build_old_libs" && old_library=$libname.$libext + func_verbose "creating $output" + + # Preserve any variables that may affect compiler behavior + for var in $variables_saved_for_relink; do + if eval test -z \"\${$var+set}\"; then + relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" + elif eval var_value=\$$var; test -z "$var_value"; then + relink_command="$var=; export $var; $relink_command" + else + func_quote_arg pretty,unquoted "$var_value" + relink_command="$var=$func_quote_arg_unquoted_result; export $var; $relink_command" + fi + done + # Quote the link command for shipping. + func_quote eval cd "`pwd`" + relink_command="($func_quote_result; $SHELL \"$progpath\" $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)" + func_quote_arg pretty,unquoted "$relink_command" + relink_command=$func_quote_arg_unquoted_result + if test yes = "$hardcode_automatic"; then + relink_command= + fi + + # Only create the output if not a dry run. + $opt_dry_run || { + for installed in no yes; do + if test yes = "$installed"; then + if test -z "$install_libdir"; then + break + fi + output=$output_objdir/${outputname}i + # Replace all uninstalled libtool libraries with the installed ones + newdependency_libs= + for deplib in $dependency_libs; do + case $deplib in + *.la) + func_basename "$deplib" + name=$func_basename_result + func_resolve_sysroot "$deplib" + eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $func_resolve_sysroot_result` + test -z "$libdir" && \ + func_fatal_error "'$deplib' is not a valid libtool archive" + func_append newdependency_libs " ${lt_sysroot:+=}$libdir/$name" + ;; + -L*) + func_stripname -L '' "$deplib" + func_replace_sysroot "$func_stripname_result" + func_append newdependency_libs " -L$func_replace_sysroot_result" + ;; + -R*) + func_stripname -R '' "$deplib" + func_replace_sysroot "$func_stripname_result" + func_append newdependency_libs " -R$func_replace_sysroot_result" + ;; + *) func_append newdependency_libs " $deplib" ;; + esac + done + dependency_libs=$newdependency_libs + newdlfiles= + + for lib in $dlfiles; do + case $lib in + *.la) + func_basename "$lib" + name=$func_basename_result + eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib` + test -z "$libdir" && \ + func_fatal_error "'$lib' is not a valid libtool archive" + func_append newdlfiles " ${lt_sysroot:+=}$libdir/$name" + ;; + *) func_append newdlfiles " $lib" ;; + esac + done + dlfiles=$newdlfiles + newdlprefiles= + for lib in $dlprefiles; do + case $lib in + *.la) + # Only pass preopened files to the pseudo-archive (for + # eventual linking with the app. that links it) if we + # didn't already link the preopened objects directly into + # the library: + func_basename "$lib" + name=$func_basename_result + eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib` + test -z "$libdir" && \ + func_fatal_error "'$lib' is not a valid libtool archive" + func_append newdlprefiles " ${lt_sysroot:+=}$libdir/$name" + ;; + esac + done + dlprefiles=$newdlprefiles + else + newdlfiles= + for lib in $dlfiles; do + case $lib in + [\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;; + *) abs=`pwd`"/$lib" ;; + esac + func_append newdlfiles " $abs" + done + dlfiles=$newdlfiles + newdlprefiles= + for lib in $dlprefiles; do + case $lib in + [\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;; + *) abs=`pwd`"/$lib" ;; + esac + func_append newdlprefiles " $abs" + done + dlprefiles=$newdlprefiles + fi + $RM $output + # place dlname in correct position for cygwin + # In fact, it would be nice if we could use this code for all target + # systems that can't hard-code library paths into their executables + # and that have no shared library path variable independent of PATH, + # but it turns out we can't easily determine that from inspecting + # libtool variables, so we have to hard-code the OSs to which it + # applies here; at the moment, that means platforms that use the PE + # object format with DLL files. See the long comment at the top of + # tests/bindir.at for full details. + tdlname=$dlname + case $host,$output,$installed,$module,$dlname in + *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll) + # If a -bindir argument was supplied, place the dll there. + if test -n "$bindir"; then + func_relative_path "$install_libdir" "$bindir" + tdlname=$func_relative_path_result/$dlname + else + # Otherwise fall back on heuristic. + tdlname=../bin/$dlname + fi + ;; + esac + $ECHO > $output "\ +# $outputname - a libtool library file +# Generated by $PROGRAM (GNU $PACKAGE) $VERSION +# +# Please DO NOT delete this file! +# It is necessary for linking the library. + +# The name that we can dlopen(3). +dlname='$tdlname' + +# Names of this library. +library_names='$library_names' + +# The name of the static archive. +old_library='$old_library' + +# Linker flags that cannot go in dependency_libs. +inherited_linker_flags='$new_inherited_linker_flags' + +# Libraries that this one depends upon. +dependency_libs='$dependency_libs' + +# Names of additional weak libraries provided by this library +weak_library_names='$weak_libs' + +# Version information for $libname. +current=$current +age=$age +revision=$revision + +# Is this an already installed library? +installed=$installed + +# Should we warn about portability when linking against -modules? +shouldnotlink=$module + +# Files to dlopen/dlpreopen +dlopen='$dlfiles' +dlpreopen='$dlprefiles' + +# Directory that this library needs to be installed in: +libdir='$install_libdir'" + if test no,yes = "$installed,$need_relink"; then + $ECHO >> $output "\ +relink_command=\"$relink_command\"" + fi + done + } + + # Do a symbolic link so that the libtool archive can be found in + # LD_LIBRARY_PATH before the program is installed. + func_show_eval '( cd "$output_objdir" && $RM "$outputname" && $LN_S "../$outputname" "$outputname" )' 'exit $?' + ;; + esac + exit $EXIT_SUCCESS +} + +if test link = "$opt_mode" || test relink = "$opt_mode"; then + func_mode_link ${1+"$@"} +fi + + +# func_mode_uninstall arg... +func_mode_uninstall () +{ + $debug_cmd + + RM=$nonopt + files= + rmforce=false + exit_status=0 + + # This variable tells wrapper scripts just to set variables rather + # than running their programs. + libtool_install_magic=$magic + + for arg + do + case $arg in + -f) func_append RM " $arg"; rmforce=: ;; + -*) func_append RM " $arg" ;; + *) func_append files " $arg" ;; + esac + done + + test -z "$RM" && \ + func_fatal_help "you must specify an RM program" + + rmdirs= + + for file in $files; do + func_dirname "$file" "" "." + dir=$func_dirname_result + if test . = "$dir"; then + odir=$objdir + else + odir=$dir/$objdir + fi + func_basename "$file" + name=$func_basename_result + test uninstall = "$opt_mode" && odir=$dir + + # Remember odir for removal later, being careful to avoid duplicates + if test clean = "$opt_mode"; then + case " $rmdirs " in + *" $odir "*) ;; + *) func_append rmdirs " $odir" ;; + esac + fi + + # Don't error if the file doesn't exist and rm -f was used. + if { test -L "$file"; } >/dev/null 2>&1 || + { test -h "$file"; } >/dev/null 2>&1 || + test -f "$file"; then + : + elif test -d "$file"; then + exit_status=1 + continue + elif $rmforce; then + continue + fi + + rmfiles=$file + + case $name in + *.la) + # Possibly a libtool archive, so verify it. + if func_lalib_p "$file"; then + func_source $dir/$name + + # Delete the libtool libraries and symlinks. + for n in $library_names; do + func_append rmfiles " $odir/$n" + done + test -n "$old_library" && func_append rmfiles " $odir/$old_library" + + case $opt_mode in + clean) + case " $library_names " in + *" $dlname "*) ;; + *) test -n "$dlname" && func_append rmfiles " $odir/$dlname" ;; + esac + test -n "$libdir" && func_append rmfiles " $odir/$name $odir/${name}i" + ;; + uninstall) + if test -n "$library_names"; then + # Do each command in the postuninstall commands. + func_execute_cmds "$postuninstall_cmds" '$rmforce || exit_status=1' + fi + + if test -n "$old_library"; then + # Do each command in the old_postuninstall commands. + func_execute_cmds "$old_postuninstall_cmds" '$rmforce || exit_status=1' + fi + # FIXME: should reinstall the best remaining shared library. + ;; + esac + fi + ;; + + *.lo) + # Possibly a libtool object, so verify it. + if func_lalib_p "$file"; then + + # Read the .lo file + func_source $dir/$name + + # Add PIC object to the list of files to remove. + if test -n "$pic_object" && test none != "$pic_object"; then + func_append rmfiles " $dir/$pic_object" + fi + + # Add non-PIC object to the list of files to remove. + if test -n "$non_pic_object" && test none != "$non_pic_object"; then + func_append rmfiles " $dir/$non_pic_object" + fi + fi + ;; + + *) + if test clean = "$opt_mode"; then + noexename=$name + case $file in + *.exe) + func_stripname '' '.exe' "$file" + file=$func_stripname_result + func_stripname '' '.exe' "$name" + noexename=$func_stripname_result + # $file with .exe has already been added to rmfiles, + # add $file without .exe + func_append rmfiles " $file" + ;; + esac + # Do a test to see if this is a libtool program. + if func_ltwrapper_p "$file"; then + if func_ltwrapper_executable_p "$file"; then + func_ltwrapper_scriptname "$file" + relink_command= + func_source $func_ltwrapper_scriptname_result + func_append rmfiles " $func_ltwrapper_scriptname_result" + else + relink_command= + func_source $dir/$noexename + fi + + # note $name still contains .exe if it was in $file originally + # as does the version of $file that was added into $rmfiles + func_append rmfiles " $odir/$name $odir/${name}S.$objext" + if test yes = "$fast_install" && test -n "$relink_command"; then + func_append rmfiles " $odir/lt-$name" + fi + if test "X$noexename" != "X$name"; then + func_append rmfiles " $odir/lt-$noexename.c" + fi + fi + fi + ;; + esac + func_show_eval "$RM $rmfiles" 'exit_status=1' + done + + # Try to remove the $objdir's in the directories where we deleted files + for dir in $rmdirs; do + if test -d "$dir"; then + func_show_eval "rmdir $dir >/dev/null 2>&1" + fi + done + + exit $exit_status +} + +if test uninstall = "$opt_mode" || test clean = "$opt_mode"; then + func_mode_uninstall ${1+"$@"} +fi + +test -z "$opt_mode" && { + help=$generic_help + func_fatal_help "you must specify a MODE" +} + +test -z "$exec_cmd" && \ + func_fatal_help "invalid operation mode '$opt_mode'" + +if test -n "$exec_cmd"; then + eval exec "$exec_cmd" + exit $EXIT_FAILURE +fi + +exit $exit_status + + +# The TAGs below are defined such that we never get into a situation +# where we disable both kinds of libraries. Given conflicting +# choices, we go for a static library, that is the most portable, +# since we can't tell whether shared libraries were disabled because +# the user asked for that or because the platform doesn't support +# them. This is particularly important on AIX, because we don't +# support having both static and shared libraries enabled at the same +# time on that platform, so we default to a shared-only configuration. +# If a disable-shared tag is given, we'll fallback to a static-only +# configuration. But we'll never go from static-only to shared-only. + +# ### BEGIN LIBTOOL TAG CONFIG: disable-shared +build_libtool_libs=no +build_old_libs=yes +# ### END LIBTOOL TAG CONFIG: disable-shared + +# ### BEGIN LIBTOOL TAG CONFIG: disable-static +build_old_libs=`case $build_libtool_libs in yes) echo no;; *) echo yes;; esac` +# ### END LIBTOOL TAG CONFIG: disable-static + +# Local Variables: +# mode:shell-script +# sh-indentation:2 +# End: diff --git a/TMessagesProj/jni/libtgvoip2/missing b/TMessagesProj/jni/libtgvoip2/missing new file mode 100644 index 000000000..625aeb118 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/missing @@ -0,0 +1,215 @@ +#! /bin/sh +# Common wrapper for a few potentially missing GNU programs. + +scriptversion=2018-03-07.03; # UTC + +# Copyright (C) 1996-2018 Free Software Foundation, Inc. +# Originally written by Fran,cois Pinard , 1996. + +# This program 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 2, or (at your option) +# any later version. + +# This program 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 this program. If not, see . + +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + +if test $# -eq 0; then + echo 1>&2 "Try '$0 --help' for more information" + exit 1 +fi + +case $1 in + + --is-lightweight) + # Used by our autoconf macros to check whether the available missing + # script is modern enough. + exit 0 + ;; + + --run) + # Back-compat with the calling convention used by older automake. + shift + ;; + + -h|--h|--he|--hel|--help) + echo "\ +$0 [OPTION]... PROGRAM [ARGUMENT]... + +Run 'PROGRAM [ARGUMENT]...', returning a proper advice when this fails due +to PROGRAM being missing or too old. + +Options: + -h, --help display this help and exit + -v, --version output version information and exit + +Supported PROGRAM values: + aclocal autoconf autoheader autom4te automake makeinfo + bison yacc flex lex help2man + +Version suffixes to PROGRAM as well as the prefixes 'gnu-', 'gnu', and +'g' are ignored when checking the name. + +Send bug reports to ." + exit $? + ;; + + -v|--v|--ve|--ver|--vers|--versi|--versio|--version) + echo "missing $scriptversion (GNU Automake)" + exit $? + ;; + + -*) + echo 1>&2 "$0: unknown '$1' option" + echo 1>&2 "Try '$0 --help' for more information" + exit 1 + ;; + +esac + +# Run the given program, remember its exit status. +"$@"; st=$? + +# If it succeeded, we are done. +test $st -eq 0 && exit 0 + +# Also exit now if we it failed (or wasn't found), and '--version' was +# passed; such an option is passed most likely to detect whether the +# program is present and works. +case $2 in --version|--help) exit $st;; esac + +# Exit code 63 means version mismatch. This often happens when the user +# tries to use an ancient version of a tool on a file that requires a +# minimum version. +if test $st -eq 63; then + msg="probably too old" +elif test $st -eq 127; then + # Program was missing. + msg="missing on your system" +else + # Program was found and executed, but failed. Give up. + exit $st +fi + +perl_URL=https://www.perl.org/ +flex_URL=https://github.com/westes/flex +gnu_software_URL=https://www.gnu.org/software + +program_details () +{ + case $1 in + aclocal|automake) + echo "The '$1' program is part of the GNU Automake package:" + echo "<$gnu_software_URL/automake>" + echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:" + echo "<$gnu_software_URL/autoconf>" + echo "<$gnu_software_URL/m4/>" + echo "<$perl_URL>" + ;; + autoconf|autom4te|autoheader) + echo "The '$1' program is part of the GNU Autoconf package:" + echo "<$gnu_software_URL/autoconf/>" + echo "It also requires GNU m4 and Perl in order to run:" + echo "<$gnu_software_URL/m4/>" + echo "<$perl_URL>" + ;; + esac +} + +give_advice () +{ + # Normalize program name to check for. + normalized_program=`echo "$1" | sed ' + s/^gnu-//; t + s/^gnu//; t + s/^g//; t'` + + printf '%s\n' "'$1' is $msg." + + configure_deps="'configure.ac' or m4 files included by 'configure.ac'" + case $normalized_program in + autoconf*) + echo "You should only need it if you modified 'configure.ac'," + echo "or m4 files included by it." + program_details 'autoconf' + ;; + autoheader*) + echo "You should only need it if you modified 'acconfig.h' or" + echo "$configure_deps." + program_details 'autoheader' + ;; + automake*) + echo "You should only need it if you modified 'Makefile.am' or" + echo "$configure_deps." + program_details 'automake' + ;; + aclocal*) + echo "You should only need it if you modified 'acinclude.m4' or" + echo "$configure_deps." + program_details 'aclocal' + ;; + autom4te*) + echo "You might have modified some maintainer files that require" + echo "the 'autom4te' program to be rebuilt." + program_details 'autom4te' + ;; + bison*|yacc*) + echo "You should only need it if you modified a '.y' file." + echo "You may want to install the GNU Bison package:" + echo "<$gnu_software_URL/bison/>" + ;; + lex*|flex*) + echo "You should only need it if you modified a '.l' file." + echo "You may want to install the Fast Lexical Analyzer package:" + echo "<$flex_URL>" + ;; + help2man*) + echo "You should only need it if you modified a dependency" \ + "of a man page." + echo "You may want to install the GNU Help2man package:" + echo "<$gnu_software_URL/help2man/>" + ;; + makeinfo*) + echo "You should only need it if you modified a '.texi' file, or" + echo "any other file indirectly affecting the aspect of the manual." + echo "You might want to install the Texinfo package:" + echo "<$gnu_software_URL/texinfo/>" + echo "The spurious makeinfo call might also be the consequence of" + echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might" + echo "want to install GNU make:" + echo "<$gnu_software_URL/make/>" + ;; + *) + echo "You might have modified some files without having the proper" + echo "tools for further handling them. Check the 'README' file, it" + echo "often tells you about the needed prerequisites for installing" + echo "this package. You may also peek at any GNU archive site, in" + echo "case some other package contains this missing '$1' program." + ;; + esac +} + +give_advice "$1" | sed -e '1s/^/WARNING: /' \ + -e '2,$s/^/ /' >&2 + +# Propagate the correct exit status (expected to be 127 for a program +# not found, 63 for a program that failed due to version mismatch). +exit $st + +# Local variables: +# eval: (add-hook 'before-save-hook 'time-stamp) +# time-stamp-start: "scriptversion=" +# time-stamp-format: "%:y-%02m-%02d.%02H" +# time-stamp-time-zone: "UTC0" +# time-stamp-end: "; # UTC" +# End: diff --git a/TMessagesProj/jni/libtgvoip2/os/android/AudioInputAndroid.cpp b/TMessagesProj/jni/libtgvoip2/os/android/AudioInputAndroid.cpp new file mode 100644 index 000000000..313a24452 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/AudioInputAndroid.cpp @@ -0,0 +1,73 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "AudioInputAndroid.h" +#include +#include "../../logging.h" +#include "JNIUtilities.h" + +extern JavaVM* sharedJVM; + +using namespace tgvoip; +using namespace tgvoip::audio; + +jmethodID AudioInputAndroid::initMethod=NULL; +jmethodID AudioInputAndroid::releaseMethod=NULL; +jmethodID AudioInputAndroid::startMethod=NULL; +jmethodID AudioInputAndroid::stopMethod=NULL; +jmethodID AudioInputAndroid::getEnabledEffectsMaskMethod=NULL; +jclass AudioInputAndroid::jniClass=NULL; + +AudioInputAndroid::AudioInputAndroid(){ + jni::DoWithJNI([this](JNIEnv* env){ + jmethodID ctor=env->GetMethodID(jniClass, "", "(J)V"); + jobject obj=env->NewObject(jniClass, ctor, (jlong)(intptr_t)this); + javaObject=env->NewGlobalRef(obj); + + env->CallVoidMethod(javaObject, initMethod, 48000, 16, 1, 960*2); + enabledEffects=(unsigned int)env->CallIntMethod(javaObject, getEnabledEffectsMaskMethod); + }); + running=false; +} + +AudioInputAndroid::~AudioInputAndroid(){ + { + MutexGuard guard(mutex); + jni::DoWithJNI([this](JNIEnv* env){ + env->CallVoidMethod(javaObject, releaseMethod); + env->DeleteGlobalRef(javaObject); + javaObject=NULL; + }); + } +} + +void AudioInputAndroid::Start(){ + MutexGuard guard(mutex); + jni::DoWithJNI([this](JNIEnv* env){ + failed=!env->CallBooleanMethod(javaObject, startMethod); + }); + running=true; +} + +void AudioInputAndroid::Stop(){ + MutexGuard guard(mutex); + running=false; + jni::DoWithJNI([this](JNIEnv* env){ + env->CallVoidMethod(javaObject, stopMethod); + }); +} + +void AudioInputAndroid::HandleCallback(JNIEnv* env, jobject buffer){ + if(!running) + return; + unsigned char* buf=(unsigned char*) env->GetDirectBufferAddress(buffer); + size_t len=(size_t) env->GetDirectBufferCapacity(buffer); + InvokeCallback(buf, len); +} + +unsigned int AudioInputAndroid::GetEnabledEffects(){ + return enabledEffects; +} diff --git a/TMessagesProj/jni/libtgvoip2/os/android/AudioInputAndroid.h b/TMessagesProj/jni/libtgvoip2/os/android/AudioInputAndroid.h new file mode 100644 index 000000000..8ee761574 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/AudioInputAndroid.h @@ -0,0 +1,43 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOINPUTANDROID_H +#define LIBTGVOIP_AUDIOINPUTANDROID_H + +#include +#include "../../audio/AudioInput.h" +#include "../../threading.h" + +namespace tgvoip{ namespace audio{ +class AudioInputAndroid : public AudioInput{ + +public: + AudioInputAndroid(); + virtual ~AudioInputAndroid(); + virtual void Start(); + virtual void Stop(); + void HandleCallback(JNIEnv* env, jobject buffer); + unsigned int GetEnabledEffects(); + static jmethodID initMethod; + static jmethodID releaseMethod; + static jmethodID startMethod; + static jmethodID stopMethod; + static jmethodID getEnabledEffectsMaskMethod; + static jclass jniClass; + + static constexpr unsigned int EFFECT_AEC=1; + static constexpr unsigned int EFFECT_NS=2; + +private: + jobject javaObject; + bool running; + Mutex mutex; + unsigned int enabledEffects=0; + +}; +}} + +#endif //LIBTGVOIP_AUDIOINPUTANDROID_H diff --git a/TMessagesProj/jni/libtgvoip2/os/android/AudioInputOpenSLES.cpp b/TMessagesProj/jni/libtgvoip2/os/android/AudioInputOpenSLES.cpp new file mode 100644 index 000000000..70e7cbafe --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/AudioInputOpenSLES.cpp @@ -0,0 +1,137 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include +#include +#include + +#include "AudioInputOpenSLES.h" +#include "../../logging.h" +#include "OpenSLEngineWrapper.h" + +#define CHECK_SL_ERROR(res, msg) if(res!=SL_RESULT_SUCCESS){ LOGE(msg); return; } +#define BUFFER_SIZE 960 // 20 ms + +using namespace tgvoip; +using namespace tgvoip::audio; + +unsigned int AudioInputOpenSLES::nativeBufferSize; + +AudioInputOpenSLES::AudioInputOpenSLES(){ + slEngine=OpenSLEngineWrapper::CreateEngine(); + + LOGI("Native buffer size is %u samples", nativeBufferSize); + if(nativeBufferSizeBUFFER_SIZE && nativeBufferSize%BUFFER_SIZE!=0){ + LOGE("native buffer size is not multiple of 20ms!!"); + nativeBufferSize+=nativeBufferSize%BUFFER_SIZE; + } + if(nativeBufferSize==BUFFER_SIZE) + nativeBufferSize*=2; + LOGI("Adjusted native buffer size is %u", nativeBufferSize); + + buffer=(int16_t*)calloc(BUFFER_SIZE, sizeof(int16_t)); + nativeBuffer=(int16_t*)calloc((size_t) nativeBufferSize, sizeof(int16_t)); + slRecorderObj=NULL; +} + +AudioInputOpenSLES::~AudioInputOpenSLES(){ + //Stop(); + (*slBufferQueue)->Clear(slBufferQueue); + (*slRecorderObj)->Destroy(slRecorderObj); + slRecorderObj=NULL; + slRecorder=NULL; + slBufferQueue=NULL; + slEngine=NULL; + OpenSLEngineWrapper::DestroyEngine(); + free(buffer); + buffer=NULL; + free(nativeBuffer); + nativeBuffer=NULL; +} + +void AudioInputOpenSLES::BufferCallback(SLAndroidSimpleBufferQueueItf bq, void *context){ + ((AudioInputOpenSLES*)context)->HandleSLCallback(); +} + +void AudioInputOpenSLES::Configure(uint32_t sampleRate, uint32_t bitsPerSample, uint32_t channels){ + assert(slRecorderObj==NULL); + SLDataLocator_IODevice loc_dev = {SL_DATALOCATOR_IODEVICE, + SL_IODEVICE_AUDIOINPUT, + SL_DEFAULTDEVICEID_AUDIOINPUT, NULL}; + SLDataSource audioSrc = {&loc_dev, NULL}; + SLDataLocator_AndroidSimpleBufferQueue loc_bq = + {SL_DATALOCATOR_ANDROIDSIMPLEBUFFERQUEUE, 1}; + SLDataFormat_PCM format_pcm = {SL_DATAFORMAT_PCM, channels, sampleRate*1000, + SL_PCMSAMPLEFORMAT_FIXED_16, SL_PCMSAMPLEFORMAT_FIXED_16, + channels==2 ? (SL_SPEAKER_FRONT_LEFT | SL_SPEAKER_FRONT_RIGHT) : SL_SPEAKER_FRONT_CENTER, SL_BYTEORDER_LITTLEENDIAN}; + SLDataSink audioSnk = {&loc_bq, &format_pcm}; + + const SLInterfaceID id[2] = {SL_IID_ANDROIDSIMPLEBUFFERQUEUE, SL_IID_ANDROIDCONFIGURATION}; + const SLboolean req[2] = {SL_BOOLEAN_TRUE, SL_BOOLEAN_TRUE}; + SLresult result = (*slEngine)->CreateAudioRecorder(slEngine, &slRecorderObj, &audioSrc, &audioSnk, 2, id, req); + CHECK_SL_ERROR(result, "Error creating recorder"); + + SLAndroidConfigurationItf recorderConfig; + result = (*slRecorderObj)->GetInterface(slRecorderObj, SL_IID_ANDROIDCONFIGURATION, &recorderConfig); + SLint32 streamType = SL_ANDROID_RECORDING_PRESET_VOICE_RECOGNITION; + result = (*recorderConfig)->SetConfiguration(recorderConfig, SL_ANDROID_KEY_RECORDING_PRESET, &streamType, sizeof(SLint32)); + + result=(*slRecorderObj)->Realize(slRecorderObj, SL_BOOLEAN_FALSE); + CHECK_SL_ERROR(result, "Error realizing recorder"); + + result=(*slRecorderObj)->GetInterface(slRecorderObj, SL_IID_RECORD, &slRecorder); + CHECK_SL_ERROR(result, "Error getting recorder interface"); + + result=(*slRecorderObj)->GetInterface(slRecorderObj, SL_IID_ANDROIDSIMPLEBUFFERQUEUE, &slBufferQueue); + CHECK_SL_ERROR(result, "Error getting buffer queue"); + + result=(*slBufferQueue)->RegisterCallback(slBufferQueue, AudioInputOpenSLES::BufferCallback, this); + CHECK_SL_ERROR(result, "Error setting buffer queue callback"); + + (*slBufferQueue)->Enqueue(slBufferQueue, nativeBuffer, nativeBufferSize*sizeof(int16_t)); +} + +void AudioInputOpenSLES::Start(){ + SLresult result=(*slRecorder)->SetRecordState(slRecorder, SL_RECORDSTATE_RECORDING); + CHECK_SL_ERROR(result, "Error starting record"); +} + +void AudioInputOpenSLES::Stop(){ + SLresult result=(*slRecorder)->SetRecordState(slRecorder, SL_RECORDSTATE_STOPPED); + CHECK_SL_ERROR(result, "Error stopping record"); +} + + +void AudioInputOpenSLES::HandleSLCallback(){ + //SLmillisecond pMsec = 0; + //(*slRecorder)->GetPosition(slRecorder, &pMsec); + //LOGI("Callback! pos=%lu", pMsec); + //InvokeCallback((unsigned char*)buffer, BUFFER_SIZE*sizeof(int16_t)); + //fwrite(nativeBuffer, 1, nativeBufferSize*2, test); + + if(nativeBufferSize==BUFFER_SIZE){ + //LOGV("nativeBufferSize==BUFFER_SIZE"); + InvokeCallback((unsigned char *) nativeBuffer, BUFFER_SIZE*sizeof(int16_t)); + }else if(nativeBufferSize=BUFFER_SIZE){ + InvokeCallback((unsigned char *) buffer, BUFFER_SIZE*sizeof(int16_t)); + positionInBuffer=0; + } + memcpy(((unsigned char*)buffer)+positionInBuffer*2, nativeBuffer, (size_t)nativeBufferSize*2); + positionInBuffer+=nativeBufferSize; + }else if(nativeBufferSize>BUFFER_SIZE){ + //LOGV("nativeBufferSize>BUFFER_SIZE"); + for(unsigned int offset=0;offsetEnqueue(slBufferQueue, nativeBuffer, nativeBufferSize*sizeof(int16_t)); +} + diff --git a/TMessagesProj/jni/libtgvoip2/os/android/AudioInputOpenSLES.h b/TMessagesProj/jni/libtgvoip2/os/android/AudioInputOpenSLES.h new file mode 100644 index 000000000..64e196e2e --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/AudioInputOpenSLES.h @@ -0,0 +1,40 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOINPUTOPENSLES_H +#define LIBTGVOIP_AUDIOINPUTOPENSLES_H + +#include +#include + +#include "../../audio/AudioInput.h" + +namespace tgvoip{ namespace audio{ +class AudioInputOpenSLES : public AudioInput{ + +public: + AudioInputOpenSLES(); + virtual ~AudioInputOpenSLES(); + virtual void Configure(uint32_t sampleRate, uint32_t bitsPerSample, uint32_t channels); + virtual void Start(); + virtual void Stop(); + + static unsigned int nativeBufferSize; + +private: + static void BufferCallback(SLAndroidSimpleBufferQueueItf bq, void *context); + void HandleSLCallback(); + SLEngineItf slEngine; + SLObjectItf slRecorderObj; + SLRecordItf slRecorder; + SLAndroidSimpleBufferQueueItf slBufferQueue; + int16_t* buffer; + int16_t* nativeBuffer; + size_t positionInBuffer; +}; +}} + +#endif //LIBTGVOIP_AUDIOINPUTOPENSLES_H diff --git a/TMessagesProj/jni/libtgvoip2/os/android/AudioOutputAndroid.cpp b/TMessagesProj/jni/libtgvoip2/os/android/AudioOutputAndroid.cpp new file mode 100644 index 000000000..c1dc2d5df --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/AudioOutputAndroid.cpp @@ -0,0 +1,107 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "AudioOutputAndroid.h" +#include +#include "../../logging.h" + +extern JavaVM* sharedJVM; + +using namespace tgvoip; +using namespace tgvoip::audio; + +jmethodID AudioOutputAndroid::initMethod=NULL; +jmethodID AudioOutputAndroid::releaseMethod=NULL; +jmethodID AudioOutputAndroid::startMethod=NULL; +jmethodID AudioOutputAndroid::stopMethod=NULL; +jclass AudioOutputAndroid::jniClass=NULL; + +AudioOutputAndroid::AudioOutputAndroid(){ + JNIEnv* env=NULL; + bool didAttach=false; + sharedJVM->GetEnv((void**) &env, JNI_VERSION_1_6); + if(!env){ + sharedJVM->AttachCurrentThread(&env, NULL); + didAttach=true; + } + + jmethodID ctor=env->GetMethodID(jniClass, "", "(J)V"); + jobject obj=env->NewObject(jniClass, ctor, (jlong)(intptr_t)this); + javaObject=env->NewGlobalRef(obj); + + env->CallVoidMethod(javaObject, initMethod, 48000, 16, 1, 960*2); + + if(didAttach){ + sharedJVM->DetachCurrentThread(); + } + running=false; +} + +AudioOutputAndroid::~AudioOutputAndroid(){ + JNIEnv* env=NULL; + bool didAttach=false; + sharedJVM->GetEnv((void**) &env, JNI_VERSION_1_6); + if(!env){ + sharedJVM->AttachCurrentThread(&env, NULL); + didAttach=true; + } + + env->CallVoidMethod(javaObject, releaseMethod); + env->DeleteGlobalRef(javaObject); + javaObject=NULL; + + if(didAttach){ + sharedJVM->DetachCurrentThread(); + } +} + +void AudioOutputAndroid::Start(){ + JNIEnv* env=NULL; + bool didAttach=false; + sharedJVM->GetEnv((void**) &env, JNI_VERSION_1_6); + if(!env){ + sharedJVM->AttachCurrentThread(&env, NULL); + didAttach=true; + } + + env->CallVoidMethod(javaObject, startMethod); + + if(didAttach){ + sharedJVM->DetachCurrentThread(); + } + running=true; +} + +void AudioOutputAndroid::Stop(){ + running=false; + JNIEnv* env=NULL; + bool didAttach=false; + sharedJVM->GetEnv((void**) &env, JNI_VERSION_1_6); + if(!env){ + sharedJVM->AttachCurrentThread(&env, NULL); + didAttach=true; + } + + env->CallVoidMethod(javaObject, stopMethod); + + if(didAttach){ + sharedJVM->DetachCurrentThread(); + } +} + +void AudioOutputAndroid::HandleCallback(JNIEnv* env, jbyteArray buffer){ + if(!running) + return; + unsigned char* buf=(unsigned char*) env->GetByteArrayElements(buffer, NULL); + size_t len=(size_t) env->GetArrayLength(buffer); + InvokeCallback(buf, len); + env->ReleaseByteArrayElements(buffer, (jbyte *) buf, 0); +} + + +bool AudioOutputAndroid::IsPlaying(){ + return running; +} diff --git a/TMessagesProj/jni/libtgvoip2/os/android/AudioOutputAndroid.h b/TMessagesProj/jni/libtgvoip2/os/android/AudioOutputAndroid.h new file mode 100644 index 000000000..dded47fb4 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/AudioOutputAndroid.h @@ -0,0 +1,37 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOOUTPUTANDROID_H +#define LIBTGVOIP_AUDIOOUTPUTANDROID_H + +#include +#include "../../audio/AudioOutput.h" + +namespace tgvoip{ namespace audio{ +class AudioOutputAndroid : public AudioOutput{ + +public: + + AudioOutputAndroid(); + virtual ~AudioOutputAndroid(); + virtual void Start(); + virtual void Stop(); + virtual bool IsPlaying() override; + void HandleCallback(JNIEnv* env, jbyteArray buffer); + static jmethodID initMethod; + static jmethodID releaseMethod; + static jmethodID startMethod; + static jmethodID stopMethod; + static jclass jniClass; + +private: + jobject javaObject; + bool running; + +}; +}} + +#endif //LIBTGVOIP_AUDIOOUTPUTANDROID_H diff --git a/TMessagesProj/jni/libtgvoip2/os/android/AudioOutputOpenSLES.cpp b/TMessagesProj/jni/libtgvoip2/os/android/AudioOutputOpenSLES.cpp new file mode 100644 index 000000000..94ccf1271 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/AudioOutputOpenSLES.cpp @@ -0,0 +1,171 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include +#include +#include +#include "AudioOutputOpenSLES.h" +#include "../../logging.h" +#include "../../VoIPController.h" +#include "OpenSLEngineWrapper.h" +#include "AudioInputAndroid.h" + +#define CHECK_SL_ERROR(res, msg) if(res!=SL_RESULT_SUCCESS){ LOGE(msg); failed=true; return; } +#define BUFFER_SIZE 960 // 20 ms + +using namespace tgvoip; +using namespace tgvoip::audio; + +unsigned int AudioOutputOpenSLES::nativeBufferSize; + +AudioOutputOpenSLES::AudioOutputOpenSLES(){ + SLresult result; + slEngine=OpenSLEngineWrapper::CreateEngine(); + + const SLInterfaceID pOutputMixIDs[] = {}; + const SLboolean pOutputMixRequired[] = {}; + result = (*slEngine)->CreateOutputMix(slEngine, &slOutputMixObj, 0, pOutputMixIDs, pOutputMixRequired); + CHECK_SL_ERROR(result, "Error creating output mix"); + + result = (*slOutputMixObj)->Realize(slOutputMixObj, SL_BOOLEAN_FALSE); + CHECK_SL_ERROR(result, "Error realizing output mix"); + + LOGI("Native buffer size is %u samples", nativeBufferSize); + /*if(nativeBufferSizeBUFFER_SIZE && nativeBufferSize%BUFFER_SIZE!=0){ + LOGE("native buffer size is not multiple of 20ms!!"); + nativeBufferSize+=nativeBufferSize%BUFFER_SIZE; + } + LOGI("Adjusted native buffer size is %u", nativeBufferSize);*/ + + buffer=(int16_t*)calloc(BUFFER_SIZE, sizeof(int16_t)); + nativeBuffer=(int16_t*)calloc((size_t) nativeBufferSize, sizeof(int16_t)); + slPlayerObj=NULL; + remainingDataSize=0; +} + +AudioOutputOpenSLES::~AudioOutputOpenSLES(){ + if(!stopped) + Stop(); + (*slBufferQueue)->Clear(slBufferQueue); + LOGV("destroy slPlayerObj"); + (*slPlayerObj)->Destroy(slPlayerObj); + LOGV("destroy slOutputMixObj"); + (*slOutputMixObj)->Destroy(slOutputMixObj); + OpenSLEngineWrapper::DestroyEngine(); + free(buffer); + free(nativeBuffer); +} + + +void AudioOutputOpenSLES::SetNativeBufferSize(unsigned int size){ + AudioOutputOpenSLES::nativeBufferSize=size; +} + +void AudioOutputOpenSLES::BufferCallback(SLAndroidSimpleBufferQueueItf bq, void *context){ + ((AudioOutputOpenSLES*)context)->HandleSLCallback(); +} + +void AudioOutputOpenSLES::Configure(uint32_t sampleRate, uint32_t bitsPerSample, uint32_t channels){ + assert(slPlayerObj==NULL); + SLDataLocator_AndroidSimpleBufferQueue locatorBufferQueue = + {SL_DATALOCATOR_ANDROIDSIMPLEBUFFERQUEUE, 1}; + SLDataFormat_PCM formatPCM = {SL_DATAFORMAT_PCM, channels, sampleRate*1000, + SL_PCMSAMPLEFORMAT_FIXED_16, SL_PCMSAMPLEFORMAT_FIXED_16, + channels==2 ? (SL_SPEAKER_FRONT_LEFT | SL_SPEAKER_FRONT_RIGHT) : SL_SPEAKER_FRONT_CENTER, SL_BYTEORDER_LITTLEENDIAN}; + SLDataSource audioSrc = {&locatorBufferQueue, &formatPCM}; + SLDataLocator_OutputMix locatorOutMix = {SL_DATALOCATOR_OUTPUTMIX, slOutputMixObj}; + SLDataSink audioSnk = {&locatorOutMix, NULL}; + + const SLInterfaceID id[2] = {SL_IID_BUFFERQUEUE, SL_IID_ANDROIDCONFIGURATION}; + const SLboolean req[2] = {SL_BOOLEAN_TRUE, SL_BOOLEAN_TRUE}; + SLresult result = (*slEngine)->CreateAudioPlayer(slEngine, &slPlayerObj, &audioSrc, &audioSnk, 2, id, req); + CHECK_SL_ERROR(result, "Error creating player"); + + + SLAndroidConfigurationItf playerConfig; + result = (*slPlayerObj)->GetInterface(slPlayerObj, SL_IID_ANDROIDCONFIGURATION, &playerConfig); + SLint32 streamType = SL_ANDROID_STREAM_VOICE; + result = (*playerConfig)->SetConfiguration(playerConfig, SL_ANDROID_KEY_STREAM_TYPE, &streamType, sizeof(SLint32)); + + + result=(*slPlayerObj)->Realize(slPlayerObj, SL_BOOLEAN_FALSE); + CHECK_SL_ERROR(result, "Error realizing player"); + + result=(*slPlayerObj)->GetInterface(slPlayerObj, SL_IID_PLAY, &slPlayer); + CHECK_SL_ERROR(result, "Error getting player interface"); + + result=(*slPlayerObj)->GetInterface(slPlayerObj, SL_IID_ANDROIDSIMPLEBUFFERQUEUE, &slBufferQueue); + CHECK_SL_ERROR(result, "Error getting buffer queue"); + + result=(*slBufferQueue)->RegisterCallback(slBufferQueue, AudioOutputOpenSLES::BufferCallback, this); + CHECK_SL_ERROR(result, "Error setting buffer queue callback"); + + (*slBufferQueue)->Enqueue(slBufferQueue, nativeBuffer, nativeBufferSize*sizeof(int16_t)); +} + +bool AudioOutputOpenSLES::IsPhone(){ + return false; +} + +void AudioOutputOpenSLES::EnableLoudspeaker(bool enabled){ + +} + +void AudioOutputOpenSLES::Start(){ + stopped=false; + SLresult result=(*slPlayer)->SetPlayState(slPlayer, SL_PLAYSTATE_PLAYING); + CHECK_SL_ERROR(result, "Error starting player"); +} + +void AudioOutputOpenSLES::Stop(){ + stopped=true; + LOGV("Stopping OpenSL output"); + SLresult result=(*slPlayer)->SetPlayState(slPlayer, SL_PLAYSTATE_PAUSED); + CHECK_SL_ERROR(result, "Error starting player"); +} + +void AudioOutputOpenSLES::HandleSLCallback(){ + /*if(stopped){ + //LOGV("left HandleSLCallback early"); + return; + }*/ + //LOGV("before InvokeCallback"); + if(!stopped){ + while(remainingDataSize0) + memmove(remainingData, remainingData+nativeBufferSize*2, remainingDataSize); + //InvokeCallback((unsigned char *) nativeBuffer, nativeBufferSize*sizeof(int16_t)); + }else{ + memset(nativeBuffer, 0, nativeBufferSize*2); + } + + (*slBufferQueue)->Enqueue(slBufferQueue, nativeBuffer, nativeBufferSize*sizeof(int16_t)); + //LOGV("left HandleSLCallback"); +} + + +bool AudioOutputOpenSLES::IsPlaying(){ + if(slPlayer){ + uint32_t state; + (*slPlayer)->GetPlayState(slPlayer, &state); + return state==SL_PLAYSTATE_PLAYING; + } + return false; +} + + +float AudioOutputOpenSLES::GetLevel(){ + return 0; // we don't use this anyway +} \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/os/android/AudioOutputOpenSLES.h b/TMessagesProj/jni/libtgvoip2/os/android/AudioOutputOpenSLES.h new file mode 100644 index 000000000..cfca08909 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/AudioOutputOpenSLES.h @@ -0,0 +1,47 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOOUTPUTOPENSLES_H +#define LIBTGVOIP_AUDIOOUTPUTOPENSLES_H + +#include +#include + +#include "../../audio/AudioOutput.h" + +namespace tgvoip{ namespace audio{ +class AudioOutputOpenSLES : public AudioOutput{ +public: + AudioOutputOpenSLES(); + virtual ~AudioOutputOpenSLES(); + virtual void Configure(uint32_t sampleRate, uint32_t bitsPerSample, uint32_t channels); + virtual bool IsPhone(); + virtual void EnableLoudspeaker(bool enabled); + virtual void Start(); + virtual void Stop(); + virtual bool IsPlaying(); + virtual float GetLevel(); + + static void SetNativeBufferSize(unsigned int size); + static unsigned int nativeBufferSize; + +private: + static void BufferCallback(SLAndroidSimpleBufferQueueItf bq, void *context); + void HandleSLCallback(); + SLEngineItf slEngine; + SLObjectItf slPlayerObj; + SLObjectItf slOutputMixObj; + SLPlayItf slPlayer; + SLAndroidSimpleBufferQueueItf slBufferQueue; + int16_t* buffer; + int16_t* nativeBuffer; + bool stopped; + unsigned char remainingData[10240]; + size_t remainingDataSize; +}; +}} + +#endif //LIBTGVOIP_AUDIOOUTPUTANDROID_H diff --git a/TMessagesProj/jni/libtgvoip2/os/android/JNIUtilities.h b/TMessagesProj/jni/libtgvoip2/os/android/JNIUtilities.h new file mode 100644 index 000000000..0735e88f4 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/JNIUtilities.h @@ -0,0 +1,66 @@ +// +// Created by Grishka on 15.08.2018. +// + +#ifndef LIBTGVOIP_JNIUTILITIES_H +#define LIBTGVOIP_JNIUTILITIES_H + +#include +#include +#include +#include +#include "../../Buffers.h" + +extern JavaVM* sharedJVM; + +namespace tgvoip{ + namespace jni{ + + inline void DoWithJNI(std::function f){ + JNIEnv *env=NULL; + bool didAttach=false; + sharedJVM->GetEnv((void **) &env, JNI_VERSION_1_6); + if(!env){ + sharedJVM->AttachCurrentThread(&env, NULL); + didAttach=true; + } + + f(env); + + if(didAttach){ + sharedJVM->DetachCurrentThread(); + } + } + + inline void AttachAndCallVoidMethod(jmethodID method, jobject obj, ...){ + if(!method || !obj) + return; + va_list va; + va_start(va, obj); + DoWithJNI([&va, method, obj](JNIEnv* env){ + env->CallVoidMethodV(obj, method, va); + }); + va_end(va); + } + + inline std::string JavaStringToStdString(JNIEnv* env, jstring jstr){ + if(!jstr) + return ""; + const char* jchars=env->GetStringUTFChars(jstr, NULL); + std::string str(jchars); + env->ReleaseStringUTFChars(jstr, jchars); + return str; + } + + inline jbyteArray BufferToByteArray(JNIEnv* env, Buffer& buf){ + jbyteArray arr=env->NewByteArray((jsize)buf.Length()); + jbyte* elements=env->GetByteArrayElements(arr, NULL); + memcpy(elements, *buf, buf.Length()); + env->ReleaseByteArrayElements(arr, elements, 0); + return arr; + } + + } +} + +#endif //LIBTGVOIP_JNIUTILITIES_H diff --git a/TMessagesProj/jni/libtgvoip2/os/android/OpenSLEngineWrapper.cpp b/TMessagesProj/jni/libtgvoip2/os/android/OpenSLEngineWrapper.cpp new file mode 100644 index 000000000..086970726 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/OpenSLEngineWrapper.cpp @@ -0,0 +1,48 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include +#include "OpenSLEngineWrapper.h" +#include "../../logging.h" + +#define CHECK_SL_ERROR(res, msg) if(res!=SL_RESULT_SUCCESS){ LOGE(msg); return NULL; } + +using namespace tgvoip; +using namespace tgvoip::audio; + + +SLObjectItf OpenSLEngineWrapper::sharedEngineObj=NULL; +SLEngineItf OpenSLEngineWrapper::sharedEngine=NULL; +int OpenSLEngineWrapper::count=0; + +void OpenSLEngineWrapper::DestroyEngine(){ + count--; + LOGI("release: engine instance count %d", count); + if(count==0){ + (*sharedEngineObj)->Destroy(sharedEngineObj); + sharedEngineObj=NULL; + sharedEngine=NULL; + } + LOGI("after release"); +} + +SLEngineItf OpenSLEngineWrapper::CreateEngine(){ + count++; + if(sharedEngine) + return sharedEngine; + const SLInterfaceID pIDs[1] = {SL_IID_ENGINE}; + const SLboolean pIDsRequired[1] = {SL_BOOLEAN_TRUE}; + SLresult result = slCreateEngine(&sharedEngineObj, 0, NULL, 1, pIDs, pIDsRequired); + CHECK_SL_ERROR(result, "Error creating engine"); + + result=(*sharedEngineObj)->Realize(sharedEngineObj, SL_BOOLEAN_FALSE); + CHECK_SL_ERROR(result, "Error realizing engine"); + + result = (*sharedEngineObj)->GetInterface(sharedEngineObj, SL_IID_ENGINE, &sharedEngine); + CHECK_SL_ERROR(result, "Error getting engine interface"); + return sharedEngine; +} + diff --git a/TMessagesProj/jni/libtgvoip2/os/android/OpenSLEngineWrapper.h b/TMessagesProj/jni/libtgvoip2/os/android/OpenSLEngineWrapper.h new file mode 100644 index 000000000..ff0958602 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/OpenSLEngineWrapper.h @@ -0,0 +1,26 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_OPENSLENGINEWRAPPER_H +#define LIBTGVOIP_OPENSLENGINEWRAPPER_H + +#include +#include + +namespace tgvoip{ namespace audio{ +class OpenSLEngineWrapper{ +public: + static SLEngineItf CreateEngine(); + static void DestroyEngine(); + +private: + static SLObjectItf sharedEngineObj; + static SLEngineItf sharedEngine; + static int count; +}; +}} + +#endif //LIBTGVOIP_OPENSLENGINEWRAPPER_H diff --git a/TMessagesProj/jni/libtgvoip2/os/android/VideoRendererAndroid.cpp b/TMessagesProj/jni/libtgvoip2/os/android/VideoRendererAndroid.cpp new file mode 100644 index 000000000..69a62da85 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/VideoRendererAndroid.cpp @@ -0,0 +1,159 @@ +// +// Created by Grishka on 12.08.2018. +// + +#include "VideoRendererAndroid.h" +#include "JNIUtilities.h" +#include "../../PrivateDefines.h" +#include "../../logging.h" + +using namespace tgvoip; +using namespace tgvoip::video; + +jmethodID VideoRendererAndroid::resetMethod=NULL; +jmethodID VideoRendererAndroid::decodeAndDisplayMethod=NULL; +jmethodID VideoRendererAndroid::setStreamEnabledMethod=NULL; +jmethodID VideoRendererAndroid::setRotationMethod=NULL; +std::vector VideoRendererAndroid::availableDecoders; +int VideoRendererAndroid::maxResolution; + +extern JavaVM* sharedJVM; + +VideoRendererAndroid::VideoRendererAndroid(jobject jobj) : queue(50){ + this->jobj=jobj; +} + +VideoRendererAndroid::~VideoRendererAndroid(){ + running=false; + Request req{ + Buffer(0), + Request::Type::Shutdown + }; + queue.Put(std::move(req)); + thread->Join(); + delete thread; + /*decoderThread.Post([this]{ + decoderEnv->DeleteGlobalRef(jobj); + });*/ +} + +void VideoRendererAndroid::Reset(uint32_t codec, unsigned int width, unsigned int height, std::vector &_csd){ + csd.clear(); + for(Buffer& b:_csd){ + csd.push_back(Buffer::CopyOf(b)); + } + this->codec=codec; + this->width=width; + this->height=height; + Request req{ + Buffer(0), + Request::Type::ResetDecoder + }; + queue.Put(std::move(req)); + Request req2{ + Buffer(0), + Request::Type::UpdateStreamState + }; + queue.Put(std::move(req2)); + + if(!thread){ + thread=new Thread(std::bind(&VideoRendererAndroid::RunThread, this)); + thread->Start(); + } +} + +void VideoRendererAndroid::DecodeAndDisplay(Buffer frame, uint32_t pts){ + /*decoderThread.Post(std::bind([this](Buffer frame){ + }, std::move(frame)));*/ + //LOGV("2 before decode %u", (unsigned int)frame.Length()); + Request req{ + std::move(frame), + Request::Type::DecodeFrame + }; + queue.Put(std::move(req)); +} + +void VideoRendererAndroid::RunThread(){ + JNIEnv* env; + sharedJVM->AttachCurrentThread(&env, NULL); + + constexpr size_t bufferSize=200*1024; + unsigned char* buf=reinterpret_cast(malloc(bufferSize)); + jobject jbuf=env->NewDirectByteBuffer(buf, bufferSize); + uint16_t lastSetRotation=0; + + while(running){ + //LOGV("before get from queue"); + Request request=std::move(queue.GetBlocking()); + //LOGV("1 before decode %u", (unsigned int)request.Length()); + if(request.type==Request::Type::Shutdown){ + LOGI("Shutting down video decoder thread"); + break; + }else if(request.type==Request::Type::DecodeFrame){ + if(request.buffer.Length()>bufferSize){ + LOGE("Frame data is too long (%u, max %u)", (int) request.buffer.Length(), (int) bufferSize); + }else{ + if(lastSetRotation!=rotation){ + lastSetRotation=rotation; + env->CallVoidMethod(jobj, setRotationMethod, (jint)rotation); + } + memcpy(buf, *request.buffer, request.buffer.Length()); + env->CallVoidMethod(jobj, decodeAndDisplayMethod, jbuf, (jint) request.buffer.Length(), 0); + } + }else if(request.type==Request::Type::ResetDecoder){ + jobjectArray jcsd=NULL; + if(!csd.empty()){ + jcsd=env->NewObjectArray((jsize)csd.size(), env->FindClass("[B"), NULL); + jsize i=0; + for(Buffer& b:csd){ + env->SetObjectArrayElement(jcsd, i, jni::BufferToByteArray(env, b)); + i++; + } + } + std::string codecStr=""; + switch(codec){ + case CODEC_AVC: + codecStr="video/avc"; + break; + case CODEC_HEVC: + codecStr="video/hevc"; + break; + case CODEC_VP8: + codecStr="video/x-vnd.on2.vp8"; + break; + case CODEC_VP9: + codecStr="video/x-vnd.on2.vp9"; + break; + } + env->CallVoidMethod(jobj, resetMethod, env->NewStringUTF(codecStr.c_str()), (jint)width, (jint)height, jcsd); + }else if(request.type==Request::Type::UpdateStreamState){ + env->CallVoidMethod(jobj, setStreamEnabledMethod, streamEnabled, streamPaused); + } + } + free(buf); + sharedJVM->DetachCurrentThread(); + LOGI("==== decoder thread exiting ===="); +} + +void VideoRendererAndroid::SetStreamEnabled(bool enabled){ + LOGI("Video stream state: %d", enabled); + streamEnabled=enabled; + Request req{ + Buffer(0), + Request::Type::UpdateStreamState + }; + queue.Put(std::move(req)); +} + +void VideoRendererAndroid::SetRotation(uint16_t rotation){ + this->rotation=rotation; +} + +void VideoRendererAndroid::SetStreamPaused(bool paused){ + streamPaused=paused; + Request req{ + Buffer(0), + Request::Type::UpdateStreamState + }; + queue.Put(std::move(req)); +} diff --git a/TMessagesProj/jni/libtgvoip2/os/android/VideoRendererAndroid.h b/TMessagesProj/jni/libtgvoip2/os/android/VideoRendererAndroid.h new file mode 100644 index 000000000..6e8a40f6e --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/VideoRendererAndroid.h @@ -0,0 +1,60 @@ +// +// Created by Grishka on 12.08.2018. +// + +#ifndef LIBTGVOIP_VIDEORENDERERANDROID_H +#define LIBTGVOIP_VIDEORENDERERANDROID_H + +#include "../../video/VideoRenderer.h" +#include "../../MessageThread.h" + +#include +#include "../../BlockingQueue.h" + +namespace tgvoip{ + namespace video{ + class VideoRendererAndroid : public VideoRenderer{ + public: + VideoRendererAndroid(jobject jobj); + virtual ~VideoRendererAndroid(); + virtual void Reset(uint32_t codec, unsigned int width, unsigned int height, std::vector& csd) override; + virtual void DecodeAndDisplay(Buffer frame, uint32_t pts) override; + virtual void SetStreamEnabled(bool enabled) override; + virtual void SetRotation(uint16_t rotation) override; + virtual void SetStreamPaused(bool paused) override; + + static jmethodID resetMethod; + static jmethodID decodeAndDisplayMethod; + static jmethodID setStreamEnabledMethod; + static jmethodID setRotationMethod; + static std::vector availableDecoders; + static int maxResolution; + private: + struct Request{ + enum Type{ + DecodeFrame, + ResetDecoder, + UpdateStreamState, + Shutdown + }; + + Buffer buffer; + Type type; + }; + void RunThread(); + Thread* thread=NULL; + bool running=true; + BlockingQueue queue; + std::vector csd; + int width; + int height; + bool streamEnabled=true; + bool streamPaused=false; + uint32_t codec; + uint16_t rotation=0; + jobject jobj; + }; + } +} + +#endif //LIBTGVOIP_VIDEORENDERERANDROID_H diff --git a/TMessagesProj/jni/libtgvoip2/os/android/VideoSourceAndroid.cpp b/TMessagesProj/jni/libtgvoip2/os/android/VideoSourceAndroid.cpp new file mode 100644 index 000000000..7e7944089 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/VideoSourceAndroid.cpp @@ -0,0 +1,92 @@ +// +// Created by Grishka on 12.08.2018. +// + +#include "VideoSourceAndroid.h" +#include "JNIUtilities.h" +#include "../../logging.h" +#include "../../PrivateDefines.h" + +using namespace tgvoip; +using namespace tgvoip::video; + +extern JavaVM* sharedJVM; + +std::vector VideoSourceAndroid::availableEncoders; + +VideoSourceAndroid::VideoSourceAndroid(jobject jobj) : javaObject(jobj){ + jni::DoWithJNI([&](JNIEnv* env){ + jclass cls=env->GetObjectClass(javaObject); + startMethod=env->GetMethodID(cls, "start", "()V"); + stopMethod=env->GetMethodID(cls, "stop", "()V"); + prepareEncoderMethod=env->GetMethodID(cls, "prepareEncoder", "(Ljava/lang/String;I)V"); + requestKeyFrameMethod=env->GetMethodID(cls, "requestKeyFrame", "()V"); + setBitrateMethod=env->GetMethodID(cls, "setBitrate", "(I)V"); + }); +} + +VideoSourceAndroid::~VideoSourceAndroid(){ + jni::DoWithJNI([this](JNIEnv* env){ + env->DeleteGlobalRef(javaObject); + }); +} + +void VideoSourceAndroid::Start(){ + jni::DoWithJNI([this](JNIEnv* env){ + env->CallVoidMethod(javaObject, startMethod); + }); +} + +void VideoSourceAndroid::Stop(){ + jni::DoWithJNI([this](JNIEnv* env){ + env->CallVoidMethod(javaObject, stopMethod); + }); +} + +void VideoSourceAndroid::SendFrame(Buffer frame, uint32_t flags){ + callback(frame, flags, rotation); +} + +void VideoSourceAndroid::SetStreamParameters(std::vector csd, unsigned int width, unsigned int height){ + LOGD("Video stream parameters: %d x %d", width, height); + this->width=width; + this->height=height; + this->csd=std::move(csd); +} + +void VideoSourceAndroid::Reset(uint32_t codec, int maxResolution){ + jni::DoWithJNI([&](JNIEnv* env){ + std::string codecStr=""; + switch(codec){ + case CODEC_AVC: + codecStr="video/avc"; + break; + case CODEC_HEVC: + codecStr="video/hevc"; + break; + case CODEC_VP8: + codecStr="video/x-vnd.on2.vp8"; + break; + case CODEC_VP9: + codecStr="video/x-vnd.on2.vp9"; + break; + } + env->CallVoidMethod(javaObject, prepareEncoderMethod, env->NewStringUTF(codecStr.c_str()), maxResolution); + }); +} + +void VideoSourceAndroid::RequestKeyFrame(){ + jni::DoWithJNI([this](JNIEnv* env){ + env->CallVoidMethod(javaObject, requestKeyFrameMethod); + }); +} + +void VideoSourceAndroid::SetBitrate(uint32_t bitrate){ + jni::DoWithJNI([&](JNIEnv* env){ + env->CallVoidMethod(javaObject, setBitrateMethod, (jint)bitrate); + }); +} + +void VideoSourceAndroid::SetStreamPaused(bool paused){ + streamStateCallback(paused); +} diff --git a/TMessagesProj/jni/libtgvoip2/os/android/VideoSourceAndroid.h b/TMessagesProj/jni/libtgvoip2/os/android/VideoSourceAndroid.h new file mode 100644 index 000000000..bac967b4a --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/android/VideoSourceAndroid.h @@ -0,0 +1,41 @@ +// +// Created by Grishka on 12.08.2018. +// + +#ifndef LIBTGVOIP_VIDEOSOURCEANDROID_H +#define LIBTGVOIP_VIDEOSOURCEANDROID_H + +#include "../../video/VideoSource.h" +#include "../../Buffers.h" +#include +#include + +namespace tgvoip{ + namespace video{ + class VideoSourceAndroid : public VideoSource{ + public: + VideoSourceAndroid(jobject jobj); + virtual ~VideoSourceAndroid(); + virtual void Start() override; + virtual void Stop() override; + virtual void Reset(uint32_t codec, int maxResolution) override; + void SendFrame(Buffer frame, uint32_t flags); + void SetStreamParameters(std::vector csd, unsigned int width, unsigned int height); + virtual void RequestKeyFrame() override; + virtual void SetBitrate(uint32_t bitrate) override; + void SetStreamPaused(bool paused); + + static std::vector availableEncoders; + private: + jobject javaObject; + jmethodID prepareEncoderMethod; + jmethodID startMethod; + jmethodID stopMethod; + jmethodID requestKeyFrameMethod; + jmethodID setBitrateMethod; + }; + } +} + + +#endif //LIBTGVOIP_VIDEOSOURCEANDROID_H diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/AudioInputAudioUnit.cpp b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioInputAudioUnit.cpp new file mode 100644 index 000000000..8cc28ce8a --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioInputAudioUnit.cpp @@ -0,0 +1,73 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include +#include +#include +#include "AudioUnitIO.h" +#include "AudioInputAudioUnit.h" +#include "../../logging.h" + +#define BUFFER_SIZE 960 + +using namespace tgvoip; +using namespace tgvoip::audio; + +AudioInputAudioUnit::AudioInputAudioUnit(std::string deviceID, AudioUnitIO* io){ + remainingDataSize=0; + isRecording=false; + this->io=io; +#if TARGET_OS_OSX + io->SetCurrentDevice(true, deviceID); +#endif +} + +AudioInputAudioUnit::~AudioInputAudioUnit(){ + +} + +void AudioInputAudioUnit::Start(){ + isRecording=true; + io->EnableInput(true); +} + +void AudioInputAudioUnit::Stop(){ + isRecording=false; + io->EnableInput(false); +} + +void AudioInputAudioUnit::HandleBufferCallback(AudioBufferList *ioData){ + int i; + for(i=0;imNumberBuffers;i++){ + AudioBuffer buf=ioData->mBuffers[i]; +#if TARGET_OS_OSX + assert(remainingDataSize+buf.mDataByteSize/2<10240); + float* src=reinterpret_cast(buf.mData); + int16_t* dst=reinterpret_cast(remainingData+remainingDataSize); + for(int j=0;j=BUFFER_SIZE*2){ + InvokeCallback((unsigned char*)remainingData, BUFFER_SIZE*2); + remainingDataSize-=BUFFER_SIZE*2; + if(remainingDataSize>0){ + memmove(remainingData, remainingData+(BUFFER_SIZE*2), remainingDataSize); + } + } + } +} + +#if TARGET_OS_OSX +void AudioInputAudioUnit::SetCurrentDevice(std::string deviceID){ + io->SetCurrentDevice(true, deviceID); +} +#endif diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/AudioInputAudioUnit.h b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioInputAudioUnit.h new file mode 100644 index 000000000..a00b50064 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioInputAudioUnit.h @@ -0,0 +1,38 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOINPUTAUDIOUNIT_H +#define LIBTGVOIP_AUDIOINPUTAUDIOUNIT_H + +#include +#include "../../audio/AudioInput.h" +#include "../../utils.h" + +namespace tgvoip{ namespace audio{ +class AudioUnitIO; + +class AudioInputAudioUnit : public AudioInput{ + +public: + TGVOIP_DISALLOW_COPY_AND_ASSIGN(AudioInputAudioUnit); + AudioInputAudioUnit(std::string deviceID, AudioUnitIO* io); + virtual ~AudioInputAudioUnit(); + virtual void Start(); + virtual void Stop(); + void HandleBufferCallback(AudioBufferList* ioData); +#if TARGET_OS_OSX + virtual void SetCurrentDevice(std::string deviceID); +#endif + +private: + unsigned char remainingData[10240]; + size_t remainingDataSize; + bool isRecording; + AudioUnitIO* io; +}; +}} + +#endif //LIBTGVOIP_AUDIOINPUTAUDIOUNIT_H diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/AudioInputAudioUnitOSX.cpp b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioInputAudioUnitOSX.cpp new file mode 100644 index 000000000..7f018d8a7 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioInputAudioUnitOSX.cpp @@ -0,0 +1,308 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include +#include +#include "AudioInputAudioUnitOSX.h" +#include "../../logging.h" +#include "../../audio/Resampler.h" +#include "../../VoIPController.h" + +#define BUFFER_SIZE 960 +#define CHECK_AU_ERROR(res, msg) if(res!=noErr){ LOGE("input: " msg": OSStatus=%d", (int)res); failed=true; return; } + +#define kOutputBus 0 +#define kInputBus 1 + +using namespace tgvoip; +using namespace tgvoip::audio; + +AudioInputAudioUnitLegacy::AudioInputAudioUnitLegacy(std::string deviceID) : AudioInput(deviceID){ + remainingDataSize=0; + isRecording=false; + + inBufferList.mBuffers[0].mData=malloc(10240); + inBufferList.mBuffers[0].mDataByteSize=10240; + inBufferList.mNumberBuffers=1; + + OSStatus status; + AudioComponentDescription inputDesc={ + .componentType = kAudioUnitType_Output, .componentSubType = kAudioUnitSubType_HALOutput, .componentFlags = 0, .componentFlagsMask = 0, + .componentManufacturer = kAudioUnitManufacturer_Apple + }; + AudioComponent component=AudioComponentFindNext(NULL, &inputDesc); + status=AudioComponentInstanceNew(component, &unit); + CHECK_AU_ERROR(status, "Error creating AudioUnit"); + + UInt32 flag=0; + status = AudioUnitSetProperty(unit, kAudioOutputUnitProperty_EnableIO, kAudioUnitScope_Output, kOutputBus, &flag, sizeof(flag)); + CHECK_AU_ERROR(status, "Error enabling AudioUnit output"); + flag=1; + status = AudioUnitSetProperty(unit, kAudioOutputUnitProperty_EnableIO, kAudioUnitScope_Input, kInputBus, &flag, sizeof(flag)); + CHECK_AU_ERROR(status, "Error enabling AudioUnit input"); + + SetCurrentDevice(deviceID); + + CFRunLoopRef theRunLoop = NULL; + AudioObjectPropertyAddress propertyAddress = { kAudioHardwarePropertyRunLoop, + kAudioObjectPropertyScopeGlobal, + kAudioObjectPropertyElementMaster }; + status = AudioObjectSetPropertyData(kAudioObjectSystemObject, &propertyAddress, 0, NULL, sizeof(CFRunLoopRef), &theRunLoop); + + propertyAddress.mSelector = kAudioHardwarePropertyDefaultInputDevice; + propertyAddress.mScope = kAudioObjectPropertyScopeGlobal; + propertyAddress.mElement = kAudioObjectPropertyElementMaster; + AudioObjectAddPropertyListener(kAudioObjectSystemObject, &propertyAddress, AudioInputAudioUnitLegacy::DefaultDeviceChangedCallback, this); + + AURenderCallbackStruct callbackStruct; + callbackStruct.inputProc = AudioInputAudioUnitLegacy::BufferCallback; + callbackStruct.inputProcRefCon=this; + status = AudioUnitSetProperty(unit, kAudioOutputUnitProperty_SetInputCallback, kAudioUnitScope_Global, kInputBus, &callbackStruct, sizeof(callbackStruct)); + CHECK_AU_ERROR(status, "Error setting input buffer callback"); + status=AudioUnitInitialize(unit); + CHECK_AU_ERROR(status, "Error initializing unit"); +} + +AudioInputAudioUnitLegacy::~AudioInputAudioUnitLegacy(){ + AudioObjectPropertyAddress propertyAddress; + propertyAddress.mSelector = kAudioHardwarePropertyDefaultInputDevice; + propertyAddress.mScope = kAudioObjectPropertyScopeGlobal; + propertyAddress.mElement = kAudioObjectPropertyElementMaster; + AudioObjectRemovePropertyListener(kAudioObjectSystemObject, &propertyAddress, AudioInputAudioUnitLegacy::DefaultDeviceChangedCallback, this); + + AudioUnitUninitialize(unit); + AudioComponentInstanceDispose(unit); + free(inBufferList.mBuffers[0].mData); +} + +void AudioInputAudioUnitLegacy::Start(){ + isRecording=true; + OSStatus status=AudioOutputUnitStart(unit); + CHECK_AU_ERROR(status, "Error starting AudioUnit"); +} + +void AudioInputAudioUnitLegacy::Stop(){ + isRecording=false; + OSStatus status=AudioOutputUnitStart(unit); + CHECK_AU_ERROR(status, "Error stopping AudioUnit"); +} + +OSStatus AudioInputAudioUnitLegacy::BufferCallback(void *inRefCon, AudioUnitRenderActionFlags *ioActionFlags, const AudioTimeStamp *inTimeStamp, UInt32 inBusNumber, UInt32 inNumberFrames, AudioBufferList *ioData){ + AudioInputAudioUnitLegacy* input=(AudioInputAudioUnitLegacy*) inRefCon; + input->inBufferList.mBuffers[0].mDataByteSize=10240; + AudioUnitRender(input->unit, ioActionFlags, inTimeStamp, inBusNumber, inNumberFrames, &input->inBufferList); + input->HandleBufferCallback(&input->inBufferList); + return noErr; +} + +void AudioInputAudioUnitLegacy::HandleBufferCallback(AudioBufferList *ioData){ + int i; + for(i=0;imNumberBuffers;i++){ + AudioBuffer buf=ioData->mBuffers[i]; + size_t len=buf.mDataByteSize; + if(hardwareSampleRate!=48000){ + len=tgvoip::audio::Resampler::Convert((int16_t*)buf.mData, (int16_t*)(remainingData+remainingDataSize), buf.mDataByteSize/2, (10240-(buf.mDataByteSize+remainingDataSize))/2, 48000, hardwareSampleRate)*2; + }else{ + assert(remainingDataSize+buf.mDataByteSize<10240); + memcpy(remainingData+remainingDataSize, buf.mData, buf.mDataByteSize); + } + remainingDataSize+=len; + while(remainingDataSize>=BUFFER_SIZE*2){ + InvokeCallback((unsigned char*)remainingData, BUFFER_SIZE*2); + remainingDataSize-=BUFFER_SIZE*2; + if(remainingDataSize>0){ + memmove(remainingData, remainingData+(BUFFER_SIZE*2), remainingDataSize); + } + } + } +} + + +void AudioInputAudioUnitLegacy::EnumerateDevices(std::vector& devs){ + AudioObjectPropertyAddress propertyAddress = { + kAudioHardwarePropertyDevices, + kAudioObjectPropertyScopeGlobal, + kAudioObjectPropertyElementMaster + }; + + UInt32 dataSize = 0; + OSStatus status = AudioObjectGetPropertyDataSize(kAudioObjectSystemObject, &propertyAddress, 0, NULL, &dataSize); + if(kAudioHardwareNoError != status) { + LOGE("AudioObjectGetPropertyDataSize (kAudioHardwarePropertyDevices) failed: %i", status); + return; + } + + UInt32 deviceCount = (UInt32)(dataSize / sizeof(AudioDeviceID)); + + + AudioDeviceID *audioDevices = (AudioDeviceID*)(malloc(dataSize)); + + status = AudioObjectGetPropertyData(kAudioObjectSystemObject, &propertyAddress, 0, NULL, &dataSize, audioDevices); + if(kAudioHardwareNoError != status) { + LOGE("AudioObjectGetPropertyData (kAudioHardwarePropertyDevices) failed: %i", status); + free(audioDevices); + audioDevices = NULL; + return; + } + + + // Iterate through all the devices and determine which are input-capable + propertyAddress.mScope = kAudioDevicePropertyScopeInput; + for(UInt32 i = 0; i < deviceCount; ++i) { + // Query device UID + CFStringRef deviceUID = NULL; + dataSize = sizeof(deviceUID); + propertyAddress.mSelector = kAudioDevicePropertyDeviceUID; + status = AudioObjectGetPropertyData(audioDevices[i], &propertyAddress, 0, NULL, &dataSize, &deviceUID); + if(kAudioHardwareNoError != status) { + LOGE("AudioObjectGetPropertyData (kAudioDevicePropertyDeviceUID) failed: %i", status); + continue; + } + + // Query device name + CFStringRef deviceName = NULL; + dataSize = sizeof(deviceName); + propertyAddress.mSelector = kAudioDevicePropertyDeviceNameCFString; + status = AudioObjectGetPropertyData(audioDevices[i], &propertyAddress, 0, NULL, &dataSize, &deviceName); + if(kAudioHardwareNoError != status) { + LOGE("AudioObjectGetPropertyData (kAudioDevicePropertyDeviceNameCFString) failed: %i", status); + continue; + } + + // Determine if the device is an input device (it is an input device if it has input channels) + dataSize = 0; + propertyAddress.mSelector = kAudioDevicePropertyStreamConfiguration; + status = AudioObjectGetPropertyDataSize(audioDevices[i], &propertyAddress, 0, NULL, &dataSize); + if(kAudioHardwareNoError != status) { + LOGE("AudioObjectGetPropertyDataSize (kAudioDevicePropertyStreamConfiguration) failed: %i", status); + continue; + } + + AudioBufferList *bufferList = (AudioBufferList*)(malloc(dataSize)); + + status = AudioObjectGetPropertyData(audioDevices[i], &propertyAddress, 0, NULL, &dataSize, bufferList); + if(kAudioHardwareNoError != status || 0 == bufferList->mNumberBuffers) { + if(kAudioHardwareNoError != status) + LOGE("AudioObjectGetPropertyData (kAudioDevicePropertyStreamConfiguration) failed: %i", status); + free(bufferList); + bufferList = NULL; + continue; + } + + free(bufferList); + bufferList = NULL; + + AudioInputDevice dev; + char buf[1024]; + CFStringGetCString(deviceName, buf, 1024, kCFStringEncodingUTF8); + dev.displayName=std::string(buf); + CFStringGetCString(deviceUID, buf, 1024, kCFStringEncodingUTF8); + dev.id=std::string(buf); + if(dev.id.rfind("VPAUAggregateAudioDevice-0x")==0) + continue; + devs.push_back(dev); + } + + free(audioDevices); + audioDevices = NULL; +} + +void AudioInputAudioUnitLegacy::SetCurrentDevice(std::string deviceID){ + UInt32 size=sizeof(AudioDeviceID); + AudioDeviceID inputDevice=0; + OSStatus status; + + if(deviceID=="default"){ + AudioObjectPropertyAddress propertyAddress; + propertyAddress.mSelector = kAudioHardwarePropertyDefaultInputDevice; + propertyAddress.mScope = kAudioObjectPropertyScopeGlobal; + propertyAddress.mElement = kAudioObjectPropertyElementMaster; + UInt32 propsize = sizeof(AudioDeviceID); + status = AudioObjectGetPropertyData(kAudioObjectSystemObject, &propertyAddress, 0, NULL, &propsize, &inputDevice); + CHECK_AU_ERROR(status, "Error getting default input device"); + }else{ + AudioObjectPropertyAddress propertyAddress = { + kAudioHardwarePropertyDevices, + kAudioObjectPropertyScopeGlobal, + kAudioObjectPropertyElementMaster + }; + UInt32 dataSize = 0; + status = AudioObjectGetPropertyDataSize(kAudioObjectSystemObject, &propertyAddress, 0, NULL, &dataSize); + CHECK_AU_ERROR(status, "Error getting devices size"); + UInt32 deviceCount = (UInt32)(dataSize / sizeof(AudioDeviceID)); + AudioDeviceID audioDevices[deviceCount]; + status = AudioObjectGetPropertyData(kAudioObjectSystemObject, &propertyAddress, 0, NULL, &dataSize, audioDevices); + CHECK_AU_ERROR(status, "Error getting device list"); + for(UInt32 i = 0; i < deviceCount; ++i) { + // Query device UID + CFStringRef deviceUID = NULL; + dataSize = sizeof(deviceUID); + propertyAddress.mSelector = kAudioDevicePropertyDeviceUID; + status = AudioObjectGetPropertyData(audioDevices[i], &propertyAddress, 0, NULL, &dataSize, &deviceUID); + CHECK_AU_ERROR(status, "Error getting device uid"); + char buf[1024]; + CFStringGetCString(deviceUID, buf, 1024, kCFStringEncodingUTF8); + if(deviceID==buf){ + LOGV("Found device for id %s", buf); + inputDevice=audioDevices[i]; + break; + } + } + if(!inputDevice){ + LOGW("Requested device not found, using default"); + SetCurrentDevice("default"); + return; + } + } + + status =AudioUnitSetProperty(unit, + kAudioOutputUnitProperty_CurrentDevice, + kAudioUnitScope_Global, + kInputBus, + &inputDevice, + size); + CHECK_AU_ERROR(status, "Error setting input device"); + + AudioStreamBasicDescription hardwareFormat; + size=sizeof(hardwareFormat); + status=AudioUnitGetProperty(unit, kAudioUnitProperty_StreamFormat, kAudioUnitScope_Input, kInputBus, &hardwareFormat, &size); + CHECK_AU_ERROR(status, "Error getting hardware format"); + hardwareSampleRate=hardwareFormat.mSampleRate; + + AudioStreamBasicDescription desiredFormat={ + .mSampleRate=hardwareFormat.mSampleRate, .mFormatID=kAudioFormatLinearPCM, .mFormatFlags=kAudioFormatFlagIsSignedInteger | kAudioFormatFlagIsPacked | kAudioFormatFlagsNativeEndian, + .mFramesPerPacket=1, .mChannelsPerFrame=1, .mBitsPerChannel=16, .mBytesPerPacket=2, .mBytesPerFrame=2 + }; + + status=AudioUnitSetProperty(unit, kAudioUnitProperty_StreamFormat, kAudioUnitScope_Output, kInputBus, &desiredFormat, sizeof(desiredFormat)); + CHECK_AU_ERROR(status, "Error setting format"); + + LOGD("Switched capture device, new sample rate %d", hardwareSampleRate); + + this->currentDevice=deviceID; + + AudioObjectPropertyAddress propertyAddress = { + kAudioDevicePropertyBufferFrameSize, + kAudioObjectPropertyScopeGlobal, + kAudioObjectPropertyElementMaster + }; + size=4; + UInt32 bufferFrameSize; + status=AudioObjectGetPropertyData(inputDevice, &propertyAddress, 0, NULL, &size, &bufferFrameSize); + if(status==noErr){ + estimatedDelay=bufferFrameSize/48; + LOGD("CoreAudio buffer size for output device is %u frames (%u ms)", bufferFrameSize, estimatedDelay); + } +} + +OSStatus AudioInputAudioUnitLegacy::DefaultDeviceChangedCallback(AudioObjectID inObjectID, UInt32 inNumberAddresses, const AudioObjectPropertyAddress *inAddresses, void *inClientData){ + LOGV("System default input device changed"); + AudioInputAudioUnitLegacy* self=(AudioInputAudioUnitLegacy*)inClientData; + if(self->currentDevice=="default"){ + self->SetCurrentDevice(self->currentDevice); + } + return noErr; +} diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/AudioInputAudioUnitOSX.h b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioInputAudioUnitOSX.h new file mode 100644 index 000000000..ee4295b68 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioInputAudioUnitOSX.h @@ -0,0 +1,39 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOINPUTAUDIOUNIT_OSX_H +#define LIBTGVOIP_AUDIOINPUTAUDIOUNIT_OSX_H + +#include +#import +#import +#include "../../audio/AudioInput.h" + +namespace tgvoip{ namespace audio{ +class AudioInputAudioUnitLegacy : public AudioInput{ + +public: + AudioInputAudioUnitLegacy(std::string deviceID); + virtual ~AudioInputAudioUnitLegacy(); + virtual void Start(); + virtual void Stop(); + void HandleBufferCallback(AudioBufferList* ioData); + static void EnumerateDevices(std::vector& devs); + virtual void SetCurrentDevice(std::string deviceID); + +private: + static OSStatus BufferCallback(void *inRefCon, AudioUnitRenderActionFlags *ioActionFlags, const AudioTimeStamp *inTimeStamp, UInt32 inBusNumber, UInt32 inNumberFrames, AudioBufferList *ioData); + static OSStatus DefaultDeviceChangedCallback(AudioObjectID inObjectID, UInt32 inNumberAddresses, const AudioObjectPropertyAddress *inAddresses, void *inClientData); + unsigned char remainingData[10240]; + size_t remainingDataSize; + bool isRecording; + AudioUnit unit; + AudioBufferList inBufferList; + int hardwareSampleRate; +}; +}} + +#endif //LIBTGVOIP_AUDIOINPUTAUDIOUNIT_OSX_H diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/AudioOutputAudioUnit.cpp b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioOutputAudioUnit.cpp new file mode 100644 index 000000000..c7c34ab80 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioOutputAudioUnit.cpp @@ -0,0 +1,84 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include +#include +#include +#include "AudioOutputAudioUnit.h" +#include "../../logging.h" +#include "AudioUnitIO.h" + +#define BUFFER_SIZE 960 + +using namespace tgvoip; +using namespace tgvoip::audio; + +AudioOutputAudioUnit::AudioOutputAudioUnit(std::string deviceID, AudioUnitIO* io){ + isPlaying=false; + remainingDataSize=0; + this->io=io; +#if TARGET_OS_OSX + io->SetCurrentDevice(false, deviceID); +#endif +} + +AudioOutputAudioUnit::~AudioOutputAudioUnit(){ +} + +void AudioOutputAudioUnit::Start(){ + isPlaying=true; + io->EnableOutput(true); +} + +void AudioOutputAudioUnit::Stop(){ + isPlaying=false; + io->EnableOutput(false); +} + +bool AudioOutputAudioUnit::IsPlaying(){ + return isPlaying; +} + +void AudioOutputAudioUnit::HandleBufferCallback(AudioBufferList *ioData){ + int i; + for(i=0;imNumberBuffers;i++){ + AudioBuffer buf=ioData->mBuffers[i]; + if(!isPlaying){ + memset(buf.mData, 0, buf.mDataByteSize); + return; + } +#if TARGET_OS_OSX + unsigned int k; + while(remainingDataSize(buf.mData); + int16_t* src=reinterpret_cast(remainingData); + for(k=0;kSetCurrentDevice(false, deviceID); +} +#endif diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/AudioOutputAudioUnit.h b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioOutputAudioUnit.h new file mode 100644 index 000000000..2880ec237 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioOutputAudioUnit.h @@ -0,0 +1,39 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOOUTPUTAUDIOUNIT_H +#define LIBTGVOIP_AUDIOOUTPUTAUDIOUNIT_H + +#include +#include +#include "../../audio/AudioOutput.h" +#include "../../utils.h" + +namespace tgvoip{ namespace audio{ +class AudioUnitIO; + +class AudioOutputAudioUnit : public AudioOutput{ +public: + TGVOIP_DISALLOW_COPY_AND_ASSIGN(AudioOutputAudioUnit); + AudioOutputAudioUnit(std::string deviceID, AudioUnitIO* io); + virtual ~AudioOutputAudioUnit(); + virtual void Start(); + virtual void Stop(); + virtual bool IsPlaying(); + void HandleBufferCallback(AudioBufferList* ioData); +#if TARGET_OS_OSX + virtual void SetCurrentDevice(std::string deviceID); +#endif + +private: + std::atomic isPlaying; + unsigned char remainingData[10240]; + size_t remainingDataSize; + AudioUnitIO* io; +}; +}} + +#endif //LIBTGVOIP_AUDIOOUTPUTAUDIOUNIT_H diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/AudioOutputAudioUnitOSX.cpp b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioOutputAudioUnitOSX.cpp new file mode 100644 index 000000000..d2c4de829 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioOutputAudioUnitOSX.cpp @@ -0,0 +1,365 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include +#include +#include +#include "AudioOutputAudioUnitOSX.h" +#include "../../logging.h" +#include "../../VoIPController.h" + +#define BUFFER_SIZE 960 +#define CHECK_AU_ERROR(res, msg) if(res!=noErr){ LOGE("output: " msg": OSStatus=%d", (int)res); return; } + +#define kOutputBus 0 +#define kInputBus 1 + +using namespace tgvoip; +using namespace tgvoip::audio; + +AudioOutputAudioUnitLegacy::AudioOutputAudioUnitLegacy(std::string deviceID){ + remainingDataSize=0; + isPlaying=false; + sysDevID=0; + + OSStatus status; + AudioComponentDescription inputDesc={ + .componentType = kAudioUnitType_Output, .componentSubType = kAudioUnitSubType_HALOutput, .componentFlags = 0, .componentFlagsMask = 0, + .componentManufacturer = kAudioUnitManufacturer_Apple + }; + AudioComponent component=AudioComponentFindNext(NULL, &inputDesc); + status=AudioComponentInstanceNew(component, &unit); + CHECK_AU_ERROR(status, "Error creating AudioUnit"); + + UInt32 flag=1; + status = AudioUnitSetProperty(unit, kAudioOutputUnitProperty_EnableIO, kAudioUnitScope_Output, kOutputBus, &flag, sizeof(flag)); + CHECK_AU_ERROR(status, "Error enabling AudioUnit output"); + flag=0; + status = AudioUnitSetProperty(unit, kAudioOutputUnitProperty_EnableIO, kAudioUnitScope_Input, kInputBus, &flag, sizeof(flag)); + CHECK_AU_ERROR(status, "Error enabling AudioUnit input"); + + char model[128]; + memset(model, 0, sizeof(model)); + size_t msize=sizeof(model); + int mres=sysctlbyname("hw.model", model, &msize, NULL, 0); + if(mres==0){ + LOGV("Mac model: %s", model); + isMacBookPro=(strncmp("MacBookPro", model, 10)==0); + } + + SetCurrentDevice(deviceID); + + CFRunLoopRef theRunLoop = NULL; + AudioObjectPropertyAddress propertyAddress = { kAudioHardwarePropertyRunLoop, + kAudioObjectPropertyScopeGlobal, + kAudioObjectPropertyElementMaster }; + status = AudioObjectSetPropertyData(kAudioObjectSystemObject, &propertyAddress, 0, NULL, sizeof(CFRunLoopRef), &theRunLoop); + + propertyAddress.mSelector = kAudioHardwarePropertyDefaultOutputDevice; + propertyAddress.mScope = kAudioObjectPropertyScopeGlobal; + propertyAddress.mElement = kAudioObjectPropertyElementMaster; + AudioObjectAddPropertyListener(kAudioObjectSystemObject, &propertyAddress, AudioOutputAudioUnitLegacy::DefaultDeviceChangedCallback, this); + + AudioStreamBasicDescription desiredFormat={ + .mSampleRate=/*hardwareFormat.mSampleRate*/48000, .mFormatID=kAudioFormatLinearPCM, .mFormatFlags=kAudioFormatFlagIsSignedInteger | kAudioFormatFlagIsPacked | kAudioFormatFlagsNativeEndian, + .mFramesPerPacket=1, .mChannelsPerFrame=1, .mBitsPerChannel=16, .mBytesPerPacket=2, .mBytesPerFrame=2 + }; + + status=AudioUnitSetProperty(unit, kAudioUnitProperty_StreamFormat, kAudioUnitScope_Input, kOutputBus, &desiredFormat, sizeof(desiredFormat)); + CHECK_AU_ERROR(status, "Error setting format"); + + AURenderCallbackStruct callbackStruct; + callbackStruct.inputProc = AudioOutputAudioUnitLegacy::BufferCallback; + callbackStruct.inputProcRefCon=this; + status = AudioUnitSetProperty(unit, kAudioUnitProperty_SetRenderCallback, kAudioUnitScope_Global, kOutputBus, &callbackStruct, sizeof(callbackStruct)); + CHECK_AU_ERROR(status, "Error setting input buffer callback"); + status=AudioUnitInitialize(unit); + CHECK_AU_ERROR(status, "Error initializing unit"); +} + +AudioOutputAudioUnitLegacy::~AudioOutputAudioUnitLegacy(){ + AudioObjectPropertyAddress propertyAddress; + propertyAddress.mSelector = kAudioHardwarePropertyDefaultOutputDevice; + propertyAddress.mScope = kAudioObjectPropertyScopeGlobal; + propertyAddress.mElement = kAudioObjectPropertyElementMaster; + AudioObjectRemovePropertyListener(kAudioObjectSystemObject, &propertyAddress, AudioOutputAudioUnitLegacy::DefaultDeviceChangedCallback, this); + + AudioObjectPropertyAddress dataSourceProp={ + kAudioDevicePropertyDataSource, + kAudioDevicePropertyScopeOutput, + kAudioObjectPropertyElementMaster + }; + if(isMacBookPro && sysDevID && AudioObjectHasProperty(sysDevID, &dataSourceProp)){ + AudioObjectRemovePropertyListener(sysDevID, &dataSourceProp, AudioOutputAudioUnitLegacy::DefaultDeviceChangedCallback, this); + } + + AudioUnitUninitialize(unit); + AudioComponentInstanceDispose(unit); +} + +void AudioOutputAudioUnitLegacy::Start(){ + isPlaying=true; + OSStatus status=AudioOutputUnitStart(unit); + CHECK_AU_ERROR(status, "Error starting AudioUnit"); +} + +void AudioOutputAudioUnitLegacy::Stop(){ + isPlaying=false; + OSStatus status=AudioOutputUnitStart(unit); + CHECK_AU_ERROR(status, "Error stopping AudioUnit"); +} + +OSStatus AudioOutputAudioUnitLegacy::BufferCallback(void *inRefCon, AudioUnitRenderActionFlags *ioActionFlags, const AudioTimeStamp *inTimeStamp, UInt32 inBusNumber, UInt32 inNumberFrames, AudioBufferList *ioData){ + AudioOutputAudioUnitLegacy* input=(AudioOutputAudioUnitLegacy*) inRefCon; + input->HandleBufferCallback(ioData); + return noErr; +} + +bool AudioOutputAudioUnitLegacy::IsPlaying(){ + return isPlaying; +} + +void AudioOutputAudioUnitLegacy::HandleBufferCallback(AudioBufferList *ioData){ + int i; + for(i=0;imNumberBuffers;i++){ + AudioBuffer buf=ioData->mBuffers[i]; + if(!isPlaying){ + memset(buf.mData, 0, buf.mDataByteSize); + return; + } + while(remainingDataSize& devs){ + AudioObjectPropertyAddress propertyAddress = { + kAudioHardwarePropertyDevices, + kAudioObjectPropertyScopeGlobal, + kAudioObjectPropertyElementMaster + }; + + UInt32 dataSize = 0; + OSStatus status = AudioObjectGetPropertyDataSize(kAudioObjectSystemObject, &propertyAddress, 0, NULL, &dataSize); + if(kAudioHardwareNoError != status) { + LOGE("AudioObjectGetPropertyDataSize (kAudioHardwarePropertyDevices) failed: %i", status); + return; + } + + UInt32 deviceCount = (UInt32)(dataSize / sizeof(AudioDeviceID)); + + + AudioDeviceID *audioDevices = (AudioDeviceID*)(malloc(dataSize)); + + status = AudioObjectGetPropertyData(kAudioObjectSystemObject, &propertyAddress, 0, NULL, &dataSize, audioDevices); + if(kAudioHardwareNoError != status) { + LOGE("AudioObjectGetPropertyData (kAudioHardwarePropertyDevices) failed: %i", status); + free(audioDevices); + audioDevices = NULL; + return; + } + + + // Iterate through all the devices and determine which are input-capable + propertyAddress.mScope = kAudioDevicePropertyScopeOutput; + for(UInt32 i = 0; i < deviceCount; ++i) { + // Query device UID + CFStringRef deviceUID = NULL; + dataSize = sizeof(deviceUID); + propertyAddress.mSelector = kAudioDevicePropertyDeviceUID; + status = AudioObjectGetPropertyData(audioDevices[i], &propertyAddress, 0, NULL, &dataSize, &deviceUID); + if(kAudioHardwareNoError != status) { + LOGE("AudioObjectGetPropertyData (kAudioDevicePropertyDeviceUID) failed: %i", status); + continue; + } + + // Query device name + CFStringRef deviceName = NULL; + dataSize = sizeof(deviceName); + propertyAddress.mSelector = kAudioDevicePropertyDeviceNameCFString; + status = AudioObjectGetPropertyData(audioDevices[i], &propertyAddress, 0, NULL, &dataSize, &deviceName); + if(kAudioHardwareNoError != status) { + LOGE("AudioObjectGetPropertyData (kAudioDevicePropertyDeviceNameCFString) failed: %i", status); + continue; + } + + // Determine if the device is an input device (it is an input device if it has input channels) + dataSize = 0; + propertyAddress.mSelector = kAudioDevicePropertyStreamConfiguration; + status = AudioObjectGetPropertyDataSize(audioDevices[i], &propertyAddress, 0, NULL, &dataSize); + if(kAudioHardwareNoError != status) { + LOGE("AudioObjectGetPropertyDataSize (kAudioDevicePropertyStreamConfiguration) failed: %i", status); + continue; + } + + AudioBufferList *bufferList = (AudioBufferList*)(malloc(dataSize)); + + status = AudioObjectGetPropertyData(audioDevices[i], &propertyAddress, 0, NULL, &dataSize, bufferList); + if(kAudioHardwareNoError != status || 0 == bufferList->mNumberBuffers) { + if(kAudioHardwareNoError != status) + LOGE("AudioObjectGetPropertyData (kAudioDevicePropertyStreamConfiguration) failed: %i", status); + free(bufferList); + bufferList = NULL; + continue; + } + + free(bufferList); + bufferList = NULL; + + AudioOutputDevice dev; + char buf[1024]; + CFStringGetCString(deviceName, buf, 1024, kCFStringEncodingUTF8); + dev.displayName=std::string(buf); + CFStringGetCString(deviceUID, buf, 1024, kCFStringEncodingUTF8); + dev.id=std::string(buf); + if(dev.id.rfind("VPAUAggregateAudioDevice-0x")==0) + continue; + devs.push_back(dev); + } + + free(audioDevices); + audioDevices = NULL; +} + +void AudioOutputAudioUnitLegacy::SetCurrentDevice(std::string deviceID){ + UInt32 size=sizeof(AudioDeviceID); + AudioDeviceID outputDevice=0; + OSStatus status; + AudioObjectPropertyAddress dataSourceProp={ + kAudioDevicePropertyDataSource, + kAudioDevicePropertyScopeOutput, + kAudioObjectPropertyElementMaster + }; + + if(isMacBookPro && sysDevID && AudioObjectHasProperty(sysDevID, &dataSourceProp)){ + AudioObjectRemovePropertyListener(sysDevID, &dataSourceProp, AudioOutputAudioUnitLegacy::DefaultDeviceChangedCallback, this); + } + + if(deviceID=="default"){ + AudioObjectPropertyAddress propertyAddress; + propertyAddress.mSelector = kAudioHardwarePropertyDefaultOutputDevice; + propertyAddress.mScope = kAudioObjectPropertyScopeGlobal; + propertyAddress.mElement = kAudioObjectPropertyElementMaster; + UInt32 propsize = sizeof(AudioDeviceID); + status = AudioObjectGetPropertyData(kAudioObjectSystemObject, &propertyAddress, 0, NULL, &propsize, &outputDevice); + CHECK_AU_ERROR(status, "Error getting default input device"); + }else{ + AudioObjectPropertyAddress propertyAddress = { + kAudioHardwarePropertyDevices, + kAudioObjectPropertyScopeGlobal, + kAudioObjectPropertyElementMaster + }; + UInt32 dataSize = 0; + status = AudioObjectGetPropertyDataSize(kAudioObjectSystemObject, &propertyAddress, 0, NULL, &dataSize); + CHECK_AU_ERROR(status, "Error getting devices size"); + UInt32 deviceCount = (UInt32)(dataSize / sizeof(AudioDeviceID)); + AudioDeviceID audioDevices[deviceCount]; + status = AudioObjectGetPropertyData(kAudioObjectSystemObject, &propertyAddress, 0, NULL, &dataSize, audioDevices); + CHECK_AU_ERROR(status, "Error getting device list"); + for(UInt32 i = 0; i < deviceCount; ++i) { + // Query device UID + CFStringRef deviceUID = NULL; + dataSize = sizeof(deviceUID); + propertyAddress.mSelector = kAudioDevicePropertyDeviceUID; + status = AudioObjectGetPropertyData(audioDevices[i], &propertyAddress, 0, NULL, &dataSize, &deviceUID); + CHECK_AU_ERROR(status, "Error getting device uid"); + char buf[1024]; + CFStringGetCString(deviceUID, buf, 1024, kCFStringEncodingUTF8); + if(deviceID==buf){ + LOGV("Found device for id %s", buf); + outputDevice=audioDevices[i]; + break; + } + } + if(!outputDevice){ + LOGW("Requested device not found, using default"); + SetCurrentDevice("default"); + return; + } + } + + status =AudioUnitSetProperty(unit, + kAudioOutputUnitProperty_CurrentDevice, + kAudioUnitScope_Global, + kOutputBus, + &outputDevice, + size); + CHECK_AU_ERROR(status, "Error setting output device"); + + AudioStreamBasicDescription hardwareFormat; + size=sizeof(hardwareFormat); + status=AudioUnitGetProperty(unit, kAudioUnitProperty_StreamFormat, kAudioUnitScope_Output, kOutputBus, &hardwareFormat, &size); + CHECK_AU_ERROR(status, "Error getting hardware format"); + hardwareSampleRate=hardwareFormat.mSampleRate; + + AudioStreamBasicDescription desiredFormat={ + .mSampleRate=48000, .mFormatID=kAudioFormatLinearPCM, .mFormatFlags=kAudioFormatFlagIsSignedInteger | kAudioFormatFlagIsPacked | kAudioFormatFlagsNativeEndian, + .mFramesPerPacket=1, .mChannelsPerFrame=1, .mBitsPerChannel=16, .mBytesPerPacket=2, .mBytesPerFrame=2 + }; + + status=AudioUnitSetProperty(unit, kAudioUnitProperty_StreamFormat, kAudioUnitScope_Input, kOutputBus, &desiredFormat, sizeof(desiredFormat)); + CHECK_AU_ERROR(status, "Error setting format"); + + LOGD("Switched playback device, new sample rate %d", hardwareSampleRate); + + this->currentDevice=deviceID; + sysDevID=outputDevice; + + AudioObjectPropertyAddress propertyAddress = { + kAudioDevicePropertyBufferFrameSize, + kAudioObjectPropertyScopeGlobal, + kAudioObjectPropertyElementMaster + }; + size=4; + UInt32 bufferFrameSize; + status=AudioObjectGetPropertyData(outputDevice, &propertyAddress, 0, NULL, &size, &bufferFrameSize); + if(status==noErr){ + estimatedDelay=bufferFrameSize/48; + LOGD("CoreAudio buffer size for output device is %u frames (%u ms)", bufferFrameSize, estimatedDelay); + } + + if(isMacBookPro){ + if(AudioObjectHasProperty(outputDevice, &dataSourceProp)){ + UInt32 dataSource; + size=4; + AudioObjectGetPropertyData(outputDevice, &dataSourceProp, 0, NULL, &size, &dataSource); + SetPanRight(dataSource=='ispk'); + AudioObjectAddPropertyListener(outputDevice, &dataSourceProp, AudioOutputAudioUnitLegacy::DefaultDeviceChangedCallback, this); + }else{ + SetPanRight(false); + } + } +} + +void AudioOutputAudioUnitLegacy::SetPanRight(bool panRight){ + LOGI("%sabling pan right on macbook pro", panRight ? "En" : "Dis"); + int32_t channelMap[]={panRight ? -1 : 0, 0}; + OSStatus status=AudioUnitSetProperty(unit, kAudioOutputUnitProperty_ChannelMap, kAudioUnitScope_Global, kOutputBus, channelMap, sizeof(channelMap)); + CHECK_AU_ERROR(status, "Error setting channel map"); +} + +OSStatus AudioOutputAudioUnitLegacy::DefaultDeviceChangedCallback(AudioObjectID inObjectID, UInt32 inNumberAddresses, const AudioObjectPropertyAddress *inAddresses, void *inClientData){ + AudioOutputAudioUnitLegacy* self=(AudioOutputAudioUnitLegacy*)inClientData; + if(inAddresses[0].mSelector==kAudioHardwarePropertyDefaultOutputDevice){ + LOGV("System default input device changed"); + if(self->currentDevice=="default"){ + self->SetCurrentDevice(self->currentDevice); + } + }else if(inAddresses[0].mSelector==kAudioDevicePropertyDataSource){ + UInt32 dataSource; + UInt32 size=4; + AudioObjectGetPropertyData(inObjectID, inAddresses, 0, NULL, &size, &dataSource); + self->SetPanRight(dataSource=='ispk'); + } + return noErr; +} diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/AudioOutputAudioUnitOSX.h b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioOutputAudioUnitOSX.h new file mode 100644 index 000000000..c4f2b9512 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioOutputAudioUnitOSX.h @@ -0,0 +1,42 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOOUTPUTAUDIOUNIT_OSX_H +#define LIBTGVOIP_AUDIOOUTPUTAUDIOUNIT_OSX_H + +#include +#import +#import +#include "../../audio/AudioOutput.h" + +namespace tgvoip{ namespace audio{ +class AudioOutputAudioUnitLegacy : public AudioOutput{ + +public: + AudioOutputAudioUnitLegacy(std::string deviceID); + virtual ~AudioOutputAudioUnitLegacy(); + virtual void Start(); + virtual void Stop(); + virtual bool IsPlaying(); + void HandleBufferCallback(AudioBufferList* ioData); + static void EnumerateDevices(std::vector& devs); + virtual void SetCurrentDevice(std::string deviceID); + +private: + static OSStatus BufferCallback(void *inRefCon, AudioUnitRenderActionFlags *ioActionFlags, const AudioTimeStamp *inTimeStamp, UInt32 inBusNumber, UInt32 inNumberFrames, AudioBufferList *ioData); + static OSStatus DefaultDeviceChangedCallback(AudioObjectID inObjectID, UInt32 inNumberAddresses, const AudioObjectPropertyAddress *inAddresses, void *inClientData); + void SetPanRight(bool panRight); + unsigned char remainingData[10240]; + size_t remainingDataSize; + bool isPlaying; + AudioUnit unit; + int hardwareSampleRate; + bool isMacBookPro; + AudioDeviceID sysDevID; +}; +}} + +#endif //LIBTGVOIP_AUDIOOUTPUTAUDIOUNIT_OSX_H diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/AudioUnitIO.cpp b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioUnitIO.cpp new file mode 100644 index 000000000..1316b75d2 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioUnitIO.cpp @@ -0,0 +1,321 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// +#include +#include "AudioUnitIO.h" +#include "AudioInputAudioUnit.h" +#include "AudioOutputAudioUnit.h" +#include "../../logging.h" +#include "../../VoIPController.h" +#include "../../VoIPServerConfig.h" + +#define CHECK_AU_ERROR(res, msg) if(res!=noErr){ LOGE(msg": OSStatus=%d", (int)res); failed=true; return; } +#define BUFFER_SIZE 960 // 20 ms + +#if TARGET_OS_OSX +#define INPUT_BUFFER_SIZE 20480 +#else +#define INPUT_BUFFER_SIZE 10240 +#endif + +#define kOutputBus 0 +#define kInputBus 1 + +#if TARGET_OS_OSX && !defined(TGVOIP_NO_OSX_PRIVATE_API) +extern "C" { +OSStatus AudioDeviceDuck(AudioDeviceID inDevice, + Float32 inDuckedLevel, + const AudioTimeStamp* __nullable inStartTime, + Float32 inRampDuration) __attribute__((weak_import)); +} +#endif + +using namespace tgvoip; +using namespace tgvoip::audio; + +AudioUnitIO::AudioUnitIO(std::string inputDeviceID, std::string outputDeviceID){ + input=NULL; + output=NULL; + inputEnabled=false; + outputEnabled=false; + failed=false; + started=false; + inBufferList.mBuffers[0].mData=malloc(INPUT_BUFFER_SIZE); + inBufferList.mBuffers[0].mDataByteSize=INPUT_BUFFER_SIZE; + inBufferList.mNumberBuffers=1; + +#if TARGET_OS_IPHONE + DarwinSpecific::ConfigureAudioSession(); +#endif + + OSStatus status; + AudioComponentDescription desc; + AudioComponent inputComponent; + desc.componentType = kAudioUnitType_Output; + desc.componentSubType = kAudioUnitSubType_VoiceProcessingIO; + desc.componentFlags = 0; + desc.componentFlagsMask = 0; + desc.componentManufacturer = kAudioUnitManufacturer_Apple; + inputComponent = AudioComponentFindNext(NULL, &desc); + status = AudioComponentInstanceNew(inputComponent, &unit); + + UInt32 flag=1; +#if TARGET_OS_IPHONE + status = AudioUnitSetProperty(unit, kAudioOutputUnitProperty_EnableIO, kAudioUnitScope_Output, kOutputBus, &flag, sizeof(flag)); + CHECK_AU_ERROR(status, "Error enabling AudioUnit output"); + status = AudioUnitSetProperty(unit, kAudioOutputUnitProperty_EnableIO, kAudioUnitScope_Input, kInputBus, &flag, sizeof(flag)); + CHECK_AU_ERROR(status, "Error enabling AudioUnit input"); +#endif + +#if TARGET_OS_IPHONE + flag=ServerConfig::GetSharedInstance()->GetBoolean("use_ios_vpio_agc", true) ? 1 : 0; +#else + flag=ServerConfig::GetSharedInstance()->GetBoolean("use_osx_vpio_agc", true) ? 1 : 0; +#endif + status=AudioUnitSetProperty(unit, kAUVoiceIOProperty_VoiceProcessingEnableAGC, kAudioUnitScope_Global, kInputBus, &flag, sizeof(flag)); + CHECK_AU_ERROR(status, "Error disabling AGC"); + + AudioStreamBasicDescription audioFormat; + audioFormat.mSampleRate = 48000; + audioFormat.mFormatID = kAudioFormatLinearPCM; +#if TARGET_OS_IPHONE + audioFormat.mFormatFlags = kAudioFormatFlagIsSignedInteger | kAudioFormatFlagIsPacked | kAudioFormatFlagsNativeEndian; + audioFormat.mBitsPerChannel = 16; + audioFormat.mBytesPerPacket = 2; + audioFormat.mBytesPerFrame = 2; +#else // OS X + audioFormat.mFormatFlags = kAudioFormatFlagIsFloat | kAudioFormatFlagIsPacked | kAudioFormatFlagsNativeEndian; + audioFormat.mBitsPerChannel = 32; + audioFormat.mBytesPerPacket = 4; + audioFormat.mBytesPerFrame = 4; +#endif + audioFormat.mFramesPerPacket = 1; + audioFormat.mChannelsPerFrame = 1; + + status = AudioUnitSetProperty(unit, kAudioUnitProperty_StreamFormat, kAudioUnitScope_Input, kOutputBus, &audioFormat, sizeof(audioFormat)); + CHECK_AU_ERROR(status, "Error setting output format"); + status = AudioUnitSetProperty(unit, kAudioUnitProperty_StreamFormat, kAudioUnitScope_Output, kInputBus, &audioFormat, sizeof(audioFormat)); + CHECK_AU_ERROR(status, "Error setting input format"); + + AURenderCallbackStruct callbackStruct; + + callbackStruct.inputProc = AudioUnitIO::BufferCallback; + callbackStruct.inputProcRefCon = this; + status = AudioUnitSetProperty(unit, kAudioUnitProperty_SetRenderCallback, kAudioUnitScope_Global, kOutputBus, &callbackStruct, sizeof(callbackStruct)); + CHECK_AU_ERROR(status, "Error setting output buffer callback"); + status = AudioUnitSetProperty(unit, kAudioOutputUnitProperty_SetInputCallback, kAudioUnitScope_Global, kInputBus, &callbackStruct, sizeof(callbackStruct)); + CHECK_AU_ERROR(status, "Error setting input buffer callback"); + +#if TARGET_OS_OSX + CFRunLoopRef theRunLoop = NULL; + AudioObjectPropertyAddress propertyAddress = { kAudioHardwarePropertyRunLoop, + kAudioObjectPropertyScopeGlobal, + kAudioObjectPropertyElementMaster }; + status = AudioObjectSetPropertyData(kAudioObjectSystemObject, &propertyAddress, 0, NULL, sizeof(CFRunLoopRef), &theRunLoop); + + propertyAddress.mSelector = kAudioHardwarePropertyDefaultOutputDevice; + propertyAddress.mScope = kAudioObjectPropertyScopeGlobal; + propertyAddress.mElement = kAudioObjectPropertyElementMaster; + AudioObjectAddPropertyListener(kAudioObjectSystemObject, &propertyAddress, AudioUnitIO::DefaultDeviceChangedCallback, this); + propertyAddress.mSelector = kAudioHardwarePropertyDefaultInputDevice; + AudioObjectAddPropertyListener(kAudioObjectSystemObject, &propertyAddress, AudioUnitIO::DefaultDeviceChangedCallback, this); + + +#endif + + + input=new AudioInputAudioUnit(inputDeviceID, this); + output=new AudioOutputAudioUnit(outputDeviceID, this); +} + +AudioUnitIO::~AudioUnitIO(){ +#if TARGET_OS_OSX + AudioObjectPropertyAddress propertyAddress; + propertyAddress.mSelector = kAudioHardwarePropertyDefaultOutputDevice; + propertyAddress.mScope = kAudioObjectPropertyScopeGlobal; + propertyAddress.mElement = kAudioObjectPropertyElementMaster; + AudioObjectRemovePropertyListener(kAudioObjectSystemObject, &propertyAddress, AudioUnitIO::DefaultDeviceChangedCallback, this); + propertyAddress.mSelector = kAudioHardwarePropertyDefaultInputDevice; + AudioObjectRemovePropertyListener(kAudioObjectSystemObject, &propertyAddress, AudioUnitIO::DefaultDeviceChangedCallback, this); +#endif + AudioOutputUnitStop(unit); + AudioUnitUninitialize(unit); + AudioComponentInstanceDispose(unit); + free(inBufferList.mBuffers[0].mData); + delete input; + delete output; +} + +OSStatus AudioUnitIO::BufferCallback(void *inRefCon, AudioUnitRenderActionFlags *ioActionFlags, const AudioTimeStamp *inTimeStamp, UInt32 inBusNumber, UInt32 inNumberFrames, AudioBufferList *ioData){ + ((AudioUnitIO*)inRefCon)->BufferCallback(ioActionFlags, inTimeStamp, inBusNumber, inNumberFrames, ioData); + return noErr; +} + +void AudioUnitIO::BufferCallback(AudioUnitRenderActionFlags *ioActionFlags, const AudioTimeStamp *inTimeStamp, UInt32 bus, UInt32 numFrames, AudioBufferList *ioData){ + if(bus==kOutputBus){ + if(output && outputEnabled){ + output->HandleBufferCallback(ioData); + }else{ + memset(ioData->mBuffers[0].mData, 0, ioData->mBuffers[0].mDataByteSize); + } + }else if(bus==kInputBus){ + inBufferList.mBuffers[0].mDataByteSize=INPUT_BUFFER_SIZE; + AudioUnitRender(unit, ioActionFlags, inTimeStamp, bus, numFrames, &inBufferList); + if(input && inputEnabled){ + input->HandleBufferCallback(&inBufferList); + } + } +} + +void AudioUnitIO::EnableInput(bool enabled){ + inputEnabled=enabled; + StartIfNeeded(); +} + +void AudioUnitIO::EnableOutput(bool enabled){ + outputEnabled=enabled; + StartIfNeeded(); +#if TARGET_OS_OSX && !defined(TGVOIP_NO_OSX_PRIVATE_API) + if(actualDuckingEnabled!=duckingEnabled){ + actualDuckingEnabled=duckingEnabled; + AudioDeviceDuck(currentOutputDeviceID, duckingEnabled ? 0.177828f : 1.0f, NULL, 0.1f); + } +#endif +} + +void AudioUnitIO::StartIfNeeded(){ + if(started) + return; + started=true; + OSStatus status = AudioUnitInitialize(unit); + CHECK_AU_ERROR(status, "Error initializing AudioUnit"); + status=AudioOutputUnitStart(unit); + CHECK_AU_ERROR(status, "Error starting AudioUnit"); +} + +AudioInput* AudioUnitIO::GetInput(){ + return input; +} + +AudioOutput* AudioUnitIO::GetOutput(){ + return output; +} + +#if TARGET_OS_OSX +OSStatus AudioUnitIO::DefaultDeviceChangedCallback(AudioObjectID inObjectID, UInt32 inNumberAddresses, const AudioObjectPropertyAddress *inAddresses, void *inClientData){ + AudioUnitIO* self=(AudioUnitIO*)inClientData; + if(inAddresses[0].mSelector==kAudioHardwarePropertyDefaultOutputDevice){ + LOGV("System default output device changed"); + if(self->currentOutputDevice=="default"){ + self->SetCurrentDevice(false, self->currentOutputDevice); + } + }else if(inAddresses[0].mSelector==kAudioHardwarePropertyDefaultInputDevice){ + LOGV("System default input device changed"); + if(self->currentInputDevice=="default"){ + self->SetCurrentDevice(true, self->currentInputDevice); + } + } + return noErr; +} + +void AudioUnitIO::SetCurrentDevice(bool input, std::string deviceID){ + LOGV("Setting current %sput device: %s", input ? "in" : "out", deviceID.c_str()); + if(started){ + AudioOutputUnitStop(unit); + AudioUnitUninitialize(unit); + } + UInt32 size=sizeof(AudioDeviceID); + AudioDeviceID device=0; + OSStatus status; + + if(deviceID=="default"){ + AudioObjectPropertyAddress propertyAddress; + propertyAddress.mSelector = input ? kAudioHardwarePropertyDefaultInputDevice : kAudioHardwarePropertyDefaultOutputDevice; + propertyAddress.mScope = kAudioObjectPropertyScopeGlobal; + propertyAddress.mElement = kAudioObjectPropertyElementMaster; + UInt32 propsize = sizeof(AudioDeviceID); + status = AudioObjectGetPropertyData(kAudioObjectSystemObject, &propertyAddress, 0, NULL, &propsize, &device); + CHECK_AU_ERROR(status, "Error getting default device"); + }else{ + AudioObjectPropertyAddress propertyAddress = { + kAudioHardwarePropertyDevices, + kAudioObjectPropertyScopeGlobal, + kAudioObjectPropertyElementMaster + }; + UInt32 dataSize = 0; + status = AudioObjectGetPropertyDataSize(kAudioObjectSystemObject, &propertyAddress, 0, NULL, &dataSize); + CHECK_AU_ERROR(status, "Error getting devices size"); + UInt32 deviceCount = (UInt32)(dataSize / sizeof(AudioDeviceID)); + AudioDeviceID audioDevices[deviceCount]; + status = AudioObjectGetPropertyData(kAudioObjectSystemObject, &propertyAddress, 0, NULL, &dataSize, audioDevices); + CHECK_AU_ERROR(status, "Error getting device list"); + for(UInt32 i = 0; i < deviceCount; ++i) { + // Query device UID + CFStringRef deviceUID = NULL; + dataSize = sizeof(deviceUID); + propertyAddress.mSelector = kAudioDevicePropertyDeviceUID; + status = AudioObjectGetPropertyData(audioDevices[i], &propertyAddress, 0, NULL, &dataSize, &deviceUID); + CHECK_AU_ERROR(status, "Error getting device uid"); + char buf[1024]; + CFStringGetCString(deviceUID, buf, 1024, kCFStringEncodingUTF8); + if(deviceID==buf){ + LOGV("Found device for id %s", buf); + device=audioDevices[i]; + break; + } + } + if(!device){ + LOGW("Requested device not found, using default"); + SetCurrentDevice(input, "default"); + return; + } + } + + status=AudioUnitSetProperty(unit, + kAudioOutputUnitProperty_CurrentDevice, + kAudioUnitScope_Global, + input ? kInputBus : kOutputBus, + &device, + size); + CHECK_AU_ERROR(status, "Error setting input device"); + + if(input) + currentInputDevice=deviceID; + else + currentOutputDevice=deviceID; + + /*AudioObjectPropertyAddress propertyAddress = { + kAudioDevicePropertyBufferFrameSize, + kAudioObjectPropertyScopeGlobal, + kAudioObjectPropertyElementMaster + }; + size=4; + UInt32 bufferFrameSize; + status=AudioObjectGetPropertyData(device, &propertyAddress, 0, NULL, &size, &bufferFrameSize); + if(status==noErr){ + estimatedDelay=bufferFrameSize/48; + LOGD("CoreAudio buffer size for device is %u frames (%u ms)", bufferFrameSize, estimatedDelay); + }*/ + if(started){ + started=false; + StartIfNeeded(); + } + if(!input){ + currentOutputDeviceID=device; + } + LOGV("Set current %sput device done", input ? "in" : "out"); +} + +void AudioUnitIO::SetDuckingEnabled(bool enabled){ + duckingEnabled=enabled; +#ifndef TGVOIP_NO_OSX_PRIVATE_API + if(outputEnabled && duckingEnabled!=actualDuckingEnabled){ + actualDuckingEnabled=enabled; + AudioDeviceDuck(currentOutputDeviceID, enabled ? 0.177828f : 1.0f, NULL, 0.1f); + } +#endif +} + +#endif diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/AudioUnitIO.h b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioUnitIO.h new file mode 100644 index 000000000..4cd41b20f --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/AudioUnitIO.h @@ -0,0 +1,58 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOUNITIO_H +#define LIBTGVOIP_AUDIOUNITIO_H + +#include +#include +#include "../../threading.h" +#include +#include +#include "../../audio/AudioIO.h" + +namespace tgvoip{ namespace audio{ +class AudioInputAudioUnit; +class AudioOutputAudioUnit; + + class AudioUnitIO : public AudioIO{ + public: + AudioUnitIO(std::string inputDeviceID, std::string outputDeviceID); + ~AudioUnitIO(); + void EnableInput(bool enabled); + void EnableOutput(bool enabled); + virtual AudioInput* GetInput(); + virtual AudioOutput* GetOutput(); +#if TARGET_OS_OSX + void SetCurrentDevice(bool input, std::string deviceID); + void SetDuckingEnabled(bool enabled); +#endif + + private: + static OSStatus BufferCallback(void *inRefCon, AudioUnitRenderActionFlags *ioActionFlags, const AudioTimeStamp *inTimeStamp, UInt32 inBusNumber, UInt32 inNumberFrames, AudioBufferList *ioData); + void BufferCallback(AudioUnitRenderActionFlags *ioActionFlags, const AudioTimeStamp *inTimeStamp, UInt32 bus, UInt32 numFrames, AudioBufferList* ioData); + void StartIfNeeded(); +#if TARGET_OS_OSX + static OSStatus DefaultDeviceChangedCallback(AudioObjectID inObjectID, UInt32 inNumberAddresses, const AudioObjectPropertyAddress *inAddresses, void *inClientData); + std::string currentInputDevice; + std::string currentOutputDevice; + bool duckingEnabled=true; +#ifndef TGVOIP_NO_OSX_PRIVATE_API + bool actualDuckingEnabled=true; +#endif // TGVOIP_NO_OSX_PRIVATE_API + AudioDeviceID currentOutputDeviceID; +#endif + AudioComponentInstance unit; + AudioInputAudioUnit* input; + AudioOutputAudioUnit* output; + AudioBufferList inBufferList; + std::atomic inputEnabled; + std::atomic outputEnabled; + bool started; + }; +}} + +#endif /* LIBTGVOIP_AUDIOUNITIO_H */ diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/DarwinSpecific.h b/TMessagesProj/jni/libtgvoip2/os/darwin/DarwinSpecific.h new file mode 100644 index 000000000..a59ce4d77 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/DarwinSpecific.h @@ -0,0 +1,32 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef TGVOIP_DARWINSPECIFIC_H +#define TGVOIP_DARWINSPECIFIC_H + +#include + +namespace tgvoip { + + struct CellularCarrierInfo; + +class DarwinSpecific{ +public: + enum{ + THREAD_PRIO_USER_INTERACTIVE, + THREAD_PRIO_USER_INITIATED, + THREAD_PRIO_UTILITY, + THREAD_PRIO_BACKGROUND, + THREAD_PRIO_DEFAULT + }; + static void GetSystemName(char* buf, size_t len); + static void SetCurrentThreadPriority(int priority); + static CellularCarrierInfo GetCarrierInfo(); + static void ConfigureAudioSession(); +}; +} + +#endif //TGVOIP_DARWINSPECIFIC_H diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/DarwinSpecific.mm b/TMessagesProj/jni/libtgvoip2/os/darwin/DarwinSpecific.mm new file mode 100644 index 000000000..e0fb63dbd --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/DarwinSpecific.mm @@ -0,0 +1,110 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "DarwinSpecific.h" +#include "../../VoIPController.h" +#include "../../logging.h" + +#import +#if TARGET_OS_IOS +#import +#import +#import +#endif + +using namespace tgvoip; + +void DarwinSpecific::GetSystemName(char* buf, size_t len){ + NSString* v=[[NSProcessInfo processInfo] operatingSystemVersionString]; + strcpy(buf, [v UTF8String]); + //[v getCString:buf maxLength:sizeof(buf) encoding:NSUTF8StringEncoding]; +} + +void DarwinSpecific::SetCurrentThreadPriority(int priority){ + NSThread* thread=[NSThread currentThread]; + if([thread respondsToSelector:@selector(setQualityOfService:)]){ + NSQualityOfService qos; + switch(priority){ + case THREAD_PRIO_USER_INTERACTIVE: + qos=NSQualityOfServiceUserInteractive; + break; + case THREAD_PRIO_USER_INITIATED: + qos=NSQualityOfServiceUserInitiated; + break; + case THREAD_PRIO_UTILITY: + qos=NSQualityOfServiceUtility; + break; + case THREAD_PRIO_BACKGROUND: + qos=NSQualityOfServiceBackground; + break; + case THREAD_PRIO_DEFAULT: + default: + qos=NSQualityOfServiceDefault; + break; + } + [thread setQualityOfService:qos]; + }else{ + double p; + switch(priority){ + case THREAD_PRIO_USER_INTERACTIVE: + p=1.0; + break; + case THREAD_PRIO_USER_INITIATED: + p=0.8; + break; + case THREAD_PRIO_UTILITY: + p=0.4; + break; + case THREAD_PRIO_BACKGROUND: + p=0.2; + break; + case THREAD_PRIO_DEFAULT: + default: + p=0.5; + break; + } + [NSThread setThreadPriority:p]; + } +} + +CellularCarrierInfo DarwinSpecific::GetCarrierInfo(){ + CellularCarrierInfo info; +#if TARGET_OS_IOS + CTTelephonyNetworkInfo* netinfo=[CTTelephonyNetworkInfo new]; + CTCarrier* carrier=[netinfo subscriberCellularProvider]; + if(carrier){ + NSString* name=[carrier carrierName]; + NSString* mcc=[carrier mobileCountryCode]; + NSString* mnc=[carrier mobileNetworkCode]; + NSString* countryCode=[carrier isoCountryCode]; + if(name && mcc && mnc && countryCode){ + info.name=[name cStringUsingEncoding:NSUTF8StringEncoding]; + info.mcc=[mcc cStringUsingEncoding:NSUTF8StringEncoding]; + info.mnc=[mnc cStringUsingEncoding:NSUTF8StringEncoding]; + info.countryCode=[[countryCode uppercaseString] cStringUsingEncoding:NSUTF8StringEncoding]; + } + } +#endif + return info; +} + +void DarwinSpecific::ConfigureAudioSession(){ +#if TARGET_OS_IOS + AVAudioSession* session=[AVAudioSession sharedInstance]; + NSError* error=nil; + [session setPreferredSampleRate:48000.0 error:&error]; + if(error){ + LOGE("Failed to set preferred sample rate on AVAudioSession: %s", [[error localizedDescription] cStringUsingEncoding:NSUTF8StringEncoding]); + return; + } + [session setPreferredIOBufferDuration:0.020 error:&error]; + if(error){ + LOGE("Failed to set preferred IO buffer duration on AVAudioSession: %s", [[error localizedDescription] cStringUsingEncoding:NSUTF8StringEncoding]); + return; + } + LOGI("Configured AVAudioSession: sampleRate=%f, IOBufferDuration=%f", session.sampleRate, session.IOBufferDuration); +#endif +} diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/SampleBufferDisplayLayerRenderer.h b/TMessagesProj/jni/libtgvoip2/os/darwin/SampleBufferDisplayLayerRenderer.h new file mode 100644 index 000000000..52e668d1f --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/SampleBufferDisplayLayerRenderer.h @@ -0,0 +1,43 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef TGVOIP_SAMPLEBUFFERDISPLAYLAYERRENDERER +#define TGVOIP_SAMPLEBUFFERDISPLAYLAYERRENDERER + +#include "../../video/VideoRenderer.h" +#include +#include +#include + +#ifdef __OBJC__ +@class TGVVideoRenderer; +#else +typedef struct objc_object TGVVideoRenderer; +#endif + +namespace tgvoip{ + namespace video{ + class SampleBufferDisplayLayerRenderer : public VideoRenderer{ + public: + SampleBufferDisplayLayerRenderer(TGVVideoRenderer* renderer); + virtual ~SampleBufferDisplayLayerRenderer(); + virtual void Reset(uint32_t codec, unsigned int width, unsigned int height, std::vector& csd) override; + virtual void DecodeAndDisplay(Buffer frame, uint32_t pts) override; + virtual void SetStreamEnabled(bool enabled) override; + virtual void SetRotation(uint16_t rotation) override; + virtual void SetStreamPaused(bool paused) override; + static int GetMaximumResolution(); + static std::vector GetAvailableDecoders(); + private: + TGVVideoRenderer* renderer; + CMFormatDescriptionRef formatDesc=NULL; + bool needReset=false; + bool streamEnabled=false; + }; + } +} + +#endif /* TGVOIP_SAMPLEBUFFERDISPLAYLAYERRENDERER */ diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/SampleBufferDisplayLayerRenderer.mm b/TMessagesProj/jni/libtgvoip2/os/darwin/SampleBufferDisplayLayerRenderer.mm new file mode 100644 index 000000000..33dd9f9aa --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/SampleBufferDisplayLayerRenderer.mm @@ -0,0 +1,175 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include +#if TARGET_OS_IPHONE +#include +#endif +#include "SampleBufferDisplayLayerRenderer.h" +#include "../../PrivateDefines.h" +#include "../../logging.h" +#include "TGVVideoRenderer.h" + +using namespace tgvoip; +using namespace tgvoip::video; + +SampleBufferDisplayLayerRenderer::SampleBufferDisplayLayerRenderer(TGVVideoRenderer* renderer) : renderer(renderer){ + +} + +SampleBufferDisplayLayerRenderer::~SampleBufferDisplayLayerRenderer(){ + +} + +void SampleBufferDisplayLayerRenderer::Reset(uint32_t codec, unsigned int width, unsigned int height, std::vector& csd){ + LOGI("video renderer reset: %d x %d", width, height); + if(formatDesc){ + CFRelease(formatDesc); + } + if(codec==CODEC_AVC){ + if(csd.size()!=2){ + LOGE("H264 requires exactly 2 CSD buffers"); + return; + } + const uint8_t* params[]={*csd[0]+4, *csd[1]+4}; + size_t paramSizes[]={csd[0].Length()-4, csd[1].Length()-4}; + OSStatus status=CMVideoFormatDescriptionCreateFromH264ParameterSets(NULL, 2, params, paramSizes, 4, &formatDesc); + if(status!=noErr){ + LOGE("CMVideoFormatDescriptionCreateFromH264ParameterSets failed: %d", status); + return; + } + CGRect rect=CMVideoFormatDescriptionGetCleanAperture(formatDesc, true); + LOGI("size from formatDesc: %f x %f", rect.size.width, rect.size.height); + }else if(codec==CODEC_HEVC){ + if(@available(iOS 11.0, *)){ + if(csd.size()!=1){ + LOGE("HEVC requires exactly 1 CSD buffer"); + return; + } + int offsets[]={0, 0, 0}; + Buffer& buf=csd[0]; + int currentNAL=0; + for(int i=0;i nalStartOffsets; + uint8_t* _data=*frame; + for(uint32_t offset=0;offset> 24), (uint8_t)(length >> 16), (uint8_t)(length >> 8), (uint8_t)length}; + out.WriteBytes(lenBytes, 4); + out.WriteBytes(frame, nalStartOffsets[i], length); + } + + CMBlockBufferRef blockBuffer; + + OSStatus status=CMBlockBufferCreateWithMemoryBlock(kCFAllocatorDefault, out.GetBuffer(), out.GetLength(), kCFAllocatorNull, NULL, 0, out.GetLength(), 0, &blockBuffer); + if(status!=noErr){ + LOGE("CMBlockBufferCreateWithMemoryBlock failed: %d", status); + return; + } + CMSampleBufferRef sampleBuffer; + status=CMSampleBufferCreate(kCFAllocatorDefault, blockBuffer, true, NULL, NULL, formatDesc, 1, 0, NULL, 0, NULL, &sampleBuffer); + if(status!=noErr){ + LOGE("CMSampleBufferCreate failed: %d", status); + return; + } + + CFRelease(blockBuffer); + CFArrayRef attachments=CMSampleBufferGetSampleAttachmentsArray(sampleBuffer, true); + CFMutableDictionaryRef dict=(CFMutableDictionaryRef)CFArrayGetValueAtIndex(attachments, 0); + CFDictionarySetValue(dict, kCMSampleAttachmentKey_DisplayImmediately, kCFBooleanTrue); + + [renderer _enqueueBuffer:sampleBuffer reset:needReset]; + needReset=false; + CFRelease(sampleBuffer); +} + +void SampleBufferDisplayLayerRenderer::SetStreamEnabled(bool enabled){ + if(enabled!=streamEnabled){ + streamEnabled=enabled; + if(enabled){ + [renderer _setResumed]; + }else{ + [renderer _setStopped]; + } + } +} + +int SampleBufferDisplayLayerRenderer::GetMaximumResolution(){ +#if TARGET_OS_IPHONE + CGRect screenSize=[UIScreen mainScreen].nativeBounds; + CGFloat minSize=std::min(screenSize.size.width, screenSize.size.height); + if(minSize>720.f){ + return INIT_VIDEO_RES_1080; + }else if(minSize>480.f){ + return INIT_VIDEO_RES_720; + }else{ + return INIT_VIDEO_RES_480; + } +#else // OS X + // TODO support OS X +#endif + return INIT_VIDEO_RES_1080; +} + +void SampleBufferDisplayLayerRenderer::SetRotation(uint16_t rotation){ + [renderer _setRotation:rotation]; +} + +void SampleBufferDisplayLayerRenderer::SetStreamPaused(bool paused){ + if(paused){ + [renderer _setPaused]; + }else if(streamEnabled){ + [renderer _setResumed]; + } +} + +std::vector SampleBufferDisplayLayerRenderer::GetAvailableDecoders(){ + std::vector res; + res.push_back(CODEC_AVC); + if(@available(iOS 11.0, *)){ + if(VTIsHardwareDecodeSupported(kCMVideoCodecType_HEVC)){ + res.push_back(CODEC_HEVC); + } + } + return res; +} diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/SetupLogging.h b/TMessagesProj/jni/libtgvoip2/os/darwin/SetupLogging.h new file mode 100644 index 000000000..ad10754e4 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/SetupLogging.h @@ -0,0 +1,3 @@ +#import + +extern void (*TGVoipLoggingFunction)(NSString *); diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/TGLogWrapper.h b/TMessagesProj/jni/libtgvoip2/os/darwin/TGLogWrapper.h new file mode 100644 index 000000000..289577e05 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/TGLogWrapper.h @@ -0,0 +1,20 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef TGVOIP_TGLOGWRAPPER_H +#define TGVOIP_TGLOGWRAPPER_H + +#if defined __cplusplus +extern "C" { +#endif + +void __tgvoip_call_tglog(const char* format, ...); + +#if defined __cplusplus +}; +#endif + +#endif //TGVOIP_TGLOGWRAPPER_H diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/TGLogWrapper.m b/TMessagesProj/jni/libtgvoip2/os/darwin/TGLogWrapper.m new file mode 100644 index 000000000..4739ec8e4 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/TGLogWrapper.m @@ -0,0 +1,13 @@ +#import + +void (*TGVoipLoggingFunction)(NSString *) = NULL; + +void __tgvoip_call_tglog(const char* format, ...){ + va_list args; + va_start(args, format); + NSString *string = [[NSString alloc] initWithFormat:[[NSString alloc]initWithUTF8String:format] arguments:args]; + va_end(args); + if (TGVoipLoggingFunction) { + TGVoipLoggingFunction(string); + } +} diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/TGVVideoRenderer.h b/TMessagesProj/jni/libtgvoip2/os/darwin/TGVVideoRenderer.h new file mode 100644 index 000000000..d7bc7f476 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/TGVVideoRenderer.h @@ -0,0 +1,48 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#import +#import + +namespace tgvoip{ +namespace video{ +class VideoRenderer; +} +} + +typedef NS_ENUM(int, TGVStreamPauseReason){ + TGVStreamPauseReasonBackground, + TGVStreamPauseReasonPoorConnection +}; + +typedef NS_ENUM(int, TGVStreamStopReason){ + TGVStreamStopReasonUser, + TGVStreamStopReasonPoorConnection +}; + +@protocol TGVVideoRendererDelegate + +- (void)incomingVideoRotationDidChange: (int)rotation; +- (void)incomingVideoStreamWillStartWithFrameSize: (CGSize)size; +- (void)incomingVideoStreamDidStopWithReason: (TGVStreamStopReason)reason; +- (void)incomingVideoStreamDidPauseWithReason: (TGVStreamPauseReason)reason; +- (void)incomingVideoStreamWillResume; + +@end + +@interface TGVVideoRenderer : NSObject + +- (instancetype)initWithDisplayLayer: (AVSampleBufferDisplayLayer *)layer delegate: (id)delegate; +- (tgvoip::video::VideoRenderer*)nativeVideoRenderer; + +- (void)_enqueueBuffer: (CMSampleBufferRef)buffer reset: (BOOL)reset; +- (void)_setSizeWidth: (uint16_t)width height: (uint16_t)height; +- (void)_setRotation: (uint16_t)rotation; +- (void)_setStopped; +- (void)_setPaused; +- (void)_setResumed; + +@end diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/TGVVideoRenderer.mm b/TMessagesProj/jni/libtgvoip2/os/darwin/TGVVideoRenderer.mm new file mode 100644 index 000000000..a2a8cb59b --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/TGVVideoRenderer.mm @@ -0,0 +1,81 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#import "TGVVideoRenderer.h" +#include "SampleBufferDisplayLayerRenderer.h" +#include "../../logging.h" + +@implementation TGVVideoRenderer{ + AVSampleBufferDisplayLayer* layer; + id delegate; + tgvoip::video::SampleBufferDisplayLayerRenderer* nativeRenderer; +} + +- (instancetype)initWithDisplayLayer:(AVSampleBufferDisplayLayer *)layer delegate:(nonnull id)delegate{ + self=[super init]; + self->layer=layer; + self->delegate=delegate; + nativeRenderer=new tgvoip::video::SampleBufferDisplayLayerRenderer(self); + layer.videoGravity=AVLayerVideoGravityResizeAspect; + return self; +} + +- (void)dealloc{ + delete nativeRenderer; +} + +- (tgvoip::video::VideoRenderer *)nativeVideoRenderer{ + return nativeRenderer; +} + +- (void)_enqueueBuffer: (CMSampleBufferRef)buffer reset: (BOOL)reset{ + /*if(reset){ + LOGV("Resetting layer"); + [layer flush]; + }*/ + LOGV("Enqueue buffer"); + [layer enqueueSampleBuffer:buffer]; + NSError* error=[layer error]; + if(error){ + LOGE("enqueueSampleBuffer failed: %s", [error.description cStringUsingEncoding:NSUTF8StringEncoding]); + } +} + +- (void)_setSizeWidth: (uint16_t)width height: (uint16_t)height{ + dispatch_async(dispatch_get_main_queue(), ^{ + LOGI("Callback: setSize %u %u", width, height); + [delegate incomingVideoStreamWillStartWithFrameSize:CGSizeMake(width, height)]; + }); +} + +- (void)_setRotation: (uint16_t)rotation{ + dispatch_async(dispatch_get_main_queue(), ^{ + LOGI("Callback: setRotation %u", rotation); + [delegate incomingVideoRotationDidChange:(int)rotation]; + }); +} + +- (void)_setStopped{ + dispatch_async(dispatch_get_main_queue(), ^{ + LOGI("Callback: setStopped"); + [delegate incomingVideoStreamDidStopWithReason:TGVStreamStopReasonUser]; + }); +} + +- (void)_setPaused{ + dispatch_async(dispatch_get_main_queue(), ^{ + LOGI("Callback: setPaused"); + [delegate incomingVideoStreamDidPauseWithReason:TGVStreamPauseReasonBackground]; + }); +} + +- (void)_setResumed{ + dispatch_async(dispatch_get_main_queue(), ^{ + LOGI("Callback: setResumed"); + [delegate incomingVideoStreamWillResume]; + }); +} +@end diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/TGVVideoSource.h b/TMessagesProj/jni/libtgvoip2/os/darwin/TGVVideoSource.h new file mode 100644 index 000000000..1a3ff7b29 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/TGVVideoSource.h @@ -0,0 +1,41 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#import +#import + +namespace tgvoip{ +namespace video{ +class VideoSource; +} +} + +typedef NS_ENUM(int, TGVVideoResolution){ + TGVVideoResolution1080, + TGVVideoResolution720, + TGVVideoResolution480, + TGVVideoResolution360 +}; + +@protocol TGVVideoSourceDelegate + +- (void)setFrameRate: (unsigned int)frameRate; + +@end + +@interface TGVVideoSource : NSObject + +- (instancetype)initWithDelegate: (id)delegate; +- (void)sendVideoFrame: (CMSampleBufferRef)buffer; +- (TGVVideoResolution)maximumSupportedVideoResolution; +- (void)setVideoRotation: (unsigned int)rotation; +- (void)pauseStream; +- (void)resumeStream; +- (tgvoip::video::VideoSource*)nativeVideoSource; + +- (void)_requestFrameRate: (unsigned int)frameRate; + +@end diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/TGVVideoSource.mm b/TMessagesProj/jni/libtgvoip2/os/darwin/TGVVideoSource.mm new file mode 100644 index 000000000..8aecdb5b5 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/TGVVideoSource.mm @@ -0,0 +1,57 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#import "TGVVideoSource.h" +#include "VideoToolboxEncoderSource.h" + +@implementation TGVVideoSource{ + tgvoip::video::VideoToolboxEncoderSource* nativeSource; + id delegate; +} + + +- (instancetype)initWithDelegate: (id)delegate{ + self=[super init]; + nativeSource=new tgvoip::video::VideoToolboxEncoderSource(self); + self->delegate=delegate; + return self; +} + +- (void)dealloc{ + delete nativeSource; +} + +- (void)sendVideoFrame: (CMSampleBufferRef)buffer{ + nativeSource->EncodeFrame(buffer); +} + +- (TGVVideoResolution)maximumSupportedVideoResolution{ + return tgvoip::video::VideoToolboxEncoderSource::SupportsFullHD() ? TGVVideoResolution1080 : TGVVideoResolution720; +} + +- (void)setVideoRotation: (unsigned int)rotation{ + nativeSource->SetRotation(rotation); +} + +- (void)pauseStream{ + nativeSource->SetStreamPaused(true); +} + +- (void)resumeStream{ + nativeSource->SetStreamPaused(false); +} + +- (tgvoip::video::VideoSource*)nativeVideoSource{ + return nativeSource; +} + +- (void)_requestFrameRate: (unsigned int)frameRate{ + dispatch_async(dispatch_get_main_queue(), ^{ + [delegate setFrameRate:frameRate]; + }); +} + +@end diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/VideoToolboxEncoderSource.h b/TMessagesProj/jni/libtgvoip2/os/darwin/VideoToolboxEncoderSource.h new file mode 100644 index 000000000..c8cc86a75 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/VideoToolboxEncoderSource.h @@ -0,0 +1,51 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_VIDEOTOOLBOXENCODERSOURCE +#define LIBTGVOIP_VIDEOTOOLBOXENCODERSOURCE + +#include "../../video/VideoSource.h" +#include +#include +#include + +#ifdef __OBJC__ +@class TGVVideoSource; +#else +typedef struct objc_object TGVVideoSource; +#endif + +namespace tgvoip{ + namespace video{ + class VideoToolboxEncoderSource : public VideoSource{ + public: + VideoToolboxEncoderSource(TGVVideoSource* parent); + virtual ~VideoToolboxEncoderSource(); + virtual void Start() override; + virtual void Stop() override; + virtual void Reset(uint32_t codec, int maxResolution) override; + virtual void RequestKeyFrame() override; + virtual void SetBitrate(uint32_t bitrate) override; + void EncodeFrame(CMSampleBufferRef frame); + void SetStreamPaused(bool paused); + static std::vector GetAvailableEncoders(); + static bool SupportsFullHD(); + private: + void EncoderCallback(OSStatus status, CMSampleBufferRef buffer, VTEncodeInfoFlags flags); + void SetEncoderBitrateAndLimit(uint32_t bitrate); + bool needUpdateStreamParams=true; + uint32_t codec=0; + VTCompressionSessionRef session=NULL; + bool keyframeRequested=false; + uint32_t bitrateChangeRequested=0; + uint32_t lastBitrate=512*1024; + unsigned int lastFrameRate=0; + TGVVideoSource* objcObject; + }; + } +} + +#endif /* LIBTGVOIP_VIDEOTOOLBOXENCODERSOURCE */ diff --git a/TMessagesProj/jni/libtgvoip2/os/darwin/VideoToolboxEncoderSource.mm b/TMessagesProj/jni/libtgvoip2/os/darwin/VideoToolboxEncoderSource.mm new file mode 100644 index 000000000..6c4ff48f8 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/darwin/VideoToolboxEncoderSource.mm @@ -0,0 +1,275 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#import +#import "TGVVideoSource.h" +#include "VideoToolboxEncoderSource.h" +#include "../../PrivateDefines.h" +#include "../../logging.h" + +using namespace tgvoip; +using namespace tgvoip::video; + +#define CHECK_ERR(err, msg) if(err!=noErr){LOGE("VideoToolboxEncoder: " msg " failed: %d", err); return;} + +VideoToolboxEncoderSource::VideoToolboxEncoderSource(TGVVideoSource* parent){ + objcObject=parent; +} + +VideoToolboxEncoderSource::~VideoToolboxEncoderSource(){ + if(session){ + CFRelease(session); + session=NULL; + } +} + +void VideoToolboxEncoderSource::Start(){ + +} + +void VideoToolboxEncoderSource::Stop(){ + +} + +void VideoToolboxEncoderSource::Reset(uint32_t codec, int maxResolution){ + if(session){ + LOGV("Releasing old compression session"); + //VTCompressionSessionCompleteFrames(session, kCMTimeInvalid); + VTCompressionSessionInvalidate(session); + CFRelease(session); + session=NULL; + LOGV("Released compression session"); + } + CMVideoCodecType codecType; + switch(codec){ + case CODEC_AVC: + codecType=kCMVideoCodecType_H264; + break; + case CODEC_HEVC: + codecType=kCMVideoCodecType_HEVC; + break; + default: + LOGE("VideoToolboxEncoder: Unsupported codec"); + return; + } + needUpdateStreamParams=true; + this->codec=codec; + // typedef void (*VTCompressionOutputCallback)(void *outputCallbackRefCon, void *sourceFrameRefCon, OSStatus status, VTEncodeInfoFlags infoFlags, CMSampleBufferRef sampleBuffer); + uint32_t width, height; + switch(maxResolution){ + case INIT_VIDEO_RES_1080: + width=1920; + height=1080; + break; + case INIT_VIDEO_RES_720: + width=1280; + height=720; + break; + case INIT_VIDEO_RES_480: + width=854; + height=480; + break; + case INIT_VIDEO_RES_360: + default: + width=640; + height=360; + break; + } + unsigned int targetFrameRate=15; + if(codec==CODEC_HEVC && maxResolution>=INIT_VIDEO_RES_720) + targetFrameRate=30; + if(lastFrameRate!=targetFrameRate){ + lastFrameRate=targetFrameRate; + [objcObject _requestFrameRate:targetFrameRate]; + } + + OSStatus status=VTCompressionSessionCreate(NULL, width, height, codecType, NULL, NULL, NULL, [](void *outputCallbackRefCon, void *sourceFrameRefCon, OSStatus status, VTEncodeInfoFlags infoFlags, CMSampleBufferRef sampleBuffer){ + reinterpret_cast(outputCallbackRefCon)->EncoderCallback(status, sampleBuffer, infoFlags); + }, this, &session); + if(status!=noErr){ + LOGE("VTCompressionSessionCreate failed: %d", status); + return; + } + LOGD("Created VTCompressionSession"); + status=VTSessionSetProperty(session, kVTCompressionPropertyKey_AllowFrameReordering, kCFBooleanFalse); + CHECK_ERR(status, "VTSessionSetProperty(AllowFrameReordering)"); + int64_t interval=5; + status=VTSessionSetProperty(session, kVTCompressionPropertyKey_MaxKeyFrameIntervalDuration, (__bridge CFTypeRef)@(interval)); + CHECK_ERR(status, "VTSessionSetProperty(MaxKeyFrameIntervalDuration)"); + SetEncoderBitrateAndLimit(lastBitrate); + status=VTSessionSetProperty(session, kVTCompressionPropertyKey_RealTime, kCFBooleanTrue); + CHECK_ERR(status, "VTSessionSetProperty(RealTime)"); + LOGD("VTCompressionSession initialized"); + + // TODO change camera frame rate dynamically based on resolution + codec +} + +void VideoToolboxEncoderSource::RequestKeyFrame(){ + keyframeRequested=true; +} + +void VideoToolboxEncoderSource::EncodeFrame(CMSampleBufferRef frame){ + if(!session) + return; + CMFormatDescriptionRef format=CMSampleBufferGetFormatDescription(frame); + CMMediaType type=CMFormatDescriptionGetMediaType(format); + if(type!=kCMMediaType_Video){ + //LOGW("Received non-video CMSampleBuffer"); + return; + } + if(bitrateChangeRequested){ + LOGI("VideoToolboxEocnder: setting bitrate to %u", bitrateChangeRequested); + SetEncoderBitrateAndLimit(bitrateChangeRequested); + lastBitrate=bitrateChangeRequested; + bitrateChangeRequested=0; + } + CFDictionaryRef frameProps=NULL; + if(keyframeRequested){ + LOGI("VideoToolboxEncoder: requesting keyframe"); + const void* keys[]={kVTEncodeFrameOptionKey_ForceKeyFrame}; + const void* values[]={kCFBooleanTrue}; + frameProps=CFDictionaryCreate(NULL, keys, values, 1, NULL, NULL); + keyframeRequested=false; + } + + //CMVideoDimensions size=CMVideoFormatDescriptionGetDimensions(format); + //LOGD("EncodeFrame %d x %d", size.width, size.height); + CVImageBufferRef imgBuffer=CMSampleBufferGetImageBuffer(frame); + //OSType pixFmt=CVPixelBufferGetPixelFormatType(imgBuffer); + //LOGV("pixel format: %c%c%c%c", PRINT_FOURCC(pixFmt)); + OSStatus status=VTCompressionSessionEncodeFrame(session, imgBuffer, CMSampleBufferGetPresentationTimeStamp(frame), CMSampleBufferGetDuration(frame), frameProps, NULL, NULL); + CHECK_ERR(status, "VTCompressionSessionEncodeFrame"); + if(frameProps) + CFRelease(frameProps); +} + +void VideoToolboxEncoderSource::SetBitrate(uint32_t bitrate){ + bitrateChangeRequested=bitrate; +} + +void VideoToolboxEncoderSource::EncoderCallback(OSStatus status, CMSampleBufferRef buffer, VTEncodeInfoFlags flags){ + if(status!=noErr){ + LOGE("EncoderCallback error: %d", status); + return; + } + if(flags & kVTEncodeInfo_FrameDropped){ + LOGW("VideoToolboxEncoder: Frame dropped"); + } + if(!CMSampleBufferGetNumSamples(buffer)){ + LOGW("Empty CMSampleBuffer"); + return; + } + if(!callback){ + return; + } + const uint8_t startCode[]={0, 0, 0, 1}; + if(needUpdateStreamParams){ + LOGI("VideoToolboxEncoder: Updating stream params"); + CMFormatDescriptionRef format=CMSampleBufferGetFormatDescription(buffer); + CMVideoDimensions size=CMVideoFormatDescriptionGetDimensions(format); + width=size.width; + height=size.height; + csd.clear(); + if(codec==CODEC_AVC){ + for(size_t i=0;i<2;i++){ + const uint8_t* ps=NULL; + size_t pl=0; + status=CMVideoFormatDescriptionGetH264ParameterSetAtIndex(format, i, &ps, &pl, NULL, NULL); + CHECK_ERR(status, "CMVideoFormatDescriptionGetH264ParameterSetAtIndex"); + Buffer b(pl+4); + b.CopyFrom(ps, 4, pl); + b.CopyFrom(startCode, 0, 4); + csd.push_back(std::move(b)); + } + }else if(codec==CODEC_HEVC){ + BufferOutputStream csdBuf(1024); + for(size_t i=0;i<3;i++){ + const uint8_t* ps=NULL; + size_t pl=0; + status=CMVideoFormatDescriptionGetHEVCParameterSetAtIndex(format, i, &ps, &pl, NULL, NULL); + CHECK_ERR(status, "CMVideoFormatDescriptionGetHEVCParameterSetAtIndex"); + csdBuf.WriteBytes(startCode, 4); + csdBuf.WriteBytes(ps, pl); + } + csd.push_back(std::move(csdBuf)); + } + needUpdateStreamParams=false; + } + CMBlockBufferRef blockBuffer=CMSampleBufferGetDataBuffer(buffer); + size_t len=CMBlockBufferGetDataLength(blockBuffer); + + int frameFlags=0; + CFArrayRef attachmentsArray=CMSampleBufferGetSampleAttachmentsArray(buffer, 0); + if(attachmentsArray && CFArrayGetCount(attachmentsArray)){ + CFBooleanRef notSync; + CFDictionaryRef dict=(CFDictionaryRef)CFArrayGetValueAtIndex(attachmentsArray, 0); + BOOL keyExists=CFDictionaryGetValueIfPresent(dict, kCMSampleAttachmentKey_NotSync, (const void **)¬Sync); + if(!keyExists || !CFBooleanGetValue(notSync)){ + frameFlags |= VIDEO_FRAME_FLAG_KEYFRAME; + } + }else{ + frameFlags |= VIDEO_FRAME_FLAG_KEYFRAME; + } + + Buffer frame(len); + CMBlockBufferCopyDataBytes(blockBuffer, 0, len, *frame); + uint32_t offset=0; + while(offset(*frame+offset)); + //LOGV("NAL length %u", nalLen); + frame.CopyFrom(startCode, offset, 4); + offset+=nalLen+4; + } + callback(std::move(frame), frameFlags, rotation); + + //LOGV("EncoderCallback: %u bytes total", (unsigned int)len); +} + +void VideoToolboxEncoderSource::SetEncoderBitrateAndLimit(uint32_t bitrate){ + OSStatus status=VTSessionSetProperty(session, kVTCompressionPropertyKey_AverageBitRate, (__bridge CFTypeRef)@(bitrate)); + CHECK_ERR(status, "VTSessionSetProperty(AverageBitRate)"); + + int64_t dataLimitValue=(int64_t)(bitrate/8); + CFNumberRef bytesPerSecond=CFNumberCreate(kCFAllocatorDefault, kCFNumberSInt64Type, &dataLimitValue); + int64_t oneValue=1; + CFNumberRef one=CFNumberCreate(kCFAllocatorDefault, kCFNumberSInt64Type, &oneValue); + const void* numbers[]={bytesPerSecond, one}; + CFArrayRef limits=CFArrayCreate(NULL, numbers, 2, &kCFTypeArrayCallBacks); + status=VTSessionSetProperty(session, kVTCompressionPropertyKey_DataRateLimits, limits); + CFRelease(bytesPerSecond); + CFRelease(one); + CFRelease(limits); + CHECK_ERR(status, "VTSessionSetProperty(DataRateLimits"); +} + +bool VideoToolboxEncoderSource::SupportsFullHD(){ + std::vector encoders=GetAvailableEncoders(); + return std::find(encoders.begin(), encoders.end(), CODEC_HEVC)!=encoders.end(); +} + +void VideoToolboxEncoderSource::SetStreamPaused(bool paused){ + +} + +std::vector VideoToolboxEncoderSource::GetAvailableEncoders(){ + std::vector res; + res.push_back(CODEC_AVC); + CFArrayRef encoders; + OSStatus status=VTCopyVideoEncoderList(NULL, &encoders); + for(CFIndex i=0;i +#include +#include +#include +#include "AudioInputALSA.h" +#include "../../logging.h" +#include "../../VoIPController.h" + +using namespace tgvoip::audio; + +#define BUFFER_SIZE 960 +#define CHECK_ERROR(res, msg) if(res<0){LOGE(msg ": %s", _snd_strerror(res)); failed=true; return;} +#define CHECK_DL_ERROR(res, msg) if(!res){LOGE(msg ": %s", dlerror()); failed=true; return;} +#define LOAD_FUNCTION(lib, name, ref) {ref=(typeof(ref))dlsym(lib, name); CHECK_DL_ERROR(ref, "Error getting entry point for " name);} + +AudioInputALSA::AudioInputALSA(std::string devID){ + isRecording=false; + handle=NULL; + + lib=dlopen("libasound.so.2", RTLD_LAZY); + if(!lib) + lib=dlopen("libasound.so", RTLD_LAZY); + if(!lib){ + LOGE("Error loading libasound: %s", dlerror()); + failed=true; + return; + } + + LOAD_FUNCTION(lib, "snd_pcm_open", _snd_pcm_open); + LOAD_FUNCTION(lib, "snd_pcm_set_params", _snd_pcm_set_params); + LOAD_FUNCTION(lib, "snd_pcm_close", _snd_pcm_close); + LOAD_FUNCTION(lib, "snd_pcm_readi", _snd_pcm_readi); + LOAD_FUNCTION(lib, "snd_pcm_recover", _snd_pcm_recover); + LOAD_FUNCTION(lib, "snd_strerror", _snd_strerror); + + SetCurrentDevice(devID); +} + +AudioInputALSA::~AudioInputALSA(){ + if(handle) + _snd_pcm_close(handle); + if(lib) + dlclose(lib); +} + +void AudioInputALSA::Start(){ + if(failed || isRecording) + return; + + isRecording=true; + thread=new Thread(std::bind(&AudioInputALSA::RunThread, this)); + thread->SetName("AudioInputALSA"); + thread->Start(); +} + +void AudioInputALSA::Stop(){ + if(!isRecording) + return; + + isRecording=false; + thread->Join(); + delete thread; + thread=NULL; +} + +void AudioInputALSA::RunThread(){ + unsigned char buffer[BUFFER_SIZE*2]; + snd_pcm_sframes_t frames; + while(isRecording){ + frames=_snd_pcm_readi(handle, buffer, BUFFER_SIZE); + if (frames < 0){ + frames = _snd_pcm_recover(handle, frames, 0); + } + if (frames < 0) { + LOGE("snd_pcm_readi failed: %s\n", _snd_strerror(frames)); + break; + } + InvokeCallback(buffer, sizeof(buffer)); + } +} + +void AudioInputALSA::SetCurrentDevice(std::string devID){ + bool wasRecording=isRecording; + isRecording=false; + if(handle){ + thread->Join(); + _snd_pcm_close(handle); + } + currentDevice=devID; + + int res=_snd_pcm_open(&handle, devID.c_str(), SND_PCM_STREAM_CAPTURE, 0); + if(res<0) + res=_snd_pcm_open(&handle, "default", SND_PCM_STREAM_CAPTURE, 0); + CHECK_ERROR(res, "snd_pcm_open failed"); + + res=_snd_pcm_set_params(handle, SND_PCM_FORMAT_S16, SND_PCM_ACCESS_RW_INTERLEAVED, 1, 48000, 1, 100000); + CHECK_ERROR(res, "snd_pcm_set_params failed"); + + if(wasRecording){ + isRecording=true; + thread->Start(); + } +} + +void AudioInputALSA::EnumerateDevices(std::vector& devs){ + int (*_snd_device_name_hint)(int card, const char* iface, void*** hints); + char* (*_snd_device_name_get_hint)(const void* hint, const char* id); + int (*_snd_device_name_free_hint)(void** hinst); + void* lib=dlopen("libasound.so.2", RTLD_LAZY); + if(!lib) + dlopen("libasound.so", RTLD_LAZY); + if(!lib) + return; + + _snd_device_name_hint=(typeof(_snd_device_name_hint))dlsym(lib, "snd_device_name_hint"); + _snd_device_name_get_hint=(typeof(_snd_device_name_get_hint))dlsym(lib, "snd_device_name_get_hint"); + _snd_device_name_free_hint=(typeof(_snd_device_name_free_hint))dlsym(lib, "snd_device_name_free_hint"); + + if(!_snd_device_name_hint || !_snd_device_name_get_hint || !_snd_device_name_free_hint){ + dlclose(lib); + return; + } + + char** hints; + int err=_snd_device_name_hint(-1, "pcm", (void***)&hints); + if(err!=0){ + dlclose(lib); + return; + } + + char** n=hints; + while(*n){ + char* name=_snd_device_name_get_hint(*n, "NAME"); + if(strncmp(name, "surround", 8)==0 || strcmp(name, "null")==0){ + free(name); + n++; + continue; + } + char* desc=_snd_device_name_get_hint(*n, "DESC"); + char* ioid=_snd_device_name_get_hint(*n, "IOID"); + if(!ioid || strcmp(ioid, "Input")==0){ + char* l1=strtok(desc, "\n"); + char* l2=strtok(NULL, "\n"); + char* tmp=strtok(l1, ","); + char* actualName=tmp; + while((tmp=strtok(NULL, ","))){ + actualName=tmp; + } + if(actualName[0]==' ') + actualName++; + AudioInputDevice dev; + dev.id=std::string(name); + if(l2){ + char buf[256]; + snprintf(buf, sizeof(buf), "%s (%s)", actualName, l2); + dev.displayName=std::string(buf); + }else{ + dev.displayName=std::string(actualName); + } + devs.push_back(dev); + } + free(name); + free(desc); + free(ioid); + n++; + } + + dlclose(lib); +} diff --git a/TMessagesProj/jni/libtgvoip2/os/linux/AudioInputALSA.h b/TMessagesProj/jni/libtgvoip2/os/linux/AudioInputALSA.h new file mode 100644 index 000000000..09888dddd --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/linux/AudioInputALSA.h @@ -0,0 +1,46 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOINPUTALSA_H +#define LIBTGVOIP_AUDIOINPUTALSA_H + +#include "../../audio/AudioInput.h" +#include "../../threading.h" +#include + +namespace tgvoip{ +namespace audio{ + +class AudioInputALSA : public AudioInput{ + +public: + AudioInputALSA(std::string devID); + virtual ~AudioInputALSA(); + virtual void Start(); + virtual void Stop(); + virtual void SetCurrentDevice(std::string devID); + static void EnumerateDevices(std::vector& devs); + +private: + void RunThread(); + + int (*_snd_pcm_open)(snd_pcm_t** pcm, const char* name, snd_pcm_stream_t stream, int mode); + int (*_snd_pcm_set_params)(snd_pcm_t* pcm, snd_pcm_format_t format, snd_pcm_access_t access, unsigned int channels, unsigned int rate, int soft_resample, unsigned int latency); + int (*_snd_pcm_close)(snd_pcm_t* pcm); + snd_pcm_sframes_t (*_snd_pcm_readi)(snd_pcm_t *pcm, const void *buffer, snd_pcm_uframes_t size); + int (*_snd_pcm_recover)(snd_pcm_t* pcm, int err, int silent); + const char* (*_snd_strerror)(int errnum); + void* lib; + + snd_pcm_t* handle; + Thread* thread; + bool isRecording; +}; + +} +} + +#endif //LIBTGVOIP_AUDIOINPUTALSA_H diff --git a/TMessagesProj/jni/libtgvoip2/os/linux/AudioInputPulse.cpp b/TMessagesProj/jni/libtgvoip2/os/linux/AudioInputPulse.cpp new file mode 100644 index 000000000..be7366b26 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/linux/AudioInputPulse.cpp @@ -0,0 +1,204 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + + +#include +#include +#include +#include "AudioInputPulse.h" +#include "../../logging.h" +#include "../../VoIPController.h" +#include "AudioPulse.h" +#include "PulseFunctions.h" +#if !defined(__GLIBC__) +#include +#endif + +#define BUFFER_SIZE 960 +#define CHECK_ERROR(res, msg) if(res!=0){LOGE(msg " failed: %s", pa_strerror(res)); failed=true; return;} + +using namespace tgvoip::audio; + +AudioInputPulse::AudioInputPulse(pa_context* context, pa_threaded_mainloop* mainloop, std::string devID){ + isRecording=false; + isConnected=false; + didStart=false; + + this->mainloop=mainloop; + this->context=context; + stream=NULL; + remainingDataSize=0; + + pa_threaded_mainloop_lock(mainloop); + + stream=CreateAndInitStream(); + pa_threaded_mainloop_unlock(mainloop); + isLocked=false; + if(!stream){ + return; + } + + SetCurrentDevice(devID); +} + +AudioInputPulse::~AudioInputPulse(){ + if(stream){ + pa_stream_disconnect(stream); + pa_stream_unref(stream); + } +} + +pa_stream* AudioInputPulse::CreateAndInitStream(){ + pa_sample_spec sampleSpec{ + .format=PA_SAMPLE_S16LE, + .rate=48000, + .channels=1 + }; + pa_proplist* proplist=pa_proplist_new(); + pa_proplist_sets(proplist, PA_PROP_FILTER_APPLY, ""); // according to PA sources, this disables any possible filters + pa_stream* stream=pa_stream_new_with_proplist(context, "libtgvoip capture", &sampleSpec, NULL, proplist); + pa_proplist_free(proplist); + if(!stream){ + LOGE("Error initializing PulseAudio (pa_stream_new)"); + failed=true; + return NULL; + } + pa_stream_set_state_callback(stream, AudioInputPulse::StreamStateCallback, this); + pa_stream_set_read_callback(stream, AudioInputPulse::StreamReadCallback, this); + return stream; +} + +void AudioInputPulse::Start(){ + if(failed || isRecording) + return; + + pa_threaded_mainloop_lock(mainloop); + isRecording=true; + pa_operation_unref(pa_stream_cork(stream, 0, NULL, NULL)); + pa_threaded_mainloop_unlock(mainloop); +} + +void AudioInputPulse::Stop(){ + if(!isRecording) + return; + + isRecording=false; + pa_threaded_mainloop_lock(mainloop); + pa_operation_unref(pa_stream_cork(stream, 1, NULL, NULL)); + pa_threaded_mainloop_unlock(mainloop); +} + +bool AudioInputPulse::IsRecording(){ + return isRecording; +} + +void AudioInputPulse::SetCurrentDevice(std::string devID){ + pa_threaded_mainloop_lock(mainloop); + currentDevice=devID; + if(isRecording && isConnected){ + pa_stream_disconnect(stream); + pa_stream_unref(stream); + isConnected=false; + stream=CreateAndInitStream(); + } + + pa_buffer_attr bufferAttr={ + .maxlength=(uint32_t)-1, + .tlength=(uint32_t)-1, + .prebuf=(uint32_t)-1, + .minreq=(uint32_t)-1, + .fragsize=960*2 + }; + int streamFlags=PA_STREAM_START_CORKED | PA_STREAM_INTERPOLATE_TIMING | PA_STREAM_AUTO_TIMING_UPDATE | PA_STREAM_ADJUST_LATENCY; + + int err=pa_stream_connect_record(stream, devID=="default" ? NULL : devID.c_str(), &bufferAttr, (pa_stream_flags_t)streamFlags); + if(err!=0){ + pa_threaded_mainloop_unlock(mainloop); + /*if(devID!="default"){ + SetCurrentDevice("default"); + return; + }*/ + } + CHECK_ERROR(err, "pa_stream_connect_record"); + + while(true){ + pa_stream_state_t streamState=pa_stream_get_state(stream); + if(!PA_STREAM_IS_GOOD(streamState)){ + LOGE("Error connecting to audio device '%s'", devID.c_str()); + pa_threaded_mainloop_unlock(mainloop); + failed=true; + return; + } + if(streamState==PA_STREAM_READY) + break; + pa_threaded_mainloop_wait(mainloop); + } + + isConnected=true; + + if(isRecording){ + pa_operation_unref(pa_stream_cork(stream, 0, NULL, NULL)); + } + pa_threaded_mainloop_unlock(mainloop); +} + +bool AudioInputPulse::EnumerateDevices(std::vector& devs){ + return AudioPulse::DoOneOperation([&](pa_context* ctx){ + return pa_context_get_source_info_list(ctx, [](pa_context* ctx, const pa_source_info* info, int eol, void* userdata){ + if(eol>0) + return; + std::vector* devs=(std::vector*)userdata; + AudioInputDevice dev; + dev.id=std::string(info->name); + dev.displayName=std::string(info->description); + devs->push_back(dev); + }, &devs); + }); +} + +void AudioInputPulse::StreamStateCallback(pa_stream *s, void* arg) { + AudioInputPulse* self=(AudioInputPulse*) arg; + pa_threaded_mainloop_signal(self->mainloop, 0); +} + +void AudioInputPulse::StreamReadCallback(pa_stream *stream, size_t requestedBytes, void *userdata){ + ((AudioInputPulse*)userdata)->StreamReadCallback(stream, requestedBytes); +} + +void AudioInputPulse::StreamReadCallback(pa_stream *stream, size_t requestedBytes) { + size_t bytesRemaining = requestedBytes; + uint8_t *buffer = NULL; + pa_usec_t latency; + if(pa_stream_get_latency(stream, &latency, NULL)==0){ + estimatedDelay=(int32_t)(latency/100); + } + while (bytesRemaining > 0) { + size_t bytesToFill = 102400; + + if (bytesToFill > bytesRemaining) bytesToFill = bytesRemaining; + + int err=pa_stream_peek(stream, (const void**) &buffer, &bytesToFill); + CHECK_ERROR(err, "pa_stream_peek"); + + if(isRecording){ + if(remainingDataSize+bytesToFill>sizeof(remainingData)){ + LOGE("Capture buffer is too big (%d)", (int)bytesToFill); + } + memcpy(remainingData+remainingDataSize, buffer, bytesToFill); + remainingDataSize+=bytesToFill; + while(remainingDataSize>=960*2){ + InvokeCallback(remainingData, 960*2); + memmove(remainingData, remainingData+960*2, remainingDataSize-960*2); + remainingDataSize-=960*2; + } + } + + err=pa_stream_drop(stream); + CHECK_ERROR(err, "pa_stream_drop"); + + bytesRemaining -= bytesToFill; + } +} diff --git a/TMessagesProj/jni/libtgvoip2/os/linux/AudioInputPulse.h b/TMessagesProj/jni/libtgvoip2/os/linux/AudioInputPulse.h new file mode 100644 index 000000000..e1d29948b --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/linux/AudioInputPulse.h @@ -0,0 +1,52 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOINPUTPULSE_H +#define LIBTGVOIP_AUDIOINPUTPULSE_H + +#include "../../audio/AudioInput.h" +#include "../../threading.h" +#include + +#define DECLARE_DL_FUNCTION(name) typeof(name)* _import_##name + +namespace tgvoip{ +namespace audio{ + +class AudioInputPulse : public AudioInput{ +public: + AudioInputPulse(pa_context* context, pa_threaded_mainloop* mainloop, std::string devID); + virtual ~AudioInputPulse(); + virtual void Start(); + virtual void Stop(); + virtual bool IsRecording(); + virtual void SetCurrentDevice(std::string devID); + static bool EnumerateDevices(std::vector& devs); + +private: + static void StreamStateCallback(pa_stream* s, void* arg); + static void StreamReadCallback(pa_stream* stream, size_t requested_bytes, void* userdata); + void StreamReadCallback(pa_stream* stream, size_t requestedBytes); + pa_stream* CreateAndInitStream(); + + pa_threaded_mainloop* mainloop; + pa_context* context; + pa_stream* stream; + + bool isRecording; + bool isConnected; + bool didStart; + bool isLocked; + unsigned char remainingData[960*8*2]; + size_t remainingDataSize; +}; + +} +} + +#undef DECLARE_DL_FUNCTION + +#endif //LIBTGVOIP_AUDIOINPUTPULSE_H diff --git a/TMessagesProj/jni/libtgvoip2/os/linux/AudioOutputALSA.cpp b/TMessagesProj/jni/libtgvoip2/os/linux/AudioOutputALSA.cpp new file mode 100644 index 000000000..dd2f436d5 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/linux/AudioOutputALSA.cpp @@ -0,0 +1,177 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + + +#include +#include +#include "AudioOutputALSA.h" +#include "../../logging.h" +#include "../../VoIPController.h" + +#define BUFFER_SIZE 960 +#define CHECK_ERROR(res, msg) if(res<0){LOGE(msg ": %s", _snd_strerror(res)); failed=true; return;} +#define CHECK_DL_ERROR(res, msg) if(!res){LOGE(msg ": %s", dlerror()); failed=true; return;} +#define LOAD_FUNCTION(lib, name, ref) {ref=(typeof(ref))dlsym(lib, name); CHECK_DL_ERROR(ref, "Error getting entry point for " name);} + +using namespace tgvoip::audio; + +AudioOutputALSA::AudioOutputALSA(std::string devID){ + isPlaying=false; + handle=NULL; + + lib=dlopen("libasound.so.2", RTLD_LAZY); + if(!lib) + lib=dlopen("libasound.so", RTLD_LAZY); + if(!lib){ + LOGE("Error loading libasound: %s", dlerror()); + failed=true; + return; + } + + LOAD_FUNCTION(lib, "snd_pcm_open", _snd_pcm_open); + LOAD_FUNCTION(lib, "snd_pcm_set_params", _snd_pcm_set_params); + LOAD_FUNCTION(lib, "snd_pcm_close", _snd_pcm_close); + LOAD_FUNCTION(lib, "snd_pcm_writei", _snd_pcm_writei); + LOAD_FUNCTION(lib, "snd_pcm_recover", _snd_pcm_recover); + LOAD_FUNCTION(lib, "snd_strerror", _snd_strerror); + + SetCurrentDevice(devID); +} + +AudioOutputALSA::~AudioOutputALSA(){ + if(handle) + _snd_pcm_close(handle); + if(lib) + dlclose(lib); +} + +void AudioOutputALSA::Start(){ + if(failed || isPlaying) + return; + + isPlaying=true; + thread=new Thread(std::bind(&AudioOutputALSA::RunThread, this)); + thread->SetName("AudioOutputALSA"); + thread->Start(); +} + +void AudioOutputALSA::Stop(){ + if(!isPlaying) + return; + + isPlaying=false; + thread->Join(); + delete thread; + thread=NULL; +} + +bool AudioOutputALSA::IsPlaying(){ + return isPlaying; +} +void AudioOutputALSA::RunThread(){ + unsigned char buffer[BUFFER_SIZE*2]; + snd_pcm_sframes_t frames; + while(isPlaying){ + InvokeCallback(buffer, sizeof(buffer)); + frames=_snd_pcm_writei(handle, buffer, BUFFER_SIZE); + if (frames < 0){ + frames = _snd_pcm_recover(handle, frames, 0); + } + if (frames < 0) { + LOGE("snd_pcm_writei failed: %s\n", _snd_strerror(frames)); + break; + } + } +} + +void AudioOutputALSA::SetCurrentDevice(std::string devID){ + bool wasPlaying=isPlaying; + isPlaying=false; + if(handle){ + thread->Join(); + _snd_pcm_close(handle); + } + currentDevice=devID; + + int res=_snd_pcm_open(&handle, devID.c_str(), SND_PCM_STREAM_PLAYBACK, 0); + if(res<0) + res=_snd_pcm_open(&handle, "default", SND_PCM_STREAM_PLAYBACK, 0); + CHECK_ERROR(res, "snd_pcm_open failed"); + + res=_snd_pcm_set_params(handle, SND_PCM_FORMAT_S16, SND_PCM_ACCESS_RW_INTERLEAVED, 1, 48000, 1, 100000); + CHECK_ERROR(res, "snd_pcm_set_params failed"); + + if(wasPlaying){ + isPlaying=true; + thread->Start(); + } +} + +void AudioOutputALSA::EnumerateDevices(std::vector& devs){ + int (*_snd_device_name_hint)(int card, const char* iface, void*** hints); + char* (*_snd_device_name_get_hint)(const void* hint, const char* id); + int (*_snd_device_name_free_hint)(void** hinst); + void* lib=dlopen("libasound.so.2", RTLD_LAZY); + if(!lib) + dlopen("libasound.so", RTLD_LAZY); + if(!lib) + return; + + _snd_device_name_hint=(typeof(_snd_device_name_hint))dlsym(lib, "snd_device_name_hint"); + _snd_device_name_get_hint=(typeof(_snd_device_name_get_hint))dlsym(lib, "snd_device_name_get_hint"); + _snd_device_name_free_hint=(typeof(_snd_device_name_free_hint))dlsym(lib, "snd_device_name_free_hint"); + + if(!_snd_device_name_hint || !_snd_device_name_get_hint || !_snd_device_name_free_hint){ + dlclose(lib); + return; + } + + char** hints; + int err=_snd_device_name_hint(-1, "pcm", (void***)&hints); + if(err!=0){ + dlclose(lib); + return; + } + + char** n=hints; + while(*n){ + char* name=_snd_device_name_get_hint(*n, "NAME"); + if(strncmp(name, "surround", 8)==0 || strcmp(name, "null")==0){ + free(name); + n++; + continue; + } + char* desc=_snd_device_name_get_hint(*n, "DESC"); + char* ioid=_snd_device_name_get_hint(*n, "IOID"); + if(!ioid || strcmp(ioid, "Output")==0){ + char* l1=strtok(desc, "\n"); + char* l2=strtok(NULL, "\n"); + char* tmp=strtok(l1, ","); + char* actualName=tmp; + while((tmp=strtok(NULL, ","))){ + actualName=tmp; + } + if(actualName[0]==' ') + actualName++; + AudioOutputDevice dev; + dev.id=std::string(name); + if(l2){ + char buf[256]; + snprintf(buf, sizeof(buf), "%s (%s)", actualName, l2); + dev.displayName=std::string(buf); + }else{ + dev.displayName=std::string(actualName); + } + devs.push_back(dev); + } + free(name); + free(desc); + free(ioid); + n++; + } + + dlclose(lib); +} diff --git a/TMessagesProj/jni/libtgvoip2/os/linux/AudioOutputALSA.h b/TMessagesProj/jni/libtgvoip2/os/linux/AudioOutputALSA.h new file mode 100644 index 000000000..7cf80fb9a --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/linux/AudioOutputALSA.h @@ -0,0 +1,46 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOOUTPUTALSA_H +#define LIBTGVOIP_AUDIOOUTPUTALSA_H + +#include "../../audio/AudioOutput.h" +#include "../../threading.h" +#include + +namespace tgvoip{ +namespace audio{ + +class AudioOutputALSA : public AudioOutput{ +public: + AudioOutputALSA(std::string devID); + virtual ~AudioOutputALSA(); + virtual void Start(); + virtual void Stop(); + virtual bool IsPlaying(); + virtual void SetCurrentDevice(std::string devID); + static void EnumerateDevices(std::vector& devs); + +private: + void RunThread(); + + int (*_snd_pcm_open)(snd_pcm_t** pcm, const char* name, snd_pcm_stream_t stream, int mode); + int (*_snd_pcm_set_params)(snd_pcm_t* pcm, snd_pcm_format_t format, snd_pcm_access_t access, unsigned int channels, unsigned int rate, int soft_resample, unsigned int latency); + int (*_snd_pcm_close)(snd_pcm_t* pcm); + snd_pcm_sframes_t (*_snd_pcm_writei)(snd_pcm_t *pcm, const void *buffer, snd_pcm_uframes_t size); + int (*_snd_pcm_recover)(snd_pcm_t* pcm, int err, int silent); + const char* (*_snd_strerror)(int errnum); + void* lib; + + snd_pcm_t* handle; + Thread* thread; + bool isPlaying; +}; + +} +} + +#endif //LIBTGVOIP_AUDIOOUTPUTALSA_H diff --git a/TMessagesProj/jni/libtgvoip2/os/linux/AudioOutputPulse.cpp b/TMessagesProj/jni/libtgvoip2/os/linux/AudioOutputPulse.cpp new file mode 100644 index 000000000..bcdacb705 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/linux/AudioOutputPulse.cpp @@ -0,0 +1,187 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + + +#include +#include +#include +#include "AudioOutputPulse.h" +#include "../../logging.h" +#include "../../VoIPController.h" +#include "AudioPulse.h" +#include "PulseFunctions.h" +#if !defined(__GLIBC__) +#include +#endif + +#define BUFFER_SIZE 960 +#define CHECK_ERROR(res, msg) if(res!=0){LOGE(msg " failed: %s", pa_strerror(res)); failed=true; return;} + +using namespace tgvoip; +using namespace tgvoip::audio; + +AudioOutputPulse::AudioOutputPulse(pa_context* context, pa_threaded_mainloop* mainloop, std::string devID){ + isPlaying=false; + isConnected=false; + didStart=false; + isLocked=false; + + this->mainloop=mainloop; + this->context=context; + stream=NULL; + remainingDataSize=0; + + pa_threaded_mainloop_lock(mainloop); + stream=CreateAndInitStream(); + pa_threaded_mainloop_unlock(mainloop); + + SetCurrentDevice(devID); +} + +AudioOutputPulse::~AudioOutputPulse(){ + if(stream){ + pa_stream_disconnect(stream); + pa_stream_unref(stream); + } +} + +pa_stream* AudioOutputPulse::CreateAndInitStream(){ + pa_sample_spec sampleSpec{ + .format=PA_SAMPLE_S16LE, + .rate=48000, + .channels=1 + }; + pa_proplist* proplist=pa_proplist_new(); + pa_proplist_sets(proplist, PA_PROP_FILTER_APPLY, ""); // according to PA sources, this disables any possible filters + pa_stream* stream=pa_stream_new_with_proplist(context, "libtgvoip playback", &sampleSpec, NULL, proplist); + pa_proplist_free(proplist); + if(!stream){ + LOGE("Error initializing PulseAudio (pa_stream_new)"); + failed=true; + return NULL; + } + pa_stream_set_state_callback(stream, AudioOutputPulse::StreamStateCallback, this); + pa_stream_set_write_callback(stream, AudioOutputPulse::StreamWriteCallback, this); + return stream; +} + +void AudioOutputPulse::Start(){ + if(failed || isPlaying) + return; + + isPlaying=true; + pa_threaded_mainloop_lock(mainloop); + pa_operation_unref(pa_stream_cork(stream, 0, NULL, NULL)); + pa_threaded_mainloop_unlock(mainloop); +} + +void AudioOutputPulse::Stop(){ + if(!isPlaying) + return; + + isPlaying=false; + pa_threaded_mainloop_lock(mainloop); + pa_operation_unref(pa_stream_cork(stream, 1, NULL, NULL)); + pa_threaded_mainloop_unlock(mainloop); +} + +bool AudioOutputPulse::IsPlaying(){ + return isPlaying; +} + +void AudioOutputPulse::SetCurrentDevice(std::string devID){ + pa_threaded_mainloop_lock(mainloop); + currentDevice=devID; + if(isPlaying && isConnected){ + pa_stream_disconnect(stream); + pa_stream_unref(stream); + isConnected=false; + stream=CreateAndInitStream(); + } + + pa_buffer_attr bufferAttr={ + .maxlength=(uint32_t)-1, + .tlength=960*2, + .prebuf=(uint32_t)-1, + .minreq=(uint32_t)-1, + .fragsize=(uint32_t)-1 + }; + int streamFlags=PA_STREAM_START_CORKED | PA_STREAM_INTERPOLATE_TIMING | PA_STREAM_AUTO_TIMING_UPDATE | PA_STREAM_ADJUST_LATENCY; + + int err=pa_stream_connect_playback(stream, devID=="default" ? NULL : devID.c_str(), &bufferAttr, (pa_stream_flags_t)streamFlags, NULL, NULL); + if(err!=0 && devID!="default"){ + SetCurrentDevice("default"); + return; + } + CHECK_ERROR(err, "pa_stream_connect_playback"); + + while(true){ + pa_stream_state_t streamState=pa_stream_get_state(stream); + if(!PA_STREAM_IS_GOOD(streamState)){ + LOGE("Error connecting to audio device '%s'", devID.c_str()); + failed=true; + return; + } + if(streamState==PA_STREAM_READY) + break; + pa_threaded_mainloop_wait(mainloop); + } + + isConnected=true; + + if(isPlaying){ + pa_operation_unref(pa_stream_cork(stream, 0, NULL, NULL)); + } + pa_threaded_mainloop_unlock(mainloop); +} + +bool AudioOutputPulse::EnumerateDevices(std::vector& devs){ + return AudioPulse::DoOneOperation([&](pa_context* ctx){ + return pa_context_get_sink_info_list(ctx, [](pa_context* ctx, const pa_sink_info* info, int eol, void* userdata){ + if(eol>0) + return; + std::vector* devs=(std::vector*)userdata; + AudioOutputDevice dev; + dev.id=std::string(info->name); + dev.displayName=std::string(info->description); + devs->push_back(dev); + }, &devs); + }); +} + +void AudioOutputPulse::StreamStateCallback(pa_stream *s, void* arg) { + AudioOutputPulse* self=(AudioOutputPulse*) arg; + pa_threaded_mainloop_signal(self->mainloop, 0); +} + +void AudioOutputPulse::StreamWriteCallback(pa_stream *stream, size_t requestedBytes, void *userdata){ + ((AudioOutputPulse*)userdata)->StreamWriteCallback(stream, requestedBytes); +} + +void AudioOutputPulse::StreamWriteCallback(pa_stream *stream, size_t requestedBytes) { + //assert(requestedBytes<=sizeof(remainingData)); + if(requestedBytes>sizeof(remainingData)){ + requestedBytes=960*2; // force buffer size to 20ms. This probably wrecks the jitter buffer, but still better than crashing + } + pa_usec_t latency; + if(pa_stream_get_latency(stream, &latency, NULL)==0){ + estimatedDelay=(int32_t)(latency/100); + } + while(requestedBytes>remainingDataSize){ + if(isPlaying){ + InvokeCallback(remainingData+remainingDataSize, 960*2); + remainingDataSize+=960*2; + }else{ + memset(remainingData+remainingDataSize, 0, requestedBytes-remainingDataSize); + remainingDataSize=requestedBytes; + } + } + int err=pa_stream_write(stream, remainingData, requestedBytes, NULL, 0, PA_SEEK_RELATIVE); + CHECK_ERROR(err, "pa_stream_write"); + remainingDataSize-=requestedBytes; + if(remainingDataSize>0) + memmove(remainingData, remainingData+requestedBytes, remainingDataSize); +} diff --git a/TMessagesProj/jni/libtgvoip2/os/linux/AudioOutputPulse.h b/TMessagesProj/jni/libtgvoip2/os/linux/AudioOutputPulse.h new file mode 100644 index 000000000..496cf85f5 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/linux/AudioOutputPulse.h @@ -0,0 +1,48 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOOUTPUTPULSE_H +#define LIBTGVOIP_AUDIOOUTPUTPULSE_H + +#include "../../audio/AudioOutput.h" +#include "../../threading.h" +#include + +namespace tgvoip{ +namespace audio{ + +class AudioOutputPulse : public AudioOutput{ +public: + AudioOutputPulse(pa_context* context, pa_threaded_mainloop* mainloop, std::string devID); + virtual ~AudioOutputPulse(); + virtual void Start(); + virtual void Stop(); + virtual bool IsPlaying(); + virtual void SetCurrentDevice(std::string devID); + static bool EnumerateDevices(std::vector& devs); + +private: + static void StreamStateCallback(pa_stream* s, void* arg); + static void StreamWriteCallback(pa_stream* stream, size_t requested_bytes, void* userdata); + void StreamWriteCallback(pa_stream* stream, size_t requestedBytes); + pa_stream* CreateAndInitStream(); + + pa_threaded_mainloop* mainloop; + pa_context* context; + pa_stream* stream; + + bool isPlaying; + bool isConnected; + bool didStart; + bool isLocked; + unsigned char remainingData[960*8*2]; + size_t remainingDataSize; +}; + +} +} + +#endif //LIBTGVOIP_AUDIOOUTPUTPULSE_H diff --git a/TMessagesProj/jni/libtgvoip2/os/linux/AudioPulse.cpp b/TMessagesProj/jni/libtgvoip2/os/linux/AudioPulse.cpp new file mode 100644 index 000000000..06cc98b5c --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/linux/AudioPulse.cpp @@ -0,0 +1,288 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "AudioPulse.h" +#include +#include "../../logging.h" + +#define DECLARE_DL_FUNCTION(name) typeof(name)* AudioPulse::_import_##name=NULL +#define CHECK_DL_ERROR(res, msg) if(!res){LOGE(msg ": %s", dlerror()); return false;} +#define LOAD_DL_FUNCTION(name) {_import_##name=(typeof(_import_##name))dlsym(lib, #name); CHECK_DL_ERROR(_import_##name, "Error getting entry point for " #name);} +#define CHECK_ERROR(res, msg) if(res!=0){LOGE(msg " failed: %s", pa_strerror(res)); failed=true; return;} + +using namespace tgvoip; +using namespace tgvoip::audio; + +bool AudioPulse::loaded=false; +void* AudioPulse::lib=NULL; + +DECLARE_DL_FUNCTION(pa_threaded_mainloop_new); +DECLARE_DL_FUNCTION(pa_threaded_mainloop_get_api); +DECLARE_DL_FUNCTION(pa_context_new); +DECLARE_DL_FUNCTION(pa_context_new_with_proplist); +DECLARE_DL_FUNCTION(pa_context_set_state_callback); +DECLARE_DL_FUNCTION(pa_threaded_mainloop_lock); +DECLARE_DL_FUNCTION(pa_threaded_mainloop_unlock); +DECLARE_DL_FUNCTION(pa_threaded_mainloop_start); +DECLARE_DL_FUNCTION(pa_context_connect); +DECLARE_DL_FUNCTION(pa_context_get_state); +DECLARE_DL_FUNCTION(pa_threaded_mainloop_wait); +DECLARE_DL_FUNCTION(pa_stream_new_with_proplist); +DECLARE_DL_FUNCTION(pa_stream_set_state_callback); +DECLARE_DL_FUNCTION(pa_stream_set_write_callback); +DECLARE_DL_FUNCTION(pa_stream_connect_playback); +DECLARE_DL_FUNCTION(pa_operation_unref); +DECLARE_DL_FUNCTION(pa_stream_cork); +DECLARE_DL_FUNCTION(pa_threaded_mainloop_stop); +DECLARE_DL_FUNCTION(pa_stream_disconnect); +DECLARE_DL_FUNCTION(pa_stream_unref); +DECLARE_DL_FUNCTION(pa_context_disconnect); +DECLARE_DL_FUNCTION(pa_context_unref); +DECLARE_DL_FUNCTION(pa_threaded_mainloop_free); +DECLARE_DL_FUNCTION(pa_threaded_mainloop_signal); +DECLARE_DL_FUNCTION(pa_stream_begin_write); +DECLARE_DL_FUNCTION(pa_stream_write); +DECLARE_DL_FUNCTION(pa_stream_get_state); +DECLARE_DL_FUNCTION(pa_strerror); +DECLARE_DL_FUNCTION(pa_stream_set_read_callback); +DECLARE_DL_FUNCTION(pa_stream_connect_record); +DECLARE_DL_FUNCTION(pa_stream_peek); +DECLARE_DL_FUNCTION(pa_stream_drop); +DECLARE_DL_FUNCTION(pa_mainloop_new); +DECLARE_DL_FUNCTION(pa_mainloop_get_api); +DECLARE_DL_FUNCTION(pa_mainloop_iterate); +DECLARE_DL_FUNCTION(pa_mainloop_free); +DECLARE_DL_FUNCTION(pa_context_get_sink_info_list); +DECLARE_DL_FUNCTION(pa_context_get_source_info_list); +DECLARE_DL_FUNCTION(pa_operation_get_state); +DECLARE_DL_FUNCTION(pa_proplist_new); +DECLARE_DL_FUNCTION(pa_proplist_sets); +DECLARE_DL_FUNCTION(pa_proplist_free); +DECLARE_DL_FUNCTION(pa_stream_get_latency); + +#include "PulseFunctions.h" + +bool AudioPulse::Load(){ + if(loaded) + return true; + + lib=dlopen("libpulse.so.0", RTLD_LAZY); + if(!lib) + lib=dlopen("libpulse.so", RTLD_LAZY); + if(!lib){ + LOGE("Error loading libpulse: %s", dlerror()); + return false; + } + + LOAD_DL_FUNCTION(pa_threaded_mainloop_new); + LOAD_DL_FUNCTION(pa_threaded_mainloop_get_api); + LOAD_DL_FUNCTION(pa_context_new); + LOAD_DL_FUNCTION(pa_context_new_with_proplist); + LOAD_DL_FUNCTION(pa_context_set_state_callback); + LOAD_DL_FUNCTION(pa_threaded_mainloop_lock); + LOAD_DL_FUNCTION(pa_threaded_mainloop_unlock); + LOAD_DL_FUNCTION(pa_threaded_mainloop_start); + LOAD_DL_FUNCTION(pa_context_connect); + LOAD_DL_FUNCTION(pa_context_get_state); + LOAD_DL_FUNCTION(pa_threaded_mainloop_wait); + LOAD_DL_FUNCTION(pa_stream_new_with_proplist); + LOAD_DL_FUNCTION(pa_stream_set_state_callback); + LOAD_DL_FUNCTION(pa_stream_set_write_callback); + LOAD_DL_FUNCTION(pa_stream_connect_playback); + LOAD_DL_FUNCTION(pa_operation_unref); + LOAD_DL_FUNCTION(pa_stream_cork); + LOAD_DL_FUNCTION(pa_threaded_mainloop_stop); + LOAD_DL_FUNCTION(pa_stream_disconnect); + LOAD_DL_FUNCTION(pa_stream_unref); + LOAD_DL_FUNCTION(pa_context_disconnect); + LOAD_DL_FUNCTION(pa_context_unref); + LOAD_DL_FUNCTION(pa_threaded_mainloop_free); + LOAD_DL_FUNCTION(pa_threaded_mainloop_signal); + LOAD_DL_FUNCTION(pa_stream_begin_write); + LOAD_DL_FUNCTION(pa_stream_write); + LOAD_DL_FUNCTION(pa_stream_get_state); + LOAD_DL_FUNCTION(pa_strerror); + LOAD_DL_FUNCTION(pa_stream_set_read_callback); + LOAD_DL_FUNCTION(pa_stream_connect_record); + LOAD_DL_FUNCTION(pa_stream_peek); + LOAD_DL_FUNCTION(pa_stream_drop); + LOAD_DL_FUNCTION(pa_mainloop_new); + LOAD_DL_FUNCTION(pa_mainloop_get_api); + LOAD_DL_FUNCTION(pa_mainloop_iterate); + LOAD_DL_FUNCTION(pa_mainloop_free); + LOAD_DL_FUNCTION(pa_context_get_sink_info_list); + LOAD_DL_FUNCTION(pa_context_get_source_info_list); + LOAD_DL_FUNCTION(pa_operation_get_state); + LOAD_DL_FUNCTION(pa_proplist_new); + LOAD_DL_FUNCTION(pa_proplist_sets); + LOAD_DL_FUNCTION(pa_proplist_free); + LOAD_DL_FUNCTION(pa_stream_get_latency); + + loaded=true; + return true; +} + +AudioPulse::AudioPulse(std::string inputDevice, std::string outputDevice){ + if(!Load()){ + failed=true; + LOGE("Failed to load libpulse"); + return; + } + + mainloop=pa_threaded_mainloop_new(); + if(!mainloop){ + LOGE("Error initializing PulseAudio (pa_threaded_mainloop_new)"); + failed=true; + return; + } + mainloopApi=pa_threaded_mainloop_get_api(mainloop); +#ifndef MAXPATHLEN + char exeName[20]; +#else + char exePath[MAXPATHLEN]; + char exeName[MAXPATHLEN]; + ssize_t lres=readlink("/proc/self/exe", exePath, sizeof(exePath)); + if(lres==-1) + lres=readlink("/proc/curproc/file", exePath, sizeof(exePath)); + if(lres==-1) + lres=readlink("/proc/curproc/exe", exePath, sizeof(exePath)); + if(lres>0){ + strcpy(exeName, basename(exePath)); + }else +#endif + { + snprintf(exeName, sizeof(exeName), "Process %d", getpid()); + } + pa_proplist* proplist=pa_proplist_new(); + pa_proplist_sets(proplist, PA_PROP_MEDIA_ROLE, "phone"); + context=pa_context_new_with_proplist(mainloopApi, exeName, proplist); + pa_proplist_free(proplist); + if(!context){ + LOGE("Error initializing PulseAudio (pa_context_new)"); + failed=true; + return; + } + pa_context_set_state_callback(context, [](pa_context* context, void* arg){ + AudioPulse* self=reinterpret_cast(arg); + pa_threaded_mainloop_signal(self->mainloop, 0); + }, this); + pa_threaded_mainloop_lock(mainloop); + isLocked=true; + int err=pa_threaded_mainloop_start(mainloop); + CHECK_ERROR(err, "pa_threaded_mainloop_start"); + didStart=true; + + err=pa_context_connect(context, NULL, PA_CONTEXT_NOAUTOSPAWN, NULL); + CHECK_ERROR(err, "pa_context_connect"); + + while(true){ + pa_context_state_t contextState=pa_context_get_state(context); + if(!PA_CONTEXT_IS_GOOD(contextState)){ + LOGE("Error initializing PulseAudio (PA_CONTEXT_IS_GOOD)"); + failed=true; + return; + } + if(contextState==PA_CONTEXT_READY) + break; + pa_threaded_mainloop_wait(mainloop); + } + pa_threaded_mainloop_unlock(mainloop); + isLocked=false; + + output=new AudioOutputPulse(context, mainloop, outputDevice); + input=new AudioInputPulse(context, mainloop, inputDevice); +} + +AudioPulse::~AudioPulse(){ + if(mainloop && didStart){ + if(isLocked) + pa_threaded_mainloop_unlock(mainloop); + pa_threaded_mainloop_stop(mainloop); + } + + if(input) + delete input; + if(output) + delete output; + + if(context){ + pa_context_disconnect(context); + pa_context_unref(context); + } + if(mainloop) + pa_threaded_mainloop_free(mainloop); +} + +AudioOutput* AudioPulse::GetOutput(){ + return output; +} + +AudioInput* AudioPulse::GetInput(){ + return input; +} + +bool AudioPulse::DoOneOperation(std::function f){ + if(!Load()) + return false; + + pa_mainloop* ml; + pa_mainloop_api* mlAPI; + pa_context* ctx; + pa_operation* op=NULL; + int paReady=0; + + ml=pa_mainloop_new(); + mlAPI=pa_mainloop_get_api(ml); + ctx=pa_context_new(mlAPI, "libtgvoip"); + + pa_context_connect(ctx, NULL, PA_CONTEXT_NOFLAGS, NULL); + pa_context_set_state_callback(ctx, [](pa_context* context, void* arg){ + pa_context_state_t state; + int* pa_ready=(int*)arg; + + state=pa_context_get_state(context); + switch(state){ + case PA_CONTEXT_UNCONNECTED: + case PA_CONTEXT_CONNECTING: + case PA_CONTEXT_AUTHORIZING: + case PA_CONTEXT_SETTING_NAME: + default: + break; + case PA_CONTEXT_FAILED: + case PA_CONTEXT_TERMINATED: + *pa_ready=2; + break; + case PA_CONTEXT_READY: + *pa_ready=1; + break; + } + }, &paReady); + + while(true){ + if(paReady==0){ + pa_mainloop_iterate(ml, 1, NULL); + continue; + } + if(paReady==2){ + pa_context_disconnect(ctx); + pa_context_unref(ctx); + pa_mainloop_free(ml); + return false; + } + if(!op){ + op=f(ctx); + continue; + } + if(pa_operation_get_state(op)==PA_OPERATION_DONE){ + pa_operation_unref(op); + pa_context_disconnect(ctx); + pa_context_unref(ctx); + pa_mainloop_free(ml); + return true; + } + pa_mainloop_iterate(ml, 1, NULL); + } +} diff --git a/TMessagesProj/jni/libtgvoip2/os/linux/AudioPulse.h b/TMessagesProj/jni/libtgvoip2/os/linux/AudioPulse.h new file mode 100644 index 000000000..26fb2b7b2 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/linux/AudioPulse.h @@ -0,0 +1,95 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_PULSEAUDIOLOADER_H +#define LIBTGVOIP_PULSEAUDIOLOADER_H + +#include +#include +#include +#include "../../audio/AudioIO.h" +#include "AudioInputPulse.h" +#include "AudioOutputPulse.h" + +#define DECLARE_DL_FUNCTION(name) static typeof(name)* _import_##name + +namespace tgvoip{ + namespace audio{ + class AudioPulse : public AudioIO{ + public: + AudioPulse(std::string inputDevice, std::string outputDevice); + virtual ~AudioPulse(); + virtual AudioInput* GetInput(); + virtual AudioOutput* GetOutput(); + + static bool Load(); + static bool DoOneOperation(std::function f); + + DECLARE_DL_FUNCTION(pa_threaded_mainloop_new); + DECLARE_DL_FUNCTION(pa_threaded_mainloop_get_api); + DECLARE_DL_FUNCTION(pa_context_new); + DECLARE_DL_FUNCTION(pa_context_new_with_proplist); + DECLARE_DL_FUNCTION(pa_context_set_state_callback); + DECLARE_DL_FUNCTION(pa_threaded_mainloop_lock); + DECLARE_DL_FUNCTION(pa_threaded_mainloop_unlock); + DECLARE_DL_FUNCTION(pa_threaded_mainloop_start); + DECLARE_DL_FUNCTION(pa_context_connect); + DECLARE_DL_FUNCTION(pa_context_get_state); + DECLARE_DL_FUNCTION(pa_threaded_mainloop_wait); + DECLARE_DL_FUNCTION(pa_stream_new_with_proplist); + DECLARE_DL_FUNCTION(pa_stream_set_state_callback); + DECLARE_DL_FUNCTION(pa_stream_set_write_callback); + DECLARE_DL_FUNCTION(pa_stream_connect_playback); + DECLARE_DL_FUNCTION(pa_operation_unref); + DECLARE_DL_FUNCTION(pa_stream_cork); + DECLARE_DL_FUNCTION(pa_threaded_mainloop_stop); + DECLARE_DL_FUNCTION(pa_stream_disconnect); + DECLARE_DL_FUNCTION(pa_stream_unref); + DECLARE_DL_FUNCTION(pa_context_disconnect); + DECLARE_DL_FUNCTION(pa_context_unref); + DECLARE_DL_FUNCTION(pa_threaded_mainloop_free); + DECLARE_DL_FUNCTION(pa_threaded_mainloop_signal); + DECLARE_DL_FUNCTION(pa_stream_begin_write); + DECLARE_DL_FUNCTION(pa_stream_write); + DECLARE_DL_FUNCTION(pa_stream_get_state); + DECLARE_DL_FUNCTION(pa_strerror); + DECLARE_DL_FUNCTION(pa_stream_set_read_callback); + DECLARE_DL_FUNCTION(pa_stream_connect_record); + DECLARE_DL_FUNCTION(pa_stream_peek); + DECLARE_DL_FUNCTION(pa_stream_drop); + + DECLARE_DL_FUNCTION(pa_mainloop_new); + DECLARE_DL_FUNCTION(pa_mainloop_get_api); + DECLARE_DL_FUNCTION(pa_mainloop_iterate); + DECLARE_DL_FUNCTION(pa_mainloop_free); + DECLARE_DL_FUNCTION(pa_context_get_sink_info_list); + DECLARE_DL_FUNCTION(pa_context_get_source_info_list); + DECLARE_DL_FUNCTION(pa_operation_get_state); + + DECLARE_DL_FUNCTION(pa_proplist_new); + DECLARE_DL_FUNCTION(pa_proplist_sets); + DECLARE_DL_FUNCTION(pa_proplist_free); + + DECLARE_DL_FUNCTION(pa_stream_get_latency); + + private: + static void* lib; + static bool loaded; + AudioInputPulse* input=NULL; + AudioOutputPulse* output=NULL; + + pa_threaded_mainloop* mainloop; + pa_mainloop_api* mainloopApi; + pa_context* context; + bool isLocked=false; + bool didStart=false; + }; + } +} + +#undef DECLARE_DL_FUNCTION + +#endif // LIBTGVOIP_PULSEAUDIOLOADER_H diff --git a/TMessagesProj/jni/libtgvoip2/os/linux/PulseFunctions.h b/TMessagesProj/jni/libtgvoip2/os/linux/PulseFunctions.h new file mode 100644 index 000000000..9e754f99a --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/linux/PulseFunctions.h @@ -0,0 +1,48 @@ +#ifndef LIBTGVOIP_PULSE_FUNCTIONS_H +#define LIBTGVOIP_PULSE_FUNCTIONS_H + +#define pa_threaded_mainloop_new AudioPulse::_import_pa_threaded_mainloop_new +#define pa_threaded_mainloop_get_api AudioPulse::_import_pa_threaded_mainloop_get_api +#define pa_context_new AudioPulse::_import_pa_context_new +#define pa_context_new_with_proplist AudioPulse::_import_pa_context_new_with_proplist +#define pa_context_set_state_callback AudioPulse::_import_pa_context_set_state_callback +#define pa_threaded_mainloop_lock AudioPulse::_import_pa_threaded_mainloop_lock +#define pa_threaded_mainloop_unlock AudioPulse::_import_pa_threaded_mainloop_unlock +#define pa_threaded_mainloop_start AudioPulse::_import_pa_threaded_mainloop_start +#define pa_context_connect AudioPulse::_import_pa_context_connect +#define pa_context_get_state AudioPulse::_import_pa_context_get_state +#define pa_threaded_mainloop_wait AudioPulse::_import_pa_threaded_mainloop_wait +#define pa_stream_new_with_proplist AudioPulse::_import_pa_stream_new_with_proplist +#define pa_stream_set_state_callback AudioPulse::_import_pa_stream_set_state_callback +#define pa_stream_set_write_callback AudioPulse::_import_pa_stream_set_write_callback +#define pa_stream_connect_playback AudioPulse::_import_pa_stream_connect_playback +#define pa_operation_unref AudioPulse::_import_pa_operation_unref +#define pa_stream_cork AudioPulse::_import_pa_stream_cork +#define pa_threaded_mainloop_stop AudioPulse::_import_pa_threaded_mainloop_stop +#define pa_stream_disconnect AudioPulse::_import_pa_stream_disconnect +#define pa_stream_unref AudioPulse::_import_pa_stream_unref +#define pa_context_disconnect AudioPulse::_import_pa_context_disconnect +#define pa_context_unref AudioPulse::_import_pa_context_unref +#define pa_threaded_mainloop_free AudioPulse::_import_pa_threaded_mainloop_free +#define pa_threaded_mainloop_signal AudioPulse::_import_pa_threaded_mainloop_signal +#define pa_stream_begin_write AudioPulse::_import_pa_stream_begin_write +#define pa_stream_write AudioPulse::_import_pa_stream_write +#define pa_strerror AudioPulse::_import_pa_strerror +#define pa_stream_get_state AudioPulse::_import_pa_stream_get_state +#define pa_stream_set_read_callback AudioPulse::_import_pa_stream_set_read_callback +#define pa_stream_connect_record AudioPulse::_import_pa_stream_connect_record +#define pa_stream_peek AudioPulse::_import_pa_stream_peek +#define pa_stream_drop AudioPulse::_import_pa_stream_drop +#define pa_mainloop_new AudioPulse::_import_pa_mainloop_new +#define pa_mainloop_get_api AudioPulse::_import_pa_mainloop_get_api +#define pa_mainloop_iterate AudioPulse::_import_pa_mainloop_iterate +#define pa_mainloop_free AudioPulse::_import_pa_mainloop_free +#define pa_context_get_sink_info_list AudioPulse::_import_pa_context_get_sink_info_list +#define pa_context_get_source_info_list AudioPulse::_import_pa_context_get_source_info_list +#define pa_operation_get_state AudioPulse::_import_pa_operation_get_state +#define pa_proplist_new AudioPulse::_import_pa_proplist_new +#define pa_proplist_sets AudioPulse::_import_pa_proplist_sets +#define pa_proplist_free AudioPulse::_import_pa_proplist_free +#define pa_stream_get_latency AudioPulse::_import_pa_stream_get_latency + +#endif //LIBTGVOIP_PULSE_FUNCTIONS_H diff --git a/TMessagesProj/jni/libtgvoip2/os/posix/NetworkSocketPosix.cpp b/TMessagesProj/jni/libtgvoip2/os/posix/NetworkSocketPosix.cpp new file mode 100644 index 000000000..c176e9eb5 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/posix/NetworkSocketPosix.cpp @@ -0,0 +1,644 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "NetworkSocketPosix.h" +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include "../../logging.h" +#include "../../VoIPController.h" +#include "../../Buffers.h" + +#ifdef __ANDROID__ +#include +#include +#include + +extern JavaVM* sharedJVM; +extern jclass jniUtilitiesClass; +#else +#include +#endif + +using namespace tgvoip; + + +NetworkSocketPosix::NetworkSocketPosix(NetworkProtocol protocol) : NetworkSocket(protocol){ + needUpdateNat64Prefix=true; + nat64Present=false; + switchToV6at=0; + isV4Available=false; + fd=-1; + closing=false; + + tcpConnectedPort=0; + + if(protocol==NetworkProtocol::TCP) + timeout=10.0; + lastSuccessfulOperationTime=VoIPController::GetCurrentTime(); +} + +NetworkSocketPosix::~NetworkSocketPosix(){ + if(fd>=0){ + Close(); + } +} + +void NetworkSocketPosix::SetMaxPriority(){ +#ifdef __APPLE__ + int prio=NET_SERVICE_TYPE_VO; + int res=setsockopt(fd, SOL_SOCKET, SO_NET_SERVICE_TYPE, &prio, sizeof(prio)); + if(res<0){ + LOGE("error setting darwin-specific net priority: %d / %s", errno, strerror(errno)); + } +#elif defined(__linux__) + int prio=6; + int res=setsockopt(fd, SOL_SOCKET, SO_PRIORITY, &prio, sizeof(prio)); + if(res<0){ + LOGE("error setting priority: %d / %s", errno, strerror(errno)); + } + prio=46 << 2; + res=setsockopt(fd, SOL_IP, IP_TOS, &prio, sizeof(prio)); + if(res<0){ + LOGE("error setting ip tos: %d / %s", errno, strerror(errno)); + } +#else + LOGI("cannot set socket priority"); +#endif +} + +void NetworkSocketPosix::Send(NetworkPacket packet){ + if(packet.data.IsEmpty() || (protocol==NetworkProtocol::UDP && packet.port==0)){ + LOGW("tried to send null packet"); + return; + } + int res; + if(protocol==NetworkProtocol::UDP){ + sockaddr_in6 addr; + if(!packet.address.isIPv6){ + if(needUpdateNat64Prefix && !isV4Available && VoIPController::GetCurrentTime()>switchToV6at && switchToV6at!=0){ + LOGV("Updating NAT64 prefix"); + nat64Present=false; + addrinfo *addr0; + int res=getaddrinfo("ipv4only.arpa", NULL, NULL, &addr0); + if(res!=0){ + LOGW("Error updating NAT64 prefix: %d / %s", res, gai_strerror(res)); + }else{ + addrinfo *addrPtr; + unsigned char *addr170=NULL; + unsigned char *addr171=NULL; + for(addrPtr=addr0; addrPtr; addrPtr=addrPtr->ai_next){ + if(addrPtr->ai_family==AF_INET6){ + sockaddr_in6 *translatedAddr=(sockaddr_in6 *) addrPtr->ai_addr; + uint32_t v4part=*((uint32_t *) &translatedAddr->sin6_addr.s6_addr[12]); + if(v4part==0xAA0000C0 && !addr170){ + addr170=translatedAddr->sin6_addr.s6_addr; + } + if(v4part==0xAB0000C0 && !addr171){ + addr171=translatedAddr->sin6_addr.s6_addr; + } + char buf[INET6_ADDRSTRLEN]; + LOGV("Got translated address: %s", inet_ntop(AF_INET6, &translatedAddr->sin6_addr, buf, sizeof(buf))); + } + } + if(addr170 && addr171 && memcmp(addr170, addr171, 12)==0){ + nat64Present=true; + memcpy(nat64Prefix, addr170, 12); + char buf[INET6_ADDRSTRLEN]; + LOGV("Found nat64 prefix from %s", inet_ntop(AF_INET6, addr170, buf, sizeof(buf))); + }else{ + LOGV("Didn't find nat64"); + } + freeaddrinfo(addr0); + } + needUpdateNat64Prefix=false; + } + memset(&addr, 0, sizeof(sockaddr_in6)); + addr.sin6_family=AF_INET6; + *((uint32_t *) &addr.sin6_addr.s6_addr[12])=packet.address.addr.ipv4; + if(nat64Present) + memcpy(addr.sin6_addr.s6_addr, nat64Prefix, 12); + else + addr.sin6_addr.s6_addr[11]=addr.sin6_addr.s6_addr[10]=0xFF; + + }else{ + memcpy(addr.sin6_addr.s6_addr, packet.address.addr.ipv6, 16); + addr.sin6_family=AF_INET6; + } + addr.sin6_port=htons(packet.port); + std::lock_guard lock(m_fd); + res = static_cast(sendto(fd, *packet.data, packet.data.Length(), 0, + reinterpret_cast(&addr), sizeof(addr))); + } else { + std::lock_guard lock(m_fd); + res = static_cast(send(fd, *packet.data, packet.data.Length(), 0)); + } + if(res<=0){ + if(errno==EAGAIN || errno==EWOULDBLOCK){ + if(!pendingOutgoingPacket.IsEmpty()){ + LOGE("Got EAGAIN but there's already a pending packet"); + failed=true; + }else{ + LOGV("Socket %d not ready to send", int(fd)); + pendingOutgoingPacket=std::move(packet); + readyToSend=false; + } + }else{ + LOGE("error sending: %d / %s", errno, strerror(errno)); + if(errno==ENETUNREACH && !isV4Available && VoIPController::GetCurrentTime() 0) { + if (!isV4Available && IN6_IS_ADDR_V4MAPPED(&srcAddr.sin6_addr)) { + isV4Available = true; + LOGI("Detected IPv4 connectivity, will not try IPv6"); + } + NetworkAddress addr = NetworkAddress::Empty(); + if (IN6_IS_ADDR_V4MAPPED(&srcAddr.sin6_addr) || (nat64Present && memcmp(nat64Prefix, srcAddr.sin6_addr.s6_addr, 12) == 0)) { + in_addr v4addr = *(reinterpret_cast(&srcAddr.sin6_addr.s6_addr[12])); + addr = NetworkAddress::IPv4(v4addr.s_addr); + } else { + addr = NetworkAddress::IPv6(srcAddr.sin6_addr.s6_addr); + } + return NetworkPacket { + Buffer::CopyOf(recvBuffer, 0, (size_t)len), + addr, + ntohs(srcAddr.sin6_port), + NetworkProtocol::UDP + }; + } else { + LOGE("error receiving %d / %s", errno, strerror(errno)); + return NetworkPacket::Empty(); + } + //LOGV("Received %d bytes from %s:%d at %.5lf", len, inet_ntoa(srcAddr.sin_addr), ntohs(srcAddr.sin_port), GetCurrentTime()); + }else if(protocol==NetworkProtocol::TCP){ + ssize_t res=(int)recv(fd, *recvBuffer, std::min(recvBuffer.Length(), maxLen), 0); + if(res<=0){ + LOGE("Error receiving from TCP socket: %d / %s", errno, strerror(errno)); + failed=true; + return NetworkPacket::Empty(); + }else{ + return NetworkPacket{ + Buffer::CopyOf(recvBuffer, 0, (size_t)res), + tcpConnectedAddress, + tcpConnectedPort, + NetworkProtocol::TCP + }; + } + } + return NetworkPacket::Empty(); +} + +void NetworkSocketPosix::Open(){ + if(protocol!=NetworkProtocol::UDP) + return; + fd=socket(PF_INET6, SOCK_DGRAM, IPPROTO_UDP); + if(fd<0){ + LOGE("error creating socket: %d / %s", errno, strerror(errno)); + failed=true; + return; + } + int flag=0; + int res=setsockopt(fd, IPPROTO_IPV6, IPV6_V6ONLY, &flag, sizeof(flag)); + if(res<0){ + LOGE("error enabling dual stack socket: %d / %s", errno, strerror(errno)); + failed=true; + return; + } + + SetMaxPriority(); + if(fcntl(fd, F_SETFL, O_NONBLOCK)==-1){ + LOGE("error setting nonblock flag on socket: %d / %s", errno, strerror(errno)); + failed=true; + return; + } + +#ifdef __APPLE__ + flag=1; + setsockopt(fd, SOL_SOCKET, SO_NOSIGPIPE, &flag, sizeof(flag)); +#endif + + int tries=0; + sockaddr_in6 addr; + //addr.sin6_addr.s_addr=0; + memset(&addr, 0, sizeof(sockaddr_in6)); + //addr.sin6_len=sizeof(sa_family_t); + addr.sin6_family=AF_INET6; + for(tries=0;tries<10;tries++){ + addr.sin6_port=htons(GenerateLocalPort()); + res=::bind(fd, (sockaddr *) &addr, sizeof(sockaddr_in6)); + LOGV("trying bind to port %u", ntohs(addr.sin6_port)); + if(res<0){ + LOGE("error binding to port %u: %d / %s", ntohs(addr.sin6_port), errno, strerror(errno)); + }else{ + break; + } + } + if(tries==10){ + addr.sin6_port=0; + res=::bind(fd, (sockaddr *) &addr, sizeof(sockaddr_in6)); + if(res<0){ + LOGE("error binding to port %u: %d / %s", ntohs(addr.sin6_port), errno, strerror(errno)); + //SetState(STATE_FAILED); + failed=true; + return; + } + } + size_t addrLen=sizeof(sockaddr_in6); + getsockname(fd, (sockaddr*)&addr, (socklen_t*) &addrLen); + LOGD("Bound to local UDP port %u", ntohs(addr.sin6_port)); + + needUpdateNat64Prefix=true; + isV4Available=false; + switchToV6at=VoIPController::GetCurrentTime()+ipv6Timeout; +} + +void NetworkSocketPosix::Close(){ + if (closing) { + return; + } + closing = true; + failed = true; + + if (fd >= 0) { + shutdown(fd, SHUT_RDWR); + close(fd); + fd = -1; + } +} + +void NetworkSocketPosix::Connect(const NetworkAddress address, uint16_t port){ + struct sockaddr_in v4={0}; + struct sockaddr_in6 v6={0}; + struct sockaddr* addr=NULL; + size_t addrLen=0; + if(!address.isIPv6){ + v4.sin_family=AF_INET; + v4.sin_addr.s_addr=address.addr.ipv4; + v4.sin_port=htons(port); + addr=reinterpret_cast(&v4); + addrLen=sizeof(v4); + }else{ + v6.sin6_family=AF_INET6; + memcpy(v6.sin6_addr.s6_addr, address.addr.ipv6, 16); + v6.sin6_flowinfo=0; + v6.sin6_scope_id=0; + v6.sin6_port=htons(port); + addr=reinterpret_cast(&v6); + addrLen=sizeof(v6); + } + fd=socket(addr->sa_family, SOCK_STREAM, IPPROTO_TCP); + if(fd<0){ + LOGE("Error creating TCP socket: %d / %s", errno, strerror(errno)); + failed=true; + return; + } + int opt=1; + setsockopt(fd, IPPROTO_TCP, TCP_NODELAY, &opt, sizeof(opt)); + timeval timeout; + timeout.tv_sec=5; + timeout.tv_usec=0; + setsockopt(fd, SOL_SOCKET, SO_SNDTIMEO, &timeout, sizeof(timeout)); + timeout.tv_sec=60; + setsockopt(fd, SOL_SOCKET, SO_RCVTIMEO, &timeout, sizeof(timeout)); + fcntl(fd, F_SETFL, O_NONBLOCK); + int res=(int)connect(fd, (const sockaddr*) addr, (socklen_t)addrLen); + if(res!=0 && errno!=EINVAL && errno!=EINPROGRESS){ + LOGW("error connecting TCP socket to %s:%u: %d / %s; %d / %s", address.ToString().c_str(), port, res, strerror(res), errno, strerror(errno)); + close(fd); + failed=true; + return; + } + tcpConnectedAddress=address; + tcpConnectedPort=port; + LOGI("successfully connected to %s:%d", tcpConnectedAddress.ToString().c_str(), tcpConnectedPort); +} + +void NetworkSocketPosix::OnActiveInterfaceChanged(){ + needUpdateNat64Prefix=true; + isV4Available=false; + switchToV6at=VoIPController::GetCurrentTime()+ipv6Timeout; +} + +std::string NetworkSocketPosix::GetLocalInterfaceInfo(NetworkAddress *v4addr, NetworkAddress *v6addr){ + std::string name=""; + // Android doesn't support ifaddrs +#ifdef __ANDROID__ + JNIEnv *env=NULL; + bool didAttach=false; + sharedJVM->GetEnv((void **) &env, JNI_VERSION_1_6); + if(!env){ + sharedJVM->AttachCurrentThread(&env, NULL); + didAttach=true; + } + + jmethodID getLocalNetworkAddressesAndInterfaceNameMethod=env->GetStaticMethodID(jniUtilitiesClass, "getLocalNetworkAddressesAndInterfaceName", "()[Ljava/lang/String;"); + jobjectArray jinfo=(jobjectArray) env->CallStaticObjectMethod(jniUtilitiesClass, getLocalNetworkAddressesAndInterfaceNameMethod); + if(jinfo){ + jstring jitfName=static_cast(env->GetObjectArrayElement(jinfo, 0)); + jstring jipv4=static_cast(env->GetObjectArrayElement(jinfo, 1)); + jstring jipv6=static_cast(env->GetObjectArrayElement(jinfo, 2)); + if(jitfName){ + const char *itfchars=env->GetStringUTFChars(jitfName, NULL); + name=std::string(itfchars); + env->ReleaseStringUTFChars(jitfName, itfchars); + } + + if(v4addr && jipv4){ + const char* ipchars=env->GetStringUTFChars(jipv4, NULL); + *v4addr=NetworkAddress::IPv4(ipchars); + env->ReleaseStringUTFChars(jipv4, ipchars); + } + if(v6addr && jipv6){ + const char* ipchars=env->GetStringUTFChars(jipv6, NULL); + *v6addr=NetworkAddress::IPv6(ipchars); + env->ReleaseStringUTFChars(jipv6, ipchars); + } + }else{ + LOGW("Failed to get android network interface info"); + } + + if(didAttach){ + sharedJVM->DetachCurrentThread(); + } +#else + struct ifaddrs* interfaces; + if(!getifaddrs(&interfaces)){ + struct ifaddrs* interface; + for(interface=interfaces;interface;interface=interface->ifa_next){ + if(!(interface->ifa_flags & IFF_UP) || !(interface->ifa_flags & IFF_RUNNING) || (interface->ifa_flags & IFF_LOOPBACK)) + continue; + const struct sockaddr_in* addr=(const struct sockaddr_in*)interface->ifa_addr; + if(addr){ + if(addr->sin_family==AF_INET){ + if((ntohl(addr->sin_addr.s_addr) & 0xFFFF0000)==0xA9FE0000) + continue; + if(v4addr) + *v4addr=NetworkAddress::IPv4(addr->sin_addr.s_addr); + name=interface->ifa_name; + }else if(addr->sin_family==AF_INET6){ + const struct sockaddr_in6* addr6=(const struct sockaddr_in6*)addr; + if((addr6->sin6_addr.s6_addr[0] & 0xF0)==0xF0) + continue; + if(v6addr) + *v6addr=NetworkAddress::IPv6(addr6->sin6_addr.s6_addr); + name=interface->ifa_name; + } + } + } + freeifaddrs(interfaces); + } +#endif + return name; +} + +uint16_t NetworkSocketPosix::GetLocalPort(){ + sockaddr_in6 addr; + size_t addrLen=sizeof(sockaddr_in6); + getsockname(fd, (sockaddr*)&addr, (socklen_t*) &addrLen); + return ntohs(addr.sin6_port); +} + +std::string NetworkSocketPosix::V4AddressToString(uint32_t address){ + char buf[INET_ADDRSTRLEN]; + in_addr addr; + addr.s_addr=address; + inet_ntop(AF_INET, &addr, buf, sizeof(buf)); + return std::string(buf); +} + +std::string NetworkSocketPosix::V6AddressToString(const unsigned char *address){ + char buf[INET6_ADDRSTRLEN]; + in6_addr addr; + memcpy(addr.s6_addr, address, 16); + inet_ntop(AF_INET6, &addr, buf, sizeof(buf)); + return std::string(buf); +} + +uint32_t NetworkSocketPosix::StringToV4Address(std::string address){ + in_addr addr; + inet_pton(AF_INET, address.c_str(), &addr); + return addr.s_addr; +} + +void NetworkSocketPosix::StringToV6Address(std::string address, unsigned char *out){ + in6_addr addr; + inet_pton(AF_INET6, address.c_str(), &addr); + memcpy(out, addr.s6_addr, 16); +} + +NetworkAddress NetworkSocketPosix::ResolveDomainName(std::string name){ + addrinfo* addr0; + NetworkAddress ret=NetworkAddress::Empty(); + int res=getaddrinfo(name.c_str(), NULL, NULL, &addr0); + if(res!=0){ + LOGW("Error updating NAT64 prefix: %d / %s", res, gai_strerror(res)); + }else{ + addrinfo* addrPtr; + for(addrPtr=addr0;addrPtr;addrPtr=addrPtr->ai_next){ + if(addrPtr->ai_family==AF_INET){ + sockaddr_in* addr=(sockaddr_in*)addrPtr->ai_addr; + ret=NetworkAddress::IPv4(addr->sin_addr.s_addr); + break; + } + } + freeaddrinfo(addr0); + } + return ret; +} + +NetworkAddress NetworkSocketPosix::GetConnectedAddress(){ + return tcpConnectedAddress; +} + +uint16_t NetworkSocketPosix::GetConnectedPort(){ + return tcpConnectedPort; +} + +void NetworkSocketPosix::SetTimeouts(int sendTimeout, int recvTimeout){ + timeval timeout; + timeout.tv_sec=sendTimeout; + timeout.tv_usec=0; + setsockopt(fd, SOL_SOCKET, SO_SNDTIMEO, &timeout, sizeof(timeout)); + timeout.tv_sec=recvTimeout; + setsockopt(fd, SOL_SOCKET, SO_RCVTIMEO, &timeout, sizeof(timeout)); +} + +bool NetworkSocketPosix::Select(std::vector &readFds, std::vector& writeFds, std::vector &errorFds, SocketSelectCanceller* _canceller){ + fd_set readSet; + fd_set writeSet; + fd_set errorSet; + FD_ZERO(&readSet); + FD_ZERO(&writeSet); + FD_ZERO(&errorSet); + SocketSelectCancellerPosix* canceller=dynamic_cast(_canceller); + if(canceller) + FD_SET(canceller->pipeRead, &readSet); + + int maxfd=canceller ? canceller->pipeRead : 0; + + for(NetworkSocket*& s:readFds){ + int sfd=GetDescriptorFromSocket(s); + if(sfd<=0){ + LOGW("can't select on one of sockets because it's not a NetworkSocketPosix instance"); + continue; + } + FD_SET(sfd, &readSet); + if(maxfdtimeout>0 && VoIPController::GetCurrentTime()-s->lastSuccessfulOperationTime>s->timeout){ + LOGW("Socket %d timed out", sfd); + s->failed=true; + } + anyFailed |= s->IsFailed(); + FD_SET(sfd, &errorSet); + if(maxfdpipeRead, &readSet) && !anyFailed){ + char c; + (void) read(canceller->pipeRead, &c, 1); + return false; + }else if(anyFailed){ + FD_ZERO(&readSet); + FD_ZERO(&writeSet); + } + + std::vector::iterator itr=readFds.begin(); + while(itr!=readFds.end()){ + int sfd=GetDescriptorFromSocket(*itr); + if(FD_ISSET(sfd, &readSet)) + (*itr)->lastSuccessfulOperationTime=VoIPController::GetCurrentTime(); + if(sfd==0 || !FD_ISSET(sfd, &readSet) || !(*itr)->OnReadyToReceive()){ + itr=readFds.erase(itr); + }else{ + ++itr; + } + } + + itr=writeFds.begin(); + while(itr!=writeFds.end()){ + int sfd=GetDescriptorFromSocket(*itr); + if(sfd==0 || !FD_ISSET(sfd, &writeSet)){ + itr=writeFds.erase(itr); + }else{ + LOGV("Socket %d is ready to send", sfd); + (*itr)->lastSuccessfulOperationTime=VoIPController::GetCurrentTime(); + if((*itr)->OnReadyToSend()) + ++itr; + else + itr=writeFds.erase(itr); + } + } + + itr=errorFds.begin(); + while(itr!=errorFds.end()){ + int sfd=GetDescriptorFromSocket(*itr); + if((sfd==0 || !FD_ISSET(sfd, &errorSet)) && !(*itr)->IsFailed()){ + itr=errorFds.erase(itr); + }else{ + ++itr; + } + } + //LOGV("select fds left: read=%d, write=%d, error=%d", (int)readFds.size(), (int)writeFds.size(), (int)errorFds.size()); + + return readFds.size()>0 || errorFds.size()>0 || writeFds.size()>0; +} + +SocketSelectCancellerPosix::SocketSelectCancellerPosix(){ + int p[2]; + int pipeRes=pipe(p); + if(pipeRes!=0){ + LOGE("pipe() failed"); + abort(); + } + pipeRead=p[0]; + pipeWrite=p[1]; +} + +SocketSelectCancellerPosix::~SocketSelectCancellerPosix(){ + close(pipeRead); + close(pipeWrite); +} + +void SocketSelectCancellerPosix::CancelSelect(){ + char c=1; + (void) write(pipeWrite, &c, 1); +} + +int NetworkSocketPosix::GetDescriptorFromSocket(NetworkSocket *socket){ + NetworkSocketPosix* sp=dynamic_cast(socket); + if(sp) + return sp->fd; + NetworkSocketWrapper* sw=dynamic_cast(socket); + if(sw) + return GetDescriptorFromSocket(sw->GetWrapped()); + return 0; +} diff --git a/TMessagesProj/jni/libtgvoip2/os/posix/NetworkSocketPosix.h b/TMessagesProj/jni/libtgvoip2/os/posix/NetworkSocketPosix.h new file mode 100644 index 000000000..ec4f6e8e9 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/posix/NetworkSocketPosix.h @@ -0,0 +1,77 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_NETWORKSOCKETPOSIX_H +#define LIBTGVOIP_NETWORKSOCKETPOSIX_H + +#include "../../NetworkSocket.h" +#include "../../Buffers.h" +#include +#include +#include +#include + +namespace tgvoip { + +class SocketSelectCancellerPosix : public SocketSelectCanceller { +friend class NetworkSocketPosix; +public: + SocketSelectCancellerPosix(); + virtual ~SocketSelectCancellerPosix(); + virtual void CancelSelect(); +private: + int pipeRead; + int pipeWrite; +}; + +class NetworkSocketPosix : public NetworkSocket { +public: + NetworkSocketPosix(NetworkProtocol protocol); + virtual ~NetworkSocketPosix() override; + virtual void Send(NetworkPacket packet) override; + virtual NetworkPacket Receive(size_t maxLen) override; + virtual void Open() override; + virtual void Close() override; + virtual void Connect(const NetworkAddress address, uint16_t port) override; + virtual std::string GetLocalInterfaceInfo(NetworkAddress* v4addr, NetworkAddress* v6addr) override; + virtual void OnActiveInterfaceChanged() override; + virtual uint16_t GetLocalPort() override; + + static std::string V4AddressToString(uint32_t address); + static std::string V6AddressToString(const unsigned char address[16]); + static uint32_t StringToV4Address(std::string address); + static void StringToV6Address(std::string address, unsigned char* out); + static NetworkAddress ResolveDomainName(std::string name); + static bool Select(std::vector& readFds, std::vector& writeFds, std::vector& errorFds, SocketSelectCanceller* canceller); + + virtual NetworkAddress GetConnectedAddress() override; + + virtual uint16_t GetConnectedPort() override; + + virtual void SetTimeouts(int sendTimeout, int recvTimeout) override; + virtual bool OnReadyToSend() override; + +protected: + virtual void SetMaxPriority() override; + +private: + static int GetDescriptorFromSocket(NetworkSocket* socket); + std::atomic fd; + std::mutex m_fd; + bool needUpdateNat64Prefix; + bool nat64Present; + double switchToV6at; + std::atomic isV4Available; + std::atomic closing; + NetworkAddress tcpConnectedAddress = NetworkAddress::Empty(); + uint16_t tcpConnectedPort; + NetworkPacket pendingOutgoingPacket = NetworkPacket::Empty(); + Buffer recvBuffer = Buffer(2048); +}; + +} + +#endif //LIBTGVOIP_NETWORKSOCKETPOSIX_H diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/AudioInputWASAPI.cpp b/TMessagesProj/jni/libtgvoip2/os/windows/AudioInputWASAPI.cpp new file mode 100644 index 000000000..1fcb92fef --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/AudioInputWASAPI.cpp @@ -0,0 +1,459 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + + +#include +#include "AudioInputWASAPI.h" +#include "../../logging.h" +#include "../../VoIPController.h" + +#define BUFFER_SIZE 960 +#define CHECK_RES(res, msg) {if(FAILED(res)){LOGE("%s failed: HRESULT=0x%08X", msg, res); failed=true; return;}} +#define SCHECK_RES(res, msg) {if(FAILED(res)){LOGE("%s failed: HRESULT=0x%08X", msg, res); return;}} + +template void SafeRelease(T **ppT) +{ + if(*ppT) + { + (*ppT)->Release(); + *ppT = NULL; + } +} + +using namespace tgvoip::audio; + +AudioInputWASAPI::AudioInputWASAPI(std::string deviceID){ + isRecording=false; + remainingDataLen=0; + refCount=1; + HRESULT res; + res=CoInitializeEx(NULL, COINIT_MULTITHREADED); + if(FAILED(res) && res!=RPC_E_CHANGED_MODE){ + CHECK_RES(res, "CoInitializeEx"); + } +#ifdef TGVOIP_WINXP_COMPAT + HANDLE (WINAPI *__CreateEventExA)(LPSECURITY_ATTRIBUTES lpEventAttributes, LPCSTR lpName, DWORD dwFlags, DWORD dwDesiredAccess); + __CreateEventExA=(HANDLE (WINAPI *)(LPSECURITY_ATTRIBUTES, LPCSTR, DWORD, DWORD))GetProcAddress(GetModuleHandleA("kernel32.dll"), "CreateEventExA"); +#undef CreateEventEx +#define CreateEventEx __CreateEventExA +#endif + shutdownEvent=CreateEventEx(NULL, NULL, 0, EVENT_MODIFY_STATE | SYNCHRONIZE); + audioSamplesReadyEvent=CreateEventEx(NULL, NULL, 0, EVENT_MODIFY_STATE | SYNCHRONIZE); + streamSwitchEvent=CreateEventEx(NULL, NULL, 0, EVENT_MODIFY_STATE | SYNCHRONIZE); + ZeroMemory(&format, sizeof(format)); + format.wFormatTag=WAVE_FORMAT_PCM; + format.nChannels=1; + format.nSamplesPerSec=48000; + format.nBlockAlign=2; + format.nAvgBytesPerSec=format.nSamplesPerSec*format.nBlockAlign; + format.wBitsPerSample=16; + +#ifdef TGVOIP_WINDOWS_DESKTOP + res=CoCreateInstance(__uuidof(MMDeviceEnumerator), NULL, CLSCTX_INPROC_SERVER, IID_PPV_ARGS(&enumerator)); + CHECK_RES(res, "CoCreateInstance(MMDeviceEnumerator)"); + res=enumerator->RegisterEndpointNotificationCallback(this); + CHECK_RES(res, "enumerator->RegisterEndpointNotificationCallback"); + audioSessionControl=NULL; + device=NULL; +#endif + + audioClient=NULL; + captureClient=NULL; + thread=NULL; + started=false; + + SetCurrentDevice(deviceID); +} + +AudioInputWASAPI::~AudioInputWASAPI(){ + if(audioClient && started){ + audioClient->Stop(); + } + +#ifdef TGVOIP_WINDOWS_DESKTOP + if(audioSessionControl){ + audioSessionControl->UnregisterAudioSessionNotification(this); + } +#endif + + SetEvent(shutdownEvent); + if(thread){ + WaitForSingleObjectEx(thread, INFINITE, false); + CloseHandle(thread); + } +#ifdef TGVOIP_WINDOWS_DESKTOP + SafeRelease(&audioSessionControl); +#endif + SafeRelease(&captureClient); + SafeRelease(&audioClient); +#ifdef TGVOIP_WINDOWS_DESKTOP + SafeRelease(&device); +#endif + CloseHandle(shutdownEvent); + CloseHandle(audioSamplesReadyEvent); + CloseHandle(streamSwitchEvent); +#ifdef TGVOIP_WINDOWS_DESKTOP + if(enumerator) + enumerator->UnregisterEndpointNotificationCallback(this); + SafeRelease(&enumerator); +#endif +} +void AudioInputWASAPI::Start(){ + isRecording=true; + if(!thread){ + thread=CreateThread(NULL, 0, AudioInputWASAPI::StartThread, this, 0, NULL); + } + + if(audioClient && !started){ + LOGI("audioClient->Start"); + audioClient->Start(); + started=true; + } +} + +void AudioInputWASAPI::Stop(){ + isRecording=false; +} + +bool AudioInputWASAPI::IsRecording(){ + return isRecording; +} + +void AudioInputWASAPI::EnumerateDevices(std::vector& devs){ +#ifdef TGVOIP_WINDOWS_DESKTOP + HRESULT res; + res=CoInitializeEx(NULL, COINIT_MULTITHREADED); + if(FAILED(res) && res!=RPC_E_CHANGED_MODE){ + SCHECK_RES(res, "CoInitializeEx"); + } + + IMMDeviceEnumerator *deviceEnumerator = NULL; + IMMDeviceCollection *deviceCollection = NULL; + + res=CoCreateInstance(__uuidof(MMDeviceEnumerator), NULL, CLSCTX_INPROC_SERVER, IID_PPV_ARGS(&deviceEnumerator)); + SCHECK_RES(res, "CoCreateInstance(MMDeviceEnumerator)"); + + res=deviceEnumerator->EnumAudioEndpoints(eCapture, DEVICE_STATE_ACTIVE, &deviceCollection); + SCHECK_RES(res, "EnumAudioEndpoints"); + + UINT devCount; + res=deviceCollection->GetCount(&devCount); + SCHECK_RES(res, "GetCount"); + + for(UINT i=0;iItem(i, &device); + SCHECK_RES(res, "GetDeviceItem"); + wchar_t* devID; + res=device->GetId(&devID); + SCHECK_RES(res, "get device id"); + + IPropertyStore* propStore; + res=device->OpenPropertyStore(STGM_READ, &propStore); + SafeRelease(&device); + SCHECK_RES(res, "OpenPropertyStore"); + + PROPVARIANT friendlyName; + PropVariantInit(&friendlyName); + res=propStore->GetValue(PKEY_Device_FriendlyName, &friendlyName); + SafeRelease(&propStore); + + AudioInputDevice dev; + + wchar_t actualFriendlyName[128]; + if(friendlyName.vt==VT_LPWSTR){ + wcsncpy(actualFriendlyName, friendlyName.pwszVal, sizeof(actualFriendlyName)/sizeof(wchar_t)); + }else{ + wcscpy(actualFriendlyName, L"Unknown"); + } + PropVariantClear(&friendlyName); + + char buf[256]; + WideCharToMultiByte(CP_UTF8, 0, devID, -1, buf, sizeof(buf), NULL, NULL); + dev.id=buf; + WideCharToMultiByte(CP_UTF8, 0, actualFriendlyName, -1, buf, sizeof(buf), NULL, NULL); + dev.displayName=buf; + devs.push_back(dev); + + CoTaskMemFree(devID); + } + + SafeRelease(&deviceCollection); + SafeRelease(&deviceEnumerator); +#endif +} + +void AudioInputWASAPI::SetCurrentDevice(std::string deviceID){ + if(thread){ + streamChangeToDevice=deviceID; + SetEvent(streamSwitchEvent); + }else{ + ActuallySetCurrentDevice(deviceID); + } +} + +void AudioInputWASAPI::ActuallySetCurrentDevice(std::string deviceID){ + currentDevice=deviceID; + HRESULT res; + + if(audioClient){ + res=audioClient->Stop(); + CHECK_RES(res, "audioClient->Stop"); + } + +#ifdef TGVOIP_WINDOWS_DESKTOP + if(audioSessionControl){ + res=audioSessionControl->UnregisterAudioSessionNotification(this); + CHECK_RES(res, "audioSessionControl->UnregisterAudioSessionNotification"); + } + + SafeRelease(&audioSessionControl); +#endif + SafeRelease(&captureClient); + SafeRelease(&audioClient); +#ifdef TGVOIP_WINDOWS_DESKTOP + SafeRelease(&device); + + IMMDeviceCollection *deviceCollection = NULL; + + if(deviceID=="default"){ + isDefaultDevice=true; + res=enumerator->GetDefaultAudioEndpoint(eCapture, eCommunications, &device); + CHECK_RES(res, "GetDefaultAudioEndpoint"); + }else{ + isDefaultDevice=false; + res=enumerator->EnumAudioEndpoints(eCapture, DEVICE_STATE_ACTIVE, &deviceCollection); + CHECK_RES(res, "EnumAudioEndpoints"); + + UINT devCount; + res=deviceCollection->GetCount(&devCount); + CHECK_RES(res, "GetCount"); + + for(UINT i=0;iItem(i, &device); + CHECK_RES(res, "GetDeviceItem"); + wchar_t* _devID; + res=device->GetId(&_devID); + CHECK_RES(res, "get device id"); + + char devID[128]; + WideCharToMultiByte(CP_UTF8, 0, _devID, -1, devID, 128, NULL, NULL); + + CoTaskMemFree(_devID); + if(deviceID==devID){ + this->device=device; + //device->AddRef(); + break; + } + } + } + + if(deviceCollection) + SafeRelease(&deviceCollection); + + if(!device){ + LOGE("Didn't find capture device; failing"); + failed=true; + return; + } + + res=device->Activate(__uuidof(IAudioClient), CLSCTX_INPROC_SERVER, NULL, (void**)&audioClient); + CHECK_RES(res, "device->Activate"); +#else + std::wstring devID; + + if (deviceID=="default"){ + Platform::String^ defaultDevID=Windows::Media::Devices::MediaDevice::GetDefaultAudioCaptureId(Windows::Media::Devices::AudioDeviceRole::Communications); + if(defaultDevID==nullptr){ + LOGE("Didn't find capture device; failing"); + failed=true; + return; + }else{ + isDefaultDevice=true; + devID=defaultDevID->Data(); + } + }else{ + int wchars_num=MultiByteToWideChar(CP_UTF8, 0, deviceID.c_str(), -1, NULL, 0); + wchar_t* wstr=new wchar_t[wchars_num]; + MultiByteToWideChar(CP_UTF8, 0, deviceID.c_str(), -1, wstr, wchars_num); + devID=wstr; + } + + HRESULT res1, res2; + IAudioClient2* audioClient2=WindowsSandboxUtils::ActivateAudioDevice(devID.c_str(), &res1, &res2); + CHECK_RES(res1, "activate1"); + CHECK_RES(res2, "activate2"); + + AudioClientProperties properties={}; + properties.cbSize=sizeof AudioClientProperties; + properties.eCategory=AudioCategory_Communications; + res = audioClient2->SetClientProperties(&properties); + CHECK_RES(res, "audioClient2->SetClientProperties"); + + audioClient=audioClient2; +#endif + + // {2C693079-3F59-49FD-964F-61C005EAA5D3} + const GUID guid = { 0x2c693079, 0x3f59, 0x49fd, { 0x96, 0x4f, 0x61, 0xc0, 0x5, 0xea, 0xa5, 0xd3 } }; + // Use 1000ms buffer to avoid resampling glitches on Windows 8.1 and older. This should not increase latency. + res = audioClient->Initialize(AUDCLNT_SHAREMODE_SHARED, AUDCLNT_STREAMFLAGS_EVENTCALLBACK | AUDCLNT_STREAMFLAGS_NOPERSIST | AUDCLNT_STREAMFLAGS_AUTOCONVERTPCM | AUDCLNT_STREAMFLAGS_SRC_DEFAULT_QUALITY, 1000*10000, 0, &format, &guid); + CHECK_RES(res, "audioClient->Initialize"); + + uint32_t bufSize; + res = audioClient->GetBufferSize(&bufSize); + CHECK_RES(res, "audioClient->GetBufferSize"); + + LOGV("buffer size: %u", bufSize); + estimatedDelay=0; + REFERENCE_TIME latency, devicePeriod; + if(SUCCEEDED(audioClient->GetStreamLatency(&latency))){ + if(SUCCEEDED(audioClient->GetDevicePeriod(&devicePeriod, NULL))){ + estimatedDelay=(int32_t)(latency/10000+devicePeriod/10000); + } + } + + res = audioClient->SetEventHandle(audioSamplesReadyEvent); + CHECK_RES(res, "audioClient->SetEventHandle"); + + res = audioClient->GetService(IID_PPV_ARGS(&captureClient)); + CHECK_RES(res, "audioClient->GetService"); + +#ifdef TGVOIP_WINDOWS_DESKTOP + res=audioClient->GetService(IID_PPV_ARGS(&audioSessionControl)); + CHECK_RES(res, "audioClient->GetService(IAudioSessionControl)"); + + res=audioSessionControl->RegisterAudioSessionNotification(this); + CHECK_RES(res, "audioSessionControl->RegisterAudioSessionNotification"); +#endif + + if(isRecording) + audioClient->Start(); + + LOGV("set current input device done"); +} + +DWORD WINAPI AudioInputWASAPI::StartThread(void* arg) { + LOGV("WASAPI capture thread starting"); + ((AudioInputWASAPI*)arg)->RunThread(); + return 0; +} + +void AudioInputWASAPI::RunThread() { + if(failed) + return; + SetThreadPriority(GetCurrentThread(), THREAD_PRIORITY_HIGHEST); + + HANDLE waitArray[]={shutdownEvent, streamSwitchEvent, audioSamplesReadyEvent}; + HRESULT res=CoInitializeEx(NULL, COINIT_MULTITHREADED); + CHECK_RES(res, "CoInitializeEx in capture thread"); + + uint32_t bufferSize=0; + uint64_t framesWritten=0; + + bool running=true; + //double prevCallback=VoIPController::GetCurrentTime(); + + while(running){ + DWORD waitResult=WaitForMultipleObjectsEx(3, waitArray, false, INFINITE, false); + if(waitResult==WAIT_OBJECT_0){ // shutdownEvent + LOGV("capture thread shutting down"); + running=false; + }else if(waitResult==WAIT_OBJECT_0+1){ // streamSwitchEvent + LOGV("stream switch"); + ActuallySetCurrentDevice(streamChangeToDevice); + ResetEvent(streamSwitchEvent); + bufferSize=0; + LOGV("stream switch done"); + }else if(waitResult==WAIT_OBJECT_0+2){ // audioSamplesReadyEvent + if(!audioClient) + continue; + res=captureClient->GetNextPacketSize(&bufferSize); + CHECK_RES(res, "captureClient->GetNextPacketSize"); + BYTE* data; + uint32_t framesAvailable=0; + DWORD flags; + + res=captureClient->GetBuffer(&data, &framesAvailable, &flags, NULL, NULL); + CHECK_RES(res, "captureClient->GetBuffer"); + size_t dataLen=framesAvailable*2; + assert(remainingDataLen+dataLen960*2){ + if(isRecording) + InvokeCallback(remainingData, 960*2); + + //LOGV("remaining data len %u", remainingDataLen); + memmove(remainingData, remainingData+(960*2), remainingDataLen-960*2); + remainingDataLen-=960*2; + } + + res=captureClient->ReleaseBuffer(framesAvailable); + CHECK_RES(res, "captureClient->ReleaseBuffer"); + //estimatedDelay=(int32_t)((devicePosition-framesWritten)/48); + + framesWritten+=framesAvailable; + } + } +} + +#ifdef TGVOIP_WINDOWS_DESKTOP +HRESULT AudioInputWASAPI::OnSessionDisconnected(AudioSessionDisconnectReason reason) { + if(!isDefaultDevice){ + streamChangeToDevice="default"; + SetEvent(streamSwitchEvent); + } + return S_OK; +} + +HRESULT AudioInputWASAPI::OnDefaultDeviceChanged(EDataFlow flow, ERole role, LPCWSTR newDevID) { + if(flow==eCapture && role==eCommunications && isDefaultDevice){ + streamChangeToDevice="default"; + SetEvent(streamSwitchEvent); + } + return S_OK; +} + +ULONG AudioInputWASAPI::AddRef(){ + return InterlockedIncrement(&refCount); +} + +ULONG AudioInputWASAPI::Release(){ + return InterlockedDecrement(&refCount); +} + +HRESULT AudioInputWASAPI::QueryInterface(REFIID iid, void** obj){ + if(!obj){ + return E_POINTER; + } + *obj=NULL; + + if(iid==IID_IUnknown){ + *obj=static_cast(static_cast(this)); + AddRef(); + }else if(iid==__uuidof(IMMNotificationClient)){ + *obj=static_cast(this); + AddRef(); + }else if(iid==__uuidof(IAudioSessionEvents)){ + *obj=static_cast(this); + AddRef(); + }else{ + return E_NOINTERFACE; + } + + return S_OK; +} +#endif \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/AudioInputWASAPI.h b/TMessagesProj/jni/libtgvoip2/os/windows/AudioInputWASAPI.h new file mode 100644 index 000000000..b92ef25ed --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/AudioInputWASAPI.h @@ -0,0 +1,105 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOINPUTWASAPI_H +#define LIBTGVOIP_AUDIOINPUTWASAPI_H + +#if WINAPI_FAMILY==WINAPI_FAMILY_PHONE_APP +#define TGVOIP_WINDOWS_PHONE +#endif +#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY==WINAPI_FAMILY_DESKTOP_APP +#define TGVOIP_WINDOWS_DESKTOP +#endif + +#include +#include +#include +#pragma warning(push) +#pragma warning(disable : 4201) +#ifndef TGVOIP_WP_SILVERLIGHT +#include +#endif +#ifdef TGVOIP_WINDOWS_DESKTOP +#include +#include +#else +#include +#include "WindowsSandboxUtils.h" +#endif +#pragma warning(pop) +#include "../../audio/AudioInput.h" + +namespace tgvoip{ +namespace audio{ + +#ifdef TGVOIP_WINDOWS_DESKTOP +class AudioInputWASAPI : public AudioInput, IMMNotificationClient, IAudioSessionEvents{ +#else +class AudioInputWASAPI : public AudioInput{ +#endif + +public: + AudioInputWASAPI(std::string deviceID); + virtual ~AudioInputWASAPI(); + virtual void Start(); + virtual void Stop(); + virtual bool IsRecording(); + virtual void SetCurrentDevice(std::string deviceID); + static void EnumerateDevices(std::vector& devs); +#ifdef TGVOIP_WINDOWS_DESKTOP + STDMETHOD_(ULONG, AddRef)(); + STDMETHOD_(ULONG, Release)(); +#endif + +private: + void ActuallySetCurrentDevice(std::string deviceID); + static DWORD WINAPI StartThread(void* arg); + void RunThread(); + WAVEFORMATEX format; + bool isRecording; + HANDLE shutdownEvent; + HANDLE audioSamplesReadyEvent; + HANDLE streamSwitchEvent; + HANDLE thread; + IAudioClient* audioClient=NULL; + IAudioCaptureClient* captureClient=NULL; +#ifdef TGVOIP_WINDOWS_DESKTOP + IMMDeviceEnumerator* enumerator; + IAudioSessionControl* audioSessionControl; + IMMDevice* device; +#endif + unsigned char remainingData[10240]; + size_t remainingDataLen; + bool isDefaultDevice; + ULONG refCount; + std::string streamChangeToDevice; + bool started; + +#ifdef TGVOIP_WINDOWS_DESKTOP + STDMETHOD(OnDisplayNameChanged) (LPCWSTR /*NewDisplayName*/, LPCGUID /*EventContext*/) { return S_OK; }; + STDMETHOD(OnIconPathChanged) (LPCWSTR /*NewIconPath*/, LPCGUID /*EventContext*/) { return S_OK; }; + STDMETHOD(OnSimpleVolumeChanged) (float /*NewSimpleVolume*/, BOOL /*NewMute*/, LPCGUID /*EventContext*/) { return S_OK; } + STDMETHOD(OnChannelVolumeChanged) (DWORD /*ChannelCount*/, float /*NewChannelVolumes*/[], DWORD /*ChangedChannel*/, LPCGUID /*EventContext*/) { return S_OK; }; + STDMETHOD(OnGroupingParamChanged) (LPCGUID /*NewGroupingParam*/, LPCGUID /*EventContext*/) { return S_OK; }; + STDMETHOD(OnStateChanged) (AudioSessionState /*NewState*/) { return S_OK; }; + STDMETHOD(OnSessionDisconnected) (AudioSessionDisconnectReason DisconnectReason); + STDMETHOD(OnDeviceStateChanged) (LPCWSTR /*DeviceId*/, DWORD /*NewState*/) { return S_OK; } + STDMETHOD(OnDeviceAdded) (LPCWSTR /*DeviceId*/) { return S_OK; }; + STDMETHOD(OnDeviceRemoved) (LPCWSTR /*DeviceId(*/) { return S_OK; }; + STDMETHOD(OnDefaultDeviceChanged) (EDataFlow Flow, ERole Role, LPCWSTR NewDefaultDeviceId); + STDMETHOD(OnPropertyValueChanged) (LPCWSTR /*DeviceId*/, const PROPERTYKEY /*Key*/) { return S_OK; }; + + // + // IUnknown + // + STDMETHOD(QueryInterface)(REFIID iid, void **pvObject); +#endif +}; + +} +} + +#endif //LIBTGVOIP_AUDIOINPUTWASAPI_H diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/AudioInputWave.cpp b/TMessagesProj/jni/libtgvoip2/os/windows/AudioInputWave.cpp new file mode 100644 index 000000000..233d95187 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/AudioInputWave.cpp @@ -0,0 +1,170 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include +#include +#include +#include "AudioInputWave.h" +#include "../../logging.h" +#include "../../VoIPController.h" + +using namespace tgvoip::audio; + +#define BUFFER_SIZE 960 +#define CHECK_ERROR(res, msg) if(res!=MMSYSERR_NOERROR){wchar_t _buf[1024]; waveInGetErrorTextW(res, _buf, 1024); LOGE(msg ": %ws (MMRESULT=0x%08X)", _buf, res); failed=true;} + +AudioInputWave::AudioInputWave(std::string deviceID){ + isRecording=false; + + for(int i=0;i<4;i++){ + ZeroMemory(&buffers[i], sizeof(WAVEHDR)); + buffers[i].dwBufferLength=960*2; + buffers[i].lpData=(char*)malloc(960*2); + } + + hWaveIn=NULL; + + SetCurrentDevice(deviceID); +} + +AudioInputWave::~AudioInputWave(){ + for(int i=0;i<4;i++){ + free(buffers[i].lpData); + } + waveInClose(hWaveIn); +} + +void AudioInputWave::Start(){ + if(!isRecording){ + isRecording=true; + + MMRESULT res; + for(int i=0;i<4;i++){ + res=waveInPrepareHeader(hWaveIn, &buffers[i], sizeof(WAVEHDR)); + CHECK_ERROR(res, "waveInPrepareHeader failed"); + res=waveInAddBuffer(hWaveIn, &buffers[i], sizeof(WAVEHDR)); + CHECK_ERROR(res, "waveInAddBuffer failed"); + } + res=waveInStart(hWaveIn); + CHECK_ERROR(res, "waveInStart failed"); + } +} + +void AudioInputWave::Stop(){ + if(isRecording){ + isRecording=false; + + MMRESULT res=waveInStop(hWaveIn); + CHECK_ERROR(res, "waveInStop failed"); + res=waveInReset(hWaveIn); + CHECK_ERROR(res, "waveInReset failed"); + for(int i=0;i<4;i++){ + res=waveInUnprepareHeader(hWaveIn, &buffers[i], sizeof(WAVEHDR)); + CHECK_ERROR(res, "waveInUnprepareHeader failed"); + } + } +} + +void CALLBACK AudioInputWave::WaveInProc(HWAVEIN hwi, UINT uMsg, DWORD_PTR dwInstance, DWORD_PTR dwParam1, DWORD_PTR dwParam2){ + if(uMsg==WIM_DATA){ + ((AudioInputWave*)dwInstance)->OnData((WAVEHDR*)dwParam1); + } +} + +void AudioInputWave::OnData(WAVEHDR* hdr){ + if(!isRecording) + return; + + InvokeCallback((unsigned char*)hdr->lpData, hdr->dwBufferLength); + hdr->dwFlags&= ~WHDR_DONE; + MMRESULT res=waveInAddBuffer(hWaveIn, hdr, sizeof(WAVEHDR)); + CHECK_ERROR(res, "waveInAddBuffer failed"); +} + +void AudioInputWave::EnumerateDevices(std::vector& devs){ + UINT num=waveInGetNumDevs(); + WAVEINCAPSW caps; + char nameBuf[512]; + for(UINT i=0;i +#include +#include +#include "../../audio/AudioInput.h" + +namespace tgvoip{ +namespace audio{ + +class AudioInputWave : public AudioInput{ + +public: + AudioInputWave(std::string deviceID); + virtual ~AudioInputWave(); + virtual void Start(); + virtual void Stop(); + virtual void SetCurrentDevice(std::string deviceID); + static void EnumerateDevices(std::vector& devs); + +private: + static void CALLBACK WaveInProc(HWAVEIN hwi, UINT uMsg, DWORD_PTR dwInstance, DWORD_PTR dwParam1, DWORD_PTR dwParam2); + void OnData(WAVEHDR* hdr); + HWAVEIN hWaveIn; + WAVEFORMATEX format; + WAVEHDR buffers[4]; + bool isRecording; +}; + +} +} + +#endif //LIBTGVOIP_AUDIOINPUTWAVE_H diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/AudioOutputWASAPI.cpp b/TMessagesProj/jni/libtgvoip2/os/windows/AudioOutputWASAPI.cpp new file mode 100644 index 000000000..e667fcc82 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/AudioOutputWASAPI.cpp @@ -0,0 +1,455 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + + +#include +#include "AudioOutputWASAPI.h" +#include "../../logging.h" +#include "../../VoIPController.h" + +#define BUFFER_SIZE 960 +#define CHECK_RES(res, msg) {if(FAILED(res)){LOGE("%s failed: HRESULT=0x%08X", msg, res); failed=true; return;}} +#define SCHECK_RES(res, msg) {if(FAILED(res)){LOGE("%s failed: HRESULT=0x%08X", msg, res); return;}} + +template void SafeRelease(T **ppT) +{ + if(*ppT) + { + (*ppT)->Release(); + *ppT = NULL; + } +} + +#ifdef TGVOIP_WINXP_COMPAT + +#endif + +using namespace tgvoip::audio; + +AudioOutputWASAPI::AudioOutputWASAPI(std::string deviceID){ + isPlaying=false; + remainingDataLen=0; + refCount=1; + HRESULT res; + res=CoInitializeEx(NULL, COINIT_MULTITHREADED); + if(FAILED(res) && res!=RPC_E_CHANGED_MODE){ + CHECK_RES(res, "CoInitializeEx"); + } +#ifdef TGVOIP_WINXP_COMPAT + HANDLE (WINAPI *__CreateEventExA)(LPSECURITY_ATTRIBUTES lpEventAttributes, LPCSTR lpName, DWORD dwFlags, DWORD dwDesiredAccess); + __CreateEventExA=(HANDLE (WINAPI *)(LPSECURITY_ATTRIBUTES, LPCSTR, DWORD, DWORD))GetProcAddress(GetModuleHandleA("kernel32.dll"), "CreateEventExA"); +#undef CreateEventEx +#define CreateEventEx __CreateEventExA +#endif + shutdownEvent=CreateEventEx(NULL, NULL, 0, EVENT_MODIFY_STATE | SYNCHRONIZE); + audioSamplesReadyEvent=CreateEventEx(NULL, NULL, 0, EVENT_MODIFY_STATE | SYNCHRONIZE); + streamSwitchEvent=CreateEventEx(NULL, NULL, 0, EVENT_MODIFY_STATE | SYNCHRONIZE); + ZeroMemory(&format, sizeof(format)); + format.wFormatTag=WAVE_FORMAT_PCM; + format.nChannels=1; + format.nSamplesPerSec=48000; + format.nBlockAlign=2; + format.nAvgBytesPerSec=format.nSamplesPerSec*format.nBlockAlign; + format.wBitsPerSample=16; + +#ifdef TGVOIP_WINDOWS_DESKTOP + res=CoCreateInstance(__uuidof(MMDeviceEnumerator), NULL, CLSCTX_INPROC_SERVER, IID_PPV_ARGS(&enumerator)); + CHECK_RES(res, "CoCreateInstance(MMDeviceEnumerator)"); + res=enumerator->RegisterEndpointNotificationCallback(this); + CHECK_RES(res, "enumerator->RegisterEndpointNotificationCallback"); + audioSessionControl=NULL; + device=NULL; +#endif + + audioClient=NULL; + renderClient=NULL; + thread=NULL; + + SetCurrentDevice(deviceID); +} + +AudioOutputWASAPI::~AudioOutputWASAPI(){ + if(audioClient){ + audioClient->Stop(); + } + +#ifdef TGVOIP_WINDOWS_DESKTOP + if(audioSessionControl){ + audioSessionControl->UnregisterAudioSessionNotification(this); + } +#endif + + SetEvent(shutdownEvent); + if(thread){ + WaitForSingleObjectEx(thread, INFINITE, false); + CloseHandle(thread); + } + SafeRelease(&renderClient); + SafeRelease(&audioClient); +#ifdef TGVOIP_WINDOWS_DESKTOP + SafeRelease(&device); + SafeRelease(&audioSessionControl); +#endif + CloseHandle(shutdownEvent); + CloseHandle(audioSamplesReadyEvent); + CloseHandle(streamSwitchEvent); +#ifdef TGVOIP_WINDOWS_DESKTOP + if(enumerator) + enumerator->UnregisterEndpointNotificationCallback(this); + SafeRelease(&enumerator); +#endif +} + +void AudioOutputWASAPI::Start(){ + isPlaying=true; + if(!thread){ + thread=CreateThread(NULL, 0, AudioOutputWASAPI::StartThread, this, 0, NULL); + } +} + +void AudioOutputWASAPI::Stop(){ + isPlaying=false; +} + +bool AudioOutputWASAPI::IsPlaying(){ + return isPlaying; +} + +void AudioOutputWASAPI::EnumerateDevices(std::vector& devs){ +#ifdef TGVOIP_WINDOWS_DESKTOP + HRESULT res; + res=CoInitializeEx(NULL, COINIT_MULTITHREADED); + if(FAILED(res) && res!=RPC_E_CHANGED_MODE){ + SCHECK_RES(res, "CoInitializeEx"); + } + + IMMDeviceEnumerator *deviceEnumerator = NULL; + IMMDeviceCollection *deviceCollection = NULL; + + res=CoCreateInstance(__uuidof(MMDeviceEnumerator), NULL, CLSCTX_INPROC_SERVER, IID_PPV_ARGS(&deviceEnumerator)); + SCHECK_RES(res, "CoCreateInstance(MMDeviceEnumerator)"); + + res=deviceEnumerator->EnumAudioEndpoints(eRender, DEVICE_STATE_ACTIVE, &deviceCollection); + SCHECK_RES(res, "EnumAudioEndpoints"); + + UINT devCount; + res=deviceCollection->GetCount(&devCount); + SCHECK_RES(res, "GetCount"); + + for(UINT i=0;iItem(i, &device); + SCHECK_RES(res, "GetDeviceItem"); + wchar_t* devID; + res=device->GetId(&devID); + SCHECK_RES(res, "get device id"); + + IPropertyStore* propStore; + res=device->OpenPropertyStore(STGM_READ, &propStore); + SafeRelease(&device); + SCHECK_RES(res, "OpenPropertyStore"); + + PROPVARIANT friendlyName; + PropVariantInit(&friendlyName); + res=propStore->GetValue(PKEY_Device_FriendlyName, &friendlyName); + SafeRelease(&propStore); + + AudioOutputDevice dev; + + wchar_t actualFriendlyName[128]; + if(friendlyName.vt==VT_LPWSTR){ + wcsncpy(actualFriendlyName, friendlyName.pwszVal, sizeof(actualFriendlyName)/sizeof(wchar_t)); + }else{ + wcscpy(actualFriendlyName, L"Unknown"); + } + PropVariantClear(&friendlyName); + + char buf[256]; + WideCharToMultiByte(CP_UTF8, 0, devID, -1, buf, sizeof(buf), NULL, NULL); + dev.id=buf; + WideCharToMultiByte(CP_UTF8, 0, actualFriendlyName, -1, buf, sizeof(buf), NULL, NULL); + dev.displayName=buf; + devs.push_back(dev); + + CoTaskMemFree(devID); + } + + SafeRelease(&deviceCollection); + SafeRelease(&deviceEnumerator); +#endif +} + +void AudioOutputWASAPI::SetCurrentDevice(std::string deviceID){ + if(thread){ + streamChangeToDevice=deviceID; + SetEvent(streamSwitchEvent); + }else{ + ActuallySetCurrentDevice(deviceID); + } +} + +void AudioOutputWASAPI::ActuallySetCurrentDevice(std::string deviceID){ + currentDevice=deviceID; + HRESULT res; + + if(audioClient){ + res=audioClient->Stop(); + CHECK_RES(res, "audioClient->Stop"); + } + +#ifdef TGVOIP_WINDOWS_DESKTOP + if(audioSessionControl){ + res=audioSessionControl->UnregisterAudioSessionNotification(this); + CHECK_RES(res, "audioSessionControl->UnregisterAudioSessionNotification"); + } + + SafeRelease(&audioSessionControl); +#endif + SafeRelease(&renderClient); + SafeRelease(&audioClient); +#ifdef TGVOIP_WINDOWS_DESKTOP + SafeRelease(&device); + + + IMMDeviceCollection *deviceCollection = NULL; + + if(deviceID=="default"){ + isDefaultDevice=true; + res=enumerator->GetDefaultAudioEndpoint(eRender, eCommunications, &device); + CHECK_RES(res, "GetDefaultAudioEndpoint"); + }else{ + isDefaultDevice=false; + res=enumerator->EnumAudioEndpoints(eRender, DEVICE_STATE_ACTIVE, &deviceCollection); + CHECK_RES(res, "EnumAudioEndpoints"); + + UINT devCount; + res=deviceCollection->GetCount(&devCount); + CHECK_RES(res, "GetCount"); + + for(UINT i=0;iItem(i, &device); + CHECK_RES(res, "GetDeviceItem"); + wchar_t* _devID; + res=device->GetId(&_devID); + CHECK_RES(res, "get device id"); + + char devID[128]; + WideCharToMultiByte(CP_UTF8, 0, _devID, -1, devID, 128, NULL, NULL); + + CoTaskMemFree(_devID); + if(deviceID==devID){ + this->device=device; + break; + } + } + } + + if(deviceCollection) + SafeRelease(&deviceCollection); + + if(!device){ + LOGE("Didn't find playback device; failing"); + failed=true; + return; + } + + res=device->Activate(__uuidof(IAudioClient), CLSCTX_INPROC_SERVER, NULL, (void**)&audioClient); + CHECK_RES(res, "device->Activate"); +#else + std::wstring devID; + + if (deviceID=="default"){ + Platform::String^ defaultDevID=Windows::Media::Devices::MediaDevice::GetDefaultAudioRenderId(Windows::Media::Devices::AudioDeviceRole::Communications); + if(defaultDevID==nullptr){ + LOGE("Didn't find playback device; failing"); + failed=true; + return; + }else{ + isDefaultDevice=true; + devID=defaultDevID->Data(); + } + }else{ + int wchars_num=MultiByteToWideChar(CP_UTF8, 0, deviceID.c_str(), -1, NULL, 0); + wchar_t* wstr=new wchar_t[wchars_num]; + MultiByteToWideChar(CP_UTF8, 0, deviceID.c_str(), -1, wstr, wchars_num); + devID=wstr; + } + + HRESULT res1, res2; + IAudioClient2* audioClient2=WindowsSandboxUtils::ActivateAudioDevice(devID.c_str(), &res1, &res2); + CHECK_RES(res1, "activate1"); + CHECK_RES(res2, "activate2"); + + AudioClientProperties properties={}; + properties.cbSize=sizeof AudioClientProperties; + properties.eCategory=AudioCategory_Communications; + res = audioClient2->SetClientProperties(&properties); + CHECK_RES(res, "audioClient2->SetClientProperties"); + + audioClient = audioClient2; +#endif + + // {2C693079-3F59-49FD-964F-61C005EAA5D3} + const GUID guid = { 0x2c693079, 0x3f59, 0x49fd, { 0x96, 0x4f, 0x61, 0xc0, 0x5, 0xea, 0xa5, 0xd3 } }; + res = audioClient->Initialize(AUDCLNT_SHAREMODE_SHARED, AUDCLNT_STREAMFLAGS_EVENTCALLBACK | AUDCLNT_STREAMFLAGS_NOPERSIST | AUDCLNT_STREAMFLAGS_AUTOCONVERTPCM | AUDCLNT_STREAMFLAGS_SRC_DEFAULT_QUALITY, 60 * 10000, 0, &format, &guid); + CHECK_RES(res, "audioClient->Initialize"); + + uint32_t bufSize; + res = audioClient->GetBufferSize(&bufSize); + CHECK_RES(res, "audioClient->GetBufferSize"); + + LOGV("buffer size: %u", bufSize); + estimatedDelay=0; + REFERENCE_TIME latency, devicePeriod; + if(SUCCEEDED(audioClient->GetStreamLatency(&latency))){ + if(SUCCEEDED(audioClient->GetDevicePeriod(&devicePeriod, NULL))){ + estimatedDelay=(int32_t)(latency/10000+devicePeriod/10000); + } + } + + res = audioClient->SetEventHandle(audioSamplesReadyEvent); + CHECK_RES(res, "audioClient->SetEventHandle"); + + res = audioClient->GetService(IID_PPV_ARGS(&renderClient)); + CHECK_RES(res, "audioClient->GetService"); + + BYTE* data; + res = renderClient->GetBuffer(bufSize, &data); + CHECK_RES(res, "renderClient->GetBuffer"); + + res = renderClient->ReleaseBuffer(bufSize, AUDCLNT_BUFFERFLAGS_SILENT); + CHECK_RES(res, "renderClient->ReleaseBuffer"); + +#ifdef TGVOIP_WINDOWS_DESKTOP + res=audioClient->GetService(IID_PPV_ARGS(&audioSessionControl)); + CHECK_RES(res, "audioClient->GetService(IAudioSessionControl)"); + + res=audioSessionControl->RegisterAudioSessionNotification(this); + CHECK_RES(res, "audioSessionControl->RegisterAudioSessionNotification"); +#endif + + audioClient->Start(); + + LOGV("set current output device done"); +} + +DWORD WINAPI AudioOutputWASAPI::StartThread(void* arg) { + ((AudioOutputWASAPI*)arg)->RunThread(); + return 0; +} + +void AudioOutputWASAPI::RunThread() { + SetThreadPriority(GetCurrentThread(), THREAD_PRIORITY_HIGHEST); + + HANDLE waitArray[]={shutdownEvent, streamSwitchEvent, audioSamplesReadyEvent}; + HRESULT res=CoInitializeEx(NULL, COINIT_MULTITHREADED); + CHECK_RES(res, "CoInitializeEx in render thread"); + + uint32_t bufferSize; + res=audioClient->GetBufferSize(&bufferSize); + CHECK_RES(res, "audioClient->GetBufferSize"); + uint64_t framesWritten=0; + + bool running=true; + //double prevCallback=VoIPController::GetCurrentTime(); + + while(running){ + DWORD waitResult=WaitForMultipleObjectsEx(3, waitArray, false, INFINITE, false); + if(waitResult==WAIT_OBJECT_0){ // shutdownEvent + LOGV("render thread shutting down"); + running=false; + }else if(waitResult==WAIT_OBJECT_0+1){ // streamSwitchEvent + LOGV("stream switch"); + ActuallySetCurrentDevice(streamChangeToDevice); + ResetEvent(streamSwitchEvent); + LOGV("stream switch done"); + }else if(waitResult==WAIT_OBJECT_0+2){ // audioSamplesReadyEvent + if(!audioClient) + continue; + + BYTE* data; + uint32_t padding; + uint32_t framesAvailable; + res=audioClient->GetCurrentPadding(&padding); + CHECK_RES(res, "audioClient->GetCurrentPadding"); + framesAvailable=bufferSize-padding; + res=renderClient->GetBuffer(framesAvailable, &data); + CHECK_RES(res, "renderClient->GetBuffer"); + + //double t=VoIPController::GetCurrentTime(); + //LOGV("framesAvail: %u, time: %f, isPlaying: %d", framesAvailable, t-prevCallback, isPlaying); + //prevCallback=t; + + size_t bytesAvailable=framesAvailable*2; + while(bytesAvailable>remainingDataLen){ + if(isPlaying){ + InvokeCallback(remainingData+remainingDataLen, 960*2); + }else{ + memset(remainingData+remainingDataLen, 0, 960*2); + } + remainingDataLen+=960*2; + } + memcpy(data, remainingData, bytesAvailable); + if(remainingDataLen>bytesAvailable){ + memmove(remainingData, remainingData+bytesAvailable, remainingDataLen-bytesAvailable); + } + remainingDataLen-=bytesAvailable; + + res=renderClient->ReleaseBuffer(framesAvailable, 0); + CHECK_RES(res, "renderClient->ReleaseBuffer"); + framesWritten+=framesAvailable; + } + } +} + +#ifdef TGVOIP_WINDOWS_DESKTOP +HRESULT AudioOutputWASAPI::OnSessionDisconnected(AudioSessionDisconnectReason reason) { + if(!isDefaultDevice){ + streamChangeToDevice="default"; + SetEvent(streamSwitchEvent); + } + return S_OK; +} + +HRESULT AudioOutputWASAPI::OnDefaultDeviceChanged(EDataFlow flow, ERole role, LPCWSTR newDevID) { + if(flow==eRender && role==eCommunications && isDefaultDevice){ + streamChangeToDevice="default"; + SetEvent(streamSwitchEvent); + } + return S_OK; +} + +ULONG AudioOutputWASAPI::AddRef(){ + return InterlockedIncrement(&refCount); +} + +ULONG AudioOutputWASAPI::Release(){ + return InterlockedDecrement(&refCount); +} + +HRESULT AudioOutputWASAPI::QueryInterface(REFIID iid, void** obj){ + if(!obj){ + return E_POINTER; + } + *obj=NULL; + + if(iid==IID_IUnknown){ + *obj=static_cast(static_cast(this)); + AddRef(); + }else if(iid==__uuidof(IMMNotificationClient)){ + *obj=static_cast(this); + AddRef(); + }else if(iid==__uuidof(IAudioSessionEvents)){ + *obj=static_cast(this); + AddRef(); + }else{ + return E_NOINTERFACE; + } + + return S_OK; +} +#endif \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/AudioOutputWASAPI.h b/TMessagesProj/jni/libtgvoip2/os/windows/AudioOutputWASAPI.h new file mode 100644 index 000000000..f3b9d559d --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/AudioOutputWASAPI.h @@ -0,0 +1,103 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_AUDIOOUTPUTWASAPI_H +#define LIBTGVOIP_AUDIOOUTPUTWASAPI_H + +#if WINAPI_FAMILY==WINAPI_FAMILY_PHONE_APP +#define TGVOIP_WINDOWS_PHONE +#endif +#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY==WINAPI_FAMILY_DESKTOP_APP +#define TGVOIP_WINDOWS_DESKTOP +#endif + +#include +#include +#include +#pragma warning(push) +#pragma warning(disable : 4201) +#ifndef TGVOIP_WP_SILVERLIGHT +#include +#endif +#ifdef TGVOIP_WINDOWS_DESKTOP +#include +#include +#else +#include +#include "WindowsSandboxUtils.h" +#endif +#pragma warning(pop) +#include "../../audio/AudioOutput.h" + +namespace tgvoip{ +namespace audio{ + +#ifdef TGVOIP_WINDOWS_DESKTOP +class AudioOutputWASAPI : public AudioOutput, IMMNotificationClient, IAudioSessionEvents{ +#else +class AudioOutputWASAPI : public AudioOutput{ +#endif +public: + AudioOutputWASAPI(std::string deviceID); + virtual ~AudioOutputWASAPI(); + virtual void Start(); + virtual void Stop(); + virtual bool IsPlaying(); + virtual void SetCurrentDevice(std::string deviceID); + static void EnumerateDevices(std::vector& devs); +#ifdef TGVOIP_WINDOWS_DESKTOP + STDMETHOD_(ULONG, AddRef)(); + STDMETHOD_(ULONG, Release)(); +#endif + +private: + void ActuallySetCurrentDevice(std::string deviceID); + static DWORD WINAPI StartThread(void* arg); + void RunThread(); + WAVEFORMATEX format; + bool isPlaying; + HANDLE shutdownEvent; + HANDLE audioSamplesReadyEvent; + HANDLE streamSwitchEvent; + HANDLE thread; + IAudioClient* audioClient=NULL; + IAudioRenderClient* renderClient=NULL; +#ifdef TGVOIP_WINDOWS_DESKTOP + IMMDeviceEnumerator* enumerator; + IAudioSessionControl* audioSessionControl; + IMMDevice* device; +#endif + unsigned char remainingData[10240]; + size_t remainingDataLen; + bool isDefaultDevice; + ULONG refCount; + std::string streamChangeToDevice; + +#ifdef TGVOIP_WINDOWS_DESKTOP + STDMETHOD(OnDisplayNameChanged) (LPCWSTR /*NewDisplayName*/, LPCGUID /*EventContext*/) { return S_OK; }; + STDMETHOD(OnIconPathChanged) (LPCWSTR /*NewIconPath*/, LPCGUID /*EventContext*/) { return S_OK; }; + STDMETHOD(OnSimpleVolumeChanged) (float /*NewSimpleVolume*/, BOOL /*NewMute*/, LPCGUID /*EventContext*/) { return S_OK; } + STDMETHOD(OnChannelVolumeChanged) (DWORD /*ChannelCount*/, float /*NewChannelVolumes*/[], DWORD /*ChangedChannel*/, LPCGUID /*EventContext*/) { return S_OK; }; + STDMETHOD(OnGroupingParamChanged) (LPCGUID /*NewGroupingParam*/, LPCGUID /*EventContext*/) { return S_OK; }; + STDMETHOD(OnStateChanged) (AudioSessionState /*NewState*/) { return S_OK; }; + STDMETHOD(OnSessionDisconnected) (AudioSessionDisconnectReason DisconnectReason); + STDMETHOD(OnDeviceStateChanged) (LPCWSTR /*DeviceId*/, DWORD /*NewState*/) { return S_OK; } + STDMETHOD(OnDeviceAdded) (LPCWSTR /*DeviceId*/) { return S_OK; }; + STDMETHOD(OnDeviceRemoved) (LPCWSTR /*DeviceId(*/) { return S_OK; }; + STDMETHOD(OnDefaultDeviceChanged) (EDataFlow Flow, ERole Role, LPCWSTR NewDefaultDeviceId); + STDMETHOD(OnPropertyValueChanged) (LPCWSTR /*DeviceId*/, const PROPERTYKEY /*Key*/) { return S_OK; }; + + // + // IUnknown + // + STDMETHOD(QueryInterface)(REFIID iid, void **pvObject); +#endif +}; + +} +} + +#endif //LIBTGVOIP_AUDIOOUTPUTWASAPI_H diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/AudioOutputWave.cpp b/TMessagesProj/jni/libtgvoip2/os/windows/AudioOutputWave.cpp new file mode 100644 index 000000000..9d0a631bd --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/AudioOutputWave.cpp @@ -0,0 +1,165 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + + +#include +#include "AudioOutputWave.h" +#include "../../logging.h" +#include "../../VoIPController.h" + +#define BUFFER_SIZE 960 +#define CHECK_ERROR(res, msg) if(res!=MMSYSERR_NOERROR){wchar_t _buf[1024]; waveOutGetErrorTextW(res, _buf, 1024); LOGE(msg ": %ws (MMRESULT=0x%08X)", _buf, res); failed=true;} + +using namespace tgvoip::audio; + +AudioOutputWave::AudioOutputWave(std::string deviceID){ + isPlaying=false; + hWaveOut=NULL; + + for(int i=0;i<4;i++){ + ZeroMemory(&buffers[i], sizeof(WAVEHDR)); + buffers[i].dwBufferLength=960*2; + buffers[i].lpData=(char*)malloc(960*2); + } + + SetCurrentDevice(deviceID); +} + +AudioOutputWave::~AudioOutputWave(){ + for(int i=0;i<4;i++){ + free(buffers[i].lpData); + } + waveOutClose(hWaveOut); +} + +void AudioOutputWave::Start(){ + if(!isPlaying){ + isPlaying=true; + + for(int i=0;i<4;i++){ + MMRESULT res=waveOutPrepareHeader(hWaveOut, &buffers[i], sizeof(WAVEHDR)); + CHECK_ERROR(res, "waveOutPrepareHeader failed"); + //InvokeCallback((unsigned char*)buffers[i].lpData, buffers[i].dwBufferLength); + ZeroMemory(buffers[i].lpData, buffers[i].dwBufferLength); + res=waveOutWrite(hWaveOut, &buffers[i], sizeof(WAVEHDR)); + CHECK_ERROR(res, "waveOutWrite failed"); + } + } +} + +void AudioOutputWave::Stop(){ + if(isPlaying){ + isPlaying=false; + + MMRESULT res=waveOutReset(hWaveOut); + CHECK_ERROR(res, "waveOutReset failed"); + for(int i=0;i<4;i++){ + res=waveOutUnprepareHeader(hWaveOut, &buffers[i], sizeof(WAVEHDR)); + CHECK_ERROR(res, "waveOutUnprepareHeader failed"); + } + } +} + +bool AudioOutputWave::IsPlaying(){ + return isPlaying; +} + +void AudioOutputWave::WaveOutProc(HWAVEOUT hwo, UINT uMsg, DWORD_PTR dwInstance, DWORD_PTR dwParam1, DWORD_PTR dwParam2) { + if(uMsg==WOM_DONE){ + ((AudioOutputWave*)dwInstance)->OnBufferDone((WAVEHDR*)dwParam1); + } +} + +void AudioOutputWave::OnBufferDone(WAVEHDR* hdr){ + if(!isPlaying) + return; + + InvokeCallback((unsigned char*)hdr->lpData, hdr->dwBufferLength); + hdr->dwFlags&= ~WHDR_DONE; + MMRESULT res=waveOutWrite(hWaveOut, hdr, sizeof(WAVEHDR)); +} + +void AudioOutputWave::EnumerateDevices(std::vector& devs){ + UINT num=waveOutGetNumDevs(); + WAVEOUTCAPSW caps; + char nameBuf[512]; + for(UINT i=0;i +#include +#include +#include "../../audio/AudioOutput.h" + +namespace tgvoip{ +namespace audio{ + +class AudioOutputWave : public AudioOutput{ +public: + AudioOutputWave(std::string deviceID); + virtual ~AudioOutputWave(); + virtual void Start(); + virtual void Stop(); + virtual bool IsPlaying(); + virtual void SetCurrentDevice(std::string deviceID); + static void EnumerateDevices(std::vector& devs); + +private: + HWAVEOUT hWaveOut; + WAVEFORMATEX format; + WAVEHDR buffers[4]; + static void CALLBACK WaveOutProc(HWAVEOUT hwo, UINT uMsg, DWORD_PTR dwInstance, DWORD_PTR dwParam1, DWORD_PTR dwParam2); + void OnBufferDone(WAVEHDR* hdr); + bool isPlaying; +}; + +} +} + +#endif //LIBTGVOIP_AUDIOOUTPUTWAVE_H diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/CXWrapper.cpp b/TMessagesProj/jni/libtgvoip2/os/windows/CXWrapper.cpp new file mode 100644 index 000000000..55c4b0f3f --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/CXWrapper.cpp @@ -0,0 +1,469 @@ +#include +#include +#include +#include +#include +#include +#include "CXWrapper.h" +#include +#include + +using namespace Windows::Storage::Streams; +using namespace Microsoft::WRL; +using namespace libtgvoip; +using namespace Platform; +using namespace tgvoip; +using namespace Windows::Security::Cryptography; +using namespace Windows::Security::Cryptography::Core; +using namespace Windows::Storage::Streams; +using namespace Windows::Data::Json; +using namespace Windows::Phone::Media::Devices; + +//CryptographicHash^ MicrosoftCryptoImpl::sha1Hash; +//CryptographicHash^ MicrosoftCryptoImpl::sha256Hash; +HashAlgorithmProvider^ MicrosoftCryptoImpl::sha1Provider; +HashAlgorithmProvider^ MicrosoftCryptoImpl::sha256Provider; +SymmetricKeyAlgorithmProvider^ MicrosoftCryptoImpl::aesKeyProvider; + +/*struct tgvoip_cx_data{ + VoIPControllerWrapper^ self; +};*/ + +VoIPControllerWrapper::VoIPControllerWrapper(){ + VoIPController::crypto.aes_ige_decrypt=MicrosoftCryptoImpl::AesIgeDecrypt; + VoIPController::crypto.aes_ige_encrypt=MicrosoftCryptoImpl::AesIgeEncrypt; + VoIPController::crypto.aes_ctr_encrypt = MicrosoftCryptoImpl::AesCtrEncrypt; + VoIPController::crypto.sha1=MicrosoftCryptoImpl::SHA1; + VoIPController::crypto.sha256=MicrosoftCryptoImpl::SHA256; + VoIPController::crypto.rand_bytes=MicrosoftCryptoImpl::RandBytes; + MicrosoftCryptoImpl::Init(); + controller=new VoIPController(); + controller->implData=(void*)this; + VoIPController::Callbacks callbacks={0}; + callbacks.connectionStateChanged=VoIPControllerWrapper::OnStateChanged; + callbacks.signalBarCountChanged=VoIPControllerWrapper::OnSignalBarsChanged; + controller->SetCallbacks(callbacks); +} + +VoIPControllerWrapper::~VoIPControllerWrapper(){ + controller->Stop(); + delete controller; +} + +void VoIPControllerWrapper::Start(){ + controller->Start(); +} + +void VoIPControllerWrapper::Connect(){ + controller->Connect(); +} + +void VoIPControllerWrapper::SetPublicEndpoints(const Platform::Array^ endpoints, bool allowP2P, int32_t connectionMaxLayer){ + std::vector eps; + for (unsigned int i = 0; i < endpoints->Length; i++) + { + libtgvoip::Endpoint^ _ep = endpoints[i]; + tgvoip::Endpoint ep; + ep.id = _ep->id; + ep.type = tgvoip::Endpoint::Type::UDP_RELAY; + char buf[128]; + if (_ep->ipv4){ + WideCharToMultiByte(CP_UTF8, 0, _ep->ipv4->Data(), -1, buf, sizeof(buf), NULL, NULL); + ep.address = NetworkAddress::IPv4(buf); + } + if (_ep->ipv6){ + WideCharToMultiByte(CP_UTF8, 0, _ep->ipv6->Data(), -1, buf, sizeof(buf), NULL, NULL); + ep.v6address = NetworkAddress::IPv6(buf); + } + ep.port = _ep->port; + if (_ep->peerTag->Length != 16) + throw ref new Platform::InvalidArgumentException("Peer tag must be exactly 16 bytes long"); + memcpy(ep.peerTag, _ep->peerTag->Data, 16); + eps.push_back(ep); + } + controller->SetRemoteEndpoints(eps, allowP2P, connectionMaxLayer); +} + +void VoIPControllerWrapper::SetNetworkType(NetworkType type){ + controller->SetNetworkType((int)type); +} + +void VoIPControllerWrapper::SetMicMute(bool mute){ + controller->SetMicMute(mute); +} + +int64 VoIPControllerWrapper::GetPreferredRelayID(){ + return controller->GetPreferredRelayID(); +} + +int32_t VoIPControllerWrapper::GetConnectionMaxLayer(){ + return tgvoip::VoIPController::GetConnectionMaxLayer(); +} + +void VoIPControllerWrapper::SetEncryptionKey(const Platform::Array^ key, bool isOutgoing){ + if(key->Length!=256) + throw ref new Platform::InvalidArgumentException("Encryption key must be exactly 256 bytes long"); + controller->SetEncryptionKey((char*)key->Data, isOutgoing); +} + +int VoIPControllerWrapper::GetSignalBarsCount(){ + return controller->GetSignalBarsCount(); +} + +CallState VoIPControllerWrapper::GetConnectionState(){ + return (CallState)controller->GetConnectionState(); +} + +TrafficStats^ VoIPControllerWrapper::GetStats(){ + tgvoip::VoIPController::TrafficStats _stats; + controller->GetStats(&_stats); + + TrafficStats^ stats = ref new TrafficStats(); + stats->bytesSentWifi = _stats.bytesSentWifi; + stats->bytesSentMobile = _stats.bytesSentMobile; + stats->bytesRecvdWifi = _stats.bytesRecvdWifi; + stats->bytesRecvdMobile = _stats.bytesRecvdMobile; + + return stats; +} + +Platform::String^ VoIPControllerWrapper::GetDebugString(){ + std::string log = controller->GetDebugString(); + size_t len = sizeof(wchar_t)*(log.length() + 1); + wchar_t* wlog = (wchar_t*)malloc(len); + MultiByteToWideChar(CP_UTF8, 0, log.c_str(), -1, wlog, len / sizeof(wchar_t)); + Platform::String^ res = ref new Platform::String(wlog); + free(wlog); + return res; +} + +Platform::String^ VoIPControllerWrapper::GetDebugLog(){ + std::string log=controller->GetDebugLog(); + size_t len=sizeof(wchar_t)*(log.length()+1); + wchar_t* wlog=(wchar_t*)malloc(len); + MultiByteToWideChar(CP_UTF8, 0, log.c_str(), -1, wlog, len/sizeof(wchar_t)); + Platform::String^ res=ref new Platform::String(wlog); + free(wlog); + return res; +} + +Error VoIPControllerWrapper::GetLastError(){ + return (Error)controller->GetLastError(); +} + +Platform::String^ VoIPControllerWrapper::GetVersion(){ + const char* v=VoIPController::GetVersion(); + wchar_t buf[32]; + MultiByteToWideChar(CP_UTF8, 0, v, -1, buf, sizeof(buf)); + return ref new Platform::String(buf); +} + +void VoIPControllerWrapper::OnStateChanged(VoIPController* c, int state){ + reinterpret_cast(c->implData)->OnStateChangedInternal(state); +} + +void VoIPControllerWrapper::OnSignalBarsChanged(VoIPController* c, int count){ + reinterpret_cast(c->implData)->OnSignalBarsChangedInternal(count); +} + +void VoIPControllerWrapper::OnStateChangedInternal(int state){ + CallStateChanged(this, (CallState)state); +} + +void VoIPControllerWrapper::OnSignalBarsChangedInternal(int count){ + SignalBarsChanged(this, count); +} + +void VoIPControllerWrapper::SetConfig(VoIPConfig^ wrapper){ + VoIPController::Config config{0}; + config.initTimeout=wrapper->initTimeout; + config.recvTimeout=wrapper->recvTimeout; + config.dataSaving=(int)wrapper->dataSaving; + config.logFilePath; + config.statsDumpFilePath; + + config.enableAEC=wrapper->enableAEC; + config.enableNS=wrapper->enableNS; + config.enableAGC=wrapper->enableAGC; + + config.enableCallUpgrade=wrapper->enableCallUpgrade; + + config.logPacketStats=wrapper->logPacketStats; + config.enableVolumeControl=wrapper->enableVolumeControl; + + config.enableVideoSend=wrapper->enableVideoSend; + config.enableVideoReceive=wrapper->enableVideoReceive; + + if(wrapper->logFilePath!=nullptr&&!wrapper->logFilePath->IsEmpty()){ + config.logFilePath = wstring(wrapper->logFilePath->Data()); + } + if (wrapper->statsDumpFilePath != nullptr&&!wrapper->statsDumpFilePath->IsEmpty()){ + config.statsDumpFilePath = wstring(wrapper->statsDumpFilePath->Data()); + } + + controller->SetConfig(config); +} + +void VoIPControllerWrapper::SetProxy(ProxyProtocol protocol, Platform::String^ address, uint16_t port, Platform::String^ username, Platform::String^ password){ + char _address[2000]; + char _username[256]; + char _password[256]; + + WideCharToMultiByte(CP_UTF8, 0, address->Data(), -1, _address, sizeof(_address), NULL, NULL); + WideCharToMultiByte(CP_UTF8, 0, username->Data(), -1, _username, sizeof(_username), NULL, NULL); + WideCharToMultiByte(CP_UTF8, 0, password->Data(), -1, _password, sizeof(_password), NULL, NULL); + + controller->SetProxy((int)protocol, _address, port, _username, _password); +} + +void VoIPControllerWrapper::SetAudioOutputGainControlEnabled(bool enabled){ + controller->SetAudioOutputGainControlEnabled(enabled); +} + +void VoIPControllerWrapper::SetInputVolume(float level){ + controller->SetInputVolume(level); +} + +void VoIPControllerWrapper::SetOutputVolume(float level){ + controller->SetOutputVolume(level); +} + +void VoIPControllerWrapper::UpdateServerConfig(Platform::String^ json){ + std::string config=ToUtf8(json->Data(), json->Length()); + ServerConfig::GetSharedInstance()->Update(config); +} + +void VoIPControllerWrapper::SwitchSpeaker(bool external){ + auto routingManager = AudioRoutingManager::GetDefault(); + if (external){ + routingManager->SetAudioEndpoint(AudioRoutingEndpoint::Speakerphone); + } + else{ + if ((routingManager->AvailableAudioEndpoints & AvailableAudioRoutingEndpoints::Bluetooth) == AvailableAudioRoutingEndpoints::Bluetooth){ + routingManager->SetAudioEndpoint(AudioRoutingEndpoint::Bluetooth); + } + else if ((routingManager->AvailableAudioEndpoints & AvailableAudioRoutingEndpoints::Earpiece) == AvailableAudioRoutingEndpoints::Earpiece){ + routingManager->SetAudioEndpoint(AudioRoutingEndpoint::Earpiece); + } + } +} + +void MicrosoftCryptoImpl::AesIgeEncrypt(uint8_t* in, uint8_t* out, size_t len, uint8_t* key, uint8_t* iv){ + IBuffer^ keybuf=IBufferFromPtr(key, 32); + CryptographicKey^ _key=aesKeyProvider->CreateSymmetricKey(keybuf); + uint8_t tmpOut[16]; + uint8_t* xPrev=iv+16; + uint8_t* yPrev=iv; + uint8_t x[16]; + uint8_t y[16]; + for(size_t offset=0;offsetCreateSymmetricKey(keybuf); + uint8_t tmpOut[16]; + uint8_t* xPrev=iv; + uint8_t* yPrev=iv+16; + uint8_t x[16]; + uint8_t y[16]; + for(size_t offset=0;offset> 24); (ct)[1] = (u8)((st) >> 16); (ct)[2] = (u8)((st) >> 8); (ct)[3] = (u8)(st); } + +typedef uint8_t u8; + +#define L_ENDIAN + +/* increment counter (128-bit int) by 2^64 */ +static void AES_ctr128_inc(unsigned char *counter) { + unsigned long c; + + /* Grab 3rd dword of counter and increment */ +#ifdef L_ENDIAN + c = GETU32(counter + 8); + c++; + PUTU32(counter + 8, c); +#else + c = GETU32(counter + 4); + c++; + PUTU32(counter + 4, c); +#endif + + /* if no overflow, we're done */ + if (c) + return; + + /* Grab top dword of counter and increment */ +#ifdef L_ENDIAN + c = GETU32(counter + 12); + c++; + PUTU32(counter + 12, c); +#else + c = GETU32(counter + 0); + c++; + PUTU32(counter + 0, c); +#endif + +} + +void MicrosoftCryptoImpl::AesCtrEncrypt(uint8_t* inout, size_t len, uint8_t* key, uint8_t* counter, uint8_t* ecount_buf, uint32_t* num){ + unsigned int n; + unsigned long l = len; + + //assert(in && out && key && counter && num); + //assert(*num < AES_BLOCK_SIZE); + + IBuffer^ keybuf = IBufferFromPtr(key, 32); + CryptographicKey^ _key = aesKeyProvider->CreateSymmetricKey(keybuf); + + n = *num; + + while (l--) { + if (n == 0) { + IBuffer^ inbuf = IBufferFromPtr(counter, 16); + IBuffer^ outbuf = CryptographicEngine::Encrypt(_key, inbuf, nullptr); + IBufferToPtr(outbuf, 16, ecount_buf); + //AES_encrypt(counter, ecount_buf, key); + AES_ctr128_inc(counter); + } + *inout = *(inout++) ^ ecount_buf[n]; + n = (n + 1) % 16; + } + + *num = n; +} + +void MicrosoftCryptoImpl::SHA1(uint8_t* msg, size_t len, uint8_t* out){ + //EnterCriticalSection(&hashMutex); + + IBuffer^ arr=IBufferFromPtr(msg, len); + CryptographicHash^ hash=sha1Provider->CreateHash(); + hash->Append(arr); + IBuffer^ res=hash->GetValueAndReset(); + IBufferToPtr(res, 20, out); + + //LeaveCriticalSection(&hashMutex); +} + +void MicrosoftCryptoImpl::SHA256(uint8_t* msg, size_t len, uint8_t* out){ + //EnterCriticalSection(&hashMutex); + + IBuffer^ arr=IBufferFromPtr(msg, len); + CryptographicHash^ hash=sha256Provider->CreateHash(); + hash->Append(arr); + IBuffer^ res=hash->GetValueAndReset(); + IBufferToPtr(res, 32, out); + //LeaveCriticalSection(&hashMutex); +} + +void MicrosoftCryptoImpl::RandBytes(uint8_t* buffer, size_t len){ + IBuffer^ res=CryptographicBuffer::GenerateRandom(len); + IBufferToPtr(res, len, buffer); +} + +void MicrosoftCryptoImpl::Init(){ + /*sha1Hash=HashAlgorithmProvider::OpenAlgorithm(HashAlgorithmNames::Sha1)->CreateHash(); + sha256Hash=HashAlgorithmProvider::OpenAlgorithm(HashAlgorithmNames::Sha256)->CreateHash();*/ + sha1Provider=HashAlgorithmProvider::OpenAlgorithm(HashAlgorithmNames::Sha1); + sha256Provider=HashAlgorithmProvider::OpenAlgorithm(HashAlgorithmNames::Sha256); + aesKeyProvider=SymmetricKeyAlgorithmProvider::OpenAlgorithm(SymmetricAlgorithmNames::AesEcb); +} + +void MicrosoftCryptoImpl::XorInt128(uint8_t* a, uint8_t* b, uint8_t* out){ + uint64_t* _a=reinterpret_cast(a); + uint64_t* _b=reinterpret_cast(b); + uint64_t* _out=reinterpret_cast(out); + _out[0]=_a[0]^_b[0]; + _out[1]=_a[1]^_b[1]; +} + +void MicrosoftCryptoImpl::IBufferToPtr(IBuffer^ buffer, size_t len, uint8_t* out) +{ + ComPtr bufferByteAccess; + reinterpret_cast(buffer)->QueryInterface(IID_PPV_ARGS(&bufferByteAccess)); + + byte* hashBuffer; + bufferByteAccess->Buffer(&hashBuffer); + CopyMemory(out, hashBuffer, len); +} + +IBuffer^ MicrosoftCryptoImpl::IBufferFromPtr(uint8_t* msg, size_t len) +{ + ComPtr nativeBuffer=Make((byte *)msg, len); + return reinterpret_cast(nativeBuffer.Get()); +} + +/*Platform::String^ VoIPControllerWrapper::TestAesIge(){ + MicrosoftCryptoImpl::Init(); + Platform::String^ res=""; + Platform::Array^ data=ref new Platform::Array(32); + Platform::Array^ out=ref new Platform::Array(32); + Platform::Array^ key=ref new Platform::Array(16); + Platform::Array^ iv=ref new Platform::Array(32); + + + CryptographicBuffer::CopyToByteArray(CryptographicBuffer::DecodeFromHexString("0000000000000000000000000000000000000000000000000000000000000000"), &data); + CryptographicBuffer::CopyToByteArray(CryptographicBuffer::DecodeFromHexString("000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f"), &iv); + CryptographicBuffer::CopyToByteArray(CryptographicBuffer::DecodeFromHexString("000102030405060708090a0b0c0d0e0f"), &key); + MicrosoftCryptoImpl::AesIgeEncrypt(data->Data, out->Data, 32, key->Data, iv->Data); + res+=CryptographicBuffer::EncodeToHexString(CryptographicBuffer::CreateFromByteArray(out)); + res+="\n"; + + CryptographicBuffer::CopyToByteArray(CryptographicBuffer::DecodeFromHexString("1A8519A6557BE652E9DA8E43DA4EF4453CF456B4CA488AA383C79C98B34797CB"), &data); + CryptographicBuffer::CopyToByteArray(CryptographicBuffer::DecodeFromHexString("000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f"), &iv); + CryptographicBuffer::CopyToByteArray(CryptographicBuffer::DecodeFromHexString("000102030405060708090a0b0c0d0e0f"), &key); + MicrosoftCryptoImpl::AesIgeDecrypt(data->Data, out->Data, 32, key->Data, iv->Data); + res+=CryptographicBuffer::EncodeToHexString(CryptographicBuffer::CreateFromByteArray(out)); + res+="\n"; + + CryptographicBuffer::CopyToByteArray(CryptographicBuffer::DecodeFromHexString("99706487A1CDE613BC6DE0B6F24B1C7AA448C8B9C3403E3467A8CAD89340F53B"), &data); + CryptographicBuffer::CopyToByteArray(CryptographicBuffer::DecodeFromHexString("6D656E746174696F6E206F6620494745206D6F646520666F72204F70656E5353"), &iv); + CryptographicBuffer::CopyToByteArray(CryptographicBuffer::DecodeFromHexString("5468697320697320616E20696D706C65"), &key); + MicrosoftCryptoImpl::AesIgeEncrypt(data->Data, out->Data, 32, key->Data, iv->Data); + res+=CryptographicBuffer::EncodeToHexString(CryptographicBuffer::CreateFromByteArray(out)); + res+="\n"; + + CryptographicBuffer::CopyToByteArray(CryptographicBuffer::DecodeFromHexString("4C2E204C6574277320686F70652042656E20676F74206974207269676874210A"), &data); + CryptographicBuffer::CopyToByteArray(CryptographicBuffer::DecodeFromHexString("6D656E746174696F6E206F6620494745206D6F646520666F72204F70656E5353"), &iv); + CryptographicBuffer::CopyToByteArray(CryptographicBuffer::DecodeFromHexString("5468697320697320616E20696D706C65"), &key); + MicrosoftCryptoImpl::AesIgeDecrypt(data->Data, out->Data, 32, key->Data, iv->Data); + res+=CryptographicBuffer::EncodeToHexString(CryptographicBuffer::CreateFromByteArray(out)); + return res; +}*/ \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/CXWrapper.h b/TMessagesProj/jni/libtgvoip2/os/windows/CXWrapper.h new file mode 100644 index 000000000..edcf7c0f2 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/CXWrapper.h @@ -0,0 +1,273 @@ +#pragma once + +#include +#include +#include +#include +#include +#include "../../VoIPController.h" +#include "../../VoIPServerConfig.h" + +using namespace Platform; + +#define STACK_ARRAY(TYPE, LEN) \ + static_cast(::alloca((LEN) * sizeof(TYPE))) + +inline std::wstring ToUtf16(const char* utf8, size_t len) { + int len16 = ::MultiByteToWideChar(CP_UTF8, 0, utf8, static_cast(len), + nullptr, 0); + wchar_t* ws = STACK_ARRAY(wchar_t, len16); + ::MultiByteToWideChar(CP_UTF8, 0, utf8, static_cast(len), ws, len16); + return std::wstring(ws, len16); +} + +inline std::wstring ToUtf16(const std::string& str) { + return ToUtf16(str.data(), str.length()); +} + +inline std::string ToUtf8(const wchar_t* wide, size_t len) { + int len8 = ::WideCharToMultiByte(CP_UTF8, 0, wide, static_cast(len), + nullptr, 0, nullptr, nullptr); + char* ns = STACK_ARRAY(char, len8); + ::WideCharToMultiByte(CP_UTF8, 0, wide, static_cast(len), ns, len8, + nullptr, nullptr); + return std::string(ns, len8); +} + +inline std::string ToUtf8(const wchar_t* wide) { + return ToUtf8(wide, wcslen(wide)); +} + +inline std::string ToUtf8(const std::wstring& wstr) { + return ToUtf8(wstr.data(), wstr.length()); +} + +namespace libtgvoip{ + public ref class Endpoint sealed{ + public: + property int64 id; + property uint16 port; + property Platform::String^ ipv4; + property Platform::String^ ipv6; + property Platform::Array^ peerTag; + }; + + public ref class TrafficStats sealed{ + public: + property uint64_t bytesSentWifi; + property uint64_t bytesRecvdWifi; + property uint64_t bytesSentMobile; + property uint64_t bytesRecvdMobile; + }; + + public enum class CallState : int{ + WaitInit=1, + WaitInitAck, + Established, + Failed + }; + + public enum class Error : int{ + Unknown=0, + Incompatible, + Timeout, + AudioIO + }; + + public enum class NetworkType : int{ + Unknown=0, + GPRS, + EDGE, + UMTS, + HSPA, + LTE, + WiFi, + Ethernet, + OtherHighSpeed, + OtherLowSpeed, + Dialup, + OtherMobile + }; + + public enum class DataSavingMode{ + Never=0, + MobileOnly, + Always + }; + + public enum class ProxyProtocol{ + None=0, + SOCKS5 + }; + + public ref class VoIPConfig sealed { + public: + VoIPConfig() { + logPacketStats = false; + enableVolumeControl = false; + enableVideoSend = false; + enableVideoReceive = false; + } + + property double initTimeout; + property double recvTimeout; + property DataSavingMode dataSaving; + property String^ logFilePath; + property String^ statsDumpFilePath; + + property bool enableAEC; + property bool enableNS; + property bool enableAGC; + + property bool enableCallUpgrade; + + property bool logPacketStats; + property bool enableVolumeControl; + + property bool enableVideoSend; + property bool enableVideoReceive; + }; + + ref class VoIPControllerWrapper; + public delegate void CallStateChangedEventHandler(VoIPControllerWrapper^ sender, CallState newState); + + ref class VoIPControllerWrapper; + public delegate void SignalBarsChangedEventHandler(VoIPControllerWrapper^ sender, int newCount); + + public ref class VoIPControllerWrapper sealed{ + public: + VoIPControllerWrapper(); + virtual ~VoIPControllerWrapper(); + void Start(); + void Connect(); + void SetPublicEndpoints(const Platform::Array^ endpoints, bool allowP2P, int32_t connectionMaxLayer); + void SetNetworkType(NetworkType type); + void SetMicMute(bool mute); + void SetEncryptionKey(const Platform::Array^ key, bool isOutgoing); + void SetConfig(VoIPConfig^ config); + void SetProxy(ProxyProtocol protocol, Platform::String^ address, uint16_t port, Platform::String^ username, Platform::String^ password); + int GetSignalBarsCount(); + CallState GetConnectionState(); + TrafficStats^ GetStats(); + Platform::String^ GetDebugString(); + Platform::String^ GetDebugLog(); + Error GetLastError(); + static Platform::String^ GetVersion(); + int64 GetPreferredRelayID(); + void SetAudioOutputGainControlEnabled(bool enabled); + + void SetInputVolume(float level); + void SetOutputVolume(float level); + + property String^ CurrentAudioInput + { + String^ get() + { + return ref new String(ToUtf16(controller->GetCurrentAudioInputID()).data()); + } + void set(String^ value) + { + controller->SetCurrentAudioInput(ToUtf8(value->Data())); + } + } + + property String^ CurrentAudioOutput + { + String^ get() + { + return ref new String(ToUtf16(controller->GetCurrentAudioOutputID()).data()); + } + void set(String^ value) + { + controller->SetCurrentAudioOutput(ToUtf8(value->Data())); + } + } + + static int32_t GetConnectionMaxLayer(); + static void UpdateServerConfig(Platform::String^ json); + static void SwitchSpeaker(bool external); + //static Platform::String^ TestAesIge(); + + event CallStateChangedEventHandler^ CallStateChanged; + event SignalBarsChangedEventHandler^ SignalBarsChanged; + + private: + static void OnStateChanged(tgvoip::VoIPController* c, int state); + static void OnSignalBarsChanged(tgvoip::VoIPController* c, int count); + void OnStateChangedInternal(int state); + void OnSignalBarsChangedInternal(int count); + tgvoip::VoIPController* controller; + }; + + ref class MicrosoftCryptoImpl{ + public: + static void AesIgeEncrypt(uint8_t* in, uint8_t* out, size_t len, uint8_t* key, uint8_t* iv); + static void AesIgeDecrypt(uint8_t* in, uint8_t* out, size_t len, uint8_t* key, uint8_t* iv); + static void AesCtrEncrypt(uint8_t* inout, size_t len, uint8_t* key, uint8_t* iv, uint8_t* ecount, uint32_t* num); + static void SHA1(uint8_t* msg, size_t len, uint8_t* out); + static void SHA256(uint8_t* msg, size_t len, uint8_t* out); + static void RandBytes(uint8_t* buffer, size_t len); + static void Init(); + private: + static inline void XorInt128(uint8_t* a, uint8_t* b, uint8_t* out); + static void IBufferToPtr(Windows::Storage::Streams::IBuffer^ buffer, size_t len, uint8_t* out); + static Windows::Storage::Streams::IBuffer^ IBufferFromPtr(uint8_t* msg, size_t len); + /*static Windows::Security::Cryptography::Core::CryptographicHash^ sha1Hash; + static Windows::Security::Cryptography::Core::CryptographicHash^ sha256Hash;*/ + static Windows::Security::Cryptography::Core::HashAlgorithmProvider^ sha1Provider; + static Windows::Security::Cryptography::Core::HashAlgorithmProvider^ sha256Provider; + static Windows::Security::Cryptography::Core::SymmetricKeyAlgorithmProvider^ aesKeyProvider; + }; + + class NativeBuffer : + public Microsoft::WRL::RuntimeClass, + ABI::Windows::Storage::Streams::IBuffer, + Windows::Storage::Streams::IBufferByteAccess> + { + public: + NativeBuffer(byte *buffer, UINT totalSize) + { + m_length=totalSize; + m_buffer=buffer; + } + + virtual ~NativeBuffer() + { + } + + STDMETHODIMP RuntimeClassInitialize(byte *buffer, UINT totalSize) + { + m_length=totalSize; + m_buffer=buffer; + return S_OK; + } + + STDMETHODIMP Buffer(byte **value) + { + *value=m_buffer; + return S_OK; + } + + STDMETHODIMP get_Capacity(UINT32 *value) + { + *value=m_length; + return S_OK; + } + + STDMETHODIMP get_Length(UINT32 *value) + { + *value=m_length; + return S_OK; + } + + STDMETHODIMP put_Length(UINT32 value) + { + m_length=value; + return S_OK; + } + + private: + UINT32 m_length; + byte *m_buffer; + }; +} \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/NetworkSocketWinsock.cpp b/TMessagesProj/jni/libtgvoip2/os/windows/NetworkSocketWinsock.cpp new file mode 100644 index 000000000..745cdc9c6 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/NetworkSocketWinsock.cpp @@ -0,0 +1,706 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include +#include +#include "NetworkSocketWinsock.h" +#if WINAPI_FAMILY==WINAPI_FAMILY_PHONE_APP + +#else +#include +#endif +#include +#include "../../logging.h" +#include "../../VoIPController.h" +#include "WindowsSpecific.h" +#include "../../Buffers.h" + +using namespace tgvoip; + +NetworkSocketWinsock::NetworkSocketWinsock(NetworkProtocol protocol) : NetworkSocket(protocol){ + needUpdateNat64Prefix=true; + nat64Present=false; + switchToV6at=0; + isV4Available=false; + closing=false; + fd=INVALID_SOCKET; + +#ifdef TGVOIP_WINXP_COMPAT + DWORD version=GetVersion(); + isAtLeastVista=LOBYTE(LOWORD(version))>=6; // Vista is 6.0, XP is 5.1 and 5.2 +#else + isAtLeastVista=true; +#endif + + WSADATA wsaData; + WSAStartup(MAKEWORD(2, 2), &wsaData); + LOGD("Initialized winsock, version %d.%d", wsaData.wHighVersion, wsaData.wVersion); + + if(protocol==NetworkProtocol::TCP) + timeout=10.0; + lastSuccessfulOperationTime=VoIPController::GetCurrentTime(); +} + +NetworkSocketWinsock::~NetworkSocketWinsock(){ +} + +void NetworkSocketWinsock::SetMaxPriority(){ + +} + +void NetworkSocketWinsock::Send(NetworkPacket packet){ + if(packet.IsEmpty() || (protocol==NetworkProtocol::UDP && packet.address.IsEmpty())){ + LOGW("tried to send null packet"); + return; + } + int res; + if(protocol==NetworkProtocol::UDP){ + if(isAtLeastVista){ + sockaddr_in6 addr; + if(!packet.address.isIPv6){ + if(needUpdateNat64Prefix && !isV4Available && VoIPController::GetCurrentTime()>switchToV6at && switchToV6at!=0){ + LOGV("Updating NAT64 prefix"); + nat64Present=false; + addrinfo *addr0; + int res=getaddrinfo("ipv4only.arpa", NULL, NULL, &addr0); + if(res!=0){ + LOGW("Error updating NAT64 prefix: %d / %s", res, gai_strerrorA(res)); + }else{ + addrinfo *addrPtr; + unsigned char *addr170=NULL; + unsigned char *addr171=NULL; + for(addrPtr=addr0; addrPtr; addrPtr=addrPtr->ai_next){ + if(addrPtr->ai_family==AF_INET6){ + sockaddr_in6 *translatedAddr=(sockaddr_in6 *) addrPtr->ai_addr; + uint32_t v4part=*((uint32_t *) &translatedAddr->sin6_addr.s6_addr[12]); + if(v4part==0xAA0000C0 && !addr170){ + addr170=translatedAddr->sin6_addr.s6_addr; + } + if(v4part==0xAB0000C0 && !addr171){ + addr171=translatedAddr->sin6_addr.s6_addr; + } + char buf[INET6_ADDRSTRLEN]; + //LOGV("Got translated address: %s", inet_ntop(AF_INET6, &translatedAddr->sin6_addr, buf, sizeof(buf))); + } + } + if(addr170 && addr171 && memcmp(addr170, addr171, 12)==0){ + nat64Present=true; + memcpy(nat64Prefix, addr170, 12); + char buf[INET6_ADDRSTRLEN]; + //LOGV("Found nat64 prefix from %s", inet_ntop(AF_INET6, addr170, buf, sizeof(buf))); + }else{ + LOGV("Didn't find nat64"); + } + freeaddrinfo(addr0); + } + needUpdateNat64Prefix=false; + } + memset(&addr, 0, sizeof(sockaddr_in6)); + addr.sin6_family=AF_INET6; + *((uint32_t *) &addr.sin6_addr.s6_addr[12])=packet.address.addr.ipv4; + if(nat64Present) + memcpy(addr.sin6_addr.s6_addr, nat64Prefix, 12); + else + addr.sin6_addr.s6_addr[11]=addr.sin6_addr.s6_addr[10]=0xFF; + + }else{ + memcpy(addr.sin6_addr.s6_addr, packet.address.addr.ipv6, 16); + } + addr.sin6_port=htons(packet.port); + res=sendto(fd, (const char*)*packet.data, packet.data.Length(), 0, (const sockaddr *) &addr, sizeof(addr)); + }else{ + sockaddr_in addr; + addr.sin_addr.s_addr=packet.address.addr.ipv4; + addr.sin_port=htons(packet.port); + addr.sin_family=AF_INET; + res=sendto(fd, (const char*)*packet.data, packet.data.Length(), 0, (const sockaddr*)&addr, sizeof(addr)); + } + }else{ + res=send(fd, (const char*)*packet.data, packet.data.Length(), 0); + } + if(res==SOCKET_ERROR){ + int error=WSAGetLastError(); + if(error==WSAEWOULDBLOCK){ + if(!pendingOutgoingPacket.IsEmpty()){ + LOGE("Got EAGAIN but there's already a pending packet"); + failed=true; + }else{ + LOGV("Socket %d not ready to send", fd); + pendingOutgoingPacket=std::move(packet); + readyToSend=false; + } + }else{ + LOGE("error sending: %d / %s", error, WindowsSpecific::GetErrorMessage(error).c_str()); + if(error==WSAENETUNREACH && !isV4Available && VoIPController::GetCurrentTime()sin6_port=port; + else + ((sockaddr_in*)addr)->sin_port=port; + res=::bind(fd, addr, addrLen); + LOGV("trying bind to port %u", ntohs(port)); + if(res<0){ + LOGE("error binding to port %u: %d / %s", ntohs(port), errno, strerror(errno)); + }else{ + break; + } + } + if(tries==10){ + if(isAtLeastVista) + ((sockaddr_in6*)addr)->sin6_port=0; + else + ((sockaddr_in*)addr)->sin_port=0; + res=::bind(fd, addr, addrLen); + if(res<0){ + LOGE("error binding to port %u: %d / %s", 0, errno, strerror(errno)); + //SetState(STATE_FAILED); + return; + } + } + getsockname(fd, addr, (socklen_t*) &addrLen); + uint16_t localUdpPort; + if(isAtLeastVista) + localUdpPort=ntohs(((sockaddr_in6*)addr)->sin6_port); + else + localUdpPort=ntohs(((sockaddr_in*)addr)->sin_port); + LOGD("Bound to local UDP port %u", localUdpPort); + + needUpdateNat64Prefix=true; + isV4Available=false; + switchToV6at=VoIPController::GetCurrentTime()+ipv6Timeout; + } +} + +void NetworkSocketWinsock::Close(){ + closing=true; + failed=true; + if(fd!=INVALID_SOCKET) + closesocket(fd); +} + +void NetworkSocketWinsock::OnActiveInterfaceChanged(){ + needUpdateNat64Prefix=true; + isV4Available=false; + switchToV6at=VoIPController::GetCurrentTime()+ipv6Timeout; +} + +std::string NetworkSocketWinsock::GetLocalInterfaceInfo(NetworkAddress *v4addr, NetworkAddress *v6addr){ +#if WINAPI_FAMILY==WINAPI_FAMILY_PHONE_APP + Windows::Networking::Connectivity::ConnectionProfile^ profile=Windows::Networking::Connectivity::NetworkInformation::GetInternetConnectionProfile(); + if(profile){ + Windows::Foundation::Collections::IVectorView^ hostnames=Windows::Networking::Connectivity::NetworkInformation::GetHostNames(); + for(unsigned int i=0;iSize;i++){ + Windows::Networking::HostName^ n = hostnames->GetAt(i); + if(n->Type!=Windows::Networking::HostNameType::Ipv4 && n->Type!=Windows::Networking::HostNameType::Ipv6) + continue; + if(n->IPInformation->NetworkAdapter->Equals(profile->NetworkAdapter)){ + if(v4addr && n->Type==Windows::Networking::HostNameType::Ipv4){ + char buf[INET_ADDRSTRLEN]; + WideCharToMultiByte(CP_UTF8, 0, n->RawName->Data(), -1, buf, sizeof(buf), NULL, NULL); + *v4addr=NetworkAddress::IPv4(buf); + }else if(v6addr && n->Type==Windows::Networking::HostNameType::Ipv6){ + char buf[INET6_ADDRSTRLEN]; + WideCharToMultiByte(CP_UTF8, 0, n->RawName->Data(), -1, buf, sizeof(buf), NULL, NULL); + *v6addr=NetworkAddress::IPv6(buf); + } + } + } + char buf[128]; + WideCharToMultiByte(CP_UTF8, 0, profile->NetworkAdapter->NetworkAdapterId.ToString()->Data(), -1, buf, sizeof(buf), NULL, NULL); + return std::string(buf); + } + return ""; +#else + IP_ADAPTER_ADDRESSES* addrs=(IP_ADAPTER_ADDRESSES*)malloc(15*1024); + ULONG size=15*1024; + ULONG flags=GAA_FLAG_SKIP_ANYCAST | GAA_FLAG_SKIP_MULTICAST | GAA_FLAG_SKIP_DNS_SERVER | GAA_FLAG_SKIP_FRIENDLY_NAME; + + ULONG res=GetAdaptersAddresses(AF_UNSPEC, flags, NULL, addrs, &size); + if(res==ERROR_BUFFER_OVERFLOW){ + addrs=(IP_ADAPTER_ADDRESSES*)realloc(addrs, size); + res=GetAdaptersAddresses(AF_UNSPEC, flags, NULL, addrs, &size); + } + + ULONG bestMetric=0; + std::string bestName(""); + + if(res==ERROR_SUCCESS){ + IP_ADAPTER_ADDRESSES* current=addrs; + while(current){ + char* name=current->AdapterName; + LOGV("Adapter '%s':", name); + IP_ADAPTER_UNICAST_ADDRESS* curAddr=current->FirstUnicastAddress; + if(current->OperStatus!=IfOperStatusUp){ + LOGV("-> (down)"); + current=current->Next; + continue; + } + if(current->IfType==IF_TYPE_SOFTWARE_LOOPBACK){ + LOGV("-> (loopback)"); + current=current->Next; + continue; + } + if(isAtLeastVista) + LOGV("v4 metric: %u, v6 metric: %u", current->Ipv4Metric, current->Ipv6Metric); + while(curAddr){ + sockaddr* addr=curAddr->Address.lpSockaddr; + if(addr->sa_family==AF_INET && v4addr){ + sockaddr_in* ipv4=(sockaddr_in*)addr; + LOGV("-> V4: %s", V4AddressToString(ipv4->sin_addr.s_addr).c_str()); + uint32_t ip=ntohl(ipv4->sin_addr.s_addr); + if((ip & 0xFFFF0000)!=0xA9FE0000){ + if(isAtLeastVista){ + if(current->Ipv4Metric>bestMetric){ + bestMetric=current->Ipv4Metric; + bestName=std::string(current->AdapterName); + *v4addr=NetworkAddress::IPv4(ipv4->sin_addr.s_addr); + } + }else{ + bestName=std::string(current->AdapterName); + *v4addr=NetworkAddress::IPv4(ipv4->sin_addr.s_addr); + } + } + }else if(addr->sa_family==AF_INET6 && v6addr){ + sockaddr_in6* ipv6=(sockaddr_in6*)addr; + LOGV("-> V6: %s", V6AddressToString(ipv6->sin6_addr.s6_addr).c_str()); + if(!IN6_IS_ADDR_LINKLOCAL(&ipv6->sin6_addr)){ + *v6addr=NetworkAddress::IPv6(ipv6->sin6_addr.s6_addr); + } + } + curAddr=curAddr->Next; + } + current=current->Next; + } + } + + free(addrs); + return bestName; +#endif +} + +uint16_t NetworkSocketWinsock::GetLocalPort(){ + if(!isAtLeastVista){ + sockaddr_in addr; + size_t addrLen=sizeof(sockaddr_in); + getsockname(fd, (sockaddr*)&addr, (socklen_t*)&addrLen); + return ntohs(addr.sin_port); + } + sockaddr_in6 addr; + size_t addrLen=sizeof(sockaddr_in6); + getsockname(fd, (sockaddr*)&addr, (socklen_t*) &addrLen); + return ntohs(addr.sin6_port); +} + +std::string NetworkSocketWinsock::V4AddressToString(uint32_t address){ + char buf[INET_ADDRSTRLEN]; + sockaddr_in addr; + ZeroMemory(&addr, sizeof(addr)); + addr.sin_family=AF_INET; + addr.sin_addr.s_addr=address; + DWORD len=sizeof(buf); +#if WINAPI_FAMILY==WINAPI_FAMILY_PHONE_APP + wchar_t wbuf[INET_ADDRSTRLEN]; + ZeroMemory(wbuf, sizeof(wbuf)); + WSAAddressToStringW((sockaddr*)&addr, sizeof(addr), NULL, wbuf, &len); + WideCharToMultiByte(CP_UTF8, 0, wbuf, -1, buf, sizeof(buf), NULL, NULL); +#else + WSAAddressToStringA((sockaddr*)&addr, sizeof(addr), NULL, buf, &len); +#endif + return std::string(buf); +} + +std::string NetworkSocketWinsock::V6AddressToString(const unsigned char *address){ + char buf[INET6_ADDRSTRLEN]; + sockaddr_in6 addr; + ZeroMemory(&addr, sizeof(addr)); + addr.sin6_family=AF_INET6; + memcpy(addr.sin6_addr.s6_addr, address, 16); + DWORD len=sizeof(buf); +#if WINAPI_FAMILY==WINAPI_FAMILY_PHONE_APP + wchar_t wbuf[INET6_ADDRSTRLEN]; + ZeroMemory(wbuf, sizeof(wbuf)); + WSAAddressToStringW((sockaddr*)&addr, sizeof(addr), NULL, wbuf, &len); + WideCharToMultiByte(CP_UTF8, 0, wbuf, -1, buf, sizeof(buf), NULL, NULL); +#else + WSAAddressToStringA((sockaddr*)&addr, sizeof(addr), NULL, buf, &len); +#endif + return std::string(buf); +} + +uint32_t NetworkSocketWinsock::StringToV4Address(std::string address){ + sockaddr_in addr; + ZeroMemory(&addr, sizeof(addr)); + addr.sin_family=AF_INET; + int size=sizeof(addr); +#if WINAPI_FAMILY==WINAPI_FAMILY_PHONE_APP + wchar_t buf[INET_ADDRSTRLEN]; + MultiByteToWideChar(CP_UTF8, 0, address.c_str(), -1, buf, INET_ADDRSTRLEN); + WSAStringToAddressW(buf, AF_INET, NULL, (sockaddr*)&addr, &size); +#else + WSAStringToAddressA((char*)address.c_str(), AF_INET, NULL, (sockaddr*)&addr, &size); +#endif + return addr.sin_addr.s_addr; +} + +void NetworkSocketWinsock::StringToV6Address(std::string address, unsigned char *out){ + sockaddr_in6 addr; + ZeroMemory(&addr, sizeof(addr)); + addr.sin6_family=AF_INET6; + int size=sizeof(addr); +#if WINAPI_FAMILY==WINAPI_FAMILY_PHONE_APP + wchar_t buf[INET6_ADDRSTRLEN]; + MultiByteToWideChar(CP_UTF8, 0, address.c_str(), -1, buf, INET6_ADDRSTRLEN); + WSAStringToAddressW(buf, AF_INET, NULL, (sockaddr*)&addr, &size); +#else + WSAStringToAddressA((char*)address.c_str(), AF_INET, NULL, (sockaddr*)&addr, &size); +#endif + memcpy(out, addr.sin6_addr.s6_addr, 16); +} + +void NetworkSocketWinsock::Connect(const NetworkAddress address, uint16_t port){ + sockaddr_in v4; + sockaddr_in6 v6; + sockaddr* addr=NULL; + size_t addrLen=0; + if(!address.isIPv6){ + v4.sin_family=AF_INET; + v4.sin_addr.s_addr=address.addr.ipv4; + v4.sin_port=htons(port); + addr=reinterpret_cast(&v4); + addrLen=sizeof(v4); + }else{ + v6.sin6_family=AF_INET6; + memcpy(v6.sin6_addr.s6_addr, address.addr.ipv6, 16); + v6.sin6_flowinfo=0; + v6.sin6_scope_id=0; + v6.sin6_port=htons(port); + addr=reinterpret_cast(&v6); + addrLen=sizeof(v6); + } + fd=socket(addr->sa_family, SOCK_STREAM, IPPROTO_TCP); + if(fd==INVALID_SOCKET){ + LOGE("Error creating TCP socket: %d", WSAGetLastError()); + failed=true; + return; + } + u_long one=1; + ioctlsocket(fd, FIONBIO, &one); + int opt=1; + setsockopt(fd, IPPROTO_TCP, TCP_NODELAY, (const char*)&opt, sizeof(opt)); + DWORD timeout=5000; + setsockopt(fd, SOL_SOCKET, SO_SNDTIMEO, (const char*)&timeout, sizeof(timeout)); + timeout=60000; + setsockopt(fd, SOL_SOCKET, SO_RCVTIMEO, (const char*)&timeout, sizeof(timeout)); + int res=connect(fd, (const sockaddr*) addr, addrLen); + if(res!=0){ + int error=WSAGetLastError(); + if(error!=WSAEINPROGRESS && error!=WSAEWOULDBLOCK){ + LOGW("error connecting TCP socket to %s:%u: %d / %s", address.ToString().c_str(), port, error, WindowsSpecific::GetErrorMessage(error).c_str()); + closesocket(fd); + failed=true; + return; + } + } + tcpConnectedAddress=address; + tcpConnectedPort=port; + LOGI("successfully connected to %s:%d", tcpConnectedAddress.ToString().c_str(), tcpConnectedPort); +} + +NetworkAddress NetworkSocketWinsock::ResolveDomainName(std::string name){ + addrinfo* addr0; + NetworkAddress ret=NetworkAddress::Empty(); + int res=getaddrinfo(name.c_str(), NULL, NULL, &addr0); + if(res!=0){ + LOGW("Error updating NAT64 prefix: %d / %s", res, gai_strerrorA(res)); + }else{ + addrinfo* addrPtr; + for(addrPtr=addr0;addrPtr;addrPtr=addrPtr->ai_next){ + if(addrPtr->ai_family==AF_INET){ + sockaddr_in* addr=(sockaddr_in*)addrPtr->ai_addr; + ret=NetworkAddress::IPv4(addr->sin_addr.s_addr); + break; + } + } + freeaddrinfo(addr0); + } + return ret; +} + +NetworkAddress NetworkSocketWinsock::GetConnectedAddress(){ + return tcpConnectedAddress; +} + +uint16_t NetworkSocketWinsock::GetConnectedPort(){ + return tcpConnectedPort; +} + +void NetworkSocketWinsock::SetTimeouts(int sendTimeout, int recvTimeout){ + DWORD timeout=sendTimeout*1000; + setsockopt(fd, SOL_SOCKET, SO_SNDTIMEO, (const char*)&timeout, sizeof(timeout)); + timeout=recvTimeout*1000; + setsockopt(fd, SOL_SOCKET, SO_RCVTIMEO, (const char*)&timeout, sizeof(timeout)); +} + +bool NetworkSocketWinsock::Select(std::vector &readFds, std::vector& writeFds, std::vector &errorFds, SocketSelectCanceller* _canceller){ + fd_set readSet; + fd_set errorSet; + fd_set writeSet; + SocketSelectCancellerWin32* canceller=dynamic_cast(_canceller); + timeval timeout={0, 10000}; + bool anyFailed=false; + int res=0; + + do{ + FD_ZERO(&readSet); + FD_ZERO(&writeSet); + FD_ZERO(&errorSet); + + for(std::vector::iterator itr=readFds.begin();itr!=readFds.end();++itr){ + int sfd=GetDescriptorFromSocket(*itr); + if(sfd==0){ + LOGW("can't select on one of sockets because it's not a NetworkSocketWinsock instance"); + continue; + } + FD_SET(sfd, &readSet); + } + + for(NetworkSocket*& s:writeFds){ + int sfd=GetDescriptorFromSocket(s); + if(sfd==0){ + LOGW("can't select on one of sockets because it's not a NetworkSocketWinsock instance"); + continue; + } + FD_SET(sfd, &writeSet); + } + + for(std::vector::iterator itr=errorFds.begin();itr!=errorFds.end();++itr){ + int sfd=GetDescriptorFromSocket(*itr); + if(sfd==0){ + LOGW("can't select on one of sockets because it's not a NetworkSocketWinsock instance"); + continue; + } + if((*itr)->timeout>0 && VoIPController::GetCurrentTime()-(*itr)->lastSuccessfulOperationTime>(*itr)->timeout){ + LOGW("Socket %d timed out", sfd); + (*itr)->failed=true; + } + anyFailed |= (*itr)->IsFailed(); + FD_SET(sfd, &errorSet); + } + if(canceller && canceller->canceled) + break; + res=select(0, &readSet, &writeSet, &errorSet, &timeout); + //LOGV("select result %d", res); + if(res==SOCKET_ERROR) + LOGE("SELECT ERROR %d", WSAGetLastError()); + }while(res==0); + + + if(canceller && canceller->canceled && !anyFailed){ + canceller->canceled=false; + return false; + }else if(anyFailed){ + FD_ZERO(&readSet); + FD_ZERO(&errorSet); + } + + std::vector::iterator itr=readFds.begin(); + while(itr!=readFds.end()){ + int sfd=GetDescriptorFromSocket(*itr); + if(FD_ISSET(sfd, &readSet)) + (*itr)->lastSuccessfulOperationTime=VoIPController::GetCurrentTime(); + if(sfd==0 || !FD_ISSET(sfd, &readSet) || !(*itr)->OnReadyToReceive()){ + itr=readFds.erase(itr); + }else{ + ++itr; + } + } + + itr=writeFds.begin(); + while(itr!=writeFds.end()){ + int sfd=GetDescriptorFromSocket(*itr); + if(FD_ISSET(sfd, &writeSet)){ + (*itr)->lastSuccessfulOperationTime=VoIPController::GetCurrentTime(); + LOGI("Socket %d is ready to send", sfd); + } + if(sfd==0 || !FD_ISSET(sfd, &writeSet) || !(*itr)->OnReadyToSend()){ + itr=writeFds.erase(itr); + }else{ + ++itr; + } + } + + itr=errorFds.begin(); + while(itr!=errorFds.end()){ + int sfd=GetDescriptorFromSocket(*itr); + if((sfd==0 || !FD_ISSET(sfd, &errorSet)) && !(*itr)->IsFailed()){ + itr=errorFds.erase(itr); + }else{ + ++itr; + } + } + //LOGV("select fds left: read=%d, error=%d", readFds.size(), errorFds.size()); + + return readFds.size()>0 || errorFds.size()>0; +} + +SocketSelectCancellerWin32::SocketSelectCancellerWin32(){ + canceled=false; +} + +SocketSelectCancellerWin32::~SocketSelectCancellerWin32(){ +} + +void SocketSelectCancellerWin32::CancelSelect(){ + canceled=true; +} + +int NetworkSocketWinsock::GetDescriptorFromSocket(NetworkSocket *socket){ + NetworkSocketWinsock* sp=dynamic_cast(socket); + if(sp) + return sp->fd; + NetworkSocketWrapper* sw=dynamic_cast(socket); + if(sw) + return GetDescriptorFromSocket(sw->GetWrapped()); + return 0; +} diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/NetworkSocketWinsock.h b/TMessagesProj/jni/libtgvoip2/os/windows/NetworkSocketWinsock.h new file mode 100644 index 000000000..7e79b1134 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/NetworkSocketWinsock.h @@ -0,0 +1,71 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_NETWORKSOCKETWINSOCK_H +#define LIBTGVOIP_NETWORKSOCKETWINSOCK_H + +#include "../../NetworkSocket.h" +#include +#include + +namespace tgvoip { +class Buffer; + +class SocketSelectCancellerWin32 : public SocketSelectCanceller{ +friend class NetworkSocketWinsock; +public: + SocketSelectCancellerWin32(); + virtual ~SocketSelectCancellerWin32(); + virtual void CancelSelect(); +private: + bool canceled; +}; + +class NetworkSocketWinsock : public NetworkSocket{ +public: + NetworkSocketWinsock(NetworkProtocol protocol); + virtual ~NetworkSocketWinsock(); + virtual void Send(NetworkPacket packet) override; + virtual NetworkPacket Receive(size_t maxLen) override; + virtual void Open() override; + virtual void Close() override; + virtual std::string GetLocalInterfaceInfo(NetworkAddress* v4addr, NetworkAddress* v6addr) override; + virtual void OnActiveInterfaceChanged() override; + virtual uint16_t GetLocalPort() override; + virtual void Connect(const NetworkAddress address, uint16_t port) override; + + static std::string V4AddressToString(uint32_t address); + static std::string V6AddressToString(const unsigned char address[16]); + static uint32_t StringToV4Address(std::string address); + static void StringToV6Address(std::string address, unsigned char* out); + static NetworkAddress ResolveDomainName(std::string name); + static bool Select(std::vector& readFds, std::vector& writeFds, std::vector& errorFds, SocketSelectCanceller* canceller); + virtual NetworkAddress GetConnectedAddress() override; + virtual uint16_t GetConnectedPort() override; + virtual void SetTimeouts(int sendTimeout, int recvTimeout) override; + virtual bool OnReadyToSend() override; + +protected: + virtual void SetMaxPriority(); + +private: + static int GetDescriptorFromSocket(NetworkSocket* socket); + uintptr_t fd; + bool needUpdateNat64Prefix; + bool nat64Present; + double switchToV6at; + bool isV4Available; + bool isAtLeastVista; + bool closing; + NetworkAddress tcpConnectedAddress=NetworkAddress::Empty(); + uint16_t tcpConnectedPort; + NetworkPacket pendingOutgoingPacket=NetworkPacket::Empty(); + Buffer recvBuf=Buffer(2048); +}; + +} + +#endif //LIBTGVOIP_NETWORKSOCKETWINSOCK_H diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/WindowsSandboxUtils.cpp b/TMessagesProj/jni/libtgvoip2/os/windows/WindowsSandboxUtils.cpp new file mode 100644 index 000000000..8fbba664e --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/WindowsSandboxUtils.cpp @@ -0,0 +1,68 @@ + +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "WindowsSandboxUtils.h" +#include +#include +#ifdef TGVOIP_WP_SILVERLIGHT +#include +#endif + +using namespace tgvoip; +using namespace Microsoft::WRL; + + +IAudioClient2* WindowsSandboxUtils::ActivateAudioDevice(const wchar_t* devID, HRESULT* callRes, HRESULT* actRes) { +#ifndef TGVOIP_WP_SILVERLIGHT + // Did I say that I hate pointlessly asynchronous things? + HANDLE event = CreateEventEx(NULL, NULL, 0, EVENT_ALL_ACCESS); + ActivationHandler activationHandler(event); + IActivateAudioInterfaceAsyncOperation* actHandler; + HRESULT cr = ActivateAudioInterfaceAsync(devID, __uuidof(IAudioClient2), NULL, (IActivateAudioInterfaceCompletionHandler*)&activationHandler, &actHandler); + if (callRes) + *callRes = cr; + DWORD resulttt = WaitForSingleObjectEx(event, INFINITE, false); + DWORD last = GetLastError(); + CloseHandle(event); + if (actRes) + *actRes = activationHandler.actResult; + return activationHandler.client; +#else + IAudioClient2* client; + HRESULT res=ActivateAudioInterface(devID, __uuidof(IAudioClient2), (void**)&client); + if(callRes) + *callRes=S_OK; + if(actRes) + *actRes=res; + return client; +#endif +} + +#ifndef TGVOIP_WP_SILVERLIGHT +ActivationHandler::ActivationHandler(HANDLE _event) : event(_event) +{ + +} + +STDMETHODIMP ActivationHandler::ActivateCompleted(IActivateAudioInterfaceAsyncOperation * operation) +{ + HRESULT hr = S_OK; + HRESULT hrActivateResult = S_OK; + IUnknown *punkAudioInterface = nullptr; + + hr = operation->GetActivateResult(&hrActivateResult, &punkAudioInterface); + if (SUCCEEDED(hr) && SUCCEEDED(hrActivateResult)) + { + punkAudioInterface->QueryInterface(IID_PPV_ARGS(&client)); + } + + SetEvent(event); + + return hr; +} + +#endif \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/WindowsSandboxUtils.h b/TMessagesProj/jni/libtgvoip2/os/windows/WindowsSandboxUtils.h new file mode 100644 index 000000000..aeddca076 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/WindowsSandboxUtils.h @@ -0,0 +1,42 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef LIBTGVOIP_WINDOWS_SANDBOX_UTILS +#define LIBTGVOIP_WINDOWS_SANDBOX_UTILS + +#include +#include +#ifndef TGVOIP_WP_SILVERLIGHT +#include +#endif +#include +#include + +using namespace Microsoft::WRL; + +namespace tgvoip { + +#ifndef TGVOIP_WP_SILVERLIGHT + class ActivationHandler : + public RuntimeClass< RuntimeClassFlags< ClassicCom >, FtmBase, IActivateAudioInterfaceCompletionHandler > + { + public: + STDMETHOD(ActivateCompleted)(IActivateAudioInterfaceAsyncOperation *operation); + + ActivationHandler(HANDLE _event); + HANDLE event; + IAudioClient2* client; + HRESULT actResult; + }; +#endif + + class WindowsSandboxUtils { + public: + static IAudioClient2* ActivateAudioDevice(const wchar_t* devID, HRESULT* callResult, HRESULT* actResult); + }; +} + +#endif // LIBTGVOIP_WINDOWS_SANDBOX_UTILS diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/WindowsSpecific.cpp b/TMessagesProj/jni/libtgvoip2/os/windows/WindowsSpecific.cpp new file mode 100644 index 000000000..3a1a23f9f --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/WindowsSpecific.cpp @@ -0,0 +1,9 @@ +#include "WindowsSpecific.h" + +using namespace tgvoip; + +std::string WindowsSpecific::GetErrorMessage(DWORD code){ + char buf[1024]={0}; + FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM, NULL, code, MAKELANGID(LANG_ENGLISH, SUBLANG_ENGLISH_US), buf, sizeof(buf), NULL); + return std::string(buf); +} \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/os/windows/WindowsSpecific.h b/TMessagesProj/jni/libtgvoip2/os/windows/WindowsSpecific.h new file mode 100644 index 000000000..617e0d598 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/os/windows/WindowsSpecific.h @@ -0,0 +1,16 @@ +#ifndef LIBTGVOIP_WINDOWS_SPECIFIC_H +#define LIBTGVOIP_WINDOWS_SPECIFIC_H + +#include +#include + +namespace tgvoip{ + + class WindowsSpecific{ + public: + static std::string GetErrorMessage(DWORD code); + }; + +} + +#endif // LIBTGVOIP_WINDOWS_SPECIFIC_H \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/tests/Info.plist b/TMessagesProj/jni/libtgvoip2/tests/Info.plist new file mode 100644 index 000000000..6c40a6cd0 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/tests/Info.plist @@ -0,0 +1,22 @@ + + + + + CFBundleDevelopmentRegion + $(DEVELOPMENT_LANGUAGE) + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + $(PRODUCT_NAME) + CFBundlePackageType + BNDL + CFBundleShortVersionString + 1.0 + CFBundleVersion + 1 + + diff --git a/TMessagesProj/jni/libtgvoip2/tests/MockReflector.cpp b/TMessagesProj/jni/libtgvoip2/tests/MockReflector.cpp new file mode 100644 index 000000000..d5a2e4246 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/tests/MockReflector.cpp @@ -0,0 +1,129 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#include "MockReflector.h" +#include +#include +#include + +using namespace tgvoip; +using namespace tgvoip::test; + +struct UdpReflectorSelfInfo{ + uint8_t peerTag[16]; + uint64_t _id1=0xFFFFFFFFFFFFFFFFLL; + uint32_t _id2=0xFFFFFFFF; + uint32_t magic=0xc01572c7; + int32_t date; + uint64_t query_id; + uint64_t my_ip_padding1; + uint32_t my_ip_padding2; + uint32_t my_ip; + uint32_t my_port; +} __attribute__((packed)); + +MockReflector::MockReflector(std::string bindAddress, uint16_t bindPort){ + sfd=socket(PF_INET, SOCK_DGRAM, IPPROTO_UDP); + assert(sfd!=-1); + sockaddr_in bindAddr={0}; + bindAddr.sin_family=AF_INET; + bindAddr.sin_port=htons(bindPort); + inet_aton(bindAddress.c_str(), &bindAddr.sin_addr); + int res=bind(sfd, (struct sockaddr*)&bindAddr, sizeof(bindAddr)); + assert(res==0); +} + +MockReflector::~MockReflector(){ + +} + +std::array, 2> MockReflector::GeneratePeerTags(){ + std::array tag1; + for(int i=0;i<16;i++){ + tag1[i]=(uint8_t)rand(); + } + tag1[15] &= 0xFE; + std::array, 2> res; + res[0]=tag1; + std::copy(tag1.begin(), tag1.end(), res[1].begin()); + res[1][15] |= 1; + return res; +} + +void MockReflector::Start(){ + if(running) + return; + running=true; + pthread_create(&thread, NULL, [](void* arg) -> void* { + reinterpret_cast(arg)->RunThread(); + return NULL; + }, this); +} + +void MockReflector::Stop(){ + running=false; + shutdown(sfd, SHUT_RDWR); + close(sfd); + pthread_join(thread, NULL); +} + +void MockReflector::SetDropAllPackets(bool drop){ + dropAllPackets=drop; +} + +void MockReflector::RunThread(){ + while(running){ + std::array buf; + sockaddr_in addr; + socklen_t addrlen=sizeof(addr); + ssize_t len=recvfrom(sfd, buf.data(), sizeof(buf), 0, (struct sockaddr*)&addr, &addrlen); + if(len<=0) + return; + if(len>=32){ + std::array peerTag; + int32_t specialID[4]; + std::copy(buf.begin(), buf.begin()+16, peerTag.begin()); + memcpy(specialID, buf.data()+16, 16); + uint64_t tagID=*reinterpret_cast(peerTag.data()); + ClientPair c=clients[tagID]; + sockaddr_in* dest; + if(peerTag[15] & 1){ + c.addr1=addr; + dest=&c.addr0; + }else{ + c.addr0=addr; + dest=&c.addr1; + } + clients[tagID]=c; + + if(specialID[0]==-1 && specialID[1]==-1 && specialID[2]==-1){ + if(specialID[3]==-1){ + continue; + }else if(specialID[3]==-2){ + UdpReflectorSelfInfo response; + memcpy(response.peerTag, peerTag.data(), 16); + response.date=(int32_t)time(NULL); + response.query_id=*reinterpret_cast(buf.data()+32); + response.my_ip_padding1=0; + response.my_ip_padding2=0xFFFF0000; + response.my_ip=(uint32_t)addr.sin_addr.s_addr; + response.my_port=ntohs(addr.sin_port); + sendto(sfd, &response, sizeof(response), 0, (struct sockaddr*)&addr, sizeof(addr)); + continue; + } + } + + if(dest->sin_family==AF_INET && !dropAllPackets){ + if(peerTag[15] & 1) + buf[15] &= 0xFE; + else + buf[15] |= 1; + + sendto(sfd, buf.data(), len, 0, (struct sockaddr*)dest, sizeof(sockaddr_in)); + } + } + } +} diff --git a/TMessagesProj/jni/libtgvoip2/tests/MockReflector.h b/TMessagesProj/jni/libtgvoip2/tests/MockReflector.h new file mode 100644 index 000000000..41a4d4b78 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/tests/MockReflector.h @@ -0,0 +1,50 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// +#ifndef TGVOIP_MOCK_REFLECTOR +#define TGVOIP_MOCK_REFLECTOR + +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include + +namespace tgvoip{ + namespace test{ + class MockReflector{ + public: + MockReflector(std::string bindAddress, uint16_t bindPort); + ~MockReflector(); + void Start(); + void Stop(); + void SetDropAllPackets(bool drop); + static std::array, 2> GeneratePeerTags(); + + private: + void RunThread(); + struct ClientPair{ + sockaddr_in addr0={0}; + sockaddr_in addr1={0}; + }; + std::unordered_map clients; // clients are identified by the first half of their peer_tag + int sfd; + pthread_t thread; + bool running=false; + bool dropAllPackets=false; + }; + } +} + +#endif //TGVOIP_MOCK_REFLECTOR diff --git a/TMessagesProj/jni/libtgvoip2/tests/libtgvoipTests.mm b/TMessagesProj/jni/libtgvoip2/tests/libtgvoipTests.mm new file mode 100644 index 000000000..c05e03894 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/tests/libtgvoipTests.mm @@ -0,0 +1,192 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#import + +#import "MockReflector.h" +#include "../VoIPController.h" +#include +#include "../webrtc_dsp/common_audio/wav_file.h" + +@interface libtgvoipTests : XCTestCase + +@end + +using namespace tgvoip; + +@implementation libtgvoipTests{ + VoIPController* controller1; + VoIPController* controller2; + std::string testWavFilePath; +} + +- (void)setUp { + [super setUp]; + // this file must be mono 16-bit 48000hz + NSString* path=[NSString stringWithFormat:@"%@/Downloads/voip_test_input.wav", NSHomeDirectory()]; + testWavFilePath=[path UTF8String]; +} + +- (void)tearDown { + + + [super tearDown]; +} + +- (void)initControllers{ + controller1=new VoIPController(); + controller2=new VoIPController(); + + std::array, 2> peerTags=test::MockReflector::GeneratePeerTags(); + std::vector endpoints1; + IPv4Address localhost("127.0.0.1"); + IPv6Address emptyV6; + endpoints1.push_back(Endpoint(1, 1033, localhost, emptyV6, Endpoint::Type::UDP_RELAY, peerTags[0].data())); + controller1->SetRemoteEndpoints(endpoints1, false, 76); + std::vector endpoints2; + endpoints2.push_back(Endpoint(1, 1033, localhost, emptyV6, Endpoint::Type::UDP_RELAY, peerTags[1].data())); + controller2->SetRemoteEndpoints(endpoints2, false, 76); + + char encryptionKey[256]; + RAND_bytes((uint8_t*)encryptionKey, sizeof(encryptionKey)); + controller1->SetEncryptionKey(encryptionKey, true); + controller2->SetEncryptionKey(encryptionKey, false); +} + +- (void)destroyControllers{ + controller1->Stop(); + delete controller1; + controller2->Stop(); + delete controller2; +} + +- (void)testBasicOperation { + webrtc::WavReader wavReader1(testWavFilePath); + webrtc::WavReader wavReader2(testWavFilePath); + webrtc::WavWriter wavWriter("output.wav", 48000, 1); + + test::MockReflector reflector("127.0.0.1", 1033); + reflector.Start(); + + [self initControllers]; + + controller1->SetAudioDataCallbacks([&wavReader1](int16_t* data, size_t len){ + wavReader1.ReadSamples(len, data); + }, [](int16_t* data, size_t len){ + + }); + + controller2->SetAudioDataCallbacks([&wavReader2](int16_t* data, size_t len){ + wavReader2.ReadSamples(len, data); + }, [&wavWriter](int16_t* data, size_t len){ + wavWriter.WriteSamples(data, len); + }); + + controller1->Start(); + controller2->Start(); + controller1->Connect(); + controller2->Connect(); + [NSThread sleepForTimeInterval:10.0]; + + [self destroyControllers]; + + reflector.Stop(); +} + +- (void)testAllocationAndDeallocation{ + test::MockReflector reflector("127.0.0.1", 1033); + reflector.Start(); + + for(int i=0;i<10;i++){ + webrtc::WavReader wavReader(testWavFilePath); + [self initControllers]; + + controller1->SetAudioDataCallbacks([&wavReader](int16_t* data, size_t len){ + wavReader.ReadSamples(len, data); + }, [](int16_t* data, size_t len){ + + }); + + controller2->SetAudioDataCallbacks([](int16_t* data, size_t len){ + + }, [](int16_t* data, size_t len){ + + }); + + controller1->Start(); + controller2->Start(); + controller1->Connect(); + controller2->Connect(); + [NSThread sleepForTimeInterval:3.0]; + + [self destroyControllers]; + } + + reflector.Stop(); +} + +- (void)testInitTimeout{ + [self initControllers]; + VoIPController::Config config; + config.enableNS=config.enableAEC=config.enableAGC=false; + config.enableCallUpgrade=false; + config.initTimeout=3.0; + controller1->SetConfig(config); + controller1->Start(); + controller1->Connect(); + [NSThread sleepForTimeInterval:1.5]; + XCTAssertEqual(controller1->GetConnectionState(), STATE_WAIT_INIT_ACK); + [NSThread sleepForTimeInterval:2.0]; + XCTAssertEqual(controller1->GetConnectionState(), STATE_FAILED); + XCTAssertEqual(controller1->GetLastError(), ERROR_TIMEOUT); + [self destroyControllers]; +} + +- (void)testPacketTimeout{ + test::MockReflector reflector("127.0.0.1", 1033); + reflector.Start(); + [self initControllers]; + + webrtc::WavReader wavReader(testWavFilePath); + controller1->SetAudioDataCallbacks([&wavReader](int16_t* data, size_t len){ + wavReader.ReadSamples(len, data); + }, [](int16_t* data, size_t len){ + + }); + + controller2->SetAudioDataCallbacks([](int16_t* data, size_t len){ + + }, [](int16_t* data, size_t len){ + + }); + + VoIPController::Config config; + config.enableNS=config.enableAEC=config.enableAGC=false; + config.enableCallUpgrade=false; + config.initTimeout=3.0; + config.recvTimeout=1.5; + controller1->SetConfig(config); + config.recvTimeout=5.0; + controller2->SetConfig(config); + + controller1->Start(); + controller2->Start(); + controller1->Connect(); + controller2->Connect(); + [NSThread sleepForTimeInterval:2.5]; + XCTAssertEqual(controller1->GetConnectionState(), STATE_ESTABLISHED); + XCTAssertEqual(controller2->GetConnectionState(), STATE_ESTABLISHED); + reflector.SetDropAllPackets(true); + [NSThread sleepForTimeInterval:2.5]; + XCTAssertEqual(controller1->GetConnectionState(), STATE_FAILED); + XCTAssertEqual(controller1->GetLastError(), ERROR_TIMEOUT); + XCTAssertEqual(controller2->GetConnectionState(), STATE_RECONNECTING); + + [self destroyControllers]; + reflector.Stop(); +} + +@end diff --git a/TMessagesProj/jni/libtgvoip2/tgvoip.pc.in b/TMessagesProj/jni/libtgvoip2/tgvoip.pc.in new file mode 100644 index 000000000..1ca775843 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/tgvoip.pc.in @@ -0,0 +1,10 @@ +prefix=@prefix@ +exec_prefix=@exec_prefix@ +libdir=@libdir@ +includedir=@includedir@ + +Name: tgvoip +Description: VoIP library for Telegram clients +Version: 2.4.4 +Libs: -L${libdir} -ltgvoip +Cflags: -I${includedir}/tgvoip diff --git a/TMessagesProj/jni/libtgvoip2/threading.h b/TMessagesProj/jni/libtgvoip2/threading.h new file mode 100644 index 000000000..f6163e90a --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/threading.h @@ -0,0 +1,356 @@ +// +// libtgvoip is free and unencumbered public domain software. +// For more information, see http://unlicense.org or the UNLICENSE file +// you should have received with this source code distribution. +// + +#ifndef __THREADING_H +#define __THREADING_H + +#include + +#if defined(_POSIX_THREADS) || defined(_POSIX_VERSION) || defined(__unix__) || defined(__unix) || (defined(__APPLE__) && defined(__MACH__)) + +#include +#include +#include +#include +#ifdef __APPLE__ +#include "os/darwin/DarwinSpecific.h" +#endif + +namespace tgvoip{ + class Mutex{ + public: + Mutex(){ + pthread_mutex_init(&mtx, NULL); + } + + ~Mutex(){ + pthread_mutex_destroy(&mtx); + } + + void Lock(){ + pthread_mutex_lock(&mtx); + } + + void Unlock(){ + pthread_mutex_unlock(&mtx); + } + + pthread_mutex_t* NativeHandle(){ + return &mtx; + } + + private: + Mutex(const Mutex& other); + pthread_mutex_t mtx; + }; + + class Thread{ + public: + Thread(std::function entry) : entry(entry){ + name=NULL; + thread=0; + } + + virtual ~Thread(){ + + } + + void Start(){ + if(pthread_create(&thread, NULL, Thread::ActualEntryPoint, this)==0){ + valid=true; + } + } + + void Join(){ + if(valid) + pthread_join(thread, NULL); + } + + void SetName(const char* name){ + this->name=name; + } + + + void SetMaxPriority(){ +#ifdef __APPLE__ + maxPriority=true; +#endif + } + + static void Sleep(double seconds){ + usleep((useconds_t)(seconds*1000000.0)); + } + + bool IsCurrent(){ + return pthread_equal(thread, pthread_self())!=0; + } + + private: + static void* ActualEntryPoint(void* arg){ + Thread* self=reinterpret_cast(arg); + if(self->name){ +#if !defined(__APPLE__) && !defined(__gnu_hurd__) + pthread_setname_np(self->thread, self->name); +#elif !defined(__gnu_hurd__) + pthread_setname_np(self->name); + if(self->maxPriority){ + DarwinSpecific::SetCurrentThreadPriority(DarwinSpecific::THREAD_PRIO_USER_INTERACTIVE); + } +#endif + } + self->entry(); + return NULL; + } + std::function entry; + pthread_t thread; + const char* name; +#ifdef __APPLE__ + bool maxPriority=false; +#endif + bool valid=false; + }; +} + +#ifdef __APPLE__ +#include +namespace tgvoip{ +class Semaphore{ +public: + Semaphore(unsigned int maxCount, unsigned int initValue){ + sem = dispatch_semaphore_create(initValue); + } + + ~Semaphore(){ +#if ! __has_feature(objc_arc) + dispatch_release(sem); +#endif + } + + void Acquire(){ + dispatch_semaphore_wait(sem, DISPATCH_TIME_FOREVER); + } + + void Release(){ + dispatch_semaphore_signal(sem); + } + + void Acquire(int count){ + for(int i=0;i +#include + +namespace tgvoip{ + class Mutex{ + public: + Mutex(){ +#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY!=WINAPI_FAMILY_PHONE_APP + InitializeCriticalSection(§ion); +#else + InitializeCriticalSectionEx(§ion, 0, 0); +#endif + } + + ~Mutex(){ + DeleteCriticalSection(§ion); + } + + void Lock(){ + EnterCriticalSection(§ion); + } + + void Unlock(){ + LeaveCriticalSection(§ion); + } + + private: + Mutex(const Mutex& other); + CRITICAL_SECTION section; + }; + + class Thread{ + public: + Thread(std::function entry) : entry(entry){ + name=NULL; + thread=NULL; + } + + ~Thread(){ + } + + void Start(){ + thread=CreateThread(NULL, 0, Thread::ActualEntryPoint, this, 0, &id); + } + + void Join(){ + if(!thread) + return; +#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY!=WINAPI_FAMILY_PHONE_APP + WaitForSingleObject(thread, INFINITE); +#else + WaitForSingleObjectEx(thread, INFINITE, false); +#endif + CloseHandle(thread); + } + + void SetName(const char* name){ + this->name=name; + } + + void SetMaxPriority(){ + SetThreadPriority(thread, THREAD_PRIORITY_HIGHEST); + } + + static void Sleep(double seconds){ + ::Sleep((DWORD)(seconds*1000)); + } + + bool IsCurrent(){ + return id==GetCurrentThreadId(); + } + + private: + static const DWORD MS_VC_EXCEPTION=0x406D1388; + + #pragma pack(push,8) + typedef struct tagTHREADNAME_INFO + { + DWORD dwType; // Must be 0x1000. + LPCSTR szName; // Pointer to name (in user addr space). + DWORD dwThreadID; // Thread ID (-1=caller thread). + DWORD dwFlags; // Reserved for future use, must be zero. + } THREADNAME_INFO; + #pragma pack(pop) + + static DWORD WINAPI ActualEntryPoint(void* arg){ + Thread* self=reinterpret_cast(arg); + if(self->name){ + THREADNAME_INFO info; + info.dwType=0x1000; + info.szName=self->name; + info.dwThreadID=-1; + info.dwFlags=0; + __try{ + RaiseException(MS_VC_EXCEPTION, 0, sizeof(info)/sizeof(ULONG_PTR), (ULONG_PTR*)&info); + }__except(EXCEPTION_EXECUTE_HANDLER){} + } + self->entry(); + return 0; + } + std::function entry; + HANDLE thread; + DWORD id; + const char* name; + }; + +class Semaphore{ +public: + Semaphore(unsigned int maxCount, unsigned int initValue){ +#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY!=WINAPI_FAMILY_PHONE_APP + h=CreateSemaphore(NULL, initValue, maxCount, NULL); +#else + h=CreateSemaphoreEx(NULL, initValue, maxCount, NULL, 0, SEMAPHORE_ALL_ACCESS); + assert(h); +#endif + } + + ~Semaphore(){ + CloseHandle(h); + } + + void Acquire(){ +#if !defined(WINAPI_FAMILY) || WINAPI_FAMILY!=WINAPI_FAMILY_PHONE_APP + WaitForSingleObject(h, INFINITE); +#else + WaitForSingleObjectEx(h, INFINITE, false); +#endif + } + + void Release(){ + ReleaseSemaphore(h, 1, NULL); + } + + void Acquire(int count){ + for(int i=0;i +#include +#include "ScreamCongestionController.h" +#include "../logging.h" +#include "../VoIPController.h" + +using namespace tgvoip; +using namespace tgvoip::video; + +namespace{ + constexpr float QDELAY_TARGET_LO=0.1f; // seconds + constexpr float QDELAY_TARGET_HI=0.4f; // seconds + constexpr float QDELAY_WEIGHT=0.1f; + constexpr float QDELAY_TREND_TH=0.2f; + constexpr uint32_t MIN_CWND=3000; // bytes + constexpr float MAX_BYTES_IN_FLIGHT_HEAD_ROOM=1.1f; + constexpr float GAIN=1.0f; + constexpr float BETA_LOSS=0.9f; + constexpr float BETA_ECN=0.9f; + constexpr float BETA_R=0.9f; + constexpr uint32_t MSS=1024; + constexpr float RATE_ADJUST_INTERVAL=0.2f; + constexpr uint32_t TARGET_BITRATE_MIN=50*1024; // bps + constexpr uint32_t TARGET_BITRATE_MAX=500*1024; // bps + constexpr uint32_t RAMP_UP_SPEED=1024*1024;//200000; // bps/s + constexpr float PRE_CONGESTION_GUARD=0.1f; + constexpr float TX_QUEUE_SIZE_FACTOR=1.0f; + constexpr float RTP_QDELAY_TH=0.02f; // seconds + constexpr float TARGET_RATE_SCALE_RTP_QDELAY=0.95f; + constexpr float QDELAY_TREND_LO=0.2f; + constexpr float T_RESUME_FAST_INCREASE=5.0f; // seconds + constexpr uint32_t RATE_PACE_MIN=50000; // bps +} + +ScreamCongestionController::ScreamCongestionController() : qdelayTarget(QDELAY_TARGET_LO), cwnd(MIN_CWND) { + +} + +void ScreamCongestionController::UpdateVariables(float qdelay){ + float qdelayFraction=qdelay/qdelayTarget; + qdelayFractionAvg=(1.0f-QDELAY_WEIGHT)*qdelayFractionAvg+qdelayFraction*QDELAY_WEIGHT; + qdelayFractionHist.Add(qdelayFraction); + float avg=qdelayFractionHist.Average(); + + float r1=0.0, r0=0.0; + for(int i=(int)qdelayFractionHist.Size()-1;i>=0;i--){ + float v=qdelayFractionHist[i]-avg; + r0+=v*v; + } + for(int i=(int)qdelayFractionHist.Size()-1;i>=1;i--){ + float v1=qdelayFractionHist[i]-avg; + float v2=qdelayFractionHist[i-1]-avg; + r1+=v1*v2; + } + float a=r1/r0; + qdelayTrend=std::min(1.0f, std::max(0.0f, a*qdelayFractionAvg)); + qdelayTrendMem=std::max(0.99f*qdelayTrendMem, qdelayTrend); + + if(qdelayTrend>QDELAY_TREND_LO){ + lastTimeQDelayTrendWasGreaterThanLo=VoIPController::GetCurrentTime(); + } +} + +void ScreamCongestionController::UpdateCWnd(float qdelay){ + if(inFastIncrease){ + if(qdelayTrend>=QDELAY_TREND_TH){ + inFastIncrease=false; + }else{ + if((float)bytesInFlight*1.5f+bytesNewlyAcked>cwnd){ + //LOGD("HERE"); + cwnd+=bytesNewlyAcked; + } + return; + } + } + + float offTarget=(qdelayTarget-qdelay)/qdelayTarget; + + float gain=GAIN; + float cwndDelta=gain*offTarget*bytesNewlyAcked*MSS/(float)cwnd; + if(offTarget>0 && (float)bytesInFlight*1.25f+bytesNewlyAcked<=cwnd){ + cwndDelta=0.0; + } + cwnd+=cwndDelta; + cwnd=std::min(cwnd, (uint32_t)(maxBytesInFlight*MAX_BYTES_IN_FLIGHT_HEAD_ROOM)); + cwnd=std::max(cwnd, MIN_CWND); +} + +void ScreamCongestionController::AdjustQDelayTarget(float qdelay){ + float qdelayNorm=qdelay/QDELAY_TARGET_LO; + qdelayNormHist.Add(qdelayNorm); + + float qdelayNormAvg=qdelayNormHist.Average(); + float qdelayNormVar=0.0; + for(uint32_t i=0;i0.002f){ + qdelayTarget=1.5f*newTarget; + }else{ + if(qdelayNormVar<0.2f){ + qdelayTarget=newTarget; + }else{ + if(newTarget0.0f){ + deltaRate*=scale; + deltaRate=std::min(deltaRate, rampUpSpeed*RATE_ADJUST_INTERVAL); + } + targetBitrate+=deltaRate; + float rtpQueueDelay=(float)rtpQueueSize/currentRate; + if(rtpQueueDelay>RTP_QDELAY_TH){ + targetBitrate=(uint32_t)((float)targetBitrate*TARGET_RATE_SCALE_RTP_QDELAY); + } + } + + float rateMediaLimit=std::max(currentRate, std::max(rateMedia, rateMediaMedian)); + rateMediaLimit*=(2.0-qdelayTrendMem); + targetBitrate=std::min(targetBitrate, (uint32_t)rateMediaLimit); + targetBitrate=std::min(TARGET_BITRATE_MAX, std::max(TARGET_BITRATE_MIN, targetBitrate)); +} + +void ScreamCongestionController::CalculateSendWindow(float qdelay){ + if(qdelay<=qdelayTarget) + sendWnd=cwnd+MSS-bytesInFlight; + else + sendWnd=cwnd-bytesInFlight; +} + +void ScreamCongestionController::ProcessAcks(float oneWayDelay, uint32_t bytesNewlyAcked, uint32_t lossCount, double rtt){ + if(prevOneWayDelay!=0.0f){ + double currentTime=VoIPController::GetCurrentTime(); + float qdelay=oneWayDelay-prevOneWayDelay; + sRTT=(float)rtt; + bytesInFlight-=bytesNewlyAcked; + rtpQueueSize-=(bytesNewlyAcked*8); + UpdateBytesInFlightHistory(); + bytesAcked+=bytesNewlyAcked; + //LOGV("Scream: qdelay = %f, newly acked = %u, in flight = %u, losses = %u", qdelay, bytesNewlyAcked, bytesInFlight, lossCount); + if(currentTime-lastVariablesUpdateTime>=0.050){ + lastVariablesUpdateTime=currentTime; + UpdateVariables(qdelay); + } + if(currentTime-lastRateAdjustmentTime>=RATE_ADJUST_INTERVAL){ + lastRateAdjustmentTime=currentTime; + AdjustBitrate(); + //LOGV("Scream: target bitrate = %u", targetBitrate); + } + if(lossCount>prevLossCount && currentTime>ignoreLossesUntil){ + LOGD("Scream: loss detected"); + ignoreLossesUntil=currentTime+rtt; + LOGD("ignoring losses for %f", rtt); + inFastIncrease=false; + cwnd=std::max(MIN_CWND, (uint32_t)(cwnd*BETA_LOSS)); + AdjustQDelayTarget(qdelay); + CalculateSendWindow(qdelay); + lossPending=true; + lastTimeQDelayTrendWasGreaterThanLo=currentTime; + }else{ + this->bytesNewlyAcked+=bytesNewlyAcked; + if(currentTime-lastCWndUpdateTime>=0.15){ + lastCWndUpdateTime=currentTime; + UpdateCWnd(qdelay); + //LOGI("Scream: cwnd = %u", cwnd); + this->bytesNewlyAcked=0; + } + AdjustQDelayTarget(qdelay); + CalculateSendWindow(qdelay); + if(!inFastIncrease){ + if(currentTime-lastTimeQDelayTrendWasGreaterThanLo>=T_RESUME_FAST_INCREASE){ + inFastIncrease=true; + } + } + } + prevLossCount=lossCount; + } + prevOneWayDelay=oneWayDelay; +} + +void ScreamCongestionController::ProcessPacketSent(uint32_t size){ + bytesInFlight+=size; + rtpQueueSize+=(size*8); + bytesSent+=size; + double currentTime=VoIPController::GetCurrentTime(); + if(currentTime-rateTransmitUpdateTime>=0.2){ + rateTransmit=(float)(bytesSent*8)/(float)(currentTime-rateTransmitUpdateTime); + rateAck=(float)(bytesAcked*8)/(float)(currentTime-rateTransmitUpdateTime); + rateTransmitUpdateTime=currentTime; + bytesSent=0; + bytesAcked=0; + //LOGV("rateTransmit %f, rateAck %f", rateTransmit, rateAck); + } + UpdateBytesInFlightHistory(); +} + +void ScreamCongestionController::ProcessPacketLost(uint32_t size){ + bytesInFlight-=size; + rtpQueueSize-=(size*8); + UpdateBytesInFlightHistory(); +} + +double ScreamCongestionController::GetPacingInterval(){ + float paceBitrate=std::max((float)RATE_PACE_MIN, cwnd*8.0f/sRTT); + //LOGV("RTT=%f cwnd=%u paceBitrate=%f fastIncrease=%d", sRTT, cwnd, paceBitrate, inFastIncrease); + double pacingInterval=rtpSize*8.0f/paceBitrate; + return std::min(0.010, pacingInterval); +} + +void ScreamCongestionController::UpdateBytesInFlightHistory(){ + double currentTime=VoIPController::GetCurrentTime(); + ValueSample now={bytesInFlight, currentTime}; + bytesInFlightHistory.push_back(now); + uint32_t max=0; + for(std::vector::iterator i=bytesInFlightHistory.begin();i!=bytesInFlightHistory.end();){ + if(currentTime-i->time>=5.0){ + i=bytesInFlightHistory.erase(i); + }else{ + max=std::max(max, i->sample); + ++i; + } + } + maxBytesInFlight=max; +} + +void ScreamCongestionController::UpdateMediaRate(uint32_t frameSize){ + bytesMedia+=frameSize; + double currentTime=VoIPController::GetCurrentTime(); + if(currentTime-rateMediaUpdateTime>=0.5){ + rateMedia=(float)(bytesMedia*8)/(float)(currentTime-rateMediaUpdateTime); + bytesMedia=0; + rateMediaUpdateTime=currentTime; + LOGV("rateMedia %f", rateMedia); + rateMediaHistory.Add(rateMedia); + rateMediaMedian=rateMediaHistory.NonZeroAverage(); + } +} + +uint32_t ScreamCongestionController::GetBitrate(){ + return targetBitrate; +} diff --git a/TMessagesProj/jni/libtgvoip2/video/ScreamCongestionController.h b/TMessagesProj/jni/libtgvoip2/video/ScreamCongestionController.h new file mode 100644 index 000000000..30d3ff1e8 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/ScreamCongestionController.h @@ -0,0 +1,80 @@ +// +// Created by Grishka on 25/02/2019. +// + +#ifndef LIBTGVOIP_SCREAMCONGESTIONCONTROLLER_H +#define LIBTGVOIP_SCREAMCONGESTIONCONTROLLER_H + +#include "../Buffers.h" +#include +#include + +namespace tgvoip{ + namespace video{ + class ScreamCongestionController{ + public: + ScreamCongestionController(); + void AdjustBitrate(); + void ProcessAcks(float oneWayDelay, uint32_t bytesNewlyAcked, uint32_t lossCount, double rtt); + void ProcessPacketSent(uint32_t size); + void ProcessPacketLost(uint32_t size); + double GetPacingInterval(); + void UpdateMediaRate(uint32_t frameSize); + uint32_t GetBitrate(); + + private: + void UpdateVariables(float qdelay); + void UpdateCWnd(float qdelay); + void AdjustQDelayTarget(float qdelay); + void CalculateSendWindow(float qdelay); + + void UpdateBytesInFlightHistory(); + + struct ValueSample{ + uint32_t sample; + double time; + }; + + float qdelayTarget; + float qdelayFractionAvg=0.0f; + HistoricBuffer qdelayFractionHist; + float qdelayTrend=0.0f; + float qdelayTrendMem=0.0f; + HistoricBuffer qdelayNormHist; + bool inFastIncrease=true; + uint32_t cwnd; + uint32_t bytesNewlyAcked=0; + uint32_t maxBytesInFlight=0; + uint32_t sendWnd=0; + uint32_t targetBitrate=0; + uint32_t targetBitrateLastMax=1; + float rateTransmit=0.0f; + float rateAck=0.0f; + float rateMedia=0.0f; + float rateMediaMedian=0.0f; + float sRTT=0.0f; + uint32_t rtpQueueSize=0; + uint32_t rtpSize=1024; //0; + float lossEventRate=0.0f; + + bool lossPending=false; + float prevOneWayDelay=0.0f; + double ignoreLossesUntil=0.0; + uint32_t prevLossCount=0; + double lastTimeQDelayTrendWasGreaterThanLo=0.0; + double lastVariablesUpdateTime=0.0; + double lastRateAdjustmentTime=0.0; + double lastCWndUpdateTime=0.0; + uint32_t bytesInFlight=0; + std::vector bytesInFlightHistory; + uint32_t bytesSent=0; + uint32_t bytesAcked=0; + uint32_t bytesMedia=0; + double rateTransmitUpdateTime=0.0; + double rateMediaUpdateTime=0.0; + HistoricBuffer rateMediaHistory; + }; + } +} + +#endif //LIBTGVOIP_SCREAMCONGESTIONCONTROLLER_H diff --git a/TMessagesProj/jni/libtgvoip2/video/VideoFEC.cpp b/TMessagesProj/jni/libtgvoip2/video/VideoFEC.cpp new file mode 100644 index 000000000..6e45edc19 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/VideoFEC.cpp @@ -0,0 +1,72 @@ +// +// Created by Grishka on 24/03/2019. +// + +#include "VideoFEC.h" +#include "../logging.h" +#include + +using namespace tgvoip; +using namespace tgvoip::video; + +Buffer ParityFEC::Encode(std::vector& packets){ + size_t maxSize=0; + + for(Buffer& pkt:packets){ + maxSize=std::max(maxSize, pkt.Length()); + } + Buffer result(maxSize+2); // add 2 bytes for length + uint8_t* _result=*result; + memset(_result, 0, result.Length()); + for(Buffer& pkt:packets){ + for(size_t i=0;i> 8); + } + + return std::move(result); +} + +Buffer ParityFEC::Decode(std::vector& dataPackets, Buffer &fecPacket){ + size_t maxSize=0; + for(Buffer& pkt:dataPackets){ + maxSize=std::max(maxSize, pkt.Length()); + } + + if(fecPacket.Length()=%u)", (unsigned int)fecPacket.Length(), (unsigned int)maxSize+2); + return Buffer(); + } + Buffer result=Buffer::CopyOf(fecPacket); + uint8_t* _result=*result; + unsigned int emptyCount=0; + for(Buffer& pkt:dataPackets){ + if(pkt.Length()==0){ + emptyCount++; + continue; + } + for(size_t i=0;i> 8); + } + if(emptyCount!=1){ + LOGE("ParityFEC: %u packets lost", emptyCount); + return Buffer(); + } + + uint16_t len=(uint16_t)_result[maxSize] | ((uint16_t)_result[maxSize+1] << 8); + if(len>maxSize){ + LOGE("ParityFEC: incorrect length %u", len); + return Buffer(); + } + LOGV("ParityFEC decoded packet size %u", len); + + result.Resize(len); + return std::move(result); +} diff --git a/TMessagesProj/jni/libtgvoip2/video/VideoFEC.h b/TMessagesProj/jni/libtgvoip2/video/VideoFEC.h new file mode 100644 index 000000000..352900329 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/VideoFEC.h @@ -0,0 +1,25 @@ +// +// Created by Grishka on 24/03/2019. +// + +#ifndef LIBTGVOIP_VIDEOFEC_H +#define LIBTGVOIP_VIDEOFEC_H + +#include "../Buffers.h" +#include + +namespace tgvoip{ + namespace video{ + class ParityFEC{ + public: + static Buffer Encode(std::vector& packets); + static Buffer Decode(std::vector& dataPackets, Buffer& fecPacket); + }; + + class CM256FEC{ + + }; + } +} + +#endif //LIBTGVOIP_VIDEOFEC_H diff --git a/TMessagesProj/jni/libtgvoip2/video/VideoPacketSender.cpp b/TMessagesProj/jni/libtgvoip2/video/VideoPacketSender.cpp new file mode 100644 index 000000000..2d74e186b --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/VideoPacketSender.cpp @@ -0,0 +1,325 @@ +// +// Created by Grishka on 19/03/2019. +// + +#include +#include "VideoPacketSender.h" +#include "VideoFEC.h" +#include "../logging.h" +#include "../PrivateDefines.h" + +using namespace tgvoip; +using namespace tgvoip::video; + +VideoPacketSender::VideoPacketSender(VoIPController* controller, VideoSource* videoSource, std::shared_ptr stream) : PacketSender(controller), stm(stream){ + SetSource(videoSource); +} + +VideoPacketSender::~VideoPacketSender(){ +} + +void VideoPacketSender::PacketAcknowledged(uint32_t seq, double sendTime, double ackTime, uint8_t type, uint32_t size){ + uint32_t bytesNewlyAcked=0; + //if(!videoKeyframeRequested){ + // video frames are stored in sentVideoFrames in order of increasing numbers + // so if a frame (or part of it) is acknowledged but isn't sentVideoFrames[0], we know there was a packet loss + for(SentVideoFrame& f:sentVideoFrames){ + for(std::vector::iterator s=f.unacknowledgedPackets.begin(); s!=f.unacknowledgedPackets.end();){ + //RecentOutgoingPacket* opkt=GetRecentOutgoingPacket(*s); + if(/*opkt && opkt->ackTime!=0.0*/*s==seq){ + s=f.unacknowledgedPackets.erase(s); + //newlyAckedVideoBytes+=opkt->size; + bytesNewlyAcked=size; + break; + }else{ + ++s; + } + } + } + for(std::vector::iterator f=sentVideoFrames.begin();f!=sentVideoFrames.end();){ + if(f->unacknowledgedPackets.empty() && f->fragmentsInQueue==0){ + f=sentVideoFrames.erase(f); + continue; + } + ++f; + } + //} + if(bytesNewlyAcked){ + float _sendTime=(float)(sendTime-GetConnectionInitTime()); + float recvTime=(float)ackTime; + float oneWayDelay=recvTime-_sendTime; + //LOGV("one-way delay: %f", oneWayDelay); + videoCongestionControl.ProcessAcks(oneWayDelay, bytesNewlyAcked, videoPacketLossCount, RTTHistory().Average(5)); + } + //videoCongestionControl.GetPacingInterval(); +} + +void VideoPacketSender::PacketLost(uint32_t seq, uint8_t type, uint32_t size){ + if(type==PKT_STREAM_EC) + return; + LOGW("VideoPacketSender::PacketLost: %u (size %u)", seq, size); + //LOGI("frame count %u", (unsigned int)sentVideoFrames.size()); + for(std::vector::iterator f=sentVideoFrames.begin();f!=sentVideoFrames.end();++f){ + std::vector::iterator pkt=std::find(f->unacknowledgedPackets.begin(), f->unacknowledgedPackets.end(), seq); + if(pkt!=f->unacknowledgedPackets.end()){ + LOGW("Lost packet belongs to frame %u", f->seq); + videoPacketLossCount++; + videoCongestionControl.ProcessPacketLost(size); + if(!videoKeyframeRequested){ + videoKeyframeRequested=true; + source->RequestKeyFrame(); + } + f->unacknowledgedPackets.erase(pkt); + if(f->unacknowledgedPackets.empty() && f->fragmentsInQueue==0){ + sentVideoFrames.erase(f); + } + return; + } + } + //abort(); +} + +void VideoPacketSender::SetSource(VideoSource *source){ + if(this->source==source) + return; + + if(this->source){ + this->source->Stop(); + this->source->SetCallback(nullptr); + //delete this->source; + } + + this->source=source; + + if(!source) + return; + + sourceChangeTime=lastVideoResolutionChangeTime=VoIPController::GetCurrentTime(); + uint32_t bitrate=videoCongestionControl.GetBitrate(); + currentVideoBitrate=bitrate; + source->SetBitrate(bitrate); + source->Reset(stm->codec, stm->resolution=GetVideoResolutionForCurrentBitrate()); + source->Start(); + source->SetCallback(std::bind(&VideoPacketSender::SendFrame, this, std::placeholders::_1, std::placeholders::_2, std::placeholders::_3)); + source->SetStreamStateCallback([this](bool paused){ + stm->paused=paused; + GetMessageThread().Post([this]{ + SendStreamFlags(*stm); + }); + }); +} + +void VideoPacketSender::SendFrame(const Buffer &_frame, uint32_t flags, uint32_t rotation){ + std::shared_ptr framePtr=std::make_shared(Buffer::CopyOf(_frame)); + GetMessageThread().Post([this, framePtr, flags, rotation]{ + const Buffer& frame=*framePtr; + + double currentTime=VoIPController::GetCurrentTime(); + + if(firstVideoFrameTime==0.0) + firstVideoFrameTime=currentTime; + + videoCongestionControl.UpdateMediaRate(static_cast(frame.Length())); + uint32_t bitrate=videoCongestionControl.GetBitrate(); + if(bitrate!=currentVideoBitrate){ + currentVideoBitrate=bitrate; + LOGD("Setting video bitrate to %u", bitrate); + source->SetBitrate(bitrate); + } + int resolutionFromBitrate=GetVideoResolutionForCurrentBitrate(); + if(resolutionFromBitrate!=stm->resolution && currentTime-lastVideoResolutionChangeTime>3.0 && currentTime-sourceChangeTime>10.0){ + LOGI("Changing video resolution: %d -> %d", stm->resolution, resolutionFromBitrate); + stm->resolution=resolutionFromBitrate; + GetMessageThread().Post([this, resolutionFromBitrate]{ + source->Reset(stm->codec, resolutionFromBitrate); + stm->csdIsValid=false; + }); + lastVideoResolutionChangeTime=currentTime; + return; + } + + if(videoKeyframeRequested){ + if(flags & VIDEO_FRAME_FLAG_KEYFRAME){ + videoKeyframeRequested=false; + }else{ + LOGV("Dropping input video frame waiting for key frame"); + //return; + } + } + + uint32_t pts=videoFrameCount++; + bool csdInvalidated=!stm->csdIsValid; + if(!stm->csdIsValid){ + std::vector &csd=source->GetCodecSpecificData(); + stm->codecSpecificData.clear(); + for(Buffer &b:csd){ + stm->codecSpecificData.push_back(Buffer::CopyOf(b)); + } + stm->csdIsValid=true; + stm->width=source->GetFrameWidth(); + stm->height=source->GetFrameHeight(); + //SendStreamCSD(); + } + + Buffer csd; + if(flags & VIDEO_FRAME_FLAG_KEYFRAME){ + BufferOutputStream os(256); + os.WriteInt16((int16_t) stm->width); + os.WriteInt16((int16_t) stm->height); + unsigned char sizeAndFlag=(unsigned char) stm->codecSpecificData.size(); + if(csdInvalidated) + sizeAndFlag|=0x80; + os.WriteByte(sizeAndFlag); + for(Buffer &b:stm->codecSpecificData){ + assert(b.Length()<255); + os.WriteByte(static_cast(b.Length())); + os.WriteBytes(b); + } + csd=std::move(os); + } + + frameSeq++; + size_t totalLength=csd.Length()+frame.Length(); + size_t segmentCount=totalLength/1024; + if(totalLength%1024>0) + segmentCount++; + SentVideoFrame sentFrame; + sentFrame.seq=frameSeq; + sentFrame.fragmentCount=static_cast(segmentCount); + sentFrame.fragmentsInQueue=0;//static_cast(segmentCount); + size_t offset=0; + size_t packetSize=totalLength/segmentCount; + for(size_t seg=0; segid | pflags)); // streamID + flags + int16_t lengthAndFlags=static_cast(len & 0x7FF); + if(segmentCount>1) + lengthAndFlags|=STREAM_DATA_XFLAG_FRAGMENTED; + if(flags & VIDEO_FRAME_FLAG_KEYFRAME) + lengthAndFlags|=STREAM_DATA_XFLAG_KEYFRAME; + pkt.WriteInt16(lengthAndFlags); + //pkt.WriteInt32(audioTimestampOut); + pkt.WriteInt32(pts); + if(segmentCount>1){ + pkt.WriteByte((unsigned char) seg); + pkt.WriteByte((unsigned char) segmentCount); + } + pkt.WriteByte((uint8_t) frameSeq); + size_t dataOffset=pkt.GetLength(); + if(seg==0){ + unsigned char _rotation; + switch(rotation){ + case 90: + _rotation=VIDEO_ROTATION_90; + break; + case 180: + _rotation=VIDEO_ROTATION_180; + break; + case 270: + _rotation=VIDEO_ROTATION_270; + break; + case 0: + default: + _rotation=VIDEO_ROTATION_0; + break; + } + pkt.WriteByte(_rotation); + dataOffset++; + + if(!csd.IsEmpty()){ + pkt.WriteBytes(csd); + len-=csd.Length(); + } + } + pkt.WriteBytes(frame, offset, len); + //LOGV("Sending segment %u of %u, length %u", (unsigned int)seg, (unsigned int)segmentCount, (unsigned int)pkt.GetLength()); + + Buffer fecPacketData(pkt.GetLength()-dataOffset); + fecPacketData.CopyFrom(pkt.GetBuffer()+dataOffset, 0, pkt.GetLength()-dataOffset); + packetsForFEC.push_back(std::move(fecPacketData)); + offset+=len; + + Buffer packetData(std::move(pkt)); + + VoIPController::PendingOutgoingPacket p{ + /*.seq=*/0, + /*.type=*/PKT_STREAM_DATA, + /*.len=*/packetData.Length(), + /*.data=*/std::move(packetData), + /*.endpoint=*/0, + }; + IncrementUnsentStreamPackets(); + uint32_t seq=SendPacket(std::move(p)); + videoCongestionControl.ProcessPacketSent(static_cast(pkt.GetLength())); + sentFrame.unacknowledgedPackets.push_back(seq); + //packetQueue.Put(QueuedPacket{std::move(p), sentFrame.seq}); + } + fecFrameCount++; + if(fecFrameCount>=3){ + Buffer fecPacket=ParityFEC::Encode(packetsForFEC); + + packetsForFEC.clear(); + fecFrameCount=0; + LOGV("FEC packet length: %u", (unsigned int) fecPacket.Length()); + BufferOutputStream out(1500); + out.WriteByte(stm->id); + out.WriteByte((uint8_t) frameSeq); + out.WriteByte(FEC_SCHEME_XOR); + out.WriteByte(3); + out.WriteInt16((int16_t) fecPacket.Length()); + out.WriteBytes(fecPacket); + + VoIPController::PendingOutgoingPacket p{ + 0, + PKT_STREAM_EC, + out.GetLength(), + Buffer(std::move(out)), + 0 + }; + uint32_t seq=SendPacket(std::move(p)); + } + sentVideoFrames.push_back(sentFrame); + }); +} + +int VideoPacketSender::GetVideoResolutionForCurrentBitrate(){ + + int peerMaxVideoResolution=GetProtocolInfo().maxVideoResolution; + int resolutionFromBitrate=INIT_VIDEO_RES_1080; + if(VoIPController::GetCurrentTime()-sourceChangeTime>10.0){ + // TODO: probably move this to server config + if(stm->codec==CODEC_AVC || stm->codec==CODEC_VP8){ + if(currentVideoBitrate>400000){ + resolutionFromBitrate=INIT_VIDEO_RES_720; + }else if(currentVideoBitrate>250000){ + resolutionFromBitrate=INIT_VIDEO_RES_480; + }else{ + resolutionFromBitrate=INIT_VIDEO_RES_360; + } + }else if(stm->codec==CODEC_HEVC || stm->codec==CODEC_VP9){ + if(currentVideoBitrate>400000){ + resolutionFromBitrate=INIT_VIDEO_RES_1080; + }else if(currentVideoBitrate>250000){ + resolutionFromBitrate=INIT_VIDEO_RES_720; + }else if(currentVideoBitrate>100000){ + resolutionFromBitrate=INIT_VIDEO_RES_480; + }else{ + resolutionFromBitrate=INIT_VIDEO_RES_360; + } + } + }else{ + if(stm->codec==CODEC_AVC || stm->codec==CODEC_VP8) + resolutionFromBitrate=INIT_VIDEO_RES_720; + else if(stm->codec==CODEC_HEVC || stm->codec==CODEC_VP9) + resolutionFromBitrate=INIT_VIDEO_RES_1080; + } + return std::min(peerMaxVideoResolution, resolutionFromBitrate); +} diff --git a/TMessagesProj/jni/libtgvoip2/video/VideoPacketSender.h b/TMessagesProj/jni/libtgvoip2/video/VideoPacketSender.h new file mode 100644 index 000000000..ec585647b --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/VideoPacketSender.h @@ -0,0 +1,66 @@ +// +// Created by Grishka on 19/03/2019. +// + +#ifndef LIBTGVOIP_VIDEOPACKETSENDER_H +#define LIBTGVOIP_VIDEOPACKETSENDER_H + +#include "../PacketSender.h" +#include "../Buffers.h" +#include "../threading.h" +#include +#include +#include + +namespace tgvoip{ + namespace video{ + class VideoSource; + + class VideoPacketSender : public PacketSender{ + public: + VideoPacketSender(VoIPController* controller, VideoSource* videoSource, std::shared_ptr stream); + virtual ~VideoPacketSender(); + virtual void PacketAcknowledged(uint32_t seq, double sendTime, double ackTime, uint8_t type, uint32_t size) override; + virtual void PacketLost(uint32_t seq, uint8_t type, uint32_t size) override; + void SetSource(VideoSource* source); + + uint32_t GetBitrate(){ + return currentVideoBitrate; + } + + private: + struct SentVideoFrame{ + uint32_t seq; + uint32_t fragmentCount; + std::vector unacknowledgedPackets; + uint32_t fragmentsInQueue; + }; + struct QueuedPacket{ + VoIPController::PendingOutgoingPacket packet; + uint32_t seq; + }; + + void SendFrame(const Buffer& frame, uint32_t flags, uint32_t rotation); + int GetVideoResolutionForCurrentBitrate(); + + VideoSource* source=NULL; + std::shared_ptr stm; + video::ScreamCongestionController videoCongestionControl; + double firstVideoFrameTime=0.0; + uint32_t videoFrameCount=0; + std::vector sentVideoFrames; + bool videoKeyframeRequested=false; + uint32_t sendVideoPacketID=MessageThread::INVALID_ID; + uint32_t videoPacketLossCount=0; + uint32_t currentVideoBitrate=0; + double lastVideoResolutionChangeTime=0.0; + double sourceChangeTime=0.0; + + std::vector packetsForFEC; + size_t fecFrameCount=0; + uint32_t frameSeq=0; + }; + } +} + +#endif //LIBTGVOIP_VIDEOPACKETSENDER_H diff --git a/TMessagesProj/jni/libtgvoip2/video/VideoRenderer.cpp b/TMessagesProj/jni/libtgvoip2/video/VideoRenderer.cpp new file mode 100644 index 000000000..b97fe83c1 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/VideoRenderer.cpp @@ -0,0 +1,29 @@ +// +// Created by Grishka on 10.08.2018. +// + +#include "VideoRenderer.h" + +#ifdef __ANDROID__ +#include "../os/android/VideoRendererAndroid.h" +#elif defined(__APPLE__) && !defined(TARGET_OSX) +#include "../os/darwin/SampleBufferDisplayLayerRenderer.h" +#endif + +std::vector tgvoip::video::VideoRenderer::GetAvailableDecoders(){ +#ifdef __ANDROID__ + return VideoRendererAndroid::availableDecoders; +#elif defined(__APPLE__) && !defined(TARGET_OSX) + return SampleBufferDisplayLayerRenderer::GetAvailableDecoders(); +#endif + return std::vector(); +} + +int tgvoip::video::VideoRenderer::GetMaximumResolution(){ +#ifdef __ANDROID__ + return VideoRendererAndroid::maxResolution; +#elif defined(__APPLE__) && !defined(TARGET_OSX) + return SampleBufferDisplayLayerRenderer::GetMaximumResolution(); +#endif + return 0; +} diff --git a/TMessagesProj/jni/libtgvoip2/video/VideoRenderer.h b/TMessagesProj/jni/libtgvoip2/video/VideoRenderer.h new file mode 100644 index 000000000..b0f3c847b --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/VideoRenderer.h @@ -0,0 +1,27 @@ +// +// Created by Grishka on 10.08.2018. +// + +#ifndef LIBTGVOIP_VIDEORENDERER_H +#define LIBTGVOIP_VIDEORENDERER_H + +#include +#include "../Buffers.h" + +namespace tgvoip{ + namespace video{ + class VideoRenderer{ + public: + static std::vector GetAvailableDecoders(); + virtual ~VideoRenderer(){}; + virtual void Reset(uint32_t codec, unsigned int width, unsigned int height, std::vector& csd)=0; + virtual void DecodeAndDisplay(Buffer frame, uint32_t pts)=0; + virtual void SetStreamEnabled(bool enabled)=0; + virtual void SetRotation(uint16_t rotation)=0; + virtual void SetStreamPaused(bool paused)=0; + static int GetMaximumResolution(); + }; + } +} + +#endif //LIBTGVOIP_VIDEORENDERER_H diff --git a/TMessagesProj/jni/libtgvoip2/video/VideoSource.cpp b/TMessagesProj/jni/libtgvoip2/video/VideoSource.cpp new file mode 100644 index 000000000..417b83c63 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/VideoSource.cpp @@ -0,0 +1,39 @@ +// +// Created by Grishka on 10.08.2018. +// + +#include "VideoSource.h" + +#ifdef __ANDROID__ +#include "../os/android/VideoSourceAndroid.h" +#elif defined(__APPLE__) && !defined(TARGET_OSX) +#include "../os/darwin/VideoToolboxEncoderSource.h" +#endif + +using namespace tgvoip; +using namespace tgvoip::video; + +std::shared_ptr VideoSource::Create(){ +#ifdef __ANDROID__ + //return std::make_shared(); + return nullptr; +#endif + return nullptr; +} + +bool VideoSource::Failed(){ + return failed; +} + +std::string VideoSource::GetErrorDescription(){ + return error; +} + +std::vector VideoSource::GetAvailableEncoders(){ +#ifdef __ANDROID__ + return VideoSourceAndroid::availableEncoders; +#elif defined(__APPLE__) && !defined(TARGET_OSX) + return VideoToolboxEncoderSource::GetAvailableEncoders(); +#endif + return std::vector(); +} diff --git a/TMessagesProj/jni/libtgvoip2/video/VideoSource.h b/TMessagesProj/jni/libtgvoip2/video/VideoSource.h new file mode 100644 index 000000000..dc8c8b5d5 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/VideoSource.h @@ -0,0 +1,61 @@ +// +// Created by Grishka on 10.08.2018. +// + +#ifndef LIBTGVOIP_VIDEOSOURCE_H +#define LIBTGVOIP_VIDEOSOURCE_H + +#include +#include +#include +#include +#include +#include "../Buffers.h" + +namespace tgvoip{ + namespace video { + class VideoSource{ + public: + virtual ~VideoSource(){}; + static std::shared_ptr Create(); + static std::vector GetAvailableEncoders(); + void SetCallback(std::function callback){ + this->callback=callback; + }; + void SetStreamStateCallback(std::function callback){ + streamStateCallback=callback; + } + virtual void Start()=0; + virtual void Stop()=0; + virtual void Reset(uint32_t codec, int maxResolution)=0; + virtual void RequestKeyFrame()=0; + virtual void SetBitrate(uint32_t bitrate)=0; + bool Failed(); + std::string GetErrorDescription(); + std::vector& GetCodecSpecificData(){ + return csd; + } + unsigned int GetFrameWidth(){ + return width; + } + unsigned int GetFrameHeight(){ + return height; + } + void SetRotation(unsigned int rotation){ + this->rotation=rotation; + } + + protected: + std::function callback; + std::function streamStateCallback; + bool failed; + std::string error; + unsigned int width=0; + unsigned int height=0; + unsigned int rotation=0; + std::vector csd; + }; + } +} + +#endif //LIBTGVOIP_VIDEOSOURCE_H diff --git a/TMessagesProj/jni/libtgvoip2/video/cm256/README.md b/TMessagesProj/jni/libtgvoip2/video/cm256/README.md new file mode 100644 index 000000000..10bfdd027 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/cm256/README.md @@ -0,0 +1,154 @@ +# cm256cc +Fast GF(256) Cauchy MDS Block Erasure Codec in C++ + +This is the rewrite in (as much as possible) clean C++ of [cm256](https://github.com/f4exb/cm256). In some contexts like Qt programs and plugins the original cm256 library does not work. + +cm256cc performance is on par or even better than cm256. This is particularly true for armv7 architecture (Raspberry Pi 2 and 3) and is the most significant with Raspberry Pi 2. + +cm256cc is a simple library for erasure codes. From given data it generates +redundant data that can be used to recover the originals. + +Currently only g++ is supported, other versions of MSVC than Visual Studio 2013 may work. Optimizations for both SSE3 (x86_64) and Neon (armv7) are available. + +The original data should be split up into equally-sized chunks. If one of these chunks +is erased, the redundant data can fill in the gap through decoding. + +The erasure code is parameterized by three values (`OriginalCount`, `RecoveryCount`, `BlockBytes`). These are: + ++ The number of blocks of original data (`OriginalCount`), which must be less than 256. ++ The number of blocks of redundant data (`RecoveryCount`), which must be no more than `256 - OriginalCount`. + +For example, if a file is split into 3 equal pieces and sent over a network, `OriginalCount` is 3. +And if 2 additional redundant packets are generated, `RecoveryCount` is 2. +In this case up to 256 - 3 = 253 additional redundant packets can be generated. + + +##### Building: Quick Setup + +This is a classical cmake project. Make sure cmake and g++ is installed in your system. create a `build` directory and cd into it. If you install the library in a custom location say `opt/install/cm256cc` use the following command line for cmake: + + - `cmake -Wno-dev -DCMAKE_INSTALL_PREFIX=/opt/install/cm256cc ..` + +Result: + + - Library will be installed as `/opt/install/cm256cc/lib/libcm256cc.so` + - Include files will be installed in `/opt/install/cm256cc/include/cm256cc` + - Binary test programs will be installed in `/opt/install/cm256cc/bin` + +##### Building: Use the library + +Include the cm256cc library in your project and cm256.h header in your program. Have a look at example programs `cm256_test.cpp`, `transmit.cpp`and `receive.cpp` in the `unit_test` folder for usage. Consult the `cm256.h header` for details on the encoding / decoding method. + + +## Usage + +Documentation is provided in the header file [cm256.h](https://github.com/catid/cm256/raw/master/cm256.h). + +When your application starts up it should call `isInitialized()` to verify that the library is constructed properly: + +~~~ + #include "cm256.h" + + CM256 cm256; + + if (!cm256.isInitialized()) { + // library not initialized + exit(1); + } +~~~ + +To generate redundancy, use the `cm256_encode` function. To solve for the original data use the `cm256_decode` function. + +Example usage: + +~~~ +bool ExampleFileUsage() +{ + CM256 cm256; + + if (!cm256.isInitialized()) { + // library not initialized + exit(1); + } + + CM256::cm256_encoder_params params; + + // Number of bytes per file block + params.BlockBytes = 4321; + + // Number of blocks + params.OriginalCount = 33; + + // Number of additional recovery blocks generated by encoder + params.RecoveryCount = 12; + + // Size of the original file + static const int OriginalFileBytes = params.OriginalCount * params.BlockBytes; + + // Allocate and fill the original file data + uint8_t* originalFileData = new uint8_t[OriginalFileBytes]; + memset(originalFileData, 1, OriginalFileBytes); + + // Pointers to data + CM256::cm256_block blocks[256]; + for (int i = 0; i < params.OriginalCount; ++i) + { + blocks[i].Block = originalFileData + i * params.BlockBytes; + } + + // Recovery data + uint8_t* recoveryBlocks = new uint8_t[params.RecoveryCount * params.BlockBytes]; + + // Generate recovery data + if (cm256.cm256_encode(params, blocks, recoveryBlocks)) + { + exit(1); + } + + // Initialize the indices + for (int i = 0; i < params.OriginalCount; ++i) + { + blocks[i].Index = CM256::cm256_get_original_block_index(params, i); + } + + //// Simulate loss of data, subsituting a recovery block in its place //// + blocks[0].Block = recoveryBlocks; // First recovery block + blocks[0].Index = cm256_get_recovery_block_index(params, 0); // First recovery block index + //// Simulate loss of data, subsituting a recovery block in its place //// + + if (cm256.cm256_decode(params, blocks)) + { + exit(1); + } + + // blocks[0].Index will now be 0. + + delete[] originalFileData; + delete[] recoveryBlocks; + + return true; +} +~~~ + +The example above is just one way to use the `cm256_decode` function. + +This API was designed to be flexible enough for UDP/IP-based file transfer where +the blocks arrive out of order. + + +#### Comparisons with Other Libraries + +The approach taken in CM256 is similar to the Intel Storage Acceleration Library (ISA-L) available here: + +https://01.org/intel%C2%AE-storage-acceleration-library-open-source-version/downloads + +ISA-L more aggressively optimizes the matrix multiplication operation, which is the most expensive step of encoding. + +CM256 takes better advantage of the m=1 case and the first recovery symbol, which is also possible with the Vandermonde matrices supported by ISA-L. + +ISA-L uses a O(N^3) Gaussian elimination solver for decoding. The CM256 decoder solves the linear system using a fast O(N^2) LDU-decomposition algorithm from "Pivoting and Backward Stability of Fast Algorithms for Solving Cauchy Linear Equations" (T. Boros, T. Kailath, V. Olshevsky), which was hand-optimized for memory accesses. + + +#### Credits + +This software was written entirely by Christopher A. Taylor and converted to clean C++ code by myself Edouard M. Griffiths . diff --git a/TMessagesProj/jni/libtgvoip2/video/cm256/cm256.cpp b/TMessagesProj/jni/libtgvoip2/video/cm256/cm256.cpp new file mode 100644 index 000000000..3af1782cd --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/cm256/cm256.cpp @@ -0,0 +1,571 @@ +/* + C++ version: + Copyright (c) 2016 Edouard M. Griffiths. All rights reserved. + + Copyright (c) 2015 Christopher A. Taylor. All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + * Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + * Neither the name of CM256 nor the names of its contributors may be + used to endorse or promote products derived from this software without + specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE + LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. +*/ + +#include "cm256.h" + +CM256::CM256() +{ + m_initialized = m_gf256Ctx.isInitialized(); +} + +CM256::~CM256() +{ +} + +/* + GF(256) Cauchy Matrix Overview + + As described on Wikipedia, each element of a normal Cauchy matrix is defined as: + + a_ij = 1 / (x_i - y_j) + The arrays x_i and y_j are vector parameters of the matrix. + The values in x_i cannot be reused in y_j. + + Moving beyond the Wikipedia... + + (1) Number of rows (R) is the range of i, and number of columns (C) is the range of j. + + (2) Being able to select x_i and y_j makes Cauchy matrices more flexible in practice + than Vandermonde matrices, which only have one parameter per row. + + (3) Cauchy matrices are always invertible, AKA always full rank, AKA when treated as + as linear system y = M*x, the linear system has a single solution. + + (4) A Cauchy matrix concatenated below a square CxC identity matrix always has rank C, + Meaning that any R rows can be eliminated from the concatenated matrix and the + matrix will still be invertible. This is how Reed-Solomon erasure codes work. + + (5) Any row or column can be multiplied by non-zero values, and the resulting matrix + is still full rank. This is true for any matrix, since it is effectively the same + as pre and post multiplying by diagonal matrices, which are always invertible. + + (6) Matrix elements with a value of 1 are much faster to operate on than other values. + For instance a matrix of [1, 1, 1, 1, 1] is invertible and much faster for various + purposes than [2, 2, 2, 2, 2]. + + (7) For GF(256) matrices, the symbols in x_i and y_j are selected from the numbers + 0...255, and so the number of rows + number of columns may not exceed 256. + Note that values in x_i and y_j may not be reused as stated above. + + In summary, Cauchy matrices + are preferred over Vandermonde matrices. (2) + are great for MDS erasure codes. (3) and (4) + should be optimized to include more 1 elements. (5) and (6) + have a limited size in GF(256), rows+cols <= 256. (7) +*/ + +/* + Selected Cauchy Matrix Form + + The matrix consists of elements a_ij, where i = row, j = column. + a_ij = 1 / (x_i - y_j), where x_i and y_j are sets of GF(256) values + that do not intersect. + + We select x_i and y_j to just be incrementing numbers for the + purposes of this library. Further optimizations may yield matrices + with more 1 elements, but the benefit seems relatively small. + + The x_i values range from 0...(originalCount - 1). + The y_j values range from originalCount...(originalCount + recoveryCount - 1). + + We then improve the Cauchy matrix by dividing each column by the + first row element of that column. The result is an invertible + matrix that has all 1 elements in the first row. This is equivalent + to a rotated Vandermonde matrix, so we could have used one of those. + + The advantage of doing this is that operations involving the first + row will be extremely fast (just memory XOR), so the decoder can + be optimized to take advantage of the shortcut when the first + recovery row can be used. + + First row element of Cauchy matrix for each column: + a_0j = 1 / (x_0 - y_j) = 1 / (x_0 - y_j) + + Our Cauchy matrix sets first row to ones, so: + a_ij = (1 / (x_i - y_j)) / a_0j + a_ij = (y_j - x_0) / (x_i - y_j) + a_ij = (y_j + x_0) div (x_i + y_j) in GF(256) +*/ + +//----------------------------------------------------------------------------- +// Encoding + +void CM256::cm256_encode_block( + cm256_encoder_params params, // Encoder parameters + cm256_block* originals, // Array of pointers to original blocks + int recoveryBlockIndex, // Return value from cm256_get_recovery_block_index() + void* recoveryBlock) // Output recovery block +{ + // If only one block of input data, + if (params.OriginalCount == 1) + { + // No meaningful operation here, degenerate to outputting the same data each time. + + memcpy(recoveryBlock, originals[0].Block, params.BlockBytes); + return; + } + // else OriginalCount >= 2: + + // Unroll first row of recovery matrix: + // The matrix we generate for the first row is all ones, + // so it is merely a parity of the original data. + if (recoveryBlockIndex == params.OriginalCount) + { + gf256_ctx::gf256_addset_mem(recoveryBlock, originals[0].Block, originals[1].Block, params.BlockBytes); + for (int j = 2; j < params.OriginalCount; ++j) + { + gf256_ctx::gf256_add_mem(recoveryBlock, originals[j].Block, params.BlockBytes); + } + return; + } + + // TBD: Faster algorithms seem to exist for computing this matrix-vector product. + + // Start the x_0 values arbitrarily from the original count. + const uint8_t x_0 = static_cast(params.OriginalCount); + + // For other rows: + { + const uint8_t x_i = static_cast(recoveryBlockIndex); + + // Unroll first operation for speed + { + const uint8_t y_0 = 0; + const uint8_t matrixElement = m_gf256Ctx.getMatrixElement(x_i, x_0, y_0); + + m_gf256Ctx.gf256_mul_mem(recoveryBlock, originals[0].Block, matrixElement, params.BlockBytes); + } + + // For each original data column, + for (int j = 1; j < params.OriginalCount; ++j) + { + const uint8_t y_j = static_cast(j); + const uint8_t matrixElement = m_gf256Ctx.getMatrixElement(x_i, x_0, y_j); + + m_gf256Ctx.gf256_muladd_mem(recoveryBlock, matrixElement, originals[j].Block, params.BlockBytes); + } + } +} + +int CM256::cm256_encode( + cm256_encoder_params params, // Encoder params + cm256_block* originals, // Array of pointers to original blocks + void* recoveryBlocks) // Output recovery blocks end-to-end +{ + // Validate input: + if (params.OriginalCount <= 0 || + params.RecoveryCount <= 0 || + params.BlockBytes <= 0) + { + return -1; + } + if (params.OriginalCount + params.RecoveryCount > 256) + { + return -2; + } + if (!originals || !recoveryBlocks) + { + return -3; + } + + uint8_t* recoveryBlock = static_cast(recoveryBlocks); + + for (int block = 0; block < params.RecoveryCount; ++block, recoveryBlock += params.BlockBytes) + { + cm256_encode_block(params, originals, (params.OriginalCount + block), recoveryBlock); + } + + return 0; +} + + +//----------------------------------------------------------------------------- +// Decoding + +CM256::CM256Decoder::CM256Decoder(gf256_ctx& gf256Ctx) : + RecoveryCount(0), + OriginalCount(0), + m_gf256Ctx(gf256Ctx) +{ +} + +CM256::CM256Decoder::~CM256Decoder() +{ +} + +bool CM256::CM256Decoder::Initialize(cm256_encoder_params& params, cm256_block* blocks) +{ + Params = params; + + cm256_block* block = blocks; + OriginalCount = 0; + RecoveryCount = 0; + + // Initialize erasures to zeros + for (int ii = 0; ii < params.OriginalCount; ++ii) + { + ErasuresIndices[ii] = 0; + } + + // For each input block, + for (int ii = 0; ii < params.OriginalCount; ++ii, ++block) + { + int row = block->Index; + + // If it is an original block, + if (row < params.OriginalCount) + { + Original[OriginalCount++] = block; + + if (ErasuresIndices[row] != 0) + { + // Error out if two row indices repeat + return false; + } + + ErasuresIndices[row] = 1; + } + else + { + Recovery[RecoveryCount++] = block; + } + } + + // Identify erasures + for (int ii = 0, indexCount = 0; ii < 256; ++ii) + { + if (!ErasuresIndices[ii]) + { + ErasuresIndices[indexCount] = static_cast( ii ); + + if (++indexCount >= RecoveryCount) + { + break; + } + } + } + + return true; +} + +void CM256::CM256Decoder::DecodeM1() +{ + // XOR all other blocks into the recovery block + uint8_t* outBlock = static_cast(Recovery[0]->Block); + const uint8_t* inBlock = nullptr; + + // For each block, + for (int ii = 0; ii < OriginalCount; ++ii) + { + const uint8_t* inBlock2 = static_cast(Original[ii]->Block); + + if (!inBlock) + { + inBlock = inBlock2; + } + else + { + // outBlock ^= inBlock ^ inBlock2 + gf256_ctx::gf256_add2_mem(outBlock, inBlock, inBlock2, Params.BlockBytes); + inBlock = nullptr; + } + } + + // Complete XORs + if (inBlock) + { + gf256_ctx::gf256_add_mem(outBlock, inBlock, Params.BlockBytes); + } + + // Recover the index it corresponds to + Recovery[0]->Index = ErasuresIndices[0]; +} + +// Generate the LU decomposition of the matrix +void CM256::CM256Decoder::GenerateLDUDecomposition(uint8_t* matrix_L, uint8_t* diag_D, uint8_t* matrix_U) +{ + // Schur-type-direct-Cauchy algorithm 2.5 from + // "Pivoting and Backward Stability of Fast Algorithms for Solving Cauchy Linear Equations" + // T. Boros, T. Kailath, V. Olshevsky + // Modified for practical use. I folded the diagonal parts of U/L matrices into the + // diagonal one to reduce the number of multiplications to perform against the input data, + // and organized the triangle matrices in memory to allow for faster SSE3 GF multiplications. + + // Matrix size NxN + const int N = RecoveryCount; + + // Generators + uint8_t g[256], b[256]; + for (int i = 0; i < N; ++i) + { + g[i] = 1; + b[i] = 1; + } + + // Temporary buffer for rotated row of U matrix + // This allows for faster GF bulk multiplication + uint8_t rotated_row_U[256]; + uint8_t* last_U = matrix_U + ((N - 1) * N) / 2 - 1; + int firstOffset_U = 0; + + // Start the x_0 values arbitrarily from the original count. + const uint8_t x_0 = static_cast(Params.OriginalCount); + + // Unrolling k = 0 just makes it slower for some reason. + for (int k = 0; k < N - 1; ++k) + { + const uint8_t x_k = Recovery[k]->Index; + const uint8_t y_k = ErasuresIndices[k]; + + // D_kk = (x_k + y_k) + // L_kk = g[k] / (x_k + y_k) + // U_kk = b[k] * (x_0 + y_k) / (x_k + y_k) + const uint8_t D_kk = gf256_ctx::gf256_add(x_k, y_k); + const uint8_t L_kk = m_gf256Ctx.gf256_div(g[k], D_kk); + const uint8_t U_kk = m_gf256Ctx.gf256_mul(m_gf256Ctx.gf256_div(b[k], D_kk), gf256_ctx::gf256_add(x_0, y_k)); + + // diag_D[k] = D_kk * L_kk * U_kk + diag_D[k] = m_gf256Ctx.gf256_mul(D_kk, m_gf256Ctx.gf256_mul(L_kk, U_kk)); + + // Computing the k-th row of L and U + uint8_t* row_L = matrix_L; + uint8_t* row_U = rotated_row_U; + for (int j = k + 1; j < N; ++j) + { + const uint8_t x_j = Recovery[j]->Index; + const uint8_t y_j = ErasuresIndices[j]; + + // L_jk = g[j] / (x_j + y_k) + // U_kj = b[j] / (x_k + y_j) + const uint8_t L_jk = m_gf256Ctx.gf256_div(g[j], gf256_ctx::gf256_add(x_j, y_k)); + const uint8_t U_kj = m_gf256Ctx.gf256_div(b[j], gf256_ctx::gf256_add(x_k, y_j)); + + *matrix_L++ = L_jk; + *row_U++ = U_kj; + + // g[j] = g[j] * (x_j + x_k) / (x_j + y_k) + // b[j] = b[j] * (y_j + y_k) / (y_j + x_k) + g[j] = m_gf256Ctx.gf256_mul(g[j], m_gf256Ctx.gf256_div(gf256_ctx::gf256_add(x_j, x_k), gf256_ctx::gf256_add(x_j, y_k))); + b[j] = m_gf256Ctx.gf256_mul(b[j], m_gf256Ctx.gf256_div(gf256_ctx::gf256_add(y_j, y_k), gf256_ctx::gf256_add(y_j, x_k))); + } + + // Do these row/column divisions in bulk for speed. + // L_jk /= L_kk + // U_kj /= U_kk + const int count = N - (k + 1); + m_gf256Ctx.gf256_div_mem(row_L, row_L, L_kk, count); + m_gf256Ctx.gf256_div_mem(rotated_row_U, rotated_row_U, U_kk, count); + + // Copy U matrix row into place in memory. + uint8_t* output_U = last_U + firstOffset_U; + row_U = rotated_row_U; + for (int j = k + 1; j < N; ++j) + { + *output_U = *row_U++; + output_U -= j; + } + firstOffset_U -= k + 2; + } + + // Multiply diagonal matrix into U + uint8_t* row_U = matrix_U; + for (int j = N - 1; j > 0; --j) + { + const uint8_t y_j = ErasuresIndices[j]; + const int count = j; + + m_gf256Ctx.gf256_mul_mem(row_U, row_U, gf256_ctx::gf256_add(x_0, y_j), count); + row_U += count; + } + + const uint8_t x_n = Recovery[N - 1]->Index; + const uint8_t y_n = ErasuresIndices[N - 1]; + + // D_nn = 1 / (x_n + y_n) + // L_nn = g[N-1] + // U_nn = b[N-1] * (x_0 + y_n) + const uint8_t L_nn = g[N - 1]; + const uint8_t U_nn = m_gf256Ctx.gf256_mul(b[N - 1], gf256_ctx::gf256_add(x_0, y_n)); + + // diag_D[N-1] = L_nn * D_nn * U_nn + diag_D[N - 1] = m_gf256Ctx.gf256_div(m_gf256Ctx.gf256_mul(L_nn, U_nn), gf256_ctx::gf256_add(x_n, y_n)); +} + +void CM256::CM256Decoder::Decode() +{ + // Matrix size is NxN, where N is the number of recovery blocks used. + const int N = RecoveryCount; + + // Start the x_0 values arbitrarily from the original count. + const uint8_t x_0 = static_cast(Params.OriginalCount); + + // Eliminate original data from the the recovery rows + for (int originalIndex = 0; originalIndex < OriginalCount; ++originalIndex) + { + const uint8_t* inBlock = static_cast(Original[originalIndex]->Block); + const uint8_t inRow = Original[originalIndex]->Index; + + for (int recoveryIndex = 0; recoveryIndex < N; ++recoveryIndex) + { + uint8_t* outBlock = static_cast(Recovery[recoveryIndex]->Block); + const uint8_t x_i = Recovery[recoveryIndex]->Index; + const uint8_t y_j = inRow; + const uint8_t matrixElement = m_gf256Ctx.getMatrixElement(x_i, x_0, y_j); + + m_gf256Ctx.gf256_muladd_mem(outBlock, matrixElement, inBlock, Params.BlockBytes); + } + } + + // Allocate matrix + static const int StackAllocSize = 2048; + uint8_t stackMatrix[StackAllocSize]; + uint8_t* dynamicMatrix = nullptr; + uint8_t* matrix = stackMatrix; + const int requiredSpace = N * N; + if (requiredSpace > StackAllocSize) + { + dynamicMatrix = new uint8_t[requiredSpace]; + matrix = dynamicMatrix; + } + + /* + Compute matrix decomposition: + + G = L * D * U + + L is lower-triangular, diagonal is all ones. + D is a diagonal matrix. + U is upper-triangular, diagonal is all ones. + */ + uint8_t* matrix_U = matrix; + uint8_t* diag_D = matrix_U + (N - 1) * N / 2; + uint8_t* matrix_L = diag_D + N; + GenerateLDUDecomposition(matrix_L, diag_D, matrix_U); + + /* + Eliminate lower left triangle. + */ + // For each column, + for (int j = 0; j < N - 1; ++j) + { + const void* block_j = Recovery[j]->Block; + + // For each row, + for (int i = j + 1; i < N; ++i) + { + void* block_i = Recovery[i]->Block; + const uint8_t c_ij = *matrix_L++; // Matrix elements are stored column-first, top-down. + + m_gf256Ctx.gf256_muladd_mem(block_i, c_ij, block_j, Params.BlockBytes); + } + } + + /* + Eliminate diagonal. + */ + for (int i = 0; i < N; ++i) + { + void* block = Recovery[i]->Block; + + Recovery[i]->Index = ErasuresIndices[i]; + + m_gf256Ctx.gf256_div_mem(block, block, diag_D[i], Params.BlockBytes); + } + + /* + Eliminate upper right triangle. + */ + for (int j = N - 1; j >= 1; --j) + { + const void* block_j = Recovery[j]->Block; + + for (int i = j - 1; i >= 0; --i) + { + void* block_i = Recovery[i]->Block; + const uint8_t c_ij = *matrix_U++; // Matrix elements are stored column-first, bottom-up. + + m_gf256Ctx.gf256_muladd_mem(block_i, c_ij, block_j, Params.BlockBytes); + } + } + + delete[] dynamicMatrix; +} + +int CM256::cm256_decode( + cm256_encoder_params params, // Encoder params + cm256_block* blocks) // Array of 'originalCount' blocks as described above +{ + if (params.OriginalCount <= 0 || + params.RecoveryCount <= 0 || + params.BlockBytes <= 0) + { + return -1; + } + if (params.OriginalCount + params.RecoveryCount > 256) + { + return -2; + } + if (!blocks) + { + return -3; + } + + // If there is only one block, + if (params.OriginalCount == 1) + { + // It is the same block repeated + blocks[0].Index = 0; + return 0; + } + + CM256Decoder state(m_gf256Ctx); + if (!state.Initialize(params, blocks)) + { + return -5; + } + + // If nothing is erased, + if (state.RecoveryCount <= 0) + { + return 0; + } + + // If m=1, + if (params.RecoveryCount == 1) + { + state.DecodeM1(); + return 0; + } + + // Decode for m>1 + state.Decode(); + return 0; +} diff --git a/TMessagesProj/jni/libtgvoip2/video/cm256/cm256.h b/TMessagesProj/jni/libtgvoip2/video/cm256/cm256.h new file mode 100644 index 000000000..5a977d404 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/cm256/cm256.h @@ -0,0 +1,200 @@ +/* + C++ version: + Copyright (c) 2016 Edouard M. Griffiths. All rights reserved. + + Copyright (c) 2015 Christopher A. Taylor. All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + * Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + * Neither the name of CM256 nor the names of its contributors may be + used to endorse or promote products derived from this software without + specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE + LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. +*/ + +#ifndef CM256_H +#define CM256_H + +#include +#include "gf256.h" +#include "export.h" + +class CM256CC_API CM256 +{ +public: + // Encoder parameters + typedef struct cm256_encoder_params_t { + // Original block count < 256 + int OriginalCount; + + // Recovery block count < 256 + int RecoveryCount; + + // Number of bytes per block (all blocks are the same size in bytes) + int BlockBytes; + } cm256_encoder_params; + + // Descriptor for data block + typedef struct cm256_block_t { + // Pointer to data received. + void* Block; + + // Block index. + // For original data, it will be in the range + // [0..(originalCount-1)] inclusive. + // For recovery data, the first one's Index must be originalCount, + // and it will be in the range + // [originalCount..(originalCount+recoveryCount-1)] inclusive. + unsigned char Index; + // Ignored during encoding, required during decoding. + } cm256_block; + + CM256(); + ~CM256(); + + bool isInitialized() const { return m_initialized; }; + + /* + * Cauchy MDS GF(256) encode + * + * This produces a set of recovery blocks that should be transmitted after the + * original data blocks. + * + * It takes in 'originalCount' equal-sized blocks and produces 'recoveryCount' + * equally-sized recovery blocks. + * + * The input 'originals' array allows more natural usage of the library. + * The output recovery blocks are stored end-to-end in 'recoveryBlocks'. + * 'recoveryBlocks' should have recoveryCount * blockBytes bytes available. + * + * Precondition: originalCount + recoveryCount <= 256 + * + * When transmitting the data, the block index of the data should be sent, + * and the recovery block index is also needed. The decoder should also + * be provided with the values of originalCount, recoveryCount and blockBytes. + * + * Example wire format: + * [originalCount(1 byte)] [recoveryCount(1 byte)] + * [blockIndex(1 byte)] [blockData(blockBytes bytes)] + * + * Be careful not to mix blocks from different encoders. + * + * It is possible to support variable-length data by including the original + * data length at the front of each message in 2 bytes, such that when it is + * recovered after a loss the data length is available in the block data and + * the remaining bytes of padding can be neglected. + * + * Returns 0 on success, and any other code indicates failure. + */ + int cm256_encode( + cm256_encoder_params params, // Encoder parameters + cm256_block* originals, // Array of pointers to original blocks + void* recoveryBlocks); // Output recovery blocks end-to-end + + /* + * Cauchy MDS GF(256) decode + * + * This recovers the original data from the recovery data in the provided + * blocks. There should be 'originalCount' blocks in the provided array. + * Recovery will always be possible if that many blocks are received. + * + * Provide the same values for 'originalCount', 'recoveryCount', and + * 'blockBytes' used by the encoder. + * + * The block Index should be set to the block index of the original data, + * as described in the cm256_block struct comments above. + * + * Recovery blocks will be replaced with original data and the Index + * will be updated to indicate the original block that was recovered. + * + * Returns 0 on success, and any other code indicates failure. + */ + int cm256_decode( + cm256_encoder_params params, // Encoder parameters + cm256_block* blocks); // Array of 'originalCount' blocks as described above + + /* + * Commodity functions + */ + + // Compute the value to put in the Index member of cm256_block + static inline unsigned char cm256_get_recovery_block_index(cm256_encoder_params params, int recoveryBlockIndex) + { + assert(recoveryBlockIndex >= 0 && recoveryBlockIndex < params.RecoveryCount); + return (unsigned char)(params.OriginalCount + recoveryBlockIndex); + } + static inline unsigned char cm256_get_original_block_index(cm256_encoder_params params, int originalBlockIndex) + { + (void) params; + assert(originalBlockIndex >= 0 && originalBlockIndex < params.OriginalCount); + return (unsigned char)(originalBlockIndex); + } + +private: + class CM256CC_API CM256Decoder + { + public: + CM256Decoder(gf256_ctx& gf256Ctx); + ~CM256Decoder(); + + // Encode parameters + cm256_encoder_params Params; + + // Recovery blocks + cm256_block* Recovery[256]; + int RecoveryCount; + + // Original blocks + cm256_block* Original[256]; + int OriginalCount; + + // Row indices that were erased + uint8_t ErasuresIndices[256]; + + // Initialize the decoder + bool Initialize(cm256_encoder_params& params, cm256_block* blocks); + + // Decode m=1 case + void DecodeM1(); + + // Decode for m>1 case + void Decode(); + + // Generate the LU decomposition of the matrix + void GenerateLDUDecomposition(uint8_t* matrix_L, uint8_t* diag_D, uint8_t* matrix_U); + + private: + gf256_ctx& m_gf256Ctx; + }; + + // Encode one block. + // Note: This function does not validate input, use with care. + void cm256_encode_block( + cm256_encoder_params params, // Encoder parameters + cm256_block* originals, // Array of pointers to original blocks + int recoveryBlockIndex, // Return value from cm256_get_recovery_block_index() + void* recoveryBlock); // Output recovery block + + gf256_ctx m_gf256Ctx; + bool m_initialized; +}; + + +#endif // CM256_H diff --git a/TMessagesProj/jni/libtgvoip2/video/cm256/export.h b/TMessagesProj/jni/libtgvoip2/video/cm256/export.h new file mode 100644 index 000000000..363145f44 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/cm256/export.h @@ -0,0 +1,45 @@ +/////////////////////////////////////////////////////////////////////////////////// +// Copyright (C) 2018 Edouard Griffiths, F4EXB. // +// // +// This program 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 as version 3 of the License, or // +// // +// This program 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 V3 for more details. // +// // +// You should have received a copy of the GNU General Public License // +// along with this program. If not, see . // +/////////////////////////////////////////////////////////////////////////////////// + +#ifndef __CM256CC_EXPORT_H +#define __CM256CC_EXPORT_H + +#if defined (__GNUC__) && (__GNUC__ >= 4) +# define __CM256CC_EXPORT __attribute__((visibility("default"))) +# define __CM256CC_IMPORT __attribute__((visibility("default"))) + +#elif defined (_MSC_VER) +# define __CM256CC_EXPORT __declspec(dllexport) +# define __CM256CC_IMPORT __declspec(dllimport) + +#else +# define __CM256CC_EXPORT +# define __CM256CC_IMPORT +#endif + +/* The 'CM256CC_API' controls the import/export of 'sdrbase' symbols and classes. + */ +#if !defined(cm256cc_STATIC) +# if defined cm256cc_EXPORTS +# define CM256CC_API __CM256CC_EXPORT +# else +# define CM256CC_API __CM256CC_IMPORT +# endif +#else +# define CM256CC_API +#endif + +#endif // __CM256CC_EXPORT_H \ No newline at end of file diff --git a/TMessagesProj/jni/libtgvoip2/video/cm256/gf256.cpp b/TMessagesProj/jni/libtgvoip2/video/cm256/gf256.cpp new file mode 100644 index 000000000..241227f92 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/cm256/gf256.cpp @@ -0,0 +1,764 @@ +/* + Copyright (c) 2015 Christopher A. Taylor. All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + * Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + * Neither the name of CM256 nor the names of its contributors may be + used to endorse or promote products derived from this software without + specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE + LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. +*/ + +#include +#include + +#include "gf256.h" + +const uint8_t gf256_ctx::GF256_GEN_POLY[GF256_GEN_POLY_COUNT] = { + 0x8e, 0x95, 0x96, 0xa6, 0xaf, 0xb1, 0xb2, 0xb4, + 0xb8, 0xc3, 0xc6, 0xd4, 0xe1, 0xe7, 0xf3, 0xfa, + }; + +gf256_ctx::gf256_ctx() : + initialized(false) +{ + gf256_init_(); +} + +gf256_ctx::~gf256_ctx() +{ +} + +// Select which polynomial to use +void gf256_ctx::gf255_poly_init(int polynomialIndex) +{ + if (polynomialIndex < 0 || polynomialIndex >= GF256_GEN_POLY_COUNT) + { + polynomialIndex = 0; + } + + Polynomial = (GF256_GEN_POLY[polynomialIndex] << 1) | 1; +} + + +//----------------------------------------------------------------------------- +// Exponential and Log Tables + +// Construct EXP and LOG tables from polynomial +void gf256_ctx::gf256_explog_init() +{ + unsigned poly = Polynomial; + uint8_t* exptab = GF256_EXP_TABLE; + uint16_t* logtab = GF256_LOG_TABLE; + + logtab[0] = 512; + exptab[0] = 1; + for (unsigned jj = 1; jj < 255; ++jj) + { + unsigned next = (unsigned)exptab[jj - 1] * 2; + if (next >= 256) next ^= poly; + + exptab[jj] = static_cast( next ); + logtab[exptab[jj]] = static_cast( jj ); + } + + exptab[255] = exptab[0]; + logtab[exptab[255]] = 255; + + for (unsigned jj = 256; jj < 2 * 255; ++jj) + { + exptab[jj] = exptab[jj % 255]; + } + + exptab[2 * 255] = 1; + + for (unsigned jj = 2 * 255 + 1; jj < 4 * 255; ++jj) + { + exptab[jj] = 0; + } +} + + +//----------------------------------------------------------------------------- +// Multiply and Divide Tables + +// Initialize MUL and DIV tables using LOG and EXP tables +void gf256_ctx::gf256_muldiv_init() +{ + // Allocate table memory 65KB x 2 + uint8_t* m = GF256_MUL_TABLE; + uint8_t* d = GF256_DIV_TABLE; + + // Unroll y = 0 subtable + for (int x = 0; x < 256; ++x) + { + m[x] = d[x] = 0; + } + + // For each other y value, + for (int y = 1; y < 256; ++y) + { + // Calculate log(y) for mult and 255 - log(y) for div + const uint8_t log_y = static_cast(GF256_LOG_TABLE[y]); + const uint8_t log_yn = 255 - log_y; + + // Next subtable + m += 256; + d += 256; + + // Unroll x = 0 + m[0] = 0; + d[0] = 0; + + // Calculate x * y, x / y + for (int x = 1; x < 256; ++x) + { + uint16_t log_x = GF256_LOG_TABLE[x]; + + m[x] = GF256_EXP_TABLE[log_x + log_y]; + d[x] = GF256_EXP_TABLE[log_x + log_yn]; + } + } +} + + +//----------------------------------------------------------------------------- +// Inverse Table + +// Initialize INV table using DIV table +void gf256_ctx::gf256_inv_init() +{ + for (int x = 0; x < 256; ++x) + { + GF256_INV_TABLE[x] = gf256_div(1, static_cast(x)); + } +} + + +//----------------------------------------------------------------------------- +// Multiply and Add Memory Tables + +/* + Fast algorithm to compute m[1..8] = a[1..8] * b in GF(256) + using SSE3 SIMD instruction set: + + Consider z = x * y in GF(256). + This operation can be performed bit-by-bit. Usefully, the partial product + of each bit is combined linearly with the rest. This means that the 8-bit + number x can be split into its high and low 4 bits, and partial products + can be formed from each half. Then the halves can be linearly combined: + + z = x[0..3] * y + x[4..7] * y + + The multiplication of each half can be done efficiently via table lookups, + and the addition in GF(256) is XOR. There must be two tables that map 16 + input elements for the low or high 4 bits of x to the two partial products. + Each value for y has a different set of two tables: + + z = TABLE_LO_y(x[0..3]) xor TABLE_HI_y(x[4..7]) + + This means that we need 16 * 2 * 256 = 8192 bytes for precomputed tables. + + Computing z[] = x[] * y can be performed 16 bytes at a time by using the + 128-bit register operations supported by modern processors. + + This is efficiently realized in SSE3 using the _mm_shuffle_epi8() function + provided by Visual Studio 2010 or newer in . This function + uses the low bits to do a table lookup on each byte. Unfortunately the + high bit of each mask byte has the special feature that it clears the + output byte when it is set, so we need to make sure it's cleared by masking + off the high bit of each byte before using it: + + clr_mask = _mm_set1_epi8(0x0f) = 0x0f0f0f0f0f0f0f0f0f0f0f0f0f0f0f0f + + For the low half of the partial product, clear the high bit of each byte + and perform the table lookup: + + p_lo = _mm_and_si128(x, clr_mask) + p_lo = _mm_shuffle_epi8(p_lo, TABLE_LO_y) + + For the high half of the partial product, shift the high 4 bits of each + byte into the low 4 bits and clear the high bit of each byte, and then + perform the table lookup: + + p_hi = _mm_srli_epi64(x, 4) + p_hi = _mm_and_si128(p_hi, clr_mask) + p_hi = _mm_shuffle_epi8(p_hi, TABLE_HI_y) + + Finally add the two partial products to form the product, recalling that + addition is XOR in a Galois field: + + result = _mm_xor_si128(p_lo, p_hi) + + This crunches 16 bytes of x at a time, and the result can be stored in z. +*/ + +/* + Intrinsic reference: + + SSE3, VS2010+, tmmintrin.h: + + GF256_M128 _mm_shuffle_epi8(GF256_M128 a, GF256_M128 mask); + Emits the Supplemental Streaming SIMD Extensions 3 (SSSE3) instruction pshufb. This instruction shuffles 16-byte parameters from a 128-bit parameter. + + Pseudo-code for PSHUFB (with 128 bit operands): + + for i = 0 to 15 { + if (SRC[(i * 8)+7] = 1 ) then + DEST[(i*8)+7..(i*8)+0] <- 0; + else + index[3..0] <- SRC[(i*8)+3 .. (i*8)+0]; + DEST[(i*8)+7..(i*8)+0] <- DEST[(index*8+7)..(index*8+0)]; + endif + } + + SSE2, VS2008+, emmintrin.h: + + GF256_M128 _mm_slli_epi64 (GF256_M128 a, int count); + Shifts the 2 signed or unsigned 64-bit integers in a left by count bits while shifting in zeros. + GF256_M128 _mm_srli_epi64 (GF256_M128 a, int count); + Shifts the 2 signed or unsigned 64-bit integers in a right by count bits while shifting in zeros. + GF256_M128 _mm_set1_epi8 (char b); + Sets the 16 signed 8-bit integer values to b. + GF256_M128 _mm_and_si128 (GF256_M128 a, GF256_M128 b); + Computes the bitwise AND of the 128-bit value in a and the 128-bit value in b. + GF256_M128 _mm_xor_si128 ( GF256_M128 a, GF256_M128 b); + Computes the bitwise XOR of the 128-bit value in a and the 128-bit value in b. +*/ + +// Initialize the MM256 tables using gf256_mul() +void gf256_ctx::gf256_muladd_mem_init() +{ + for (int y = 0; y < 256; ++y) + { + uint8_t lo[16], hi[16]; + + // TABLE_LO_Y maps 0..15 to 8-bit partial product based on y. + for (unsigned char x = 0; x < 16; ++x) + { + lo[x] = gf256_mul(x, static_cast( y )); + hi[x] = gf256_mul(x << 4, static_cast( y )); + } + + const GF256_M128 table_lo = _mm_set_epi8( + lo[15], lo[14], lo[13], lo[12], lo[11], lo[10], lo[9], lo[8], + lo[7], lo[6], lo[5], lo[4], lo[3], lo[2], lo[1], lo[0]); + const GF256_M128 table_hi = _mm_set_epi8( + hi[15], hi[14], hi[13], hi[12], hi[11], hi[10], hi[9], hi[8], + hi[7], hi[6], hi[5], hi[4], hi[3], hi[2], hi[1], hi[0]); + _mm_store_si128(MM256_TABLE_LO_Y + y, table_lo); + _mm_store_si128(MM256_TABLE_HI_Y + y, table_hi); + } +} + +//----------------------------------------------------------------------------- +// Initialization +// +// Initialize a context, filling in the tables. +// +// Thread-safety / Usage Notes: +// +// It is perfectly safe and encouraged to use a gf256_ctx object from multiple +// threads. The gf256_init() is relatively expensive and should only be done +// once, though it will take less than a millisecond. +// +// The gf256_ctx object must be aligned to 16 byte boundary. +// Simply tag the object with GF256_ALIGNED to achieve this. +// +// Example: +// static GF256_ALIGNED gf256_ctx TheGF256Context; +// gf256_init(&TheGF256Context, 0); +// +// Returns 0 on success and other values on failure. + +int gf256_ctx::gf256_init_() +{ + // Avoid multiple initialization + if (initialized) + { + return 0; + } + + if (!IsLittleEndian()) + { + fprintf(stderr, "gf256_ctx::gf256_init_: Little Endian architecture expected (code won't work without mods)\n"); + return -2; + } + + gf255_poly_init(DefaultPolynomialIndex); + gf256_explog_init(); + gf256_muldiv_init(); + gf256_inv_init(); + gf256_muladd_mem_init(); + + initialized = true; + fprintf(stderr, "gf256_ctx::gf256_init_: initialized\n"); + return 0; +} + +//----------------------------------------------------------------------------- +// Operations with context + +void gf256_ctx::gf256_mul_mem(void * GF256_RESTRICT vz, const void * GF256_RESTRICT vx, uint8_t y, int bytes) +{ + // Use a single if-statement to handle special cases + if (y <= 1) + { + if (y == 0) + { + memset(vz, 0, bytes); + } + return; + } + + // Partial product tables; see above + const GF256_M128 table_lo_y = _mm_load_si128(MM256_TABLE_LO_Y + y); + const GF256_M128 table_hi_y = _mm_load_si128(MM256_TABLE_HI_Y + y); + + // clr_mask = 0x0f0f0f0f0f0f0f0f0f0f0f0f0f0f0f0f + const GF256_M128 clr_mask = _mm_set1_epi8(0x0f); + + GF256_M128 * GF256_RESTRICT z16 = reinterpret_cast(vz); + const GF256_M128 * GF256_RESTRICT x16 = reinterpret_cast(vx); + + // Handle multiples of 16 bytes + while (bytes >= 16) + { + // See above comments for details + GF256_M128 x0 = _mm_loadu_si128(x16); + GF256_M128 l0 = _mm_and_si128(x0, clr_mask); + x0 = _mm_srli_epi64(x0, 4); + GF256_M128 h0 = _mm_and_si128(x0, clr_mask); + l0 = _mm_shuffle_epi8(table_lo_y, l0); + h0 = _mm_shuffle_epi8(table_hi_y, h0); + _mm_storeu_si128(z16, _mm_xor_si128(l0, h0)); + + x16++; + z16++; + bytes -= 16; + } + + uint8_t * GF256_RESTRICT z8 = reinterpret_cast(z16); + const uint8_t * GF256_RESTRICT x8 = reinterpret_cast(x16); + const uint8_t * GF256_RESTRICT table = GF256_MUL_TABLE + ((unsigned)y << 8); + + // Handle a block of 8 bytes + if (bytes >= 8) + { + uint64_t word = table[x8[0]]; + word |= (uint64_t)table[x8[1]] << 8; + word |= (uint64_t)table[x8[2]] << 16; + word |= (uint64_t)table[x8[3]] << 24; + word |= (uint64_t)table[x8[4]] << 32; + word |= (uint64_t)table[x8[5]] << 40; + word |= (uint64_t)table[x8[6]] << 48; + word |= (uint64_t)table[x8[7]] << 56; + *(uint64_t*)z8 = word; + + x8 += 8; + z8 += 8; + bytes -= 8; + } + + // Handle a block of 4 bytes + if (bytes >= 4) + { + uint32_t word = table[x8[0]]; + word |= (uint32_t)table[x8[1]] << 8; + word |= (uint32_t)table[x8[2]] << 16; + word |= (uint32_t)table[x8[3]] << 24; + *(uint32_t*)z8 = word; + + x8 += 4; + z8 += 4; + bytes -= 4; + } + + // Handle single bytes + for (int i = bytes; i > 0; i--) { + z8[i-1] = table[x8[i-1]]; + } +} + +void gf256_ctx::gf256_muladd_mem(void * GF256_RESTRICT vz, uint8_t y, const void * GF256_RESTRICT vx, int bytes) +{ + // Use a single if-statement to handle special cases + if (y <= 1) + { + if (y == 1) + { + gf256_add_mem(vz, vx, bytes); + } + return; + } + + // Partial product tables; see above + const GF256_M128 table_lo_y = _mm_load_si128(MM256_TABLE_LO_Y + y); + const GF256_M128 table_hi_y = _mm_load_si128(MM256_TABLE_HI_Y + y); + + // clr_mask = 0x0f0f0f0f0f0f0f0f0f0f0f0f0f0f0f0f + const GF256_M128 clr_mask = _mm_set1_epi8(0x0f); + + GF256_M128 * GF256_RESTRICT z16 = reinterpret_cast(vz); + const GF256_M128 * GF256_RESTRICT x16 = reinterpret_cast(vx); + + // Handle multiples of 16 bytes + while (bytes >= 16) + { + // See above comments for details + GF256_M128 x0 = _mm_loadu_si128(x16); + GF256_M128 l0 = _mm_and_si128(x0, clr_mask); + x0 = _mm_srli_epi64(x0, 4); + GF256_M128 h0 = _mm_and_si128(x0, clr_mask); + l0 = _mm_shuffle_epi8(table_lo_y, l0); + h0 = _mm_shuffle_epi8(table_hi_y, h0); + const GF256_M128 p0 = _mm_xor_si128(l0, h0); + const GF256_M128 z0 = _mm_loadu_si128(z16); + _mm_storeu_si128(z16, _mm_xor_si128(p0, z0)); + + x16++; + z16++; + bytes -= 16; + } + + uint8_t * GF256_RESTRICT z8 = reinterpret_cast(z16); + const uint8_t * GF256_RESTRICT x8 = reinterpret_cast(x16); + const uint8_t * GF256_RESTRICT table = GF256_MUL_TABLE + ((unsigned)y << 8); + + // Handle a block of 8 bytes + if (bytes >= 8) + { + uint64_t word = table[x8[0]]; + word |= (uint64_t)table[x8[1]] << 8; + word |= (uint64_t)table[x8[2]] << 16; + word |= (uint64_t)table[x8[3]] << 24; + word |= (uint64_t)table[x8[4]] << 32; + word |= (uint64_t)table[x8[5]] << 40; + word |= (uint64_t)table[x8[6]] << 48; + word |= (uint64_t)table[x8[7]] << 56; + *(uint64_t*)z8 ^= word; + + x8 += 8; + z8 += 8; + bytes -= 8; + } + + // Handle a block of 4 bytes + if (bytes >= 4) + { + uint32_t word = table[x8[0]]; + word |= (uint32_t)table[x8[1]] << 8; + word |= (uint32_t)table[x8[2]] << 16; + word |= (uint32_t)table[x8[3]] << 24; + *(uint32_t*)z8 ^= word; + + x8 += 4; + z8 += 4; + bytes -= 4; + } + + // Handle single bytes + for (int i = bytes; i > 0; i--) { + z8[i-1] ^= table[x8[i-1]]; + } +} + +//----------------------------------------------------------------------------- +// Static operations + +void gf256_ctx::gf256_add_mem(void * GF256_RESTRICT vx, const void * GF256_RESTRICT vy, int bytes) +{ + GF256_M128 * GF256_RESTRICT x16 = reinterpret_cast(vx); + const GF256_M128 * GF256_RESTRICT y16 = reinterpret_cast(vy); + + // Handle multiples of 64 bytes + while (bytes >= 64) + { + GF256_M128 x0 = _mm_loadu_si128(x16); + GF256_M128 x1 = _mm_loadu_si128(x16 + 1); + GF256_M128 x2 = _mm_loadu_si128(x16 + 2); + GF256_M128 x3 = _mm_loadu_si128(x16 + 3); + GF256_M128 y0 = _mm_loadu_si128(y16); + GF256_M128 y1 = _mm_loadu_si128(y16 + 1); + GF256_M128 y2 = _mm_loadu_si128(y16 + 2); + GF256_M128 y3 = _mm_loadu_si128(y16 + 3); + + _mm_storeu_si128(x16, + _mm_xor_si128(x0, y0)); + _mm_storeu_si128(x16 + 1, + _mm_xor_si128(x1, y1)); + _mm_storeu_si128(x16 + 2, + _mm_xor_si128(x2, y2)); + _mm_storeu_si128(x16 + 3, + _mm_xor_si128(x3, y3)); + + x16 += 4; + y16 += 4; + bytes -= 64; + } + + // Handle multiples of 16 bytes + while (bytes >= 16) + { + // x[i] = x[i] xor y[i] + _mm_storeu_si128(x16, + _mm_xor_si128( + _mm_loadu_si128(x16), + _mm_loadu_si128(y16))); + + x16++; + y16++; + bytes -= 16; + } + + uint8_t * GF256_RESTRICT x1 = reinterpret_cast(x16); + const uint8_t * GF256_RESTRICT y1 = reinterpret_cast(y16); + + // Handle a block of 8 bytes + if (bytes >= 8) + { + uint64_t * GF256_RESTRICT x8 = reinterpret_cast(x1); + const uint64_t * GF256_RESTRICT y8 = reinterpret_cast(y1); + *x8 ^= *y8; + + x1 += 8; + y1 += 8; + bytes -= 8; + } + + // Handle a block of 4 bytes + if (bytes >= 4) + { + uint32_t * GF256_RESTRICT x4 = reinterpret_cast(x1); + const uint32_t * GF256_RESTRICT y4 = reinterpret_cast(y1); + *x4 ^= *y4; + + x1 += 4; + y1 += 4; + bytes -= 4; + } + + // Handle final bytes + for (int i = bytes; i > 0; i--) { + x1[i-1] ^= y1[i-1]; + } +} + +void gf256_ctx::gf256_add2_mem(void * GF256_RESTRICT vz, const void * GF256_RESTRICT vx, const void * GF256_RESTRICT vy, int bytes) +{ + GF256_M128 * GF256_RESTRICT z16 = reinterpret_cast(vz); + const GF256_M128 * GF256_RESTRICT x16 = reinterpret_cast(vx); + const GF256_M128 * GF256_RESTRICT y16 = reinterpret_cast(vy); + + // Handle multiples of 16 bytes + while (bytes >= 16) + { + // z[i] = x[i] xor y[i] + _mm_storeu_si128(z16, + _mm_xor_si128( + _mm_loadu_si128(z16), + _mm_xor_si128( + _mm_loadu_si128(x16), + _mm_loadu_si128(y16)))); + + x16++; + y16++; + z16++; + bytes -= 16; + } + + uint8_t * GF256_RESTRICT z1 = reinterpret_cast(z16); + const uint8_t * GF256_RESTRICT x1 = reinterpret_cast(x16); + const uint8_t * GF256_RESTRICT y1 = reinterpret_cast(y16); + + // Handle a block of 8 bytes + if (bytes >= 8) + { + uint64_t * GF256_RESTRICT z8 = reinterpret_cast(z1); + const uint64_t * GF256_RESTRICT x8 = reinterpret_cast(x1); + const uint64_t * GF256_RESTRICT y8 = reinterpret_cast(y1); + *z8 ^= *x8 ^ *y8; + + x1 += 8; + y1 += 8; + z1 += 8; + bytes -= 8; + } + + // Handle a block of 4 bytes + if (bytes >= 4) + { + uint32_t * GF256_RESTRICT z4 = reinterpret_cast(z1); + const uint32_t * GF256_RESTRICT x4 = reinterpret_cast(x1); + const uint32_t * GF256_RESTRICT y4 = reinterpret_cast(y1); + *z4 ^= *x4 ^ *y4; + + x1 += 4; + y1 += 4; + z1 += 4; + bytes -= 4; + } + + // Handle final bytes + for (int i = bytes; i > 0; i--) { + z1[i-1] ^= x1[i-1] ^ y1[i-1]; + } +} + +void gf256_ctx::gf256_addset_mem(void * GF256_RESTRICT vz, const void * GF256_RESTRICT vx, const void * GF256_RESTRICT vy, int bytes) +{ + GF256_M128 * GF256_RESTRICT z16 = reinterpret_cast(vz); + const GF256_M128 * GF256_RESTRICT x16 = reinterpret_cast(vx); + const GF256_M128 * GF256_RESTRICT y16 = reinterpret_cast(vy); + + // Handle multiples of 64 bytes + while (bytes >= 64) + { + GF256_M128 x0 = _mm_loadu_si128(x16); + GF256_M128 x1 = _mm_loadu_si128(x16 + 1); + GF256_M128 x2 = _mm_loadu_si128(x16 + 2); + GF256_M128 x3 = _mm_loadu_si128(x16 + 3); + GF256_M128 y0 = _mm_loadu_si128(y16); + GF256_M128 y1 = _mm_loadu_si128(y16 + 1); + GF256_M128 y2 = _mm_loadu_si128(y16 + 2); + GF256_M128 y3 = _mm_loadu_si128(y16 + 3); + + _mm_storeu_si128(z16, _mm_xor_si128(x0, y0)); + _mm_storeu_si128(z16 + 1, _mm_xor_si128(x1, y1)); + _mm_storeu_si128(z16 + 2, _mm_xor_si128(x2, y2)); + _mm_storeu_si128(z16 + 3, _mm_xor_si128(x3, y3)); + + x16 += 4; + y16 += 4; + z16 += 4; + bytes -= 64; + } + + // Handle multiples of 16 bytes + while (bytes >= 16) + { + // z[i] = x[i] xor y[i] + _mm_storeu_si128(z16, + _mm_xor_si128( + _mm_loadu_si128(x16), + _mm_loadu_si128(y16))); + + x16++; + y16++; + z16++; + bytes -= 16; + } + + uint8_t * GF256_RESTRICT z1 = reinterpret_cast(z16); + const uint8_t * GF256_RESTRICT x1 = reinterpret_cast(x16); + const uint8_t * GF256_RESTRICT y1 = reinterpret_cast(y16); + + // Handle a block of 8 bytes + if (bytes >= 8) + { + uint64_t * GF256_RESTRICT z8 = reinterpret_cast(z1); + const uint64_t * GF256_RESTRICT x8 = reinterpret_cast(x1); + const uint64_t * GF256_RESTRICT y8 = reinterpret_cast(y1); + *z8 = *x8 ^ *y8; + + x1 += 8; + y1 += 8; + z1 += 8; + bytes -= 8; + } + + // Handle a block of 4 bytes + if (bytes >= 4) + { + uint32_t * GF256_RESTRICT z4 = reinterpret_cast(z1); + const uint32_t * GF256_RESTRICT x4 = reinterpret_cast(x1); + const uint32_t * GF256_RESTRICT y4 = reinterpret_cast(y1); + *z4 = *x4 ^ *y4; + + x1 += 4; + y1 += 4; + z1 += 4; + bytes -= 4; + } + + // Handle final bytes + for (int i = bytes; i > 0; i--) { + z1[i-1] = x1[i-1] ^ y1[i-1]; + } +} + +void gf256_memswap(void * GF256_RESTRICT vx, void * GF256_RESTRICT vy, int bytes) +{ + GF256_M128 * GF256_RESTRICT x16 = reinterpret_cast(vx); + GF256_M128 * GF256_RESTRICT y16 = reinterpret_cast(vy); + + // Handle blocks of 16 bytes + while (bytes >= 16) + { + GF256_M128 x0 = _mm_loadu_si128(x16); + GF256_M128 y0 = _mm_loadu_si128(y16); + _mm_storeu_si128(x16, y0); + _mm_storeu_si128(y16, x0); + + bytes -= 16; + ++x16; + ++y16; + } + + uint8_t * GF256_RESTRICT x1 = reinterpret_cast(x16); + uint8_t * GF256_RESTRICT y1 = reinterpret_cast(y16); + + // Handle a block of 8 bytes + if (bytes >= 8) + { + uint64_t * GF256_RESTRICT x8 = reinterpret_cast(x1); + uint64_t * GF256_RESTRICT y8 = reinterpret_cast(y1); + + uint64_t temp = *x8; + *x8 = *y8; + *y8 = temp; + + x1 += 8; + y1 += 8; + bytes -= 8; + } + + // Handle a block of 4 bytes + if (bytes >= 4) + { + uint32_t * GF256_RESTRICT x4 = reinterpret_cast(x1); + uint32_t * GF256_RESTRICT y4 = reinterpret_cast(y1); + + uint32_t temp = *x4; + *x4 = *y4; + *y4 = temp; + + x1 += 4; + y1 += 4; + bytes -= 4; + } + + // Handle final bytes + uint8_t temp; + + for (int i = bytes; i > 0; i--) { + temp = x1[i-1]; x1[i-1] = y1[i-1]; y1[i-1] = temp; + } +} diff --git a/TMessagesProj/jni/libtgvoip2/video/cm256/gf256.h b/TMessagesProj/jni/libtgvoip2/video/cm256/gf256.h new file mode 100644 index 000000000..a9bf98dd2 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/cm256/gf256.h @@ -0,0 +1,240 @@ +/* + Copyright (c) 2015 Christopher A. Taylor. All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + * Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright notice, + this list of conditions and the following disclaimer in the documentation + and/or other materials provided with the distribution. + * Neither the name of CM256 nor the names of its contributors may be + used to endorse or promote products derived from this software without + specific prior written permission. + + THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE + LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. +*/ + +#ifndef GF256_H +#define GF256_H + +#include // uint32_t etc +#include // memcpy, memset +#include "export.h" + +// TBD: Fix the polynomial at one value and use precomputed tables here to +// simplify the API for GF256.h version 2. Avoids user data alignment issues. + + +//----------------------------------------------------------------------------- +// Platform-Specific Definitions +// +// Edit these to port to your architecture + +#if defined(USE_SSSE3) + +#ifdef _MSC_VER + + // Compiler-specific 128-bit SIMD register keyword + #define GF256_M128 __m128i + + // Compiler-specific C++11 restrict keyword + #define GF256_RESTRICT_KW __restrict + + // Compiler-specific force inline keyword + #define GF256_FORCE_INLINE __forceinline + + // Compiler-specific alignment keyword + #define GF256_ALIGNED __declspec(align(16)) + + // Compiler-specific SSE headers + #include // SSE3: _mm_shuffle_epi8 + #include // SSE2 + +#else + + // Compiler-specific 128-bit SIMD register keyword + #define GF256_M128 __m128i + + // Compiler-specific C++11 restrict keyword + #define GF256_RESTRICT_KW __restrict__ + + // Compiler-specific force inline keyword + #define GF256_FORCE_INLINE __attribute__((always_inline)) inline + + // Compiler-specific alignment keyword + #define GF256_ALIGNED __attribute__((aligned(16))) + + // Compiler-specific SSE headers + #include + +#endif + +#elif defined(USE_NEON) + + #include "sse2neon.h" + + // Compiler-specific 128-bit SIMD register keyword + #define GF256_M128 __m128i + + // Compiler-specific C++11 restrict keyword + #define GF256_RESTRICT_KW __restrict__ + + // Compiler-specific force inline keyword + #define GF256_FORCE_INLINE __attribute__((always_inline)) inline + + // Compiler-specific alignment keyword + #define GF256_ALIGNED __attribute__((aligned(16))) + +#endif + +#if defined(NO_RESTRICT) + #define GF256_RESTRICT +#else + #define GF256_RESTRICT GF256_RESTRICT_KW +#endif + +#ifndef nullptr + #define nullptr NULL +#endif + +//----------------------------------------------------------------------------- +// GF(256) Context +// +// The context object stores tables required to perform library calculations. +// +// Usage Notes: +// This struct should be aligned in memory, meaning that a pointer to it should +// have the low 4 bits cleared. To achieve this simply tag the gf256_ctx object +// with the GF256_ALIGNED macro provided above. + +#ifdef _MSC_VER + #pragma warning(push) + #pragma warning(disable: 4324) // warning C4324: 'gf256_ctx' : structure was padded due to __declspec(align()) +#endif + +class CM256CC_API gf256_ctx // 141,072 bytes +{ +public: + gf256_ctx(); + ~gf256_ctx(); + + bool isInitialized() const { return initialized; } + + /** Performs "x[] += y[]" bulk memory XOR operation */ + static void gf256_add_mem(void * GF256_RESTRICT vx, const void * GF256_RESTRICT vy, int bytes); + /** Performs "z[] += x[] + y[]" bulk memory operation */ + static void gf256_add2_mem(void * GF256_RESTRICT vz, const void * GF256_RESTRICT vx, const void * GF256_RESTRICT vy, int bytes); + /** Performs "z[] = x[] + y[]" bulk memory operation */ + static void gf256_addset_mem(void * GF256_RESTRICT vz, const void * GF256_RESTRICT vx, const void * GF256_RESTRICT vy, int bytes); + /** Swap two memory buffers in-place */ + static void gf256_memswap(void * GF256_RESTRICT vx, void * GF256_RESTRICT vy, int bytes); + + // return x + y + static GF256_FORCE_INLINE uint8_t gf256_add(const uint8_t x, const uint8_t y) + { + return x ^ y; + } + + // return x * y + // For repeated multiplication by a constant, it is faster to put the constant in y. + GF256_FORCE_INLINE uint8_t gf256_mul(uint8_t x, uint8_t y) + { + return GF256_MUL_TABLE[((unsigned)y << 8) + x]; + } + + // return x / y + // Memory-access optimized for constant divisors in y. + GF256_FORCE_INLINE uint8_t gf256_div(uint8_t x, uint8_t y) + { + return GF256_DIV_TABLE[((unsigned)y << 8) + x]; + } + + // return 1 / x + GF256_FORCE_INLINE uint8_t gf256_inv(uint8_t x) + { + return GF256_INV_TABLE[x]; + } + + // This function generates each matrix element based on x_i, x_0, y_j + // Note that for x_i == x_0, this will return 1, so it is better to unroll out the first row. + GF256_FORCE_INLINE unsigned char getMatrixElement(const unsigned char x_i, const unsigned char x_0, const unsigned char y_j) + { + return gf256_div(gf256_add(y_j, x_0), gf256_add(x_i, y_j)); + } + + /** Performs "z[] = x[] * y" bulk memory operation */ + void gf256_mul_mem(void * GF256_RESTRICT vz, const void * GF256_RESTRICT vx, uint8_t y, int bytes); + /** Performs "z[] += x[] * y" bulk memory operation */ + void gf256_muladd_mem(void * GF256_RESTRICT vz, uint8_t y, const void * GF256_RESTRICT vx, int bytes); + + /** Performs "x[] /= y" bulk memory operation */ + GF256_FORCE_INLINE void gf256_div_mem(void * GF256_RESTRICT vz, + const void * GF256_RESTRICT vx, uint8_t y, int bytes) + { + gf256_mul_mem(vz, vx, GF256_INV_TABLE[y], bytes); // Multiply by inverse + } + + // Polynomial used + unsigned Polynomial; + + // Log/Exp tables + uint16_t GF256_LOG_TABLE[256]; + uint8_t GF256_EXP_TABLE[512 * 2 + 1]; + + // Mul/Div/Inv tables + uint8_t GF256_MUL_TABLE[256 * 256]; + uint8_t GF256_DIV_TABLE[256 * 256]; + uint8_t GF256_INV_TABLE[256]; + + // Muladd_mem tables + // We require memory to be aligned since the SIMD instructions benefit from + // aligned accesses to the MM256_* table data. + GF256_ALIGNED GF256_M128 MM256_TABLE_LO_Y[256]; + GF256_ALIGNED GF256_M128 MM256_TABLE_HI_Y[256]; + +private: + int gf256_init_(); + + void gf255_poly_init(int polynomialIndex); //!< Select which polynomial to use + void gf256_explog_init(); //!< Construct EXP and LOG tables from polynomial + void gf256_muldiv_init(); //!< Initialize MUL and DIV tables using LOG and EXP tables + void gf256_inv_init(); //!< Initialize INV table using DIV table + void gf256_muladd_mem_init(); //!< Initialize the MM256 tables using gf256_mul() + + static bool IsLittleEndian() + { + int x = 1; + char *y = (char *) &x; + + return *y != 0; + } + + //----------------------------------------------------------------------------- + // Generator Polynomial + + // There are only 16 irreducible polynomials for GF(256) + static const int GF256_GEN_POLY_COUNT = 16; + static const uint8_t GF256_GEN_POLY[GF256_GEN_POLY_COUNT]; + static const int DefaultPolynomialIndex = 3; + + bool initialized; +}; + +#ifdef _MSC_VER + #pragma warning(pop) +#endif + + +#endif // GF256_H diff --git a/TMessagesProj/jni/libtgvoip2/video/cm256/sse2neon.h b/TMessagesProj/jni/libtgvoip2/video/cm256/sse2neon.h new file mode 100644 index 000000000..469741682 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/video/cm256/sse2neon.h @@ -0,0 +1,1014 @@ +#ifndef SSE2NEON_H_ +#define SSE2NEON_H_ + +#ifndef SSE2NEON_H +#define SSE2NEON_H + +// This header file provides a simple API translation layer +// between SSE intrinsics to their corresponding ARM NEON versions +// +// This header file does not (yet) translate *all* of the SSE intrinsics. +// Since this is in support of a specific porting effort, I have only +// included the intrinsics I needed to get my port to work. +// +// Questions/Comments/Feedback send to: jratcliffscarab@gmail.com +// +// If you want to improve or add to this project, send me an +// email and I will probably approve your access to the depot. +// +// Project is located here: +// +// https://github.com/jratcliff63367/sse2neon +// +// Show your appreciation for open source by sending me a bitcoin tip to the following +// address. +// +// TipJar: 1PzgWDSyq4pmdAXRH8SPUtta4SWGrt4B1p : +// https://blockchain.info/address/1PzgWDSyq4pmdAXRH8SPUtta4SWGrt4B1p +// +// +// Contributors to this project are: +// +// John W. Ratcliff : jratcliffscarab@gmail.com +// Brandon Rowlett : browlett@nvidia.com +// Ken Fast : kfast@gdeb.com +// +// +/* +** The MIT license: +** +** Permission is hereby granted, MEMALLOC_FREE of charge, to any person obtaining a copy +** of this software and associated documentation files (the "Software"), to deal +** in the Software without restriction, including without limitation the rights +** to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +** copies of the Software, and to permit persons to whom the Software is furnished +** to do so, subject to the following conditions: +** +** The above copyright notice and this permission notice shall be included in all +** copies or substantial portions of the Software. + +** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +** IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +** FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +** AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, +** WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN +** CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +*/ + +#define GCC 1 +#define ENABLE_CPP_VERSION 0 + +#if GCC +#define FORCE_INLINE inline __attribute__((always_inline)) +#else +#define FORCE_INLINE inline +#endif + +#include "arm_neon.h" + +/*******************************************************/ +/* MACRO for shuffle parameter for _mm_shuffle_ps(). */ +/* Argument fp3 is a digit[0123] that represents the fp*/ +/* from argument "b" of mm_shuffle_ps that will be */ +/* placed in fp3 of result. fp2 is the same for fp2 in */ +/* result. fp1 is a digit[0123] that represents the fp */ +/* from argument "a" of mm_shuffle_ps that will be */ +/* places in fp1 of result. fp0 is the same for fp0 of */ +/* result */ +/*******************************************************/ +#define _MM_SHUFFLE(fp3,fp2,fp1,fp0) (((fp3) << 6) | ((fp2) << 4) | \ + ((fp1) << 2) | ((fp0))) + +typedef float32x4_t __m128; +typedef int32x4_t __m128i; + +// ****************************************** +// Set/get methods +// ****************************************** + +// Sets the 128-bit value to zero https://msdn.microsoft.com/en-us/library/vstudio/ys7dw0kh(v=vs.100).aspx +FORCE_INLINE __m128i _mm_setzero_si128() +{ + return vdupq_n_s32(0); +} + +// Clears the four single-precision, floating-point values. https://msdn.microsoft.com/en-us/library/vstudio/tk1t2tbz(v=vs.100).aspx +FORCE_INLINE __m128 _mm_setzero_ps(void) +{ + return vdupq_n_f32(0); +} + +// Sets the four single-precision, floating-point values to w. https://msdn.microsoft.com/en-us/library/vstudio/2x1se8ha(v=vs.100).aspx +FORCE_INLINE __m128 _mm_set1_ps(float _w) +{ + return vdupq_n_f32(_w); +} + +// Sets the four single-precision, floating-point values to w. https://msdn.microsoft.com/en-us/library/vstudio/2x1se8ha(v=vs.100).aspx +FORCE_INLINE __m128 _mm_set_ps1(float _w) +{ + return vdupq_n_f32(_w); +} + +// Sets the four single-precision, floating-point values to the four inputs. https://msdn.microsoft.com/en-us/library/vstudio/afh0zf75(v=vs.100).aspx +FORCE_INLINE __m128 _mm_set_ps(float w, float z, float y, float x) +{ + float __attribute__((aligned(16))) data[4] = { x, y, z, w }; + return vld1q_f32(data); +} + +// Sets the four single-precision, floating-point values to the four inputs in reverse order. https://msdn.microsoft.com/en-us/library/vstudio/d2172ct3(v=vs.100).aspx +FORCE_INLINE __m128 _mm_setr_ps(float w, float z , float y , float x ) +{ + float __attribute__ ((aligned (16))) data[4] = { w, z, y, x }; + return vld1q_f32(data); +} + +// Sets the 4 signed 32-bit integer values to i. https://msdn.microsoft.com/en-us/library/vstudio/h4xscxat(v=vs.100).aspx +FORCE_INLINE __m128i _mm_set1_epi32(int _i) +{ + return vdupq_n_s32(_i); +} + +// Sets the 4 signed 32-bit integer values. https://msdn.microsoft.com/en-us/library/vstudio/019beekt(v=vs.100).aspx +FORCE_INLINE __m128i _mm_set_epi32(int i3, int i2, int i1, int i0) +{ + int32_t __attribute__((aligned(16))) data[4] = { i0, i1, i2, i3 }; + return vld1q_s32(data); +} + +// Stores four single-precision, floating-point values. https://msdn.microsoft.com/en-us/library/vstudio/s3h4ay6y(v=vs.100).aspx +FORCE_INLINE void _mm_store_ps(float *p, __m128 a) +{ + vst1q_f32(p, a); +} + +// Stores four single-precision, floating-point values. https://msdn.microsoft.com/en-us/library/44e30x22(v=vs.100).aspx +FORCE_INLINE void _mm_storeu_ps(float *p, __m128 a) +{ + vst1q_f32(p, a); +} + +// Stores four 32-bit integer values as (as a __m128i value) at the address p. https://msdn.microsoft.com/en-us/library/vstudio/edk11s13(v=vs.100).aspx +FORCE_INLINE void _mm_store_si128(__m128i *p, __m128i a ) +{ + vst1q_s32((int32_t*) p,a); +} + +// Stores the lower single - precision, floating - point value. https://msdn.microsoft.com/en-us/library/tzz10fbx(v=vs.100).aspx +FORCE_INLINE void _mm_store_ss(float *p, __m128 a) +{ + vst1q_lane_f32(p, a, 0); +} + +// Reads the lower 64 bits of b and stores them into the lower 64 bits of a. https://msdn.microsoft.com/en-us/library/hhwf428f%28v=vs.90%29.aspx +FORCE_INLINE void _mm_storel_epi64(__m128i* a, __m128i b) +{ + *a = (__m128i)vsetq_lane_s64((int64_t)vget_low_s32(b), *(int64x2_t*)a, 0); +} + +// Loads a single single-precision, floating-point value, copying it into all four words https://msdn.microsoft.com/en-us/library/vstudio/5cdkf716(v=vs.100).aspx +FORCE_INLINE __m128 _mm_load1_ps(const float * p) +{ + return vld1q_dup_f32(p); +} + +// Loads four single-precision, floating-point values. https://msdn.microsoft.com/en-us/library/vstudio/zzd50xxt(v=vs.100).aspx +FORCE_INLINE __m128 _mm_load_ps(const float * p) +{ + return vld1q_f32(p); +} + +// Loads four single-precision, floating-point values. https://msdn.microsoft.com/en-us/library/x1b16s7z%28v=vs.90%29.aspx +FORCE_INLINE __m128 _mm_loadu_ps(const float * p) +{ + // for neon, alignment doesn't matter, so _mm_load_ps and _mm_loadu_ps are equivalent for neon + return vld1q_f32(p); +} + +// Loads an single - precision, floating - point value into the low word and clears the upper three words. https://msdn.microsoft.com/en-us/library/548bb9h4%28v=vs.90%29.aspx +FORCE_INLINE __m128 _mm_load_ss(const float * p) +{ + __m128 result = vdupq_n_f32(0); + return vsetq_lane_f32(*p, result, 0); +} + + +// ****************************************** +// Logic/Binary operations +// ****************************************** + +// Compares for inequality. https://msdn.microsoft.com/en-us/library/sf44thbx(v=vs.100).aspx +FORCE_INLINE __m128 _mm_cmpneq_ps(__m128 a, __m128 b) +{ + return (__m128)vmvnq_s32((__m128i)vceqq_f32(a, b)); +} + +// Computes the bitwise AND-NOT of the four single-precision, floating-point values of a and b. https://msdn.microsoft.com/en-us/library/vstudio/68h7wd02(v=vs.100).aspx +FORCE_INLINE __m128 _mm_andnot_ps(__m128 a, __m128 b) +{ + return (__m128)vbicq_s32((__m128i)b, (__m128i)a); // *NOTE* argument swap +} + +// Computes the bitwise AND of the 128-bit value in b and the bitwise NOT of the 128-bit value in a. https://msdn.microsoft.com/en-us/library/vstudio/1beaceh8(v=vs.100).aspx +FORCE_INLINE __m128i _mm_andnot_si128(__m128i a, __m128i b) +{ + return (__m128i)vbicq_s32(b, a); // *NOTE* argument swap +} + +// Computes the bitwise AND of the 128-bit value in a and the 128-bit value in b. https://msdn.microsoft.com/en-us/library/vstudio/6d1txsa8(v=vs.100).aspx +FORCE_INLINE __m128i _mm_and_si128(__m128i a, __m128i b) +{ + return (__m128i)vandq_s32(a, b); +} + +// Computes the bitwise AND of the four single-precision, floating-point values of a and b. https://msdn.microsoft.com/en-us/library/vstudio/73ck1xc5(v=vs.100).aspx +FORCE_INLINE __m128 _mm_and_ps(__m128 a, __m128 b) +{ + return (__m128)vandq_s32((__m128i)a, (__m128i)b); +} + +// Computes the bitwise OR of the four single-precision, floating-point values of a and b. https://msdn.microsoft.com/en-us/library/vstudio/7ctdsyy0(v=vs.100).aspx +FORCE_INLINE __m128 _mm_or_ps(__m128 a, __m128 b) +{ + return (__m128)vorrq_s32((__m128i)a, (__m128i)b); +} + +// Computes bitwise EXOR (exclusive-or) of the four single-precision, floating-point values of a and b. https://msdn.microsoft.com/en-us/library/ss6k3wk8(v=vs.100).aspx +FORCE_INLINE __m128 _mm_xor_ps(__m128 a, __m128 b) +{ + return (__m128)veorq_s32((__m128i)a, (__m128i)b); +} + +// Computes the bitwise OR of the 128-bit value in a and the 128-bit value in b. https://msdn.microsoft.com/en-us/library/vstudio/ew8ty0db(v=vs.100).aspx +FORCE_INLINE __m128i _mm_or_si128(__m128i a, __m128i b) +{ + return (__m128i)vorrq_s32(a, b); +} + +// Computes the bitwise XOR of the 128-bit value in a and the 128-bit value in b. https://msdn.microsoft.com/en-us/library/fzt08www(v=vs.100).aspx +FORCE_INLINE __m128i _mm_xor_si128(__m128i a, __m128i b) +{ + return veorq_s32(a, b); +} + +// NEON does not provide this method +// Creates a 4-bit mask from the most significant bits of the four single-precision, floating-point values. https://msdn.microsoft.com/en-us/library/vstudio/4490ys29(v=vs.100).aspx +FORCE_INLINE int _mm_movemask_ps(__m128 a) +{ +#if ENABLE_CPP_VERSION // I am not yet convinced that the NEON version is faster than the C version of this + uint32x4_t &ia = *(uint32x4_t *)&a; + return (ia[0] >> 31) | ((ia[1] >> 30) & 2) | ((ia[2] >> 29) & 4) | ((ia[3] >> 28) & 8); +#else + static const uint32x4_t movemask = { 1, 2, 4, 8 }; + static const uint32x4_t highbit = { 0x80000000, 0x80000000, 0x80000000, 0x80000000 }; + uint32x4_t t0 = vreinterpretq_u32_f32(a); + uint32x4_t t1 = vtstq_u32(t0, highbit); + uint32x4_t t2 = vandq_u32(t1, movemask); + uint32x2_t t3 = vorr_u32(vget_low_u32(t2), vget_high_u32(t2)); + return vget_lane_u32(t3, 0) | vget_lane_u32(t3, 1); +#endif +} + +// Takes the upper 64 bits of a and places it in the low end of the result +// Takes the lower 64 bits of b and places it into the high end of the result. +FORCE_INLINE __m128 _mm_shuffle_ps_1032(__m128 a, __m128 b) +{ + return vcombine_f32(vget_high_f32(a), vget_low_f32(b)); +} + +// takes the lower two 32-bit values from a and swaps them and places in high end of result +// takes the higher two 32 bit values from b and swaps them and places in low end of result. +FORCE_INLINE __m128 _mm_shuffle_ps_2301(__m128 a, __m128 b) +{ + return vcombine_f32(vrev64_f32(vget_low_f32(a)), vrev64_f32(vget_high_f32(b))); +} + +// keeps the low 64 bits of b in the low and puts the high 64 bits of a in the high +FORCE_INLINE __m128 _mm_shuffle_ps_3210(__m128 a, __m128 b) +{ + return vcombine_f32(vget_low_f32(a), vget_high_f32(b)); +} + +FORCE_INLINE __m128 _mm_shuffle_ps_0011(__m128 a, __m128 b) +{ + return vcombine_f32(vdup_n_f32(vgetq_lane_f32(a, 1)), vdup_n_f32(vgetq_lane_f32(b, 0))); +} + +FORCE_INLINE __m128 _mm_shuffle_ps_0022(__m128 a, __m128 b) +{ + return vcombine_f32(vdup_n_f32(vgetq_lane_f32(a, 2)), vdup_n_f32(vgetq_lane_f32(b, 0))); +} + +FORCE_INLINE __m128 _mm_shuffle_ps_2200(__m128 a, __m128 b) +{ + return vcombine_f32(vdup_n_f32(vgetq_lane_f32(a, 0)), vdup_n_f32(vgetq_lane_f32(b, 2))); +} + +FORCE_INLINE __m128 _mm_shuffle_ps_3202(__m128 a, __m128 b) +{ + float32_t a0 = vgetq_lane_f32(a, 0); + float32_t a2 = vgetq_lane_f32(a, 2); + float32x2_t aVal = vdup_n_f32(a2); + aVal = vset_lane_f32(a0, aVal, 1); + return vcombine_f32(aVal, vget_high_f32(b)); +} + +FORCE_INLINE __m128 _mm_shuffle_ps_1133(__m128 a, __m128 b) +{ + return vcombine_f32(vdup_n_f32(vgetq_lane_f32(a, 3)), vdup_n_f32(vgetq_lane_f32(b, 1))); +} + +FORCE_INLINE __m128 _mm_shuffle_ps_2010(__m128 a, __m128 b) +{ + float32_t b0 = vgetq_lane_f32(b, 0); + float32_t b2 = vgetq_lane_f32(b, 2); + float32x2_t bVal = vdup_n_f32(b0); + bVal = vset_lane_f32(b2, bVal, 1); + return vcombine_f32(vget_low_f32(a), bVal); +} + +FORCE_INLINE __m128 _mm_shuffle_ps_2001(__m128 a, __m128 b) +{ + float32_t b0 = vgetq_lane_f32(b, 0); + float32_t b2 = vgetq_lane_f32(b, 2); + float32x2_t bVal = vdup_n_f32(b0); + bVal = vset_lane_f32(b2, bVal, 1); + return vcombine_f32(vrev64_f32(vget_low_f32(a)), bVal); +} + +FORCE_INLINE __m128 _mm_shuffle_ps_2032(__m128 a, __m128 b) +{ + float32_t b0 = vgetq_lane_f32(b, 0); + float32_t b2 = vgetq_lane_f32(b, 2); + float32x2_t bVal = vdup_n_f32(b0); + bVal = vset_lane_f32(b2, bVal, 1); + return vcombine_f32(vget_high_f32(a), bVal); +} + + +// NEON does not support a general purpose permute intrinsic +// Currently I am not sure whether the C implementation is faster or slower than the NEON version. +// Note, this has to be expanded as a template because the shuffle value must be an immediate value. +// The same is true on SSE as well. +// Selects four specific single-precision, floating-point values from a and b, based on the mask i. https://msdn.microsoft.com/en-us/library/vstudio/5f0858x0(v=vs.100).aspx +template +FORCE_INLINE __m128 _mm_shuffle_ps_default(__m128 a, __m128 b) +{ +#if ENABLE_CPP_VERSION // I am not convinced that the NEON version is faster than the C version yet. + __m128 ret; + ret[0] = a[i & 0x3]; + ret[1] = a[(i >> 2) & 0x3]; + ret[2] = b[(i >> 4) & 0x03]; + ret[3] = b[(i >> 6) & 0x03]; + return ret; +#else + __m128 ret = vmovq_n_f32(vgetq_lane_f32(a, i & 0x3)); + ret = vsetq_lane_f32(vgetq_lane_f32(a, (i >> 2) & 0x3), ret, 1); + ret = vsetq_lane_f32(vgetq_lane_f32(b, (i >> 4) & 0x3), ret, 2); + ret = vsetq_lane_f32(vgetq_lane_f32(b, (i >> 6) & 0x3), ret, 3); + return ret; +#endif +} + +template +FORCE_INLINE __m128 _mm_shuffle_ps_function(__m128 a, __m128 b) +{ + switch (i) + { + case _MM_SHUFFLE(1, 0, 3, 2): return _mm_shuffle_ps_1032(a, b); break; + case _MM_SHUFFLE(2, 3, 0, 1): return _mm_shuffle_ps_2301(a, b); break; + case _MM_SHUFFLE(3, 2, 1, 0): return _mm_shuffle_ps_3210(a, b); break; + case _MM_SHUFFLE(0, 0, 1, 1): return _mm_shuffle_ps_0011(a, b); break; + case _MM_SHUFFLE(0, 0, 2, 2): return _mm_shuffle_ps_0022(a, b); break; + case _MM_SHUFFLE(2, 2, 0, 0): return _mm_shuffle_ps_2200(a, b); break; + case _MM_SHUFFLE(3, 2, 0, 2): return _mm_shuffle_ps_3202(a, b); break; + case _MM_SHUFFLE(1, 1, 3, 3): return _mm_shuffle_ps_1133(a, b); break; + case _MM_SHUFFLE(2, 0, 1, 0): return _mm_shuffle_ps_2010(a, b); break; + case _MM_SHUFFLE(2, 0, 0, 1): return _mm_shuffle_ps_2001(a, b); break; + case _MM_SHUFFLE(2, 0, 3, 2): return _mm_shuffle_ps_2032(a, b); break; + default: _mm_shuffle_ps_default(a, b); + } +} + +#define _mm_shuffle_ps(a,b,i) _mm_shuffle_ps_function(a,b) + +// Takes the upper 64 bits of a and places it in the low end of the result +// Takes the lower 64 bits of b and places it into the high end of the result. +FORCE_INLINE __m128i _mm_shuffle_epi_1032(__m128i a, __m128i b) +{ + return vcombine_s32(vget_high_s32(a), vget_low_s32(b)); +} + +// takes the lower two 32-bit values from a and swaps them and places in low end of result +// takes the higher two 32 bit values from b and swaps them and places in high end of result. +FORCE_INLINE __m128i _mm_shuffle_epi_2301(__m128i a, __m128i b) +{ + return vcombine_s32(vrev64_s32(vget_low_s32(a)), vrev64_s32(vget_high_s32(b))); +} + +// shift a right by 32 bits, and put the lower 32 bits of a into the upper 32 bits of b +// when a and b are the same, rotates the least significant 32 bits into the most signficant 32 bits, and shifts the rest down +FORCE_INLINE __m128i _mm_shuffle_epi_0321(__m128i a, __m128i b) +{ + return vextq_s32(a, b, 1); +} + +// shift a left by 32 bits, and put the upper 32 bits of b into the lower 32 bits of a +// when a and b are the same, rotates the most significant 32 bits into the least signficant 32 bits, and shifts the rest up +FORCE_INLINE __m128i _mm_shuffle_epi_2103(__m128i a, __m128i b) +{ + return vextq_s32(a, b, 3); +} + +// gets the lower 64 bits of a, and places it in the upper 64 bits +// gets the lower 64 bits of b and places it in the lower 64 bits +FORCE_INLINE __m128i _mm_shuffle_epi_1010(__m128i a, __m128i b) +{ + return vcombine_s32(vget_low_s32(a), vget_low_s32(b)); +} + +// gets the lower 64 bits of a, and places it in the upper 64 bits +// gets the lower 64 bits of b, swaps the 0 and 1 elements, and places it in the lower 64 bits +FORCE_INLINE __m128i _mm_shuffle_epi_1001(__m128i a, __m128i b) +{ + return vcombine_s32(vrev64_s32(vget_low_s32(a)), vget_low_s32(b)); +} + +// gets the lower 64 bits of a, swaps the 0 and 1 elements and places it in the upper 64 bits +// gets the lower 64 bits of b, swaps the 0 and 1 elements, and places it in the lower 64 bits +FORCE_INLINE __m128i _mm_shuffle_epi_0101(__m128i a, __m128i b) +{ + return vcombine_s32(vrev64_s32(vget_low_s32(a)), vrev64_s32(vget_low_s32(b))); +} + +FORCE_INLINE __m128i _mm_shuffle_epi_2211(__m128i a, __m128i b) +{ + return vcombine_s32(vdup_n_s32(vgetq_lane_s32(a, 1)), vdup_n_s32(vgetq_lane_s32(b, 2))); +} + +FORCE_INLINE __m128i _mm_shuffle_epi_0122(__m128i a, __m128i b) +{ + return vcombine_s32(vdup_n_s32(vgetq_lane_s32(a, 2)), vrev64_s32(vget_low_s32(b))); +} + +FORCE_INLINE __m128i _mm_shuffle_epi_3332(__m128i a, __m128i b) +{ + return vcombine_s32(vget_high_s32(a), vdup_n_s32(vgetq_lane_s32(b, 3))); +} + +template +FORCE_INLINE __m128i _mm_shuffle_epi32_default(__m128i a, __m128i b) +{ +#if ENABLE_CPP_VERSION + __m128i ret; + ret[0] = a[i & 0x3]; + ret[1] = a[(i >> 2) & 0x3]; + ret[2] = b[(i >> 4) & 0x03]; + ret[3] = b[(i >> 6) & 0x03]; + return ret; +#else + __m128i ret = vmovq_n_s32(vgetq_lane_s32(a, i & 0x3)); + ret = vsetq_lane_s32(vgetq_lane_s32(a, (i >> 2) & 0x3), ret, 1); + ret = vsetq_lane_s32(vgetq_lane_s32(b, (i >> 4) & 0x3), ret, 2); + ret = vsetq_lane_s32(vgetq_lane_s32(b, (i >> 6) & 0x3), ret, 3); + return ret; +#endif +} + +template +FORCE_INLINE __m128i _mm_shuffle_epi32_function(__m128i a, __m128i b) +{ + switch (i) + { + case _MM_SHUFFLE(1, 0, 3, 2): return _mm_shuffle_epi_1032(a, b); break; + case _MM_SHUFFLE(2, 3, 0, 1): return _mm_shuffle_epi_2301(a, b); break; + case _MM_SHUFFLE(0, 3, 2, 1): return _mm_shuffle_epi_0321(a, b); break; + case _MM_SHUFFLE(2, 1, 0, 3): return _mm_shuffle_epi_2103(a, b); break; + case _MM_SHUFFLE(1, 0, 1, 0): return _mm_shuffle_epi_1010(a, b); break; + case _MM_SHUFFLE(1, 0, 0, 1): return _mm_shuffle_epi_1001(a, b); break; + case _MM_SHUFFLE(0, 1, 0, 1): return _mm_shuffle_epi_0101(a, b); break; + case _MM_SHUFFLE(2, 2, 1, 1): return _mm_shuffle_epi_2211(a, b); break; + case _MM_SHUFFLE(0, 1, 2, 2): return _mm_shuffle_epi_0122(a, b); break; + case _MM_SHUFFLE(3, 3, 3, 2): return _mm_shuffle_epi_3332(a, b); break; + default: return _mm_shuffle_epi32_default(a, b); + } +} + +template +FORCE_INLINE __m128i _mm_shuffle_epi32_splat(__m128i a) +{ + return vdupq_n_s32(vgetq_lane_s32(a, i)); +} + +template +FORCE_INLINE __m128i _mm_shuffle_epi32_single(__m128i a) +{ + switch (i) + { + case _MM_SHUFFLE(0, 0, 0, 0): return _mm_shuffle_epi32_splat<0>(a); break; + case _MM_SHUFFLE(1, 1, 1, 1): return _mm_shuffle_epi32_splat<1>(a); break; + case _MM_SHUFFLE(2, 2, 2, 2): return _mm_shuffle_epi32_splat<2>(a); break; + case _MM_SHUFFLE(3, 3, 3, 3): return _mm_shuffle_epi32_splat<3>(a); break; + default: return _mm_shuffle_epi32_function(a, a); + } +} + +// Shuffles the 4 signed or unsigned 32-bit integers in a as specified by imm. https://msdn.microsoft.com/en-us/library/56f67xbk%28v=vs.90%29.aspx +#define _mm_shuffle_epi32(a,i) _mm_shuffle_epi32_single(a) + +template +FORCE_INLINE __m128i _mm_shufflehi_epi16_function(__m128i a) +{ + int16x8_t ret = (int16x8_t)a; + int16x4_t highBits = vget_high_s16(ret); + ret = vsetq_lane_s16(vget_lane_s16(highBits, i & 0x3), ret, 4); + ret = vsetq_lane_s16(vget_lane_s16(highBits, (i >> 2) & 0x3), ret, 5); + ret = vsetq_lane_s16(vget_lane_s16(highBits, (i >> 4) & 0x3), ret, 6); + ret = vsetq_lane_s16(vget_lane_s16(highBits, (i >> 6) & 0x3), ret, 7); + return (__m128i)ret; +} + +// Shuffles the upper 4 signed or unsigned 16 - bit integers in a as specified by imm. https://msdn.microsoft.com/en-us/library/13ywktbs(v=vs.100).aspx +#define _mm_shufflehi_epi16(a,i) _mm_shufflehi_epi16_function(a) + +// Shifts the 4 signed or unsigned 32-bit integers in a left by count bits while shifting in zeros. : https://msdn.microsoft.com/en-us/library/z2k3bbtb%28v=vs.90%29.aspx +#define _mm_slli_epi32(a, imm) (__m128i)vshlq_n_s32(a,imm) + +//Shifts the 4 signed or unsigned 32-bit integers in a right by count bits while shifting in zeros. https://msdn.microsoft.com/en-us/library/w486zcfa(v=vs.100).aspx +#define _mm_srli_epi32( a, imm ) (__m128i)vshrq_n_u32((uint32x4_t)a, imm) + +// Shifts the 4 signed 32 - bit integers in a right by count bits while shifting in the sign bit. https://msdn.microsoft.com/en-us/library/z1939387(v=vs.100).aspx +#define _mm_srai_epi32( a, imm ) vshrq_n_s32(a, imm) + +// Shifts the 128 - bit value in a right by imm bytes while shifting in zeros.imm must be an immediate. https://msdn.microsoft.com/en-us/library/305w28yz(v=vs.100).aspx +//#define _mm_srli_si128( a, imm ) (__m128i)vmaxq_s8((int8x16_t)a, vextq_s8((int8x16_t)a, vdupq_n_s8(0), imm)) +#define _mm_srli_si128( a, imm ) (__m128i)vextq_s8((int8x16_t)a, vdupq_n_s8(0), (imm)) + +// Shifts the 128-bit value in a left by imm bytes while shifting in zeros. imm must be an immediate. https://msdn.microsoft.com/en-us/library/34d3k2kt(v=vs.100).aspx +#define _mm_slli_si128( a, imm ) (__m128i)vextq_s8(vdupq_n_s8(0), (int8x16_t)a, 16 - (imm)) + +// NEON does not provide a version of this function, here is an article about some ways to repro the results. +// http://stackoverflow.com/questions/11870910/sse-mm-movemask-epi8-equivalent-method-for-arm-neon +// Creates a 16-bit mask from the most significant bits of the 16 signed or unsigned 8-bit integers in a and zero extends the upper bits. https://msdn.microsoft.com/en-us/library/vstudio/s090c8fk(v=vs.100).aspx +FORCE_INLINE int _mm_movemask_epi8(__m128i _a) +{ + uint8x16_t input = (uint8x16_t)_a; + const int8_t __attribute__((aligned(16))) xr[8] = { -7, -6, -5, -4, -3, -2, -1, 0 }; + uint8x8_t mask_and = vdup_n_u8(0x80); + int8x8_t mask_shift = vld1_s8(xr); + + uint8x8_t lo = vget_low_u8(input); + uint8x8_t hi = vget_high_u8(input); + + lo = vand_u8(lo, mask_and); + lo = vshl_u8(lo, mask_shift); + + hi = vand_u8(hi, mask_and); + hi = vshl_u8(hi, mask_shift); + + lo = vpadd_u8(lo, lo); + lo = vpadd_u8(lo, lo); + lo = vpadd_u8(lo, lo); + + hi = vpadd_u8(hi, hi); + hi = vpadd_u8(hi, hi); + hi = vpadd_u8(hi, hi); + + return ((hi[0] << 8) | (lo[0] & 0xFF)); +} + + +// ****************************************** +// Math operations +// ****************************************** + +// Subtracts the four single-precision, floating-point values of a and b. https://msdn.microsoft.com/en-us/library/vstudio/1zad2k61(v=vs.100).aspx +FORCE_INLINE __m128 _mm_sub_ps(__m128 a, __m128 b) +{ + return vsubq_f32(a, b); +} + +// Subtracts the 4 signed or unsigned 32-bit integers of b from the 4 signed or unsigned 32-bit integers of a. https://msdn.microsoft.com/en-us/library/vstudio/fhh866h0(v=vs.100).aspx +FORCE_INLINE __m128i _mm_sub_epi32(__m128i a, __m128i b) +{ + return vsubq_s32(a, b); +} + +// Adds the four single-precision, floating-point values of a and b. https://msdn.microsoft.com/en-us/library/vstudio/c9848chc(v=vs.100).aspx +FORCE_INLINE __m128 _mm_add_ps(__m128 a, __m128 b) +{ + return vaddq_f32(a, b); +} + +// Adds the 4 signed or unsigned 32-bit integers in a to the 4 signed or unsigned 32-bit integers in b. https://msdn.microsoft.com/en-us/library/vstudio/09xs4fkk(v=vs.100).aspx +FORCE_INLINE __m128i _mm_add_epi32(__m128i a, __m128i b) +{ + return vaddq_s32(a, b); +} + +// Adds the 8 signed or unsigned 16-bit integers in a to the 8 signed or unsigned 16-bit integers in b. https://msdn.microsoft.com/en-us/library/fceha5k4(v=vs.100).aspx +FORCE_INLINE __m128i _mm_add_epi16(__m128i a, __m128i b) +{ + return (__m128i)vaddq_s16((int16x8_t)a, (int16x8_t)b); +} + +// Multiplies the 8 signed or unsigned 16-bit integers from a by the 8 signed or unsigned 16-bit integers from b. https://msdn.microsoft.com/en-us/library/vstudio/9ks1472s(v=vs.100).aspx +FORCE_INLINE __m128i _mm_mullo_epi16(__m128i a, __m128i b) +{ + return (__m128i)vmulq_s16((int16x8_t)a, (int16x8_t)b); +} + +// Multiplies the 4 signed or unsigned 32-bit integers from a by the 4 signed or unsigned 32-bit integers from b. https://msdn.microsoft.com/en-us/library/vstudio/bb531409(v=vs.100).aspx +FORCE_INLINE __m128i _mm_mullo_epi32 (__m128i a, __m128i b) +{ + return (__m128i)vmulq_s32((int32x4_t)a,(int32x4_t)b); +} + +// Multiplies the four single-precision, floating-point values of a and b. https://msdn.microsoft.com/en-us/library/vstudio/22kbk6t9(v=vs.100).aspx +FORCE_INLINE __m128 _mm_mul_ps(__m128 a, __m128 b) +{ + return vmulq_f32(a, b); +} + +// This version does additional iterations to improve accuracy. Between 1 and 4 recommended. +// Computes the approximations of reciprocals of the four single-precision, floating-point values of a. https://msdn.microsoft.com/en-us/library/vstudio/796k1tty(v=vs.100).aspx +FORCE_INLINE __m128 recipq_newton(__m128 in, int n) +{ + __m128 recip = vrecpeq_f32(in); + for (int i = 0; i C++ +// header. + +#ifndef ABSL_ALGORITHM_ALGORITHM_H_ +#define ABSL_ALGORITHM_ALGORITHM_H_ + +#include +#include +#include + +namespace absl { + +namespace algorithm_internal { + +// Performs comparisons with operator==, similar to C++14's `std::equal_to<>`. +struct EqualTo { + template + bool operator()(const T& a, const U& b) const { + return a == b; + } +}; + +template +bool EqualImpl(InputIter1 first1, InputIter1 last1, InputIter2 first2, + InputIter2 last2, Pred pred, std::input_iterator_tag, + std::input_iterator_tag) { + while (true) { + if (first1 == last1) return first2 == last2; + if (first2 == last2) return false; + if (!pred(*first1, *first2)) return false; + ++first1; + ++first2; + } +} + +template +bool EqualImpl(InputIter1 first1, InputIter1 last1, InputIter2 first2, + InputIter2 last2, Pred&& pred, std::random_access_iterator_tag, + std::random_access_iterator_tag) { + return (last1 - first1 == last2 - first2) && + std::equal(first1, last1, first2, std::forward(pred)); +} + +// When we are using our own internal predicate that just applies operator==, we +// forward to the non-predicate form of std::equal. This enables an optimization +// in libstdc++ that can result in std::memcmp being used for integer types. +template +bool EqualImpl(InputIter1 first1, InputIter1 last1, InputIter2 first2, + InputIter2 last2, algorithm_internal::EqualTo /* unused */, + std::random_access_iterator_tag, + std::random_access_iterator_tag) { + return (last1 - first1 == last2 - first2) && + std::equal(first1, last1, first2); +} + +template +It RotateImpl(It first, It middle, It last, std::true_type) { + return std::rotate(first, middle, last); +} + +template +It RotateImpl(It first, It middle, It last, std::false_type) { + std::rotate(first, middle, last); + return std::next(first, std::distance(middle, last)); +} + +} // namespace algorithm_internal + +// Compares the equality of two ranges specified by pairs of iterators, using +// the given predicate, returning true iff for each corresponding iterator i1 +// and i2 in the first and second range respectively, pred(*i1, *i2) == true +// +// This comparison takes at most min(`last1` - `first1`, `last2` - `first2`) +// invocations of the predicate. Additionally, if InputIter1 and InputIter2 are +// both random-access iterators, and `last1` - `first1` != `last2` - `first2`, +// then the predicate is never invoked and the function returns false. +// +// This is a C++11-compatible implementation of C++14 `std::equal`. See +// http://en.cppreference.com/w/cpp/algorithm/equal for more information. +template +bool equal(InputIter1 first1, InputIter1 last1, InputIter2 first2, + InputIter2 last2, Pred&& pred) { + return algorithm_internal::EqualImpl( + first1, last1, first2, last2, std::forward(pred), + typename std::iterator_traits::iterator_category{}, + typename std::iterator_traits::iterator_category{}); +} + +// Performs comparison of two ranges specified by pairs of iterators using +// operator==. +template +bool equal(InputIter1 first1, InputIter1 last1, InputIter2 first2, + InputIter2 last2) { + return absl::equal(first1, last1, first2, last2, + algorithm_internal::EqualTo{}); +} + +// Performs a linear search for `value` using the iterator `first` up to +// but not including `last`, returning true if [`first`, `last`) contains an +// element equal to `value`. +// +// A linear search is of O(n) complexity which is guaranteed to make at most +// n = (`last` - `first`) comparisons. A linear search over short containers +// may be faster than a binary search, even when the container is sorted. +template +bool linear_search(InputIterator first, InputIterator last, + const EqualityComparable& value) { + return std::find(first, last, value) != last; +} + +// Performs a left rotation on a range of elements (`first`, `last`) such that +// `middle` is now the first element. `rotate()` returns an iterator pointing to +// the first element before rotation. This function is exactly the same as +// `std::rotate`, but fixes a bug in gcc +// <= 4.9 where `std::rotate` returns `void` instead of an iterator. +// +// The complexity of this algorithm is the same as that of `std::rotate`, but if +// `ForwardIterator` is not a random-access iterator, then `absl::rotate` +// performs an additional pass over the range to construct the return value. + +template +ForwardIterator rotate(ForwardIterator first, ForwardIterator middle, + ForwardIterator last) { + return algorithm_internal::RotateImpl( + first, middle, last, + std::is_same()); +} + +} // namespace absl + +#endif // ABSL_ALGORITHM_ALGORITHM_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/attributes.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/attributes.h new file mode 100644 index 000000000..291ad89ee --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/attributes.h @@ -0,0 +1,597 @@ +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// This header file defines macros for declaring attributes for functions, +// types, and variables. +// +// These macros are used within Abseil and allow the compiler to optimize, where +// applicable, certain function calls. +// +// This file is used for both C and C++! +// +// Most macros here are exposing GCC or Clang features, and are stubbed out for +// other compilers. +// +// GCC attributes documentation: +// https://gcc.gnu.org/onlinedocs/gcc-4.7.0/gcc/Function-Attributes.html +// https://gcc.gnu.org/onlinedocs/gcc-4.7.0/gcc/Variable-Attributes.html +// https://gcc.gnu.org/onlinedocs/gcc-4.7.0/gcc/Type-Attributes.html +// +// Most attributes in this file are already supported by GCC 4.7. However, some +// of them are not supported in older version of Clang. Thus, we check +// `__has_attribute()` first. If the check fails, we check if we are on GCC and +// assume the attribute exists on GCC (which is verified on GCC 4.7). +// +// ----------------------------------------------------------------------------- +// Sanitizer Attributes +// ----------------------------------------------------------------------------- +// +// Sanitizer-related attributes are not "defined" in this file (and indeed +// are not defined as such in any file). To utilize the following +// sanitizer-related attributes within your builds, define the following macros +// within your build using a `-D` flag, along with the given value for +// `-fsanitize`: +// +// * `ADDRESS_SANITIZER` + `-fsanitize=address` (Clang, GCC 4.8) +// * `MEMORY_SANITIZER` + `-fsanitize=memory` (Clang-only) +// * `THREAD_SANITIZER + `-fsanitize=thread` (Clang, GCC 4.8+) +// * `UNDEFINED_BEHAVIOR_SANITIZER` + `-fsanitize=undefined` (Clang, GCC 4.9+) +// * `CONTROL_FLOW_INTEGRITY` + -fsanitize=cfi (Clang-only) +// +// Example: +// +// // Enable branches in the Abseil code that are tagged for ASan: +// $ bazel build --copt=-DADDRESS_SANITIZER --copt=-fsanitize=address +// --linkopt=-fsanitize=address *target* +// +// Since these macro names are only supported by GCC and Clang, we only check +// for `__GNUC__` (GCC or Clang) and the above macros. +#ifndef ABSL_BASE_ATTRIBUTES_H_ +#define ABSL_BASE_ATTRIBUTES_H_ + +// ABSL_HAVE_ATTRIBUTE +// +// A function-like feature checking macro that is a wrapper around +// `__has_attribute`, which is defined by GCC 5+ and Clang and evaluates to a +// nonzero constant integer if the attribute is supported or 0 if not. +// +// It evaluates to zero if `__has_attribute` is not defined by the compiler. +// +// GCC: https://gcc.gnu.org/gcc-5/changes.html +// Clang: https://clang.llvm.org/docs/LanguageExtensions.html +#ifdef __has_attribute +#define ABSL_HAVE_ATTRIBUTE(x) __has_attribute(x) +#else +#define ABSL_HAVE_ATTRIBUTE(x) 0 +#endif + +// ABSL_HAVE_CPP_ATTRIBUTE +// +// A function-like feature checking macro that accepts C++11 style attributes. +// It's a wrapper around `__has_cpp_attribute`, defined by ISO C++ SD-6 +// (http://en.cppreference.com/w/cpp/experimental/feature_test). If we don't +// find `__has_cpp_attribute`, will evaluate to 0. +#if defined(__cplusplus) && defined(__has_cpp_attribute) +// NOTE: requiring __cplusplus above should not be necessary, but +// works around https://bugs.llvm.org/show_bug.cgi?id=23435. +#define ABSL_HAVE_CPP_ATTRIBUTE(x) __has_cpp_attribute(x) +#else +#define ABSL_HAVE_CPP_ATTRIBUTE(x) 0 +#endif + +// ----------------------------------------------------------------------------- +// Function Attributes +// ----------------------------------------------------------------------------- +// +// GCC: https://gcc.gnu.org/onlinedocs/gcc/Function-Attributes.html +// Clang: https://clang.llvm.org/docs/AttributeReference.html + +// ABSL_PRINTF_ATTRIBUTE +// ABSL_SCANF_ATTRIBUTE +// +// Tells the compiler to perform `printf` format string checking if the +// compiler supports it; see the 'format' attribute in +// . +// +// Note: As the GCC manual states, "[s]ince non-static C++ methods +// have an implicit 'this' argument, the arguments of such methods +// should be counted from two, not one." +#if ABSL_HAVE_ATTRIBUTE(format) || (defined(__GNUC__) && !defined(__clang__)) +#define ABSL_PRINTF_ATTRIBUTE(string_index, first_to_check) \ + __attribute__((__format__(__printf__, string_index, first_to_check))) +#define ABSL_SCANF_ATTRIBUTE(string_index, first_to_check) \ + __attribute__((__format__(__scanf__, string_index, first_to_check))) +#else +#define ABSL_PRINTF_ATTRIBUTE(string_index, first_to_check) +#define ABSL_SCANF_ATTRIBUTE(string_index, first_to_check) +#endif + +// ABSL_ATTRIBUTE_ALWAYS_INLINE +// ABSL_ATTRIBUTE_NOINLINE +// +// Forces functions to either inline or not inline. Introduced in gcc 3.1. +#if ABSL_HAVE_ATTRIBUTE(always_inline) || \ + (defined(__GNUC__) && !defined(__clang__)) +#define ABSL_ATTRIBUTE_ALWAYS_INLINE __attribute__((always_inline)) +#define ABSL_HAVE_ATTRIBUTE_ALWAYS_INLINE 1 +#else +#define ABSL_ATTRIBUTE_ALWAYS_INLINE +#endif + +#if ABSL_HAVE_ATTRIBUTE(noinline) || (defined(__GNUC__) && !defined(__clang__)) +#define ABSL_ATTRIBUTE_NOINLINE __attribute__((noinline)) +#define ABSL_HAVE_ATTRIBUTE_NOINLINE 1 +#else +#define ABSL_ATTRIBUTE_NOINLINE +#endif + +// ABSL_ATTRIBUTE_NO_TAIL_CALL +// +// Prevents the compiler from optimizing away stack frames for functions which +// end in a call to another function. +#if ABSL_HAVE_ATTRIBUTE(disable_tail_calls) +#define ABSL_HAVE_ATTRIBUTE_NO_TAIL_CALL 1 +#define ABSL_ATTRIBUTE_NO_TAIL_CALL __attribute__((disable_tail_calls)) +#elif defined(__GNUC__) && !defined(__clang__) +#define ABSL_HAVE_ATTRIBUTE_NO_TAIL_CALL 1 +#define ABSL_ATTRIBUTE_NO_TAIL_CALL \ + __attribute__((optimize("no-optimize-sibling-calls"))) +#else +#define ABSL_ATTRIBUTE_NO_TAIL_CALL +#define ABSL_HAVE_ATTRIBUTE_NO_TAIL_CALL 0 +#endif + +// ABSL_ATTRIBUTE_WEAK +// +// Tags a function as weak for the purposes of compilation and linking. +// Weak attributes currently do not work properly in LLVM's Windows backend, +// so disable them there. See https://bugs.llvm.org/show_bug.cgi?id=37598 +// for futher information. +#if (ABSL_HAVE_ATTRIBUTE(weak) || \ + (defined(__GNUC__) && !defined(__clang__))) && \ + !(defined(__llvm__) && defined(_WIN32)) +#undef ABSL_ATTRIBUTE_WEAK +#define ABSL_ATTRIBUTE_WEAK __attribute__((weak)) +#define ABSL_HAVE_ATTRIBUTE_WEAK 1 +#else +#define ABSL_ATTRIBUTE_WEAK +#define ABSL_HAVE_ATTRIBUTE_WEAK 0 +#endif + +// ABSL_ATTRIBUTE_NONNULL +// +// Tells the compiler either (a) that a particular function parameter +// should be a non-null pointer, or (b) that all pointer arguments should +// be non-null. +// +// Note: As the GCC manual states, "[s]ince non-static C++ methods +// have an implicit 'this' argument, the arguments of such methods +// should be counted from two, not one." +// +// Args are indexed starting at 1. +// +// For non-static class member functions, the implicit `this` argument +// is arg 1, and the first explicit argument is arg 2. For static class member +// functions, there is no implicit `this`, and the first explicit argument is +// arg 1. +// +// Example: +// +// /* arg_a cannot be null, but arg_b can */ +// void Function(void* arg_a, void* arg_b) ABSL_ATTRIBUTE_NONNULL(1); +// +// class C { +// /* arg_a cannot be null, but arg_b can */ +// void Method(void* arg_a, void* arg_b) ABSL_ATTRIBUTE_NONNULL(2); +// +// /* arg_a cannot be null, but arg_b can */ +// static void StaticMethod(void* arg_a, void* arg_b) +// ABSL_ATTRIBUTE_NONNULL(1); +// }; +// +// If no arguments are provided, then all pointer arguments should be non-null. +// +// /* No pointer arguments may be null. */ +// void Function(void* arg_a, void* arg_b, int arg_c) ABSL_ATTRIBUTE_NONNULL(); +// +// NOTE: The GCC nonnull attribute actually accepts a list of arguments, but +// ABSL_ATTRIBUTE_NONNULL does not. +#if ABSL_HAVE_ATTRIBUTE(nonnull) || (defined(__GNUC__) && !defined(__clang__)) +#define ABSL_ATTRIBUTE_NONNULL(arg_index) __attribute__((nonnull(arg_index))) +#else +#define ABSL_ATTRIBUTE_NONNULL(...) +#endif + +// ABSL_ATTRIBUTE_NORETURN +// +// Tells the compiler that a given function never returns. +#if ABSL_HAVE_ATTRIBUTE(noreturn) || (defined(__GNUC__) && !defined(__clang__)) +#define ABSL_ATTRIBUTE_NORETURN __attribute__((noreturn)) +#elif defined(_MSC_VER) +#define ABSL_ATTRIBUTE_NORETURN __declspec(noreturn) +#else +#define ABSL_ATTRIBUTE_NORETURN +#endif + +// ABSL_ATTRIBUTE_NO_SANITIZE_ADDRESS +// +// Tells the AddressSanitizer (or other memory testing tools) to ignore a given +// function. Useful for cases when a function reads random locations on stack, +// calls _exit from a cloned subprocess, deliberately accesses buffer +// out of bounds or does other scary things with memory. +// NOTE: GCC supports AddressSanitizer(asan) since 4.8. +// https://gcc.gnu.org/gcc-4.8/changes.html +#if defined(__GNUC__) && defined(ADDRESS_SANITIZER) +#define ABSL_ATTRIBUTE_NO_SANITIZE_ADDRESS __attribute__((no_sanitize_address)) +#else +#define ABSL_ATTRIBUTE_NO_SANITIZE_ADDRESS +#endif + +// ABSL_ATTRIBUTE_NO_SANITIZE_MEMORY +// +// Tells the MemorySanitizer to relax the handling of a given function. All +// "Use of uninitialized value" warnings from such functions will be suppressed, +// and all values loaded from memory will be considered fully initialized. +// This attribute is similar to the ADDRESS_SANITIZER attribute above, but deals +// with initialized-ness rather than addressability issues. +// NOTE: MemorySanitizer(msan) is supported by Clang but not GCC. +#if defined(__GNUC__) && defined(MEMORY_SANITIZER) +#define ABSL_ATTRIBUTE_NO_SANITIZE_MEMORY __attribute__((no_sanitize_memory)) +#else +#define ABSL_ATTRIBUTE_NO_SANITIZE_MEMORY +#endif + +// ABSL_ATTRIBUTE_NO_SANITIZE_THREAD +// +// Tells the ThreadSanitizer to not instrument a given function. +// NOTE: GCC supports ThreadSanitizer(tsan) since 4.8. +// https://gcc.gnu.org/gcc-4.8/changes.html +#if defined(__GNUC__) && defined(THREAD_SANITIZER) +#define ABSL_ATTRIBUTE_NO_SANITIZE_THREAD __attribute__((no_sanitize_thread)) +#else +#define ABSL_ATTRIBUTE_NO_SANITIZE_THREAD +#endif + +// ABSL_ATTRIBUTE_NO_SANITIZE_UNDEFINED +// +// Tells the UndefinedSanitizer to ignore a given function. Useful for cases +// where certain behavior (eg. division by zero) is being used intentionally. +// NOTE: GCC supports UndefinedBehaviorSanitizer(ubsan) since 4.9. +// https://gcc.gnu.org/gcc-4.9/changes.html +#if defined(__GNUC__) && \ + (defined(UNDEFINED_BEHAVIOR_SANITIZER) || defined(ADDRESS_SANITIZER)) +#define ABSL_ATTRIBUTE_NO_SANITIZE_UNDEFINED \ + __attribute__((no_sanitize("undefined"))) +#else +#define ABSL_ATTRIBUTE_NO_SANITIZE_UNDEFINED +#endif + +// ABSL_ATTRIBUTE_NO_SANITIZE_CFI +// +// Tells the ControlFlowIntegrity sanitizer to not instrument a given function. +// See https://clang.llvm.org/docs/ControlFlowIntegrity.html for details. +#if defined(__GNUC__) && defined(CONTROL_FLOW_INTEGRITY) +#define ABSL_ATTRIBUTE_NO_SANITIZE_CFI __attribute__((no_sanitize("cfi"))) +#else +#define ABSL_ATTRIBUTE_NO_SANITIZE_CFI +#endif + +// ABSL_ATTRIBUTE_RETURNS_NONNULL +// +// Tells the compiler that a particular function never returns a null pointer. +#if ABSL_HAVE_ATTRIBUTE(returns_nonnull) || \ + (defined(__GNUC__) && \ + (__GNUC__ > 5 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 9)) && \ + !defined(__clang__)) +#define ABSL_ATTRIBUTE_RETURNS_NONNULL __attribute__((returns_nonnull)) +#else +#define ABSL_ATTRIBUTE_RETURNS_NONNULL +#endif + +// ABSL_HAVE_ATTRIBUTE_SECTION +// +// Indicates whether labeled sections are supported. Weak symbol support is +// a prerequisite. Labeled sections are not supported on Darwin/iOS. +#ifdef ABSL_HAVE_ATTRIBUTE_SECTION +#error ABSL_HAVE_ATTRIBUTE_SECTION cannot be directly set +#elif (ABSL_HAVE_ATTRIBUTE(section) || \ + (defined(__GNUC__) && !defined(__clang__))) && \ + !defined(__APPLE__) && ABSL_HAVE_ATTRIBUTE_WEAK +#define ABSL_HAVE_ATTRIBUTE_SECTION 1 + +// ABSL_ATTRIBUTE_SECTION +// +// Tells the compiler/linker to put a given function into a section and define +// `__start_ ## name` and `__stop_ ## name` symbols to bracket the section. +// This functionality is supported by GNU linker. Any function annotated with +// `ABSL_ATTRIBUTE_SECTION` must not be inlined, or it will be placed into +// whatever section its caller is placed into. +// +#ifndef ABSL_ATTRIBUTE_SECTION +#define ABSL_ATTRIBUTE_SECTION(name) \ + __attribute__((section(#name))) __attribute__((noinline)) +#endif + + +// ABSL_ATTRIBUTE_SECTION_VARIABLE +// +// Tells the compiler/linker to put a given variable into a section and define +// `__start_ ## name` and `__stop_ ## name` symbols to bracket the section. +// This functionality is supported by GNU linker. +#ifndef ABSL_ATTRIBUTE_SECTION_VARIABLE +#define ABSL_ATTRIBUTE_SECTION_VARIABLE(name) __attribute__((section(#name))) +#endif + +// ABSL_DECLARE_ATTRIBUTE_SECTION_VARS +// +// A weak section declaration to be used as a global declaration +// for ABSL_ATTRIBUTE_SECTION_START|STOP(name) to compile and link +// even without functions with ABSL_ATTRIBUTE_SECTION(name). +// ABSL_DEFINE_ATTRIBUTE_SECTION should be in the exactly one file; it's +// a no-op on ELF but not on Mach-O. +// +#ifndef ABSL_DECLARE_ATTRIBUTE_SECTION_VARS +#define ABSL_DECLARE_ATTRIBUTE_SECTION_VARS(name) \ + extern char __start_##name[] ABSL_ATTRIBUTE_WEAK; \ + extern char __stop_##name[] ABSL_ATTRIBUTE_WEAK +#endif +#ifndef ABSL_DEFINE_ATTRIBUTE_SECTION_VARS +#define ABSL_INIT_ATTRIBUTE_SECTION_VARS(name) +#define ABSL_DEFINE_ATTRIBUTE_SECTION_VARS(name) +#endif + +// ABSL_ATTRIBUTE_SECTION_START +// +// Returns `void*` pointers to start/end of a section of code with +// functions having ABSL_ATTRIBUTE_SECTION(name). +// Returns 0 if no such functions exist. +// One must ABSL_DECLARE_ATTRIBUTE_SECTION_VARS(name) for this to compile and +// link. +// +#define ABSL_ATTRIBUTE_SECTION_START(name) \ + (reinterpret_cast(__start_##name)) +#define ABSL_ATTRIBUTE_SECTION_STOP(name) \ + (reinterpret_cast(__stop_##name)) + +#else // !ABSL_HAVE_ATTRIBUTE_SECTION + +#define ABSL_HAVE_ATTRIBUTE_SECTION 0 + +// provide dummy definitions +#define ABSL_ATTRIBUTE_SECTION(name) +#define ABSL_ATTRIBUTE_SECTION_VARIABLE(name) +#define ABSL_INIT_ATTRIBUTE_SECTION_VARS(name) +#define ABSL_DEFINE_ATTRIBUTE_SECTION_VARS(name) +#define ABSL_DECLARE_ATTRIBUTE_SECTION_VARS(name) +#define ABSL_ATTRIBUTE_SECTION_START(name) (reinterpret_cast(0)) +#define ABSL_ATTRIBUTE_SECTION_STOP(name) (reinterpret_cast(0)) + +#endif // ABSL_ATTRIBUTE_SECTION + +// ABSL_ATTRIBUTE_STACK_ALIGN_FOR_OLD_LIBC +// +// Support for aligning the stack on 32-bit x86. +#if ABSL_HAVE_ATTRIBUTE(force_align_arg_pointer) || \ + (defined(__GNUC__) && !defined(__clang__)) +#if defined(__i386__) +#define ABSL_ATTRIBUTE_STACK_ALIGN_FOR_OLD_LIBC \ + __attribute__((force_align_arg_pointer)) +#define ABSL_REQUIRE_STACK_ALIGN_TRAMPOLINE (0) +#elif defined(__x86_64__) +#define ABSL_REQUIRE_STACK_ALIGN_TRAMPOLINE (1) +#define ABSL_ATTRIBUTE_STACK_ALIGN_FOR_OLD_LIBC +#else // !__i386__ && !__x86_64 +#define ABSL_REQUIRE_STACK_ALIGN_TRAMPOLINE (0) +#define ABSL_ATTRIBUTE_STACK_ALIGN_FOR_OLD_LIBC +#endif // __i386__ +#else +#define ABSL_ATTRIBUTE_STACK_ALIGN_FOR_OLD_LIBC +#define ABSL_REQUIRE_STACK_ALIGN_TRAMPOLINE (0) +#endif + +// ABSL_MUST_USE_RESULT +// +// Tells the compiler to warn about unused results. +// +// When annotating a function, it must appear as the first part of the +// declaration or definition. The compiler will warn if the return value from +// such a function is unused: +// +// ABSL_MUST_USE_RESULT Sprocket* AllocateSprocket(); +// AllocateSprocket(); // Triggers a warning. +// +// When annotating a class, it is equivalent to annotating every function which +// returns an instance. +// +// class ABSL_MUST_USE_RESULT Sprocket {}; +// Sprocket(); // Triggers a warning. +// +// Sprocket MakeSprocket(); +// MakeSprocket(); // Triggers a warning. +// +// Note that references and pointers are not instances: +// +// Sprocket* SprocketPointer(); +// SprocketPointer(); // Does *not* trigger a warning. +// +// ABSL_MUST_USE_RESULT allows using cast-to-void to suppress the unused result +// warning. For that, warn_unused_result is used only for clang but not for gcc. +// https://gcc.gnu.org/bugzilla/show_bug.cgi?id=66425 +// +// Note: past advice was to place the macro after the argument list. +#if ABSL_HAVE_ATTRIBUTE(nodiscard) +#define ABSL_MUST_USE_RESULT [[nodiscard]] +#elif defined(__clang__) && ABSL_HAVE_ATTRIBUTE(warn_unused_result) +#define ABSL_MUST_USE_RESULT __attribute__((warn_unused_result)) +#else +#define ABSL_MUST_USE_RESULT +#endif + +// ABSL_ATTRIBUTE_HOT, ABSL_ATTRIBUTE_COLD +// +// Tells GCC that a function is hot or cold. GCC can use this information to +// improve static analysis, i.e. a conditional branch to a cold function +// is likely to be not-taken. +// This annotation is used for function declarations. +// +// Example: +// +// int foo() ABSL_ATTRIBUTE_HOT; +#if ABSL_HAVE_ATTRIBUTE(hot) || (defined(__GNUC__) && !defined(__clang__)) +#define ABSL_ATTRIBUTE_HOT __attribute__((hot)) +#else +#define ABSL_ATTRIBUTE_HOT +#endif + +#if ABSL_HAVE_ATTRIBUTE(cold) || (defined(__GNUC__) && !defined(__clang__)) +#define ABSL_ATTRIBUTE_COLD __attribute__((cold)) +#else +#define ABSL_ATTRIBUTE_COLD +#endif + +// ABSL_XRAY_ALWAYS_INSTRUMENT, ABSL_XRAY_NEVER_INSTRUMENT, ABSL_XRAY_LOG_ARGS +// +// We define the ABSL_XRAY_ALWAYS_INSTRUMENT and ABSL_XRAY_NEVER_INSTRUMENT +// macro used as an attribute to mark functions that must always or never be +// instrumented by XRay. Currently, this is only supported in Clang/LLVM. +// +// For reference on the LLVM XRay instrumentation, see +// http://llvm.org/docs/XRay.html. +// +// A function with the XRAY_ALWAYS_INSTRUMENT macro attribute in its declaration +// will always get the XRay instrumentation sleds. These sleds may introduce +// some binary size and runtime overhead and must be used sparingly. +// +// These attributes only take effect when the following conditions are met: +// +// * The file/target is built in at least C++11 mode, with a Clang compiler +// that supports XRay attributes. +// * The file/target is built with the -fxray-instrument flag set for the +// Clang/LLVM compiler. +// * The function is defined in the translation unit (the compiler honors the +// attribute in either the definition or the declaration, and must match). +// +// There are cases when, even when building with XRay instrumentation, users +// might want to control specifically which functions are instrumented for a +// particular build using special-case lists provided to the compiler. These +// special case lists are provided to Clang via the +// -fxray-always-instrument=... and -fxray-never-instrument=... flags. The +// attributes in source take precedence over these special-case lists. +// +// To disable the XRay attributes at build-time, users may define +// ABSL_NO_XRAY_ATTRIBUTES. Do NOT define ABSL_NO_XRAY_ATTRIBUTES on specific +// packages/targets, as this may lead to conflicting definitions of functions at +// link-time. +// +#if ABSL_HAVE_CPP_ATTRIBUTE(clang::xray_always_instrument) && \ + !defined(ABSL_NO_XRAY_ATTRIBUTES) +#define ABSL_XRAY_ALWAYS_INSTRUMENT [[clang::xray_always_instrument]] +#define ABSL_XRAY_NEVER_INSTRUMENT [[clang::xray_never_instrument]] +#if ABSL_HAVE_CPP_ATTRIBUTE(clang::xray_log_args) +#define ABSL_XRAY_LOG_ARGS(N) \ + [[clang::xray_always_instrument, clang::xray_log_args(N)]] +#else +#define ABSL_XRAY_LOG_ARGS(N) [[clang::xray_always_instrument]] +#endif +#else +#define ABSL_XRAY_ALWAYS_INSTRUMENT +#define ABSL_XRAY_NEVER_INSTRUMENT +#define ABSL_XRAY_LOG_ARGS(N) +#endif + +// ABSL_ATTRIBUTE_REINITIALIZES +// +// Indicates that a member function reinitializes the entire object to a known +// state, independent of the previous state of the object. +// +// The clang-tidy check bugprone-use-after-move allows member functions marked +// with this attribute to be called on objects that have been moved from; +// without the attribute, this would result in a use-after-move warning. +#if ABSL_HAVE_CPP_ATTRIBUTE(clang::reinitializes) +#define ABSL_ATTRIBUTE_REINITIALIZES [[clang::reinitializes]] +#else +#define ABSL_ATTRIBUTE_REINITIALIZES +#endif + +// ----------------------------------------------------------------------------- +// Variable Attributes +// ----------------------------------------------------------------------------- + +// ABSL_ATTRIBUTE_UNUSED +// +// Prevents the compiler from complaining about variables that appear unused. +#if ABSL_HAVE_ATTRIBUTE(unused) || (defined(__GNUC__) && !defined(__clang__)) +#undef ABSL_ATTRIBUTE_UNUSED +#define ABSL_ATTRIBUTE_UNUSED __attribute__((__unused__)) +#else +#define ABSL_ATTRIBUTE_UNUSED +#endif + +// ABSL_ATTRIBUTE_INITIAL_EXEC +// +// Tells the compiler to use "initial-exec" mode for a thread-local variable. +// See http://people.redhat.com/drepper/tls.pdf for the gory details. +#if ABSL_HAVE_ATTRIBUTE(tls_model) || (defined(__GNUC__) && !defined(__clang__)) +#define ABSL_ATTRIBUTE_INITIAL_EXEC __attribute__((tls_model("initial-exec"))) +#else +#define ABSL_ATTRIBUTE_INITIAL_EXEC +#endif + +// ABSL_ATTRIBUTE_PACKED +// +// Prevents the compiler from padding a structure to natural alignment +#if ABSL_HAVE_ATTRIBUTE(packed) || (defined(__GNUC__) && !defined(__clang__)) +#define ABSL_ATTRIBUTE_PACKED __attribute__((__packed__)) +#else +#define ABSL_ATTRIBUTE_PACKED +#endif + +// ABSL_ATTRIBUTE_FUNC_ALIGN +// +// Tells the compiler to align the function start at least to certain +// alignment boundary +#if ABSL_HAVE_ATTRIBUTE(aligned) || (defined(__GNUC__) && !defined(__clang__)) +#define ABSL_ATTRIBUTE_FUNC_ALIGN(bytes) __attribute__((aligned(bytes))) +#else +#define ABSL_ATTRIBUTE_FUNC_ALIGN(bytes) +#endif + +// ABSL_CONST_INIT +// +// A variable declaration annotated with the `ABSL_CONST_INIT` attribute will +// not compile (on supported platforms) unless the variable has a constant +// initializer. This is useful for variables with static and thread storage +// duration, because it guarantees that they will not suffer from the so-called +// "static init order fiasco". Prefer to put this attribute on the most visible +// declaration of the variable, if there's more than one, because code that +// accesses the variable can then use the attribute for optimization. +// +// Example: +// +// class MyClass { +// public: +// ABSL_CONST_INIT static MyType my_var; +// }; +// +// MyType MyClass::my_var = MakeMyType(...); +// +// Note that this attribute is redundant if the variable is declared constexpr. +#if ABSL_HAVE_CPP_ATTRIBUTE(clang::require_constant_initialization) +// NOLINTNEXTLINE(whitespace/braces) +#define ABSL_CONST_INIT [[clang::require_constant_initialization]] +#else +#define ABSL_CONST_INIT +#endif // ABSL_HAVE_CPP_ATTRIBUTE(clang::require_constant_initialization) + +#endif // ABSL_BASE_ATTRIBUTES_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/config.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/config.h new file mode 100644 index 000000000..ca089f6d0 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/config.h @@ -0,0 +1,443 @@ +// +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ----------------------------------------------------------------------------- +// File: config.h +// ----------------------------------------------------------------------------- +// +// This header file defines a set of macros for checking the presence of +// important compiler and platform features. Such macros can be used to +// produce portable code by parameterizing compilation based on the presence or +// lack of a given feature. +// +// We define a "feature" as some interface we wish to program to: for example, +// a library function or system call. A value of `1` indicates support for +// that feature; any other value indicates the feature support is undefined. +// +// Example: +// +// Suppose a programmer wants to write a program that uses the 'mmap()' system +// call. The Abseil macro for that feature (`ABSL_HAVE_MMAP`) allows you to +// selectively include the `mmap.h` header and bracket code using that feature +// in the macro: +// +// #include "absl/base/config.h" +// +// #ifdef ABSL_HAVE_MMAP +// #include "sys/mman.h" +// #endif //ABSL_HAVE_MMAP +// +// ... +// #ifdef ABSL_HAVE_MMAP +// void *ptr = mmap(...); +// ... +// #endif // ABSL_HAVE_MMAP + +#ifndef ABSL_BASE_CONFIG_H_ +#define ABSL_BASE_CONFIG_H_ + +// Included for the __GLIBC__ macro (or similar macros on other systems). +#include + +#ifdef __cplusplus +// Included for __GLIBCXX__, _LIBCPP_VERSION +#include +#endif // __cplusplus + +#if defined(__APPLE__) +// Included for TARGET_OS_IPHONE, __IPHONE_OS_VERSION_MIN_REQUIRED, +// __IPHONE_8_0. +#include +#include +#endif + +#include "absl/base/policy_checks.h" + +// ----------------------------------------------------------------------------- +// Compiler Feature Checks +// ----------------------------------------------------------------------------- + +// ABSL_HAVE_BUILTIN() +// +// Checks whether the compiler supports a Clang Feature Checking Macro, and if +// so, checks whether it supports the provided builtin function "x" where x +// is one of the functions noted in +// https://clang.llvm.org/docs/LanguageExtensions.html +// +// Note: Use this macro to avoid an extra level of #ifdef __has_builtin check. +// http://releases.llvm.org/3.3/tools/clang/docs/LanguageExtensions.html +#ifdef __has_builtin +#define ABSL_HAVE_BUILTIN(x) __has_builtin(x) +#else +#define ABSL_HAVE_BUILTIN(x) 0 +#endif + +// ABSL_HAVE_TLS is defined to 1 when __thread should be supported. +// We assume __thread is supported on Linux when compiled with Clang or compiled +// against libstdc++ with _GLIBCXX_HAVE_TLS defined. +#ifdef ABSL_HAVE_TLS +#error ABSL_HAVE_TLS cannot be directly set +#elif defined(__linux__) && (defined(__clang__) || defined(_GLIBCXX_HAVE_TLS)) +#define ABSL_HAVE_TLS 1 +#endif + +// ABSL_HAVE_STD_IS_TRIVIALLY_DESTRUCTIBLE +// +// Checks whether `std::is_trivially_destructible` is supported. +// +// Notes: All supported compilers using libc++ support this feature, as does +// gcc >= 4.8.1 using libstdc++, and Visual Studio. +#ifdef ABSL_HAVE_STD_IS_TRIVIALLY_DESTRUCTIBLE +#error ABSL_HAVE_STD_IS_TRIVIALLY_DESTRUCTIBLE cannot be directly set +#elif defined(_LIBCPP_VERSION) || \ + (!defined(__clang__) && defined(__GNUC__) && defined(__GLIBCXX__) && \ + (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 8))) || \ + defined(_MSC_VER) +#define ABSL_HAVE_STD_IS_TRIVIALLY_DESTRUCTIBLE 1 +#endif + +// ABSL_HAVE_STD_IS_TRIVIALLY_CONSTRUCTIBLE +// +// Checks whether `std::is_trivially_default_constructible` and +// `std::is_trivially_copy_constructible` are supported. + +// ABSL_HAVE_STD_IS_TRIVIALLY_ASSIGNABLE +// +// Checks whether `std::is_trivially_copy_assignable` is supported. + +// Notes: Clang with libc++ supports these features, as does gcc >= 5.1 with +// either libc++ or libstdc++, and Visual Studio. +#if defined(ABSL_HAVE_STD_IS_TRIVIALLY_CONSTRUCTIBLE) +#error ABSL_HAVE_STD_IS_TRIVIALLY_CONSTRUCTIBLE cannot be directly set +#elif defined(ABSL_HAVE_STD_IS_TRIVIALLY_ASSIGNABLE) +#error ABSL_HAVE_STD_IS_TRIVIALLY_ASSIGNABLE cannot directly set +#elif (defined(__clang__) && defined(_LIBCPP_VERSION)) || \ + (!defined(__clang__) && defined(__GNUC__) && \ + (__GNUC__ > 5 || (__GNUC__ == 5 && __GNUC_MINOR__ >= 1)) && \ + (defined(_LIBCPP_VERSION) || defined(__GLIBCXX__))) || \ + defined(_MSC_VER) +#define ABSL_HAVE_STD_IS_TRIVIALLY_CONSTRUCTIBLE 1 +#define ABSL_HAVE_STD_IS_TRIVIALLY_ASSIGNABLE 1 +#endif + +// ABSL_HAVE_THREAD_LOCAL +// +// Checks whether C++11's `thread_local` storage duration specifier is +// supported. +#ifdef ABSL_HAVE_THREAD_LOCAL +#error ABSL_HAVE_THREAD_LOCAL cannot be directly set +#elif defined(__APPLE__) +// Notes: +// * Xcode's clang did not support `thread_local` until version 8, and +// even then not for all iOS < 9.0. +// * Xcode 9.3 started disallowing `thread_local` for 32-bit iOS simulator +// targeting iOS 9.x. +// * Xcode 10 moves the deployment target check for iOS < 9.0 to link time +// making __has_feature unreliable there. +// +// Otherwise, `__has_feature` is only supported by Clang so it has be inside +// `defined(__APPLE__)` check. +#if __has_feature(cxx_thread_local) && \ + !(TARGET_OS_IPHONE && __IPHONE_OS_VERSION_MIN_REQUIRED < __IPHONE_9_0) +#define ABSL_HAVE_THREAD_LOCAL 1 +#endif +#else // !defined(__APPLE__) +#define ABSL_HAVE_THREAD_LOCAL 1 +#endif + +// There are platforms for which TLS should not be used even though the compiler +// makes it seem like it's supported (Android NDK < r12b for example). +// This is primarily because of linker problems and toolchain misconfiguration: +// Abseil does not intend to support this indefinitely. Currently, the newest +// toolchain that we intend to support that requires this behavior is the +// r11 NDK - allowing for a 5 year support window on that means this option +// is likely to be removed around June of 2021. +// TLS isn't supported until NDK r12b per +// https://developer.android.com/ndk/downloads/revision_history.html +// Since NDK r16, `__NDK_MAJOR__` and `__NDK_MINOR__` are defined in +// . For NDK < r16, users should define these macros, +// e.g. `-D__NDK_MAJOR__=11 -D__NKD_MINOR__=0` for NDK r11. +#if defined(__ANDROID__) && defined(__clang__) +#if __has_include() +#include +#endif // __has_include() +#if defined(__ANDROID__) && defined(__clang__) && defined(__NDK_MAJOR__) && \ + defined(__NDK_MINOR__) && \ + ((__NDK_MAJOR__ < 12) || ((__NDK_MAJOR__ == 12) && (__NDK_MINOR__ < 1))) +#undef ABSL_HAVE_TLS +#undef ABSL_HAVE_THREAD_LOCAL +#endif +#endif // defined(__ANDROID__) && defined(__clang__) + +// ABSL_HAVE_INTRINSIC_INT128 +// +// Checks whether the __int128 compiler extension for a 128-bit integral type is +// supported. +// +// Note: __SIZEOF_INT128__ is defined by Clang and GCC when __int128 is +// supported, but we avoid using it in certain cases: +// * On Clang: +// * Building using Clang for Windows, where the Clang runtime library has +// 128-bit support only on LP64 architectures, but Windows is LLP64. +// * Building for aarch64, where __int128 exists but has exhibits a sporadic +// compiler crashing bug. +// * On Nvidia's nvcc: +// * nvcc also defines __GNUC__ and __SIZEOF_INT128__, but not all versions +// actually support __int128. +#ifdef ABSL_HAVE_INTRINSIC_INT128 +#error ABSL_HAVE_INTRINSIC_INT128 cannot be directly set +#elif defined(__SIZEOF_INT128__) +#if (defined(__clang__) && !defined(_WIN32) && !defined(__aarch64__)) || \ + (defined(__CUDACC__) && __CUDACC_VER_MAJOR__ >= 9) || \ + (defined(__GNUC__) && !defined(__clang__) && !defined(__CUDACC__)) +#define ABSL_HAVE_INTRINSIC_INT128 1 +#elif defined(__CUDACC__) +// __CUDACC_VER__ is a full version number before CUDA 9, and is defined to a +// string explaining that it has been removed starting with CUDA 9. We use +// nested #ifs because there is no short-circuiting in the preprocessor. +// NOTE: `__CUDACC__` could be undefined while `__CUDACC_VER__` is defined. +#if __CUDACC_VER__ >= 70000 +#define ABSL_HAVE_INTRINSIC_INT128 1 +#endif // __CUDACC_VER__ >= 70000 +#endif // defined(__CUDACC__) +#endif // ABSL_HAVE_INTRINSIC_INT128 + +// ABSL_HAVE_EXCEPTIONS +// +// Checks whether the compiler both supports and enables exceptions. Many +// compilers support a "no exceptions" mode that disables exceptions. +// +// Generally, when ABSL_HAVE_EXCEPTIONS is not defined: +// +// * Code using `throw` and `try` may not compile. +// * The `noexcept` specifier will still compile and behave as normal. +// * The `noexcept` operator may still return `false`. +// +// For further details, consult the compiler's documentation. +#ifdef ABSL_HAVE_EXCEPTIONS +#error ABSL_HAVE_EXCEPTIONS cannot be directly set. + +#elif defined(__clang__) +// TODO(calabrese) +// Switch to using __cpp_exceptions when we no longer support versions < 3.6. +// For details on this check, see: +// http://releases.llvm.org/3.6.0/tools/clang/docs/ReleaseNotes.html#the-exceptions-macro +#if defined(__EXCEPTIONS) && __has_feature(cxx_exceptions) +#define ABSL_HAVE_EXCEPTIONS 1 +#endif // defined(__EXCEPTIONS) && __has_feature(cxx_exceptions) + +// Handle remaining special cases and default to exceptions being supported. +#elif !(defined(__GNUC__) && (__GNUC__ < 5) && !defined(__EXCEPTIONS)) && \ + !(defined(__GNUC__) && (__GNUC__ >= 5) && !defined(__cpp_exceptions)) && \ + !(defined(_MSC_VER) && !defined(_CPPUNWIND)) +#define ABSL_HAVE_EXCEPTIONS 1 +#endif + +// ----------------------------------------------------------------------------- +// Platform Feature Checks +// ----------------------------------------------------------------------------- + +// Currently supported operating systems and associated preprocessor +// symbols: +// +// Linux and Linux-derived __linux__ +// Android __ANDROID__ (implies __linux__) +// Linux (non-Android) __linux__ && !__ANDROID__ +// Darwin (Mac OS X and iOS) __APPLE__ +// Akaros (http://akaros.org) __ros__ +// Windows _WIN32 +// NaCL __native_client__ +// AsmJS __asmjs__ +// WebAssembly __wasm__ +// Fuchsia __Fuchsia__ +// +// Note that since Android defines both __ANDROID__ and __linux__, one +// may probe for either Linux or Android by simply testing for __linux__. + +// ABSL_HAVE_MMAP +// +// Checks whether the platform has an mmap(2) implementation as defined in +// POSIX.1-2001. +#ifdef ABSL_HAVE_MMAP +#error ABSL_HAVE_MMAP cannot be directly set +#elif defined(__linux__) || defined(__APPLE__) || defined(__FreeBSD__) || \ + defined(__ros__) || defined(__native_client__) || defined(__asmjs__) || \ + defined(__wasm__) || defined(__Fuchsia__) || defined(__sun) || \ + defined(__ASYLO__) +#define ABSL_HAVE_MMAP 1 +#endif + +// ABSL_HAVE_PTHREAD_GETSCHEDPARAM +// +// Checks whether the platform implements the pthread_(get|set)schedparam(3) +// functions as defined in POSIX.1-2001. +#ifdef ABSL_HAVE_PTHREAD_GETSCHEDPARAM +#error ABSL_HAVE_PTHREAD_GETSCHEDPARAM cannot be directly set +#elif defined(__linux__) || defined(__APPLE__) || defined(__FreeBSD__) || \ + defined(__ros__) +#define ABSL_HAVE_PTHREAD_GETSCHEDPARAM 1 +#endif + +// ABSL_HAVE_SCHED_YIELD +// +// Checks whether the platform implements sched_yield(2) as defined in +// POSIX.1-2001. +#ifdef ABSL_HAVE_SCHED_YIELD +#error ABSL_HAVE_SCHED_YIELD cannot be directly set +#elif defined(__linux__) || defined(__ros__) || defined(__native_client__) +#define ABSL_HAVE_SCHED_YIELD 1 +#endif + +// ABSL_HAVE_SEMAPHORE_H +// +// Checks whether the platform supports the header and sem_open(3) +// family of functions as standardized in POSIX.1-2001. +// +// Note: While Apple provides for both iOS and macOS, it is +// explicitly deprecated and will cause build failures if enabled for those +// platforms. We side-step the issue by not defining it here for Apple +// platforms. +#ifdef ABSL_HAVE_SEMAPHORE_H +#error ABSL_HAVE_SEMAPHORE_H cannot be directly set +#elif defined(__linux__) || defined(__ros__) +#define ABSL_HAVE_SEMAPHORE_H 1 +#endif + +// ABSL_HAVE_ALARM +// +// Checks whether the platform supports the header and alarm(2) +// function as standardized in POSIX.1-2001. +#ifdef ABSL_HAVE_ALARM +#error ABSL_HAVE_ALARM cannot be directly set +#elif defined(__GOOGLE_GRTE_VERSION__) +// feature tests for Google's GRTE +#define ABSL_HAVE_ALARM 1 +#elif defined(__GLIBC__) +// feature test for glibc +#define ABSL_HAVE_ALARM 1 +#elif defined(_MSC_VER) +// feature tests for Microsoft's library +#elif defined(__EMSCRIPTEN__) +// emscripten doesn't support signals +#elif defined(__native_client__) +#else +// other standard libraries +#define ABSL_HAVE_ALARM 1 +#endif + +// ABSL_IS_LITTLE_ENDIAN +// ABSL_IS_BIG_ENDIAN +// +// Checks the endianness of the platform. +// +// Notes: uses the built in endian macros provided by GCC (since 4.6) and +// Clang (since 3.2); see +// https://gcc.gnu.org/onlinedocs/cpp/Common-Predefined-Macros.html. +// Otherwise, if _WIN32, assume little endian. Otherwise, bail with an error. +#if defined(ABSL_IS_BIG_ENDIAN) +#error "ABSL_IS_BIG_ENDIAN cannot be directly set." +#endif +#if defined(ABSL_IS_LITTLE_ENDIAN) +#error "ABSL_IS_LITTLE_ENDIAN cannot be directly set." +#endif + +#if (defined(__BYTE_ORDER__) && defined(__ORDER_LITTLE_ENDIAN__) && \ + __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__) +#define ABSL_IS_LITTLE_ENDIAN 1 +#elif defined(__BYTE_ORDER__) && defined(__ORDER_BIG_ENDIAN__) && \ + __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__ +#define ABSL_IS_BIG_ENDIAN 1 +#elif defined(_WIN32) +#define ABSL_IS_LITTLE_ENDIAN 1 +#else +#error "absl endian detection needs to be set up for your compiler" +#endif + +// ABSL_HAVE_STD_ANY +// +// Checks whether C++17 std::any is available by checking whether exists. +#ifdef ABSL_HAVE_STD_ANY +#error "ABSL_HAVE_STD_ANY cannot be directly set." +#endif + +#ifdef __has_include +#if __has_include() && __cplusplus >= 201703L +#define ABSL_HAVE_STD_ANY 1 +#endif +#endif + +// ABSL_HAVE_STD_OPTIONAL +// +// Checks whether C++17 std::optional is available. +#ifdef ABSL_HAVE_STD_OPTIONAL +#error "ABSL_HAVE_STD_OPTIONAL cannot be directly set." +#endif + +#ifdef __has_include +#if __has_include() && __cplusplus >= 201703L +#define ABSL_HAVE_STD_OPTIONAL 1 +#endif +#endif + +// ABSL_HAVE_STD_VARIANT +// +// Checks whether C++17 std::variant is available. +#ifdef ABSL_HAVE_STD_VARIANT +#error "ABSL_HAVE_STD_VARIANT cannot be directly set." +#endif + +#ifdef __has_include +#if __has_include() && __cplusplus >= 201703L +#define ABSL_HAVE_STD_VARIANT 1 +#endif +#endif + +// ABSL_HAVE_STD_STRING_VIEW +// +// Checks whether C++17 std::string_view is available. +#ifdef ABSL_HAVE_STD_STRING_VIEW +#error "ABSL_HAVE_STD_STRING_VIEW cannot be directly set." +#endif + +#ifdef __has_include +#if __has_include() && __cplusplus >= 201703L +#define ABSL_HAVE_STD_STRING_VIEW 1 +#endif +#endif + +// For MSVC, `__has_include` is supported in VS 2017 15.3, which is later than +// the support for , , , . So we use +// _MSC_VER to check whether we have VS 2017 RTM (when , , +// , is implemented) or higher. Also, `__cplusplus` is +// not correctly set by MSVC, so we use `_MSVC_LANG` to check the language +// version. +// TODO(zhangxy): fix tests before enabling aliasing for `std::any`. +#if defined(_MSC_VER) && _MSC_VER >= 1910 && \ + ((defined(_MSVC_LANG) && _MSVC_LANG > 201402) || __cplusplus > 201402) +// #define ABSL_HAVE_STD_ANY 1 +#define ABSL_HAVE_STD_OPTIONAL 1 +#define ABSL_HAVE_STD_VARIANT 1 +#define ABSL_HAVE_STD_STRING_VIEW 1 +#endif + +// In debug mode, MSVC 2017's std::variant throws a EXCEPTION_ACCESS_VIOLATION +// SEH exception from emplace for variant when constructing the +// struct can throw. This defeats some of variant_test and +// variant_exception_safety_test. +#if defined(_MSC_VER) && _MSC_VER >= 1700 && defined(_DEBUG) +#define ABSL_INTERNAL_MSVC_2017_DBG_MODE +#endif + +#endif // ABSL_BASE_CONFIG_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/atomic_hook.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/atomic_hook.h new file mode 100644 index 000000000..b458511b0 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/atomic_hook.h @@ -0,0 +1,165 @@ +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// + +#ifndef ABSL_BASE_INTERNAL_ATOMIC_HOOK_H_ +#define ABSL_BASE_INTERNAL_ATOMIC_HOOK_H_ + +#include +#include +#include +#include + +#ifdef _MSC_FULL_VER +#define ABSL_HAVE_WORKING_ATOMIC_POINTER 0 +#else +#define ABSL_HAVE_WORKING_ATOMIC_POINTER 1 +#endif + +namespace absl { +namespace base_internal { + +template +class AtomicHook; + +// AtomicHook is a helper class, templatized on a raw function pointer type, for +// implementing Abseil customization hooks. It is a callable object that +// dispatches to the registered hook. +// +// A default constructed object performs a no-op (and returns a default +// constructed object) if no hook has been registered. +// +// Hooks can be pre-registered via constant initialization, for example, +// ABSL_CONST_INIT static AtomicHook my_hook(DefaultAction); +// and then changed at runtime via a call to Store(). +// +// Reads and writes guarantee memory_order_acquire/memory_order_release +// semantics. +template +class AtomicHook { + public: + using FnPtr = ReturnType (*)(Args...); + + // Constructs an object that by default performs a no-op (and + // returns a default constructed object) when no hook as been registered. + constexpr AtomicHook() : AtomicHook(DummyFunction) {} + + // Constructs an object that by default dispatches to/returns the + // pre-registered default_fn when no hook has been registered at runtime. +#if ABSL_HAVE_WORKING_ATOMIC_POINTER + explicit constexpr AtomicHook(FnPtr default_fn) + : hook_(default_fn), default_fn_(default_fn) {} +#else + explicit constexpr AtomicHook(FnPtr default_fn) + : hook_(kUninitialized), default_fn_(default_fn) {} +#endif + + // Stores the provided function pointer as the value for this hook. + // + // This is intended to be called once. Multiple calls are legal only if the + // same function pointer is provided for each call. The store is implemented + // as a memory_order_release operation, and read accesses are implemented as + // memory_order_acquire. + void Store(FnPtr fn) { + bool success = DoStore(fn); + static_cast(success); + assert(success); + } + + // Invokes the registered callback. If no callback has yet been registered, a + // default-constructed object of the appropriate type is returned instead. + template + ReturnType operator()(CallArgs&&... args) const { + return DoLoad()(std::forward(args)...); + } + + // Returns the registered callback, or nullptr if none has been registered. + // Useful if client code needs to conditionalize behavior based on whether a + // callback was registered. + // + // Note that atomic_hook.Load()() and atomic_hook() have different semantics: + // operator()() will perform a no-op if no callback was registered, while + // Load()() will dereference a null function pointer. Prefer operator()() to + // Load()() unless you must conditionalize behavior on whether a hook was + // registered. + FnPtr Load() const { + FnPtr ptr = DoLoad(); + return (ptr == DummyFunction) ? nullptr : ptr; + } + + private: + static ReturnType DummyFunction(Args...) { + return ReturnType(); + } + + // Current versions of MSVC (as of September 2017) have a broken + // implementation of std::atomic: Its constructor attempts to do the + // equivalent of a reinterpret_cast in a constexpr context, which is not + // allowed. + // + // This causes an issue when building with LLVM under Windows. To avoid this, + // we use a less-efficient, intptr_t-based implementation on Windows. +#if ABSL_HAVE_WORKING_ATOMIC_POINTER + // Return the stored value, or DummyFunction if no value has been stored. + FnPtr DoLoad() const { return hook_.load(std::memory_order_acquire); } + + // Store the given value. Returns false if a different value was already + // stored to this object. + bool DoStore(FnPtr fn) { + assert(fn); + FnPtr expected = default_fn_; + const bool store_succeeded = hook_.compare_exchange_strong( + expected, fn, std::memory_order_acq_rel, std::memory_order_acquire); + const bool same_value_already_stored = (expected == fn); + return store_succeeded || same_value_already_stored; + } + + std::atomic hook_; +#else // !ABSL_HAVE_WORKING_ATOMIC_POINTER + // Use a sentinel value unlikely to be the address of an actual function. + static constexpr intptr_t kUninitialized = 0; + + static_assert(sizeof(intptr_t) >= sizeof(FnPtr), + "intptr_t can't contain a function pointer"); + + FnPtr DoLoad() const { + const intptr_t value = hook_.load(std::memory_order_acquire); + if (value == kUninitialized) { + return default_fn_; + } + return reinterpret_cast(value); + } + + bool DoStore(FnPtr fn) { + assert(fn); + const auto value = reinterpret_cast(fn); + intptr_t expected = kUninitialized; + const bool store_succeeded = hook_.compare_exchange_strong( + expected, value, std::memory_order_acq_rel, std::memory_order_acquire); + const bool same_value_already_stored = (expected == value); + return store_succeeded || same_value_already_stored; + } + + std::atomic hook_; +#endif + + const FnPtr default_fn_; +}; + +#undef ABSL_HAVE_WORKING_ATOMIC_POINTER + +} // namespace base_internal +} // namespace absl + +#endif // ABSL_BASE_INTERNAL_ATOMIC_HOOK_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/identity.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/identity.h new file mode 100644 index 000000000..a1a5d70a8 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/identity.h @@ -0,0 +1,33 @@ +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// + +#ifndef ABSL_BASE_INTERNAL_IDENTITY_H_ +#define ABSL_BASE_INTERNAL_IDENTITY_H_ + +namespace absl { +namespace internal { + +template +struct identity { + typedef T type; +}; + +template +using identity_t = typename identity::type; + +} // namespace internal +} // namespace absl + +#endif // ABSL_BASE_INTERNAL_IDENTITY_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/inline_variable.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/inline_variable.h new file mode 100644 index 000000000..f7bb8c565 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/inline_variable.h @@ -0,0 +1,107 @@ +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +#ifndef ABSL_BASE_INTERNAL_INLINE_VARIABLE_EMULATION_H_ +#define ABSL_BASE_INTERNAL_INLINE_VARIABLE_EMULATION_H_ + +#include + +#include "absl/base/internal/identity.h" + +// File: +// This file define a macro that allows the creation of or emulation of C++17 +// inline variables based on whether or not the feature is supported. + +//////////////////////////////////////////////////////////////////////////////// +// Macro: ABSL_INTERNAL_INLINE_CONSTEXPR(type, name, init) +// +// Description: +// Expands to the equivalent of an inline constexpr instance of the specified +// `type` and `name`, initialized to the value `init`. If the compiler being +// used is detected as supporting actual inline variables as a language +// feature, then the macro expands to an actual inline variable definition. +// +// Requires: +// `type` is a type that is usable in an extern variable declaration. +// +// Requires: `name` is a valid identifier +// +// Requires: +// `init` is an expression that can be used in the following definition: +// constexpr type name = init; +// +// Usage: +// +// // Equivalent to: `inline constexpr size_t variant_npos = -1;` +// ABSL_INTERNAL_INLINE_CONSTEXPR(size_t, variant_npos, -1); +// +// Differences in implementation: +// For a direct, language-level inline variable, decltype(name) will be the +// type that was specified along with const qualification, whereas for +// emulated inline variables, decltype(name) may be different (in practice +// it will likely be a reference type). +//////////////////////////////////////////////////////////////////////////////// + +#ifdef __cpp_inline_variables + +// Clang's -Wmissing-variable-declarations option erroneously warned that +// inline constexpr objects need to be pre-declared. This has now been fixed, +// but we will need to support this workaround for people building with older +// versions of clang. +// +// Bug: https://bugs.llvm.org/show_bug.cgi?id=35862 +// +// Note: +// identity_t is used here so that the const and name are in the +// appropriate place for pointer types, reference types, function pointer +// types, etc.. +#if defined(__clang__) +#define ABSL_INTERNAL_EXTERN_DECL(type, name) \ + extern const ::absl::internal::identity_t name; +#else // Otherwise, just define the macro to do nothing. +#define ABSL_INTERNAL_EXTERN_DECL(type, name) +#endif // defined(__clang__) + +// See above comment at top of file for details. +#define ABSL_INTERNAL_INLINE_CONSTEXPR(type, name, init) \ + ABSL_INTERNAL_EXTERN_DECL(type, name) \ + inline constexpr ::absl::internal::identity_t name = init + +#else + +// See above comment at top of file for details. +// +// Note: +// identity_t is used here so that the const and name are in the +// appropriate place for pointer types, reference types, function pointer +// types, etc.. +#define ABSL_INTERNAL_INLINE_CONSTEXPR(var_type, name, init) \ + template \ + struct AbslInternalInlineVariableHolder##name { \ + static constexpr ::absl::internal::identity_t kInstance = init; \ + }; \ + \ + template \ + constexpr ::absl::internal::identity_t \ + AbslInternalInlineVariableHolder##name::kInstance; \ + \ + static constexpr const ::absl::internal::identity_t& \ + name = /* NOLINT */ \ + AbslInternalInlineVariableHolder##name<>::kInstance; \ + static_assert(sizeof(void (*)(decltype(name))) != 0, \ + "Silence unused variable warnings.") + +#endif // __cpp_inline_variables + +#endif // ABSL_BASE_INTERNAL_INLINE_VARIABLE_EMULATION_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/invoke.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/invoke.h new file mode 100644 index 000000000..8c3f4f606 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/invoke.h @@ -0,0 +1,188 @@ +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// absl::base_internal::Invoke(f, args...) is an implementation of +// INVOKE(f, args...) from section [func.require] of the C++ standard. +// +// [func.require] +// Define INVOKE (f, t1, t2, ..., tN) as follows: +// 1. (t1.*f)(t2, ..., tN) when f is a pointer to a member function of a class T +// and t1 is an object of type T or a reference to an object of type T or a +// reference to an object of a type derived from T; +// 2. ((*t1).*f)(t2, ..., tN) when f is a pointer to a member function of a +// class T and t1 is not one of the types described in the previous item; +// 3. t1.*f when N == 1 and f is a pointer to member data of a class T and t1 is +// an object of type T or a reference to an object of type T or a reference +// to an object of a type derived from T; +// 4. (*t1).*f when N == 1 and f is a pointer to member data of a class T and t1 +// is not one of the types described in the previous item; +// 5. f(t1, t2, ..., tN) in all other cases. +// +// The implementation is SFINAE-friendly: substitution failure within Invoke() +// isn't an error. + +#ifndef ABSL_BASE_INTERNAL_INVOKE_H_ +#define ABSL_BASE_INTERNAL_INVOKE_H_ + +#include +#include +#include + +// The following code is internal implementation detail. See the comment at the +// top of this file for the API documentation. + +namespace absl { +namespace base_internal { + +// The five classes below each implement one of the clauses from the definition +// of INVOKE. The inner class template Accept checks whether the +// clause is applicable; static function template Invoke(f, args...) does the +// invocation. +// +// By separating the clause selection logic from invocation we make sure that +// Invoke() does exactly what the standard says. + +template +struct StrippedAccept { + template + struct Accept : Derived::template AcceptImpl::type>::type...> {}; +}; + +// (t1.*f)(t2, ..., tN) when f is a pointer to a member function of a class T +// and t1 is an object of type T or a reference to an object of type T or a +// reference to an object of a type derived from T. +struct MemFunAndRef : StrippedAccept { + template + struct AcceptImpl : std::false_type {}; + + template + struct AcceptImpl + : std::is_base_of {}; + + template + struct AcceptImpl + : std::is_base_of {}; + + template + static decltype((std::declval().* + std::declval())(std::declval()...)) + Invoke(MemFun&& mem_fun, Obj&& obj, Args&&... args) { + return (std::forward(obj).* + std::forward(mem_fun))(std::forward(args)...); + } +}; + +// ((*t1).*f)(t2, ..., tN) when f is a pointer to a member function of a +// class T and t1 is not one of the types described in the previous item. +struct MemFunAndPtr : StrippedAccept { + template + struct AcceptImpl : std::false_type {}; + + template + struct AcceptImpl + : std::integral_constant::value> {}; + + template + struct AcceptImpl + : std::integral_constant::value> {}; + + template + static decltype(((*std::declval()).* + std::declval())(std::declval()...)) + Invoke(MemFun&& mem_fun, Ptr&& ptr, Args&&... args) { + return ((*std::forward(ptr)).* + std::forward(mem_fun))(std::forward(args)...); + } +}; + +// t1.*f when N == 1 and f is a pointer to member data of a class T and t1 is +// an object of type T or a reference to an object of type T or a reference +// to an object of a type derived from T. +struct DataMemAndRef : StrippedAccept { + template + struct AcceptImpl : std::false_type {}; + + template + struct AcceptImpl : std::is_base_of {}; + + template + static decltype(std::declval().*std::declval()) Invoke( + DataMem&& data_mem, Ref&& ref) { + return std::forward(ref).*std::forward(data_mem); + } +}; + +// (*t1).*f when N == 1 and f is a pointer to member data of a class T and t1 +// is not one of the types described in the previous item. +struct DataMemAndPtr : StrippedAccept { + template + struct AcceptImpl : std::false_type {}; + + template + struct AcceptImpl + : std::integral_constant::value> {}; + + template + static decltype((*std::declval()).*std::declval()) Invoke( + DataMem&& data_mem, Ptr&& ptr) { + return (*std::forward(ptr)).*std::forward(data_mem); + } +}; + +// f(t1, t2, ..., tN) in all other cases. +struct Callable { + // Callable doesn't have Accept because it's the last clause that gets picked + // when none of the previous clauses are applicable. + template + static decltype(std::declval()(std::declval()...)) Invoke( + F&& f, Args&&... args) { + return std::forward(f)(std::forward(args)...); + } +}; + +// Resolves to the first matching clause. +template +struct Invoker { + typedef typename std::conditional< + MemFunAndRef::Accept::value, MemFunAndRef, + typename std::conditional< + MemFunAndPtr::Accept::value, MemFunAndPtr, + typename std::conditional< + DataMemAndRef::Accept::value, DataMemAndRef, + typename std::conditional::value, + DataMemAndPtr, Callable>::type>::type>:: + type>::type type; +}; + +// The result type of Invoke. +template +using InvokeT = decltype(Invoker::type::Invoke( + std::declval(), std::declval()...)); + +// Invoke(f, args...) is an implementation of INVOKE(f, args...) from section +// [func.require] of the C++ standard. +template +InvokeT Invoke(F&& f, Args&&... args) { + return Invoker::type::Invoke(std::forward(f), + std::forward(args)...); +} +} // namespace base_internal +} // namespace absl + +#endif // ABSL_BASE_INTERNAL_INVOKE_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/raw_logging.cc b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/raw_logging.cc new file mode 100644 index 000000000..d9485a66c --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/raw_logging.cc @@ -0,0 +1,234 @@ +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +#include "absl/base/internal/raw_logging.h" + +#include +#include +#include +#include +#include + +#include "absl/base/attributes.h" +#include "absl/base/config.h" +#include "absl/base/internal/atomic_hook.h" +#include "absl/base/log_severity.h" + +// We know how to perform low-level writes to stderr in POSIX and Windows. For +// these platforms, we define the token ABSL_LOW_LEVEL_WRITE_SUPPORTED. +// Much of raw_logging.cc becomes a no-op when we can't output messages, +// although a FATAL ABSL_RAW_LOG message will still abort the process. + +// ABSL_HAVE_POSIX_WRITE is defined when the platform provides posix write() +// (as from unistd.h) +// +// This preprocessor token is also defined in raw_io.cc. If you need to copy +// this, consider moving both to config.h instead. +#if defined(__linux__) || defined(__APPLE__) || defined(__FreeBSD__) || \ + defined(__Fuchsia__) || defined(__native_client__) +#include + + +#define ABSL_HAVE_POSIX_WRITE 1 +#define ABSL_LOW_LEVEL_WRITE_SUPPORTED 1 +#else +#undef ABSL_HAVE_POSIX_WRITE +#endif + +// ABSL_HAVE_SYSCALL_WRITE is defined when the platform provides the syscall +// syscall(SYS_write, /*int*/ fd, /*char* */ buf, /*size_t*/ len); +// for low level operations that want to avoid libc. +#if (defined(__linux__) || defined(__FreeBSD__)) && !defined(__ANDROID__) +#include +#define ABSL_HAVE_SYSCALL_WRITE 1 +#define ABSL_LOW_LEVEL_WRITE_SUPPORTED 1 +#else +#undef ABSL_HAVE_SYSCALL_WRITE +#endif + +#ifdef _WIN32 +#include + +#define ABSL_HAVE_RAW_IO 1 +#define ABSL_LOW_LEVEL_WRITE_SUPPORTED 1 +#else +#undef ABSL_HAVE_RAW_IO +#endif + +// TODO(gfalcon): We want raw-logging to work on as many platforms as possible. +// Explicitly #error out when not ABSL_LOW_LEVEL_WRITE_SUPPORTED, except for a +// whitelisted set of platforms for which we expect not to be able to raw log. + +ABSL_CONST_INIT static absl::base_internal::AtomicHook< + absl::raw_logging_internal::LogPrefixHook> log_prefix_hook; +ABSL_CONST_INIT static absl::base_internal::AtomicHook< + absl::raw_logging_internal::AbortHook> abort_hook; + +#ifdef ABSL_LOW_LEVEL_WRITE_SUPPORTED +static const char kTruncated[] = " ... (message truncated)\n"; + +// sprintf the format to the buffer, adjusting *buf and *size to reflect the +// consumed bytes, and return whether the message fit without truncation. If +// truncation occurred, if possible leave room in the buffer for the message +// kTruncated[]. +inline static bool VADoRawLog(char** buf, int* size, const char* format, + va_list ap) ABSL_PRINTF_ATTRIBUTE(3, 0); +inline static bool VADoRawLog(char** buf, int* size, + const char* format, va_list ap) { + int n = vsnprintf(*buf, *size, format, ap); + bool result = true; + if (n < 0 || n > *size) { + result = false; + if (static_cast(*size) > sizeof(kTruncated)) { + n = *size - sizeof(kTruncated); // room for truncation message + } else { + n = 0; // no room for truncation message + } + } + *size -= n; + *buf += n; + return result; +} +#endif // ABSL_LOW_LEVEL_WRITE_SUPPORTED + +static constexpr int kLogBufSize = 3000; + +namespace { + +// CAVEAT: vsnprintf called from *DoRawLog below has some (exotic) code paths +// that invoke malloc() and getenv() that might acquire some locks. + +// Helper for RawLog below. +// *DoRawLog writes to *buf of *size and move them past the written portion. +// It returns true iff there was no overflow or error. +bool DoRawLog(char** buf, int* size, const char* format, ...) + ABSL_PRINTF_ATTRIBUTE(3, 4); +bool DoRawLog(char** buf, int* size, const char* format, ...) { + va_list ap; + va_start(ap, format); + int n = vsnprintf(*buf, *size, format, ap); + va_end(ap); + if (n < 0 || n > *size) return false; + *size -= n; + *buf += n; + return true; +} + +void RawLogVA(absl::LogSeverity severity, const char* file, int line, + const char* format, va_list ap) ABSL_PRINTF_ATTRIBUTE(4, 0); +void RawLogVA(absl::LogSeverity severity, const char* file, int line, + const char* format, va_list ap) { + char buffer[kLogBufSize]; + char* buf = buffer; + int size = sizeof(buffer); +#ifdef ABSL_LOW_LEVEL_WRITE_SUPPORTED + bool enabled = true; +#else + bool enabled = false; +#endif + +#ifdef ABSL_MIN_LOG_LEVEL + if (severity < static_cast(ABSL_MIN_LOG_LEVEL) && + severity < absl::LogSeverity::kFatal) { + enabled = false; + } +#endif + + auto log_prefix_hook_ptr = log_prefix_hook.Load(); + if (log_prefix_hook_ptr) { + enabled = log_prefix_hook_ptr(severity, file, line, &buf, &size); + } else { + if (enabled) { + DoRawLog(&buf, &size, "[%s : %d] RAW: ", file, line); + } + } + const char* const prefix_end = buf; + +#ifdef ABSL_LOW_LEVEL_WRITE_SUPPORTED + if (enabled) { + bool no_chop = VADoRawLog(&buf, &size, format, ap); + if (no_chop) { + DoRawLog(&buf, &size, "\n"); + } else { + DoRawLog(&buf, &size, "%s", kTruncated); + } + absl::raw_logging_internal::SafeWriteToStderr(buffer, strlen(buffer)); + } +#else + static_cast(format); + static_cast(ap); +#endif + + // Abort the process after logging a FATAL message, even if the output itself + // was suppressed. + if (severity == absl::LogSeverity::kFatal) { + abort_hook(file, line, buffer, prefix_end, buffer + kLogBufSize); + abort(); + } +} + +} // namespace + +namespace absl { +namespace raw_logging_internal { +void SafeWriteToStderr(const char *s, size_t len) { +#if defined(ABSL_HAVE_SYSCALL_WRITE) + syscall(SYS_write, STDERR_FILENO, s, len); +#elif defined(ABSL_HAVE_POSIX_WRITE) + write(STDERR_FILENO, s, len); +#elif defined(ABSL_HAVE_RAW_IO) + _write(/* stderr */ 2, s, len); +#else + // stderr logging unsupported on this platform + (void) s; + (void) len; +#endif +} + +void RawLog(absl::LogSeverity severity, const char* file, int line, + const char* format, ...) ABSL_PRINTF_ATTRIBUTE(4, 5); +void RawLog(absl::LogSeverity severity, const char* file, int line, + const char* format, ...) { + va_list ap; + va_start(ap, format); + RawLogVA(severity, file, line, format, ap); + va_end(ap); +} + +// Non-formatting version of RawLog(). +// +// TODO(gfalcon): When string_view no longer depends on base, change this +// interface to take its message as a string_view instead. +static void DefaultInternalLog(absl::LogSeverity severity, const char* file, + int line, const std::string& message) { + RawLog(severity, file, line, "%s", message.c_str()); +} + +bool RawLoggingFullySupported() { +#ifdef ABSL_LOW_LEVEL_WRITE_SUPPORTED + return true; +#else // !ABSL_LOW_LEVEL_WRITE_SUPPORTED + return false; +#endif // !ABSL_LOW_LEVEL_WRITE_SUPPORTED +} + +ABSL_CONST_INIT absl::base_internal::AtomicHook + internal_log_function(DefaultInternalLog); + +void RegisterInternalLogFunction(InternalLogFunction func) { + internal_log_function.Store(func); +} + +} // namespace raw_logging_internal +} // namespace absl diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/raw_logging.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/raw_logging.h new file mode 100644 index 000000000..79a7bb9b2 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/raw_logging.h @@ -0,0 +1,180 @@ +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Thread-safe logging routines that do not allocate any memory or +// acquire any locks, and can therefore be used by low-level memory +// allocation, synchronization, and signal-handling code. + +#ifndef ABSL_BASE_INTERNAL_RAW_LOGGING_H_ +#define ABSL_BASE_INTERNAL_RAW_LOGGING_H_ + +#include + +#include "absl/base/attributes.h" +#include "absl/base/internal/atomic_hook.h" +#include "absl/base/log_severity.h" +#include "absl/base/macros.h" +#include "absl/base/port.h" + +// This is similar to LOG(severity) << format..., but +// * it is to be used ONLY by low-level modules that can't use normal LOG() +// * it is designed to be a low-level logger that does not allocate any +// memory and does not need any locks, hence: +// * it logs straight and ONLY to STDERR w/o buffering +// * it uses an explicit printf-format and arguments list +// * it will silently chop off really long message strings +// Usage example: +// ABSL_RAW_LOG(ERROR, "Failed foo with %i: %s", status, error); +// This will print an almost standard log line like this to stderr only: +// E0821 211317 file.cc:123] RAW: Failed foo with 22: bad_file +#define ABSL_RAW_LOG(severity, ...) \ + do { \ + constexpr const char* absl_raw_logging_internal_basename = \ + ::absl::raw_logging_internal::Basename(__FILE__, \ + sizeof(__FILE__) - 1); \ + ::absl::raw_logging_internal::RawLog(ABSL_RAW_LOGGING_INTERNAL_##severity, \ + absl_raw_logging_internal_basename, \ + __LINE__, __VA_ARGS__); \ + } while (0) + +// Similar to CHECK(condition) << message, but for low-level modules: +// we use only ABSL_RAW_LOG that does not allocate memory. +// We do not want to provide args list here to encourage this usage: +// if (!cond) ABSL_RAW_LOG(FATAL, "foo ...", hard_to_compute_args); +// so that the args are not computed when not needed. +#define ABSL_RAW_CHECK(condition, message) \ + do { \ + if (ABSL_PREDICT_FALSE(!(condition))) { \ + ABSL_RAW_LOG(FATAL, "Check %s failed: %s", #condition, message); \ + } \ + } while (0) + +// ABSL_INTERNAL_LOG and ABSL_INTERNAL_CHECK work like the RAW variants above, +// except that if the richer log library is linked into the binary, we dispatch +// to that instead. This is potentially useful for internal logging and +// assertions, where we are using RAW_LOG neither for its async-signal-safety +// nor for its non-allocating nature, but rather because raw logging has very +// few other dependencies. +// +// The API is a subset of the above: each macro only takes two arguments. Use +// StrCat if you need to build a richer message. +#define ABSL_INTERNAL_LOG(severity, message) \ + do { \ + constexpr const char* absl_raw_logging_internal_basename = \ + ::absl::raw_logging_internal::Basename(__FILE__, \ + sizeof(__FILE__) - 1); \ + ::absl::raw_logging_internal::internal_log_function( \ + ABSL_RAW_LOGGING_INTERNAL_##severity, \ + absl_raw_logging_internal_basename, __LINE__, message); \ + } while (0) + +#define ABSL_INTERNAL_CHECK(condition, message) \ + do { \ + if (ABSL_PREDICT_FALSE(!(condition))) { \ + std::string death_message = "Check " #condition " failed: "; \ + death_message += std::string(message); \ + ABSL_INTERNAL_LOG(FATAL, death_message); \ + } \ + } while (0) + +#define ABSL_RAW_LOGGING_INTERNAL_INFO ::absl::LogSeverity::kInfo +#define ABSL_RAW_LOGGING_INTERNAL_WARNING ::absl::LogSeverity::kWarning +#define ABSL_RAW_LOGGING_INTERNAL_ERROR ::absl::LogSeverity::kError +#define ABSL_RAW_LOGGING_INTERNAL_FATAL ::absl::LogSeverity::kFatal +#define ABSL_RAW_LOGGING_INTERNAL_LEVEL(severity) \ + ::absl::NormalizeLogSeverity(severity) + +namespace absl { +namespace raw_logging_internal { + +// Helper function to implement ABSL_RAW_LOG +// Logs format... at "severity" level, reporting it +// as called from file:line. +// This does not allocate memory or acquire locks. +void RawLog(absl::LogSeverity severity, const char* file, int line, + const char* format, ...) ABSL_PRINTF_ATTRIBUTE(4, 5); + +// Writes the provided buffer directly to stderr, in a safe, low-level manner. +// +// In POSIX this means calling write(), which is async-signal safe and does +// not malloc. If the platform supports the SYS_write syscall, we invoke that +// directly to side-step any libc interception. +void SafeWriteToStderr(const char *s, size_t len); + +// compile-time function to get the "base" filename, that is, the part of +// a filename after the last "/" or "\" path separator. The search starts at +// the end of the string; the second parameter is the length of the string. +constexpr const char* Basename(const char* fname, int offset) { + return offset == 0 || fname[offset - 1] == '/' || fname[offset - 1] == '\\' + ? fname + offset + : Basename(fname, offset - 1); +} + +// For testing only. +// Returns true if raw logging is fully supported. When it is not +// fully supported, no messages will be emitted, but a log at FATAL +// severity will cause an abort. +// +// TODO(gfalcon): Come up with a better name for this method. +bool RawLoggingFullySupported(); + +// Function type for a raw_logging customization hook for suppressing messages +// by severity, and for writing custom prefixes on non-suppressed messages. +// +// The installed hook is called for every raw log invocation. The message will +// be logged to stderr only if the hook returns true. FATAL errors will cause +// the process to abort, even if writing to stderr is suppressed. The hook is +// also provided with an output buffer, where it can write a custom log message +// prefix. +// +// The raw_logging system does not allocate memory or grab locks. User-provided +// hooks must avoid these operations, and must not throw exceptions. +// +// 'severity' is the severity level of the message being written. +// 'file' and 'line' are the file and line number where the ABSL_RAW_LOG macro +// was located. +// 'buffer' and 'buf_size' are pointers to the buffer and buffer size. If the +// hook writes a prefix, it must increment *buffer and decrement *buf_size +// accordingly. +using LogPrefixHook = bool (*)(absl::LogSeverity severity, const char* file, + int line, char** buffer, int* buf_size); + +// Function type for a raw_logging customization hook called to abort a process +// when a FATAL message is logged. If the provided AbortHook() returns, the +// logging system will call abort(). +// +// 'file' and 'line' are the file and line number where the ABSL_RAW_LOG macro +// was located. +// The null-terminated logged message lives in the buffer between 'buf_start' +// and 'buf_end'. 'prefix_end' points to the first non-prefix character of the +// buffer (as written by the LogPrefixHook.) +using AbortHook = void (*)(const char* file, int line, const char* buf_start, + const char* prefix_end, const char* buf_end); + +// Internal logging function for ABSL_INTERNAL_LOG to dispatch to. +// +// TODO(gfalcon): When string_view no longer depends on base, change this +// interface to take its message as a string_view instead. +using InternalLogFunction = void (*)(absl::LogSeverity severity, + const char* file, int line, + const std::string& message); + +extern base_internal::AtomicHook internal_log_function; + +void RegisterInternalLogFunction(InternalLogFunction func); + +} // namespace raw_logging_internal +} // namespace absl + +#endif // ABSL_BASE_INTERNAL_RAW_LOGGING_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/throw_delegate.cc b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/throw_delegate.cc new file mode 100644 index 000000000..46dc573cf --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/throw_delegate.cc @@ -0,0 +1,106 @@ +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +#include "absl/base/internal/throw_delegate.h" + +#include +#include +#include +#include +#include "absl/base/config.h" +#include "absl/base/internal/raw_logging.h" + +namespace absl { +namespace base_internal { + +namespace { +template +[[noreturn]] void Throw(const T& error) { +#ifdef ABSL_HAVE_EXCEPTIONS + throw error; +#else + ABSL_RAW_LOG(ERROR, "%s", error.what()); + abort(); +#endif +} +} // namespace + +void ThrowStdLogicError(const std::string& what_arg) { + Throw(std::logic_error(what_arg)); +} +void ThrowStdLogicError(const char* what_arg) { + Throw(std::logic_error(what_arg)); +} +void ThrowStdInvalidArgument(const std::string& what_arg) { + Throw(std::invalid_argument(what_arg)); +} +void ThrowStdInvalidArgument(const char* what_arg) { + Throw(std::invalid_argument(what_arg)); +} + +void ThrowStdDomainError(const std::string& what_arg) { + Throw(std::domain_error(what_arg)); +} +void ThrowStdDomainError(const char* what_arg) { + Throw(std::domain_error(what_arg)); +} + +void ThrowStdLengthError(const std::string& what_arg) { + Throw(std::length_error(what_arg)); +} +void ThrowStdLengthError(const char* what_arg) { + Throw(std::length_error(what_arg)); +} + +void ThrowStdOutOfRange(const std::string& what_arg) { + Throw(std::out_of_range(what_arg)); +} +void ThrowStdOutOfRange(const char* what_arg) { + Throw(std::out_of_range(what_arg)); +} + +void ThrowStdRuntimeError(const std::string& what_arg) { + Throw(std::runtime_error(what_arg)); +} +void ThrowStdRuntimeError(const char* what_arg) { + Throw(std::runtime_error(what_arg)); +} + +void ThrowStdRangeError(const std::string& what_arg) { + Throw(std::range_error(what_arg)); +} +void ThrowStdRangeError(const char* what_arg) { + Throw(std::range_error(what_arg)); +} + +void ThrowStdOverflowError(const std::string& what_arg) { + Throw(std::overflow_error(what_arg)); +} +void ThrowStdOverflowError(const char* what_arg) { + Throw(std::overflow_error(what_arg)); +} + +void ThrowStdUnderflowError(const std::string& what_arg) { + Throw(std::underflow_error(what_arg)); +} +void ThrowStdUnderflowError(const char* what_arg) { + Throw(std::underflow_error(what_arg)); +} + +void ThrowStdBadFunctionCall() { Throw(std::bad_function_call()); } + +void ThrowStdBadAlloc() { Throw(std::bad_alloc()); } + +} // namespace base_internal +} // namespace absl diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/throw_delegate.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/throw_delegate.h new file mode 100644 index 000000000..70e2d7709 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/internal/throw_delegate.h @@ -0,0 +1,71 @@ +// +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// + +#ifndef ABSL_BASE_INTERNAL_THROW_DELEGATE_H_ +#define ABSL_BASE_INTERNAL_THROW_DELEGATE_H_ + +#include + +namespace absl { +namespace base_internal { + +// Helper functions that allow throwing exceptions consistently from anywhere. +// The main use case is for header-based libraries (eg templates), as they will +// be built by many different targets with their own compiler options. +// In particular, this will allow a safe way to throw exceptions even if the +// caller is compiled with -fno-exceptions. This is intended for implementing +// things like map<>::at(), which the standard documents as throwing an +// exception on error. +// +// Using other techniques like #if tricks could lead to ODR violations. +// +// You shouldn't use it unless you're writing code that you know will be built +// both with and without exceptions and you need to conform to an interface +// that uses exceptions. + +[[noreturn]] void ThrowStdLogicError(const std::string& what_arg); +[[noreturn]] void ThrowStdLogicError(const char* what_arg); +[[noreturn]] void ThrowStdInvalidArgument(const std::string& what_arg); +[[noreturn]] void ThrowStdInvalidArgument(const char* what_arg); +[[noreturn]] void ThrowStdDomainError(const std::string& what_arg); +[[noreturn]] void ThrowStdDomainError(const char* what_arg); +[[noreturn]] void ThrowStdLengthError(const std::string& what_arg); +[[noreturn]] void ThrowStdLengthError(const char* what_arg); +[[noreturn]] void ThrowStdOutOfRange(const std::string& what_arg); +[[noreturn]] void ThrowStdOutOfRange(const char* what_arg); +[[noreturn]] void ThrowStdRuntimeError(const std::string& what_arg); +[[noreturn]] void ThrowStdRuntimeError(const char* what_arg); +[[noreturn]] void ThrowStdRangeError(const std::string& what_arg); +[[noreturn]] void ThrowStdRangeError(const char* what_arg); +[[noreturn]] void ThrowStdOverflowError(const std::string& what_arg); +[[noreturn]] void ThrowStdOverflowError(const char* what_arg); +[[noreturn]] void ThrowStdUnderflowError(const std::string& what_arg); +[[noreturn]] void ThrowStdUnderflowError(const char* what_arg); + +[[noreturn]] void ThrowStdBadFunctionCall(); +[[noreturn]] void ThrowStdBadAlloc(); + +// ThrowStdBadArrayNewLength() cannot be consistently supported because +// std::bad_array_new_length is missing in libstdc++ until 4.9.0. +// https://gcc.gnu.org/onlinedocs/gcc-4.8.3/libstdc++/api/a01379_source.html +// https://gcc.gnu.org/onlinedocs/gcc-4.9.0/libstdc++/api/a01327_source.html +// libcxx (as of 3.2) and msvc (as of 2015) both have it. +// [[noreturn]] void ThrowStdBadArrayNewLength(); + +} // namespace base_internal +} // namespace absl + +#endif // ABSL_BASE_INTERNAL_THROW_DELEGATE_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/log_severity.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/log_severity.h new file mode 100644 index 000000000..5770d3629 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/log_severity.h @@ -0,0 +1,67 @@ +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// + +#ifndef ABSL_BASE_INTERNAL_LOG_SEVERITY_H_ +#define ABSL_BASE_INTERNAL_LOG_SEVERITY_H_ + +#include + +#include "absl/base/attributes.h" + +namespace absl { + +// Four severity levels are defined. Logging APIs should terminate the program +// when a message is logged at severity `kFatal`; the other levels have no +// special semantics. +enum class LogSeverity : int { + kInfo = 0, + kWarning = 1, + kError = 2, + kFatal = 3, +}; + +// Returns an iterable of all standard `absl::LogSeverity` values, ordered from +// least to most severe. +constexpr std::array LogSeverities() { + return {{absl::LogSeverity::kInfo, absl::LogSeverity::kWarning, + absl::LogSeverity::kError, absl::LogSeverity::kFatal}}; +} + +// Returns the all-caps string representation (e.g. "INFO") of the specified +// severity level if it is one of the normal levels and "UNKNOWN" otherwise. +constexpr const char* LogSeverityName(absl::LogSeverity s) { + return s == absl::LogSeverity::kInfo + ? "INFO" + : s == absl::LogSeverity::kWarning + ? "WARNING" + : s == absl::LogSeverity::kError + ? "ERROR" + : s == absl::LogSeverity::kFatal ? "FATAL" : "UNKNOWN"; +} + +// Values less than `kInfo` normalize to `kInfo`; values greater than `kFatal` +// normalize to `kError` (**NOT** `kFatal`). +constexpr absl::LogSeverity NormalizeLogSeverity(absl::LogSeverity s) { + return s < absl::LogSeverity::kInfo + ? absl::LogSeverity::kInfo + : s > absl::LogSeverity::kFatal ? absl::LogSeverity::kError : s; +} +constexpr absl::LogSeverity NormalizeLogSeverity(int s) { + return NormalizeLogSeverity(static_cast(s)); +} + +} // namespace absl + +#endif // ABSL_BASE_INTERNAL_LOG_SEVERITY_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/macros.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/macros.h new file mode 100644 index 000000000..9e7ab375e --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/macros.h @@ -0,0 +1,212 @@ +// +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ----------------------------------------------------------------------------- +// File: macros.h +// ----------------------------------------------------------------------------- +// +// This header file defines the set of language macros used within Abseil code. +// For the set of macros used to determine supported compilers and platforms, +// see absl/base/config.h instead. +// +// This code is compiled directly on many platforms, including client +// platforms like Windows, Mac, and embedded systems. Before making +// any changes here, make sure that you're not breaking any platforms. +// + +#ifndef ABSL_BASE_MACROS_H_ +#define ABSL_BASE_MACROS_H_ + +#include +#include + +#include "absl/base/port.h" + +// ABSL_ARRAYSIZE() +// +// Returns the number of elements in an array as a compile-time constant, which +// can be used in defining new arrays. If you use this macro on a pointer by +// mistake, you will get a compile-time error. +#define ABSL_ARRAYSIZE(array) \ + (sizeof(::absl::macros_internal::ArraySizeHelper(array))) + +namespace absl { +namespace macros_internal { +// Note: this internal template function declaration is used by ABSL_ARRAYSIZE. +// The function doesn't need a definition, as we only use its type. +template +auto ArraySizeHelper(const T (&array)[N]) -> char (&)[N]; +} // namespace macros_internal +} // namespace absl + +// kLinkerInitialized +// +// An enum used only as a constructor argument to indicate that a variable has +// static storage duration, and that the constructor should do nothing to its +// state. Use of this macro indicates to the reader that it is legal to +// declare a static instance of the class, provided the constructor is given +// the absl::base_internal::kLinkerInitialized argument. +// +// Normally, it is unsafe to declare a static variable that has a constructor or +// a destructor because invocation order is undefined. However, if the type can +// be zero-initialized (which the loader does for static variables) into a valid +// state and the type's destructor does not affect storage, then a constructor +// for static initialization can be declared. +// +// Example: +// // Declaration +// explicit MyClass(absl::base_internal:LinkerInitialized x) {} +// +// // Invocation +// static MyClass my_global(absl::base_internal::kLinkerInitialized); +namespace absl { +namespace base_internal { +enum LinkerInitialized { + kLinkerInitialized = 0, +}; +} // namespace base_internal +} // namespace absl + +// ABSL_FALLTHROUGH_INTENDED +// +// Annotates implicit fall-through between switch labels, allowing a case to +// indicate intentional fallthrough and turn off warnings about any lack of a +// `break` statement. The ABSL_FALLTHROUGH_INTENDED macro should be followed by +// a semicolon and can be used in most places where `break` can, provided that +// no statements exist between it and the next switch label. +// +// Example: +// +// switch (x) { +// case 40: +// case 41: +// if (truth_is_out_there) { +// ++x; +// ABSL_FALLTHROUGH_INTENDED; // Use instead of/along with annotations +// // in comments +// } else { +// return x; +// } +// case 42: +// ... +// +// Notes: when compiled with clang in C++11 mode, the ABSL_FALLTHROUGH_INTENDED +// macro is expanded to the [[clang::fallthrough]] attribute, which is analysed +// when performing switch labels fall-through diagnostic +// (`-Wimplicit-fallthrough`). See clang documentation on language extensions +// for details: +// http://clang.llvm.org/docs/AttributeReference.html#fallthrough-clang-fallthrough +// +// When used with unsupported compilers, the ABSL_FALLTHROUGH_INTENDED macro +// has no effect on diagnostics. In any case this macro has no effect on runtime +// behavior and performance of code. +#ifdef ABSL_FALLTHROUGH_INTENDED +#error "ABSL_FALLTHROUGH_INTENDED should not be defined." +#endif + +// TODO(zhangxy): Use c++17 standard [[fallthrough]] macro, when supported. +#if defined(__clang__) && defined(__has_warning) +#if __has_feature(cxx_attributes) && __has_warning("-Wimplicit-fallthrough") +#define ABSL_FALLTHROUGH_INTENDED [[clang::fallthrough]] +#endif +#elif defined(__GNUC__) && __GNUC__ >= 7 +#define ABSL_FALLTHROUGH_INTENDED [[gnu::fallthrough]] +#endif + +#ifndef ABSL_FALLTHROUGH_INTENDED +#define ABSL_FALLTHROUGH_INTENDED \ + do { \ + } while (0) +#endif + +// ABSL_DEPRECATED() +// +// Marks a deprecated class, struct, enum, function, method and variable +// declarations. The macro argument is used as a custom diagnostic message (e.g. +// suggestion of a better alternative). +// +// Example: +// +// class ABSL_DEPRECATED("Use Bar instead") Foo {...}; +// ABSL_DEPRECATED("Use Baz instead") void Bar() {...} +// +// Every usage of a deprecated entity will trigger a warning when compiled with +// clang's `-Wdeprecated-declarations` option. This option is turned off by +// default, but the warnings will be reported by clang-tidy. +#if defined(__clang__) && __cplusplus >= 201103L +#define ABSL_DEPRECATED(message) __attribute__((deprecated(message))) +#endif + +#ifndef ABSL_DEPRECATED +#define ABSL_DEPRECATED(message) +#endif + +// ABSL_BAD_CALL_IF() +// +// Used on a function overload to trap bad calls: any call that matches the +// overload will cause a compile-time error. This macro uses a clang-specific +// "enable_if" attribute, as described at +// http://clang.llvm.org/docs/AttributeReference.html#enable-if +// +// Overloads which use this macro should be bracketed by +// `#ifdef ABSL_BAD_CALL_IF`. +// +// Example: +// +// int isdigit(int c); +// #ifdef ABSL_BAD_CALL_IF +// int isdigit(int c) +// ABSL_BAD_CALL_IF(c <= -1 || c > 255, +// "'c' must have the value of an unsigned char or EOF"); +// #endif // ABSL_BAD_CALL_IF + +#if defined(__clang__) +# if __has_attribute(enable_if) +# define ABSL_BAD_CALL_IF(expr, msg) \ + __attribute__((enable_if(expr, "Bad call trap"), unavailable(msg))) +# endif +#endif + +// ABSL_ASSERT() +// +// In C++11, `assert` can't be used portably within constexpr functions. +// ABSL_ASSERT functions as a runtime assert but works in C++11 constexpr +// functions. Example: +// +// constexpr double Divide(double a, double b) { +// return ABSL_ASSERT(b != 0), a / b; +// } +// +// This macro is inspired by +// https://akrzemi1.wordpress.com/2017/05/18/asserts-in-constexpr-functions/ +#if defined(NDEBUG) +#define ABSL_ASSERT(expr) (false ? (void)(expr) : (void)0) +#else +#define ABSL_ASSERT(expr) \ + (ABSL_PREDICT_TRUE((expr)) ? (void)0 \ + : [] { assert(false && #expr); }()) // NOLINT +#endif + +#ifdef ABSL_HAVE_EXCEPTIONS +#define ABSL_INTERNAL_TRY try +#define ABSL_INTERNAL_CATCH_ANY catch (...) +#define ABSL_INTERNAL_RETHROW do { throw; } while (false) +#else // ABSL_HAVE_EXCEPTIONS +#define ABSL_INTERNAL_TRY if (true) +#define ABSL_INTERNAL_CATCH_ANY else if (false) +#define ABSL_INTERNAL_RETHROW do {} while (false) +#endif // ABSL_HAVE_EXCEPTIONS + +#endif // ABSL_BASE_MACROS_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/optimization.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/optimization.h new file mode 100644 index 000000000..2fddfc800 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/optimization.h @@ -0,0 +1,165 @@ +// +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ----------------------------------------------------------------------------- +// File: optimization.h +// ----------------------------------------------------------------------------- +// +// This header file defines portable macros for performance optimization. + +#ifndef ABSL_BASE_OPTIMIZATION_H_ +#define ABSL_BASE_OPTIMIZATION_H_ + +#include "absl/base/config.h" + +// ABSL_BLOCK_TAIL_CALL_OPTIMIZATION +// +// Instructs the compiler to avoid optimizing tail-call recursion. Use of this +// macro is useful when you wish to preserve the existing function order within +// a stack trace for logging, debugging, or profiling purposes. +// +// Example: +// +// int f() { +// int result = g(); +// ABSL_BLOCK_TAIL_CALL_OPTIMIZATION(); +// return result; +// } +#if defined(__pnacl__) +#define ABSL_BLOCK_TAIL_CALL_OPTIMIZATION() if (volatile int x = 0) { (void)x; } +#elif defined(__clang__) +// Clang will not tail call given inline volatile assembly. +#define ABSL_BLOCK_TAIL_CALL_OPTIMIZATION() __asm__ __volatile__("") +#elif defined(__GNUC__) +// GCC will not tail call given inline volatile assembly. +#define ABSL_BLOCK_TAIL_CALL_OPTIMIZATION() __asm__ __volatile__("") +#elif defined(_MSC_VER) +#include +// The __nop() intrinsic blocks the optimisation. +#define ABSL_BLOCK_TAIL_CALL_OPTIMIZATION() __nop() +#else +#define ABSL_BLOCK_TAIL_CALL_OPTIMIZATION() if (volatile int x = 0) { (void)x; } +#endif + +// ABSL_CACHELINE_SIZE +// +// Explicitly defines the size of the L1 cache for purposes of alignment. +// Setting the cacheline size allows you to specify that certain objects be +// aligned on a cacheline boundary with `ABSL_CACHELINE_ALIGNED` declarations. +// (See below.) +// +// NOTE: this macro should be replaced with the following C++17 features, when +// those are generally available: +// +// * `std::hardware_constructive_interference_size` +// * `std::hardware_destructive_interference_size` +// +// See http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2016/p0154r1.html +// for more information. +#if defined(__GNUC__) +// Cache line alignment +#if defined(__i386__) || defined(__x86_64__) +#define ABSL_CACHELINE_SIZE 64 +#elif defined(__powerpc64__) +#define ABSL_CACHELINE_SIZE 128 +#elif defined(__aarch64__) +// We would need to read special register ctr_el0 to find out L1 dcache size. +// This value is a good estimate based on a real aarch64 machine. +#define ABSL_CACHELINE_SIZE 64 +#elif defined(__arm__) +// Cache line sizes for ARM: These values are not strictly correct since +// cache line sizes depend on implementations, not architectures. There +// are even implementations with cache line sizes configurable at boot +// time. +#if defined(__ARM_ARCH_5T__) +#define ABSL_CACHELINE_SIZE 32 +#elif defined(__ARM_ARCH_7A__) +#define ABSL_CACHELINE_SIZE 64 +#endif +#endif + +#ifndef ABSL_CACHELINE_SIZE +// A reasonable default guess. Note that overestimates tend to waste more +// space, while underestimates tend to waste more time. +#define ABSL_CACHELINE_SIZE 64 +#endif + +// ABSL_CACHELINE_ALIGNED +// +// Indicates that the declared object be cache aligned using +// `ABSL_CACHELINE_SIZE` (see above). Cacheline aligning objects allows you to +// load a set of related objects in the L1 cache for performance improvements. +// Cacheline aligning objects properly allows constructive memory sharing and +// prevents destructive (or "false") memory sharing. +// +// NOTE: this macro should be replaced with usage of `alignas()` using +// `std::hardware_constructive_interference_size` and/or +// `std::hardware_destructive_interference_size` when available within C++17. +// +// See http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2016/p0154r1.html +// for more information. +// +// On some compilers, `ABSL_CACHELINE_ALIGNED` expands to +// `__attribute__((aligned(ABSL_CACHELINE_SIZE)))`. For compilers where this is +// not known to work, the macro expands to nothing. +// +// No further guarantees are made here. The result of applying the macro +// to variables and types is always implementation-defined. +// +// WARNING: It is easy to use this attribute incorrectly, even to the point +// of causing bugs that are difficult to diagnose, crash, etc. It does not +// of itself guarantee that objects are aligned to a cache line. +// +// Recommendations: +// +// 1) Consult compiler documentation; this comment is not kept in sync as +// toolchains evolve. +// 2) Verify your use has the intended effect. This often requires inspecting +// the generated machine code. +// 3) Prefer applying this attribute to individual variables. Avoid +// applying it to types. This tends to localize the effect. +#define ABSL_CACHELINE_ALIGNED __attribute__((aligned(ABSL_CACHELINE_SIZE))) + +#else // not GCC +#define ABSL_CACHELINE_SIZE 64 +#define ABSL_CACHELINE_ALIGNED +#endif + +// ABSL_PREDICT_TRUE, ABSL_PREDICT_FALSE +// +// Enables the compiler to prioritize compilation using static analysis for +// likely paths within a boolean branch. +// +// Example: +// +// if (ABSL_PREDICT_TRUE(expression)) { +// return result; // Faster if more likely +// } else { +// return 0; +// } +// +// Compilers can use the information that a certain branch is not likely to be +// taken (for instance, a CHECK failure) to optimize for the common case in +// the absence of better information (ie. compiling gcc with `-fprofile-arcs`). +#if ABSL_HAVE_BUILTIN(__builtin_expect) || \ + (defined(__GNUC__) && !defined(__clang__)) +#define ABSL_PREDICT_FALSE(x) (__builtin_expect(x, 0)) +#define ABSL_PREDICT_TRUE(x) (__builtin_expect(!!(x), 1)) +#else +#define ABSL_PREDICT_FALSE(x) (x) +#define ABSL_PREDICT_TRUE(x) (x) +#endif + +#endif // ABSL_BASE_OPTIMIZATION_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/policy_checks.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/policy_checks.h new file mode 100644 index 000000000..0a07fc035 --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/policy_checks.h @@ -0,0 +1,121 @@ +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ----------------------------------------------------------------------------- +// File: policy_checks.h +// ----------------------------------------------------------------------------- +// +// This header enforces a minimum set of policies at build time, such as the +// supported compiler and library versions. Unsupported configurations are +// reported with `#error`. This enforcement is best effort, so successfully +// compiling this header does not guarantee a supported configuration. + +#ifndef ABSL_BASE_POLICY_CHECKS_H_ +#define ABSL_BASE_POLICY_CHECKS_H_ + +// Included for the __GLIBC_PREREQ macro used below. +#include + +// Included for the _STLPORT_VERSION macro used below. +#if defined(__cplusplus) +#include +#endif + +// ----------------------------------------------------------------------------- +// Operating System Check +// ----------------------------------------------------------------------------- + +#if defined(__CYGWIN__) +#error "Cygwin is not supported." +#endif + +// ----------------------------------------------------------------------------- +// Compiler Check +// ----------------------------------------------------------------------------- + +// We support MSVC++ 14.0 update 2 and later. +// This minimum will go up. +#if defined(_MSC_FULL_VER) && _MSC_FULL_VER < 190023918 && !defined(__clang__) +#error "This package requires Visual Studio 2015 Update 2 or higher." +#endif + +// We support gcc 4.7 and later. +// This minimum will go up. +#if defined(__GNUC__) && !defined(__clang__) +#if __GNUC__ < 4 || (__GNUC__ == 4 && __GNUC_MINOR__ < 7) +#error "This package requires gcc 4.7 or higher." +#endif +#endif + +// We support Apple Xcode clang 4.2.1 (version 421.11.65) and later. +// This corresponds to Apple Xcode version 4.5. +// This minimum will go up. +#if defined(__apple_build_version__) && __apple_build_version__ < 4211165 +#error "This package requires __apple_build_version__ of 4211165 or higher." +#endif + +// ----------------------------------------------------------------------------- +// C++ Version Check +// ----------------------------------------------------------------------------- + +// Enforce C++11 as the minimum. Note that Visual Studio has not +// advanced __cplusplus despite being good enough for our purposes, so +// so we exempt it from the check. +#if defined(__cplusplus) && !defined(_MSC_VER) +#if __cplusplus < 201103L +#error "C++ versions less than C++11 are not supported." +#endif +#endif + +// ----------------------------------------------------------------------------- +// Standard Library Check +// ----------------------------------------------------------------------------- + +// We have chosen glibc 2.12 as the minimum as it was tagged for release +// in May, 2010 and includes some functionality used in Google software +// (for instance pthread_setname_np): +// https://sourceware.org/ml/libc-alpha/2010-05/msg00000.html +#if defined(__GLIBC__) && defined(__GLIBC_PREREQ) +#if !__GLIBC_PREREQ(2, 12) +#error "Minimum required version of glibc is 2.12." +#endif +#endif + +#if defined(_STLPORT_VERSION) +#error "STLPort is not supported." +#endif + +// ----------------------------------------------------------------------------- +// `char` Size Check +// ----------------------------------------------------------------------------- + +// Abseil currently assumes CHAR_BIT == 8. If you would like to use Abseil on a +// platform where this is not the case, please provide us with the details about +// your platform so we can consider relaxing this requirement. +#if CHAR_BIT != 8 +#error "Abseil assumes CHAR_BIT == 8." +#endif + +// ----------------------------------------------------------------------------- +// `int` Size Check +// ----------------------------------------------------------------------------- + +// Abseil currently assumes that an int is 4 bytes. If you would like to use +// Abseil on a platform where this is not the case, please provide us with the +// details about your platform so we can consider relaxing this requirement. +#if INT_MAX < 2147483647 +#error "Abseil assumes that int is at least 4 bytes. " +#endif + +#endif // ABSL_BASE_POLICY_CHECKS_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/port.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/port.h new file mode 100644 index 000000000..1c67257fd --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/base/port.h @@ -0,0 +1,26 @@ +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// This files is a forwarding header for other headers containing various +// portability macros and functions. +// This file is used for both C and C++! + +#ifndef ABSL_BASE_PORT_H_ +#define ABSL_BASE_PORT_H_ + +#include "absl/base/attributes.h" +#include "absl/base/config.h" +#include "absl/base/optimization.h" + +#endif // ABSL_BASE_PORT_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/container/inlined_vector.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/container/inlined_vector.h new file mode 100644 index 000000000..642dae6cb --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/container/inlined_vector.h @@ -0,0 +1,1451 @@ +// Copyright 2018 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ----------------------------------------------------------------------------- +// File: inlined_vector.h +// ----------------------------------------------------------------------------- +// +// This header file contains the declaration and definition of an "inlined +// vector" which behaves in an equivalent fashion to a `std::vector`, except +// that storage for small sequences of the vector are provided inline without +// requiring any heap allocation. +// +// An `absl::InlinedVector` specifies the default capacity `N` as one of +// its template parameters. Instances where `size() <= N` hold contained +// elements in inline space. Typically `N` is very small so that sequences that +// are expected to be short do not require allocations. +// +// An `absl::InlinedVector` does not usually require a specific allocator. If +// the inlined vector grows beyond its initial constraints, it will need to +// allocate (as any normal `std::vector` would). This is usually performed with +// the default allocator (defined as `std::allocator`). Optionally, a custom +// allocator type may be specified as `A` in `absl::InlinedVector`. + +#ifndef ABSL_CONTAINER_INLINED_VECTOR_H_ +#define ABSL_CONTAINER_INLINED_VECTOR_H_ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "absl/algorithm/algorithm.h" +#include "absl/base/internal/throw_delegate.h" +#include "absl/base/optimization.h" +#include "absl/base/port.h" +#include "absl/memory/memory.h" + +namespace absl { + +// ----------------------------------------------------------------------------- +// InlinedVector +// ----------------------------------------------------------------------------- +// +// An `absl::InlinedVector` is designed to be a drop-in replacement for +// `std::vector` for use cases where the vector's size is sufficiently small +// that it can be inlined. If the inlined vector does grow beyond its estimated +// capacity, it will trigger an initial allocation on the heap, and will behave +// as a `std:vector`. The API of the `absl::InlinedVector` within this file is +// designed to cover the same API footprint as covered by `std::vector`. +template > +class InlinedVector { + constexpr static typename A::size_type inlined_capacity() { + return static_cast(N); + } + + static_assert(inlined_capacity() > 0, "InlinedVector needs inlined capacity"); + + template + using DisableIfIntegral = + absl::enable_if_t::value>; + + template + using EnableIfInputIterator = absl::enable_if_t::iterator_category, + std::input_iterator_tag>::value>; + + template + using IteratorCategory = + typename std::iterator_traits::iterator_category; + + using rvalue_reference = typename A::value_type&&; + + public: + using allocator_type = A; + using value_type = typename allocator_type::value_type; + using pointer = typename allocator_type::pointer; + using const_pointer = typename allocator_type::const_pointer; + using reference = typename allocator_type::reference; + using const_reference = typename allocator_type::const_reference; + using size_type = typename allocator_type::size_type; + using difference_type = typename allocator_type::difference_type; + using iterator = pointer; + using const_iterator = const_pointer; + using reverse_iterator = std::reverse_iterator; + using const_reverse_iterator = std::reverse_iterator; + + // --------------------------------------------------------------------------- + // InlinedVector Constructors and Destructor + // --------------------------------------------------------------------------- + + // Creates an empty inlined vector with a default initialized allocator. + InlinedVector() noexcept(noexcept(allocator_type())) + : allocator_and_tag_(allocator_type()) {} + + // Creates an empty inlined vector with a specified allocator. + explicit InlinedVector(const allocator_type& alloc) noexcept + : allocator_and_tag_(alloc) {} + + // Creates an inlined vector with `n` copies of `value_type()`. + explicit InlinedVector(size_type n, + const allocator_type& alloc = allocator_type()) + : allocator_and_tag_(alloc) { + InitAssign(n); + } + + // Creates an inlined vector with `n` copies of `v`. + InlinedVector(size_type n, const_reference v, + const allocator_type& alloc = allocator_type()) + : allocator_and_tag_(alloc) { + InitAssign(n, v); + } + + // Creates an inlined vector of copies of the values in `init_list`. + InlinedVector(std::initializer_list init_list, + const allocator_type& alloc = allocator_type()) + : allocator_and_tag_(alloc) { + AppendRange(init_list.begin(), init_list.end()); + } + + // Creates an inlined vector with elements constructed from the provided + // Iterator range [`first`, `last`). + // + // NOTE: The `enable_if` prevents ambiguous interpretation between a call to + // this constructor with two integral arguments and a call to the above + // `InlinedVector(size_type, const_reference)` constructor. + template * = nullptr> + InlinedVector(InputIterator first, InputIterator last, + const allocator_type& alloc = allocator_type()) + : allocator_and_tag_(alloc) { + AppendRange(first, last); + } + + // Creates a copy of `other` using `other`'s allocator. + InlinedVector(const InlinedVector& other); + + // Creates a copy of `other` but with a specified allocator. + InlinedVector(const InlinedVector& other, const allocator_type& alloc); + + // Creates an inlined vector by moving in the contents of `other`. + // + // NOTE: This move constructor does not allocate and only moves the underlying + // objects, so its `noexcept` specification depends on whether moving the + // underlying objects can throw or not. We assume: + // a) move constructors should only throw due to allocation failure and + // b) if `value_type`'s move constructor allocates, it uses the same + // allocation function as the `InlinedVector`'s allocator, so the move + // constructor is non-throwing if the allocator is non-throwing or + // `value_type`'s move constructor is specified as `noexcept`. + InlinedVector(InlinedVector&& v) noexcept( + absl::allocator_is_nothrow::value || + std::is_nothrow_move_constructible::value); + + // Creates an inlined vector by moving in the contents of `other`. + // + // NOTE: This move constructor allocates and subsequently moves the underlying + // objects, so its `noexcept` specification depends on whether the allocation + // can throw and whether moving the underlying objects can throw. Based on the + // same assumptions as above, the `noexcept` specification is dominated by + // whether the allocation can throw regardless of whether `value_type`'s move + // constructor is specified as `noexcept`. + InlinedVector(InlinedVector&& v, const allocator_type& alloc) noexcept( + absl::allocator_is_nothrow::value); + + ~InlinedVector() { clear(); } + + // --------------------------------------------------------------------------- + // InlinedVector Member Accessors + // --------------------------------------------------------------------------- + + // `InlinedVector::empty()` + // + // Checks if the inlined vector has no elements. + bool empty() const noexcept { return !size(); } + + // `InlinedVector::size()` + // + // Returns the number of elements in the inlined vector. + size_type size() const noexcept { return tag().size(); } + + // `InlinedVector::max_size()` + // + // Returns the maximum number of elements the vector can hold. + size_type max_size() const noexcept { + // One bit of the size storage is used to indicate whether the inlined + // vector is allocated. As a result, the maximum size of the container that + // we can express is half of the max for `size_type`. + return (std::numeric_limits::max)() / 2; + } + + // `InlinedVector::capacity()` + // + // Returns the number of elements that can be stored in the inlined vector + // without requiring a reallocation of underlying memory. + // + // NOTE: For most inlined vectors, `capacity()` should equal + // `inlined_capacity()`. For inlined vectors which exceed this capacity, they + // will no longer be inlined and `capacity()` will equal its capacity on the + // allocated heap. + size_type capacity() const noexcept { + return allocated() ? allocation().capacity() : inlined_capacity(); + } + + // `InlinedVector::data()` + // + // Returns a `pointer` to elements of the inlined vector. This pointer can be + // used to access and modify the contained elements. + // Only results within the range [`0`, `size()`) are defined. + pointer data() noexcept { + return allocated() ? allocated_space() : inlined_space(); + } + + // Overload of `InlinedVector::data()` to return a `const_pointer` to elements + // of the inlined vector. This pointer can be used to access (but not modify) + // the contained elements. + const_pointer data() const noexcept { + return allocated() ? allocated_space() : inlined_space(); + } + + // `InlinedVector::operator[]()` + // + // Returns a `reference` to the `i`th element of the inlined vector using the + // array operator. + reference operator[](size_type i) { + assert(i < size()); + return data()[i]; + } + + // Overload of `InlinedVector::operator[]()` to return a `const_reference` to + // the `i`th element of the inlined vector. + const_reference operator[](size_type i) const { + assert(i < size()); + return data()[i]; + } + + // `InlinedVector::at()` + // + // Returns a `reference` to the `i`th element of the inlined vector. + reference at(size_type i) { + if (ABSL_PREDICT_FALSE(i >= size())) { + base_internal::ThrowStdOutOfRange( + "InlinedVector::at() failed bounds check"); + } + return data()[i]; + } + + // Overload of `InlinedVector::at()` to return a `const_reference` to the + // `i`th element of the inlined vector. + const_reference at(size_type i) const { + if (ABSL_PREDICT_FALSE(i >= size())) { + base_internal::ThrowStdOutOfRange( + "InlinedVector::at() failed bounds check"); + } + return data()[i]; + } + + // `InlinedVector::front()` + // + // Returns a `reference` to the first element of the inlined vector. + reference front() { + assert(!empty()); + return at(0); + } + + // Overload of `InlinedVector::front()` returns a `const_reference` to the + // first element of the inlined vector. + const_reference front() const { + assert(!empty()); + return at(0); + } + + // `InlinedVector::back()` + // + // Returns a `reference` to the last element of the inlined vector. + reference back() { + assert(!empty()); + return at(size() - 1); + } + + // Overload of `InlinedVector::back()` to return a `const_reference` to the + // last element of the inlined vector. + const_reference back() const { + assert(!empty()); + return at(size() - 1); + } + + // `InlinedVector::begin()` + // + // Returns an `iterator` to the beginning of the inlined vector. + iterator begin() noexcept { return data(); } + + // Overload of `InlinedVector::begin()` to return a `const_iterator` to + // the beginning of the inlined vector. + const_iterator begin() const noexcept { return data(); } + + // `InlinedVector::end()` + // + // Returns an `iterator` to the end of the inlined vector. + iterator end() noexcept { return data() + size(); } + + // Overload of `InlinedVector::end()` to return a `const_iterator` to the + // end of the inlined vector. + const_iterator end() const noexcept { return data() + size(); } + + // `InlinedVector::cbegin()` + // + // Returns a `const_iterator` to the beginning of the inlined vector. + const_iterator cbegin() const noexcept { return begin(); } + + // `InlinedVector::cend()` + // + // Returns a `const_iterator` to the end of the inlined vector. + const_iterator cend() const noexcept { return end(); } + + // `InlinedVector::rbegin()` + // + // Returns a `reverse_iterator` from the end of the inlined vector. + reverse_iterator rbegin() noexcept { return reverse_iterator(end()); } + + // Overload of `InlinedVector::rbegin()` to return a + // `const_reverse_iterator` from the end of the inlined vector. + const_reverse_iterator rbegin() const noexcept { + return const_reverse_iterator(end()); + } + + // `InlinedVector::rend()` + // + // Returns a `reverse_iterator` from the beginning of the inlined vector. + reverse_iterator rend() noexcept { return reverse_iterator(begin()); } + + // Overload of `InlinedVector::rend()` to return a `const_reverse_iterator` + // from the beginning of the inlined vector. + const_reverse_iterator rend() const noexcept { + return const_reverse_iterator(begin()); + } + + // `InlinedVector::crbegin()` + // + // Returns a `const_reverse_iterator` from the end of the inlined vector. + const_reverse_iterator crbegin() const noexcept { return rbegin(); } + + // `InlinedVector::crend()` + // + // Returns a `const_reverse_iterator` from the beginning of the inlined + // vector. + const_reverse_iterator crend() const noexcept { return rend(); } + + // `InlinedVector::get_allocator()` + // + // Returns a copy of the allocator of the inlined vector. + allocator_type get_allocator() const { return allocator(); } + + + // --------------------------------------------------------------------------- + // InlinedVector Member Mutators + // --------------------------------------------------------------------------- + + // `InlinedVector::operator=()` + // + // Replaces the contents of the inlined vector with copies of the elements in + // the provided `std::initializer_list`. + InlinedVector& operator=(std::initializer_list init_list) { + AssignRange(init_list.begin(), init_list.end()); + return *this; + } + + // Overload of `InlinedVector::operator=()` to replace the contents of the + // inlined vector with the contents of `other`. + InlinedVector& operator=(const InlinedVector& other) { + if (ABSL_PREDICT_FALSE(this == &other)) return *this; + + // Optimized to avoid reallocation. + // Prefer reassignment to copy construction for elements. + if (size() < other.size()) { // grow + reserve(other.size()); + std::copy(other.begin(), other.begin() + size(), begin()); + std::copy(other.begin() + size(), other.end(), std::back_inserter(*this)); + } else { // maybe shrink + erase(begin() + other.size(), end()); + std::copy(other.begin(), other.end(), begin()); + } + return *this; + } + + // Overload of `InlinedVector::operator=()` to replace the contents of the + // inlined vector with the contents of `other`. + // + // NOTE: As a result of calling this overload, `other` may be empty or it's + // contents may be left in a moved-from state. + InlinedVector& operator=(InlinedVector&& other) { + if (ABSL_PREDICT_FALSE(this == &other)) return *this; + + if (other.allocated()) { + clear(); + tag().set_allocated_size(other.size()); + init_allocation(other.allocation()); + other.tag() = Tag(); + } else { + if (allocated()) clear(); + // Both are inlined now. + if (size() < other.size()) { + auto mid = std::make_move_iterator(other.begin() + size()); + std::copy(std::make_move_iterator(other.begin()), mid, begin()); + UninitializedCopy(mid, std::make_move_iterator(other.end()), end()); + } else { + auto new_end = std::copy(std::make_move_iterator(other.begin()), + std::make_move_iterator(other.end()), begin()); + Destroy(new_end, end()); + } + tag().set_inline_size(other.size()); + } + return *this; + } + + // `InlinedVector::assign()` + // + // Replaces the contents of the inlined vector with `n` copies of `v`. + void assign(size_type n, const_reference v) { + if (n <= size()) { // Possibly shrink + std::fill_n(begin(), n, v); + erase(begin() + n, end()); + return; + } + // Grow + reserve(n); + std::fill_n(begin(), size(), v); + if (allocated()) { + UninitializedFill(allocated_space() + size(), allocated_space() + n, v); + tag().set_allocated_size(n); + } else { + UninitializedFill(inlined_space() + size(), inlined_space() + n, v); + tag().set_inline_size(n); + } + } + + // Overload of `InlinedVector::assign()` to replace the contents of the + // inlined vector with copies of the values in the provided + // `std::initializer_list`. + void assign(std::initializer_list init_list) { + AssignRange(init_list.begin(), init_list.end()); + } + + // Overload of `InlinedVector::assign()` to replace the contents of the + // inlined vector with values constructed from the range [`first`, `last`). + template * = nullptr> + void assign(InputIterator first, InputIterator last) { + AssignRange(first, last); + } + + // `InlinedVector::resize()` + // + // Resizes the inlined vector to contain `n` elements. If `n` is smaller than + // the inlined vector's current size, extra elements are destroyed. If `n` is + // larger than the initial size, new elements are value-initialized. + void resize(size_type n); + + // Overload of `InlinedVector::resize()` to resize the inlined vector to + // contain `n` elements where, if `n` is larger than `size()`, the new values + // will be copy-constructed from `v`. + void resize(size_type n, const_reference v); + + // `InlinedVector::insert()` + // + // Copies `v` into `position`, returning an `iterator` pointing to the newly + // inserted element. + iterator insert(const_iterator position, const_reference v) { + return emplace(position, v); + } + + // Overload of `InlinedVector::insert()` for moving `v` into `position`, + // returning an iterator pointing to the newly inserted element. + iterator insert(const_iterator position, rvalue_reference v) { + return emplace(position, std::move(v)); + } + + // Overload of `InlinedVector::insert()` for inserting `n` contiguous copies + // of `v` starting at `position`. Returns an `iterator` pointing to the first + // of the newly inserted elements. + iterator insert(const_iterator position, size_type n, const_reference v) { + return InsertWithCount(position, n, v); + } + + // Overload of `InlinedVector::insert()` for copying the contents of the + // `std::initializer_list` into the vector starting at `position`. Returns an + // `iterator` pointing to the first of the newly inserted elements. + iterator insert(const_iterator position, + std::initializer_list init_list) { + return insert(position, init_list.begin(), init_list.end()); + } + + // Overload of `InlinedVector::insert()` for inserting elements constructed + // from the range [`first`, `last`). Returns an `iterator` pointing to the + // first of the newly inserted elements. + // + // NOTE: The `enable_if` is intended to disambiguate the two three-argument + // overloads of `insert()`. + template > + iterator insert(const_iterator position, InputIterator first, + InputIterator last) { + return InsertWithRange(position, first, last, + IteratorCategory()); + } + + // `InlinedVector::emplace()` + // + // Constructs and inserts an object in the inlined vector at the given + // `position`, returning an `iterator` pointing to the newly emplaced element. + template + iterator emplace(const_iterator position, Args&&... args); + + // `InlinedVector::emplace_back()` + // + // Constructs and appends a new element to the end of the inlined vector, + // returning a `reference` to the emplaced element. + template + reference emplace_back(Args&&... args) { + size_type s = size(); + assert(s <= capacity()); + if (ABSL_PREDICT_FALSE(s == capacity())) { + return GrowAndEmplaceBack(std::forward(args)...); + } + assert(s < capacity()); + + pointer space; + if (allocated()) { + tag().set_allocated_size(s + 1); + space = allocated_space(); + } else { + tag().set_inline_size(s + 1); + space = inlined_space(); + } + return Construct(space + s, std::forward(args)...); + } + + // `InlinedVector::push_back()` + // + // Appends a copy of `v` to the end of the inlined vector. + void push_back(const_reference v) { static_cast(emplace_back(v)); } + + // Overload of `InlinedVector::push_back()` for moving `v` into a newly + // appended element. + void push_back(rvalue_reference v) { + static_cast(emplace_back(std::move(v))); + } + + // `InlinedVector::pop_back()` + // + // Destroys the element at the end of the inlined vector and shrinks the size + // by `1` (unless the inlined vector is empty, in which case this is a no-op). + void pop_back() noexcept { + assert(!empty()); + size_type s = size(); + if (allocated()) { + Destroy(allocated_space() + s - 1, allocated_space() + s); + tag().set_allocated_size(s - 1); + } else { + Destroy(inlined_space() + s - 1, inlined_space() + s); + tag().set_inline_size(s - 1); + } + } + + // `InlinedVector::erase()` + // + // Erases the element at `position` of the inlined vector, returning an + // `iterator` pointing to the first element following the erased element. + // + // NOTE: May return the end iterator, which is not dereferencable. + iterator erase(const_iterator position) { + assert(position >= begin()); + assert(position < end()); + + iterator pos = const_cast(position); + std::move(pos + 1, end(), pos); + pop_back(); + return pos; + } + + // Overload of `InlinedVector::erase()` for erasing all elements in the + // range [`from`, `to`) in the inlined vector. Returns an `iterator` pointing + // to the first element following the range erased or the end iterator if `to` + // was the end iterator. + iterator erase(const_iterator from, const_iterator to); + + // `InlinedVector::clear()` + // + // Destroys all elements in the inlined vector, sets the size of `0` and + // deallocates the heap allocation if the inlined vector was allocated. + void clear() noexcept { + size_type s = size(); + if (allocated()) { + Destroy(allocated_space(), allocated_space() + s); + allocation().Dealloc(allocator()); + } else if (s != 0) { // do nothing for empty vectors + Destroy(inlined_space(), inlined_space() + s); + } + tag() = Tag(); + } + + // `InlinedVector::reserve()` + // + // Enlarges the underlying representation of the inlined vector so it can hold + // at least `n` elements. This method does not change `size()` or the actual + // contents of the vector. + // + // NOTE: If `n` does not exceed `capacity()`, `reserve()` will have no + // effects. Otherwise, `reserve()` will reallocate, performing an n-time + // element-wise move of everything contained. + void reserve(size_type n) { + if (n > capacity()) { + // Make room for new elements + EnlargeBy(n - size()); + } + } + + // `InlinedVector::shrink_to_fit()` + // + // Reduces memory usage by freeing unused memory. After this call, calls to + // `capacity()` will be equal to `(std::max)(inlined_capacity(), size())`. + // + // If `size() <= inlined_capacity()` and the elements are currently stored on + // the heap, they will be moved to the inlined storage and the heap memory + // will be deallocated. + // + // If `size() > inlined_capacity()` and `size() < capacity()` the elements + // will be moved to a smaller heap allocation. + void shrink_to_fit() { + const auto s = size(); + if (ABSL_PREDICT_FALSE(!allocated() || s == capacity())) return; + + if (s <= inlined_capacity()) { + // Move the elements to the inlined storage. + // We have to do this using a temporary, because `inlined_storage` and + // `allocation_storage` are in a union field. + auto temp = std::move(*this); + assign(std::make_move_iterator(temp.begin()), + std::make_move_iterator(temp.end())); + return; + } + + // Reallocate storage and move elements. + // We can't simply use the same approach as above, because `assign()` would + // call into `reserve()` internally and reserve larger capacity than we need + Allocation new_allocation(allocator(), s); + UninitializedCopy(std::make_move_iterator(allocated_space()), + std::make_move_iterator(allocated_space() + s), + new_allocation.buffer()); + ResetAllocation(new_allocation, s); + } + + // `InlinedVector::swap()` + // + // Swaps the contents of this inlined vector with the contents of `other`. + void swap(InlinedVector& other); + + template + friend Hash AbslHashValue(Hash hash, const InlinedVector& inlined_vector) { + const_pointer p = inlined_vector.data(); + size_type n = inlined_vector.size(); + return Hash::combine(Hash::combine_contiguous(std::move(hash), p, n), n); + } + + private: + // Holds whether the vector is allocated or not in the lowest bit and the size + // in the high bits: + // `size_ = (size << 1) | is_allocated;` + class Tag { + public: + Tag() : size_(0) {} + size_type size() const { return size_ / 2; } + void add_size(size_type n) { size_ += n * 2; } + void set_inline_size(size_type n) { size_ = n * 2; } + void set_allocated_size(size_type n) { size_ = (n * 2) + 1; } + bool allocated() const { return size_ % 2; } + + private: + size_type size_; + }; + + // Derives from `allocator_type` to use the empty base class optimization. + // If the `allocator_type` is stateless, we can store our instance for free. + class AllocatorAndTag : private allocator_type { + public: + explicit AllocatorAndTag(const allocator_type& a) : allocator_type(a) {} + + Tag& tag() { return tag_; } + const Tag& tag() const { return tag_; } + + allocator_type& allocator() { return *this; } + const allocator_type& allocator() const { return *this; } + + private: + Tag tag_; + }; + + class Allocation { + public: + Allocation(allocator_type& a, size_type capacity) + : capacity_(capacity), buffer_(Create(a, capacity)) {} + + void Dealloc(allocator_type& a) { + std::allocator_traits::deallocate(a, buffer_, capacity_); + } + + size_type capacity() const { return capacity_; } + + const_pointer buffer() const { return buffer_; } + + pointer buffer() { return buffer_; } + + private: + static pointer Create(allocator_type& a, size_type n) { + return std::allocator_traits::allocate(a, n); + } + + size_type capacity_; + pointer buffer_; + }; + + const Tag& tag() const { return allocator_and_tag_.tag(); } + + Tag& tag() { return allocator_and_tag_.tag(); } + + Allocation& allocation() { + return reinterpret_cast(rep_.allocation_storage.allocation); + } + + const Allocation& allocation() const { + return reinterpret_cast( + rep_.allocation_storage.allocation); + } + + void init_allocation(const Allocation& allocation) { + new (&rep_.allocation_storage.allocation) Allocation(allocation); + } + + // TODO(absl-team): investigate whether the reinterpret_cast is appropriate. + pointer inlined_space() { + return reinterpret_cast( + std::addressof(rep_.inlined_storage.inlined[0])); + } + + const_pointer inlined_space() const { + return reinterpret_cast( + std::addressof(rep_.inlined_storage.inlined[0])); + } + + pointer allocated_space() { return allocation().buffer(); } + + const_pointer allocated_space() const { return allocation().buffer(); } + + const allocator_type& allocator() const { + return allocator_and_tag_.allocator(); + } + + allocator_type& allocator() { return allocator_and_tag_.allocator(); } + + bool allocated() const { return tag().allocated(); } + + // Enlarge the underlying representation so we can store `size_ + delta` elems + // in allocated space. The size is not changed, and any newly added memory is + // not initialized. + void EnlargeBy(size_type delta); + + // Shift all elements from `position` to `end()` by `n` places to the right. + // If the vector needs to be enlarged, memory will be allocated. + // Returns `iterator`s pointing to the start of the previously-initialized + // portion and the start of the uninitialized portion of the created gap. + // The number of initialized spots is `pair.second - pair.first`. The number + // of raw spots is `n - (pair.second - pair.first)`. + // + // Updates the size of the InlinedVector internally. + std::pair ShiftRight(const_iterator position, + size_type n); + + void ResetAllocation(Allocation new_allocation, size_type new_size) { + if (allocated()) { + Destroy(allocated_space(), allocated_space() + size()); + assert(begin() == allocated_space()); + allocation().Dealloc(allocator()); + allocation() = new_allocation; + } else { + Destroy(inlined_space(), inlined_space() + size()); + init_allocation(new_allocation); // bug: only init once + } + tag().set_allocated_size(new_size); + } + + template + reference GrowAndEmplaceBack(Args&&... args) { + assert(size() == capacity()); + const size_type s = size(); + + Allocation new_allocation(allocator(), 2 * capacity()); + + reference new_element = + Construct(new_allocation.buffer() + s, std::forward(args)...); + UninitializedCopy(std::make_move_iterator(data()), + std::make_move_iterator(data() + s), + new_allocation.buffer()); + + ResetAllocation(new_allocation, s + 1); + + return new_element; + } + + void InitAssign(size_type n); + + void InitAssign(size_type n, const_reference v); + + template + reference Construct(pointer p, Args&&... args) { + std::allocator_traits::construct( + allocator(), p, std::forward(args)...); + return *p; + } + + template + void UninitializedCopy(Iterator src, Iterator src_last, pointer dst) { + for (; src != src_last; ++dst, ++src) Construct(dst, *src); + } + + template + void UninitializedFill(pointer dst, pointer dst_last, const Args&... args) { + for (; dst != dst_last; ++dst) Construct(dst, args...); + } + + // Destroy [`from`, `to`) in place. + void Destroy(pointer from, pointer to); + + template + void AppendRange(Iterator first, Iterator last, std::input_iterator_tag) { + std::copy(first, last, std::back_inserter(*this)); + } + + template + void AppendRange(Iterator first, Iterator last, std::forward_iterator_tag); + + template + void AppendRange(Iterator first, Iterator last) { + AppendRange(first, last, IteratorCategory()); + } + + template + void AssignRange(Iterator first, Iterator last, std::input_iterator_tag); + + template + void AssignRange(Iterator first, Iterator last, std::forward_iterator_tag); + + template + void AssignRange(Iterator first, Iterator last) { + AssignRange(first, last, IteratorCategory()); + } + + iterator InsertWithCount(const_iterator position, size_type n, + const_reference v); + + template + iterator InsertWithRange(const_iterator position, InputIterator first, + InputIterator last, std::input_iterator_tag); + + template + iterator InsertWithRange(const_iterator position, ForwardIterator first, + ForwardIterator last, std::forward_iterator_tag); + + // Stores either the inlined or allocated representation + union Rep { + using ValueTypeBuffer = + absl::aligned_storage_t; + using AllocationBuffer = + absl::aligned_storage_t; + + // Structs wrap the buffers to perform indirection that solves a bizarre + // compilation error on Visual Studio (all known versions). + struct InlinedRep { + ValueTypeBuffer inlined[inlined_capacity()]; + }; + struct AllocatedRep { + AllocationBuffer allocation; + }; + + InlinedRep inlined_storage; + AllocatedRep allocation_storage; + }; + + AllocatorAndTag allocator_and_tag_; + Rep rep_; +}; + +// ----------------------------------------------------------------------------- +// InlinedVector Non-Member Functions +// ----------------------------------------------------------------------------- + +// `swap()` +// +// Swaps the contents of two inlined vectors. This convenience function +// simply calls `InlinedVector::swap()`. +template +void swap(InlinedVector& a, + InlinedVector& b) noexcept(noexcept(a.swap(b))) { + a.swap(b); +} + +// `operator==()` +// +// Tests the equivalency of the contents of two inlined vectors. +template +bool operator==(const InlinedVector& a, + const InlinedVector& b) { + return absl::equal(a.begin(), a.end(), b.begin(), b.end()); +} + +// `operator!=()` +// +// Tests the inequality of the contents of two inlined vectors. +template +bool operator!=(const InlinedVector& a, + const InlinedVector& b) { + return !(a == b); +} + +// `operator<()` +// +// Tests whether the contents of one inlined vector are less than the contents +// of another through a lexicographical comparison operation. +template +bool operator<(const InlinedVector& a, + const InlinedVector& b) { + return std::lexicographical_compare(a.begin(), a.end(), b.begin(), b.end()); +} + +// `operator>()` +// +// Tests whether the contents of one inlined vector are greater than the +// contents of another through a lexicographical comparison operation. +template +bool operator>(const InlinedVector& a, + const InlinedVector& b) { + return b < a; +} + +// `operator<=()` +// +// Tests whether the contents of one inlined vector are less than or equal to +// the contents of another through a lexicographical comparison operation. +template +bool operator<=(const InlinedVector& a, + const InlinedVector& b) { + return !(b < a); +} + +// `operator>=()` +// +// Tests whether the contents of one inlined vector are greater than or equal to +// the contents of another through a lexicographical comparison operation. +template +bool operator>=(const InlinedVector& a, + const InlinedVector& b) { + return !(a < b); +} + +// ----------------------------------------------------------------------------- +// Implementation of InlinedVector +// +// Do not depend on any below implementation details! +// ----------------------------------------------------------------------------- + +template +InlinedVector::InlinedVector(const InlinedVector& other) + : allocator_and_tag_(other.allocator()) { + reserve(other.size()); + if (allocated()) { + UninitializedCopy(other.begin(), other.end(), allocated_space()); + tag().set_allocated_size(other.size()); + } else { + UninitializedCopy(other.begin(), other.end(), inlined_space()); + tag().set_inline_size(other.size()); + } +} + +template +InlinedVector::InlinedVector(const InlinedVector& other, + const allocator_type& alloc) + : allocator_and_tag_(alloc) { + reserve(other.size()); + if (allocated()) { + UninitializedCopy(other.begin(), other.end(), allocated_space()); + tag().set_allocated_size(other.size()); + } else { + UninitializedCopy(other.begin(), other.end(), inlined_space()); + tag().set_inline_size(other.size()); + } +} + +template +InlinedVector::InlinedVector(InlinedVector&& other) noexcept( + absl::allocator_is_nothrow::value || + std::is_nothrow_move_constructible::value) + : allocator_and_tag_(other.allocator_and_tag_) { + if (other.allocated()) { + // We can just steal the underlying buffer from the source. + // That leaves the source empty, so we clear its size. + init_allocation(other.allocation()); + other.tag() = Tag(); + } else { + UninitializedCopy( + std::make_move_iterator(other.inlined_space()), + std::make_move_iterator(other.inlined_space() + other.size()), + inlined_space()); + } +} + +template +InlinedVector::InlinedVector(InlinedVector&& other, + const allocator_type& alloc) noexcept( // + absl::allocator_is_nothrow::value) + : allocator_and_tag_(alloc) { + if (other.allocated()) { + if (alloc == other.allocator()) { + // We can just steal the allocation from the source. + tag() = other.tag(); + init_allocation(other.allocation()); + other.tag() = Tag(); + } else { + // We need to use our own allocator + reserve(other.size()); + UninitializedCopy(std::make_move_iterator(other.begin()), + std::make_move_iterator(other.end()), + allocated_space()); + tag().set_allocated_size(other.size()); + } + } else { + UninitializedCopy( + std::make_move_iterator(other.inlined_space()), + std::make_move_iterator(other.inlined_space() + other.size()), + inlined_space()); + tag().set_inline_size(other.size()); + } +} + +template +void InlinedVector::InitAssign(size_type n, const_reference v) { + if (n > inlined_capacity()) { + Allocation new_allocation(allocator(), n); + init_allocation(new_allocation); + UninitializedFill(allocated_space(), allocated_space() + n, v); + tag().set_allocated_size(n); + } else { + UninitializedFill(inlined_space(), inlined_space() + n, v); + tag().set_inline_size(n); + } +} + +template +void InlinedVector::InitAssign(size_type n) { + if (n > inlined_capacity()) { + Allocation new_allocation(allocator(), n); + init_allocation(new_allocation); + UninitializedFill(allocated_space(), allocated_space() + n); + tag().set_allocated_size(n); + } else { + UninitializedFill(inlined_space(), inlined_space() + n); + tag().set_inline_size(n); + } +} + +template +void InlinedVector::resize(size_type n) { + size_type s = size(); + if (n < s) { + erase(begin() + n, end()); + return; + } + reserve(n); + assert(capacity() >= n); + + // Fill new space with elements constructed in-place. + if (allocated()) { + UninitializedFill(allocated_space() + s, allocated_space() + n); + tag().set_allocated_size(n); + } else { + UninitializedFill(inlined_space() + s, inlined_space() + n); + tag().set_inline_size(n); + } +} + +template +void InlinedVector::resize(size_type n, const_reference v) { + size_type s = size(); + if (n < s) { + erase(begin() + n, end()); + return; + } + reserve(n); + assert(capacity() >= n); + + // Fill new space with copies of 'v'. + if (allocated()) { + UninitializedFill(allocated_space() + s, allocated_space() + n, v); + tag().set_allocated_size(n); + } else { + UninitializedFill(inlined_space() + s, inlined_space() + n, v); + tag().set_inline_size(n); + } +} + +template +template +auto InlinedVector::emplace(const_iterator position, Args&&... args) + -> iterator { + assert(position >= begin()); + assert(position <= end()); + if (ABSL_PREDICT_FALSE(position == end())) { + emplace_back(std::forward(args)...); + return end() - 1; + } + + T new_t = T(std::forward(args)...); + + auto range = ShiftRight(position, 1); + if (range.first == range.second) { + // constructing into uninitialized memory + Construct(range.first, std::move(new_t)); + } else { + // assigning into moved-from object + *range.first = T(std::move(new_t)); + } + + return range.first; +} + +template +auto InlinedVector::erase(const_iterator from, const_iterator to) + -> iterator { + assert(begin() <= from); + assert(from <= to); + assert(to <= end()); + + iterator range_start = const_cast(from); + iterator range_end = const_cast(to); + + size_type s = size(); + ptrdiff_t erase_gap = std::distance(range_start, range_end); + if (erase_gap > 0) { + pointer space; + if (allocated()) { + space = allocated_space(); + tag().set_allocated_size(s - erase_gap); + } else { + space = inlined_space(); + tag().set_inline_size(s - erase_gap); + } + std::move(range_end, space + s, range_start); + Destroy(space + s - erase_gap, space + s); + } + return range_start; +} + +template +void InlinedVector::swap(InlinedVector& other) { + using std::swap; // Augment ADL with `std::swap`. + if (ABSL_PREDICT_FALSE(this == &other)) return; + + if (allocated() && other.allocated()) { + // Both out of line, so just swap the tag, allocation, and allocator. + swap(tag(), other.tag()); + swap(allocation(), other.allocation()); + swap(allocator(), other.allocator()); + return; + } + if (!allocated() && !other.allocated()) { + // Both inlined: swap up to smaller size, then move remaining elements. + InlinedVector* a = this; + InlinedVector* b = &other; + if (size() < other.size()) { + swap(a, b); + } + + const size_type a_size = a->size(); + const size_type b_size = b->size(); + assert(a_size >= b_size); + // `a` is larger. Swap the elements up to the smaller array size. + std::swap_ranges(a->inlined_space(), a->inlined_space() + b_size, + b->inlined_space()); + + // Move the remaining elements: + // [`b_size`, `a_size`) from `a` -> [`b_size`, `a_size`) from `b` + b->UninitializedCopy(a->inlined_space() + b_size, + a->inlined_space() + a_size, + b->inlined_space() + b_size); + a->Destroy(a->inlined_space() + b_size, a->inlined_space() + a_size); + + swap(a->tag(), b->tag()); + swap(a->allocator(), b->allocator()); + assert(b->size() == a_size); + assert(a->size() == b_size); + return; + } + + // One is out of line, one is inline. + // We first move the elements from the inlined vector into the + // inlined space in the other vector. We then put the other vector's + // pointer/capacity into the originally inlined vector and swap + // the tags. + InlinedVector* a = this; + InlinedVector* b = &other; + if (a->allocated()) { + swap(a, b); + } + assert(!a->allocated()); + assert(b->allocated()); + const size_type a_size = a->size(); + const size_type b_size = b->size(); + // In an optimized build, `b_size` would be unused. + static_cast(b_size); + + // Made Local copies of `size()`, don't need `tag()` accurate anymore + swap(a->tag(), b->tag()); + + // Copy `b_allocation` out before `b`'s union gets clobbered by `inline_space` + Allocation b_allocation = b->allocation(); + + b->UninitializedCopy(a->inlined_space(), a->inlined_space() + a_size, + b->inlined_space()); + a->Destroy(a->inlined_space(), a->inlined_space() + a_size); + + a->allocation() = b_allocation; + + if (a->allocator() != b->allocator()) { + swap(a->allocator(), b->allocator()); + } + + assert(b->size() == a_size); + assert(a->size() == b_size); +} + +template +void InlinedVector::EnlargeBy(size_type delta) { + const size_type s = size(); + assert(s <= capacity()); + + size_type target = std::max(inlined_capacity(), s + delta); + + // Compute new capacity by repeatedly doubling current capacity + // TODO(psrc): Check and avoid overflow? + size_type new_capacity = capacity(); + while (new_capacity < target) { + new_capacity <<= 1; + } + + Allocation new_allocation(allocator(), new_capacity); + + UninitializedCopy(std::make_move_iterator(data()), + std::make_move_iterator(data() + s), + new_allocation.buffer()); + + ResetAllocation(new_allocation, s); +} + +template +auto InlinedVector::ShiftRight(const_iterator position, size_type n) + -> std::pair { + iterator start_used = const_cast(position); + iterator start_raw = const_cast(position); + size_type s = size(); + size_type required_size = s + n; + + if (required_size > capacity()) { + // Compute new capacity by repeatedly doubling current capacity + size_type new_capacity = capacity(); + while (new_capacity < required_size) { + new_capacity <<= 1; + } + // Move everyone into the new allocation, leaving a gap of `n` for the + // requested shift. + Allocation new_allocation(allocator(), new_capacity); + size_type index = position - begin(); + UninitializedCopy(std::make_move_iterator(data()), + std::make_move_iterator(data() + index), + new_allocation.buffer()); + UninitializedCopy(std::make_move_iterator(data() + index), + std::make_move_iterator(data() + s), + new_allocation.buffer() + index + n); + ResetAllocation(new_allocation, s); + + // New allocation means our iterator is invalid, so we'll recalculate. + // Since the entire gap is in new space, there's no used space to reuse. + start_raw = begin() + index; + start_used = start_raw; + } else { + // If we had enough space, it's a two-part move. Elements going into + // previously-unoccupied space need an `UninitializedCopy()`. Elements + // going into a previously-occupied space are just a `std::move()`. + iterator pos = const_cast(position); + iterator raw_space = end(); + size_type slots_in_used_space = raw_space - pos; + size_type new_elements_in_used_space = std::min(n, slots_in_used_space); + size_type new_elements_in_raw_space = n - new_elements_in_used_space; + size_type old_elements_in_used_space = + slots_in_used_space - new_elements_in_used_space; + + UninitializedCopy(std::make_move_iterator(pos + old_elements_in_used_space), + std::make_move_iterator(raw_space), + raw_space + new_elements_in_raw_space); + std::move_backward(pos, pos + old_elements_in_used_space, raw_space); + + // If the gap is entirely in raw space, the used space starts where the raw + // space starts, leaving no elements in used space. If the gap is entirely + // in used space, the raw space starts at the end of the gap, leaving all + // elements accounted for within the used space. + start_used = pos; + start_raw = pos + new_elements_in_used_space; + } + tag().add_size(n); + return std::make_pair(start_used, start_raw); +} + +template +void InlinedVector::Destroy(pointer from, pointer to) { + for (pointer cur = from; cur != to; ++cur) { + std::allocator_traits::destroy(allocator(), cur); + } +#ifndef NDEBUG + // Overwrite unused memory with `0xab` so we can catch uninitialized usage. + // Cast to `void*` to tell the compiler that we don't care that we might be + // scribbling on a vtable pointer. + if (from != to) { + auto len = sizeof(value_type) * std::distance(from, to); + std::memset(reinterpret_cast(from), 0xab, len); + } +#endif +} + +template +template +void InlinedVector::AppendRange(Iterator first, Iterator last, + std::forward_iterator_tag) { + auto length = std::distance(first, last); + reserve(size() + length); + if (allocated()) { + UninitializedCopy(first, last, allocated_space() + size()); + tag().set_allocated_size(size() + length); + } else { + UninitializedCopy(first, last, inlined_space() + size()); + tag().set_inline_size(size() + length); + } +} + +template +template +void InlinedVector::AssignRange(Iterator first, Iterator last, + std::input_iterator_tag) { + // Optimized to avoid reallocation. + // Prefer reassignment to copy construction for elements. + iterator out = begin(); + for (; first != last && out != end(); ++first, ++out) { + *out = *first; + } + erase(out, end()); + std::copy(first, last, std::back_inserter(*this)); +} + +template +template +void InlinedVector::AssignRange(Iterator first, Iterator last, + std::forward_iterator_tag) { + auto length = std::distance(first, last); + // Prefer reassignment to copy construction for elements. + if (static_cast(length) <= size()) { + erase(std::copy(first, last, begin()), end()); + return; + } + reserve(length); + iterator out = begin(); + for (; out != end(); ++first, ++out) *out = *first; + if (allocated()) { + UninitializedCopy(first, last, out); + tag().set_allocated_size(length); + } else { + UninitializedCopy(first, last, out); + tag().set_inline_size(length); + } +} + +template +auto InlinedVector::InsertWithCount(const_iterator position, + size_type n, const_reference v) + -> iterator { + assert(position >= begin() && position <= end()); + if (ABSL_PREDICT_FALSE(n == 0)) return const_cast(position); + + value_type copy = v; + std::pair it_pair = ShiftRight(position, n); + std::fill(it_pair.first, it_pair.second, copy); + UninitializedFill(it_pair.second, it_pair.first + n, copy); + + return it_pair.first; +} + +template +template +auto InlinedVector::InsertWithRange(const_iterator position, + InputIterator first, + InputIterator last, + std::input_iterator_tag) + -> iterator { + assert(position >= begin() && position <= end()); + size_type index = position - cbegin(); + size_type i = index; + while (first != last) insert(begin() + i++, *first++); + return begin() + index; +} + +template +template +auto InlinedVector::InsertWithRange(const_iterator position, + ForwardIterator first, + ForwardIterator last, + std::forward_iterator_tag) + -> iterator { + assert(position >= begin() && position <= end()); + if (ABSL_PREDICT_FALSE(first == last)) return const_cast(position); + + auto n = std::distance(first, last); + std::pair it_pair = ShiftRight(position, n); + size_type used_spots = it_pair.second - it_pair.first; + ForwardIterator open_spot = std::next(first, used_spots); + std::copy(first, open_spot, it_pair.first); + UninitializedCopy(open_spot, last, it_pair.second); + return it_pair.first; +} + +} // namespace absl + +#endif // ABSL_CONTAINER_INLINED_VECTOR_H_ diff --git a/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/memory/memory.h b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/memory/memory.h new file mode 100644 index 000000000..8bf4fe82a --- /dev/null +++ b/TMessagesProj/jni/libtgvoip2/webrtc_dsp/absl/memory/memory.h @@ -0,0 +1,697 @@ +// Copyright 2017 The Abseil Authors. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// ----------------------------------------------------------------------------- +// File: memory.h +// ----------------------------------------------------------------------------- +// +// This header file contains utility functions for managing the creation and +// conversion of smart pointers. This file is an extension to the C++ +// standard library header file. + +#ifndef ABSL_MEMORY_MEMORY_H_ +#define ABSL_MEMORY_MEMORY_H_ + +#include +#include +#include +#include +#include +#include + +#include "absl/base/macros.h" +#include "absl/meta/type_traits.h" + +namespace absl { + +// ----------------------------------------------------------------------------- +// Function Template: WrapUnique() +// ----------------------------------------------------------------------------- +// +// Adopts ownership from a raw pointer and transfers it to the returned +// `std::unique_ptr`, whose type is deduced. Because of this deduction, *do not* +// specify the template type `T` when calling `WrapUnique`. +// +// Example: +// X* NewX(int, int); +// auto x = WrapUnique(NewX(1, 2)); // 'x' is std::unique_ptr. +// +// The purpose of WrapUnique is to automatically deduce the pointer type. If you +// wish to make the type explicit, for readability reasons or because you prefer +// to use a base-class pointer rather than a derived one, just use +// `std::unique_ptr` directly. +// +// Example: +// X* Factory(int, int); +// auto x = std::unique_ptr(Factory(1, 2)); +// - or - +// std::unique_ptr x(Factory(1, 2)); +// +// This has the added advantage of working whether Factory returns a raw +// pointer or a `std::unique_ptr`. +// +// While `absl::WrapUnique` is useful for capturing the output of a raw +// pointer factory, prefer 'absl::make_unique(args...)' over +// 'absl::WrapUnique(new T(args...))'. +// +// auto x = WrapUnique(new X(1, 2)); // works, but nonideal. +// auto x = make_unique(1, 2); // safer, standard, avoids raw 'new'. +// +// Note that `absl::WrapUnique(p)` is valid only if `delete p` is a valid +// expression. In particular, `absl::WrapUnique()` cannot wrap pointers to +// arrays, functions or void, and it must not be used to capture pointers +// obtained from array-new expressions (even though that would compile!). +template +std::unique_ptr WrapUnique(T* ptr) { + static_assert(!std::is_array::value, "array types are unsupported"); + static_assert(std::is_object::value, "non-object types are unsupported"); + return std::unique_ptr(ptr); +} + +namespace memory_internal { + +// Traits to select proper overload and return type for `absl::make_unique<>`. +template +struct MakeUniqueResult { + using scalar = std::unique_ptr; +}; +template +struct MakeUniqueResult { + using array = std::unique_ptr; +}; +template +struct MakeUniqueResult { + using invalid = void; +}; + +} // namespace memory_internal + +// gcc 4.8 has __cplusplus at 201301 but doesn't define make_unique. Other +// supported compilers either just define __cplusplus as 201103 but have +// make_unique (msvc), or have make_unique whenever __cplusplus > 201103 (clang) +#if (__cplusplus > 201103L || defined(_MSC_VER)) && \ + !(defined(__GNUC__) && __GNUC__ == 4 && __GNUC_MINOR__ == 8) +using std::make_unique; +#else +// ----------------------------------------------------------------------------- +// Function Template: make_unique() +// ----------------------------------------------------------------------------- +// +// Creates a `std::unique_ptr<>`, while avoiding issues creating temporaries +// during the construction process. `absl::make_unique<>` also avoids redundant +// type declarations, by avoiding the need to explicitly use the `new` operator. +// +// This implementation of `absl::make_unique<>` is designed for C++11 code and +// will be replaced in C++14 by the equivalent `std::make_unique<>` abstraction. +// `absl::make_unique<>` is designed to be 100% compatible with +// `std::make_unique<>` so that the eventual migration will involve a simple +// rename operation. +// +// For more background on why `std::unique_ptr(new T(a,b))` is problematic, +// see Herb Sutter's explanation on +// (Exception-Safe Function Calls)[http://herbsutter.com/gotw/_102/]. +// (In general, reviewers should treat `new T(a,b)` with scrutiny.) +// +// Example usage: +// +// auto p = make_unique(args...); // 'p' is a std::unique_ptr +// auto pa = make_unique(5); // 'pa' is a std::unique_ptr +// +// Three overloads of `absl::make_unique` are required: +// +// - For non-array T: +// +// Allocates a T with `new T(std::forward args...)`, +// forwarding all `args` to T's constructor. +// Returns a `std::unique_ptr` owning that object. +// +// - For an array of unknown bounds T[]: +// +// `absl::make_unique<>` will allocate an array T of type U[] with +// `new U[n]()` and return a `std::unique_ptr` owning that array. +// +// Note that 'U[n]()' is different from 'U[n]', and elements will be +// value-initialized. Note as well that `std::unique_ptr` will perform its +// own destruction of the array elements upon leaving scope, even though +// the array [] does not have a default destructor. +// +// NOTE: an array of unknown bounds T[] may still be (and often will be) +// initialized to have a size, and will still use this overload. E.g: +// +// auto my_array = absl::make_unique(10); +// +// - For an array of known bounds T[N]: +// +// `absl::make_unique<>` is deleted (like with `std::make_unique<>`) as +// this overload is not useful. +// +// NOTE: an array of known bounds T[N] is not considered a useful +// construction, and may cause undefined behavior in templates. E.g: +// +// auto my_array = absl::make_unique(); +// +// In those cases, of course, you can still use the overload above and +// simply initialize it to its desired size: +// +// auto my_array = absl::make_unique(10); + +// `absl::make_unique` overload for non-array types. +template +typename memory_internal::MakeUniqueResult::scalar make_unique( + Args&&... args) { + return std::unique_ptr(new T(std::forward(args)...)); +} + +// `absl::make_unique` overload for an array T[] of unknown bounds. +// The array allocation needs to use the `new T[size]` form and cannot take +// element constructor arguments. The `std::unique_ptr` will manage destructing +// these array elements. +template +typename memory_internal::MakeUniqueResult::array make_unique(size_t n) { + return std::unique_ptr(new typename absl::remove_extent_t[n]()); +} + +// `absl::make_unique` overload for an array T[N] of known bounds. +// This construction will be rejected. +template +typename memory_internal::MakeUniqueResult::invalid make_unique( + Args&&... /* args */) = delete; +#endif + +// ----------------------------------------------------------------------------- +// Function Template: RawPtr() +// ----------------------------------------------------------------------------- +// +// Extracts the raw pointer from a pointer-like value `ptr`. `absl::RawPtr` is +// useful within templates that need to handle a complement of raw pointers, +// `std::nullptr_t`, and smart pointers. +template +auto RawPtr(T&& ptr) -> decltype(std::addressof(*ptr)) { + // ptr is a forwarding reference to support Ts with non-const operators. + return (ptr != nullptr) ? std::addressof(*ptr) : nullptr; +} +inline std::nullptr_t RawPtr(std::nullptr_t) { return nullptr; } + +// ----------------------------------------------------------------------------- +// Function Template: ShareUniquePtr() +// ----------------------------------------------------------------------------- +// +// Adopts a `std::unique_ptr` rvalue and returns a `std::shared_ptr` of deduced +// type. Ownership (if any) of the held value is transferred to the returned +// shared pointer. +// +// Example: +// +// auto up = absl::make_unique(10); +// auto sp = absl::ShareUniquePtr(std::move(up)); // shared_ptr +// CHECK_EQ(*sp, 10); +// CHECK(up == nullptr); +// +// Note that this conversion is correct even when T is an array type, and more +// generally it works for *any* deleter of the `unique_ptr` (single-object +// deleter, array deleter, or any custom deleter), since the deleter is adopted +// by the shared pointer as well. The deleter is copied (unless it is a +// reference). +// +// Implements the resolution of [LWG 2415](http://wg21.link/lwg2415), by which a +// null shared pointer does not attempt to call the deleter. +template +std::shared_ptr ShareUniquePtr(std::unique_ptr&& ptr) { + return ptr ? std::shared_ptr(std::move(ptr)) : std::shared_ptr(); +} + +// ----------------------------------------------------------------------------- +// Function Template: WeakenPtr() +// ----------------------------------------------------------------------------- +// +// Creates a weak pointer associated with a given shared pointer. The returned +// value is a `std::weak_ptr` of deduced type. +// +// Example: +// +// auto sp = std::make_shared(10); +// auto wp = absl::WeakenPtr(sp); +// CHECK_EQ(sp.get(), wp.lock().get()); +// sp.reset(); +// CHECK(wp.lock() == nullptr); +// +template +std::weak_ptr WeakenPtr(const std::shared_ptr& ptr) { + return std::weak_ptr(ptr); +} + +namespace memory_internal { + +// ExtractOr::type evaluates to E if possible. Otherwise, D. +template