From cdced95d4697cbd11c4a439da68688c1dd09a5a9 Mon Sep 17 00:00:00 2001 From: infinitepower18 <44692189+infinitepower18@users.noreply.github.com> Date: Fri, 1 Dec 2023 18:24:03 +0000 Subject: [PATCH 1/2] use latest swift syntax version --- Package.resolved | 6 +++--- Package.swift | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/Package.resolved b/Package.resolved index eb2448d..985385d 100644 --- a/Package.resolved +++ b/Package.resolved @@ -23,9 +23,9 @@ "package": "SwiftSyntax", "repositoryURL": "https://github.com/apple/swift-syntax", "state": { - "branch": "main", - "revision": "dfb8deb846e16d98e1d5b2261ed608121e096037", - "version": null + "branch": null, + "revision": "6ad4ea24b01559dde0773e3d091f1b9e36175036", + "version": "509.0.2" } } ] diff --git a/Package.swift b/Package.swift index fee5d3d..9f0c6fc 100644 --- a/Package.swift +++ b/Package.swift @@ -12,7 +12,7 @@ let docc: PackageDescription.Package.Dependency = .package( ) let swiftSyntax = PackageDescription.Package.Dependency.package( url: "https://github.com/apple/swift-syntax", - branch: "main" + from: "509.0.2" ) let package = Package( From ab611a26b6b8f5280e54778e455a722ae58a54ea Mon Sep 17 00:00:00 2001 From: fummicc1 Date: Sun, 3 Dec 2023 10:27:25 +0900 Subject: [PATCH 2/2] Fix compile error in CsvBuilder --- Sources/CsvBuilder/CsvCompositionParser.swift | 18 ++++++++---------- 1 file changed, 8 insertions(+), 10 deletions(-) diff --git a/Sources/CsvBuilder/CsvCompositionParser.swift b/Sources/CsvBuilder/CsvCompositionParser.swift index e1cc35d..c50766d 100644 --- a/Sources/CsvBuilder/CsvCompositionParser.swift +++ b/Sources/CsvBuilder/CsvCompositionParser.swift @@ -42,7 +42,7 @@ public struct CsvCompositionParser { if !validateInheritedType(decl: decl) { break } - let members = decl.members.members + let members = decl.memberBlock.members let columns = decl.findColumns(type: C.self, members: members) .map { Csv.Column.init(name: $0, style: .random()) } allColumns.append(contentsOf: columns) @@ -60,10 +60,10 @@ public struct CsvCompositionParser { static func validateInheritedType(decl: StructDeclSyntax) -> Bool { decl.inheritanceClause? - .inheritedTypeCollection - .map(\.typeName) + .inheritedTypes + .map(\.type) .compactMap { syntax in - syntax.as(SimpleTypeIdentifierSyntax.self) + syntax.as(IdentifierTypeSyntax.self) } .first(where: { syntax in syntax.name.description.contains("CsvComposition") @@ -71,20 +71,18 @@ public struct CsvCompositionParser { } static func extractColumns(_ type: C.Type, variableDecl decl: VariableDeclSyntax) -> [String] { - guard let attributes = decl.attributes else { - return [] - } + let attributes = decl.attributes return attributes.compactMap { attribute in var columns: [String] = [] for attr in attributes { guard let attr = attr.as(AttributeSyntax.self) else { continue } - let hasCsvRowsAttr = attr.attributeName.as(SimpleTypeIdentifierSyntax.self)?.name.text == "CsvRows" + let hasCsvRowsAttr = attr.attributeName.as(IdentifierTypeSyntax.self)?.name.text == "CsvRows" if !hasCsvRowsAttr { continue } - guard let tokens = attr.argument?.tokens(viewMode: .all) else { + guard let tokens = attr.arguments?.tokens(viewMode: .all) else { continue } let column = tokens @@ -107,7 +105,7 @@ public struct CsvCompositionParser { } extension StructDeclSyntax { - func findColumns(type: (some CsvComposition).Type, members: MemberDeclListSyntax) -> [String] { + func findColumns(type: (some CsvComposition).Type, members: MemberBlockItemListSyntax) -> [String] { var columns: [String] = [] for member in members { guard let decl = member.decl.as(VariableDeclSyntax.self) else {