jsonschema2pojo uses the structural rules present in a JSON Schema document to generate DTO style Java classes.
| Attribute | Description | Required | 
| source | The input JSON schema. | Yes | 
| targetDirectory | The directory that generated .java source files will be saved to. | Yes | 
| annotationStyle | The style of annotations to use in the generated Java types. Supported values: 
 | No (default JACKSON2) | 
| inclusionLevel | The level of inclusion to be set for generated java types (to control level of inclusion in
            case of Jackson1 or Jackson2 serializator). Each level will have its own set of mapping annotations.
            Supported values: 
 | Default value NON_NULL) | 
| classNamePrefix | Whether to add a prefix to generated classes | No (default "") | 
| classNameSuffix | Whether to add a suffix to generated classes | No (default "") | 
| fileExtensions | A string containing file extensions that should be considered full extensions and therefore ignored when generating classnames. | No (default ""(none)) | 
| classpath | Additional classpath to use. Any path elements provided here will be added to the classpath
            when this task is invoked. If a support for filesets/filelists/dirsets etc is required, this property can also be set as a nested element like: 
<jsonschema2pojo ...
    <classpath>
        <fileset dir="custom-libs">
            <include name="**/*.jar" />
        </fileset>
    </classpath>
<jsonschema2pojo/>
 | No | 
| classpathRef | Additional classpath to use, given as a reference to a path defined elsewhere. Can be used in
            conjuction with the classpathoption (the result is the union of all paths). | No | 
| customAnnotator | A fully qualified class name, referring to a custom annotator class that implements  If you want to use the custom annotator alone, set  | No | 
| customRuleFactory | A fully qualified class name, referring to a custom rule factory class that extends  By specifying a custom implementation you can customize most aspects of code generation by returning custom instances of rules. | No | 
| generateBuilders | Whether to generate builder-style methods of the form withXxx(value)(that returnthis), alongside the standard, void-return setters. | No (default false) | 
| includeAccessors | Whether to include getters/setters or to omit these accessor methods and create public fields instead. | No (default true) | 
| includeAdditionalProperties | Whether to allow 'additional properties' support in objects. Setting this to false will disable additional properties support, regardless of the input schema(s). | No (default true) | 
| includeDynamicAccessors | Whether to include dynamic getters, setters, and builders or to omit these methods. | No (default false) | 
| includeConstructors | Whether to generate constructors for generated Java types | No (default false) | 
| constructorsRequiredPropertiesOnly | Whether generated constructors should have parameters for all properties, or only required ones. | No (default false) | 
| includeHashcodeAndEquals | Whether to use include hashCodeandequalsmethods in generated Java
            types. | No (default true) | 
| includeJsr303Annotations | Whether to include JSR-303/349 annotations
            (for schema rules like minimum, maximum, etc) in generated Java types. Schema rules and the annotation they produce: 
 @Validto
            support validation of an entire document tree. | No (default false) | 
| includeJsr305Annotations | Whether to include JSR-305 annotations (for
            defect detection) in generated Java types. Schema rules and the annotation they produce: 
 @NonNulladded, and@Nullableon all
            other fields. | No (default false) | 
| includeToString | Whether to use include a toStringmethod in generated Java types. | No (default true) | 
| initializeCollections | Whether to initialize Set and List fields as empty collections, or leave them as null. | Yes (default true) | 
| outputEncoding | The character encoding that should be used when writing the generated Java source files. | No (default UTF-8) | 
| parcelable | **EXPERIMENTAL** Whether to make the generated types 'parcelable' (for Android development). | No (default false) | 
| serializable | Whether to make the generated types 'serializable'. | No (default false) | 
| propertyWordDelimiters | A string containing any characters that should act as word delimiters when choosing Java bean property names. | No (default "- _" (hyphen, space, underscore)) | 
| removeOldOutput | Whether to empty the target directory before generation occurs, to clear out all source files
            that have been generated previously. Be warned, when activated this option will cause jsonschema2pojo to indiscriminately delete the entire contents of the target directory (all files and folders) before it begins generating sources. | No (default JSONSCHEMA) | 
| skip | Whether to skip type generation entirely (useful when set via a build property to allow quick disabling of this task using a command line property). | No (default false) | 
| sourceType | The type of input documents that will be read Supported values: 
 | No (default JSONSCHEMA) | 
| targetPackage | Package name used for generated Java classes (for types where a fully qualified name has not been supplied in the schema using the 'javaType' property). | No | 
| useCommonsLang3 | Whether to use commons-lang 3.x imports instead of commons-lang 2.x imports when adding equals, hashCode and toString methods. | No (default false) | 
| useDoubleNumbers | Whether to use the java type double(orDouble) instead offloat(orFloat) when representing the JSON Schema type 'number'. | No (default true) | 
| useBigDecimals | Whether to use the java type BigDecimalinstead offloat(orjava.lang.Float)
            when representing the JSON Schema type 'number'. Note that this overridesuseDoubleNumbers. | No (default false) | 
| useJodaDates | Whether to use org.joda.time.DateTimeinstead ofjava.util.Datewhen
            adding date-time type fields to generated Java types. | No (default false) | 
| useJodaLocalDates | Whether to use org.joda.time.LocalDateinstead ofjava.lang.Stringwhen adding string fields with format date to generated Java types. | No (default false) | 
| useJodaLocalTimes | Whether to use org.joda.time.LocalTimeinstead ofjava.lang.Stringwhen adding string fields with format time to generated Java types. | No (default false) | 
| useLongIntegers | Whether to use the java type long(orLong) instead ofint(orInteger) when representing the JSON Schema type 'integer'. | No (default false) | 
| useBigIntegers | Whether to use the java type BigIntegerinstead ofint(orjava.lang.Integer)
            when representing the JSON Schema type 'integer'. Note that this overridesuseLongIntegers. | No (default false) | 
| usePrimitives | Whether to use primitives ( long,double,boolean)
            instead of wrapper types where possible when generating bean properties (has the side-effect of making
            those. | No (default false) | 
| targetVersion | The target version for generated source files. | No (default 1.6) | 
| dateTimeType | The java type to use instead of java.util.Datewhen adding date-time type fields
            to generated Java types.
 | No | 
| dateType | The java type to use instead of java.lang.Stringwhen adding string fields with
            format date to generated Java types.
 | No | 
| timeType | The java type to use instead of java.lang.Stringwhen adding string fields with
            format time to generated Java types.
 | No | 
| formatDateTimes | Whether the fields of type date-timehave the@JsonFormatannotation
            with pattern set to the default value ofyyyy-MM-dd'T'HH:mm:ss.SSSand timezone set to default
            value ofUTC | No (default false) | 
| refFragmentPathDelimiters | A string containing any characters that should act as path delimiters when resolving $ref fragments. By default, #, / and . are used in an attempt to support JSON Pointer and JSON Path. | No (default #/.) | 
<taskdef name="jsonschema2pojo" classname="org.jsonschema2pojo.ant.Jsonschema2PojoTask">
    <classpath> <!-- classpath only required if jars have *NOT* been added to $ANT_HOME/lib -->
        <fileset dir="my-downloaded-libs">
            <include name="**/*.jar" />
        </fileset>
    </classpath>
</taskdef>
<target name="generate">
    <jsonschema2pojo source="address.json"
                     targetDirectory="build/generated-types"
                     targetPackage="com.example"/>
</target>
    
The above uses the taskdef task to make the jsonschema2pojo task available. The generate target invokes the jsonschema2pojo task to generate java classes based on an input schema called address.json.