Сбой iOS в релизе после обновления модулей GoogleMaps и GooglePlaces - PullRequest
4 голосов
/ 26 марта 2019

У меня есть приложение target-c, которое до сих пор использует GoogleMaps и GooglePlaces pods, версии 2.7.0 .Из-за недавнего устаревания Google просит обновить обе версии до v3.0.0 .https://developers.google.com/places/ios-sdk/client-migration

Проблема

Когда я редактирую приложение для использования версий 3.0.0, оно падает сразу после запуска LaunchScreen без вызова делегата didFinishLaunchingWithOptions .Это происходит только в версии и только с физическими устройствами .

#0  0x00000001014d5290 in std::__1::vector<int, std::__1::allocator<int> >::vector(std::__1::vector<int, std::__1::allocator<int> > const&) ()
#1  0x0000000101633178 in std::__1::vector<unsigned int, std::__1::allocator<unsigned int> >::vector(unsigned long) ()
#2  0x0000000101683494 in GMSx_absl::base_internal::InitGetTID() ()
#3  0x000000010167ae38 in void GMSx_absl::base_internal::CallOnceImpl<void (&)()>(std::__1::atomic<unsigned int>*, GMSx_absl::base_internal::SchedulingMode, void (&&&)()) ()
#4  0x00000001016833c4 in GMSx_absl::base_internal::GetTID() ()
#5  0x00000001016566a0 in GMSx_base_logging::LogMessage::Flush() ()
#6  0x00000001016564d4 in GMSx_base_logging::LogMessage::~LogMessage() ()
#7  0x0000000101655290 in (anonymous namespace)::AddFlagValidator(void const*, bool (*)()) ()
#8  0x00000001016841d0 in _GLOBAL__sub_I_vlog_is_on.cc ()
#9  0x0000000102649504 in ImageLoaderMachO::doModInitFunctions(ImageLoader::LinkContext const&) ()
#10 0x0000000102649738 in ImageLoaderMachO::doInitialization(ImageLoader::LinkContext const&) ()
#11 0x0000000102644768 in ImageLoader::recursiveInitialization(ImageLoader::LinkContext const&, unsigned int, char const*, ImageLoader::InitializerTimingList&, ImageLoader::UninitedUpwards&) ()
#12 0x0000000102643798 in ImageLoader::processInitializers(ImageLoader::LinkContext const&, unsigned int, ImageLoader::InitializerTimingList&, ImageLoader::UninitedUpwards&) ()
#13 0x0000000102643854 in ImageLoader::runInitializers(ImageLoader::LinkContext const&, ImageLoader::InitializerTimingList&) ()
#14 0x00000001026326a4 in dyld::initializeMainExecutable() ()
#15 0x0000000102637468 in dyld::_main(macho_header const*, unsigned long, int, char const**, char const**, char const**, unsigned long*) ()
#16 0x0000000102631044 in _dyld_start ()

Дамп символов

<_NSCallStackArray 0x104f67740>(
0   ???                                 0x00000001050f890c 0x0 + 4379871500,
1   MyApp                              0x00000001010416e0 main + 0,
2   MyApp                              0x0000000101683494 _ZN9GMSx_absl13base_internalL10InitGetTIDEv + 116,
3   MyApp                              0x000000010167ae38 _ZN9GMSx_absl13base_internal12CallOnceImplIRFvvEJEEEvPNSt3__16atomicIjEENS0_14SchedulingModeEOT_DpOT0_ + 88,
4   MyApp                              0x00000001016833c4 _ZN9GMSx_absl13base_internal6GetTIDEv + 420,
5   MyApp                              0x00000001016566a0 _ZN17GMSx_base_logging10LogMessage5FlushEv + 280,
6   MyApp                              0x00000001016564d4 _ZN17GMSx_base_logging10LogMessageD2Ev + 20,
7   MyApp                              0x0000000101655290 _ZN12_GLOBAL__N_116AddFlagValidatorEPKvPFbvE + 316,
8   MyApp                              0x00000001016841d0 _GLOBAL__sub_I_vlog_is_on.cc + 56,
9   ???                                 0x0000000102649504 0x0 + 4335113476,
10  ???                                 0x0000000102649738 0x0 + 4335114040,
11  ???                                 0x0000000102644768 0x0 + 4335093608,
12  ???                                 0x0000000102643798 0x0 + 4335089560,
13  ???                                 0x0000000102643854 0x0 + 4335089748,
14  ???                                 0x00000001026326a4 0x0 + 4335019684,
15  ???                                 0x0000000102637468 0x0 + 4335039592,
16  ???                                 0x0000000102631044 0x0 + 4335013956
)

Что я пробовал до сих пор

Просто чтобы убедиться, что это не 'фальшивая ошибка' :

  • очистка папки сборки
  • удаление производных данных
  • удаление папки pods и рабочей области и повторное создание всех с pod install
  • многократным перезапуском Xcode и Mac

Но я также попробовал эти обходные пути:

  • Отключить битовый код
  • Установка быстрой компиляции в ноль (из самой быстрой)

Ничто из вышеперечисленного не решило и не пропустило сбой.Восстановление версий до 2.7.0 делает приложение снова работающим!

Кто-нибудь испытывал нечто подобное с библиотеками GoogleMaps и GooglePaces?Кто-нибудь может предложить другой способ исследования проблемы?

Решение

Версия 3.0.3 стручков решает ошибку

1 Ответ

0 голосов
/ 26 марта 2019

Cocoapods потерпит неудачу, если версии не совпадают, чтобы решить;

открыть терминал и;

  sudo gem install cocoapods

Добавить --pre для получения последней предварительной версии:

  sudo gem install cocoapods --pre
...