embulk-output-snowflake 0.1.1 → 0.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/.gitignore +14 -0
- data/LICENSE.txt +21 -0
- data/README.md +15 -59
- data/build.gradle +112 -3
- data/config/checkstyle/checkstyle.xml +128 -0
- data/config/checkstyle/default.xml +108 -0
- data/gradle/wrapper/gradle-wrapper.jar +0 -0
- data/gradle/wrapper/gradle-wrapper.properties +6 -0
- data/gradlew +172 -0
- data/gradlew.bat +84 -0
- data/lib/embulk/output/snowflake.rb +1 -1
- data/src/main/java/org/embulk/output/SnowflakeOutputPlugin.java +72 -100
- data/src/main/java/org/embulk/output/snowflake/SnowflakeCopyBatchInsert.java +373 -0
- data/src/main/java/org/embulk/output/snowflake/SnowflakeOutputConnection.java +98 -27
- data/src/main/java/org/embulk/output/snowflake/SnowflakeOutputConnector.java +12 -13
- data/src/main/java/org/embulk/output/snowflake/SnowflakeUtils.java +17 -0
- data/src/main/java/org/embulk/output/snowflake/StageIdentifier.java +61 -0
- data/src/main/java/org/embulk/output/snowflake/StageIdentifierHolder.java +20 -0
- data/src/test/java/org/embulk/output/snowflake/TestSnowflakeOutputPlugin.java +5 -0
- metadata +53 -11
- data/classpath/embulk-output-jdbc-0.1.1.jar +0 -0
- data/classpath/embulk-output-snowflake-0.1.1.jar +0 -0
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
|
-
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
2
|
+
SHA256:
|
3
|
+
metadata.gz: 48b8dd29071c4d984c226b731d678d2d4f060d5a79a5a7a1f7087de70dd01a24
|
4
|
+
data.tar.gz: f26570456ebd96ad1aea6901b497d05d5f6da9da93ed8b5d4cd1b28e3c036671
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 5b8c4e8528ca2f2628311d93cd719478a7d7416cff8cddb6924fdf1283593758a97636443e3b9bf5ff28f3b3b9d018da721f7c0716a4a5f39519402b106662ed
|
7
|
+
data.tar.gz: afc42992e170b0cb415f7fa2cb47a828db07f047e75e68c7133429305fdf79670f33e46a814e40863dd722231b9915b774a4c5c86f16262622d87386749bee3e
|
data/.gitignore
ADDED
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
CHANGED
@@ -1,6 +1,6 @@
|
|
1
|
-
#
|
1
|
+
# Snowflake output plugin for Embulk
|
2
2
|
|
3
|
-
Snowflake output plugin for Embulk loads records to
|
3
|
+
Snowflake output plugin for Embulk loads records to Snowflake.
|
4
4
|
|
5
5
|
## Overview
|
6
6
|
|
@@ -10,37 +10,33 @@ Snowflake output plugin for Embulk loads records to a Snowflake using a JDBC dri
|
|
10
10
|
|
11
11
|
## Configuration
|
12
12
|
|
13
|
-
- **
|
14
|
-
- **
|
15
|
-
- **
|
16
|
-
- **
|
17
|
-
- **
|
13
|
+
- **host**: database host name (string, required)
|
14
|
+
- **user**: database login user name (string, required)
|
15
|
+
- **password**: database login password (string, default: "")
|
16
|
+
- **warehouse**: destination warehouse name (string, required)
|
17
|
+
- **database**: destination database name (string, required)
|
18
|
+
- **schema**: destination schema name (string, default: "public")
|
18
19
|
- **table**: destination table name (string, required)
|
19
|
-
- **create_table_constraint**: table constraint added to `CREATE TABLE` statement, like `CREATE TABLE <table_name> (<column1> <type1>, <column2> <type2>, ..., <create_table_constraint>) <create_table_option>`.
|
20
|
-
- **create_table_option**: table option added to `CREATE TABLE` statement, like `CREATE TABLE <table_name> (<column1> <type1>, <column2> <type2>, ..., <create_table_constraint>) <create_table_option>`.
|
21
|
-
- **transaction_isolation**: transaction isolation level for each connection ("read_uncommitted", "read_committed", "repeatable_read" or "serializable"). if not specified, database default value will be used.
|
22
|
-
- **options**: extra JDBC properties (hash, default: {})
|
23
20
|
- **retry_limit**: max retry count for database operations (integer, default: 12). When intermediate table to create already created by another process, this plugin will retry with another table name to avoid collision.
|
24
21
|
- **retry_wait**: initial retry wait time in milliseconds (integer, default: 1000 (1 second))
|
25
22
|
- **max_retry_wait**: upper limit of retry wait, which will be doubled at every retry (integer, default: 1800000 (30 minutes))
|
26
|
-
- **mode**: "insert", "insert_direct", "truncate_insert"
|
23
|
+
- **mode**: "insert", "insert_direct", "truncate_insert" or "replace". See below. (string, required)
|
27
24
|
- **batch_size**: size of a single batch insert (integer, default: 16777216)
|
28
|
-
- **max_table_name_length**: maximum length of table name in this RDBMS (integer, default: 256)
|
29
25
|
- **default_timezone**: If input column type (embulk type) is timestamp, this plugin needs to format the timestamp into a SQL string. This default_timezone option is used to control the timezone. You can overwrite timezone for each columns using column_options option. (string, default: `UTC`)
|
30
26
|
- **column_options**: advanced: a key-value pairs where key is a column name and value is options for the column.
|
31
|
-
- **type**: type of a column when this plugin creates new tables (e.g. `VARCHAR(255)`, `INTEGER NOT NULL UNIQUE`). This used when this plugin creates intermediate tables (insert and
|
32
|
-
- **value_type**: This plugin converts input column type (embulk type) into a database type to build a
|
27
|
+
- **type**: type of a column when this plugin creates new tables (e.g. `VARCHAR(255)`, `INTEGER NOT NULL UNIQUE`). This used when this plugin creates intermediate tables (insert, truncate_insert and merge modes), when it creates the target table (insert_direct and replace modes), and when it creates nonexistent target table automatically. (string, default: depends on input column type. `BIGINT` if input column type is long, `BOOLEAN` if boolean, `DOUBLE PRECISION` if double, `CLOB` if string, `TIMESTAMP` if timestamp)
|
28
|
+
- **value_type**: This plugin converts input column type (embulk type) into a database type to build a TSV to put TSV to internal storage. This value_type option controls the type of the value in a TSV. (string, default: depends on the sql type of the column. Available values options are: `byte`, `short`, `int`, `long`, `double`, `float`, `boolean`, `string`, `nstring`, `date`, `time`, `timestamp`, `decimal`, `json`, `null`, `pass`)
|
33
29
|
- **timestamp_format**: If input column type (embulk type) is timestamp and value_type is `string` or `nstring`, this plugin needs to format the timestamp value into a string. This timestamp_format option is used to control the format of the timestamp. (string, default: `%Y-%m-%d %H:%M:%S.%6N`)
|
34
30
|
- **timezone**: If input column type (embulk type) is timestamp, this plugin needs to format the timestamp value into a SQL string. In this cases, this timezone option is used to control the timezone. (string, value of default_timezone option is used by default)
|
35
31
|
- **before_load**: if set, this SQL will be executed before loading all records. In truncate_insert mode, the SQL will be executed after truncating. replace mode doesn't support this option.
|
36
32
|
- **after_load**: if set, this SQL will be executed after loading all records.
|
37
33
|
|
38
|
-
|
34
|
+
### Modes
|
39
35
|
|
40
36
|
* **insert**:
|
41
37
|
* Behavior: This mode writes rows to some intermediate tables first. If all those tasks run correctly, runs `INSERT INTO <target_table> SELECT * FROM <intermediate_table_1> UNION ALL SELECT * FROM <intermediate_table_2> UNION ALL ...` query. If the target table doesn't exist, it is created automatically.
|
42
38
|
* Transactional: Yes. This mode successfully writes all rows, or fails with writing zero rows.
|
43
|
-
* Resumable:
|
39
|
+
* Resumable: No.
|
44
40
|
* **insert_direct**:
|
45
41
|
* Behavior: This mode inserts rows to the target table directly. If the target table doesn't exist, it is created automatically.
|
46
42
|
* Transactional: No. If fails, the target table could have some rows inserted.
|
@@ -48,54 +44,14 @@ Snowflake output plugin for Embulk loads records to a Snowflake using a JDBC dri
|
|
48
44
|
* **truncate_insert**:
|
49
45
|
* Behavior: Same with `insert` mode excepting that it truncates the target table right before the last `INSERT ...` query.
|
50
46
|
* Transactional: Yes.
|
51
|
-
* Resumable:
|
47
|
+
* Resumable: No.
|
52
48
|
* **replace**:
|
53
49
|
* Behavior: This mode writes rows to an intermediate table first. If all those tasks run correctly, drops the target table and alters the name of the intermediate table into the target table name.
|
54
|
-
* Transactional: No. If fails, the target table could be dropped.
|
55
|
-
* Resumable: No.
|
56
|
-
* **merge**:
|
57
|
-
* Behavior: This mode writes rows to some intermediate tables first. If all those tasks run correctly, merges the intermediate tables into the target table. Namely, if primary keys of a record in the intermediate tables already exist in the target table, the target record is updated by the intermediate record, otherwise the intermediate record is inserted. If the target table doesn't exist, it is created automatically.
|
58
50
|
* Transactional: Yes.
|
59
|
-
* Resumable: Yes.
|
60
|
-
* **merge_direct**:
|
61
|
-
* Behavior: This mode merges rows to the target table directly. Namely, if primary keys of an input record already exist in the target table, the target record is updated by the input record, otherwise the input record is inserted. If the target table doesn't exist, it is created automatically.
|
62
|
-
* Transactional: No.
|
63
51
|
* Resumable: No.
|
64
52
|
|
65
|
-
## Example
|
66
|
-
|
67
|
-
```yaml
|
68
|
-
out:
|
69
|
-
type: snowflake
|
70
|
-
driver_path: /opt/snowflake-jdbc-3.8.0.jar
|
71
|
-
url: jdbc:snowflake://host.eu-central-1.snowflakecomputing.com/?db=development&warehouse=dwh&role=bi&schema=dwh
|
72
|
-
user: myuser
|
73
|
-
password: "mypassword"
|
74
|
-
table: my_table
|
75
|
-
mode: insert
|
76
|
-
```
|
77
|
-
|
78
|
-
Advanced configuration:
|
79
|
-
|
80
|
-
```yaml
|
81
|
-
out:
|
82
|
-
type: snowflake
|
83
|
-
driver_path: /opt/snowflake-jdbc-3.8.0.jar
|
84
|
-
url: jdbc:snowflake://host.eu-central-1.snowflakecomputing.com/?db=development&warehouse=dwh&role=bi&schema=dwh
|
85
|
-
user: myuser
|
86
|
-
password: "mypassword"
|
87
|
-
table: my_table
|
88
|
-
options: {loglevel: 2}
|
89
|
-
mode: insert_direct
|
90
|
-
column_options:
|
91
|
-
my_col_1: {type: 'VARCHAR(255)'}
|
92
|
-
my_col_3: {type: 'INT NOT NULL'}
|
93
|
-
my_col_4: {value_type: string, timestamp_format: `%Y-%m-%d %H:%M:%S %z`, timezone: '-0700'}
|
94
|
-
my_col_5: {type: 'DECIMAL(18,9)', value_type: pass}
|
95
|
-
```
|
96
|
-
|
97
53
|
## Build
|
98
54
|
|
99
55
|
```
|
100
|
-
$ ./gradlew gem
|
56
|
+
$ ./gradlew gem # -t to watch change of files and rebuild continuously
|
101
57
|
```
|
data/build.gradle
CHANGED
@@ -1,5 +1,114 @@
|
|
1
|
+
plugins {
|
2
|
+
id 'com.jfrog.bintray' version '1.8.4'
|
3
|
+
id "com.github.jruby-gradle.base" version "1.6.0"
|
4
|
+
id "java"
|
5
|
+
id "checkstyle"
|
6
|
+
}
|
7
|
+
import com.github.jrubygradle.JRubyExec
|
8
|
+
repositories {
|
9
|
+
mavenCentral()
|
10
|
+
jcenter()
|
11
|
+
maven {
|
12
|
+
url "https://dl.bintray.com/embulk-output-jdbc/maven"
|
13
|
+
}
|
14
|
+
}
|
15
|
+
configurations {
|
16
|
+
provided
|
17
|
+
defaultJdbcDriver
|
18
|
+
}
|
19
|
+
|
20
|
+
version = "0.2.0"
|
21
|
+
|
22
|
+
sourceCompatibility = 1.8
|
23
|
+
targetCompatibility = 1.8
|
24
|
+
|
1
25
|
dependencies {
|
2
|
-
compile
|
3
|
-
|
4
|
-
|
26
|
+
compile "org.embulk:embulk-core:0.9.23"
|
27
|
+
provided "org.embulk:embulk-core:0.9.23"
|
28
|
+
// compile "YOUR_JAR_DEPENDENCY_GROUP:YOUR_JAR_DEPENDENCY_MODULE:YOUR_JAR_DEPENDENCY_VERSION"
|
29
|
+
compile "org.embulk.output.jdbc:embulk-output-jdbc:0.8.7"
|
30
|
+
compile "net.snowflake:snowflake-jdbc:3.12.8"
|
31
|
+
defaultJdbcDriver "net.snowflake:snowflake-jdbc:3.12.8"
|
32
|
+
|
33
|
+
testCompile "junit:junit:4.+"
|
34
|
+
}
|
35
|
+
|
36
|
+
task classpath(type: Copy, dependsOn: ["jar"]) {
|
37
|
+
doFirst { file('classpath').deleteDir() }
|
38
|
+
from (configurations.runtime - configurations.provided - configurations.defaultJdbcDriver + files(jar.archivePath))
|
39
|
+
into 'classpath'
|
40
|
+
}
|
41
|
+
task defaultJdbcDriver(type: Copy, dependsOn: ["jar"]) {
|
42
|
+
doFirst { file('default_jdbc_driver').deleteDir() }
|
43
|
+
from (configurations.defaultJdbcDriver)
|
44
|
+
into 'default_jdbc_driver'
|
45
|
+
}
|
46
|
+
clean {
|
47
|
+
delete 'classpath'
|
48
|
+
delete 'default_jdbc_driver'
|
49
|
+
}
|
50
|
+
|
51
|
+
checkstyle {
|
52
|
+
configFile = file("${project.rootDir}/config/checkstyle/checkstyle.xml")
|
53
|
+
toolVersion = '6.14.1'
|
54
|
+
}
|
55
|
+
checkstyleMain {
|
56
|
+
configFile = file("${project.rootDir}/config/checkstyle/default.xml")
|
57
|
+
ignoreFailures = true
|
58
|
+
}
|
59
|
+
checkstyleTest {
|
60
|
+
configFile = file("${project.rootDir}/config/checkstyle/default.xml")
|
61
|
+
ignoreFailures = true
|
62
|
+
}
|
63
|
+
task checkstyle(type: Checkstyle) {
|
64
|
+
classpath = sourceSets.main.output + sourceSets.test.output
|
65
|
+
source = sourceSets.main.allJava + sourceSets.test.allJava
|
66
|
+
}
|
67
|
+
|
68
|
+
task gem(type: JRubyExec, dependsOn: ["gemspec", "classpath", 'defaultJdbcDriver']) {
|
69
|
+
jrubyArgs "-S"
|
70
|
+
script "gem"
|
71
|
+
scriptArgs "build", "${project.name}.gemspec"
|
72
|
+
doLast { ant.move(file: "${project.name}-${project.version}.gem", todir: "pkg") }
|
73
|
+
}
|
74
|
+
|
75
|
+
task gemPush(type: JRubyExec, dependsOn: ["gem"]) {
|
76
|
+
jrubyArgs "-S"
|
77
|
+
script "gem"
|
78
|
+
scriptArgs "push", "pkg/${project.name}-${project.version}.gem"
|
79
|
+
}
|
80
|
+
|
81
|
+
task "package"(dependsOn: ["gemspec", "classpath"]) {
|
82
|
+
doLast {
|
83
|
+
println "> Build succeeded."
|
84
|
+
println "> You can run embulk with '-L ${file(".").absolutePath}' argument."
|
85
|
+
}
|
86
|
+
}
|
87
|
+
|
88
|
+
task gemspec {
|
89
|
+
ext.gemspecFile = file("${project.name}.gemspec")
|
90
|
+
inputs.file "build.gradle"
|
91
|
+
outputs.file gemspecFile
|
92
|
+
doLast { gemspecFile.write($/
|
93
|
+
Gem::Specification.new do |spec|
|
94
|
+
spec.name = "${project.name}"
|
95
|
+
spec.version = "${project.version}"
|
96
|
+
spec.authors = ["giwa"]
|
97
|
+
spec.summary = %[Snowflake output plugin for Embulk]
|
98
|
+
spec.description = %[Dumps records to Snowflake.]
|
99
|
+
spec.email = ["ugw.gi.world@gmail.com"]
|
100
|
+
spec.licenses = ["MIT"]
|
101
|
+
spec.homepage = "https://github.com/trocco-io/embulk-output-snowflake"
|
102
|
+
|
103
|
+
spec.files = `git ls-files`.split("\n") + Dir["classpath/*.jar"] + Dir["default_jdbc_driver/*.jar"]
|
104
|
+
spec.test_files = spec.files.grep(%r"^(test|spec)/")
|
105
|
+
spec.require_paths = ["lib"]
|
106
|
+
|
107
|
+
#spec.add_dependency 'YOUR_GEM_DEPENDENCY', ['~> YOUR_GEM_DEPENDENCY_VERSION']
|
108
|
+
spec.add_development_dependency 'bundler', ['~> 1.0']
|
109
|
+
spec.add_development_dependency 'rake', ['~> 12.0']
|
110
|
+
end
|
111
|
+
/$)
|
112
|
+
}
|
5
113
|
}
|
114
|
+
clean { delete "${project.name}.gemspec" }
|
@@ -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>
|