|
1 | 1 | package cc.unitmesh.container
|
2 | 2 |
|
3 | 3 | import cc.unitmesh.devti.provider.RunService
|
| 4 | +import com.intellij.docker.DockerCloudConfiguration |
| 5 | +import com.intellij.docker.DockerCloudType |
| 6 | +import com.intellij.docker.DockerServerRuntimesManager |
4 | 7 | import com.intellij.docker.dockerFile.DockerLanguage
|
5 | 8 | import com.intellij.execution.configurations.RunProfile
|
| 9 | +import com.intellij.openapi.application.ApplicationManager |
| 10 | +import com.intellij.openapi.application.runReadAction |
6 | 11 | import com.intellij.openapi.project.Project
|
7 | 12 | import com.intellij.openapi.vfs.VirtualFile
|
8 | 13 | import com.intellij.psi.PsiElement
|
| 14 | +import com.intellij.psi.PsiManager |
| 15 | +import com.intellij.remoteServer.impl.configuration.RemoteServerImpl |
| 16 | +import kotlinx.coroutines.future.await |
| 17 | +import kotlinx.coroutines.runBlocking |
| 18 | +import java.awt.EventQueue.invokeAndWait |
9 | 19 |
|
10 | 20 | class RunDockerfileService : RunService {
|
11 |
| - override fun isApplicable(project: Project, file: VirtualFile): Boolean = file.name == "Dockerfile" |
12 | 21 |
|
13 |
| - fun isApplicable(element: PsiElement) = element.containingFile?.language == DockerLanguage.INSTANCE |
| 22 | + override fun isApplicable(project: Project, file: VirtualFile): Boolean = file.name == "Dockerfile" || |
| 23 | + runReadAction { PsiManager.getInstance(project).findFile(file)?.language == DockerLanguage.INSTANCE } |
14 | 24 |
|
15 | 25 | override fun runConfigurationClass(project: Project): Class<out RunProfile>? = null
|
16 | 26 |
|
| 27 | + fun defaultDockerConnection() = |
| 28 | + RemoteServerImpl("DockerConnection", DockerCloudType.getInstance(), DockerCloudConfiguration.createDefault()) |
| 29 | + |
17 | 30 | override fun runFile(project: Project, virtualFile: VirtualFile, psiElement: PsiElement?, isFromToolAction: Boolean)
|
18 | 31 | : String? {
|
19 |
| - return super.runFile(project, virtualFile, psiElement, isFromToolAction) |
| 32 | + |
| 33 | + ApplicationManager.getApplication().invokeAndWait { |
| 34 | + runBlocking { |
| 35 | + val runtime = DockerServerRuntimesManager.getInstance(project) |
| 36 | + .getOrCreateConnection(defaultDockerConnection()) |
| 37 | + .await() |
| 38 | + |
| 39 | +// runtime.runtimesManager |
| 40 | + } |
| 41 | + } |
| 42 | + |
| 43 | + |
| 44 | + return null |
20 | 45 | }
|
21 | 46 | }
|
0 commit comments