forked from chromium/chromium
-
Notifications
You must be signed in to change notification settings - Fork 0
/
error_codes.cc
84 lines (64 loc) · 2.43 KB
/
error_codes.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chromecast/base/error_codes.h"
#include <errno.h>
#include <fcntl.h>
#include <string>
#include "base/files/file_util.h"
#include "base/logging.h"
#include "base/strings/string_number_conversions.h"
#include "chromecast/base/path_utils.h"
namespace chromecast {
namespace {
const char kInitialErrorFile[] = "initial_error";
base::FilePath GetInitialErrorFilePath() {
return GetHomePathASCII(kInitialErrorFile);
}
} // namespace
ErrorCode GetInitialErrorCode() {
std::string initial_error_code_str;
if (!base::ReadFileToString(GetInitialErrorFilePath(),
&initial_error_code_str)) {
return NO_ERROR;
}
int initial_error_code = 0;
if (base::StringToInt(initial_error_code_str, &initial_error_code) &&
initial_error_code >= NO_ERROR && initial_error_code <= ERROR_UNKNOWN) {
DVLOG(1) << "Initial error from " << GetInitialErrorFilePath().value()
<< ": " << initial_error_code;
return static_cast<ErrorCode>(initial_error_code);
}
LOG(ERROR) << "Unknown initial error code: " << initial_error_code_str;
return NO_ERROR;
}
bool SetInitialErrorCode(ErrorCode initial_error_code) {
// Note: Do not use Chromium IO methods in this function. When cast_shell
// crashes, this function can be called by any thread.
const std::string error_file_path = GetInitialErrorFilePath().value();
if (initial_error_code > NO_ERROR && initial_error_code <= ERROR_UNKNOWN) {
const std::string initial_error_code_str(
base::NumberToString(initial_error_code));
int fd = creat(error_file_path.c_str(), 0640);
if (fd < 0) {
PLOG(ERROR) << "Could not open error code file";
return false;
}
int written =
write(fd, initial_error_code_str.data(), initial_error_code_str.size());
if (written != static_cast<int>(initial_error_code_str.size())) {
PLOG(ERROR) << "Could not write error code to file: written=" << written
<< ", expected=" << initial_error_code_str.size();
close(fd);
return false;
}
close(fd);
return true;
}
// Remove initial error file if no error.
if (unlink(error_file_path.c_str()) == 0 || errno == ENOENT)
return true;
PLOG(ERROR) << "Failed to remove error file";
return false;
}
} // namespace chromecast