Kotlin: Kotlin doesn’t see Java Lombok accessors?

Kotlin Programming

Question or issue of Kotlin Programming:

Using Kotlin 1.0.0 release (compiling in IntelliJ 15).

println(myPojoInstance.foo)

When it tries to compile code (in IntelliJ or Gradle) that references Lombok based POJOs it gives the error “Cannot access ‘foo’: it is ‘private’ in “MyPojo”. Which is true, they’re all private and my object has @Value @Builder for lombok annotations.

I’ve tried specifically calling getFoo(), but it says “unresolved reference for getFoo”. There’s perhaps some trick to make Kotlin aware of how to handle the lombok annotations?

How to solve this issue?

Solution no. 1:

Generally, no, it doesn’t. The reason of that behavior is that Lombok is an annotation processor for javac but when the kotlin compiler runs it uses javac as well but with no annotation processing so this is why kotlin don’t see declarations that wasn’t yet generated.

The only workaround for now is to define strict compilation order: Java first and after that kotlin. Unfortunately this approach has great disadvantage: you can’t use Kotlin code from Java in this case. To workaround it you may need multimodule project that may cause a lot of pain

Solution no. 2:

To add to Sergey Mashkov’s response (adding here I don’t have enough rep points to comment on it), here’s an example app of a Gradle multi-project setup where Kotlin can see the Lombok-generated code (without kapt or delomboking. Caveats do apply – namely, Kotlin can call the Java code, but Java can’t call the Kotlin code in that particular module (as this would create a circular dependency). This kind of build might be suitable if you have an existing Java codebase and all new code is written in Kotlin, though.

I would love to see full Lombok/Kotlin support, however. While Kotlin is fully interoperable with Java, the reality is that Lombok is very widely used, and this issue may prevent a large number of developers who would like to switch to Kotlin from doing so.

Solution no. 3:

As it was mentioned in comments above, delombok helps.
In case of maven build it would be:

    org.projectlombok
    lombok-maven-plugin
    ${lombok.version}.0
    
        
            delombok
            generate-sources
            
                delombok
            
            
                
                    skip
                
                true
            
        
        
            test-delombok
            generate-test-sources
            
                testDelombok
            
            
                true
            
        
    

Solution no. 4:

Looks like it works if you use delombok according to site and add the target/generated-sources/delombok folder in the pom.xml under build > plugins > plugin > kotlin-maven-plugin

Hope this helps!