func applyMethodTemplate()

in Sources/MockoloFramework/Templates/MethodTemplate.swift [20:158]


    func applyMethodTemplate(name: String,
                             identifier: String,
                             kind: MethodKind,
                             useTemplateFunc: Bool,
                             allowSetCallCount: Bool,
                             enableFuncArgsHistory: Bool,
                             isStatic: Bool,
                             customModifiers: [String: Modifier]?,
                             isOverride: Bool,
                             genericTypeParams: [ParamModel],
                             genericWhereClause: String?,
                             params: [ParamModel],
                             returnType: Type,
                             accessLevel: String,
                             suffix: String,
                             argsHistory: ArgumentsHistoryModel?,
                             handler: ClosureModel?) -> String {
        var template = ""

        let returnTypeName = returnType.isUnknown ? "" : returnType.typeName

        let acl = accessLevel.isEmpty ? "" : accessLevel+" "
        let genericTypeDeclsStr = genericTypeParams.compactMap {$0.render(with: "", encloser: "")}.joined(separator: ", ")
        let genericTypesStr = genericTypeDeclsStr.isEmpty ? "" : "<\(genericTypeDeclsStr)>"
        var genericWhereStr = ""
        if let clause = genericWhereClause {
            genericWhereStr = " \(clause)"
        }
        let paramDeclsStr = params.compactMap{$0.render(with: "", encloser: "")}.joined(separator: ", ")

        switch kind {
        case .initKind(_, _):  // ClassTemplate needs to handle this as it needs a context of all the vars
            return ""
        default:

            guard let handler = handler else { return "" }

            let callCount = "\(identifier)\(String.callCountSuffix)"
            let handlerVarName = "\(identifier)\(String.handlerSuffix)"
            let handlerVarType = handler.type.typeName // ?? "Any"
            let handlerReturn = handler.render(with: identifier, encloser: "") ?? ""

            let suffixStr = suffix.isEmpty ? "" : "\(suffix) "
            let returnStr = returnTypeName.isEmpty ? "" : "-> \(returnTypeName)"
            let staticStr = isStatic ? String.static + " " : ""
            let keyword = isSubscript ? "" : "func "
            var body = ""

            if useTemplateFunc {
                let callMockFunc = !suffix.hasThrowsOrRethrows && (handler.type.cast?.isEmpty ?? false)
                if callMockFunc {
                    let handlerParamValsStr = params.map { (arg) -> String in
                        if arg.type.typeName.hasPrefix(String.autoclosure) {
                            return arg.name.safeName + "()"
                        }
                        return arg.name.safeName
                    }.joined(separator: ", ")

                    let defaultVal = type.defaultVal() // ?? "nil"

                    var mockReturn = ".error"
                    if returnType.typeName.isEmpty {
                        mockReturn = ".void"
                    } else if let val = defaultVal {
                        mockReturn = ".val(\(val))"
                    }

                    body = """
                    \(2.tab)mockFunc(&\(callCount))(\"\(name)\", \(handlerVarName)?(\(handlerParamValsStr)), \(mockReturn))
                    """
                }
            }

            if body.isEmpty {
                body = """
                \(2.tab)\(callCount) += 1
                """

                if let argsHistory = argsHistory, argsHistory.enable(force: enableFuncArgsHistory) {
                    let argsHistoryCapture = argsHistory.render(with: identifier, encloser: "", enableFuncArgsHistory: enableFuncArgsHistory) ?? ""

                    body = """
                    \(body)
                    \(2.tab)\(argsHistoryCapture)
                    """
                }

                body = """
                \(body)
                \(handlerReturn)
                """
            }

            var wrapped = body
            if isSubscript {
                wrapped = """
                \(2.tab)get {
                \(body)
                \(2.tab)}
                \(2.tab)set { }
                """
            }

            let overrideStr = isOverride ? "\(String.override) " : ""
            let modifierTypeStr: String
            if let customModifiers = customModifiers,
            let customModifier: Modifier = customModifiers[name] {
                modifierTypeStr = customModifier.rawValue + " "
            } else {
                modifierTypeStr = ""
            }
            let privateSetSpace = allowSetCallCount ? "" : "\(String.privateSet) "

            template = """

            \(1.tab)\(acl)\(staticStr)\(privateSetSpace)var \(callCount) = 0
            """

            if let argsHistory = argsHistory, argsHistory.enable(force: enableFuncArgsHistory) {
                let argsHistoryVarName = "\(identifier)\(String.argsHistorySuffix)"
                let argsHistoryVarType = argsHistory.type.typeName

                template = """
                \(template)
                \(1.tab)\(acl)\(staticStr)var \(argsHistoryVarName) = \(argsHistoryVarType)()
                """
            }

            template = """
            \(template)
            \(1.tab)\(acl)\(staticStr)var \(handlerVarName): \(handlerVarType)
            \(1.tab)\(acl)\(staticStr)\(overrideStr)\(modifierTypeStr)\(keyword)\(name)\(genericTypesStr)(\(paramDeclsStr)) \(suffixStr)\(returnStr)\(genericWhereStr) {
            \(wrapped)
            \(1.tab)}
            """
        }

        return template
    }