Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
7e774b6cf5 | ||
|
|
8b371fa5d2 | ||
|
|
02fd579f19 | ||
|
|
e915bc0cfb | ||
|
|
f4c2c75aa1 |
8
.github/deploy
vendored
8
.github/deploy
vendored
@@ -115,12 +115,12 @@ func podspec(repo: Repo, user: User, pkg: Package) -> (Substring, String) {
|
|||||||
return (name, """
|
return (name, """
|
||||||
Pod::Spec.new do |s|
|
Pod::Spec.new do |s|
|
||||||
s.name = '\(name)'
|
s.name = '\(name)'
|
||||||
s.version = '\(tag)'
|
|
||||||
s.summary = '\(repo.description)'
|
|
||||||
s.homepage = "https://github.com/\(slug)"
|
|
||||||
s.license = '\(repo.license.spdx_id)'
|
|
||||||
s.author = { '\(user.name)': '\(user.email)' }
|
s.author = { '\(user.name)': '\(user.email)' }
|
||||||
s.source = { git: "https://github.com/\(slug).git", tag: '\(tag)' }
|
s.source = { git: "https://github.com/\(slug).git", tag: '\(tag)' }
|
||||||
|
s.version = '\(tag)'
|
||||||
|
s.summary = '\(repo.description)'
|
||||||
|
s.license = '\(repo.license.spdx_id)'
|
||||||
|
s.homepage = "https://github.com/\(slug)"
|
||||||
s.social_media_url = 'https://twitter.com/\(owner)'
|
s.social_media_url = 'https://twitter.com/\(owner)'
|
||||||
s.osx.deployment_target = '10.10'
|
s.osx.deployment_target = '10.10'
|
||||||
s.ios.deployment_target = '8.0'
|
s.ios.deployment_target = '8.0'
|
||||||
|
|||||||
@@ -64,6 +64,7 @@ jobs:
|
|||||||
name: Check Linux tests are sync’d
|
name: Check Linux tests are sync’d
|
||||||
install: swift test --generate-linuxmain
|
install: swift test --generate-linuxmain
|
||||||
script: git diff --exit-code
|
script: git diff --exit-code
|
||||||
|
osx_image: xcode10.2
|
||||||
|
|
||||||
- stage: deploy
|
- stage: deploy
|
||||||
name: Jazzy
|
name: Jazzy
|
||||||
|
|||||||
@@ -53,7 +53,7 @@ help me continue my work, I appreciate it x
|
|||||||
<img src="https://c5.patreon.com/external/logo/become_a_patron_button@2x.png" width="160">
|
<img src="https://c5.patreon.com/external/logo/become_a_patron_button@2x.png" width="160">
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
[Other donation/tipping options](http://mxcl.github.io/donate/)
|
[Other donation/tipping options](http://mxcl.dev/#donate)
|
||||||
|
|
||||||
# Handbook
|
# Handbook
|
||||||
|
|
||||||
@@ -316,7 +316,7 @@ pursuit of getting it *right*)! We will tag 1.0 as soon as possible.
|
|||||||
|
|
||||||
### Get push notifications for new releases
|
### Get push notifications for new releases
|
||||||
|
|
||||||
https://codebasesaga.com/canopy/
|
https://mxcl.dev/canopy/
|
||||||
|
|
||||||
# Alternatives
|
# Alternatives
|
||||||
|
|
||||||
@@ -328,7 +328,7 @@ https://codebasesaga.com/canopy/
|
|||||||
|
|
||||||
[badge-platforms]: https://img.shields.io/badge/platforms-macOS%20%7C%20Linux%20%7C%20iOS%20%7C%20tvOS%20%7C%20watchOS-lightgrey.svg
|
[badge-platforms]: https://img.shields.io/badge/platforms-macOS%20%7C%20Linux%20%7C%20iOS%20%7C%20tvOS%20%7C%20watchOS-lightgrey.svg
|
||||||
[badge-languages]: https://img.shields.io/badge/swift-4.2%20%7C%205.0-orange.svg
|
[badge-languages]: https://img.shields.io/badge/swift-4.2%20%7C%205.0-orange.svg
|
||||||
[docs]: https://mxcl.github.io/Path.swift/Structs/Path.html
|
[docs]: https://mxcl.dev/Path.swift/Structs/Path.html
|
||||||
[badge-jazzy]: https://raw.githubusercontent.com/mxcl/Path.swift/gh-pages/badge.svg?sanitize=true
|
[badge-jazzy]: https://raw.githubusercontent.com/mxcl/Path.swift/gh-pages/badge.svg?sanitize=true
|
||||||
[badge-codecov]: https://codecov.io/gh/mxcl/Path.swift/branch/master/graph/badge.svg
|
[badge-codecov]: https://codecov.io/gh/mxcl/Path.swift/branch/master/graph/badge.svg
|
||||||
[badge-ci]: https://travis-ci.com/mxcl/Path.swift.svg
|
[badge-ci]: https://travis-ci.com/mxcl/Path.swift.svg
|
||||||
|
|||||||
@@ -34,6 +34,11 @@ public extension Bundle {
|
|||||||
var path: Path {
|
var path: Path {
|
||||||
return Path(string: bundlePath)
|
return Path(string: bundlePath)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Returns the executable for this bundle, if there is one, not all bundles have one hence `Optional`.
|
||||||
|
var executable: Path? {
|
||||||
|
return executablePath.flatMap(Path.init)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Extensions on `String` that work with `Path` rather than `String` or `URL`
|
/// Extensions on `String` that work with `Path` rather than `String` or `URL`
|
||||||
|
|||||||
@@ -53,11 +53,25 @@ public struct Path: Equatable, Hashable, Comparable {
|
|||||||
- Note: On macOS, removes an initial component of “/private/var/automount”, “/var/automount”, or “/private” from the path, if the result still indicates an existing file or directory (checked by consulting the file system).
|
- Note: On macOS, removes an initial component of “/private/var/automount”, “/var/automount”, or “/private” from the path, if the result still indicates an existing file or directory (checked by consulting the file system).
|
||||||
- Returns: The path or `nil` if fed a relative path or a `~foo` string where there is no user `foo`.
|
- Returns: The path or `nil` if fed a relative path or a `~foo` string where there is no user `foo`.
|
||||||
*/
|
*/
|
||||||
public init?(_ description: String) {
|
public init?<S: StringProtocol>(_ description: S) {
|
||||||
var pathComponents = description.split(separator: "/")
|
var pathComponents = description.split(separator: "/")
|
||||||
switch description.first {
|
switch description.first {
|
||||||
case "/":
|
case "/":
|
||||||
break
|
#if os(macOS)
|
||||||
|
func ifExists(withPrefix prefix: String, removeFirst n: Int) {
|
||||||
|
assert(prefix.split(separator: "/").count == n)
|
||||||
|
|
||||||
|
if description.hasPrefix(prefix), FileManager.default.fileExists(atPath: String(description)) {
|
||||||
|
pathComponents.removeFirst(n)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ifExists(withPrefix: "/private/var/automount", removeFirst: 3)
|
||||||
|
ifExists(withPrefix: "/var/automount", removeFirst: 2)
|
||||||
|
ifExists(withPrefix: "/private", removeFirst: 1)
|
||||||
|
#endif
|
||||||
|
self.string = join_(prefix: "/", pathComponents: pathComponents)
|
||||||
|
|
||||||
case "~":
|
case "~":
|
||||||
if description == "~" {
|
if description == "~" {
|
||||||
self = Path.home
|
self = Path.home
|
||||||
@@ -82,26 +96,11 @@ public struct Path: Equatable, Hashable, Comparable {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
pathComponents.remove(at: 0)
|
pathComponents.remove(at: 0)
|
||||||
pathComponents.insert(contentsOf: tilded.split(separator: "/"), at: 0)
|
self.string = join_(prefix: tilded, pathComponents: pathComponents)
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
#if os(macOS)
|
|
||||||
func ifExists(withPrefix prefix: String, removeFirst n: Int) {
|
|
||||||
assert(prefix.split(separator: "/").count == n)
|
|
||||||
|
|
||||||
if description.hasPrefix(prefix), FileManager.default.fileExists(atPath: description) {
|
|
||||||
pathComponents.removeFirst(n)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ifExists(withPrefix: "/private/var/automount", removeFirst: 3)
|
|
||||||
ifExists(withPrefix: "/var/automount", removeFirst: 2)
|
|
||||||
ifExists(withPrefix: "/private", removeFirst: 1)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
self.string = join_(prefix: "/", pathComponents: pathComponents)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -403,6 +403,7 @@ class PathTests: XCTestCase {
|
|||||||
XCTAssertEqual(bndl.privateFrameworks, tmpdir.Frameworks)
|
XCTAssertEqual(bndl.privateFrameworks, tmpdir.Frameworks)
|
||||||
XCTAssertEqual(bndl.resources, tmpdir)
|
XCTAssertEqual(bndl.resources, tmpdir)
|
||||||
XCTAssertNil(bndl.path(forResource: "foo", ofType: "bar"))
|
XCTAssertNil(bndl.path(forResource: "foo", ofType: "bar"))
|
||||||
|
XCTAssertNil(bndl.executable)
|
||||||
|
|
||||||
#if os(macOS)
|
#if os(macOS)
|
||||||
XCTAssertEqual(bndl.defaultSharedFrameworksPath, tmpdir.Contents.Frameworks)
|
XCTAssertEqual(bndl.defaultSharedFrameworksPath, tmpdir.Contents.Frameworks)
|
||||||
@@ -593,4 +594,14 @@ class PathTests: XCTestCase {
|
|||||||
XCTAssertEqual(Path.root.foo.bar.components, ["/", "foo", "bar"])
|
XCTAssertEqual(Path.root.foo.bar.components, ["/", "foo", "bar"])
|
||||||
XCTAssertEqual(Path.root.components, ["/"])
|
XCTAssertEqual(Path.root.components, ["/"])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func testFlatMap() throws {
|
||||||
|
// testing compile works
|
||||||
|
let foo: String? = "/a"
|
||||||
|
_ = foo.flatMap(Path.init)
|
||||||
|
let bar: Substring? = "/a"
|
||||||
|
_ = bar.flatMap(Path.init)
|
||||||
|
let baz: String.SubSequence? = "/a/b:1".split(separator: ":").first
|
||||||
|
_ = baz.flatMap(Path.init)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,7 +1,11 @@
|
|||||||
|
#if !canImport(ObjectiveC)
|
||||||
import XCTest
|
import XCTest
|
||||||
|
|
||||||
extension PathTests {
|
extension PathTests {
|
||||||
static let __allTests = [
|
// DO NOT MODIFY: This is autogenerated, use:
|
||||||
|
// `swift test --generate-linuxmain`
|
||||||
|
// to regenerate.
|
||||||
|
static let __allTests__PathTests = [
|
||||||
("testBasename", testBasename),
|
("testBasename", testBasename),
|
||||||
("testBundleExtensions", testBundleExtensions),
|
("testBundleExtensions", testBundleExtensions),
|
||||||
("testCodable", testCodable),
|
("testCodable", testCodable),
|
||||||
@@ -19,6 +23,7 @@ extension PathTests {
|
|||||||
("testFileHandleExtensions", testFileHandleExtensions),
|
("testFileHandleExtensions", testFileHandleExtensions),
|
||||||
("testFileReference", testFileReference),
|
("testFileReference", testFileReference),
|
||||||
("testFilesystemAttributes", testFilesystemAttributes),
|
("testFilesystemAttributes", testFilesystemAttributes),
|
||||||
|
("testFlatMap", testFlatMap),
|
||||||
("testInitializerForRelativePath", testInitializerForRelativePath),
|
("testInitializerForRelativePath", testInitializerForRelativePath),
|
||||||
("testIsDirectory", testIsDirectory),
|
("testIsDirectory", testIsDirectory),
|
||||||
("testJoin", testJoin),
|
("testJoin", testJoin),
|
||||||
@@ -48,10 +53,9 @@ extension PathTests {
|
|||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
#if !os(macOS)
|
|
||||||
public func __allTests() -> [XCTestCaseEntry] {
|
public func __allTests() -> [XCTestCaseEntry] {
|
||||||
return [
|
return [
|
||||||
testCase(PathTests.__allTests),
|
testCase(PathTests.__allTests__PathTests),
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
Reference in New Issue
Block a user