embulk 0.3.2 → 0.4.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.
- checksums.yaml +5 -13
- data/.travis.yml +16 -0
- data/Gemfile +0 -1
- data/README.md +37 -19
- data/Rakefile +5 -37
- data/bin/embulk +1 -1
- data/build.gradle +178 -95
- data/embulk-core/build.gradle +1 -1
- data/embulk-core/src/main/java/org/embulk/command/Runner.java +11 -10
- data/embulk-core/src/main/java/org/embulk/config/ConfigDiff.java +26 -0
- data/embulk-core/src/main/java/org/embulk/config/ConfigInject.java +14 -0
- data/embulk-core/src/main/java/org/embulk/config/DataSourceImpl.java +2 -2
- data/embulk-core/src/main/java/org/embulk/config/DataSourceSerDe.java +4 -3
- data/embulk-core/src/main/java/org/embulk/config/TaskSerDe.java +5 -3
- data/embulk-core/src/main/java/org/embulk/config/TaskValidationException.java +1 -0
- data/embulk-core/src/main/java/org/embulk/exec/ExecutionResult.java +6 -6
- data/embulk-core/src/main/java/org/embulk/exec/GuessExecutor.java +19 -19
- data/embulk-core/src/main/java/org/embulk/exec/LocalExecutor.java +61 -36
- data/embulk-core/src/main/java/org/embulk/plugin/InjectedPluginSource.java +4 -0
- data/embulk-core/src/main/java/org/embulk/plugin/PluginManager.java +16 -1
- data/embulk-core/src/main/java/org/embulk/spi/Column.java +1 -1
- data/embulk-core/src/main/java/org/embulk/spi/{SchemaVisitor.java → ColumnVisitor.java} +1 -1
- data/embulk-core/src/main/java/org/embulk/spi/Exec.java +3 -3
- data/embulk-core/src/main/java/org/embulk/spi/ExecSession.java +2 -2
- data/embulk-core/src/main/java/org/embulk/spi/FileInputPlugin.java +3 -3
- data/embulk-core/src/main/java/org/embulk/spi/FileInputRunner.java +3 -3
- data/embulk-core/src/main/java/org/embulk/spi/FileOutputPlugin.java +3 -3
- data/embulk-core/src/main/java/org/embulk/spi/FileOutputRunner.java +3 -3
- data/embulk-core/src/main/java/org/embulk/spi/FilterPlugin.java +1 -1
- data/embulk-core/src/main/java/org/embulk/spi/GuessPlugin.java +2 -2
- data/embulk-core/src/main/java/org/embulk/spi/InputPlugin.java +3 -3
- data/embulk-core/src/main/java/org/embulk/spi/OutputPlugin.java +3 -3
- data/embulk-core/src/main/java/org/embulk/spi/PluginClassLoader.java +80 -0
- data/embulk-core/src/main/java/org/embulk/spi/Schema.java +1 -1
- data/embulk-core/src/main/java/org/embulk/spi/time/TimestampFormatter.java +2 -2
- data/embulk-core/src/main/java/org/embulk/spi/time/TimestampParser.java +2 -2
- data/embulk-core/src/main/java/org/embulk/spi/util/Filters.java +1 -1
- data/embulk-core/src/main/java/org/embulk/spi/util/LineEncoder.java +2 -2
- data/embulk-core/src/main/java/org/embulk/spi/util/PagePrinter.java +6 -6
- data/embulk-core/src/main/java/org/embulk/spi/util/Pages.java +6 -6
- data/embulk-core/src/test/java/org/embulk/GuiceBinder.java +1 -1
- data/embulk-core/src/test/java/org/embulk/plugin/MockPluginSource.java +1 -0
- data/embulk-core/src/test/java/org/embulk/spi/MockFormatterPlugin.java +2 -2
- data/embulk-core/src/test/java/org/embulk/spi/PageTestUtils.java +1 -1
- data/embulk-core/src/test/java/org/embulk/spi/TestFileInputRunner.java +3 -3
- data/embulk-core/src/test/java/org/embulk/spi/TestFileOutputRunner.java +4 -4
- data/embulk-docs/Makefile +178 -0
- data/embulk-docs/build.gradle +20 -0
- data/embulk-docs/make.bat +243 -0
- data/embulk-docs/push-gh-pages.sh +29 -0
- data/embulk-docs/src/conf.py +260 -0
- data/embulk-docs/src/index.rst +19 -0
- data/embulk-docs/src/release.rst +14 -0
- data/embulk-docs/src/release/release-0.1.0.rst +8 -0
- data/embulk-docs/src/release/release-0.2.0.rst +16 -0
- data/embulk-docs/src/release/release-0.2.1.rst +19 -0
- data/embulk-docs/src/release/release-0.3.0.rst +34 -0
- data/embulk-docs/src/release/release-0.3.1.rst +11 -0
- data/embulk-docs/src/release/release-0.3.2.rst +15 -0
- data/embulk-docs/src/release/release-0.4.0.rst +74 -0
- data/embulk-standards/build.gradle +0 -1
- data/embulk-standards/src/main/java/org/embulk/standards/CsvFormatterPlugin.java +2 -2
- data/embulk-standards/src/main/java/org/embulk/standards/CsvParserPlugin.java +12 -3
- data/embulk-standards/src/main/java/org/embulk/standards/GzipFileDecoderPlugin.java +2 -2
- data/embulk-standards/src/main/java/org/embulk/standards/LocalFileInputPlugin.java +49 -26
- data/embulk-standards/src/main/java/org/embulk/standards/LocalFileOutputPlugin.java +16 -17
- data/embulk-standards/src/main/java/org/embulk/standards/NullOutputPlugin.java +4 -4
- data/embulk-standards/src/main/java/org/embulk/standards/StandardPluginModule.java +0 -1
- data/embulk-standards/src/main/java/org/embulk/standards/StdoutOutputPlugin.java +5 -5
- data/gradle/wrapper/gradle-wrapper.jar +0 -0
- data/gradle/wrapper/gradle-wrapper.properties +2 -2
- data/lib/embulk/buffer.rb +2 -2
- data/lib/embulk/column.rb +6 -6
- data/lib/embulk/command/embulk_example.rb +1 -1
- data/lib/embulk/command/embulk_new_plugin.rb +87 -0
- data/lib/embulk/command/embulk_run.rb +84 -26
- data/lib/embulk/data/bundle/Gemfile +12 -20
- data/lib/embulk/data/bundle/embulk/{filter_example.rb → filter/example.rb} +3 -3
- data/lib/embulk/data/bundle/embulk/{input_example.rb → input/example.rb} +3 -3
- data/lib/embulk/data/bundle/embulk/{output_example.rb → output/example.rb} +3 -3
- data/lib/embulk/data/new/LICENSE.txt +21 -0
- data/lib/embulk/data/new/README.md.erb +75 -0
- data/lib/embulk/data/new/gitignore.erb +12 -0
- data/lib/embulk/data/new/java/build.gradle.erb +57 -0
- data/lib/embulk/data/new/java/decoder.java.erb +40 -0
- data/lib/embulk/data/new/java/encoder.java.erb +40 -0
- data/lib/embulk/data/new/java/file_input.java.erb +64 -0
- data/lib/embulk/data/new/java/file_output.java.erb +66 -0
- data/lib/embulk/data/new/java/filter.java.erb +47 -0
- data/lib/embulk/data/new/java/formatter.java.erb +45 -0
- data/lib/embulk/data/new/java/gradle/wrapper/gradle-wrapper.jar +0 -0
- data/lib/embulk/data/new/java/gradle/wrapper/gradle-wrapper.properties +6 -0
- data/lib/embulk/data/new/java/gradlew +164 -0
- data/lib/embulk/data/new/java/gradlew.bat +90 -0
- data/lib/embulk/data/new/java/input.java.erb +69 -0
- data/lib/embulk/data/new/java/output.java.erb +65 -0
- data/lib/embulk/data/new/java/parser.java.erb +51 -0
- data/lib/embulk/data/new/java/plugin_loader.rb.erb +3 -0
- data/lib/embulk/data/new/java/test.java.erb +5 -0
- data/lib/embulk/data/new/ruby/Gemfile +2 -0
- data/lib/embulk/data/new/ruby/Rakefile +1 -0
- data/lib/embulk/data/new/ruby/filter.rb.erb +39 -0
- data/lib/embulk/data/new/ruby/gemspec.erb +19 -0
- data/lib/embulk/data/new/ruby/input.rb.erb +47 -0
- data/lib/embulk/data/new/ruby/output.rb.erb +59 -0
- data/lib/embulk/data/package_data.rb +64 -0
- data/lib/embulk/data_source.rb +2 -2
- data/lib/embulk/decoder_plugin.rb +27 -0
- data/lib/embulk/encoder_plugin.rb +27 -0
- data/lib/embulk/error.rb +3 -0
- data/lib/embulk/file_input_plugin.rb +27 -0
- data/lib/embulk/file_output_plugin.rb +27 -0
- data/lib/embulk/filter_plugin.rb +28 -9
- data/lib/embulk/formatter_plugin.rb +105 -0
- data/lib/embulk/guess_csv.rb +10 -1
- data/lib/embulk/guess_plugin.rb +22 -27
- data/lib/embulk/input_plugin.rb +34 -20
- data/lib/embulk/java/bootstrap.rb +5 -0
- data/lib/embulk/java/imports.rb +7 -0
- data/lib/embulk/java_plugin.rb +84 -0
- data/lib/embulk/output_plugin.rb +35 -19
- data/lib/embulk/page.rb +1 -1
- data/lib/embulk/page_builder.rb +1 -1
- data/lib/embulk/parser_plugin.rb +76 -0
- data/lib/embulk/plugin.rb +130 -65
- data/lib/embulk/plugin_registry.rb +19 -8
- data/lib/embulk/schema.rb +4 -4
- data/lib/embulk/version.rb +1 -1
- data/settings.gradle +1 -0
- metadata +123 -90
- data/ChangeLog +0 -46
- data/embulk-cli/pom.xml +0 -94
- data/embulk-core/pom.xml +0 -148
- data/embulk-core/src/main/java/org/embulk/config/NextConfig.java +0 -26
- data/embulk-standards/pom.xml +0 -68
- data/embulk-standards/src/main/java/org/embulk/standards/S3FileInputPlugin.java +0 -250
- data/embulk-standards/src/test/java/org/embulk/standards/TestS3FileInputPlugin.java +0 -43
- data/pom.xml +0 -541
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
plugins {
|
|
2
|
+
id "com.jfrog.bintray" version "1.1"
|
|
3
|
+
id "com.github.jruby-gradle.base" version "0.1.5"
|
|
4
|
+
id "java"
|
|
5
|
+
}
|
|
6
|
+
import com.github.jrubygradle.JRubyExec
|
|
7
|
+
repositories {
|
|
8
|
+
mavenCentral()
|
|
9
|
+
jcenter()
|
|
10
|
+
}
|
|
11
|
+
configurations {
|
|
12
|
+
provided
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
version = "0.1.0"
|
|
16
|
+
|
|
17
|
+
dependencies {
|
|
18
|
+
compile "org.embulk:embulk-core:<%= Embulk::VERSION %>"
|
|
19
|
+
provided "org.embulk:embulk-core:<%= Embulk::VERSION %>"
|
|
20
|
+
// compile "YOUR_JAR_DEPENDENCY_GROUP:YOUR_JAR_DEPENDENCY_MODULE:YOUR_JAR_DEPENDENCY_VERSION"
|
|
21
|
+
testCompile "junit:junit:4.+"
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
task classpath(type: Copy, dependsOn: ["jar"]) {
|
|
25
|
+
doFirst { file("classpath").deleteDir() }
|
|
26
|
+
from (configurations.runtime - configurations.provided + files(jar.archivePath))
|
|
27
|
+
into "classpath"
|
|
28
|
+
}
|
|
29
|
+
clean { delete 'classpath' }
|
|
30
|
+
|
|
31
|
+
task gem(type: JRubyExec, dependsOn: ["build", "gemspec", "classpath"]) {
|
|
32
|
+
jrubyArgs "-rrubygems/gem_runner", "-eGem::GemRunner.new.run(ARGV)", "build"
|
|
33
|
+
script "build/gemspec"
|
|
34
|
+
doLast { ant.move(file: "${project.name}-${project.version}.gem", todir: "pkg") }
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
task gemspec << { file("build/gemspec").write($/
|
|
38
|
+
Gem::Specification.new do |spec|
|
|
39
|
+
spec.name = "${project.name}"
|
|
40
|
+
spec.version = "${project.version}"
|
|
41
|
+
spec.authors = [<%= author.dump %>]
|
|
42
|
+
spec.summary = %[<%= display_name %> <%= display_category %> plugin for Embulk]
|
|
43
|
+
spec.description = %[<%= display_name %> <%= display_category %> plugin is an Embulk plugin <%= description %>]
|
|
44
|
+
spec.email = [<%= email.dump %>]
|
|
45
|
+
spec.licenses = ["MIT"]
|
|
46
|
+
# TODO: spec.homepage = <%= "https://github.com/#{email[/([^@]*)/]}/#{project_name}".dump %>
|
|
47
|
+
|
|
48
|
+
spec.files = `git ls-files`.split("\n") + Dir["classpath/*.jar"]
|
|
49
|
+
spec.test_files = spec.files.grep(%r"^(test|spec)/")
|
|
50
|
+
spec.require_paths = ["lib"]
|
|
51
|
+
|
|
52
|
+
#spec.add_dependency 'YOUR_GEM_DEPENDENCY', ['~> YOUR_GEM_DEPENDENCY_VERSION']
|
|
53
|
+
spec.add_development_dependency 'bundler', ['~> 1.0']
|
|
54
|
+
spec.add_development_dependency 'rake', ['>= 10.0']
|
|
55
|
+
end
|
|
56
|
+
/$)
|
|
57
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
package org.embulk.<%= embulk_category %>;
|
|
2
|
+
|
|
3
|
+
import org.embulk.config.Config;
|
|
4
|
+
import org.embulk.config.ConfigDefault;
|
|
5
|
+
import org.embulk.config.ConfigSource;
|
|
6
|
+
import org.embulk.config.Task;
|
|
7
|
+
import org.embulk.config.TaskSource;
|
|
8
|
+
import org.embulk.spi.DecoderPlugin;
|
|
9
|
+
import org.embulk.spi.FileInput;
|
|
10
|
+
|
|
11
|
+
public class <%= java_class_name %>
|
|
12
|
+
implements DecoderPlugin
|
|
13
|
+
{
|
|
14
|
+
public interface PluginTask
|
|
15
|
+
extends Task
|
|
16
|
+
{
|
|
17
|
+
@Config("property1")
|
|
18
|
+
public String getProperty1();
|
|
19
|
+
|
|
20
|
+
@Config("property2")
|
|
21
|
+
@ConfigDefault("0")
|
|
22
|
+
public int getProperty2();
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
@Override
|
|
26
|
+
public void transaction(ConfigSource config, DecoderPlugin.Control control)
|
|
27
|
+
{
|
|
28
|
+
PluginTask task = config.loadConfig(PluginTask.class);
|
|
29
|
+
|
|
30
|
+
control.run(task.dump());
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
@Override
|
|
34
|
+
public FileInput open(TaskSource taskSource, FileInput input)
|
|
35
|
+
{
|
|
36
|
+
PluginTask task = taskSource.loadTask(PluginTask.class);
|
|
37
|
+
|
|
38
|
+
// TODO
|
|
39
|
+
}
|
|
40
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
package org.embulk.<%= embulk_category %>;
|
|
2
|
+
|
|
3
|
+
import org.embulk.config.Config;
|
|
4
|
+
import org.embulk.config.ConfigDefault;
|
|
5
|
+
import org.embulk.config.ConfigSource;
|
|
6
|
+
import org.embulk.config.Task;
|
|
7
|
+
import org.embulk.config.TaskSource;
|
|
8
|
+
import org.embulk.spi.EncoderPlugin;
|
|
9
|
+
import org.embulk.spi.FileOutput;
|
|
10
|
+
|
|
11
|
+
public class <%= java_class_name %>
|
|
12
|
+
implements EncoderPlugin
|
|
13
|
+
{
|
|
14
|
+
public interface PluginTask
|
|
15
|
+
extends Task
|
|
16
|
+
{
|
|
17
|
+
@Config("property1")
|
|
18
|
+
public String getProperty1();
|
|
19
|
+
|
|
20
|
+
@Config("property2")
|
|
21
|
+
@ConfigDefault("0")
|
|
22
|
+
public int getProperty2();
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
@Override
|
|
26
|
+
public void transaction(ConfigSource config, EncoderPlugin.Control control)
|
|
27
|
+
{
|
|
28
|
+
PluginTask task = config.loadConfig(PluginTask.class);
|
|
29
|
+
|
|
30
|
+
control.run(task.dump());
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
@Override
|
|
34
|
+
public FileOutput open(TaskSource taskSource, FileOutput fileOutput)
|
|
35
|
+
{
|
|
36
|
+
PluginTask task = taskSource.loadTask(PluginTask.class);
|
|
37
|
+
|
|
38
|
+
// TODO
|
|
39
|
+
}
|
|
40
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
package org.embulk.<%= embulk_category %>;
|
|
2
|
+
|
|
3
|
+
import java.util.List;
|
|
4
|
+
import org.embulk.config.CommitReport;
|
|
5
|
+
import org.embulk.config.Config;
|
|
6
|
+
import org.embulk.config.ConfigDefault;
|
|
7
|
+
import org.embulk.config.ConfigDiff;
|
|
8
|
+
import org.embulk.config.ConfigSource;
|
|
9
|
+
import org.embulk.config.Task;
|
|
10
|
+
import org.embulk.config.TaskSource;
|
|
11
|
+
import org.embulk.spi.Exec;
|
|
12
|
+
import org.embulk.spi.FileInputPlugin;
|
|
13
|
+
import org.embulk.spi.TransactionalFileInput;
|
|
14
|
+
|
|
15
|
+
public class <%= java_class_name %>
|
|
16
|
+
implements FileInputPlugin
|
|
17
|
+
{
|
|
18
|
+
public interface PluginTask
|
|
19
|
+
extends Task
|
|
20
|
+
{
|
|
21
|
+
@Config("property1")
|
|
22
|
+
public String getProperty1();
|
|
23
|
+
|
|
24
|
+
@Config("property2")
|
|
25
|
+
@ConfigDefault("0")
|
|
26
|
+
public int getProperty2();
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
@Override
|
|
30
|
+
public ConfigDiff transaction(ConfigSource config, FileInputPlugin.Control control)
|
|
31
|
+
{
|
|
32
|
+
PluginTask task = config.loadConfig(PluginTask.class);
|
|
33
|
+
|
|
34
|
+
// processorCount is usually number of input files
|
|
35
|
+
int processorCount = 1; // number of run() method calls
|
|
36
|
+
|
|
37
|
+
return resume(task.dump(), processorCount, control);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
@Override
|
|
41
|
+
public ConfigDiff resume(TaskSource taskSource,
|
|
42
|
+
int processorCount,
|
|
43
|
+
FileInputPlugin.Control control)
|
|
44
|
+
{
|
|
45
|
+
control.run(taskSource, processorCount);
|
|
46
|
+
return Exec.newConfigDiff();
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
@Override
|
|
50
|
+
public void cleanup(TaskSource taskSource,
|
|
51
|
+
int processorCount,
|
|
52
|
+
List<CommitReport> successCommitReports)
|
|
53
|
+
{
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
@Override
|
|
57
|
+
public TransactionalFileInput open(TaskSource taskSource, int processorIndex)
|
|
58
|
+
{
|
|
59
|
+
PluginTask task = taskSource.loadTask(PluginTask.class);
|
|
60
|
+
|
|
61
|
+
// TODO
|
|
62
|
+
throw new UnsupportedOperationException("The 'open' method needs to be implemented");
|
|
63
|
+
}
|
|
64
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
package org.embulk.<%= embulk_category %>;
|
|
2
|
+
|
|
3
|
+
import java.util.List;
|
|
4
|
+
import org.embulk.config.CommitReport;
|
|
5
|
+
import org.embulk.config.Config;
|
|
6
|
+
import org.embulk.config.ConfigDefault;
|
|
7
|
+
import org.embulk.config.ConfigDiff;
|
|
8
|
+
import org.embulk.config.ConfigSource;
|
|
9
|
+
import org.embulk.config.Task;
|
|
10
|
+
import org.embulk.config.TaskSource;
|
|
11
|
+
import org.embulk.spi.Exec;
|
|
12
|
+
import org.embulk.spi.FileOutputPlugin;
|
|
13
|
+
import org.embulk.spi.TransactionalFileOutput;
|
|
14
|
+
|
|
15
|
+
public class <%= java_class_name %>
|
|
16
|
+
implements FileOutputPlugin
|
|
17
|
+
{
|
|
18
|
+
public interface PluginTask
|
|
19
|
+
extends Task
|
|
20
|
+
{
|
|
21
|
+
@Config("property1")
|
|
22
|
+
public String getProperty1();
|
|
23
|
+
|
|
24
|
+
@Config("property2")
|
|
25
|
+
@ConfigDefault("0")
|
|
26
|
+
public int getProperty2();
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
@Override
|
|
30
|
+
public ConfigDiff transaction(ConfigSource config, int processorCount,
|
|
31
|
+
FileOutputPlugin.Control control)
|
|
32
|
+
{
|
|
33
|
+
PluginTask task = config.loadConfig(PluginTask.class);
|
|
34
|
+
|
|
35
|
+
// retryable (idempotent) output:
|
|
36
|
+
// return resume(task.dump(), processorCount, control);
|
|
37
|
+
|
|
38
|
+
// non-retryable (non-idempotent) output:
|
|
39
|
+
control.run(task.dump());
|
|
40
|
+
return Exec.newConfigDiff();
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
@Override
|
|
44
|
+
public ConfigDiff resume(TaskSource taskSource,
|
|
45
|
+
int processorCount,
|
|
46
|
+
FileOutputPlugin.Control control)
|
|
47
|
+
{
|
|
48
|
+
throw new UnsupportedOperationException("<%= name %> output plugin does not support resuming");
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
@Override
|
|
52
|
+
public void cleanup(TaskSource taskSource,
|
|
53
|
+
int processorCount,
|
|
54
|
+
List<CommitReport> successCommitReports)
|
|
55
|
+
{
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
@Override
|
|
59
|
+
public TransactionalFileOutput open(TaskSource taskSource, final int processorIndex)
|
|
60
|
+
{
|
|
61
|
+
PluginTask task = taskSource.loadTask(PluginTask.class);
|
|
62
|
+
|
|
63
|
+
// TODO
|
|
64
|
+
throw new UnsupportedOperationException("The 'open' method needs to be implemented");
|
|
65
|
+
}
|
|
66
|
+
}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
package org.embulk.<%= embulk_category %>;
|
|
2
|
+
|
|
3
|
+
import org.embulk.config.Config;
|
|
4
|
+
import org.embulk.config.ConfigDefault;
|
|
5
|
+
import org.embulk.config.ConfigDiff;
|
|
6
|
+
import org.embulk.config.ConfigSource;
|
|
7
|
+
import org.embulk.config.Task;
|
|
8
|
+
import org.embulk.config.TaskSource;
|
|
9
|
+
import org.embulk.spi.Column;
|
|
10
|
+
import org.embulk.spi.FilterPlugin;
|
|
11
|
+
import org.embulk.spi.PageOutput;
|
|
12
|
+
import org.embulk.spi.Schema;
|
|
13
|
+
|
|
14
|
+
public class <%= java_class_name %>
|
|
15
|
+
implements FilterPlugin
|
|
16
|
+
{
|
|
17
|
+
public interface PluginTask
|
|
18
|
+
extends Task
|
|
19
|
+
{
|
|
20
|
+
@Config("property1")
|
|
21
|
+
public String getProperty1();
|
|
22
|
+
|
|
23
|
+
@Config("property2")
|
|
24
|
+
@ConfigDefault("0")
|
|
25
|
+
public int getProperty2();
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
@Override
|
|
29
|
+
public void transaction(ConfigSource config, Schema inputSchema,
|
|
30
|
+
FilterPlugin.Control control)
|
|
31
|
+
{
|
|
32
|
+
PluginTask task = config.loadConfig(PluginTask.class);
|
|
33
|
+
|
|
34
|
+
Schema outputSchema = inputSchema;
|
|
35
|
+
|
|
36
|
+
control.run(task.dump(), outputSchema);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
@Override
|
|
40
|
+
public PageOutput open(TaskSource taskSource, Schema inputSchema,
|
|
41
|
+
Schema outputSchema, PageOutput output)
|
|
42
|
+
{
|
|
43
|
+
PluginTask task = taskSource.loadTask(PluginTask.class);
|
|
44
|
+
|
|
45
|
+
// TODO
|
|
46
|
+
}
|
|
47
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
package org.embulk.<%= embulk_category %>;
|
|
2
|
+
|
|
3
|
+
import org.embulk.config.Config;
|
|
4
|
+
import org.embulk.config.ConfigDefault;
|
|
5
|
+
import org.embulk.config.ConfigDiff;
|
|
6
|
+
import org.embulk.config.ConfigSource;
|
|
7
|
+
import org.embulk.config.Task;
|
|
8
|
+
import org.embulk.config.TaskSource;
|
|
9
|
+
import org.embulk.spi.FormatterPlugin;
|
|
10
|
+
import org.embulk.spi.PageOutput;
|
|
11
|
+
import org.embulk.spi.FileOutput;
|
|
12
|
+
import org.embulk.spi.Schema;
|
|
13
|
+
|
|
14
|
+
public class <%= java_class_name %>
|
|
15
|
+
implements FormatterPlugin
|
|
16
|
+
{
|
|
17
|
+
public interface PluginTask
|
|
18
|
+
extends Task
|
|
19
|
+
{
|
|
20
|
+
@Config("property1")
|
|
21
|
+
public String getProperty1();
|
|
22
|
+
|
|
23
|
+
@Config("property2")
|
|
24
|
+
@ConfigDefault("0")
|
|
25
|
+
public int getProperty2();
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
@Override
|
|
29
|
+
public void transaction(ConfigSource config, Schema schema,
|
|
30
|
+
FormatterPlugin.Control control)
|
|
31
|
+
{
|
|
32
|
+
PluginTask task = config.loadConfig(PluginTask.class);
|
|
33
|
+
|
|
34
|
+
control.run(task.dump());
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
@Override
|
|
38
|
+
public PageOutput open(TaskSource taskSource, Schema schema,
|
|
39
|
+
FileOutput output)
|
|
40
|
+
{
|
|
41
|
+
PluginTask task = taskSource.loadTask(PluginTask.class);
|
|
42
|
+
|
|
43
|
+
// TODO
|
|
44
|
+
}
|
|
45
|
+
}
|
|
Binary file
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
|
|
3
|
+
##############################################################################
|
|
4
|
+
##
|
|
5
|
+
## Gradle start up script for UN*X
|
|
6
|
+
##
|
|
7
|
+
##############################################################################
|
|
8
|
+
|
|
9
|
+
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
|
10
|
+
DEFAULT_JVM_OPTS=""
|
|
11
|
+
|
|
12
|
+
APP_NAME="Gradle"
|
|
13
|
+
APP_BASE_NAME=`basename "$0"`
|
|
14
|
+
|
|
15
|
+
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
|
16
|
+
MAX_FD="maximum"
|
|
17
|
+
|
|
18
|
+
warn ( ) {
|
|
19
|
+
echo "$*"
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
die ( ) {
|
|
23
|
+
echo
|
|
24
|
+
echo "$*"
|
|
25
|
+
echo
|
|
26
|
+
exit 1
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
# OS specific support (must be 'true' or 'false').
|
|
30
|
+
cygwin=false
|
|
31
|
+
msys=false
|
|
32
|
+
darwin=false
|
|
33
|
+
case "`uname`" in
|
|
34
|
+
CYGWIN* )
|
|
35
|
+
cygwin=true
|
|
36
|
+
;;
|
|
37
|
+
Darwin* )
|
|
38
|
+
darwin=true
|
|
39
|
+
;;
|
|
40
|
+
MINGW* )
|
|
41
|
+
msys=true
|
|
42
|
+
;;
|
|
43
|
+
esac
|
|
44
|
+
|
|
45
|
+
# For Cygwin, ensure paths are in UNIX format before anything is touched.
|
|
46
|
+
if $cygwin ; then
|
|
47
|
+
[ -n "$JAVA_HOME" ] && JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
|
|
48
|
+
fi
|
|
49
|
+
|
|
50
|
+
# Attempt to set APP_HOME
|
|
51
|
+
# Resolve links: $0 may be a link
|
|
52
|
+
PRG="$0"
|
|
53
|
+
# Need this for relative symlinks.
|
|
54
|
+
while [ -h "$PRG" ] ; do
|
|
55
|
+
ls=`ls -ld "$PRG"`
|
|
56
|
+
link=`expr "$ls" : '.*-> \(.*\)$'`
|
|
57
|
+
if expr "$link" : '/.*' > /dev/null; then
|
|
58
|
+
PRG="$link"
|
|
59
|
+
else
|
|
60
|
+
PRG=`dirname "$PRG"`"/$link"
|
|
61
|
+
fi
|
|
62
|
+
done
|
|
63
|
+
SAVED="`pwd`"
|
|
64
|
+
cd "`dirname \"$PRG\"`/" >&-
|
|
65
|
+
APP_HOME="`pwd -P`"
|
|
66
|
+
cd "$SAVED" >&-
|
|
67
|
+
|
|
68
|
+
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
|
|
69
|
+
|
|
70
|
+
# Determine the Java command to use to start the JVM.
|
|
71
|
+
if [ -n "$JAVA_HOME" ] ; then
|
|
72
|
+
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
|
73
|
+
# IBM's JDK on AIX uses strange locations for the executables
|
|
74
|
+
JAVACMD="$JAVA_HOME/jre/sh/java"
|
|
75
|
+
else
|
|
76
|
+
JAVACMD="$JAVA_HOME/bin/java"
|
|
77
|
+
fi
|
|
78
|
+
if [ ! -x "$JAVACMD" ] ; then
|
|
79
|
+
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
|
|
80
|
+
|
|
81
|
+
Please set the JAVA_HOME variable in your environment to match the
|
|
82
|
+
location of your Java installation."
|
|
83
|
+
fi
|
|
84
|
+
else
|
|
85
|
+
JAVACMD="java"
|
|
86
|
+
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
|
87
|
+
|
|
88
|
+
Please set the JAVA_HOME variable in your environment to match the
|
|
89
|
+
location of your Java installation."
|
|
90
|
+
fi
|
|
91
|
+
|
|
92
|
+
# Increase the maximum file descriptors if we can.
|
|
93
|
+
if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then
|
|
94
|
+
MAX_FD_LIMIT=`ulimit -H -n`
|
|
95
|
+
if [ $? -eq 0 ] ; then
|
|
96
|
+
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
|
|
97
|
+
MAX_FD="$MAX_FD_LIMIT"
|
|
98
|
+
fi
|
|
99
|
+
ulimit -n $MAX_FD
|
|
100
|
+
if [ $? -ne 0 ] ; then
|
|
101
|
+
warn "Could not set maximum file descriptor limit: $MAX_FD"
|
|
102
|
+
fi
|
|
103
|
+
else
|
|
104
|
+
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
|
|
105
|
+
fi
|
|
106
|
+
fi
|
|
107
|
+
|
|
108
|
+
# For Darwin, add options to specify how the application appears in the dock
|
|
109
|
+
if $darwin; then
|
|
110
|
+
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
|
|
111
|
+
fi
|
|
112
|
+
|
|
113
|
+
# For Cygwin, switch paths to Windows format before running java
|
|
114
|
+
if $cygwin ; then
|
|
115
|
+
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
|
|
116
|
+
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
|
|
117
|
+
|
|
118
|
+
# We build the pattern for arguments to be converted via cygpath
|
|
119
|
+
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
|
|
120
|
+
SEP=""
|
|
121
|
+
for dir in $ROOTDIRSRAW ; do
|
|
122
|
+
ROOTDIRS="$ROOTDIRS$SEP$dir"
|
|
123
|
+
SEP="|"
|
|
124
|
+
done
|
|
125
|
+
OURCYGPATTERN="(^($ROOTDIRS))"
|
|
126
|
+
# Add a user-defined pattern to the cygpath arguments
|
|
127
|
+
if [ "$GRADLE_CYGPATTERN" != "" ] ; then
|
|
128
|
+
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
|
|
129
|
+
fi
|
|
130
|
+
# Now convert the arguments - kludge to limit ourselves to /bin/sh
|
|
131
|
+
i=0
|
|
132
|
+
for arg in "$@" ; do
|
|
133
|
+
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
|
|
134
|
+
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
|
|
135
|
+
|
|
136
|
+
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
|
|
137
|
+
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
|
|
138
|
+
else
|
|
139
|
+
eval `echo args$i`="\"$arg\""
|
|
140
|
+
fi
|
|
141
|
+
i=$((i+1))
|
|
142
|
+
done
|
|
143
|
+
case $i in
|
|
144
|
+
(0) set -- ;;
|
|
145
|
+
(1) set -- "$args0" ;;
|
|
146
|
+
(2) set -- "$args0" "$args1" ;;
|
|
147
|
+
(3) set -- "$args0" "$args1" "$args2" ;;
|
|
148
|
+
(4) set -- "$args0" "$args1" "$args2" "$args3" ;;
|
|
149
|
+
(5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
|
|
150
|
+
(6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
|
|
151
|
+
(7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
|
|
152
|
+
(8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
|
|
153
|
+
(9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
|
|
154
|
+
esac
|
|
155
|
+
fi
|
|
156
|
+
|
|
157
|
+
# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules
|
|
158
|
+
function splitJvmOpts() {
|
|
159
|
+
JVM_OPTS=("$@")
|
|
160
|
+
}
|
|
161
|
+
eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS
|
|
162
|
+
JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME"
|
|
163
|
+
|
|
164
|
+
exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@"
|