Thirumurugan | 7ea0a5e | 2024-10-16 15:44:03 | [diff] [blame] | 1 | // Copyright 2024 The Chromium Authors |
| 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
| 5 | #include "base/logging/rust_log_integration.h" |
| 6 | |
Collin Baker | 7cbc0d17 | 2025-03-19 21:02:01 | [diff] [blame] | 7 | #include <stdint.h> |
| 8 | |
Thirumurugan | 7ea0a5e | 2024-10-16 15:44:03 | [diff] [blame] | 9 | #include "base/logging.h" |
Lukasz Anforowicz | 191a4d3 | 2024-11-12 01:48:08 | [diff] [blame] | 10 | #include "base/logging/log_severity.h" |
Collin Baker | f0fd42e | 2025-03-21 16:47:39 | [diff] [blame] | 11 | #include "base/logging/rust_logger.rs.h" |
| 12 | #include "third_party/rust/cxx/v1/cxx.h" |
Thirumurugan | 7ea0a5e | 2024-10-16 15:44:03 | [diff] [blame] | 13 | |
Peter Kasting | 811504a7 | 2025-01-09 03:18:50 | [diff] [blame] | 14 | namespace logging::internal { |
Thirumurugan | 7ea0a5e | 2024-10-16 15:44:03 | [diff] [blame] | 15 | |
Collin Baker | e1e02fde | 2025-03-26 16:40:16 | [diff] [blame] | 16 | LogMessageRustWrapper::LogMessageRustWrapper(const char* file, |
Collin Baker | f0fd42e | 2025-03-21 16:47:39 | [diff] [blame] | 17 | int line, |
| 18 | ::logging::LogSeverity severity) |
| 19 | : log_message(file, line, severity) {} |
| 20 | |
| 21 | void LogMessageRustWrapper::write_to_stream(rust::Str str) { |
| 22 | log_message.stream().write(str.data(), |
| 23 | static_cast<std::streamsize>(str.size())); |
| 24 | } |
| 25 | |
| 26 | void print_rust_log(const RustFmtArguments& msg, |
Collin Baker | e1e02fde | 2025-03-26 16:40:16 | [diff] [blame] | 27 | const char* file, |
Collin Baker | 7cbc0d17 | 2025-03-19 21:02:01 | [diff] [blame] | 28 | int32_t line, |
| 29 | int32_t severity, |
| 30 | bool verbose) { |
Lukasz Anforowicz | 191a4d3 | 2024-11-12 01:48:08 | [diff] [blame] | 31 | // TODO(danakj): If `verbose` make the log equivalent to VLOG instead of LOG. |
Collin Baker | e1e02fde | 2025-03-26 16:40:16 | [diff] [blame] | 32 | LogMessageRustWrapper wrapper(file, line, severity); |
Collin Baker | f0fd42e | 2025-03-21 16:47:39 | [diff] [blame] | 33 | msg.format(wrapper); |
Thirumurugan | 7ea0a5e | 2024-10-16 15:44:03 | [diff] [blame] | 34 | } |
| 35 | |
Peter Kasting | 811504a7 | 2025-01-09 03:18:50 | [diff] [blame] | 36 | } // namespace logging::internal |