-
-
Notifications
You must be signed in to change notification settings - Fork 43
Expand file tree
/
Copy pathContentAt.swift
More file actions
67 lines (62 loc) · 2.19 KB
/
Copy pathContentAt.swift
File metadata and controls
67 lines (62 loc) · 2.19 KB
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
import SwiftDiagnostics
import SwiftSyntax
import SwiftSyntaxMacros
/// Attribute type for `ContentAt` macro-attribute.
///
/// This type can validate`ContentAt` macro-attribute
/// usage and extract data for `Codable` macro to
/// generate implementation.
package struct ContentAt: PropertyAttribute {
/// The node syntax provided
/// during initialization.
let node: AttributeSyntax
/// Creates a new instance with the provided node.
///
/// The initializer fails to create new instance if the name
/// of the provided node is different than this attribute.
///
/// - Parameter node: The attribute syntax to create with.
/// - Returns: Newly created attribute instance.
init?(from node: AttributeSyntax) {
guard
node.attributeName.as(IdentifierTypeSyntax.self)!
.name.text == Self.name
else { return nil }
self.node = node
}
/// Builds diagnoser that can validate this macro
/// attached declaration.
///
/// The following conditions are checked by the
/// built diagnoser:
/// * Attached declaration is an enum/protocol declaration.
/// * Macro should be used in presence of `Codable`.
/// * Macro usage is not duplicated for the same
/// declaration.
///
/// - Returns: The built diagnoser instance.
func diagnoser() -> DiagnosticProducer {
return AggregatedDiagnosticProducer {
expect(syntaxes: EnumDeclSyntax.self, ProtocolDeclSyntax.self)
mustBeCombined(with: Codable.self)
mustBeCombined(
with: CodedAt.self, or: DecodedAt.self, EncodedAt.self
)
cantDuplicate()
}
}
}
extension ContentAt: KeyPathProvider {
/// Indicates whether `CodingKey` path
/// data is provided to this instance.
///
/// Always `true` for this type.
var provided: Bool { true }
/// Updates `CodingKey` path using the provided path.
///
/// The `CodingKey` path overrides current `CodingKey` path data.
///
/// - Parameter path: Current `CodingKey` path.
/// - Returns: Updated `CodingKey` path.
func keyPath(withExisting path: [String]) -> [String] { providedPath }
}