mirror of
https://github.com/github/codeql.git
synced 2025-12-23 04:06:37 +01:00
Merge pull request #9263 from tamasvajk/kotlin-versions
Kotlin: Add support for versions 1.5.0, 1.5.10, and 1.5.21
This commit is contained in:
@@ -30,8 +30,13 @@ sourceSets {
|
|||||||
// change the excludes for building with other versions:
|
// change the excludes for building with other versions:
|
||||||
excludes = [
|
excludes = [
|
||||||
"utils/versions/v_1_4_32/*.kt",
|
"utils/versions/v_1_4_32/*.kt",
|
||||||
|
"utils/versions/v_1_5_0/*.kt",
|
||||||
|
"utils/versions/v_1_5_10/*.kt",
|
||||||
|
"utils/versions/v_1_5_21/*.kt",
|
||||||
"utils/versions/v_1_5_31/*.kt",
|
"utils/versions/v_1_5_31/*.kt",
|
||||||
"utils/versions/v_1_6_10/*.kt"]
|
"utils/versions/v_1_6_10/*.kt",
|
||||||
|
// "utils/versions/v_1_6_20/*.kt",
|
||||||
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ def version_string_to_tuple(version):
|
|||||||
m = re.match(r'([0-9]+)\.([0-9]+)\.([0-9]+)', version)
|
m = re.match(r'([0-9]+)\.([0-9]+)\.([0-9]+)', version)
|
||||||
return tuple([int(m.group(i)) for i in range(1, 4)])
|
return tuple([int(m.group(i)) for i in range(1, 4)])
|
||||||
|
|
||||||
many_versions = [ '1.4.32', '1.5.31', '1.6.10', '1.6.20' ]
|
many_versions = [ '1.4.32', '1.5.0', '1.5.10', '1.5.21', '1.5.31', '1.6.10', '1.6.20' ]
|
||||||
|
|
||||||
many_versions_tuples = [version_string_to_tuple(v) for v in many_versions]
|
many_versions_tuples = [version_string_to_tuple(v) for v in many_versions]
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,17 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import com.github.codeql.KotlinUsesExtractor
|
||||||
|
import com.github.codeql.Severity
|
||||||
|
import org.jetbrains.kotlin.ir.ObsoleteDescriptorBasedAPI
|
||||||
|
import org.jetbrains.kotlin.ir.util.DeclarationStubGenerator
|
||||||
|
import org.jetbrains.kotlin.ir.util.SymbolTable
|
||||||
|
|
||||||
|
@OptIn(ObsoleteDescriptorBasedAPI::class)
|
||||||
|
fun <TIrStub> KotlinUsesExtractor.getIrStubFromDescriptor(generateStub: (DeclarationStubGenerator) -> TIrStub) : TIrStub? =
|
||||||
|
(pluginContext.symbolTable as? SymbolTable) ?.let {
|
||||||
|
val stubGenerator = DeclarationStubGenerator(pluginContext.moduleDescriptor, it, pluginContext.languageVersionSettings)
|
||||||
|
generateStub(stubGenerator)
|
||||||
|
} ?: run {
|
||||||
|
logger.error("Plugin context has no symbol table, couldn't get IR stub")
|
||||||
|
null
|
||||||
|
}
|
||||||
@@ -0,0 +1,5 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import org.jetbrains.kotlin.ir.SourceManager
|
||||||
|
|
||||||
|
typealias FileEntry = SourceManager.FileEntry
|
||||||
@@ -0,0 +1,8 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import org.jetbrains.kotlin.backend.common.extensions.IrPluginContext
|
||||||
|
import org.jetbrains.kotlin.ir.declarations.IrClass
|
||||||
|
|
||||||
|
fun functionN(pluginContext: IrPluginContext): (Int) -> IrClass {
|
||||||
|
return { i -> pluginContext.irBuiltIns.functionFactory.functionN(i) }
|
||||||
|
}
|
||||||
@@ -0,0 +1,21 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import com.intellij.psi.PsiElement
|
||||||
|
import org.jetbrains.kotlin.ir.IrElement
|
||||||
|
import org.jetbrains.kotlin.ir.declarations.IrFile
|
||||||
|
import org.jetbrains.kotlin.psi.KtFile
|
||||||
|
import org.jetbrains.kotlin.psi2ir.PsiSourceManager
|
||||||
|
|
||||||
|
class Psi2Ir : Psi2IrFacade {
|
||||||
|
companion object {
|
||||||
|
val psiManager = PsiSourceManager()
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun getKtFile(irFile: IrFile): KtFile? {
|
||||||
|
return psiManager.getKtFile(irFile)
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun findPsiElement(irElement: IrElement, irFile: IrFile): PsiElement? {
|
||||||
|
return psiManager.findPsiElement(irElement, irFile)
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import org.jetbrains.kotlin.backend.jvm.codegen.isRawType
|
||||||
|
import org.jetbrains.kotlin.ir.types.IrSimpleType
|
||||||
|
|
||||||
|
|
||||||
|
fun IrSimpleType.isRawType() = this.isRawType()
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import com.github.codeql.KotlinUsesExtractor
|
||||||
|
import com.github.codeql.Severity
|
||||||
|
import org.jetbrains.kotlin.ir.ObsoleteDescriptorBasedAPI
|
||||||
|
import org.jetbrains.kotlin.ir.util.DeclarationStubGenerator
|
||||||
|
import org.jetbrains.kotlin.ir.util.SymbolTable
|
||||||
|
|
||||||
|
@OptIn(ObsoleteDescriptorBasedAPI::class)
|
||||||
|
fun <TIrStub> KotlinUsesExtractor.getIrStubFromDescriptor(generateStub: (DeclarationStubGenerator) -> TIrStub) : TIrStub? =
|
||||||
|
(pluginContext.symbolTable as? SymbolTable) ?.let {
|
||||||
|
val stubGenerator = DeclarationStubGenerator(pluginContext.moduleDescriptor, it, pluginContext.languageVersionSettings)
|
||||||
|
generateStub(stubGenerator)
|
||||||
|
} ?: run {
|
||||||
|
logger.error("Plugin context has no symbol table, couldn't get IR stub")
|
||||||
|
null
|
||||||
|
}
|
||||||
@@ -0,0 +1,5 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import org.jetbrains.kotlin.ir.SourceManager
|
||||||
|
|
||||||
|
typealias FileEntry = SourceManager.FileEntry
|
||||||
@@ -0,0 +1,8 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import org.jetbrains.kotlin.backend.common.extensions.IrPluginContext
|
||||||
|
import org.jetbrains.kotlin.ir.declarations.IrClass
|
||||||
|
|
||||||
|
fun functionN(pluginContext: IrPluginContext): (Int) -> IrClass {
|
||||||
|
return { i -> pluginContext.irBuiltIns.functionFactory.functionN(i) }
|
||||||
|
}
|
||||||
@@ -0,0 +1,21 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import com.intellij.psi.PsiElement
|
||||||
|
import org.jetbrains.kotlin.ir.IrElement
|
||||||
|
import org.jetbrains.kotlin.ir.declarations.IrFile
|
||||||
|
import org.jetbrains.kotlin.psi.KtFile
|
||||||
|
import org.jetbrains.kotlin.psi2ir.PsiSourceManager
|
||||||
|
|
||||||
|
class Psi2Ir : Psi2IrFacade {
|
||||||
|
companion object {
|
||||||
|
val psiManager = PsiSourceManager()
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun getKtFile(irFile: IrFile): KtFile? {
|
||||||
|
return psiManager.getKtFile(irFile)
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun findPsiElement(irElement: IrElement, irFile: IrFile): PsiElement? {
|
||||||
|
return psiManager.findPsiElement(irElement, irFile)
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import org.jetbrains.kotlin.backend.jvm.codegen.isRawType
|
||||||
|
import org.jetbrains.kotlin.ir.types.IrSimpleType
|
||||||
|
|
||||||
|
|
||||||
|
fun IrSimpleType.isRawType() = this.isRawType()
|
||||||
@@ -0,0 +1,18 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import com.github.codeql.KotlinUsesExtractor
|
||||||
|
import com.github.codeql.Severity
|
||||||
|
import org.jetbrains.kotlin.ir.ObsoleteDescriptorBasedAPI
|
||||||
|
import org.jetbrains.kotlin.ir.util.DeclarationStubGenerator
|
||||||
|
import org.jetbrains.kotlin.ir.util.SymbolTable
|
||||||
|
import org.jetbrains.kotlin.psi2ir.generators.DeclarationStubGeneratorImpl
|
||||||
|
|
||||||
|
@OptIn(ObsoleteDescriptorBasedAPI::class)
|
||||||
|
fun <TIrStub> KotlinUsesExtractor.getIrStubFromDescriptor(generateStub: (DeclarationStubGenerator) -> TIrStub) : TIrStub? =
|
||||||
|
(pluginContext.symbolTable as? SymbolTable) ?.let {
|
||||||
|
val stubGenerator = DeclarationStubGeneratorImpl(pluginContext.moduleDescriptor, it, pluginContext.languageVersionSettings)
|
||||||
|
generateStub(stubGenerator)
|
||||||
|
} ?: run {
|
||||||
|
logger.error("Plugin context has no symbol table, couldn't get IR stub")
|
||||||
|
null
|
||||||
|
}
|
||||||
@@ -0,0 +1,5 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import org.jetbrains.kotlin.ir.IrFileEntry
|
||||||
|
|
||||||
|
typealias FileEntry = IrFileEntry
|
||||||
@@ -0,0 +1,8 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import org.jetbrains.kotlin.backend.common.extensions.IrPluginContext
|
||||||
|
import org.jetbrains.kotlin.ir.declarations.IrClass
|
||||||
|
|
||||||
|
fun functionN(pluginContext: IrPluginContext): (Int) -> IrClass {
|
||||||
|
return { i -> pluginContext.irBuiltIns.functionFactory.functionN(i) }
|
||||||
|
}
|
||||||
@@ -0,0 +1,18 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import com.intellij.psi.PsiElement
|
||||||
|
import org.jetbrains.kotlin.backend.common.psi.PsiSourceManager
|
||||||
|
import org.jetbrains.kotlin.backend.jvm.ir.getKtFile
|
||||||
|
import org.jetbrains.kotlin.ir.IrElement
|
||||||
|
import org.jetbrains.kotlin.ir.declarations.IrFile
|
||||||
|
import org.jetbrains.kotlin.psi.KtFile
|
||||||
|
|
||||||
|
class Psi2Ir: Psi2IrFacade {
|
||||||
|
override fun getKtFile(irFile: IrFile): KtFile? {
|
||||||
|
return irFile.getKtFile()
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun findPsiElement(irElement: IrElement, irFile: IrFile): PsiElement? {
|
||||||
|
return PsiSourceManager.findPsiElement(irElement, irFile)
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,7 @@
|
|||||||
|
package com.github.codeql.utils.versions
|
||||||
|
|
||||||
|
import org.jetbrains.kotlin.backend.jvm.codegen.isRawType
|
||||||
|
import org.jetbrains.kotlin.ir.types.IrSimpleType
|
||||||
|
|
||||||
|
|
||||||
|
fun IrSimpleType.isRawType() = this.isRawType()
|
||||||
Reference in New Issue
Block a user