@Override
  public void close() throws IOException {
    super.close();

    // Let's mark row as closed, if we had any...
    finishRow();
    _writer.close(
        _ioContext.isResourceManaged() || isEnabled(JsonGenerator.Feature.AUTO_CLOSE_TARGET));
  }
 @Override
 public void setSchema(FormatSchema schema) {
   if (schema instanceof CsvSchema) {
     if (_schema != schema) {
       _schema = (CsvSchema) schema;
       _writer = _writer.withSchema(_schema);
     }
   } else {
     super.setSchema(schema);
   }
 }
Beispiel #3
0
  @Override
  public void close() throws IOException {
    super.close();

    /* 05-Dec-2008, tatu: To add [JACKSON-27], need to close open
     *   scopes.
     */
    // First: let's see that we still have buffers...
    if (_outputBuffer != null && isEnabled(JsonGenerator.Feature.AUTO_CLOSE_JSON_CONTENT)) {
      while (true) {
        JsonStreamContext ctxt = getOutputContext();
        if (ctxt.inArray()) {
          writeEndArray();
        } else if (ctxt.inObject()) {
          writeEndObject();
        } else {
          break;
        }
      }
    }
    _flushBuffer();

    /* 25-Nov-2008, tatus: As per [JACKSON-16] we are not to call close()
     *   on the underlying Reader, unless we "own" it, or auto-closing
     *   feature is enabled.
     *   One downside: when using UTF8Writer, underlying buffer(s)
     *   may not be properly recycled if we don't close the writer.
     */
    if (_writer != null) {
      if (_ioContext.isResourceManaged() || isEnabled(JsonGenerator.Feature.AUTO_CLOSE_TARGET)) {
        _writer.close();
      } else if (isEnabled(JsonGenerator.Feature.FLUSH_PASSED_TO_STREAM)) {
        // If we can't close it, we should at least flush
        _writer.flush();
      }
    }
    // Internal buffer(s) generator has can now be released as well
    _releaseBuffers();
  }