Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Generated types not visible to IntelliJ #1102

Open
cgruber opened this issue Jan 19, 2024 · 10 comments
Open

Generated types not visible to IntelliJ #1102

cgruber opened this issue Jan 19, 2024 · 10 comments
Assignees

Comments

@cgruber
Copy link
Collaborator

cgruber commented Jan 19, 2024

When running kotlin in IntelliJ, code that is generated in either ksp or kapt processors (e.g. dagger, or custom ksp) are not attached in a way that IJ can see them. They compile, but redline. This also has the effect of making the generated sources un-findable by the IDE.

Related: ksp-generated sources are not visible under bazel-out. kapt-generated sources are, under bazel-bin/path/to/library/_javac/lib/lib-java_tmp/path/to/library/GeneratedFile.java. .kt files generated by KSP are available in the deep directories, but not attached anywhere within bazel-out, so they can't even be navigated to from within the project.

While this is strictly an IntelliJ Bazel plugin issue, it seems to likely be an issue with various aspects and what info attached during rules_kotlin related actions. I'm not sure how to better describe this, but can dig into it with anyone, with examples.

@cgruber
Copy link
Collaborator Author

cgruber commented Jan 19, 2024

@restingbull is a comedian

@henrikpersson
Copy link

Adding something like this to the BUILD that uses the kt_ksp_plugin "fixed" it for me:

java_plugin(
    name = "convince_intellij_this_module_generates_code",
    srcs = ["Empty.java"],
    generates_api = True,
)

@dvpermyakov
Copy link

dvpermyakov commented Jul 29, 2024

Bump this thread 😄 Does anyone have a plan to implement this feature?

@th0masb
Copy link

th0masb commented Aug 7, 2024

Yeah I am encountering this issue trying to use the koin ksp compiler for annotation processing. I have something similar to

kt_ksp_plugin(
    name = "koin_codegen",
    processor_class = "org.koin.compiler.BuilderProcessor",
    deps = [
        "@maven//:io_insert_koin_koin_ksp_compiler_jvm",
    ],
)

kt_jvm_library(
    name = "generated_koin",
    srcs = glob(["src/main/kotlin/**"]),
    plugins = [":koin_codegen"],
    deps = _DEPS,
)

which produces a generated_koin.jar correctly in bazel-bin/path/to/package but Intellij does not add this jar to the external libraries list when another lib adds it as a dep and you cannot use it properly in ij.

@TwoClocks
Copy link

I'm stuck on this as well. Have a custom KSP processor that works fine in bazel, but intellij doesn't import the source jar. The KSP plugin is generating the source jar just fine.

Not sure if this is a rules_kotlin problem, or intellij bazel problem.

This can't be "the way it is"? Nobody can see the source for any ksp plugin? That seems kinda crazy. I assume my custom processor isn't doing something it should but I can't figure out what that might be. Especially as it works fine w/ gradle.

@henrikpersson I don't quite understand your fix. Do you add this stub plugin to the target using the ksp plugin? or do you add it to the ksp plugin? Could you give more context/exampels?

@henrikpersson
Copy link

@TwoClocks

I don't remember and trashed the code, but I think it was something like this:

kt_ksp_plugin(
    name = "processor",
    processor_class = "..",
    deps = [
        ":processorimpl",
    ],
)

kt_jvm_library(
    name = "processorimpl",
    resources = ["META-INF/services/com.google.devtools.ksp.processing.SymbolProcessorProvider"],
    exported_plugins = [":convince_intellij_this_module_generates_code"],
    deps = [],
)

java_plugin(	
    name = "convince_intellij_this_module_generates_code",	
    srcs = ["Empty.java"],	
    generates_api = True,	
)

Where Empty.java

class Empty {}

@TwoClocks
Copy link

I've made a simple project that reproduces this problem.

https://github.com/TwoClocks/Bazel-KSP-code-generation-bug

@Bencodes
Copy link
Collaborator

@TwoClocks we had this issue internally as well. The Kotlin rules should be mirroring the Java rules in how generated code is returned as part of the providers as seen here. This however didn't work for us and we ended up patching the ASWB Intellij plugin to properly handle generated code.

@TwoClocks
Copy link

TwoClocks commented Dec 13, 2024

@Bencodes Thanks for looking into this. What does the change to the ASWB plugin looks like? The jetbrains bazel EAP has the same issue, but if maybe they'd take a patch?

In my test repro the source comes out as Main-ksp-kt-gensrc.jar, and your patch is looking for ctx.label.name + "-gensrc.jar". Maybe ctx.lable.name is missing some part of -ksp-kt? The target is just "Main"

kt_jvm_binary(
	name = "Main",
	srcs = ["src/main/kotlin/ksp_bug/app/Main.kt"],
	main_class = "ksp_bug.app.MainKt",
	deps = [":annotation"],
	plugins = [":custom_processor"],
)

I've been unable to build rules_kotlin or I'd check myself.

@ratnikov
Copy link

I've kept banging my head against this as well. This doesn't impact just ksp, but regular java_plugin as well, right?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

8 participants