public class TextDelimited extends cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
fields
is set to either Fields.ALL
or Fields.UNKNOWN
and
skipHeader
or hasHeader
is true
, the field names will be retrieved from the header of the
file and used during planning. The header will parsed with the same rules as the body of the file.
By default headers are not skipped.
TextDelimited may also be used to write a "header" in a file. The fields names for the header are taken directly
from the declared fields. Or if the declared fields are Fields.ALL
or Fields.UNKNOWN
, the
resolved field names will be used, if any.
By default headers are not written.
If hasHeaders
is set to true
on a constructor, both skipHeader
and writeHeader
will
be set to true
.
By default this Scheme
is both strict
and safe
.
Strict meaning if a line of text does not parse into the expected number of fields, this class will throw a
TapException
. If strict is false
, then Tuple
will be returned with null
values
for the missing fields.
Safe meaning if a field cannot be coerced into an expected type, a null
will be used for the value.
If safe is false
, a TapException
will be thrown.
Also by default, quote
strings are not searched for to improve processing speed. If a file is
COMMA delimited but may have COMMA's in a value, the whole value should be surrounded by the quote string, typically
double quotes (").
Note all empty fields in a line will be returned as null
unless coerced into a new type.
This Scheme may source/sink Fields.ALL
, when given on the constructor the new instance will automatically
default to strict == false as the number of fields parsed are arbitrary or unknown. A type array may not be given
either, so all values will be returned as Strings.
By default, all text is encoded/decoded as UTF-8. This can be changed via the charsetName
constructor
argument.
To override field and line parsing behaviors, sub-class DelimitedParser
or provide a
FieldTypeResolver
implementation.
Note that there should be no expectation that TextDelimited, or specifically DelimitedParser
, can handle
all delimited and quoted combinations reliably. Attempting to do so would impair its performance and maintainability.
Further, it can be safely said any corrupted files will not be supported for obvious reasons. Corrupted files may
result in exceptions or could cause edge cases in the underlying java regular expression engine.
A large part of Cascading was designed to help users cleans data. Thus the recommendation is to create Flows that
are responsible for cleansing large data-sets when faced with the problem
DelimitedParser maybe sub-classed and extended if necessary.TextLine
,
Serialized FormModifier and Type | Field and Description |
---|---|
static java.lang.String |
DEFAULT_CHARSET |
Constructor and Description |
---|
TextDelimited()
Constructor TextDelimited creates a new TextDelimited instance sourcing
Fields.UNKNOWN , sinking
Fields.ALL and using TAB as the default delimiter. |
TextDelimited(boolean hasHeader,
cascading.scheme.util.DelimitedParser delimitedParser)
Constructor TextDelimited creates a new TextDelimited instance sourcing
Fields.UNKNOWN , sinking
Fields.ALL and using the given delimitedParser instance for parsing. |
TextDelimited(boolean hasHeader,
java.lang.String delimiter)
Constructor TextDelimited creates a new TextDelimited instance sourcing
Fields.UNKNOWN , sinking
Fields.ALL and using TAB as the default delimiter. |
TextDelimited(boolean hasHeader,
java.lang.String delimiter,
java.lang.String quote)
Constructor TextDelimited creates a new TextDelimited instance sourcing
Fields.UNKNOWN , sinking
Fields.ALL and using TAB as the default delimiter. |
TextDelimited(cascading.scheme.util.DelimitedParser delimitedParser)
Constructor TextDelimited creates a new TextDelimited instance sourcing
Fields.UNKNOWN , sinking
Fields.ALL and using the given delimitedParser instance for parsing. |
TextDelimited(cascading.tuple.Fields fields)
Constructor TextDelimited creates a new TextDelimited instance with TAB as the default delimiter.
|
TextDelimited(cascading.tuple.Fields fields,
boolean skipHeader,
boolean writeHeader,
cascading.scheme.util.DelimitedParser delimitedParser)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean skipHeader,
boolean writeHeader,
java.lang.String delimiter)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean skipHeader,
boolean writeHeader,
java.lang.String delimiter,
boolean strict,
java.lang.String quote,
java.lang.Class[] types,
boolean safe)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean skipHeader,
boolean writeHeader,
java.lang.String delimiter,
boolean strict,
java.lang.String quote,
java.lang.Class[] types,
boolean safe,
java.lang.String charsetName)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean skipHeader,
boolean writeHeader,
java.lang.String delimiter,
java.lang.Class[] types)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean skipHeader,
boolean writeHeader,
java.lang.String charsetName,
cascading.scheme.util.DelimitedParser delimitedParser)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean skipHeader,
boolean writeHeader,
java.lang.String delimiter,
java.lang.String quote,
java.lang.Class[] types)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean skipHeader,
boolean writeHeader,
java.lang.String delimiter,
java.lang.String quote,
java.lang.Class[] types,
boolean safe)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean hasHeader,
cascading.scheme.util.DelimitedParser delimitedParser)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean hasHeader,
java.lang.String delimiter)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean hasHeader,
java.lang.String delimiter,
java.lang.Class[] types)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean hasHeader,
java.lang.String delimiter,
java.lang.String quote)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean hasHeader,
java.lang.String delimiter,
java.lang.String quote,
java.lang.Class[] types)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean hasHeader,
java.lang.String delimiter,
java.lang.String quote,
java.lang.Class[] types,
boolean safe)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean hasHeader,
java.lang.String delimiter,
java.lang.String quote,
java.lang.Class[] types,
boolean safe,
java.lang.String charsetName)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
boolean hasHeader,
java.lang.String delimiter,
java.lang.String quote,
java.lang.String charsetName)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
java.lang.String delimiter)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
java.lang.String delimiter,
java.lang.Class[] types)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
java.lang.String delimiter,
java.lang.String quote)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
java.lang.String delimiter,
java.lang.String quote,
java.lang.Class[] types)
Constructor TextDelimited creates a new TextDelimited instance.
|
TextDelimited(cascading.tuple.Fields fields,
java.lang.String delimiter,
java.lang.String quote,
java.lang.Class[] types,
boolean safe)
Constructor TextDelimited creates a new TextDelimited instance.
|
Modifier and Type | Method and Description |
---|---|
java.io.LineNumberReader |
createInput(java.io.InputStream inputStream) |
java.io.PrintWriter |
createOutput(java.io.OutputStream outputStream) |
java.lang.String |
getCharsetName() |
java.lang.String |
getDelimiter()
Method getDelimiter returns the delimiter used to parse fields from the current line of text.
|
java.lang.String |
getQuote()
Method getQuote returns the quote string, if any, used to encapsulate each field in a line to delimited text.
|
boolean |
isSymmetrical() |
void |
presentSinkFields(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess,
cascading.tap.Tap tap,
cascading.tuple.Fields fields) |
void |
presentSourceFields(cascading.flow.FlowProcess<? extends java.util.Properties> process,
cascading.tap.Tap tap,
cascading.tuple.Fields fields) |
cascading.tuple.Fields |
retrieveSourceFields(cascading.flow.FlowProcess<? extends java.util.Properties> process,
cascading.tap.Tap tap) |
void |
setSinkFields(cascading.tuple.Fields sinkFields) |
void |
setSourceFields(cascading.tuple.Fields sourceFields) |
void |
sink(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess,
cascading.scheme.SinkCall<java.io.PrintWriter,java.io.OutputStream> sinkCall) |
void |
sinkCleanup(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess,
cascading.scheme.SinkCall<java.io.PrintWriter,java.io.OutputStream> sinkCall) |
void |
sinkConfInit(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess,
cascading.tap.Tap<java.util.Properties,java.io.InputStream,java.io.OutputStream> tap,
java.util.Properties conf) |
void |
sinkPrepare(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess,
cascading.scheme.SinkCall<java.io.PrintWriter,java.io.OutputStream> sinkCall) |
boolean |
source(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess,
cascading.scheme.SourceCall<java.io.LineNumberReader,java.io.InputStream> sourceCall) |
void |
sourceCleanup(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess,
cascading.scheme.SourceCall<java.io.LineNumberReader,java.io.InputStream> sourceCall) |
void |
sourceConfInit(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess,
cascading.tap.Tap<java.util.Properties,java.io.InputStream,java.io.OutputStream> tap,
java.util.Properties conf) |
void |
sourcePrepare(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess,
cascading.scheme.SourceCall<java.io.LineNumberReader,java.io.InputStream> sourceCall) |
void |
sourceRePrepare(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess,
cascading.scheme.SourceCall<java.io.LineNumberReader,java.io.InputStream> sourceCall) |
public static final java.lang.String DEFAULT_CHARSET
public TextDelimited()
Fields.UNKNOWN
, sinking
Fields.ALL
and using TAB as the default delimiter.
Use this constructor if the source and sink fields will be resolved during planning, for example, when using
with a Checkpoint
Tap.@ConstructorProperties(value={"hasHeader","delimiter"}) public TextDelimited(boolean hasHeader, java.lang.String delimiter)
Fields.UNKNOWN
, sinking
Fields.ALL
and using TAB as the default delimiter.
Use this constructor if the source and sink fields will be resolved during planning, for example, when using
with a Checkpoint
Tap.hasHeader
- delimiter
- @ConstructorProperties(value={"hasHeader","delimiter","quote"}) public TextDelimited(boolean hasHeader, java.lang.String delimiter, java.lang.String quote)
Fields.UNKNOWN
, sinking
Fields.ALL
and using TAB as the default delimiter.
Use this constructor if the source and sink fields will be resolved during planning, for example, when using
with a Checkpoint
Tap.hasHeader
- delimiter
- quote
- @ConstructorProperties(value={"hasHeader","delimitedParser"}) public TextDelimited(boolean hasHeader, cascading.scheme.util.DelimitedParser delimitedParser)
Fields.UNKNOWN
, sinking
Fields.ALL
and using the given delimitedParser instance for parsing.
Use this constructor if the source and sink fields will be resolved during planning, for example, when using
with a Checkpoint
Tap.hasHeader
- delimitedParser
- @ConstructorProperties(value="delimitedParser") public TextDelimited(cascading.scheme.util.DelimitedParser delimitedParser)
Fields.UNKNOWN
, sinking
Fields.ALL
and using the given delimitedParser instance for parsing.
Use this constructor if the source and sink fields will be resolved during planning, for example, when using
with a Checkpoint
Tap.
This constructor will set skipHeader
and writeHeader
values to true.delimitedParser
- @ConstructorProperties(value="fields") public TextDelimited(cascading.tuple.Fields fields)
fields
- of type Fields@ConstructorProperties(value={"fields","delimiter"}) public TextDelimited(cascading.tuple.Fields fields, java.lang.String delimiter)
fields
- of type Fieldsdelimiter
- of type String@ConstructorProperties(value={"fields","hasHeader","delimiter"}) public TextDelimited(cascading.tuple.Fields fields, boolean hasHeader, java.lang.String delimiter)
fields
- of type FieldshasHeader
- of type booleandelimiter
- of type String@ConstructorProperties(value={"fields","skipHeader","writeHeader","delimiter"}) public TextDelimited(cascading.tuple.Fields fields, boolean skipHeader, boolean writeHeader, java.lang.String delimiter)
fields
- of type FieldsskipHeader
- of type booleandelimiter
- of type String@ConstructorProperties(value={"fields","delimiter","types"}) public TextDelimited(cascading.tuple.Fields fields, java.lang.String delimiter, java.lang.Class[] types)
fields
- of type Fieldsdelimiter
- of type Stringtypes
- of type Class[]@ConstructorProperties(value={"fields","hasHeader","delimiter","types"}) public TextDelimited(cascading.tuple.Fields fields, boolean hasHeader, java.lang.String delimiter, java.lang.Class[] types)
fields
- of type FieldshasHeader
- of type booleandelimiter
- of type Stringtypes
- of type Class[]@ConstructorProperties(value={"fields","skipHeader","writeHeader","delimiter","types"}) public TextDelimited(cascading.tuple.Fields fields, boolean skipHeader, boolean writeHeader, java.lang.String delimiter, java.lang.Class[] types)
fields
- of type FieldsskipHeader
- of type booleanwriteHeader
- of type booleandelimiter
- of type Stringtypes
- of type Class[]@ConstructorProperties(value={"fields","delimiter","quote","types"}) public TextDelimited(cascading.tuple.Fields fields, java.lang.String delimiter, java.lang.String quote, java.lang.Class[] types)
fields
- of type Fieldsdelimiter
- of type Stringquote
- of type Stringtypes
- of type Class[]@ConstructorProperties(value={"fields","hasHeader","delimiter","quote","types"}) public TextDelimited(cascading.tuple.Fields fields, boolean hasHeader, java.lang.String delimiter, java.lang.String quote, java.lang.Class[] types)
fields
- of type FieldshasHeader
- of type booleandelimiter
- of type Stringquote
- of type Stringtypes
- of type Class[]@ConstructorProperties(value={"fields","skipHeader","writeHeader","delimiter","quote","types"}) public TextDelimited(cascading.tuple.Fields fields, boolean skipHeader, boolean writeHeader, java.lang.String delimiter, java.lang.String quote, java.lang.Class[] types)
fields
- of type FieldsskipHeader
- of type booleanwriteHeader
- of type booleandelimiter
- of type Stringquote
- of type Stringtypes
- of type Class[]@ConstructorProperties(value={"fields","delimiter","quote","types","safe"}) public TextDelimited(cascading.tuple.Fields fields, java.lang.String delimiter, java.lang.String quote, java.lang.Class[] types, boolean safe)
fields
- of type Fieldsdelimiter
- of type Stringquote
- of type Stringtypes
- of type Class[]safe
- of type boolean@ConstructorProperties(value={"fields","hasHeader","delimiter","quote","types","safe"}) public TextDelimited(cascading.tuple.Fields fields, boolean hasHeader, java.lang.String delimiter, java.lang.String quote, java.lang.Class[] types, boolean safe)
fields
- of type FieldshasHeader
- of type booleandelimiter
- of type Stringquote
- of type Stringtypes
- of type Class[]safe
- of type boolean@ConstructorProperties(value={"fields","hasHeader","delimiter","quote","types","safe","charsetName"}) public TextDelimited(cascading.tuple.Fields fields, boolean hasHeader, java.lang.String delimiter, java.lang.String quote, java.lang.Class[] types, boolean safe, java.lang.String charsetName)
fields
- of type FieldshasHeader
- of type booleandelimiter
- of type Stringquote
- of type Stringtypes
- of type Class[]safe
- of type booleancharsetName
- of type String@ConstructorProperties(value={"fields","skipHeader","writeHeader","delimiter","quote","types","safe"}) public TextDelimited(cascading.tuple.Fields fields, boolean skipHeader, boolean writeHeader, java.lang.String delimiter, java.lang.String quote, java.lang.Class[] types, boolean safe)
fields
- of type FieldsskipHeader
- of type booleanwriteHeader
- of type booleandelimiter
- of type Stringquote
- of type Stringtypes
- of type Class[]safe
- of type boolean@ConstructorProperties(value={"fields","delimiter","quote"}) public TextDelimited(cascading.tuple.Fields fields, java.lang.String delimiter, java.lang.String quote)
fields
- of type Fieldsdelimiter
- of type Stringquote
- of type String@ConstructorProperties(value={"fields","hasHeader","delimiter","quote"}) public TextDelimited(cascading.tuple.Fields fields, boolean hasHeader, java.lang.String delimiter, java.lang.String quote)
fields
- of type FieldshasHeader
- of type booleandelimiter
- of type Stringquote
- of type String@ConstructorProperties(value={"fields","hasHeader","delimiter","quote","charsetName"}) public TextDelimited(cascading.tuple.Fields fields, boolean hasHeader, java.lang.String delimiter, java.lang.String quote, java.lang.String charsetName)
fields
- of type FieldshasHeader
- of type booleandelimiter
- of type Stringquote
- of type StringcharsetName
- of type String@ConstructorProperties(value={"fields","skipHeader","writeHeader","delimiter","strict","quote","types","safe"}) public TextDelimited(cascading.tuple.Fields fields, boolean skipHeader, boolean writeHeader, java.lang.String delimiter, boolean strict, java.lang.String quote, java.lang.Class[] types, boolean safe)
fields
- of type FieldsskipHeader
- of type booleanwriteHeader
- of type booleandelimiter
- of type Stringstrict
- of type booleanquote
- of type Stringtypes
- of type Class[]safe
- of type boolean@ConstructorProperties(value={"fields","skipHeader","writeHeader","delimiter","strict","quote","types","safe","charsetName"}) public TextDelimited(cascading.tuple.Fields fields, boolean skipHeader, boolean writeHeader, java.lang.String delimiter, boolean strict, java.lang.String quote, java.lang.Class[] types, boolean safe, java.lang.String charsetName)
fields
- of type FieldsskipHeader
- of type booleanwriteHeader
- of type booleandelimiter
- of type Stringstrict
- of type booleanquote
- of type Stringtypes
- of type Class[]safe
- of type booleancharsetName
- of type String@ConstructorProperties(value={"fields","skipHeader","writeHeader","delimitedParser"}) public TextDelimited(cascading.tuple.Fields fields, boolean skipHeader, boolean writeHeader, cascading.scheme.util.DelimitedParser delimitedParser)
fields
- of type FieldswriteHeader
- of type booleandelimitedParser
- of type DelimitedParser@ConstructorProperties(value={"fields","hasHeader","delimitedParser"}) public TextDelimited(cascading.tuple.Fields fields, boolean hasHeader, cascading.scheme.util.DelimitedParser delimitedParser)
fields
- of type FieldshasHeader
- of type booleandelimitedParser
- of type DelimitedParser@ConstructorProperties(value={"fields","skipHeader","writeHeader","charsetName","delimitedParser"}) public TextDelimited(cascading.tuple.Fields fields, boolean skipHeader, boolean writeHeader, java.lang.String charsetName, cascading.scheme.util.DelimitedParser delimitedParser)
fields
- of type FieldswriteHeader
- of type booleancharsetName
- of type StringdelimitedParser
- of type DelimitedParserpublic java.lang.String getCharsetName()
public java.lang.String getDelimiter()
public java.lang.String getQuote()
public java.io.LineNumberReader createInput(java.io.InputStream inputStream)
public java.io.PrintWriter createOutput(java.io.OutputStream outputStream)
public void setSinkFields(cascading.tuple.Fields sinkFields)
setSinkFields
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
public void setSourceFields(cascading.tuple.Fields sourceFields)
setSourceFields
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
public boolean isSymmetrical()
isSymmetrical
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
public cascading.tuple.Fields retrieveSourceFields(cascading.flow.FlowProcess<? extends java.util.Properties> process, cascading.tap.Tap tap)
retrieveSourceFields
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
public void presentSourceFields(cascading.flow.FlowProcess<? extends java.util.Properties> process, cascading.tap.Tap tap, cascading.tuple.Fields fields)
presentSourceFields
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
public void presentSinkFields(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess, cascading.tap.Tap tap, cascading.tuple.Fields fields)
presentSinkFields
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
public void sourceConfInit(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess, cascading.tap.Tap<java.util.Properties,java.io.InputStream,java.io.OutputStream> tap, java.util.Properties conf)
sourceConfInit
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
public void sourcePrepare(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess, cascading.scheme.SourceCall<java.io.LineNumberReader,java.io.InputStream> sourceCall) throws java.io.IOException
sourcePrepare
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
java.io.IOException
public void sourceRePrepare(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess, cascading.scheme.SourceCall<java.io.LineNumberReader,java.io.InputStream> sourceCall) throws java.io.IOException
sourceRePrepare
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
java.io.IOException
public boolean source(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess, cascading.scheme.SourceCall<java.io.LineNumberReader,java.io.InputStream> sourceCall) throws java.io.IOException
source
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
java.io.IOException
public void sourceCleanup(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess, cascading.scheme.SourceCall<java.io.LineNumberReader,java.io.InputStream> sourceCall) throws java.io.IOException
sourceCleanup
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
java.io.IOException
public void sinkConfInit(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess, cascading.tap.Tap<java.util.Properties,java.io.InputStream,java.io.OutputStream> tap, java.util.Properties conf)
sinkConfInit
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
public void sinkPrepare(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess, cascading.scheme.SinkCall<java.io.PrintWriter,java.io.OutputStream> sinkCall)
sinkPrepare
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
public void sink(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess, cascading.scheme.SinkCall<java.io.PrintWriter,java.io.OutputStream> sinkCall) throws java.io.IOException
sink
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
java.io.IOException
public void sinkCleanup(cascading.flow.FlowProcess<? extends java.util.Properties> flowProcess, cascading.scheme.SinkCall<java.io.PrintWriter,java.io.OutputStream> sinkCall)
sinkCleanup
in class cascading.scheme.Scheme<java.util.Properties,java.io.InputStream,java.io.OutputStream,java.io.LineNumberReader,java.io.PrintWriter>
Copyright © 2007-2015 Xplenty, Inc. All Rights Reserved.