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

org.supercsv.cellprocessor.joda.ParseDateTimeZone Maven / Gradle / Ivy

Go to download

An extension for Super CSV that contains cell processors for Joda-Time classes

The newest version!
/*
 * Copyright 2007 Kasper B. Graversen
 * 
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *     http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.supercsv.cellprocessor.joda;

import org.joda.time.DateTimeZone;
import org.supercsv.cellprocessor.CellProcessorAdaptor;
import org.supercsv.cellprocessor.ift.CellProcessor;
import org.supercsv.exception.SuperCsvCellProcessorException;
import org.supercsv.util.CsvContext;

/**
 * Converts a String (the ID of the timezone, e.g. 'Australia/Brisbane') to a
 * Joda DateTimeZone.
 * 
 * @since 2.3.0
 * @author James Bassett
 */
public class ParseDateTimeZone extends CellProcessorAdaptor {

	/**
	 * Constructs a new ParseDateTimeZone processor, which parses a
	 * String as a Joda DateTimeZone.
	 */
	public ParseDateTimeZone() {
	}

	/**
	 * Constructs a new ParseDateTimeZone processor, which parses a
	 * String as a Joda DateTimeZone, then calls the next processor in the
	 * chain.
	 * 
	 * @param next
	 *            the next processor in the chain
	 */
	public ParseDateTimeZone(final CellProcessor next) {
		super(next);
	}

	/**
	 * {@inheritDoc}
	 * 
	 * @throws SuperCsvCellProcessorException
	 *             if value is null or is not a String
	 */
	public Object execute(final Object value, final CsvContext context) {
		validateInputNotNull(value, context);
		if (!(value instanceof String)) {
			throw new SuperCsvCellProcessorException(String.class, value,
					context, this);
		}
		final DateTimeZone result;
		try {
			result = DateTimeZone.forID((String) value);
		} catch (IllegalArgumentException e) {
			throw new SuperCsvCellProcessorException(
					"Failed to parse value as a DateTimeZone", context, this, e);
		}
		return next.execute(result, context);

	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy