summaryrefslogtreecommitdiffstats
path: root/updater/updater.cpp
diff options
context:
space:
mode:
authorTianjie Xu <xunchang@google.com>2016-05-23 23:28:44 +0200
committerandroid-build-merger <android-build-merger@google.com>2016-05-23 23:28:44 +0200
commit8a43084979c3fc3da20e23fc325922e5d01e2424 (patch)
tree6930deb10e9c1f0f7e7a160773455edbd0d027d4 /updater/updater.cpp
parentresolve merge conflicts of 86a28d0 to klp-modular-dev am: a5bc59620f am: 36acff7d7e am: 1f814d7630 am: ca45737e27 am: 8a1d4e97ad am: aa02888e55 am: 300af0779d am: fc1d9a49d1 am: b02b2fe392 am: 75dea9ca3a am: bd43d7e92b (diff)
parentresolve merge conflicts of 3aabd77 to nyc-mr1-dev-plus-aosp (diff)
downloadandroid_bootable_recovery-8a43084979c3fc3da20e23fc325922e5d01e2424.tar
android_bootable_recovery-8a43084979c3fc3da20e23fc325922e5d01e2424.tar.gz
android_bootable_recovery-8a43084979c3fc3da20e23fc325922e5d01e2424.tar.bz2
android_bootable_recovery-8a43084979c3fc3da20e23fc325922e5d01e2424.tar.lz
android_bootable_recovery-8a43084979c3fc3da20e23fc325922e5d01e2424.tar.xz
android_bootable_recovery-8a43084979c3fc3da20e23fc325922e5d01e2424.tar.zst
android_bootable_recovery-8a43084979c3fc3da20e23fc325922e5d01e2424.zip
Diffstat (limited to 'updater/updater.cpp')
-rw-r--r--updater/updater.cpp17
1 files changed, 17 insertions, 0 deletions
diff --git a/updater/updater.cpp b/updater/updater.cpp
index 759c1c97e..0da7a4e82 100644
--- a/updater/updater.cpp
+++ b/updater/updater.cpp
@@ -160,11 +160,28 @@ int main(int argc, char** argv) {
printf("script aborted: %s\n", state.errmsg);
char* line = strtok(state.errmsg, "\n");
while (line) {
+ // Parse the error code in abort message.
+ // Example: "E30: This package is for bullhead devices."
+ if (*line == 'E') {
+ if (sscanf(line, "E%u: ", &state.error_code) != 1) {
+ printf("Failed to parse error code: [%s]\n", line);
+ }
+ }
fprintf(cmd_pipe, "ui_print %s\n", line);
line = strtok(NULL, "\n");
}
fprintf(cmd_pipe, "ui_print\n");
}
+
+ if (state.error_code != kNoError) {
+ fprintf(cmd_pipe, "log error: %d\n", state.error_code);
+ // Cause code should provide additional information about the abort;
+ // report only when an error exists.
+ if (state.cause_code != kNoCause) {
+ fprintf(cmd_pipe, "log cause: %d\n", state.cause_code);
+ }
+ }
+
free(state.errmsg);
return 7;
} else {