All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.databene.model.consumer.TextFileExporter Maven / Gradle / Ivy

Go to download

benerator is a framework for creating realistic and valid high-volume test data, used for testing (unit/integration/load) and showcase setup. Metadata constraints are imported from systems and/or configuration files. Data can imported from and exported to files and systems, anonymized or generated from scratch. Domain packages provide reusable generators for creating domain-specific data as names and addresses internationalizable in language and region. It is strongly customizable with plugins and configuration options.

There is a newer version: 0.9.8
Show newest version
/*
 * (c) Copyright 2008-2009 by Volker Bergmann. All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, is permitted under the terms of the
 * GNU General Public License.
 *
 * For redistributing this software or a derivative work under a license other
 * than the GPL-compatible Free Software License as defined by the Free
 * Software Foundation or approved by OSI, you must first obtain a commercial
 * license to this software product from Volker Bergmann.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 * WITHOUT A WARRANTY OF ANY KIND. ALL EXPRESS OR IMPLIED CONDITIONS,
 * REPRESENTATIONS AND WARRANTIES, INCLUDING ANY IMPLIED WARRANTY OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE
 * HEREBY EXCLUDED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 */

package org.databene.model.consumer;

import java.io.IOException;
import java.io.PrintWriter;

import org.databene.commons.ConfigurationError;
import org.databene.commons.IOUtil;
import org.databene.commons.SystemInfo;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * Parent class for Exporters that export data to a text file.
*
* Created: 11.07.2008 09:50:46 * @since 0.5.4 * @author Volker Bergmann */ public class TextFileExporter extends FormattingConsumer implements FileExporter { private static final String DEFAULT_ENCODING = SystemInfo.getFileEncoding(); private static final String DEFAULT_LINE_SEPARATOR = SystemInfo.getLineSeparator(); private static final Logger LOG = LoggerFactory.getLogger(TextFileExporter.class); // attributes ------------------------------------------------------------------------------------------------------ protected String uri; protected String encoding; protected String lineSeparator; protected boolean append; protected PrintWriter printer; // constructors ---------------------------------------------------------------------------------------------------- public TextFileExporter() { this(null, null, null); } public TextFileExporter(String uri) { this(uri, null, null); } public TextFileExporter(String uri, String encoding, String lineSeparator) { this.uri = (uri != null ? uri : "export.txt"); this.encoding = (encoding != null ? encoding : DEFAULT_ENCODING); this.lineSeparator = (lineSeparator != null ? lineSeparator : DEFAULT_LINE_SEPARATOR); this.append = false; } // callback interface for child classes ---------------------------------------------------------------------------- /** * This method is called after printer initialization and before writing the first data entry. * Overwrite this method in child classes e.g. for writing a file header. * @param data the first data item to write to the file */ protected void postInitPrinter(E data) { // overwrite this in child classes, e.g. for writing a file header } /** * Writes the data to the output file. * It uses the parent class settings for rendering the object. * Overwrite this in a child class for custom output formats. * @param data the data object to output */ protected void startConsumingImpl(E data) { printer.print(plainConverter.convert(data)); printer.print(lineSeparator); } /** * This method is called after writing the last data entry and before closing the underlying printer. * Overwrite this method in child classes e.g. for writing a file footer. */ private void preClosePrinter() { // overwrite this in child classes, e.g. for writing a file footer } // properties ------------------------------------------------------------------------------------------------------ public String getUri() { return uri; } public void setUri(String uri) { this.uri = uri; } public String getEncoding() { return encoding; } public void setEncoding(String encoding) { this.encoding = encoding; } public String getLineSeparator() { return lineSeparator; } public void setLineSeparator(String lineSeparator) { this.lineSeparator = lineSeparator; } public boolean isAppend() { return append; } public void setAppend(boolean append) { this.append = append; } // Consumer interface ---------------------------------------------------------------------------------------------- public final synchronized void startConsuming(E data) { try { if (printer == null) initPrinter(data); startConsumingImpl(data); } catch (IOException e) { throw new RuntimeException(e); } } @Override public void flush() { if (printer != null) printer.flush(); } @Override public void close() { try { if (printer == null) { try { initPrinter(null); } catch (IOException e) { LOG.error("Error initializing empty file", e); } } preClosePrinter(); } finally { printer.close(); } } // private helpers ------------------------------------------------------------------------------------------------- protected void initPrinter(E data) throws IOException { if (uri == null) throw new ConfigurationError("Property 'uri' not set on bean " + getClass().getName()); printer = IOUtil.getPrinterForURI(uri, encoding, append, lineSeparator, true); postInitPrinter(data); } // java.lang.Object overrides -------------------------------------------------------------------------------------- @Override public String toString() { return getClass().getSimpleName() + "[" + uri + "]"; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy