Расшифровка протобуф данных из plCrashReporter - PullRequest
1 голос
/ 09 декабря 2010

Я интегрирую plCrashReporter в одно из моих приложений, чтобы добавить функцию отчетов о сбоях.По сути, если я обнаруживаю сбой, я собираю отчет о сбое как NSData ...

NSData *crashData;
NSError *error;
crashData = [crashReporter loadPendingCrashReportDataAndReturnError: &error];

crashData теперь содержит весь отчет.Я могу вставить эти crashData в структуру PLCrashReport и прочитать ее параметры, но я бы просто отправил весь большой двоичный объект на мои серверы и посмотрел его там.Когда данные доходят до меня, это выглядит примерно так:

706c6372 61736801 0a110801 1205342e 322e3118 02209184 82e80412
1b0a1263 6f6d2e73 6d756c65 2e545061 696e4465 76120531 2e362e32
1adb0208 00120618 d4a5f59d 03120618 bda5f59d 03120418 b5b96c12
0618df95 b09d0312 0618938b 9f9a0312 0618f9bb f68d0312 0618cdbc
f68d0312

Мне не повезло, что я получил что-то значимое из этого.Я пытался использовать plcrashutil, но безуспешно ...

. / Plcrashutil convert --format = iphone example.plcrash Не удалось декодировать журнал сбоя: не удалось декодировать недопустимый заголовок журнала сбоя

Я также попытался использовать protobuf от Google, но не смог его запустить.

У меня есть файл dSYM, но я даже не собираюсь его символизировать.

Я использую Mac OS X 10.6.5.

Буду очень признателен за любые советы.Спасибо!

1 Ответ

2 голосов
/ 11 декабря 2010

Разобрался!Отчет отправляется в шестнадцатеричном виде, но преобразование его в двоичный код позволяет вам затем запустить его через plcrashutil.Вот моя HexToBinary.cpp реализация.

...