File: DiagnosticFileWriter.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (44 lines) | stat: -rw-r--r-- 1,718 bytes parent folder | download
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
/*
 This source file is part of the Swift.org open source project

 Copyright (c) 2023 Apple Inc. and the Swift project authors
 Licensed under Apache License v2.0 with Runtime Library Exception

 See https://swift.org/LICENSE.txt for license information
 See https://swift.org/CONTRIBUTORS.txt for Swift project authors
*/

import Foundation

/// A diagnostic consumer that writes detailed diagnostic information to a file.
///
/// For tools interacting with DocC, the diagnostic file format includes more information about the diagnostics than what
/// is output to the consoles. 
public final class DiagnosticFileWriter: DiagnosticConsumer {
    /// The path where the diagnostic file writer should write the diagnostics file.
    var outputPath: URL
    
    /// Creates a new diagnostic file writer with a specific output path.
    /// - Parameter outputPath: The path where the diagnostic file writer should write the diagnostics file.
    public init(outputPath: URL) {
        self.outputPath = outputPath
    }
    private var receivedProblems: [Problem] = []
    
    public func receive(_ problems: [Problem]) {
        receivedProblems.append(contentsOf: problems)
    }
    
    public func flush() throws {
        let fileContent = DiagnosticFile(problems: receivedProblems)
        // Don't clear the received problems, `flush()` is called more than once.
        let encoder = RenderJSONEncoder.makeEncoder(emitVariantOverrides: false)
        try encoder.encode(fileContent).write(to: outputPath, options: .atomic)
    }
    
    // This is deprecated but still necessary to implement.
    @available(*, deprecated, renamed: "flush()")
    public func finalize() throws {
        try flush()
    }
}