src.com.ibm.as400.access.DateFieldDescription Maven / Gradle / Ivy
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (AS/400 Toolbox for Java - OSS version)
//
// Filename: DateFieldDescription.java
//
// The source code contained herein is licensed under the IBM Public License
// Version 1.0, which has been approved by the Open Source Initiative.
// Copyright (C) 1997-2000 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.access;
import java.io.Serializable;
import java.util.Vector;
//@B0A
import java.util.Date;
import java.util.HashSet;
import java.text.SimpleDateFormat;
/**
*Represents the description of the data in a date field.
*It allows:
*
*- The user to describe a date field to the RecordFormat object.
*
- The RecordFormat object to describe a date field to the user.
*
*Click hereto see an example.
**/
public class DateFieldDescription extends FieldDescription implements Serializable
{
static final long serialVersionUID = 4L;
static HashSet formatsWithFixedSeparators_;
// The date format for this field
private String dateFormat_ = null;
// The date separator for this field
private String dateSeparator_ = null;
/**
*Constructs a DateFieldDescription object.
**/
public DateFieldDescription()
{
}
/**
*Constructs a DateFieldDescription object. It uses the specified data type and name
*of the field.
*The length of the field will be the length specified on the AS400Text object.
*@param dataType Describes the field and provides
* the conversion capability for the contents of the field.
*@param name The name of the field.
**/
public DateFieldDescription(AS400Text dataType, String name)
{
super(dataType, name);
}
/**
*Constructs a DateFieldDescription object. It uses the specified data type, name, and
*DDS name of the field.
*@param dataType Describes the field and provides
* the conversion capability for the contents of the field.
*@param name The name of the field.
*@param ddsName The DDS name of this field. This is the
* name of the field as it would appear in a DDS description of the
* field. The length of ddsName must be 10 characters or less.
**/
public DateFieldDescription(AS400Text dataType, String name, String ddsName)
{
super(dataType, name, ddsName);
}
/**
*Constructs a DateFieldDescription object. It uses the specified data type and name
*of the field.
*The length of the field will be the length reported by the AS400Date object.
*@param dataType Describes the field and provides
* the conversion capability for the contents of the field.
*@param name The name of the field.
**/
public DateFieldDescription(AS400Date dataType, String name)
{
super(dataType, name);
}
/**
*Constructs a DateFieldDescription object. It uses the specified data type, name, and
*DDS name of the field.
*@param dataType Describes the field and provides
* the conversion capability for the contents of the field.
*@param name The name of the field.
*@param ddsName The DDS name of this field. This is the
* name of the field as it would appear in a DDS description of the
* field. The length of ddsName must be 10 characters or less.
**/
public DateFieldDescription(AS400Date dataType, String name, String ddsName)
{
super(dataType, name, ddsName);
}
/**
*Returns the value specified for the DATFMT keyword for this field.
*@return The value specified for DATFMT for
* this field. If DATFMT was not specified for this field,
* an empty string is returned.
**/
public String getDATFMT()
{
return (dateFormat_ == null ? "" : dateFormat_);
}
/**
*Returns the value specified for the DATSEP keyword for this field.
*@return The value specified for DATSEP for
* this field. If DATSEP was not specified for this field,
* an empty string is returned.
**/
public String getDATSEP()
{
return dateSeparator_ == null ? "" : dateSeparator_;
}
/**
*Returns the DDS description for the field. This is a string containing
*the description of the field as it would be specified in a DDS source file.
*This method is used by AS400File.createDDSSourceFile (called by the AS400File.create methods)
*to specify the field
*in the DDS source file which is used to create the file for the user who
*has passed in a RecordFormat object.
*@return The DDS description of this field properly formatted for entry
*into a DDS source file.
**/
String[] getDDSDescription()
{
Vector v = new Vector();
// Name columns (10)
StringBuffer desc = new StringBuffer(ddsName_);
// Blank pad the ddsName to 10 characters.
while(desc.length() < 10)
{
desc.append(" ");
}
// Reference column (1)
if (!refFld_.equals(""))
{
desc.append("R");
}
else
{
desc.append(" ");
}
// Get length as 5 digit string, right justified
// Length columns (5)
desc.append(" "); // No length can be specified for a date field
// Type column (1)
desc.append("L");
// Decimal positions columns (2)
desc.append(" ");
// Not used columns (7)
desc.append(" ");
// Add fixed portion of DDS description to Vector
v.addElement(desc.toString());
// Add the field level keywords
String[] keywords = super.getFieldFunctions();
if (keywords != null)
{
for (int i = 0; i < keywords.length; ++i)
{
v.addElement(keywords[i]);
}
}
if (dateFormat_ != null)
{
v.addElement("DATFMT(" + dateFormat_ + ") ");
}
if (dateSeparator_ != null)
{
if (!formatHasFixedSeparator(dateFormat_)) {
v.addElement("DATSEP('" + dateSeparator_ + "') ");
}
else {
if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "DDS date format " + dateFormat_ + " has a fixed separator.");
}
}
if (defaultValue_ != null)
{
v.addElement("DFT('" + defaultValue_.toString() + "') ");
}
//@B0A
else if (isDFTNull_)
{
v.addElement("DFT(*NULL) ");
}
String[] s = new String[v.size()];
v.copyInto(s);
return s;
}
static boolean formatHasFixedSeparator(String format)
{
// According to the DDS spec for DATSEP:
// "If you specify the *ISO, *USA, *EUR, or *JIS date format value on the DATFMT keyword, you cannot specify the DATSEP keyword. These formats have a fixed date separator."
// Similarly, according to the DDS spec for TIMTSEP:
// "If you specify *ISO, *USA, *EUR, or *JIS time format on the TIMFMT keyword, you cannot specify the TIMSEP keyword. These formats have a fixed separator."
if (getFormatsWithFixedSeparators().contains(format)) return true;
else return false;
}
private static HashSet getFormatsWithFixedSeparators()
{
if (formatsWithFixedSeparators_ == null)
{
synchronized (DateFieldDescription.class)
{
if (formatsWithFixedSeparators_ == null)
{
formatsWithFixedSeparators_ = new HashSet(6);
formatsWithFixedSeparators_.add("*ISO");
formatsWithFixedSeparators_.add("*USA");
formatsWithFixedSeparators_.add("*EUR");
formatsWithFixedSeparators_.add("*JIS");
}
}
}
return formatsWithFixedSeparators_;
}
/**
*Sets the AS400DataType object describing this field.
*@param dataType The AS400DataType that describes this field. The dataType
*cannot be null.
**/
public void setDataType(AS400Text dataType)
{
// Verify parameters
if (dataType == null)
{
throw new NullPointerException("dataType");
}
dataType_ = dataType;
// Set the length of the field based on the data type
length_ = dataType.getByteLength();
}
/**
*Sets the AS400DataType object describing this field.
*@param dataType The AS400DataType that describes this field. The dataType
*cannot be null.
**/
public void setDataType(AS400Date dataType)
{
// Verify parameters
if (dataType == null)
{
throw new NullPointerException("dataType");
}
dataType_ = dataType;
// Set the length of the field based on the data type
length_ = dataType.getByteLength();
}
/**
*Sets the value to specify for the DATFMT keyword for this field.
*@param dateFormat The value to specify for DATFMT for
* this field. The dateFormat cannot be null.
**/
public void setDATFMT(String dateFormat)
{
if (dateFormat == null) throw new NullPointerException("dateFormat");
if (dateFormat.startsWith("*")) {
dateFormat_ = dateFormat.toUpperCase();
}
else {
dateFormat_ = "*" + dateFormat.toUpperCase();
}
// Inform the AS400Date object of the format.
if (dataType_ instanceof AS400Date) {
((AS400Date)dataType_).setFormat(dateFormat);
}
}
/**
*Sets the value to specify for the DATSEP keyword for this field.
*@param separator The value to specify for DATSEP for this field.
*A null value indicates "no separator".
**/
public void setDATSEP(String separator)
{
// Inform the AS400Date object of the separator.
if (dataType_ instanceof AS400Date)
{
if (separator != null && separator.length() > 1) {
throw new ExtendedIllegalArgumentException("separator (" + separator + ")", ExtendedIllegalArgumentException.LENGTH_NOT_VALID);
}
Character sep = ( separator == null ? null : new Character(separator.charAt(0)));
((AS400Date)dataType_).setSeparator(sep);
}
dateSeparator_ = separator;
}
//@B0C - javadoc
/**
*Sets the value for the DFT keyword for this field.
*@param defaultValue The default value for this
* field. The defaultValuecannot be null.
*To set a default value of *NULL, use the setDFTNull() method.
**/
public void setDFT(String defaultValue)
{
if (defaultValue == null)
{
throw new NullPointerException("defaultValue");
}
defaultValue_ = defaultValue;
isDFTNull_ = false; //@B0A
isDFTCurrent_ = false; //@B0A
DFTCurrentValue_ = null; //@B0A
}
//@B0A
/**
*Sets the default value for this field to be the current date.
*Calling this method will replace the DFT keyword that was previously
*set on a call to setDFT(String) or setDFTNull().
**/
public void setDFTCurrent()
{
isDFTCurrent_ = true;
isDFTNull_ = false;
defaultValue_ = null;
DFTCurrentValue_ = (new SimpleDateFormat("yyyy-MM-dd")).format(new Date());
}
//@B0A
/**
*Sets the value for the DFT keyword to be *NULL for this field.
*Calling this method will replace the DFT keyword that was previously
*set on a call to setDFT(String) or setDFTCurrent(). Note: This field
*must also have its ALWNULL keyword set to true to prevent DDS errors.
**/
public void setDFTNull()
{
isDFTNull_ = true;
defaultValue_ = null;
isDFTCurrent_ = false;
DFTCurrentValue_ = null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy