xref: /aosp_15_r20/external/webrtc/api/rtc_event_log_output.h (revision d9f758449e529ab9291ac668be2861e7a55c2422)
1*d9f75844SAndroid Build Coastguard Worker /*
2*d9f75844SAndroid Build Coastguard Worker  *  Copyright (c) 2017 The WebRTC project authors. All Rights Reserved.
3*d9f75844SAndroid Build Coastguard Worker  *
4*d9f75844SAndroid Build Coastguard Worker  *  Use of this source code is governed by a BSD-style license
5*d9f75844SAndroid Build Coastguard Worker  *  that can be found in the LICENSE file in the root of the source
6*d9f75844SAndroid Build Coastguard Worker  *  tree. An additional intellectual property rights grant can be found
7*d9f75844SAndroid Build Coastguard Worker  *  in the file PATENTS.  All contributing project authors may
8*d9f75844SAndroid Build Coastguard Worker  *  be found in the AUTHORS file in the root of the source tree.
9*d9f75844SAndroid Build Coastguard Worker  */
10*d9f75844SAndroid Build Coastguard Worker 
11*d9f75844SAndroid Build Coastguard Worker #ifndef API_RTC_EVENT_LOG_OUTPUT_H_
12*d9f75844SAndroid Build Coastguard Worker #define API_RTC_EVENT_LOG_OUTPUT_H_
13*d9f75844SAndroid Build Coastguard Worker 
14*d9f75844SAndroid Build Coastguard Worker #include <string>
15*d9f75844SAndroid Build Coastguard Worker 
16*d9f75844SAndroid Build Coastguard Worker #include "absl/strings/string_view.h"
17*d9f75844SAndroid Build Coastguard Worker 
18*d9f75844SAndroid Build Coastguard Worker namespace webrtc {
19*d9f75844SAndroid Build Coastguard Worker 
20*d9f75844SAndroid Build Coastguard Worker // NOTE: This class is still under development and may change without notice.
21*d9f75844SAndroid Build Coastguard Worker class RtcEventLogOutput {
22*d9f75844SAndroid Build Coastguard Worker  public:
23*d9f75844SAndroid Build Coastguard Worker   virtual ~RtcEventLogOutput() = default;
24*d9f75844SAndroid Build Coastguard Worker 
25*d9f75844SAndroid Build Coastguard Worker   // An output normally starts out active, though that might not always be
26*d9f75844SAndroid Build Coastguard Worker   // the case (e.g. failed to open a file for writing).
27*d9f75844SAndroid Build Coastguard Worker   // Once an output has become inactive (e.g. maximum file size reached), it can
28*d9f75844SAndroid Build Coastguard Worker   // never become active again.
29*d9f75844SAndroid Build Coastguard Worker   virtual bool IsActive() const = 0;
30*d9f75844SAndroid Build Coastguard Worker 
31*d9f75844SAndroid Build Coastguard Worker   // Write encoded events to an output. Returns true if the output was
32*d9f75844SAndroid Build Coastguard Worker   // successfully written in its entirety. Otherwise, no guarantee is given
33*d9f75844SAndroid Build Coastguard Worker   // about how much data was written, if any. The output sink becomes inactive
34*d9f75844SAndroid Build Coastguard Worker   // after the first time `false` is returned. Write() may not be called on
35*d9f75844SAndroid Build Coastguard Worker   // an inactive output sink.
36*d9f75844SAndroid Build Coastguard Worker   virtual bool Write(absl::string_view output) = 0;
37*d9f75844SAndroid Build Coastguard Worker 
38*d9f75844SAndroid Build Coastguard Worker   // Indicates that buffers should be written to disk if applicable.
Flush()39*d9f75844SAndroid Build Coastguard Worker   virtual void Flush() {}
40*d9f75844SAndroid Build Coastguard Worker };
41*d9f75844SAndroid Build Coastguard Worker 
42*d9f75844SAndroid Build Coastguard Worker }  // namespace webrtc
43*d9f75844SAndroid Build Coastguard Worker 
44*d9f75844SAndroid Build Coastguard Worker #endif  // API_RTC_EVENT_LOG_OUTPUT_H_
45