Sources/SwiftCodeSanKit/Core/RefChecker.swift (89 lines of code) (raw):

// // Copyright (c) 2018. Uber Technologies // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // import Foundation import SwiftSyntax /** Checks for referenced decls */ final class RefChecker: SyntaxVisitor { var imports = [String]() private var declMap = DeclMap() private var path: String private var module: String private var reflist = [String]() var refs: Set<String> { return Set(reflist) } init(_ path: String, module: String, declMap: DeclMap) { self.path = path self.module = module self.declMap = declMap } override func visit(_ node: CodeBlockItemSyntax) -> SyntaxVisitorContinueKind { if node.item.is(ExprSyntax.self) || node.item.is(StmtSyntax.self) { reflist.append(contentsOf: node.item.refTypes(with: declMap)) return .skipChildren } return .visitChildren } override func visit(_ node: VariableDeclSyntax) -> SyntaxVisitorContinueKind { reflist.append(contentsOf: node.refTypes(with: declMap)) if node.isOverride { reflist.append(node.name) } return .visitChildren } override func visit(_ node: FunctionDeclSyntax) -> SyntaxVisitorContinueKind { reflist.append(contentsOf: node.refTypes(with: declMap)) if node.isOverride { reflist.append(node.name) } return .visitChildren } override func visit(_ node: SubscriptDeclSyntax) -> SyntaxVisitorContinueKind { reflist.append(contentsOf: node.refTypes(with: declMap)) return .visitChildren } override func visit(_ node: InitializerDeclSyntax) -> SyntaxVisitorContinueKind { reflist.append(contentsOf: node.refTypes(with: declMap)) if node.isOverride { reflist.append(node.name) } return .visitChildren } override func visit(_ node: EnumCaseDeclSyntax) -> SyntaxVisitorContinueKind { reflist.append(contentsOf: node.refTypes(with: declMap)) return .visitChildren } override func visit(_ node: ClassDeclSyntax) -> SyntaxVisitorContinueKind { reflist.append(contentsOf: node.refTypes(with: declMap)) return .visitChildren } override func visit(_ node: ProtocolDeclSyntax) -> SyntaxVisitorContinueKind { reflist.append(contentsOf: node.refTypes(with: declMap)) return .visitChildren } override func visit(_ node: ExtensionDeclSyntax) -> SyntaxVisitorContinueKind { reflist.append(contentsOf: node.refTypes(with: declMap)) reflist.append(node.name) return .visitChildren } override func visit(_ node: StructDeclSyntax) -> SyntaxVisitorContinueKind { reflist.append(contentsOf: node.refTypes(with: declMap)) return .visitChildren } override func visit(_ node: EnumDeclSyntax) -> SyntaxVisitorContinueKind { reflist.append(contentsOf: node.refTypes(with: declMap)) return .visitChildren } override func visit(_ node: TypealiasDeclSyntax) -> SyntaxVisitorContinueKind { reflist.append(contentsOf: node.refTypes(with: declMap)) return .visitChildren } override func visit(_ node: AssociatedtypeDeclSyntax) -> SyntaxVisitorContinueKind { reflist.append(contentsOf: node.refTypes(with: declMap)) return .visitChildren } override func visit(_ node: ImportDeclSyntax) -> SyntaxVisitorContinueKind { if node.attributes == nil, node.importKind == nil { let str = node.path.description.trimmed imports.append(str) } return .skipChildren } }