File: TemporaryFileMatching.swift

package info (click to toggle)
swiftlang 6.1.3-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,791,532 kB
  • sloc: cpp: 9,901,743; ansic: 2,201,431; asm: 1,091,827; python: 308,252; objc: 82,166; f90: 80,126; lisp: 38,358; pascal: 25,559; sh: 20,429; ml: 5,058; perl: 4,745; makefile: 4,484; awk: 3,535; javascript: 3,018; xml: 918; fortran: 664; cs: 573; ruby: 396
file content (78 lines) | stat: -rw-r--r-- 2,629 bytes parent folder | download | duplicates (2)
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
//===-------- TemporaryFileMatch.swift - Driver Testing Extensions --------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2020 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 the list of Swift project authors
//
//===----------------------------------------------------------------------===//

import TSCBasic
import SwiftDriver


public func matchTemporary(_ path: VirtualPath, basename: String, fileExtension: String?) -> Bool {
  let relativePath: RelativePath
  switch path {
    case .temporary(let tempPath):
      relativePath = tempPath
    case .temporaryWithKnownContents(let tempPath, _):
      relativePath = tempPath
    default:
      return false
  }
  return relativePath.basenameWithoutExt.hasPrefix(basename) &&
         fileExtension == relativePath.extension
}

public func matchTemporary(_ path: VirtualPath, _ filename: String) -> Bool {
  let components = filename.components(separatedBy: ".")
  if components.count == 1 {
    return matchTemporary(path, basename: filename, fileExtension: nil)
  } else if components.count == 2 {
    return matchTemporary(path, basename: components[0], fileExtension: components[1])
  } else {
    let basename = components[0 ..< components.count - 1].joined()
    return matchTemporary(path, basename: basename, fileExtension: components.last)
  }
}

public func commandContainsFlagTemporaryPathSequence(_ cmd: [Job.ArgTemplate],
                                                     flag: Job.ArgTemplate,
                                                     filename: String)
-> Bool {
  for (index, element) in cmd.enumerated() {
    if element == flag,
       (index + 1) < cmd.count {
      guard case .path(let relativePath) = cmd[index + 1] else {
        continue
      }
      if matchTemporary(relativePath, filename) {
        return true
      }
    }
  }
  return false
}

public func commandContainsTemporaryPath(_ cmd: [Job.ArgTemplate],
                                         _ filename: String)
-> Bool {
  return cmd.contains {
    guard case .path(let path) = $0 else { return false }
    return matchTemporary(path, filename)
  }
}

public func commandContainsTemporaryResponsePath(_ cmd: [Job.ArgTemplate],
                                                 _ filename: String)
-> Bool {
  return cmd.contains {
    guard case .responseFilePath(let path) = $0 else { return false }
    return matchTemporary(path, filename)
  }
}