Skip to content

Commit

Permalink
Run swift-format
Browse files Browse the repository at this point in the history
  • Loading branch information
stephencelis authored and github-actions[bot] committed Oct 6, 2023
1 parent 0727d7f commit 35acd94
Show file tree
Hide file tree
Showing 6 changed files with 40 additions and 17 deletions.
27 changes: 20 additions & 7 deletions Tests/MacroTestingTests/MacroExamples/AddAsyncMacro.swift
Original file line number Diff line number Diff line change
Expand Up @@ -42,23 +42,30 @@ public struct AddAsyncMacro: PeerMacro {
}

// This only makes sense void functions
if funcDecl.signature.returnClause?.type.with(\.leadingTrivia, []).with(\.trailingTrivia, []).description != "Void" {
if funcDecl.signature.returnClause?.type.with(\.leadingTrivia, []).with(\.trailingTrivia, [])
.description != "Void"
{
throw CustomError.message(
"@addAsync requires an function that returns void"
)
}

// Requires a completion handler block as last parameter
guard let completionHandlerParameterAttribute = funcDecl.signature.parameterClause.parameters.last?.type.as(AttributedTypeSyntax.self),
let completionHandlerParameter = completionHandlerParameterAttribute.baseType.as(FunctionTypeSyntax.self)
guard
let completionHandlerParameterAttribute = funcDecl.signature.parameterClause.parameters.last?
.type.as(AttributedTypeSyntax.self),
let completionHandlerParameter = completionHandlerParameterAttribute.baseType.as(
FunctionTypeSyntax.self)
else {
throw CustomError.message(
"@addAsync requires an function that has a completion handler as last parameter"
)
}

// Completion handler needs to return Void
if completionHandlerParameter.returnClause.type.with(\.leadingTrivia, []).with(\.trailingTrivia, []).description != "Void" {
if completionHandlerParameter.returnClause.type.with(\.leadingTrivia, []).with(
\.trailingTrivia, []
).description != "Void" {
throw CustomError.message(
"@addAsync requires an function that has a completion handler that returns Void"
)
Expand All @@ -67,14 +74,18 @@ public struct AddAsyncMacro: PeerMacro {
let returnType = completionHandlerParameter.parameters.first?.type

let isResultReturn = returnType?.children(viewMode: .all).first?.description == "Result"
let successReturnType = isResultReturn ? returnType!.as(IdentifierTypeSyntax.self)!.genericArgumentClause?.arguments.first!.argument : returnType
let successReturnType =
isResultReturn
? returnType!.as(IdentifierTypeSyntax.self)!.genericArgumentClause?.arguments.first!.argument
: returnType

// Remove completionHandler and comma from the previous parameter
var newParameterList = funcDecl.signature.parameterClause.parameters
newParameterList.removeLast()
let newParameterListLastParameter = newParameterList.last!
newParameterList.removeLast()
newParameterList.append(newParameterListLastParameter.with(\.trailingTrivia, []).with(\.trailingComma, nil))
newParameterList.append(
newParameterListLastParameter.with(\.trailingTrivia, []).with(\.trailingComma, nil))

// Drop the @addAsync attribute from the new declaration.
let newAttributeList = funcDecl.attributes.filter {
Expand Down Expand Up @@ -136,7 +147,9 @@ public struct AddAsyncMacro: PeerMacro {
)
.with(
\.returnClause,
successReturnType != nil ? ReturnClauseSyntax(leadingTrivia: .space, type: successReturnType!.with(\.leadingTrivia, .space)) : nil
successReturnType != nil
? ReturnClauseSyntax(
leadingTrivia: .space, type: successReturnType!.with(\.leadingTrivia, .space)) : nil
) // add result type
.with(
\.parameterClause,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,8 @@ public struct AddCompletionHandlerMacro: PeerMacro {
}

// Form the completion handler parameter.
let resultType: TypeSyntax? = funcDecl.signature.returnClause?.type.with(\.leadingTrivia, []).with(\.trailingTrivia, [])
let resultType: TypeSyntax? = funcDecl.signature.returnClause?.type.with(\.leadingTrivia, [])
.with(\.trailingTrivia, [])

let completionHandlerParam =
FunctionParameterSyntax(
Expand Down
12 changes: 8 additions & 4 deletions Tests/MacroTestingTests/MacroExamples/CustomCodable.swift
Original file line number Diff line number Diff line change
Expand Up @@ -24,18 +24,22 @@ public enum CustomCodable: MemberMacro {
let cases = memberList.compactMap({ member -> String? in
// is a property
guard
let propertyName = member.decl.as(VariableDeclSyntax.self)?.bindings.first?.pattern.as(IdentifierPatternSyntax.self)?.identifier.text
let propertyName = member.decl.as(VariableDeclSyntax.self)?.bindings.first?.pattern.as(
IdentifierPatternSyntax.self)?.identifier.text
else {
return nil
}

// if it has a CodableKey macro on it
if let customKeyMacro = member.decl.as(VariableDeclSyntax.self)?.attributes.first(where: { element in
element.as(AttributeSyntax.self)?.attributeName.as(IdentifierTypeSyntax.self)?.description == "CodableKey"
if let customKeyMacro = member.decl.as(VariableDeclSyntax.self)?.attributes.first(where: {
element in
element.as(AttributeSyntax.self)?.attributeName.as(IdentifierTypeSyntax.self)?.description
== "CodableKey"
}) {

// Uses the value in the Macro
let customKeyValue = customKeyMacro.as(AttributeSyntax.self)!.arguments!.as(LabeledExprListSyntax.self)!.first!.expression
let customKeyValue = customKeyMacro.as(AttributeSyntax.self)!.arguments!.as(
LabeledExprListSyntax.self)!.first!.expression

return "case \(propertyName) = \(customKeyValue)"
} else {
Expand Down
9 changes: 6 additions & 3 deletions Tests/MacroTestingTests/MacroExamples/MetaEnumMacro.swift
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,9 @@ public struct MetaEnumMacro {
let access: DeclModifierListSyntax.Element?
let parentParamName: TokenSyntax

init(node: AttributeSyntax, declaration: some DeclGroupSyntax, context: some MacroExpansionContext) throws {
init(
node: AttributeSyntax, declaration: some DeclGroupSyntax, context: some MacroExpansionContext
) throws {
guard let enumDecl = declaration.as(EnumDeclSyntax.self) else {
throw DiagnosticsError(diagnostics: [
CaseMacroDiagnostic.notAnEnum(declaration).diagnose(at: Syntax(node))
Expand Down Expand Up @@ -94,7 +96,7 @@ extension EnumDeclSyntax {
var caseElements: [EnumCaseElementSyntax] {
memberBlock.members.flatMap { member in
guard let caseDecl = member.decl.as(EnumCaseDeclSyntax.self) else {
return Array<EnumCaseElementSyntax>()
return [EnumCaseElementSyntax]()
}

return Array(caseDecl.elements)
Expand All @@ -110,7 +112,8 @@ extension CaseMacroDiagnostic: DiagnosticMessage {
var message: String {
switch self {
case .notAnEnum(let decl):
return "'@MetaEnum' can only be attached to an enum, not \(decl.descriptiveDeclKind(withArticle: true))"
return
"'@MetaEnum' can only be attached to an enum, not \(decl.descriptiveDeclKind(withArticle: true))"
}
}

Expand Down
3 changes: 2 additions & 1 deletion Tests/MacroTestingTests/MacroExamples/NewTypeMacro.swift
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,8 @@ extension NewTypeMacro: MemberMacro {
.expression.as(MemberAccessExprSyntax.self),
let rawType = memberAccessExn.base?.as(DeclReferenceExprSyntax.self)
else {
throw CustomError.message(#"@NewType requires the raw type as an argument, in the form "RawType.self"."#)
throw CustomError.message(
#"@NewType requires the raw type as an argument, in the form "RawType.self"."#)
}

guard let declaration = declaration.as(StructDeclSyntax.self) else {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,8 @@ public struct WrapStoredPropertiesMacro: MemberAttributeMacro {
stringLiteral.segments.count == 1,
case let .stringSegment(wrapperName)? = stringLiteral.segments.first
else {
throw CustomError.message("macro requires a string literal containing the name of an attribute")
throw CustomError.message(
"macro requires a string literal containing the name of an attribute")
}

return [
Expand Down

0 comments on commit 35acd94

Please sign in to comment.