File: Duration.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 (60 lines) | stat: -rw-r--r-- 2,290 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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
/*
 This source file is part of the Swift.org open source project

 Copyright (c) 2021 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

extension Benchmark {
    /// A duration metric in milliseconds.
    ///
    /// Use this metric to measure how long a given named task takes.
    public class Duration: DynamicallyIdentifiableMetric, BenchmarkBlockMetric {
        public static let identifier = "duration"
        public static let displayName = "Duration for an operation"

        public var identifier: String { "duration-\(self.id)" }
        public var displayName: String { "Duration for '\(self.id)'" }

        public var result: MetricValue?

        private let id: String
        private var startTime = 0.0
        
        /// Creates a new instance with the given name.
        ///
        /// Since this metric can be used multiple times to measure
        /// the duration of various tasks, `init(id:)` requires you
        /// to provide an id for the task being measured. The `id`
        /// parameter will be appended to the metric identifier in the
        /// exported benchmark report to keep the various durations
        /// distinguishable like so: `duration-myTask1`, `duration-my-other-task`, etc.
        public init(id: String) {
            self.id = id
        }
        
        public func begin() {
            startTime = ProcessInfo.processInfo.systemUptime
        }
        
        public func end() {
            // We need to multiply the resulting duration by 1000 to store
            // a value in milliseconds as an integer to avoid floating point
            // encoding artifacts.
            result = .duration((ProcessInfo.processInfo.systemUptime - startTime))
        }
        
        /// Convenience init to use when the duration is tracked elsewhere.
        /// - Parameter id: The id for the metric.
        /// - Parameter duration: The duration value in seconds to be logged.
        public init(id: String, duration: TimeInterval) {
            self.id = id
            result = .duration(duration)
        }
    }
}