embulk-output-kafka 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +12 -0
  3. data/LICENSE.txt +21 -0
  4. data/README.md +110 -0
  5. data/build.gradle +113 -0
  6. data/classpath/audience-annotations-0.5.0.jar +0 -0
  7. data/classpath/avro-1.9.0.jar +0 -0
  8. data/classpath/common-config-5.3.0.jar +0 -0
  9. data/classpath/common-utils-5.3.0.jar +0 -0
  10. data/classpath/commons-compress-1.18.jar +0 -0
  11. data/classpath/embulk-output-kafka-0.1.0.jar +0 -0
  12. data/classpath/jackson-annotations-2.9.0.jar +0 -0
  13. data/classpath/jackson-core-2.9.9.jar +0 -0
  14. data/classpath/jackson-databind-2.9.9.jar +0 -0
  15. data/classpath/jline-0.9.94.jar +0 -0
  16. data/classpath/jsr305-3.0.2.jar +0 -0
  17. data/classpath/kafka-avro-serializer-5.3.0.jar +0 -0
  18. data/classpath/kafka-clients-5.3.0-ccs.jar +0 -0
  19. data/classpath/kafka-schema-registry-client-5.3.0.jar +0 -0
  20. data/classpath/lz4-java-1.6.0.jar +0 -0
  21. data/classpath/netty-3.10.6.Final.jar +0 -0
  22. data/classpath/slf4j-api-1.7.26.jar +0 -0
  23. data/classpath/snappy-java-1.1.7.3.jar +0 -0
  24. data/classpath/spotbugs-annotations-3.1.9.jar +0 -0
  25. data/classpath/zkclient-0.10.jar +0 -0
  26. data/classpath/zookeeper-3.4.14.jar +0 -0
  27. data/classpath/zstd-jni-1.4.0-1.jar +0 -0
  28. data/config/checkstyle/checkstyle.xml +128 -0
  29. data/config/checkstyle/default.xml +108 -0
  30. data/gradle/wrapper/gradle-wrapper.jar +0 -0
  31. data/gradle/wrapper/gradle-wrapper.properties +5 -0
  32. data/gradlew +172 -0
  33. data/gradlew.bat +84 -0
  34. data/lib/embulk/output/kafka.rb +3 -0
  35. data/src/main/java/org/embulk/output/kafka/AvroFormatColumnVisitor.java +189 -0
  36. data/src/main/java/org/embulk/output/kafka/JsonFormatColumnVisitor.java +103 -0
  37. data/src/main/java/org/embulk/output/kafka/KafkaJsonSerializer.java +23 -0
  38. data/src/main/java/org/embulk/output/kafka/KafkaOutputColumnVisitor.java +53 -0
  39. data/src/main/java/org/embulk/output/kafka/KafkaOutputPlugin.java +323 -0
  40. data/src/main/java/org/embulk/output/kafka/RecordProducerFactory.java +105 -0
  41. data/src/test/java/org/embulk/output/kafka/TestKafkaOutputPlugin.java +5 -0
  42. data/src/test/resources/SimpleRecord.avsc +9 -0
  43. data/src/test/resources/config_complex.yml +26 -0
  44. data/src/test/resources/config_complex_avro.yml +43 -0
  45. data/src/test/resources/config_simple.yml +22 -0
  46. data/src/test/resources/config_simple_avro.yml +32 -0
  47. data/src/test/resources/config_simple_avro_avsc_file.yml +25 -0
  48. data/src/test/resources/config_with_key_column.yml +23 -0
  49. data/src/test/resources/in1.csv +4 -0
  50. data/src/test/resources/in_complex.csv +5 -0
  51. metadata +121 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 1c3f5f6030d31658069560ca259993a1b4032522
4
+ data.tar.gz: a1b253e969692fdb3838aaf311450e31c870aba5
5
+ SHA512:
6
+ metadata.gz: 94e2243466075f14a158e0142eabebf51b81b828434b0189d0e600ec48379fd1dce7fcd5c3d49a44e2962173104952905e495b8f45d42e289bd2e07a735611d1
7
+ data.tar.gz: '08af7e9195d7d44a109021cf929cb024fdbe2d8baef8f877586dbe96745e65da307d8fbc8c27506b12727c6f420f275fe860dcb17cba88028416c4b17fd86ebc'
data/.gitignore ADDED
@@ -0,0 +1,12 @@
1
+ *~
2
+ /pkg/
3
+ /tmp/
4
+ *.gemspec
5
+ .gradle/
6
+ /classpath/
7
+ build/
8
+ .idea
9
+ /.settings/
10
+ /.metadata/
11
+ .classpath
12
+ .project
data/LICENSE.txt ADDED
@@ -0,0 +1,21 @@
1
+
2
+ MIT License
3
+
4
+ Permission is hereby granted, free of charge, to any person obtaining
5
+ a copy of this software and associated documentation files (the
6
+ "Software"), to deal in the Software without restriction, including
7
+ without limitation the rights to use, copy, modify, merge, publish,
8
+ distribute, sublicense, and/or sell copies of the Software, and to
9
+ permit persons to whom the Software is furnished to do so, subject to
10
+ the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be
13
+ included in all copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
16
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
17
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
18
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
19
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
20
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
21
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,110 @@
1
+ # Kafka output plugin for Embulk
2
+
3
+ ## Overview
4
+
5
+ * **Plugin type**: output
6
+ * **Load all or nothing**: no
7
+ * **Resume supported**: no
8
+ * **Cleanup supported**: yes
9
+
10
+ ## Configuration
11
+
12
+ - **broker**: kafka broker host and port (array<string>, required)
13
+ - **topic**: target topic name (string, required)
14
+ - **topic_column**: use column value as target topic (string, default: `null`)
15
+ - **schema_registry_url**: Schema Registy URL that is needed for avro format (string, default: `null`)
16
+ - **serialize_format**: use column value as target topic (enum, required, `json` or `avro_with_schema_registry`)
17
+ - **avsc_file**: avro schema file path (string, default: `null`)
18
+ - **avsc**: inline avro schema config (json, default: `null`)
19
+ - **key_column_name**: use column value as record key (string, default: `null`, if this parameter is null, set random number as record key)
20
+ - **record_batch_size**: kafka producer record batch size (integer, default: `500`)
21
+ - **acks**: kafka producer require acks (string, default: `"1"`)
22
+ - **retries**: kafka producer max retry count (integer, default: `1`)
23
+ - **other_producer_configs**: other producer configs (json, default: `{}`)
24
+
25
+ If use `avro_with_schema_registry` format, following configs are required.
26
+
27
+ - **schema_registry_url**
28
+ - **avsc** or **avsc_file**
29
+
30
+ ## Example
31
+
32
+ ```yaml
33
+ in:
34
+ type: file
35
+ path_prefix: ./src/test/resources/in1
36
+ parser:
37
+ charset: UTF-8
38
+ newline: CRLF
39
+ type: csv
40
+ delimiter: ','
41
+ quote: '"'
42
+ escape: '"'
43
+ null_string: 'NULL'
44
+ skip_header_lines: 1
45
+ columns:
46
+ - {name: 'id', type: string}
47
+ - {name: 'int_item', type: long}
48
+ - {name: 'varchar_item', type: string}
49
+
50
+ out:
51
+ type: kafka
52
+ topic: "json-topic"
53
+ serialize_format: json
54
+ brokers:
55
+ - "localhost:9092"
56
+ ```
57
+
58
+ ```yaml
59
+ in:
60
+ type: file
61
+ path_prefix: ./src/test/resources/in_complex
62
+ parser:
63
+ charset: UTF-8
64
+ newline: CRLF
65
+ type: csv
66
+ delimiter: "\t"
67
+ quote: "\0"
68
+ escape: "\0"
69
+ null_string: 'NULL'
70
+ skip_header_lines: 1
71
+ columns:
72
+ - {name: 'id', type: string}
73
+ - {name: 'int_item', type: long}
74
+ - {name: 'time', type: timestamp, format: "%Y-%m-%dT%H:%M:%S"}
75
+ - {name: 'array', type: json}
76
+ - {name: 'data', type: json}
77
+
78
+ out:
79
+ type: kafka
80
+ topic: "avro-complex-topic"
81
+ acks: all
82
+ retries: 3
83
+ brokers:
84
+ - "localhost:9092"
85
+ schema_registry_url: "http://localhost:48081/"
86
+ serialize_format: avro_with_schema_registry
87
+ other_producer_configs:
88
+ buffer.memory: "67108864"
89
+ avsc:
90
+ type: record
91
+ name: ComplexRecord
92
+ fields: [
93
+ {name: "id", type: "string"},
94
+ {name: "int_item", type: "long"},
95
+ {name: "time", type: "long", logicalType: "timestamp-milli"},
96
+ {name: "array", type: {type: "array", items: "long"}},
97
+ {name: "data", type: {type: "record", name: "InnerData", fields: [
98
+ {name: "hoge", type: "string"},
99
+ {name: "aaa", type: ["null", "string"]},
100
+ {name: "array", type: {type: "array", items: "long"}},
101
+ ]}},
102
+ ]
103
+ ```
104
+
105
+
106
+ ## Build
107
+
108
+ ```
109
+ $ ./gradlew gem # -t to watch change of files and rebuild continuously
110
+ ```
data/build.gradle ADDED
@@ -0,0 +1,113 @@
1
+ plugins {
2
+ id "com.jfrog.bintray" version "1.1"
3
+ id "com.github.jruby-gradle.base" version "1.5.0"
4
+ id "java"
5
+ id "checkstyle"
6
+ }
7
+ import com.github.jrubygradle.JRubyExec
8
+ repositories {
9
+ mavenCentral()
10
+ jcenter()
11
+
12
+ maven {
13
+ url "http://packages.confluent.io/maven/"
14
+ }
15
+ }
16
+ configurations {
17
+ provided
18
+ }
19
+
20
+ version = "0.1.0"
21
+
22
+ sourceCompatibility = 1.8
23
+ targetCompatibility = 1.8
24
+
25
+ dependencies {
26
+ compile "org.embulk:embulk-core:0.9.17"
27
+ provided "org.embulk:embulk-core:0.9.17"
28
+ // compile "YOUR_JAR_DEPENDENCY_GROUP:YOUR_JAR_DEPENDENCY_MODULE:YOUR_JAR_DEPENDENCY_VERSION"
29
+ testCompile "junit:junit:4.12"
30
+ testCompile "org.embulk:embulk-test:0.9.17"
31
+ testCompile "org.embulk:embulk-standards:0.9.17"
32
+
33
+ compile "org.apache.kafka:kafka-clients:2.3.0"
34
+ compile("org.apache.avro:avro:1.9.0") {
35
+ }
36
+ compile("io.confluent:kafka-avro-serializer:5.3.0") {
37
+ }
38
+
39
+ testCompile("com.github.charithe:kafka-junit:4.1.6") {
40
+ }
41
+ }
42
+
43
+ task classpath(type: Copy, dependsOn: ["jar"]) {
44
+ doFirst { file("classpath").deleteDir() }
45
+ from (configurations.runtime - configurations.provided + files(jar.archivePath))
46
+ into "classpath"
47
+ }
48
+ clean { delete "classpath" }
49
+
50
+ checkstyle {
51
+ configFile = file("${project.rootDir}/config/checkstyle/checkstyle.xml")
52
+ toolVersion = '6.14.1'
53
+ }
54
+ checkstyleMain {
55
+ configFile = file("${project.rootDir}/config/checkstyle/default.xml")
56
+ ignoreFailures = true
57
+ }
58
+ checkstyleTest {
59
+ configFile = file("${project.rootDir}/config/checkstyle/default.xml")
60
+ ignoreFailures = true
61
+ }
62
+ task checkstyle(type: Checkstyle) {
63
+ classpath = sourceSets.main.output + sourceSets.test.output
64
+ source = sourceSets.main.allJava + sourceSets.test.allJava
65
+ }
66
+
67
+ task gem(type: JRubyExec, dependsOn: ["gemspec", "classpath"]) {
68
+ jrubyArgs "-S"
69
+ script "gem"
70
+ scriptArgs "build", "${project.name}.gemspec"
71
+ doLast { ant.move(file: "${project.name}-${project.version}.gem", todir: "pkg") }
72
+ }
73
+
74
+ task gemPush(type: JRubyExec, dependsOn: ["gem"]) {
75
+ jrubyArgs "-S"
76
+ script "gem"
77
+ scriptArgs "push", "pkg/${project.name}-${project.version}.gem"
78
+ }
79
+
80
+ task "package"(dependsOn: ["gemspec", "classpath"]) {
81
+ doLast {
82
+ println "> Build succeeded."
83
+ println "> You can run embulk with '-L ${file(".").absolutePath}' argument."
84
+ }
85
+ }
86
+
87
+ task gemspec {
88
+ ext.gemspecFile = file("${project.name}.gemspec")
89
+ inputs.file "build.gradle"
90
+ outputs.file gemspecFile
91
+ doLast { gemspecFile.write($/
92
+ Gem::Specification.new do |spec|
93
+ spec.name = "${project.name}"
94
+ spec.version = "${project.version}"
95
+ spec.authors = ["joker1007"]
96
+ spec.summary = %[Kafka output plugin for Embulk]
97
+ spec.description = %[Dumps records to Kafka.]
98
+ spec.email = ["kakyoin.hierophant@gmail.com"]
99
+ spec.licenses = ["MIT"]
100
+ # TODO set this: spec.homepage = "https://github.com/kakyoin.hierophant/embulk-output-kafka"
101
+
102
+ spec.files = `git ls-files`.split("\n") + Dir["classpath/*.jar"]
103
+ spec.test_files = spec.files.grep(%r"^(test|spec)/")
104
+ spec.require_paths = ["lib"]
105
+
106
+ #spec.add_dependency 'YOUR_GEM_DEPENDENCY', ['~> YOUR_GEM_DEPENDENCY_VERSION']
107
+ spec.add_development_dependency 'bundler', ['~> 1.0']
108
+ spec.add_development_dependency 'rake', ['~> 12.0']
109
+ end
110
+ /$)
111
+ }
112
+ }
113
+ clean { delete "${project.name}.gemspec" }
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
Binary file
@@ -0,0 +1,128 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <!DOCTYPE module PUBLIC
3
+ "-//Puppy Crawl//DTD Check Configuration 1.3//EN"
4
+ "http://www.puppycrawl.com/dtds/configuration_1_3.dtd">
5
+ <module name="Checker">
6
+ <!-- https://github.com/facebook/presto/blob/master/src/checkstyle/checks.xml -->
7
+ <module name="FileTabCharacter"/>
8
+ <module name="NewlineAtEndOfFile">
9
+ <property name="lineSeparator" value="lf"/>
10
+ </module>
11
+ <module name="RegexpMultiline">
12
+ <property name="format" value="\r"/>
13
+ <property name="message" value="Line contains carriage return"/>
14
+ </module>
15
+ <module name="RegexpMultiline">
16
+ <property name="format" value=" \n"/>
17
+ <property name="message" value="Line has trailing whitespace"/>
18
+ </module>
19
+ <module name="RegexpMultiline">
20
+ <property name="format" value="\{\n\n"/>
21
+ <property name="message" value="Blank line after opening brace"/>
22
+ </module>
23
+ <module name="RegexpMultiline">
24
+ <property name="format" value="\n\n\s*\}"/>
25
+ <property name="message" value="Blank line before closing brace"/>
26
+ </module>
27
+ <module name="RegexpMultiline">
28
+ <property name="format" value="\n\n\n"/>
29
+ <property name="message" value="Multiple consecutive blank lines"/>
30
+ </module>
31
+ <module name="RegexpMultiline">
32
+ <property name="format" value="\n\n\Z"/>
33
+ <property name="message" value="Blank line before end of file"/>
34
+ </module>
35
+ <module name="RegexpMultiline">
36
+ <property name="format" value="Preconditions\.checkNotNull"/>
37
+ <property name="message" value="Use of checkNotNull"/>
38
+ </module>
39
+
40
+ <module name="TreeWalker">
41
+ <module name="EmptyBlock">
42
+ <property name="option" value="text"/>
43
+ <property name="tokens" value="
44
+ LITERAL_DO, LITERAL_ELSE, LITERAL_FINALLY, LITERAL_IF,
45
+ LITERAL_FOR, LITERAL_TRY, LITERAL_WHILE, INSTANCE_INIT, STATIC_INIT"/>
46
+ </module>
47
+ <module name="EmptyStatement"/>
48
+ <module name="EmptyForInitializerPad"/>
49
+ <module name="EmptyForIteratorPad">
50
+ <property name="option" value="space"/>
51
+ </module>
52
+ <module name="MethodParamPad">
53
+ <property name="allowLineBreaks" value="true"/>
54
+ <property name="option" value="nospace"/>
55
+ </module>
56
+ <module name="ParenPad"/>
57
+ <module name="TypecastParenPad"/>
58
+ <module name="NeedBraces"/>
59
+ <module name="LeftCurly">
60
+ <property name="option" value="nl"/>
61
+ <property name="tokens" value="CLASS_DEF, CTOR_DEF, INTERFACE_DEF, METHOD_DEF"/>
62
+ </module>
63
+ <module name="LeftCurly">
64
+ <property name="option" value="eol"/>
65
+ <property name="tokens" value="
66
+ LITERAL_CATCH, LITERAL_DO, LITERAL_ELSE, LITERAL_FINALLY, LITERAL_FOR,
67
+ LITERAL_IF, LITERAL_SWITCH, LITERAL_SYNCHRONIZED, LITERAL_TRY, LITERAL_WHILE"/>
68
+ </module>
69
+ <module name="RightCurly">
70
+ <property name="option" value="alone"/>
71
+ </module>
72
+ <module name="GenericWhitespace"/>
73
+ <module name="WhitespaceAfter"/>
74
+ <module name="NoWhitespaceBefore"/>
75
+
76
+ <module name="UpperEll"/>
77
+ <module name="DefaultComesLast"/>
78
+ <module name="ArrayTypeStyle"/>
79
+ <module name="MultipleVariableDeclarations"/>
80
+ <module name="ModifierOrder"/>
81
+ <module name="OneStatementPerLine"/>
82
+ <module name="StringLiteralEquality"/>
83
+ <module name="MutableException"/>
84
+ <module name="EqualsHashCode"/>
85
+ <module name="InnerAssignment"/>
86
+ <module name="InterfaceIsType"/>
87
+ <module name="HideUtilityClassConstructor"/>
88
+
89
+ <module name="MemberName"/>
90
+ <module name="LocalVariableName"/>
91
+ <module name="LocalFinalVariableName"/>
92
+ <module name="TypeName"/>
93
+ <module name="PackageName"/>
94
+ <module name="ParameterName"/>
95
+ <module name="StaticVariableName"/>
96
+ <module name="ClassTypeParameterName">
97
+ <property name="format" value="^[A-Z][0-9]?$"/>
98
+ </module>
99
+ <module name="MethodTypeParameterName">
100
+ <property name="format" value="^[A-Z][0-9]?$"/>
101
+ </module>
102
+
103
+ <module name="AvoidStarImport"/>
104
+ <module name="RedundantImport"/>
105
+ <module name="UnusedImports"/>
106
+ <module name="ImportOrder">
107
+ <property name="groups" value="*,javax,java"/>
108
+ <property name="separated" value="true"/>
109
+ <property name="option" value="bottom"/>
110
+ <property name="sortStaticImportsAlphabetically" value="true"/>
111
+ </module>
112
+
113
+ <module name="WhitespaceAround">
114
+ <property name="allowEmptyConstructors" value="true"/>
115
+ <property name="allowEmptyMethods" value="true"/>
116
+ <property name="ignoreEnhancedForColon" value="false"/>
117
+ <property name="tokens" value="
118
+ ASSIGN, BAND, BAND_ASSIGN, BOR, BOR_ASSIGN, BSR, BSR_ASSIGN,
119
+ BXOR, BXOR_ASSIGN, COLON, DIV, DIV_ASSIGN, EQUAL, GE, GT, LAND, LE,
120
+ LITERAL_ASSERT, LITERAL_CATCH, LITERAL_DO, LITERAL_ELSE,
121
+ LITERAL_FINALLY, LITERAL_FOR, LITERAL_IF, LITERAL_RETURN,
122
+ LITERAL_SYNCHRONIZED, LITERAL_TRY, LITERAL_WHILE,
123
+ LOR, LT, MINUS, MINUS_ASSIGN, MOD, MOD_ASSIGN, NOT_EQUAL,
124
+ PLUS, PLUS_ASSIGN, QUESTION, SL, SLIST, SL_ASSIGN, SR, SR_ASSIGN,
125
+ STAR, STAR_ASSIGN, TYPE_EXTENSION_AND"/>
126
+ </module>
127
+ </module>
128
+ </module>
@@ -0,0 +1,108 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <!DOCTYPE module PUBLIC
3
+ "-//Puppy Crawl//DTD Check Configuration 1.3//EN"
4
+ "http://www.puppycrawl.com/dtds/configuration_1_3.dtd">
5
+ <!--
6
+ This is a subset of ./checkstyle.xml which allows some loose styles
7
+ -->
8
+ <module name="Checker">
9
+ <module name="FileTabCharacter"/>
10
+ <module name="NewlineAtEndOfFile">
11
+ <property name="lineSeparator" value="lf"/>
12
+ </module>
13
+ <module name="RegexpMultiline">
14
+ <property name="format" value="\r"/>
15
+ <property name="message" value="Line contains carriage return"/>
16
+ </module>
17
+ <module name="RegexpMultiline">
18
+ <property name="format" value=" \n"/>
19
+ <property name="message" value="Line has trailing whitespace"/>
20
+ </module>
21
+ <module name="RegexpMultiline">
22
+ <property name="format" value="\n\n\n"/>
23
+ <property name="message" value="Multiple consecutive blank lines"/>
24
+ </module>
25
+ <module name="RegexpMultiline">
26
+ <property name="format" value="\n\n\Z"/>
27
+ <property name="message" value="Blank line before end of file"/>
28
+ </module>
29
+
30
+ <module name="TreeWalker">
31
+ <module name="EmptyBlock">
32
+ <property name="option" value="text"/>
33
+ <property name="tokens" value="
34
+ LITERAL_DO, LITERAL_ELSE, LITERAL_FINALLY, LITERAL_IF,
35
+ LITERAL_FOR, LITERAL_TRY, LITERAL_WHILE, INSTANCE_INIT, STATIC_INIT"/>
36
+ </module>
37
+ <module name="EmptyStatement"/>
38
+ <module name="EmptyForInitializerPad"/>
39
+ <module name="EmptyForIteratorPad">
40
+ <property name="option" value="space"/>
41
+ </module>
42
+ <module name="MethodParamPad">
43
+ <property name="allowLineBreaks" value="true"/>
44
+ <property name="option" value="nospace"/>
45
+ </module>
46
+ <module name="ParenPad"/>
47
+ <module name="TypecastParenPad"/>
48
+ <module name="NeedBraces"/>
49
+ <module name="LeftCurly">
50
+ <property name="option" value="nl"/>
51
+ <property name="tokens" value="CLASS_DEF, CTOR_DEF, INTERFACE_DEF, METHOD_DEF"/>
52
+ </module>
53
+ <module name="LeftCurly">
54
+ <property name="option" value="eol"/>
55
+ <property name="tokens" value="
56
+ LITERAL_CATCH, LITERAL_DO, LITERAL_ELSE, LITERAL_FINALLY, LITERAL_FOR,
57
+ LITERAL_IF, LITERAL_SWITCH, LITERAL_SYNCHRONIZED, LITERAL_TRY, LITERAL_WHILE"/>
58
+ </module>
59
+ <module name="RightCurly">
60
+ <property name="option" value="alone"/>
61
+ </module>
62
+ <module name="GenericWhitespace"/>
63
+ <module name="WhitespaceAfter"/>
64
+ <module name="NoWhitespaceBefore"/>
65
+
66
+ <module name="UpperEll"/>
67
+ <module name="DefaultComesLast"/>
68
+ <module name="ArrayTypeStyle"/>
69
+ <module name="MultipleVariableDeclarations"/>
70
+ <module name="ModifierOrder"/>
71
+ <module name="OneStatementPerLine"/>
72
+ <module name="StringLiteralEquality"/>
73
+ <module name="MutableException"/>
74
+ <module name="EqualsHashCode"/>
75
+ <module name="InnerAssignment"/>
76
+ <module name="InterfaceIsType"/>
77
+ <module name="HideUtilityClassConstructor"/>
78
+
79
+ <module name="MemberName"/>
80
+ <module name="LocalVariableName"/>
81
+ <module name="LocalFinalVariableName"/>
82
+ <module name="TypeName"/>
83
+ <module name="PackageName"/>
84
+ <module name="ParameterName"/>
85
+ <module name="StaticVariableName"/>
86
+ <module name="ClassTypeParameterName">
87
+ <property name="format" value="^[A-Z][0-9]?$"/>
88
+ </module>
89
+ <module name="MethodTypeParameterName">
90
+ <property name="format" value="^[A-Z][0-9]?$"/>
91
+ </module>
92
+
93
+ <module name="WhitespaceAround">
94
+ <property name="allowEmptyConstructors" value="true"/>
95
+ <property name="allowEmptyMethods" value="true"/>
96
+ <property name="ignoreEnhancedForColon" value="false"/>
97
+ <property name="tokens" value="
98
+ ASSIGN, BAND, BAND_ASSIGN, BOR, BOR_ASSIGN, BSR, BSR_ASSIGN,
99
+ BXOR, BXOR_ASSIGN, COLON, DIV, DIV_ASSIGN, EQUAL, GE, GT, LAND, LE,
100
+ LITERAL_ASSERT, LITERAL_CATCH, LITERAL_DO, LITERAL_ELSE,
101
+ LITERAL_FINALLY, LITERAL_FOR, LITERAL_IF, LITERAL_RETURN,
102
+ LITERAL_SYNCHRONIZED, LITERAL_TRY, LITERAL_WHILE,
103
+ LOR, LT, MINUS, MINUS_ASSIGN, MOD, MOD_ASSIGN, NOT_EQUAL,
104
+ PLUS, PLUS_ASSIGN, QUESTION, SL, SLIST, SL_ASSIGN, SR, SR_ASSIGN,
105
+ STAR, STAR_ASSIGN, TYPE_EXTENSION_AND"/>
106
+ </module>
107
+ </module>
108
+ </module>
Binary file
@@ -0,0 +1,5 @@
1
+ distributionBase=GRADLE_USER_HOME
2
+ distributionPath=wrapper/dists
3
+ zipStoreBase=GRADLE_USER_HOME
4
+ zipStorePath=wrapper/dists
5
+ distributionUrl=https\://services.gradle.org/distributions/gradle-4.1-bin.zip