Slide 1

Slide 1 text

Code generation on the Java VM Sean Sullivan 2019-12-05

Slide 2

Slide 2 text

Code generation Java Kotlin Scala

Slide 3

Slide 3 text

Why code generation?

Slide 4

Slide 4 text

less boilerplate more consistency Why code generation?

Slide 5

Slide 5 text

class names parameter names method names exception names Consistency error handling logging JSON serialization network I/O

Slide 6

Slide 6 text

Code generation is not a new idea

Slide 7

Slide 7 text

2001: Apache Axis

Slide 8

Slide 8 text

wsdl2java August 2001

Slide 9

Slide 9 text

2003: Apache XmlBeans

Slide 10

Slide 10 text

September 2003 SchemaCodeGenerator

Slide 11

Slide 11 text

The most common use case for source code generation…

Slide 12

Slide 12 text

generating client libraries for REST API’s

Slide 13

Slide 13 text

bytecode source code Two kinds of code generation

Slide 14

Slide 14 text

Code generation Bytecode generation

Slide 15

Slide 15 text

Bytecode generators produce Java class definitions

Slide 16

Slide 16 text

ByteBuddy ObjectWeb ASM cglib Bytecode libraries Javassist Commons BCEL AspectJ

Slide 17

Slide 17 text

Spring Framework

Slide 18

Slide 18 text

cglib spring-core

Slide 19

Slide 19 text

cglib spring-beans

Slide 20

Slide 20 text

Micronaut framework

Slide 21

Slide 21 text

“Unlike Spring which relies exclusively on runtime reflection and proxies, Micronaut uses compile time data to implement dependency injection” micronaut https://docs.micronaut.io/latest/guide/ioc.html

Slide 22

Slide 22 text

“This goal is achieved through the use of Java’s annotation processors" micronaut https://docs.micronaut.io/latest/guide/index.html

Slide 23

Slide 23 text

micronaut https://github.com/micronaut-projects/micronaut-core Annotation processors

Slide 24

Slide 24 text

micronaut ObjectWeb ASM https://github.com/micronaut-projects/micronaut-core

Slide 25

Slide 25 text

Mockito

Slide 26

Slide 26 text

mockito 2.x ByteBuddy https://github.com/mockito/mockito

Slide 27

Slide 27 text

“Mockito switched from CGLIB to the great library ByteBuddy to make mocks” https://github.com/mockito/mockito/wiki/What%27s-new-in-Mockito-2 mockito 2.x

Slide 28

Slide 28 text

Datadog Java agent

Slide 29

Slide 29 text

Datadog Java agent ByteBuddy https://github.com/DataDog/dd-trace-java

Slide 30

Slide 30 text

How can I implement a custom Java agent?

Slide 31

Slide 31 text

Java agent example https://github.com/sullis/java-lang-instrument-example/

Slide 32

Slide 32 text

Java agent example “premain” method https://github.com/sullis/java-lang-instrument-example/

Slide 33

Slide 33 text

Java agent example https://github.com/sullis/java-lang-instrument-example/ ByteBuddy AgentBuilder

Slide 34

Slide 34 text

Code generation Source code generation

Slide 35

Slide 35 text

java.lang.StringBuilder java.io.StringWriter Source generation

Slide 36

Slide 36 text

javapoet CodeModel jdeparser2 javaparser Source generation

Slide 37

Slide 37 text

kotlinpoet kotlinx-ast kastree Source generation

Slide 38

Slide 38 text

scalameta treehugger.scala Source generation

Slide 39

Slide 39 text

JavaPoet

Slide 40

Slide 40 text

JavaPoet https://github.com/square/javapoet

Slide 41

Slide 41 text

package com.example.helloworld; public final class HelloWorld { public static void main(String[] args) { System.out.println("Hello, JavaPoet!"); } } JavaPoet

Slide 42

Slide 42 text

import com.squareup.javapoet.*; MethodSpec main = MethodSpec.methodBuilder("main") .addModifiers(Modifier.PUBLIC, Modifier.STATIC) .returns(void.class) .addParameter(String[].class, "args") .addStatement("$T.out.println($S)", System.class, "Hello, JavaPoet!") .build(); TypeSpec helloWorld = TypeSpec.classBuilder("HelloWorld") .addModifiers(Modifier.PUBLIC, Modifier.FINAL) .addMethod(main) .build(); JavaFile javaFile = JavaFile.builder("com.example.helloworld", helloWorld) .build(); javaFile.writeTo(System.out); JavaPoet method builder class builder file builder

Slide 43

Slide 43 text

AWS SDK for Java v2

Slide 44

Slide 44 text

AWS SDK for Java v2 “To provide SDK support for the many services that AWS owns, the AWS SDKs make extensive use of code generation” https://aws.amazon.com/blogs/developer/aws-sdk-for-java-2-x-released/

Slide 45

Slide 45 text

AWS SDK for Java v2

Slide 46

Slide 46 text

JavaPoet AWS SDK for Java v2

Slide 47

Slide 47 text

Dagger

Slide 48

Slide 48 text

“Dagger 2 is the first to implement the full stack with generated code” Dagger 2.x “Dependency injection frameworks have existed for years with a whole variety of APIs for configuring and injecting” https://dagger.dev/users-guide.html

Slide 49

Slide 49 text

Dagger 2.x https://dagger.dev/users-guide.html

Slide 50

Slide 50 text

JavaPoet Dagger 2.x

Slide 51

Slide 51 text

REST API code generators apibuilder project guardrail project openapi-generator

Slide 52

Slide 52 text

ApiBuilder project

Slide 53

Slide 53 text

https://www.apibuilder.io/ ApiBuilder

Slide 54

Slide 54 text

https://github.com/apicollective/apibuilder-generator/ ApiBuilder

Slide 55

Slide 55 text

ApiBuilder demo

Slide 56

Slide 56 text

Guardrail project

Slide 57

Slide 57 text

https://guardrail.dev/ Guardrail

Slide 58

Slide 58 text

https://github.com/twilio/guardrail Guardrail

Slide 59

Slide 59 text

https://github.com/twilio/guardrail Guardrail: Scala ScalaMeta

Slide 60

Slide 60 text

https://github.com/twilio/guardrail Guardrail: Java JavaParser

Slide 61

Slide 61 text

Guardrail example

Slide 62

Slide 62 text

guardrail-maven-plugin com.twilio guardrail-maven-plugin_2.12 0.54.5 …

Slide 63

Slide 63 text

guardrail-maven-plugin java client dropwizard ${project.basedir}/src/main/openapi/petstore.json com.example.clients.petstore Java client

Slide 64

Slide 64 text

guardrail-maven-plugin

Slide 65

Slide 65 text

openapi-generator project

Slide 66

Slide 66 text

openapi-generator

Slide 67

Slide 67 text

openapi-generator

Slide 68

Slide 68 text

openapi-generator

Slide 69

Slide 69 text

Final thoughts code generation is a powerful technique use a code generator to generate client libraries contribute to open source projects

Slide 70

Slide 70 text

Code generation Questions?

Slide 71

Slide 71 text

The End