|
1 | 1 | // Copyright The OpenTelemetry Authors |
2 | 2 | // SPDX-License-Identifier: Apache-2.0 |
3 | 3 |
|
| 4 | +#include <algorithm> |
4 | 5 | #include <chrono> |
5 | 6 | #include <memory> |
6 | 7 | #include <utility> |
@@ -75,77 +76,66 @@ void MultiLogRecordProcessor::OnEmit(std::unique_ptr<Recordable> &&record) noexc |
75 | 76 |
|
76 | 77 | bool MultiLogRecordProcessor::ForceFlush(std::chrono::microseconds timeout) noexcept |
77 | 78 | { |
78 | | - // Convert to nanos to prevent overflow |
79 | | - std::chrono::nanoseconds timeout_ns = std::chrono::nanoseconds::max(); |
80 | | - if (std::chrono::duration_cast<std::chrono::microseconds>(timeout_ns) > timeout) |
81 | | - { |
82 | | - timeout_ns = std::chrono::duration_cast<std::chrono::nanoseconds>(timeout); |
83 | | - } |
84 | 79 | bool result = true; |
85 | 80 | auto start_time = std::chrono::system_clock::now(); |
86 | 81 | auto overflow_checker = std::chrono::system_clock::time_point::max(); |
87 | 82 | std::chrono::system_clock::time_point expire_time; |
88 | | - if (overflow_checker - start_time <= timeout_ns) |
| 83 | + if (std::chrono::duration_cast<std::chrono::system_clock::duration>(overflow_checker - |
| 84 | + start_time) <= timeout) |
89 | 85 | { |
90 | 86 | expire_time = overflow_checker; |
91 | 87 | } |
92 | 88 | else |
93 | 89 | { |
94 | 90 | expire_time = |
95 | | - start_time + std::chrono::duration_cast<std::chrono::system_clock::duration>(timeout_ns); |
| 91 | + start_time + std::chrono::duration_cast<std::chrono::system_clock::duration>(timeout); |
96 | 92 | } |
97 | 93 | for (auto &processor : processors_) |
98 | 94 | { |
99 | | - if (!processor->ForceFlush(std::chrono::duration_cast<std::chrono::microseconds>(timeout_ns))) |
| 95 | + if (!processor->ForceFlush(timeout)) |
100 | 96 | { |
101 | 97 | result = false; |
102 | 98 | } |
103 | 99 | start_time = std::chrono::system_clock::now(); |
104 | 100 | if (expire_time > start_time) |
105 | 101 | { |
106 | | - timeout_ns = std::chrono::duration_cast<std::chrono::nanoseconds>(expire_time - start_time); |
| 102 | + timeout = std::chrono::duration_cast<std::chrono::microseconds>(expire_time - start_time); |
107 | 103 | } |
108 | 104 | else |
109 | 105 | { |
110 | | - timeout_ns = std::chrono::nanoseconds::zero(); |
| 106 | + timeout = std::chrono::microseconds::zero(); |
111 | 107 | } |
112 | 108 | } |
113 | 109 | return result; |
114 | 110 | } |
115 | 111 |
|
116 | 112 | bool MultiLogRecordProcessor::Shutdown(std::chrono::microseconds timeout) noexcept |
117 | 113 | { |
118 | | - // Converto nanos to prevent overflow |
119 | | - std::chrono::nanoseconds timeout_ns = std::chrono::nanoseconds::max(); |
120 | | - if (std::chrono::duration_cast<std::chrono::microseconds>(timeout_ns) > timeout) |
121 | | - { |
122 | | - timeout_ns = std::chrono::duration_cast<std::chrono::nanoseconds>(timeout); |
123 | | - } |
124 | 114 | bool result = true; |
125 | 115 | auto start_time = std::chrono::system_clock::now(); |
126 | 116 | auto overflow_checker = std::chrono::system_clock::time_point::max(); |
127 | 117 | std::chrono::system_clock::time_point expire_time; |
128 | | - if (overflow_checker - start_time <= timeout_ns) |
| 118 | + if (std::chrono::duration_cast<std::chrono::system_clock::duration>(overflow_checker - |
| 119 | + start_time) <= timeout) |
129 | 120 | { |
130 | 121 | expire_time = overflow_checker; |
131 | 122 | } |
132 | 123 | else |
133 | 124 | { |
134 | 125 | expire_time = |
135 | | - start_time + std::chrono::duration_cast<std::chrono::system_clock::duration>(timeout_ns); |
| 126 | + start_time + std::chrono::duration_cast<std::chrono::system_clock::duration>(timeout); |
136 | 127 | } |
137 | 128 | for (auto &processor : processors_) |
138 | 129 | { |
139 | | - result |= |
140 | | - processor->Shutdown(std::chrono::duration_cast<std::chrono::microseconds>(timeout_ns)); |
| 130 | + result |= processor->Shutdown(timeout); |
141 | 131 | start_time = std::chrono::system_clock::now(); |
142 | 132 | if (expire_time > start_time) |
143 | 133 | { |
144 | | - timeout_ns = std::chrono::duration_cast<std::chrono::nanoseconds>(expire_time - start_time); |
| 134 | + timeout = std::chrono::duration_cast<std::chrono::microseconds>(expire_time - start_time); |
145 | 135 | } |
146 | 136 | else |
147 | 137 | { |
148 | | - timeout_ns = std::chrono::nanoseconds::zero(); |
| 138 | + timeout = std::chrono::microseconds::zero(); |
149 | 139 | } |
150 | 140 | } |
151 | 141 | return result; |
|
0 commit comments