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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
- SHA1:
3
- metadata.gz: 383ccdda739d086fd4ec83452382f75139b859b7
4
- data.tar.gz: e115339e03ef287b89638c0411ffbafc24e4c2f9
2
+ SHA256:
3
+ metadata.gz: 48b8dd29071c4d984c226b731d678d2d4f060d5a79a5a7a1f7087de70dd01a24
4
+ data.tar.gz: f26570456ebd96ad1aea6901b497d05d5f6da9da93ed8b5d4cd1b28e3c036671
5
5
  SHA512:
6
- metadata.gz: da715c55401a0bf7b7009293196db2a115330e79ac935aa92ea3aa296d513c98d119886c2c743384c4bde23f823339543792bd16afcf3a4141aaa50e728c62df
7
- data.tar.gz: 9de41d872c721e23de9e501fe89cbb6fea440cd8eaf0f9483b7ba31b1096e7ef4439a67a2ed9dcfa573c61dcf259df5929935567dcf82f6d0dcd6027c981b81b
6
+ metadata.gz: 5b8c4e8528ca2f2628311d93cd719478a7d7416cff8cddb6924fdf1283593758a97636443e3b9bf5ff28f3b3b9d018da721f7c0716a4a5f39519402b106662ed
7
+ data.tar.gz: afc42992e170b0cb415f7fa2cb47a828db07f047e75e68c7133429305fdf79670f33e46a814e40863dd722231b9915b774a4c5c86f16262622d87386749bee3e
@@ -0,0 +1,14 @@
1
+ *~
2
+ /pkg/
3
+ /tmp/
4
+ *.gemspec
5
+ .gradle/
6
+ /classpath/
7
+ build/
8
+ .idea
9
+ /.settings/
10
+ /.metadata/
11
+ .classpath
12
+ .project
13
+ config.yml
14
+ default_jdbc_driver/
@@ -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
- # Generic JDBC output plugin for Embulk
1
+ # Snowflake output plugin for Embulk
2
2
 
3
- Snowflake output plugin for Embulk loads records to a Snowflake using a JDBC driver.
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
- - **driver_path**: path to the jar file of the Snowflake JDBC driver (e.g. 'snowflake-jdbc-3.8.0.jar') (string, optional)
14
- - **url**: URL of the JDBC connection (e.g. 'jdbc:snowflake://host.eu-central-1.snowflakecomputing.com/?db=development') (string, required)
15
- - **user**: database login user name (string, optional)
16
- - **password**: database login password (string, optional)
17
- - **schema**: destination schema name (string, default: use default schema)
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", or "replace". See below (string, required)
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 truncate_insert modes), when it creates the target table (replace mode), 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)
32
- - **value_type**: This plugin converts input column type (embulk type) into a database type to build a INSERT statement. This value_type option controls the type of the value in a INSERT statement. (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`)
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
- ## Modes
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: Yes.
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: Yes.
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
  ```
@@ -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 project(':embulk-output-jdbc')
3
-
4
- testCompile project(':embulk-output-jdbc').sourceSets.test.output
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>