Coverage Summary for Class: ParsedSql (com.kotlinorm.beans.parser)

Class Class, % Method, % Branch, % Line, % Instruction, %
ParsedSql 100% (1/1) 50% (3/6) 78.6% (11/14) 95.3% (123/129)


 /**
  * Copyright 2022-2025 kronos-orm
  *
  * 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.
  */
 
 package com.kotlinorm.beans.parser
 
 import com.kotlinorm.beans.parser.NamedParameterUtils.buildValueArray
 import com.kotlinorm.beans.parser.NamedParameterUtils.substituteNamedParameters
 
 /**
  * Created by OUSC on 2022/11/4 14:09
  *
  * Codes based on <a href="https://github.com/spring-projects/spring-framework/blob/main/spring-jdbc/src/main/java/org/springframework/jdbc/support/ParsedSql.java">ParsedSql</a>
  *
  * All rights reserved.
  */
 class ParsedSql(
     var originalSql: String = "", var paramMap: Map<String, Any?> = mapOf(),
     var parameterNames: MutableList<String> = ArrayList(),
     var parameterIndexes: MutableList<IntArray> = ArrayList(),
     var namedParameterCount: Int = 0,
     var unnamedParameterCount: Int = 0,
     var totalParameterCount: Int = 0,
     var jdbcSql: String = ""
 ) {
     val jdbcParamList by lazy {
         buildValueArray(this, paramMap)
     }
     /**
      * Add a named parameter parsed from this SQL statement.
      * @param parameterName the name of the parameter
      * @param startIndex the start index in the original SQL String
      * @param endIndex the end index in the original SQL String
      */
     fun addNamedParameter(parameterName: String, startIndex: Int, endIndex: Int) {
         parameterNames.add(parameterName)
         parameterIndexes.add(intArrayOf(startIndex, endIndex))
     }
 
     /**
      * Exposes the original SQL String.
      */
     override fun toString(): String {
         return originalSql
     }
 
     operator fun component1(): String {
         return jdbcSql
     }
 
     operator fun component2(): Array<Any?> {
         return jdbcParamList
     }
 
 }